From a1b72f0dc9b852c69f612406e685aeba13a18860 Mon Sep 17 00:00:00 2001 From: lior Date: Tue, 10 Feb 2015 18:28:16 +0200 Subject: [PATCH] app on --- README.md | 13 +- app/.htaccess | 19 + app/css/.gitkeep | 0 app/css/.product-thumb-list.css.swp | Bin 0 -> 12288 bytes app/css/ajax-loader.css | 26 + app/css/animate.css | 99 + app/css/app.css | 240 + app/css/bootstrap-theme.css | 393 + app/css/bootstrap.min.css | 9 + app/css/category-list.css | 39 + app/css/category-thumb-list.css | 121 + app/css/modal-ajax-loader.css | 23 + app/css/product-details.css | 52 + app/css/product-full-list.css | 95 + app/css/product-full.css | 38 + app/css/product-thumb-list.css | 117 + app/css/product-title.css | 28 + app/css/st-accordion.css | 7 + app/css/static-block.css | 25 + app/css/styles.css | 2917 +++ app/css/thumbnail-list.css | 121 + app/env/dev.js | 16 + app/favicon.ico | Bin 0 -> 33110 bytes app/fonts/glyphicons-halflings-regular.eot | Bin 0 -> 14079 bytes app/fonts/glyphicons-halflings-regular.svg | 228 + app/fonts/glyphicons-halflings-regular.ttf | Bin 0 -> 29512 bytes app/fonts/glyphicons-halflings-regular.woff | Bin 0 -> 16448 bytes app/img/.gitkeep | 0 app/img/ajax-loader.gif | Bin 0 -> 673 bytes app/img/arrow-down.png | Bin 0 -> 161 bytes app/img/back.png | Bin 0 -> 2629 bytes app/img/bg-black.png | Bin 0 -> 1074 bytes app/img/bg-hover.png | Bin 0 -> 960 bytes app/img/button-tray-down.png | Bin 0 -> 1506 bytes app/img/button-tray-up.png | Bin 0 -> 1466 bytes app/img/forward.png | Bin 0 -> 2614 bytes app/img/glyphicons-halflings-white.png | Bin 0 -> 8777 bytes app/img/glyphicons-halflings.png | Bin 0 -> 12799 bytes app/img/icon-instagram.png | Bin 0 -> 3362 bytes app/img/left-arrow.png | Bin 0 -> 1038 bytes app/img/maya-logo.gif | Bin 0 -> 1862 bytes app/img/maya-logo.jpg | Bin 0 -> 7705 bytes app/img/nav-bg.png | Bin 0 -> 995 bytes app/img/nav-dot.png | Bin 0 -> 1901 bytes app/img/pause.png | Bin 0 -> 1131 bytes app/img/play.png | Bin 0 -> 1562 bytes app/img/progress-back.png | Bin 0 -> 929 bytes app/img/progress-bar.png | Bin 0 -> 929 bytes app/img/progress.gif | Bin 0 -> 2608 bytes app/img/right-arrow.png | Bin 0 -> 1160 bytes app/img/shopping-bag-icon-big.png | Bin 0 -> 1320 bytes app/img/shopping-bag-icon.png | Bin 0 -> 4005 bytes app/img/st-cat-sprite.png | Bin 0 -> 2901 bytes app/img/thumb-back.png | Bin 0 -> 2122 bytes app/img/thumb-forward.png | Bin 0 -> 2118 bytes app/index-async.html | 58 + app/index.html | 82 + app/index.html02052014 | 80 + app/index.html13052014 | 80 + app/js/app.js | 11 + app/js/controllers/AccordionCtrl.js | 29 + app/js/controllers/AjaxLoaderCtrl.js | 7 + app/js/controllers/CMSPageController.js | 36 + app/js/controllers/CartIconController.js | 72 + app/js/controllers/CategoryListController.js | 77 + .../CategoryThumbListController.js | 317 + app/js/controllers/DynamicBlockController.js | 34 + .../controllers/GeneralThumbListController.js | 611 + app/js/controllers/HeaderController.js | 14 + app/js/controllers/MainController.js | 179 + app/js/controllers/ModalAjaxLoaderCtrl.js | 8 + app/js/controllers/ProductDetailsCtrl.js | 157 + app/js/controllers/ProductFullController.js | 118 + .../controllers/ProductFullListController.js | 404 + app/js/controllers/ProductOptionCtrl.js | 26 + .../controllers/ProductThumbListController.js | 122 + app/js/controllers/ProductTitleController.js | 202 + app/js/controllers/StaticBlockController.js | 38 + app/js/controllers/ThumbnailController.js | 802 + app/js/controllers/ThumbnailController1.js | 412 + app/js/controllers/ThumbnailController_old.js | 412 + app/js/directives.js | 307 + app/js/filters.js | 10 + app/js/jquery-2.0.3.min.js | 6 + app/js/models/CartModel.js | 48 + app/js/models/CategoryModel.js | 35 + app/js/models/ContentModel.js | 60 + app/js/models/ProductModel.js | 271 + app/js/module.js | 12 + app/js/routingstates.js | 77 + app/js/script.js | 62 + app/js/services/PageService.js | 13 + app/js/services/ProductsService.js | 680 + app/js/services/ProductsService_1.js | 74 + app/lib/angular/angular.js | 21605 ++++++++++++++++ app/lib/angular/angular.min.js | 209 + .../jquery.elevateZoom-3.0.8.min.js | 66 + app/lib/jquery/jquery-2.0.3.min.js | 6 + app/lib/jquery/jquery-2.1.0.min.js | 4 + app/lib/jquery/jquery-ui-1.10.3.custom.min.js | 6 + .../ui-bootstrap/ui-bootstrap-0.9.0.min.js | 2 + .../ui-bootstrap-tpls-0.6.0.min.js | 2 + .../ui-bootstrap-tpls-0.9.0.min.js | 2 + app/lib/ui-router/angular-ui-router.min.js | 7 + app/lib/ui-router/build/angular-ui-router.js | 1290 + .../ui-router/build/angular-ui-router.min.js | 7 + app/partials/.gitkeep | 0 app/partials/directives/ajax-loader.html | 4 + app/partials/directives/cart-icon.html | 7 + app/partials/directives/category-list.html | 13 + .../directives/category-thumb-list.html | 8 + app/partials/directives/cms-page.html | 1 + app/partials/directives/gen-thumb-list.html | 46 + .../directives/modal-ajax-loader.html | 4 + app/partials/directives/product-details.html | 38 + .../directives/product-full-list.html | 27 + app/partials/directives/product-full.html | 12 + app/partials/directives/product-option.html | 31 + .../directives/product-thumb-list.html | 8 + app/partials/directives/product-title.html | 7 + app/partials/directives/st-accordion.html | 8 + app/partials/directives/static-block.html | 2 + app/partials/directives/thumbnail-item.html | 12 + app/partials/directives/thumbnail-list.html | 26 + app/partials/layouts/category-thumb-list.html | 16 + app/partials/layouts/cms-page.html | 1 + app/partials/layouts/home.html | 12 + app/partials/layouts/product-details.html | 1 + app/snapshots/data.json | 1 + app/snapshots/sp__c=10.html | 1 + app/snapshots/sp__c=13.html | 1 + app/snapshots/sp__c=18.html | 1 + app/snapshots/sp__c=35.html | 1 + app/snapshots/sp_index.html | 1 + app/stats/stats.html | 648 + app/wstats.php | 24 + .../ExtendAPI/Model/Catalog/Category.php | 111 + .../Model/Catalog/Category/Rest/Guest/V1.php | 24 + .../Model/Catalog/Category/TopCatsProds.php | 10 + .../Category/Topcatsprods/Rest/Guest/V1.php | 14 + .../ExtendAPI/Model/Catalog/Product.php | 161 + .../Model/Catalog/Product/Options.php | 15 + .../Catalog/Product/Options/Rest/Guest/V1.php | 5 + .../Model/Catalog/Product/PrevNext.php | 158 + .../Product/Prevnext/Rest/Guest/V1.php | 37 + .../Catalog/Product/ProductAttributes.php | 37 + .../Model/Catalog/Product/ProductIds.php | 10 + .../Catalog/Product/ProductNextThumb.php | 84 + .../Model/Catalog/Product/ProductThumbs.php | 42 + .../Productattributes/Rest/Guest/V1.php | 23 + .../Product/Productids/Rest/Guest/V1.php | 33 + .../Productnextthumb/Rest/Guest/V1.php | 20 + .../Product/Productthumbs/Rest/Guest/V1.php | 19 + .../Model/Catalog/Product/Rest/Guest/V1.php | 18 + .../ExtendAPI/Model/Checkout/Cart/Product.php | 102 + .../Checkout/Cart/Product/Rest/Guest/V1.php | 10 + .../Maxxsol/ExtendAPI/Model/Cms/Block.php | 27 + .../Model/Cms/Block/Rest/Guest/V1.php | 15 + .../Maxxsol/ExtendAPI/Model/Page/Html.php | 26 + .../ExtendAPI/Model/Page/Html/Block.php | 14 + .../Model/Page/Html/Block/Rest/Guest/V1.php | 19 + .../Maxxsol/ExtendAPI/Model/Page/TopLinks.php | 34 + .../Model/Page/Toplinks/Rest/Guest/V1.php | 9 + .../Maxxsol/ExtendAPI/etc/api2.xml | 376 + .../Maxxsol/ExtendAPI/etc/config.xml | 15 + magento-modules/Maxxsol/MATax/Helper/Data.php | 10 + .../Maxxsol/MATax/Helper/Tax/Data.php | 10 + .../Maxxsol/MATax/Model/Tax/Calculation.php | 33 + .../Maxxsol/MATax/etc/config-sample.xml | 14 + magento-modules/Maxxsol/MATax/etc/config.xml | 30 + .../Model/Catalog/Product/Observer.php | 44 + .../Maxxsol/StoryPlugin/etc/config-sample.xml | 14 + .../Maxxsol/StoryPlugin/etc/config.xml | 42 + .../Maxxsol/StoryPlugin/etc/system.xml | 35 + .../StoryPlugin/scripts/new-product.sh | 0 magento-modules/Maxxsol_ExtendAPI.xml | 9 + magento-modules/Maxxsol_MATax.xml | 9 + magento-modules/Maxxsol_StoryPlugin.xml | 9 + magento-modules/Readme.txt | 7 + magento-modules/install-magento-modules.sh | 14 + 180 files changed, 36584 insertions(+), 1 deletion(-) create mode 100644 app/.htaccess create mode 100644 app/css/.gitkeep create mode 100644 app/css/.product-thumb-list.css.swp create mode 100644 app/css/ajax-loader.css create mode 100644 app/css/animate.css create mode 100644 app/css/app.css create mode 100644 app/css/bootstrap-theme.css create mode 100644 app/css/bootstrap.min.css create mode 100644 app/css/category-list.css create mode 100644 app/css/category-thumb-list.css create mode 100644 app/css/modal-ajax-loader.css create mode 100644 app/css/product-details.css create mode 100644 app/css/product-full-list.css create mode 100644 app/css/product-full.css create mode 100644 app/css/product-thumb-list.css create mode 100644 app/css/product-title.css create mode 100644 app/css/st-accordion.css create mode 100644 app/css/static-block.css create mode 100644 app/css/styles.css create mode 100644 app/css/thumbnail-list.css create mode 100644 app/env/dev.js create mode 100644 app/favicon.ico create mode 100644 app/fonts/glyphicons-halflings-regular.eot create mode 100644 app/fonts/glyphicons-halflings-regular.svg create mode 100644 app/fonts/glyphicons-halflings-regular.ttf create mode 100644 app/fonts/glyphicons-halflings-regular.woff create mode 100644 app/img/.gitkeep create mode 100644 app/img/ajax-loader.gif create mode 100644 app/img/arrow-down.png create mode 100644 app/img/back.png create mode 100644 app/img/bg-black.png create mode 100644 app/img/bg-hover.png create mode 100644 app/img/button-tray-down.png create mode 100644 app/img/button-tray-up.png create mode 100644 app/img/forward.png create mode 100644 app/img/glyphicons-halflings-white.png create mode 100644 app/img/glyphicons-halflings.png create mode 100644 app/img/icon-instagram.png create mode 100644 app/img/left-arrow.png create mode 100644 app/img/maya-logo.gif create mode 100644 app/img/maya-logo.jpg create mode 100644 app/img/nav-bg.png create mode 100644 app/img/nav-dot.png create mode 100644 app/img/pause.png create mode 100644 app/img/play.png create mode 100644 app/img/progress-back.png create mode 100644 app/img/progress-bar.png create mode 100644 app/img/progress.gif create mode 100644 app/img/right-arrow.png create mode 100644 app/img/shopping-bag-icon-big.png create mode 100644 app/img/shopping-bag-icon.png create mode 100644 app/img/st-cat-sprite.png create mode 100644 app/img/thumb-back.png create mode 100644 app/img/thumb-forward.png create mode 100644 app/index-async.html create mode 100644 app/index.html create mode 100644 app/index.html02052014 create mode 100644 app/index.html13052014 create mode 100644 app/js/app.js create mode 100644 app/js/controllers/AccordionCtrl.js create mode 100644 app/js/controllers/AjaxLoaderCtrl.js create mode 100644 app/js/controllers/CMSPageController.js create mode 100644 app/js/controllers/CartIconController.js create mode 100644 app/js/controllers/CategoryListController.js create mode 100644 app/js/controllers/CategoryThumbListController.js create mode 100644 app/js/controllers/DynamicBlockController.js create mode 100644 app/js/controllers/GeneralThumbListController.js create mode 100644 app/js/controllers/HeaderController.js create mode 100644 app/js/controllers/MainController.js create mode 100644 app/js/controllers/ModalAjaxLoaderCtrl.js create mode 100644 app/js/controllers/ProductDetailsCtrl.js create mode 100644 app/js/controllers/ProductFullController.js create mode 100644 app/js/controllers/ProductFullListController.js create mode 100644 app/js/controllers/ProductOptionCtrl.js create mode 100644 app/js/controllers/ProductThumbListController.js create mode 100644 app/js/controllers/ProductTitleController.js create mode 100644 app/js/controllers/StaticBlockController.js create mode 100644 app/js/controllers/ThumbnailController.js create mode 100644 app/js/controllers/ThumbnailController1.js create mode 100644 app/js/controllers/ThumbnailController_old.js create mode 100644 app/js/directives.js create mode 100644 app/js/filters.js create mode 100644 app/js/jquery-2.0.3.min.js create mode 100644 app/js/models/CartModel.js create mode 100644 app/js/models/CategoryModel.js create mode 100644 app/js/models/ContentModel.js create mode 100644 app/js/models/ProductModel.js create mode 100644 app/js/module.js create mode 100644 app/js/routingstates.js create mode 100644 app/js/script.js create mode 100644 app/js/services/PageService.js create mode 100644 app/js/services/ProductsService.js create mode 100644 app/js/services/ProductsService_1.js create mode 100644 app/lib/angular/angular.js create mode 100644 app/lib/angular/angular.min.js create mode 100644 app/lib/jquery/elevateZoom/jquery.elevateZoom-3.0.8.min.js create mode 100644 app/lib/jquery/jquery-2.0.3.min.js create mode 100644 app/lib/jquery/jquery-2.1.0.min.js create mode 100644 app/lib/jquery/jquery-ui-1.10.3.custom.min.js create mode 100644 app/lib/ui-bootstrap/ui-bootstrap-0.9.0.min.js create mode 100644 app/lib/ui-bootstrap/ui-bootstrap-tpls-0.6.0.min.js create mode 100644 app/lib/ui-bootstrap/ui-bootstrap-tpls-0.9.0.min.js create mode 100644 app/lib/ui-router/angular-ui-router.min.js create mode 100644 app/lib/ui-router/build/angular-ui-router.js create mode 100644 app/lib/ui-router/build/angular-ui-router.min.js create mode 100644 app/partials/.gitkeep create mode 100644 app/partials/directives/ajax-loader.html create mode 100644 app/partials/directives/cart-icon.html create mode 100644 app/partials/directives/category-list.html create mode 100644 app/partials/directives/category-thumb-list.html create mode 100644 app/partials/directives/cms-page.html create mode 100644 app/partials/directives/gen-thumb-list.html create mode 100644 app/partials/directives/modal-ajax-loader.html create mode 100644 app/partials/directives/product-details.html create mode 100644 app/partials/directives/product-full-list.html create mode 100644 app/partials/directives/product-full.html create mode 100644 app/partials/directives/product-option.html create mode 100644 app/partials/directives/product-thumb-list.html create mode 100644 app/partials/directives/product-title.html create mode 100644 app/partials/directives/st-accordion.html create mode 100644 app/partials/directives/static-block.html create mode 100644 app/partials/directives/thumbnail-item.html create mode 100644 app/partials/directives/thumbnail-list.html create mode 100644 app/partials/layouts/category-thumb-list.html create mode 100644 app/partials/layouts/cms-page.html create mode 100644 app/partials/layouts/home.html create mode 100644 app/partials/layouts/product-details.html create mode 100644 app/snapshots/data.json create mode 100644 app/snapshots/sp__c=10.html create mode 100644 app/snapshots/sp__c=13.html create mode 100644 app/snapshots/sp__c=18.html create mode 100644 app/snapshots/sp__c=35.html create mode 100644 app/snapshots/sp_index.html create mode 100644 app/stats/stats.html create mode 100644 app/wstats.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Category.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Category/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Category/TopCatsProds.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Category/Topcatsprods/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Options.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Options/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/PrevNext.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Prevnext/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/ProductAttributes.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/ProductIds.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/ProductNextThumb.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/ProductThumbs.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Productattributes/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Productids/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Productnextthumb/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Productthumbs/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Catalog/Product/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Checkout/Cart/Product.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Checkout/Cart/Product/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Cms/Block.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Cms/Block/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Page/Html.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Page/Html/Block.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Page/Html/Block/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Page/TopLinks.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/Model/Page/Toplinks/Rest/Guest/V1.php create mode 100644 magento-modules/Maxxsol/ExtendAPI/etc/api2.xml create mode 100644 magento-modules/Maxxsol/ExtendAPI/etc/config.xml create mode 100644 magento-modules/Maxxsol/MATax/Helper/Data.php create mode 100644 magento-modules/Maxxsol/MATax/Helper/Tax/Data.php create mode 100644 magento-modules/Maxxsol/MATax/Model/Tax/Calculation.php create mode 100644 magento-modules/Maxxsol/MATax/etc/config-sample.xml create mode 100644 magento-modules/Maxxsol/MATax/etc/config.xml create mode 100644 magento-modules/Maxxsol/StoryPlugin/Model/Catalog/Product/Observer.php create mode 100644 magento-modules/Maxxsol/StoryPlugin/etc/config-sample.xml create mode 100644 magento-modules/Maxxsol/StoryPlugin/etc/config.xml create mode 100644 magento-modules/Maxxsol/StoryPlugin/etc/system.xml create mode 100644 magento-modules/Maxxsol/StoryPlugin/scripts/new-product.sh create mode 100644 magento-modules/Maxxsol_ExtendAPI.xml create mode 100644 magento-modules/Maxxsol_MATax.xml create mode 100644 magento-modules/Maxxsol_StoryPlugin.xml create mode 100644 magento-modules/Readme.txt create mode 100644 magento-modules/install-magento-modules.sh diff --git a/README.md b/README.md index 8968938..8a7b57f 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,13 @@ # Storee -An AngularJS layer above magento. With full-screen images and product pages +Storee is a project that builds a responsive AngularJs layer and runs it above a Magento back-end. It communicates with Magento using RESTful APIs and provides a full-screen catalog, as well as individual product pages. It integrates with Magento for the shopping cart. Back-end is all Magento. + +## Features + +- Specialized directives for full-screen design +- Product page directives +- Grunt builds for dev and production environment +- Jasmine unit tests +- Server-side rendering using PhantomJS +- Infrastructure for client-side product caching +- Magento RESTful APIs + diff --git a/app/.htaccess b/app/.htaccess new file mode 100644 index 0000000..71e7d58 --- /dev/null +++ b/app/.htaccess @@ -0,0 +1,19 @@ + +ModPagespeed off + + + +RewriteEngine On +RewriteCond %{HTTP_HOST} !^www\. +RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L] + + + + + + ExpiresActive On + ExpiresDefault A1 + Header append Cache-Control must-revalidate + + + \ No newline at end of file diff --git a/app/css/.gitkeep b/app/css/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/app/css/.product-thumb-list.css.swp b/app/css/.product-thumb-list.css.swp new file mode 100644 index 0000000000000000000000000000000000000000..c2b165cddfc97409bd0030c46a947d502b0f8e63 GIT binary patch literal 12288 zcmeI2O^g&p6vqn<0)U98B~EUcC8rkqbu+H}8JLs2tQ7P5k%A^bE7Z%EyVMI{9r+*HpcF z^?$Ek?Pj}PdHUcyow26~t}TRoc>IN@J{jLi&OS+ql2Rwl|97?6GHY?6SjTo{>*~GB z9j40NZnx~~R#5hMr_7?L?8b39QqpU?+R}czRks2WYa7j1w`9IC3K#{hOM$j-SbH`d znVzavl5rE`57N809l0(Orn6DNC}0#Y3K#{90!9I&fKk9GaBC}|qc!AZEaA3%8SVVO zX6T+jnwwF;C}0#Y3K#{90!9I&fKk9GU=%P47zK<1x1a*dBjmodgsfW!=kfpl-rxWK zZYJbYunZQ!6JQ=pfHANEtOsks<+}*^1^f(t0vEyO;A3zGybd&Y9vlNl!82eA+yib0 zmp2je8~7Dm0O!H`;5Exa2D}0^sDu6BA@Bg$1pZ!6$Y0=3@CP^#J^*LHdtezjU=r*EJHSQ6>;m`%*VP+E#doN4OvP;<4H*s)&BUu;`UUu>gx$U2MZ zPn>p2%jE5p#t`Tg9$rEk4g&t5z!8vzD&#wC~Wqt5=&Z;0;aT zOa5{lT(IiR(yGo4_b!}GY&q8;Ptxzk)JeT9<}1VzVIV?2LQ}_=9j-EEld&roHrS)k zepviaCf1XPpR`2i@g;{=tCg%Jnb}$y09OW5Idr1YXk`5~U(%MxU8$HBGIWpg5mhyZEmAOoAibM_rQ*kVn-pja3;q-xpo!c{Vs z4QA54l39Ff3b*Vh8 zD-(A_8e`X`yDeU1ZsIk?ek~HJ5lDs|o@7d9t;JMRAXW&)s0}o1tZ(SX)V=vtCCkZD z`euEp4GUaUn`@T%3T<;Kr%^j8P508E+H_TUDeEW9WH}w2nX~emJXMtBygdn_L;KBx zbEV_UlLKZDV9MHBj!f7h$bCg+sI3NTi2y}-`~VL+Tnm@cL%hw$OT}|(RtXlAV(cj^ z=1L3}0v3oS@~WR{X?f7S{fFZuinwxFoNudMIhmWCo0-cC!{F&NQK{suR|rt8B}dh& z+dvB)a2iJ}EY_DF9{tm#x5sGJUNN_oyH*cy7+%v{msDw2GDRN-Xj9+e@Q56KR#?kOSps?#M}bEbDY(=~c{9(HJAhlS`E@sMhtQ_WjA z-!;lm_RKw@rLxI_q^{4xCVKcH?sr4E li > a:hover, +.dropdown-menu > li > a:focus, +.dropdown-menu > .active > a, +.dropdown-menu > .active > a:hover, +.dropdown-menu > .active > a:focus { + background-color: #357ebd; + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#428bca), to(#357ebd)); + background-image: -webkit-linear-gradient(top, #428bca, 0%, #357ebd, 100%); + background-image: -moz-linear-gradient(top, #428bca 0%, #357ebd 100%); + background-image: linear-gradient(to bottom, #428bca 0%, #357ebd 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff357ebd', GradientType=0); +} + +.navbar { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#ffffff), to(#f8f8f8)); + background-image: -webkit-linear-gradient(top, #ffffff, 0%, #f8f8f8, 100%); + background-image: -moz-linear-gradient(top, #ffffff 0%, #f8f8f8 100%); + background-image: linear-gradient(to bottom, #ffffff 0%, #f8f8f8 100%); + background-repeat: repeat-x; + border-radius: 4px; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#fff8f8f8', GradientType=0); + -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 5px rgba(0, 0, 0, 0.075); + box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 5px rgba(0, 0, 0, 0.075); +} + +.navbar .navbar-nav > .active > a { + background-color: #f8f8f8; +} + +.navbar-brand, +.navbar-nav > li > a { + text-shadow: 0 1px 0 rgba(255, 255, 255, 0.25); +} + +.navbar-inverse { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#3c3c3c), to(#222222)); + background-image: -webkit-linear-gradient(top, #3c3c3c, 0%, #222222, 100%); + background-image: -moz-linear-gradient(top, #3c3c3c 0%, #222222 100%); + background-image: linear-gradient(to bottom, #3c3c3c 0%, #222222 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff3c3c3c', endColorstr='#ff222222', GradientType=0); +} + +.navbar-inverse .navbar-nav > .active > a { + background-color: #222222; +} + +.navbar-inverse .navbar-brand, +.navbar-inverse .navbar-nav > li > a { + text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); +} + +.navbar-static-top, +.navbar-fixed-top, +.navbar-fixed-bottom { + border-radius: 0; +} + +.alert { + text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2); + -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05); + box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05); +} + +.alert-success { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#dff0d8), to(#c8e5bc)); + background-image: -webkit-linear-gradient(top, #dff0d8, 0%, #c8e5bc, 100%); + background-image: -moz-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%); + background-image: linear-gradient(to bottom, #dff0d8 0%, #c8e5bc 100%); + background-repeat: repeat-x; + border-color: #b2dba1; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffc8e5bc', GradientType=0); +} + +.alert-info { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#d9edf7), to(#b9def0)); + background-image: -webkit-linear-gradient(top, #d9edf7, 0%, #b9def0, 100%); + background-image: -moz-linear-gradient(top, #d9edf7 0%, #b9def0 100%); + background-image: linear-gradient(to bottom, #d9edf7 0%, #b9def0 100%); + background-repeat: repeat-x; + border-color: #9acfea; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffb9def0', GradientType=0); +} + +.alert-warning { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#fcf8e3), to(#f8efc0)); + background-image: -webkit-linear-gradient(top, #fcf8e3, 0%, #f8efc0, 100%); + background-image: -moz-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%); + background-image: linear-gradient(to bottom, #fcf8e3 0%, #f8efc0 100%); + background-repeat: repeat-x; + border-color: #f5e79e; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fff8efc0', GradientType=0); +} + +.alert-danger { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#f2dede), to(#e7c3c3)); + background-image: -webkit-linear-gradient(top, #f2dede, 0%, #e7c3c3, 100%); + background-image: -moz-linear-gradient(top, #f2dede 0%, #e7c3c3 100%); + background-image: linear-gradient(to bottom, #f2dede 0%, #e7c3c3 100%); + background-repeat: repeat-x; + border-color: #dca7a7; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffe7c3c3', GradientType=0); +} + +.progress { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#ebebeb), to(#f5f5f5)); + background-image: -webkit-linear-gradient(top, #ebebeb, 0%, #f5f5f5, 100%); + background-image: -moz-linear-gradient(top, #ebebeb 0%, #f5f5f5 100%); + background-image: linear-gradient(to bottom, #ebebeb 0%, #f5f5f5 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffebebeb', endColorstr='#fff5f5f5', GradientType=0); +} + +.progress-bar { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#428bca), to(#3071a9)); + background-image: -webkit-linear-gradient(top, #428bca, 0%, #3071a9, 100%); + background-image: -moz-linear-gradient(top, #428bca 0%, #3071a9 100%); + background-image: linear-gradient(to bottom, #428bca 0%, #3071a9 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff3071a9', GradientType=0); +} + +.progress-bar-success { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#5cb85c), to(#449d44)); + background-image: -webkit-linear-gradient(top, #5cb85c, 0%, #449d44, 100%); + background-image: -moz-linear-gradient(top, #5cb85c 0%, #449d44 100%); + background-image: linear-gradient(to bottom, #5cb85c 0%, #449d44 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5cb85c', endColorstr='#ff449d44', GradientType=0); +} + +.progress-bar-info { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#5bc0de), to(#31b0d5)); + background-image: -webkit-linear-gradient(top, #5bc0de, 0%, #31b0d5, 100%); + background-image: -moz-linear-gradient(top, #5bc0de 0%, #31b0d5 100%); + background-image: linear-gradient(to bottom, #5bc0de 0%, #31b0d5 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de', endColorstr='#ff31b0d5', GradientType=0); +} + +.progress-bar-warning { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#f0ad4e), to(#ec971f)); + background-image: -webkit-linear-gradient(top, #f0ad4e, 0%, #ec971f, 100%); + background-image: -moz-linear-gradient(top, #f0ad4e 0%, #ec971f 100%); + background-image: linear-gradient(to bottom, #f0ad4e 0%, #ec971f 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff0ad4e', endColorstr='#ffec971f', GradientType=0); +} + +.progress-bar-danger { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#d9534f), to(#c9302c)); + background-image: -webkit-linear-gradient(top, #d9534f, 0%, #c9302c, 100%); + background-image: -moz-linear-gradient(top, #d9534f 0%, #c9302c 100%); + background-image: linear-gradient(to bottom, #d9534f 0%, #c9302c 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9534f', endColorstr='#ffc9302c', GradientType=0); +} + +.list-group { + border-radius: 4px; + -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); + box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); +} + +.list-group-item.active, +.list-group-item.active:hover, +.list-group-item.active:focus { + text-shadow: 0 -1px 0 #3071a9; + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#428bca), to(#3278b3)); + background-image: -webkit-linear-gradient(top, #428bca, 0%, #3278b3, 100%); + background-image: -moz-linear-gradient(top, #428bca 0%, #3278b3 100%); + background-image: linear-gradient(to bottom, #428bca 0%, #3278b3 100%); + background-repeat: repeat-x; + border-color: #3278b3; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff3278b3', GradientType=0); +} + +.panel { + -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); + box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); +} + +.panel-default > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#f5f5f5), to(#e8e8e8)); + background-image: -webkit-linear-gradient(top, #f5f5f5, 0%, #e8e8e8, 100%); + background-image: -moz-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%); + background-image: linear-gradient(to bottom, #f5f5f5 0%, #e8e8e8 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5', endColorstr='#ffe8e8e8', GradientType=0); +} + +.panel-primary > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#428bca), to(#357ebd)); + background-image: -webkit-linear-gradient(top, #428bca, 0%, #357ebd, 100%); + background-image: -moz-linear-gradient(top, #428bca 0%, #357ebd 100%); + background-image: linear-gradient(to bottom, #428bca 0%, #357ebd 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff357ebd', GradientType=0); +} + +.panel-success > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#dff0d8), to(#d0e9c6)); + background-image: -webkit-linear-gradient(top, #dff0d8, 0%, #d0e9c6, 100%); + background-image: -moz-linear-gradient(top, #dff0d8 0%, #d0e9c6 100%); + background-image: linear-gradient(to bottom, #dff0d8 0%, #d0e9c6 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffd0e9c6', GradientType=0); +} + +.panel-info > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#d9edf7), to(#c4e3f3)); + background-image: -webkit-linear-gradient(top, #d9edf7, 0%, #c4e3f3, 100%); + background-image: -moz-linear-gradient(top, #d9edf7 0%, #c4e3f3 100%); + background-image: linear-gradient(to bottom, #d9edf7 0%, #c4e3f3 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffc4e3f3', GradientType=0); +} + +.panel-warning > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#fcf8e3), to(#faf2cc)); + background-image: -webkit-linear-gradient(top, #fcf8e3, 0%, #faf2cc, 100%); + background-image: -moz-linear-gradient(top, #fcf8e3 0%, #faf2cc 100%); + background-image: linear-gradient(to bottom, #fcf8e3 0%, #faf2cc 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fffaf2cc', GradientType=0); +} + +.panel-danger > .panel-heading { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#f2dede), to(#ebcccc)); + background-image: -webkit-linear-gradient(top, #f2dede, 0%, #ebcccc, 100%); + background-image: -moz-linear-gradient(top, #f2dede 0%, #ebcccc 100%); + background-image: linear-gradient(to bottom, #f2dede 0%, #ebcccc 100%); + background-repeat: repeat-x; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffebcccc', GradientType=0); +} + +.well { + background-image: -webkit-gradient(linear, left 0%, left 100%, from(#e8e8e8), to(#f5f5f5)); + background-image: -webkit-linear-gradient(top, #e8e8e8, 0%, #f5f5f5, 100%); + background-image: -moz-linear-gradient(top, #e8e8e8 0%, #f5f5f5 100%); + background-image: linear-gradient(to bottom, #e8e8e8 0%, #f5f5f5 100%); + background-repeat: repeat-x; + border-color: #dcdcdc; + filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffe8e8e8', endColorstr='#fff5f5f5', GradientType=0); + -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 0 rgba(255, 255, 255, 0.1); + box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 0 rgba(255, 255, 255, 0.1); +} \ No newline at end of file diff --git a/app/css/bootstrap.min.css b/app/css/bootstrap.min.css new file mode 100644 index 0000000..a553c4f --- /dev/null +++ b/app/css/bootstrap.min.css @@ -0,0 +1,9 @@ +/*! + * Bootstrap v3.0.0 + * + * Copyright 2013 Twitter, Inc + * Licensed under the Apache License v2.0 + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Designed and built with all the love in the world by @mdo and @fat. + *//*! normalize.css v2.1.0 | MIT License | git.io/normalize */article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}[hidden]{display:none}html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}a:focus{outline:thin dotted}a:active,a:hover{outline:0}h1{margin:.67em 0;font-size:2em}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:bold}dfn{font-style:italic}hr{height:0;-moz-box-sizing:content-box;box-sizing:content-box}mark{color:#000;background:#ff0}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:0}fieldset{padding:.35em .625em .75em;margin:0 2px;border:1px solid #c0c0c0}legend{padding:0;border:0}button,input,select,textarea{margin:0;font-family:inherit;font-size:100%}button,input{line-height:normal}button,select{text-transform:none}button,html input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button}button[disabled],html input[disabled]{cursor:default}input[type="checkbox"],input[type="radio"]{padding:0;box-sizing:border-box}input[type="search"]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@media print{*{color:#000!important;text-shadow:none!important;background:transparent!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100%!important}@page{margin:2cm .5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.table td,.table th{background-color:#fff!important}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table-bordered th,.table-bordered td{border:1px solid #ddd!important}}*,*:before,*:after{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:62.5%;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.428571429;color:#333;background-color:#fff}input,button,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button,input,select[multiple],textarea{background-image:none}a{color:#428bca;text-decoration:none}a:hover,a:focus{color:#2a6496;text-decoration:underline}a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}img{vertical-align:middle}.img-responsive{display:block;height:auto;max-width:100%}.img-rounded{border-radius:6px}.img-thumbnail{display:inline-block;height:auto;max-width:100%;padding:4px;line-height:1.428571429;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16.099999999999998px;font-weight:200;line-height:1.4}@media(min-width:768px){.lead{font-size:21px}}small{font-size:85%}cite{font-style:normal}.text-muted{color:#999}.text-primary{color:#428bca}.text-warning{color:#c09853}.text-danger{color:#b94a48}.text-success{color:#468847}.text-info{color:#3a87ad}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-weight:500;line-height:1.1}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small,.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small{font-weight:normal;line-height:1;color:#999}h1,h2,h3{margin-top:20px;margin-bottom:10px}h4,h5,h6{margin-top:10px;margin-bottom:10px}h1,.h1{font-size:36px}h2,.h2{font-size:30px}h3,.h3{font-size:24px}h4,.h4{font-size:18px}h5,.h5{font-size:14px}h6,.h6{font-size:12px}h1 small,.h1 small{font-size:24px}h2 small,.h2 small{font-size:18px}h3 small,.h3 small,h4 small,.h4 small{font-size:14px}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ul,ol{margin-top:0;margin-bottom:10px}ul ul,ol ul,ul ol,ol ol{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-bottom:20px}dt,dd{line-height:1.428571429}dt{font-weight:bold}dd{margin-left:0}@media(min-width:768px){.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}.dl-horizontal dd:before,.dl-horizontal dd:after{display:table;content:" "}.dl-horizontal dd:after{clear:both}.dl-horizontal dd:before,.dl-horizontal dd:after{display:table;content:" "}.dl-horizontal dd:after{clear:both}}abbr[title],abbr[data-original-title]{cursor:help;border-bottom:1px dotted #999}abbr.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;border-left:5px solid #eee}blockquote p{font-size:17.5px;font-weight:300;line-height:1.25}blockquote p:last-child{margin-bottom:0}blockquote small{display:block;line-height:1.428571429;color:#999}blockquote small:before{content:'\2014 \00A0'}blockquote.pull-right{padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0}blockquote.pull-right p,blockquote.pull-right small{text-align:right}blockquote.pull-right small:before{content:''}blockquote.pull-right small:after{content:'\00A0 \2014'}q:before,q:after,blockquote:before,blockquote:after{content:""}address{display:block;margin-bottom:20px;font-style:normal;line-height:1.428571429}code,pre{font-family:Monaco,Menlo,Consolas,"Courier New",monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;white-space:nowrap;background-color:#f9f2f4;border-radius:4px}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.428571429;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre.prettyprint{margin-bottom:20px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.container:before,.container:after{display:table;content:" "}.container:after{clear:both}.container:before,.container:after{display:table;content:" "}.container:after{clear:both}.row{margin-right:-15px;margin-left:-15px}.row:before,.row:after{display:table;content:" "}.row:after{clear:both}.row:before,.row:after{display:table;content:" "}.row:after{clear:both}.col-xs-1,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.col-xs-10,.col-xs-11,.col-xs-12,.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11,.col-sm-12,.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11,.col-md-12,.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11,.col-lg-12{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.col-xs-10,.col-xs-11{float:left}.col-xs-1{width:8.333333333333332%}.col-xs-2{width:16.666666666666664%}.col-xs-3{width:25%}.col-xs-4{width:33.33333333333333%}.col-xs-5{width:41.66666666666667%}.col-xs-6{width:50%}.col-xs-7{width:58.333333333333336%}.col-xs-8{width:66.66666666666666%}.col-xs-9{width:75%}.col-xs-10{width:83.33333333333334%}.col-xs-11{width:91.66666666666666%}.col-xs-12{width:100%}@media(min-width:768px){.container{max-width:750px}.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11{float:left}.col-sm-1{width:8.333333333333332%}.col-sm-2{width:16.666666666666664%}.col-sm-3{width:25%}.col-sm-4{width:33.33333333333333%}.col-sm-5{width:41.66666666666667%}.col-sm-6{width:50%}.col-sm-7{width:58.333333333333336%}.col-sm-8{width:66.66666666666666%}.col-sm-9{width:75%}.col-sm-10{width:83.33333333333334%}.col-sm-11{width:91.66666666666666%}.col-sm-12{width:100%}.col-sm-push-1{left:8.333333333333332%}.col-sm-push-2{left:16.666666666666664%}.col-sm-push-3{left:25%}.col-sm-push-4{left:33.33333333333333%}.col-sm-push-5{left:41.66666666666667%}.col-sm-push-6{left:50%}.col-sm-push-7{left:58.333333333333336%}.col-sm-push-8{left:66.66666666666666%}.col-sm-push-9{left:75%}.col-sm-push-10{left:83.33333333333334%}.col-sm-push-11{left:91.66666666666666%}.col-sm-pull-1{right:8.333333333333332%}.col-sm-pull-2{right:16.666666666666664%}.col-sm-pull-3{right:25%}.col-sm-pull-4{right:33.33333333333333%}.col-sm-pull-5{right:41.66666666666667%}.col-sm-pull-6{right:50%}.col-sm-pull-7{right:58.333333333333336%}.col-sm-pull-8{right:66.66666666666666%}.col-sm-pull-9{right:75%}.col-sm-pull-10{right:83.33333333333334%}.col-sm-pull-11{right:91.66666666666666%}.col-sm-offset-1{margin-left:8.333333333333332%}.col-sm-offset-2{margin-left:16.666666666666664%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-4{margin-left:33.33333333333333%}.col-sm-offset-5{margin-left:41.66666666666667%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-7{margin-left:58.333333333333336%}.col-sm-offset-8{margin-left:66.66666666666666%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-10{margin-left:83.33333333333334%}.col-sm-offset-11{margin-left:91.66666666666666%}}@media(min-width:992px){.container{max-width:970px}.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11{float:left}.col-md-1{width:8.333333333333332%}.col-md-2{width:16.666666666666664%}.col-md-3{width:25%}.col-md-4{width:33.33333333333333%}.col-md-5{width:41.66666666666667%}.col-md-6{width:50%}.col-md-7{width:58.333333333333336%}.col-md-8{width:66.66666666666666%}.col-md-9{width:75%}.col-md-10{width:83.33333333333334%}.col-md-11{width:91.66666666666666%}.col-md-12{width:100%}.col-md-push-0{left:auto}.col-md-push-1{left:8.333333333333332%}.col-md-push-2{left:16.666666666666664%}.col-md-push-3{left:25%}.col-md-push-4{left:33.33333333333333%}.col-md-push-5{left:41.66666666666667%}.col-md-push-6{left:50%}.col-md-push-7{left:58.333333333333336%}.col-md-push-8{left:66.66666666666666%}.col-md-push-9{left:75%}.col-md-push-10{left:83.33333333333334%}.col-md-push-11{left:91.66666666666666%}.col-md-pull-0{right:auto}.col-md-pull-1{right:8.333333333333332%}.col-md-pull-2{right:16.666666666666664%}.col-md-pull-3{right:25%}.col-md-pull-4{right:33.33333333333333%}.col-md-pull-5{right:41.66666666666667%}.col-md-pull-6{right:50%}.col-md-pull-7{right:58.333333333333336%}.col-md-pull-8{right:66.66666666666666%}.col-md-pull-9{right:75%}.col-md-pull-10{right:83.33333333333334%}.col-md-pull-11{right:91.66666666666666%}.col-md-offset-0{margin-left:0}.col-md-offset-1{margin-left:8.333333333333332%}.col-md-offset-2{margin-left:16.666666666666664%}.col-md-offset-3{margin-left:25%}.col-md-offset-4{margin-left:33.33333333333333%}.col-md-offset-5{margin-left:41.66666666666667%}.col-md-offset-6{margin-left:50%}.col-md-offset-7{margin-left:58.333333333333336%}.col-md-offset-8{margin-left:66.66666666666666%}.col-md-offset-9{margin-left:75%}.col-md-offset-10{margin-left:83.33333333333334%}.col-md-offset-11{margin-left:91.66666666666666%}}@media(min-width:1200px){.container{max-width:1170px}.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11{float:left}.col-lg-1{width:8.333333333333332%}.col-lg-2{width:16.666666666666664%}.col-lg-3{width:25%}.col-lg-4{width:33.33333333333333%}.col-lg-5{width:41.66666666666667%}.col-lg-6{width:50%}.col-lg-7{width:58.333333333333336%}.col-lg-8{width:66.66666666666666%}.col-lg-9{width:75%}.col-lg-10{width:83.33333333333334%}.col-lg-11{width:91.66666666666666%}.col-lg-12{width:100%}.col-lg-push-0{left:auto}.col-lg-push-1{left:8.333333333333332%}.col-lg-push-2{left:16.666666666666664%}.col-lg-push-3{left:25%}.col-lg-push-4{left:33.33333333333333%}.col-lg-push-5{left:41.66666666666667%}.col-lg-push-6{left:50%}.col-lg-push-7{left:58.333333333333336%}.col-lg-push-8{left:66.66666666666666%}.col-lg-push-9{left:75%}.col-lg-push-10{left:83.33333333333334%}.col-lg-push-11{left:91.66666666666666%}.col-lg-pull-0{right:auto}.col-lg-pull-1{right:8.333333333333332%}.col-lg-pull-2{right:16.666666666666664%}.col-lg-pull-3{right:25%}.col-lg-pull-4{right:33.33333333333333%}.col-lg-pull-5{right:41.66666666666667%}.col-lg-pull-6{right:50%}.col-lg-pull-7{right:58.333333333333336%}.col-lg-pull-8{right:66.66666666666666%}.col-lg-pull-9{right:75%}.col-lg-pull-10{right:83.33333333333334%}.col-lg-pull-11{right:91.66666666666666%}.col-lg-offset-0{margin-left:0}.col-lg-offset-1{margin-left:8.333333333333332%}.col-lg-offset-2{margin-left:16.666666666666664%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-4{margin-left:33.33333333333333%}.col-lg-offset-5{margin-left:41.66666666666667%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-7{margin-left:58.333333333333336%}.col-lg-offset-8{margin-left:66.66666666666666%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-10{margin-left:83.33333333333334%}.col-lg-offset-11{margin-left:91.66666666666666%}}table{max-width:100%;background-color:transparent}th{text-align:left}.table{width:100%;margin-bottom:20px}.table thead>tr>th,.table tbody>tr>th,.table tfoot>tr>th,.table thead>tr>td,.table tbody>tr>td,.table tfoot>tr>td{padding:8px;line-height:1.428571429;vertical-align:top;border-top:1px solid #ddd}.table thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table caption+thead tr:first-child th,.table colgroup+thead tr:first-child th,.table thead:first-child tr:first-child th,.table caption+thead tr:first-child td,.table colgroup+thead tr:first-child td,.table thead:first-child tr:first-child td{border-top:0}.table tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed thead>tr>th,.table-condensed tbody>tr>th,.table-condensed tfoot>tr>th,.table-condensed thead>tr>td,.table-condensed tbody>tr>td,.table-condensed tfoot>tr>td{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>thead>tr>th,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>tbody>tr>td,.table-bordered>tfoot>tr>td{border:1px solid #ddd}.table-bordered>thead>tr>th,.table-bordered>thead>tr>td{border-bottom-width:2px}.table-striped>tbody>tr:nth-child(odd)>td,.table-striped>tbody>tr:nth-child(odd)>th{background-color:#f9f9f9}.table-hover>tbody>tr:hover>td,.table-hover>tbody>tr:hover>th{background-color:#f5f5f5}table col[class*="col-"]{display:table-column;float:none}table td[class*="col-"],table th[class*="col-"]{display:table-cell;float:none}.table>thead>tr>td.active,.table>tbody>tr>td.active,.table>tfoot>tr>td.active,.table>thead>tr>th.active,.table>tbody>tr>th.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>tbody>tr.active>td,.table>tfoot>tr.active>td,.table>thead>tr.active>th,.table>tbody>tr.active>th,.table>tfoot>tr.active>th{background-color:#f5f5f5}.table>thead>tr>td.success,.table>tbody>tr>td.success,.table>tfoot>tr>td.success,.table>thead>tr>th.success,.table>tbody>tr>th.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>tbody>tr.success>td,.table>tfoot>tr.success>td,.table>thead>tr.success>th,.table>tbody>tr.success>th,.table>tfoot>tr.success>th{background-color:#dff0d8;border-color:#d6e9c6}.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover,.table-hover>tbody>tr.success:hover>td{background-color:#d0e9c6;border-color:#c9e2b3}.table>thead>tr>td.danger,.table>tbody>tr>td.danger,.table>tfoot>tr>td.danger,.table>thead>tr>th.danger,.table>tbody>tr>th.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>tbody>tr.danger>td,.table>tfoot>tr.danger>td,.table>thead>tr.danger>th,.table>tbody>tr.danger>th,.table>tfoot>tr.danger>th{background-color:#f2dede;border-color:#eed3d7}.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover,.table-hover>tbody>tr.danger:hover>td{background-color:#ebcccc;border-color:#e6c1c7}.table>thead>tr>td.warning,.table>tbody>tr>td.warning,.table>tfoot>tr>td.warning,.table>thead>tr>th.warning,.table>tbody>tr>th.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>tbody>tr.warning>td,.table>tfoot>tr.warning>td,.table>thead>tr.warning>th,.table>tbody>tr.warning>th,.table>tfoot>tr.warning>th{background-color:#fcf8e3;border-color:#fbeed5}.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover,.table-hover>tbody>tr.warning:hover>td{background-color:#faf2cc;border-color:#f8e5be}@media(max-width:768px){.table-responsive{width:100%;margin-bottom:15px;overflow-x:scroll;overflow-y:hidden;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0;background-color:#fff}.table-responsive>.table>thead>tr>th,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tfoot>tr>td{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>thead>tr>th:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child{border-left:0}.table-responsive>.table-bordered>thead>tr>th:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child{border-right:0}.table-responsive>.table-bordered>thead>tr:last-child>th,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>th,.table-responsive>.table-bordered>thead>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>td{border-bottom:0}}fieldset{padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;margin-bottom:5px;font-weight:bold}input[type="search"]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type="radio"],input[type="checkbox"]{margin:4px 0 0;margin-top:1px \9;line-height:normal}input[type="file"]{display:block}select[multiple],select[size]{height:auto}select optgroup{font-family:inherit;font-size:inherit;font-style:inherit}input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}input[type="number"]::-webkit-outer-spin-button,input[type="number"]::-webkit-inner-spin-button{height:auto}.form-control:-moz-placeholder{color:#999}.form-control::-moz-placeholder{color:#999}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.428571429;color:#555;vertical-align:middle;background-color:#fff;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(102,175,233,0.6);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(102,175,233,0.6)}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{cursor:not-allowed;background-color:#eee}textarea.form-control{height:auto}.form-group{margin-bottom:15px}.radio,.checkbox{display:block;min-height:20px;padding-left:20px;margin-top:10px;margin-bottom:10px;vertical-align:middle}.radio label,.checkbox label{display:inline;margin-bottom:0;font-weight:normal;cursor:pointer}.radio input[type="radio"],.radio-inline input[type="radio"],.checkbox input[type="checkbox"],.checkbox-inline input[type="checkbox"]{float:left;margin-left:-20px}.radio+.radio,.checkbox+.checkbox{margin-top:-5px}.radio-inline,.checkbox-inline{display:inline-block;padding-left:20px;margin-bottom:0;font-weight:normal;vertical-align:middle;cursor:pointer}.radio-inline+.radio-inline,.checkbox-inline+.checkbox-inline{margin-top:0;margin-left:10px}input[type="radio"][disabled],input[type="checkbox"][disabled],.radio[disabled],.radio-inline[disabled],.checkbox[disabled],.checkbox-inline[disabled],fieldset[disabled] input[type="radio"],fieldset[disabled] input[type="checkbox"],fieldset[disabled] .radio,fieldset[disabled] .radio-inline,fieldset[disabled] .checkbox,fieldset[disabled] .checkbox-inline{cursor:not-allowed}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}textarea.input-sm{height:auto}.input-lg{height:45px;padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}select.input-lg{height:45px;line-height:45px}textarea.input-lg{height:auto}.has-warning .help-block,.has-warning .control-label{color:#c09853}.has-warning .form-control{border-color:#c09853;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-warning .form-control:focus{border-color:#a47e3c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #dbc59e}.has-warning .input-group-addon{color:#c09853;background-color:#fcf8e3;border-color:#c09853}.has-error .help-block,.has-error .control-label{color:#b94a48}.has-error .form-control{border-color:#b94a48;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-error .form-control:focus{border-color:#953b39;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #d59392}.has-error .input-group-addon{color:#b94a48;background-color:#f2dede;border-color:#b94a48}.has-success .help-block,.has-success .control-label{color:#468847}.has-success .form-control{border-color:#468847;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075)}.has-success .form-control:focus{border-color:#356635;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b;box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 6px #7aba7b}.has-success .input-group-addon{color:#468847;background-color:#dff0d8;border-color:#468847}.form-control-static{padding-top:7px;margin-bottom:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media(min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block}.form-inline .radio,.form-inline .checkbox{display:inline-block;padding-left:0;margin-top:0;margin-bottom:0}.form-inline .radio input[type="radio"],.form-inline .checkbox input[type="checkbox"]{float:none;margin-left:0}}.form-horizontal .control-label,.form-horizontal .radio,.form-horizontal .checkbox,.form-horizontal .radio-inline,.form-horizontal .checkbox-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}.form-horizontal .form-group:before,.form-horizontal .form-group:after{display:table;content:" "}.form-horizontal .form-group:after{clear:both}.form-horizontal .form-group:before,.form-horizontal .form-group:after{display:table;content:" "}.form-horizontal .form-group:after{clear:both}@media(min-width:768px){.form-horizontal .control-label{text-align:right}}.btn{display:inline-block;padding:6px 12px;margin-bottom:0;font-size:14px;font-weight:normal;line-height:1.428571429;text-align:center;white-space:nowrap;vertical-align:middle;cursor:pointer;border:1px solid transparent;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn:hover,.btn:focus{color:#333;text-decoration:none}.btn:active,.btn.active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,0.125);box-shadow:inset 0 3px 5px rgba(0,0,0,0.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{pointer-events:none;cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default:hover,.btn-default:focus,.btn-default:active,.btn-default.active,.open .dropdown-toggle.btn-default{color:#333;background-color:#ebebeb;border-color:#adadad}.btn-default:active,.btn-default.active,.open .dropdown-toggle.btn-default{background-image:none}.btn-default.disabled,.btn-default[disabled],fieldset[disabled] .btn-default,.btn-default.disabled:hover,.btn-default[disabled]:hover,fieldset[disabled] .btn-default:hover,.btn-default.disabled:focus,.btn-default[disabled]:focus,fieldset[disabled] .btn-default:focus,.btn-default.disabled:active,.btn-default[disabled]:active,fieldset[disabled] .btn-default:active,.btn-default.disabled.active,.btn-default[disabled].active,fieldset[disabled] .btn-default.active{background-color:#fff;border-color:#ccc}.btn-primary{color:#fff;background-color:#428bca;border-color:#357ebd}.btn-primary:hover,.btn-primary:focus,.btn-primary:active,.btn-primary.active,.open .dropdown-toggle.btn-primary{color:#fff;background-color:#3276b1;border-color:#285e8e}.btn-primary:active,.btn-primary.active,.open .dropdown-toggle.btn-primary{background-image:none}.btn-primary.disabled,.btn-primary[disabled],fieldset[disabled] .btn-primary,.btn-primary.disabled:hover,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary:hover,.btn-primary.disabled:focus,.btn-primary[disabled]:focus,fieldset[disabled] .btn-primary:focus,.btn-primary.disabled:active,.btn-primary[disabled]:active,fieldset[disabled] .btn-primary:active,.btn-primary.disabled.active,.btn-primary[disabled].active,fieldset[disabled] .btn-primary.active{background-color:#428bca;border-color:#357ebd}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning:hover,.btn-warning:focus,.btn-warning:active,.btn-warning.active,.open .dropdown-toggle.btn-warning{color:#fff;background-color:#ed9c28;border-color:#d58512}.btn-warning:active,.btn-warning.active,.open .dropdown-toggle.btn-warning{background-image:none}.btn-warning.disabled,.btn-warning[disabled],fieldset[disabled] .btn-warning,.btn-warning.disabled:hover,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning:hover,.btn-warning.disabled:focus,.btn-warning[disabled]:focus,fieldset[disabled] .btn-warning:focus,.btn-warning.disabled:active,.btn-warning[disabled]:active,fieldset[disabled] .btn-warning:active,.btn-warning.disabled.active,.btn-warning[disabled].active,fieldset[disabled] .btn-warning.active{background-color:#f0ad4e;border-color:#eea236}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger:hover,.btn-danger:focus,.btn-danger:active,.btn-danger.active,.open .dropdown-toggle.btn-danger{color:#fff;background-color:#d2322d;border-color:#ac2925}.btn-danger:active,.btn-danger.active,.open .dropdown-toggle.btn-danger{background-image:none}.btn-danger.disabled,.btn-danger[disabled],fieldset[disabled] .btn-danger,.btn-danger.disabled:hover,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger:hover,.btn-danger.disabled:focus,.btn-danger[disabled]:focus,fieldset[disabled] .btn-danger:focus,.btn-danger.disabled:active,.btn-danger[disabled]:active,fieldset[disabled] .btn-danger:active,.btn-danger.disabled.active,.btn-danger[disabled].active,fieldset[disabled] .btn-danger.active{background-color:#d9534f;border-color:#d43f3a}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success:hover,.btn-success:focus,.btn-success:active,.btn-success.active,.open .dropdown-toggle.btn-success{color:#fff;background-color:#47a447;border-color:#398439}.btn-success:active,.btn-success.active,.open .dropdown-toggle.btn-success{background-image:none}.btn-success.disabled,.btn-success[disabled],fieldset[disabled] .btn-success,.btn-success.disabled:hover,.btn-success[disabled]:hover,fieldset[disabled] .btn-success:hover,.btn-success.disabled:focus,.btn-success[disabled]:focus,fieldset[disabled] .btn-success:focus,.btn-success.disabled:active,.btn-success[disabled]:active,fieldset[disabled] .btn-success:active,.btn-success.disabled.active,.btn-success[disabled].active,fieldset[disabled] .btn-success.active{background-color:#5cb85c;border-color:#4cae4c}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info:hover,.btn-info:focus,.btn-info:active,.btn-info.active,.open .dropdown-toggle.btn-info{color:#fff;background-color:#39b3d7;border-color:#269abc}.btn-info:active,.btn-info.active,.open .dropdown-toggle.btn-info{background-image:none}.btn-info.disabled,.btn-info[disabled],fieldset[disabled] .btn-info,.btn-info.disabled:hover,.btn-info[disabled]:hover,fieldset[disabled] .btn-info:hover,.btn-info.disabled:focus,.btn-info[disabled]:focus,fieldset[disabled] .btn-info:focus,.btn-info.disabled:active,.btn-info[disabled]:active,fieldset[disabled] .btn-info:active,.btn-info.disabled.active,.btn-info[disabled].active,fieldset[disabled] .btn-info.active{background-color:#5bc0de;border-color:#46b8da}.btn-link{font-weight:normal;color:#428bca;cursor:pointer;border-radius:0}.btn-link,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:hover,.btn-link:focus,.btn-link:active{border-color:transparent}.btn-link:hover,.btn-link:focus{color:#2a6496;text-decoration:underline;background-color:transparent}.btn-link[disabled]:hover,fieldset[disabled] .btn-link:hover,.btn-link[disabled]:focus,fieldset[disabled] .btn-link:focus{color:#999;text-decoration:none}.btn-lg{padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}.btn-sm,.btn-xs{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-xs{padding:1px 5px}.btn-block{display:block;width:100%;padding-right:0;padding-left:0}.btn-block+.btn-block{margin-top:5px}input[type="submit"].btn-block,input[type="reset"].btn-block,input[type="button"].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition:height .35s ease;transition:height .35s ease}@font-face{font-family:'Glyphicons Halflings';src:url('../fonts/glyphicons-halflings-regular.eot');src:url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'),url('../fonts/glyphicons-halflings-regular.woff') format('woff'),url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'),url('../fonts/glyphicons-halflings-regular.svg#glyphicons-halflingsregular') format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';-webkit-font-smoothing:antialiased;font-style:normal;font-weight:normal;line-height:1}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-print:before{content:"\e045"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-briefcase:before{content:"\1f4bc"}.glyphicon-calendar:before{content:"\1f4c5"}.glyphicon-pushpin:before{content:"\1f4cc"}.glyphicon-paperclip:before{content:"\1f4ce"}.glyphicon-camera:before{content:"\1f4f7"}.glyphicon-lock:before{content:"\1f512"}.glyphicon-bell:before{content:"\1f514"}.glyphicon-bookmark:before{content:"\1f516"}.glyphicon-fire:before{content:"\1f525"}.glyphicon-wrench:before{content:"\1f527"}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px solid #000;border-right:4px solid transparent;border-bottom:0 dotted;border-left:4px solid transparent;content:""}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;list-style:none;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,0.175);box-shadow:0 6px 12px rgba(0,0,0,0.175);background-clip:padding-box}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:normal;line-height:1.428571429;color:#333;white-space:nowrap}.dropdown-menu>li>a:hover,.dropdown-menu>li>a:focus{color:#fff;text-decoration:none;background-color:#428bca}.dropdown-menu>.active>a,.dropdown-menu>.active>a:hover,.dropdown-menu>.active>a:focus{color:#fff;text-decoration:none;background-color:#428bca;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{color:#999}.dropdown-menu>.disabled>a:hover,.dropdown-menu>.disabled>a:focus{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.428571429;color:#999}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}@media(min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}}.btn-default .caret{border-top-color:#333}.btn-primary .caret,.btn-success .caret,.btn-warning .caret,.btn-danger .caret,.btn-info .caret{border-top-color:#fff}.dropup .btn-default .caret{border-bottom-color:#333}.dropup .btn-primary .caret,.dropup .btn-success .caret,.dropup .btn-warning .caret,.dropup .btn-danger .caret,.dropup .btn-info .caret{border-bottom-color:#fff}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group>.btn,.btn-group-vertical>.btn{position:relative;float:left}.btn-group>.btn:hover,.btn-group-vertical>.btn:hover,.btn-group>.btn:focus,.btn-group-vertical>.btn:focus,.btn-group>.btn:active,.btn-group-vertical>.btn:active,.btn-group>.btn.active,.btn-group-vertical>.btn.active{z-index:2}.btn-group>.btn:focus,.btn-group-vertical>.btn:focus{outline:0}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar:before,.btn-toolbar:after{display:table;content:" "}.btn-toolbar:after{clear:both}.btn-toolbar:before,.btn-toolbar:after{display:table;content:" "}.btn-toolbar:after{clear:both}.btn-toolbar .btn-group{float:left}.btn-toolbar>.btn+.btn,.btn-toolbar>.btn-group+.btn,.btn-toolbar>.btn+.btn-group,.btn-toolbar>.btn-group+.btn-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child>.btn:last-child,.btn-group>.btn-group:first-child>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child>.btn:first-child{border-bottom-left-radius:0;border-top-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group-xs>.btn{padding:5px 10px;padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-sm>.btn{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-lg>.btn{padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,0.125);box-shadow:inset 0 3px 5px rgba(0,0,0,0.125)}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group:before,.btn-group-vertical>.btn-group:after{display:table;content:" "}.btn-group-vertical>.btn-group:after{clear:both}.btn-group-vertical>.btn-group:before,.btn-group-vertical>.btn-group:after{display:table;content:" "}.btn-group-vertical>.btn-group:after{clear:both}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-right-radius:0;border-bottom-left-radius:4px;border-top-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child>.btn:last-child,.btn-group-vertical>.btn-group:first-child>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child>.btn:first-child{border-top-right-radius:0;border-top-left-radius:0}.btn-group-justified{display:table;width:100%;border-collapse:separate;table-layout:fixed}.btn-group-justified .btn{display:table-cell;float:none;width:1%}[data-toggle="buttons"]>.btn>input[type="radio"],[data-toggle="buttons"]>.btn>input[type="checkbox"]{display:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group.col{float:none;padding-right:0;padding-left:0}.input-group .form-control{width:100%;margin-bottom:0}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:45px;padding:10px 16px;font-size:18px;line-height:1.33;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:45px;line-height:45px}textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group-addon,.input-group-btn,.input-group .form-control{display:table-cell}.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child),.input-group .form-control:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:normal;line-height:1;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type="radio"],.input-group-addon input[type="checkbox"]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:last-child>.btn,.input-group-btn:last-child>.dropdown-toggle,.input-group-btn:first-child>.btn:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-4px}.input-group-btn>.btn:hover,.input-group-btn>.btn:active{z-index:2}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav:before,.nav:after{display:table;content:" "}.nav:after{clear:both}.nav:before,.nav:after{display:table;content:" "}.nav:after{clear:both}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:hover,.nav>li>a:focus{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#999}.nav>li.disabled>a:hover,.nav>li.disabled>a:focus{color:#999;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:hover,.nav .open>a:focus{background-color:#eee;border-color:#428bca}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.428571429;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:hover,.nav-tabs>li.active>a:focus{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{text-align:center}@media(min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}}.nav-tabs.nav-justified>li>a{margin-right:0;border-bottom:1px solid #ddd}.nav-tabs.nav-justified>.active>a{border-bottom-color:#fff}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:5px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:hover,.nav-pills>li.active>a:focus{color:#fff;background-color:#428bca}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{text-align:center}@media(min-width:768px){.nav-justified>li{display:table-cell;width:1%}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-bottom:1px solid #ddd}.nav-tabs-justified>.active>a{border-bottom-color:#fff}.tabbable:before,.tabbable:after{display:table;content:" "}.tabbable:after{clear:both}.tabbable:before,.tabbable:after{display:table;content:" "}.tabbable:after{clear:both}.tab-content>.tab-pane,.pill-content>.pill-pane{display:none}.tab-content>.active,.pill-content>.active{display:block}.nav .caret{border-top-color:#428bca;border-bottom-color:#428bca}.nav a:hover .caret{border-top-color:#2a6496;border-bottom-color:#2a6496}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-right-radius:0;border-top-left-radius:0}.navbar{position:relative;z-index:1000;min-height:50px;margin-bottom:20px;border:1px solid transparent}.navbar:before,.navbar:after{display:table;content:" "}.navbar:after{clear:both}.navbar:before,.navbar:after{display:table;content:" "}.navbar:after{clear:both}@media(min-width:768px){.navbar{border-radius:4px}}.navbar-header:before,.navbar-header:after{display:table;content:" "}.navbar-header:after{clear:both}.navbar-header:before,.navbar-header:after{display:table;content:" "}.navbar-header:after{clear:both}@media(min-width:768px){.navbar-header{float:left}}.navbar-collapse{max-height:340px;padding-right:15px;padding-left:15px;overflow-x:visible;border-top:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,0.1);-webkit-overflow-scrolling:touch}.navbar-collapse:before,.navbar-collapse:after{display:table;content:" "}.navbar-collapse:after{clear:both}.navbar-collapse:before,.navbar-collapse:after{display:table;content:" "}.navbar-collapse:after{clear:both}.navbar-collapse.in{overflow-y:auto}@media(min-width:768px){.navbar-collapse{width:auto;border-top:0;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-collapse .navbar-nav.navbar-left:first-child{margin-left:-15px}.navbar-collapse .navbar-nav.navbar-right:last-child{margin-right:-15px}.navbar-collapse .navbar-text:last-child{margin-right:0}}.container>.navbar-header,.container>.navbar-collapse{margin-right:-15px;margin-left:-15px}@media(min-width:768px){.container>.navbar-header,.container>.navbar-collapse{margin-right:0;margin-left:0}}.navbar-static-top{border-width:0 0 1px}@media(min-width:768px){.navbar-static-top{border-radius:0}}.navbar-fixed-top,.navbar-fixed-bottom{position:fixed;right:0;left:0;border-width:0 0 1px}@media(min-width:768px){.navbar-fixed-top,.navbar-fixed-bottom{border-radius:0}}.navbar-fixed-top{top:0;z-index:1030}.navbar-fixed-bottom{bottom:0;margin-bottom:0}.navbar-brand{float:left;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:hover,.navbar-brand:focus{text-decoration:none}@media(min-width:768px){.navbar>.container .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-top:8px;margin-right:15px;margin-bottom:8px;background-color:transparent;border:1px solid transparent;border-radius:4px}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media(min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media(max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;box-shadow:none}.navbar-nav .open .dropdown-menu>li>a,.navbar-nav .open .dropdown-menu .dropdown-header{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:hover,.navbar-nav .open .dropdown-menu>li>a:focus{background-image:none}}@media(min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}@media(min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important}}.navbar-form{padding:10px 15px;margin-top:8px;margin-right:-15px;margin-bottom:8px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.1)}@media(min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block}.navbar-form .radio,.navbar-form .checkbox{display:inline-block;padding-left:0;margin-top:0;margin-bottom:0}.navbar-form .radio input[type="radio"],.navbar-form .checkbox input[type="checkbox"]{float:none;margin-left:0}}@media(max-width:767px){.navbar-form .form-group{margin-bottom:5px}}@media(min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-right-radius:0;border-top-left-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-nav.pull-right>li>.dropdown-menu,.navbar-nav>li>.dropdown-menu.pull-right{right:0;left:auto}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-text{float:left;margin-top:15px;margin-bottom:15px}@media(min-width:768px){.navbar-text{margin-right:15px;margin-left:15px}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:hover,.navbar-default .navbar-brand:focus{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:hover,.navbar-default .navbar-nav>li>a:focus{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:hover,.navbar-default .navbar-nav>.active>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:hover,.navbar-default .navbar-nav>.disabled>a:focus{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:hover,.navbar-default .navbar-toggle:focus{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#ccc}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e6e6e6}.navbar-default .navbar-nav>.dropdown>a:hover .caret,.navbar-default .navbar-nav>.dropdown>a:focus .caret{border-top-color:#333;border-bottom-color:#333}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:hover,.navbar-default .navbar-nav>.open>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.open>a .caret,.navbar-default .navbar-nav>.open>a:hover .caret,.navbar-default .navbar-nav>.open>a:focus .caret{border-top-color:#555;border-bottom-color:#555}.navbar-default .navbar-nav>.dropdown>a .caret{border-top-color:#777;border-bottom-color:#777}@media(max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#999}.navbar-inverse .navbar-brand:hover,.navbar-inverse .navbar-brand:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#999}.navbar-inverse .navbar-nav>li>a{color:#999}.navbar-inverse .navbar-nav>li>a:hover,.navbar-inverse .navbar-nav>li>a:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:hover,.navbar-inverse .navbar-nav>.active>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:hover,.navbar-inverse .navbar-nav>.disabled>a:focus{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:hover,.navbar-inverse .navbar-toggle:focus{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:hover,.navbar-inverse .navbar-nav>.open>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.dropdown>a:hover .caret{border-top-color:#fff;border-bottom-color:#fff}.navbar-inverse .navbar-nav>.dropdown>a .caret{border-top-color:#999;border-bottom-color:#999}.navbar-inverse .navbar-nav>.open>a .caret,.navbar-inverse .navbar-nav>.open>a:hover .caret,.navbar-inverse .navbar-nav>.open>a:focus .caret{border-top-color:#fff;border-bottom-color:#fff}@media(max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#999}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#999}.navbar-inverse .navbar-link:hover{color:#fff}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#999}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.428571429;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-bottom-left-radius:4px;border-top-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>li>a:hover,.pagination>li>span:hover,.pagination>li>a:focus,.pagination>li>span:focus{background-color:#eee}.pagination>.active>a,.pagination>.active>span,.pagination>.active>a:hover,.pagination>.active>span:hover,.pagination>.active>a:focus,.pagination>.active>span:focus{z-index:2;color:#fff;cursor:default;background-color:#428bca;border-color:#428bca}.pagination>.disabled>span,.pagination>.disabled>a,.pagination>.disabled>a:hover,.pagination>.disabled>a:focus{color:#999;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-bottom-left-radius:6px;border-top-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-bottom-left-radius:3px;border-top-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager:before,.pager:after{display:table;content:" "}.pager:after{clear:both}.pager:before,.pager:after{display:table;content:" "}.pager:after{clear:both}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:hover,.pager li>a:focus{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:hover,.pager .disabled>a:focus,.pager .disabled>span{color:#999;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:bold;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}.label[href]:hover,.label[href]:focus{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.label-default{background-color:#999}.label-default[href]:hover,.label-default[href]:focus{background-color:#808080}.label-primary{background-color:#428bca}.label-primary[href]:hover,.label-primary[href]:focus{background-color:#3071a9}.label-success{background-color:#5cb85c}.label-success[href]:hover,.label-success[href]:focus{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:hover,.label-info[href]:focus{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:hover,.label-warning[href]:focus{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:hover,.label-danger[href]:focus{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:bold;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;background-color:#999;border-radius:10px}.badge:empty{display:none}a.badge:hover,a.badge:focus{color:#fff;text-decoration:none;cursor:pointer}.btn .badge{position:relative;top:-1px}a.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#428bca;background-color:#fff}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding:30px;margin-bottom:30px;font-size:21px;font-weight:200;line-height:2.1428571435;color:inherit;background-color:#eee}.jumbotron h1{line-height:1;color:inherit}.jumbotron p{line-height:1.4}.container .jumbotron{border-radius:6px}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron{padding-right:60px;padding-left:60px}.jumbotron h1{font-size:63px}}.thumbnail{display:inline-block;display:block;height:auto;max-width:100%;padding:4px;line-height:1.428571429;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.thumbnail>img{display:block;height:auto;max-width:100%}a.thumbnail:hover,a.thumbnail:focus{border-color:#428bca}.thumbnail>img{margin-right:auto;margin-left:auto}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:bold}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable{padding-right:35px}.alert-dismissable .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#356635}.alert-info{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#2d6987}.alert-warning{color:#c09853;background-color:#fcf8e3;border-color:#fbeed5}.alert-warning hr{border-top-color:#f8e5be}.alert-warning .alert-link{color:#a47e3c}.alert-danger{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.alert-danger hr{border-top-color:#e6c1c7}.alert-danger .alert-link{color:#953b39}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-moz-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:0 0}to{background-position:40px 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;color:#fff;text-align:center;background-color:#428bca;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-webkit-transition:width .6s ease;transition:width .6s ease}.progress-striped .progress-bar{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-size:40px 40px}.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;-ms-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.media,.media-body{overflow:hidden;zoom:1}.media,.media .media{margin-top:15px}.media:first-child{margin-top:0}.media-object{display:block}.media-heading{margin:0 0 5px}.media>.pull-left{margin-right:10px}.media>.pull-right{margin-left:10px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-right-radius:4px;border-top-left-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}a.list-group-item{color:#555}a.list-group-item .list-group-item-heading{color:#333}a.list-group-item:hover,a.list-group-item:focus{text-decoration:none;background-color:#f5f5f5}.list-group-item.active,.list-group-item.active:hover,.list-group-item.active:focus{z-index:2;color:#fff;background-color:#428bca;border-color:#428bca}.list-group-item.active .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:hover .list-group-item-text,.list-group-item.active:focus .list-group-item-text{color:#e1edf7}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,0.05);box-shadow:0 1px 1px rgba(0,0,0,0.05)}.panel-body{padding:15px}.panel-body:before,.panel-body:after{display:table;content:" "}.panel-body:after{clear:both}.panel-body:before,.panel-body:after{display:table;content:" "}.panel-body:after{clear:both}.panel>.list-group{margin-bottom:0}.panel>.list-group .list-group-item{border-width:1px 0}.panel>.list-group .list-group-item:first-child{border-top-right-radius:0;border-top-left-radius:0}.panel>.list-group .list-group-item:last-child{border-bottom:0}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.panel>.table{margin-bottom:0}.panel>.panel-body+.table{border-top:1px solid #ddd}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-right-radius:3px;border-top-left-radius:3px}.panel-title{margin-top:0;margin-bottom:0;font-size:16px}.panel-title>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel-group .panel{margin-bottom:0;overflow:hidden;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse .panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse .panel-body{border-top-color:#ddd}.panel-default>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#428bca}.panel-primary>.panel-heading{color:#fff;background-color:#428bca;border-color:#428bca}.panel-primary>.panel-heading+.panel-collapse .panel-body{border-top-color:#428bca}.panel-primary>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#428bca}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse .panel-body{border-top-color:#d6e9c6}.panel-success>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#d6e9c6}.panel-warning{border-color:#fbeed5}.panel-warning>.panel-heading{color:#c09853;background-color:#fcf8e3;border-color:#fbeed5}.panel-warning>.panel-heading+.panel-collapse .panel-body{border-top-color:#fbeed5}.panel-warning>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#fbeed5}.panel-danger{border-color:#eed3d7}.panel-danger>.panel-heading{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.panel-danger>.panel-heading+.panel-collapse .panel-body{border-top-color:#eed3d7}.panel-danger>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#eed3d7}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse .panel-body{border-top-color:#bce8f1}.panel-info>.panel-footer+.panel-collapse .panel-body{border-bottom-color:#bce8f1}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);box-shadow:inset 0 1px 1px rgba(0,0,0,0.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,0.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:bold;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.close:hover,.close:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.5;filter:alpha(opacity=50)}button.close{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}body.modal-open,.modal-open .navbar-fixed-top,.modal-open .navbar-fixed-bottom{margin-right:15px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;display:none;overflow:auto;overflow-y:scroll}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;-moz-transition:-moz-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.modal-dialog{z-index:1050;width:auto;padding:10px;margin-right:auto;margin-left:auto}.modal-content{position:relative;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,0.2);border-radius:6px;outline:0;-webkit-box-shadow:0 3px 9px rgba(0,0,0,0.5);box-shadow:0 3px 9px rgba(0,0,0,0.5);background-clip:padding-box}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1030;background-color:#000}.modal-backdrop.fade{opacity:0;filter:alpha(opacity=0)}.modal-backdrop.in{opacity:.5;filter:alpha(opacity=50)}.modal-header{min-height:16.428571429px;padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.428571429}.modal-body{position:relative;padding:20px}.modal-footer{padding:19px 20px 20px;margin-top:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer:before,.modal-footer:after{display:table;content:" "}.modal-footer:after{clear:both}.modal-footer:before,.modal-footer:after{display:table;content:" "}.modal-footer:after{clear:both}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}@media screen and (min-width:768px){.modal-dialog{right:auto;left:50%;width:600px;padding-top:30px;padding-bottom:30px}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,0.5);box-shadow:0 5px 15px rgba(0,0,0,0.5)}}.tooltip{position:absolute;z-index:1030;display:block;font-size:12px;line-height:1.4;opacity:0;filter:alpha(opacity=0);visibility:visible}.tooltip.in{opacity:.9;filter:alpha(opacity=90)}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-top-color:#000;border-width:5px 5px 0}.tooltip.top-left .tooltip-arrow{bottom:0;left:5px;border-top-color:#000;border-width:5px 5px 0}.tooltip.top-right .tooltip-arrow{right:5px;bottom:0;border-top-color:#000;border-width:5px 5px 0}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-right-color:#000;border-width:5px 5px 5px 0}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-left-color:#000;border-width:5px 0 5px 5px}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-bottom-color:#000;border-width:0 5px 5px}.tooltip.bottom-left .tooltip-arrow{top:0;left:5px;border-bottom-color:#000;border-width:0 5px 5px}.tooltip.bottom-right .tooltip-arrow{top:0;right:5px;border-bottom-color:#000;border-width:0 5px 5px}.popover{position:absolute;top:0;left:0;z-index:1010;display:none;max-width:276px;padding:1px;text-align:left;white-space:normal;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);background-clip:padding-box}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;font-weight:normal;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover .arrow,.popover .arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover .arrow{border-width:11px}.popover .arrow:after{border-width:10px;content:""}.popover.top .arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,0.25);border-bottom-width:0}.popover.top .arrow:after{bottom:1px;margin-left:-10px;border-top-color:#fff;border-bottom-width:0;content:" "}.popover.right .arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,0.25);border-left-width:0}.popover.right .arrow:after{bottom:-10px;left:1px;border-right-color:#fff;border-left-width:0;content:" "}.popover.bottom .arrow{top:-11px;left:50%;margin-left:-11px;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,0.25);border-top-width:0}.popover.bottom .arrow:after{top:1px;margin-left:-10px;border-bottom-color:#fff;border-top-width:0;content:" "}.popover.left .arrow{top:50%;right:-11px;margin-top:-11px;border-left-color:#999;border-left-color:rgba(0,0,0,0.25);border-right-width:0}.popover.left .arrow:after{right:1px;bottom:-10px;border-left-color:#fff;border-right-width:0;content:" "}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>img,.carousel-inner>.item>a>img{display:block;height:auto;max-width:100%;line-height:1}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,0.6);opacity:.5;filter:alpha(opacity=50)}.carousel-control.left{background-image:-webkit-gradient(linear,0 top,100% top,from(rgba(0,0,0,0.5)),to(rgba(0,0,0,0.0001)));background-image:-webkit-linear-gradient(left,color-stop(rgba(0,0,0,0.5) 0),color-stop(rgba(0,0,0,0.0001) 100%));background-image:-moz-linear-gradient(left,rgba(0,0,0,0.5) 0,rgba(0,0,0,0.0001) 100%);background-image:linear-gradient(to right,rgba(0,0,0,0.5) 0,rgba(0,0,0,0.0001) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000',endColorstr='#00000000',GradientType=1)}.carousel-control.right{right:0;left:auto;background-image:-webkit-gradient(linear,0 top,100% top,from(rgba(0,0,0,0.0001)),to(rgba(0,0,0,0.5)));background-image:-webkit-linear-gradient(left,color-stop(rgba(0,0,0,0.0001) 0),color-stop(rgba(0,0,0,0.5) 100%));background-image:-moz-linear-gradient(left,rgba(0,0,0,0.0001) 0,rgba(0,0,0,0.5) 100%);background-image:linear-gradient(to right,rgba(0,0,0,0.0001) 0,rgba(0,0,0,0.5) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000',endColorstr='#80000000',GradientType=1)}.carousel-control:hover,.carousel-control:focus{color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-control .icon-prev,.carousel-control .icon-next,.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right{position:absolute;top:50%;left:50%;z-index:5;display:inline-block}.carousel-control .icon-prev,.carousel-control .icon-next{width:20px;height:20px;margin-top:-10px;margin-left:-10px;font-family:serif}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,0.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .icon-prev,.carousel-control .icon-next{width:30px;height:30px;margin-top:-15px;margin-left:-15px;font-size:30px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.clearfix:before,.clearfix:after{display:table;content:" "}.clearfix:after{clear:both}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.affix{position:fixed}@-ms-viewport{width:device-width}@media screen and (max-width:400px){@-ms-viewport{width:320px}}.hidden{display:none!important;visibility:hidden!important}.visible-xs{display:none!important}tr.visible-xs{display:none!important}th.visible-xs,td.visible-xs{display:none!important}@media(max-width:767px){.visible-xs{display:block!important}tr.visible-xs{display:table-row!important}th.visible-xs,td.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-xs.visible-sm{display:block!important}tr.visible-xs.visible-sm{display:table-row!important}th.visible-xs.visible-sm,td.visible-xs.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-xs.visible-md{display:block!important}tr.visible-xs.visible-md{display:table-row!important}th.visible-xs.visible-md,td.visible-xs.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-xs.visible-lg{display:block!important}tr.visible-xs.visible-lg{display:table-row!important}th.visible-xs.visible-lg,td.visible-xs.visible-lg{display:table-cell!important}}.visible-sm{display:none!important}tr.visible-sm{display:none!important}th.visible-sm,td.visible-sm{display:none!important}@media(max-width:767px){.visible-sm.visible-xs{display:block!important}tr.visible-sm.visible-xs{display:table-row!important}th.visible-sm.visible-xs,td.visible-sm.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-sm{display:block!important}tr.visible-sm{display:table-row!important}th.visible-sm,td.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-sm.visible-md{display:block!important}tr.visible-sm.visible-md{display:table-row!important}th.visible-sm.visible-md,td.visible-sm.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-sm.visible-lg{display:block!important}tr.visible-sm.visible-lg{display:table-row!important}th.visible-sm.visible-lg,td.visible-sm.visible-lg{display:table-cell!important}}.visible-md{display:none!important}tr.visible-md{display:none!important}th.visible-md,td.visible-md{display:none!important}@media(max-width:767px){.visible-md.visible-xs{display:block!important}tr.visible-md.visible-xs{display:table-row!important}th.visible-md.visible-xs,td.visible-md.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-md.visible-sm{display:block!important}tr.visible-md.visible-sm{display:table-row!important}th.visible-md.visible-sm,td.visible-md.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-md{display:block!important}tr.visible-md{display:table-row!important}th.visible-md,td.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-md.visible-lg{display:block!important}tr.visible-md.visible-lg{display:table-row!important}th.visible-md.visible-lg,td.visible-md.visible-lg{display:table-cell!important}}.visible-lg{display:none!important}tr.visible-lg{display:none!important}th.visible-lg,td.visible-lg{display:none!important}@media(max-width:767px){.visible-lg.visible-xs{display:block!important}tr.visible-lg.visible-xs{display:table-row!important}th.visible-lg.visible-xs,td.visible-lg.visible-xs{display:table-cell!important}}@media(min-width:768px) and (max-width:991px){.visible-lg.visible-sm{display:block!important}tr.visible-lg.visible-sm{display:table-row!important}th.visible-lg.visible-sm,td.visible-lg.visible-sm{display:table-cell!important}}@media(min-width:992px) and (max-width:1199px){.visible-lg.visible-md{display:block!important}tr.visible-lg.visible-md{display:table-row!important}th.visible-lg.visible-md,td.visible-lg.visible-md{display:table-cell!important}}@media(min-width:1200px){.visible-lg{display:block!important}tr.visible-lg{display:table-row!important}th.visible-lg,td.visible-lg{display:table-cell!important}}.hidden-xs{display:block!important}tr.hidden-xs{display:table-row!important}th.hidden-xs,td.hidden-xs{display:table-cell!important}@media(max-width:767px){.hidden-xs{display:none!important}tr.hidden-xs{display:none!important}th.hidden-xs,td.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-xs.hidden-sm{display:none!important}tr.hidden-xs.hidden-sm{display:none!important}th.hidden-xs.hidden-sm,td.hidden-xs.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-xs.hidden-md{display:none!important}tr.hidden-xs.hidden-md{display:none!important}th.hidden-xs.hidden-md,td.hidden-xs.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-xs.hidden-lg{display:none!important}tr.hidden-xs.hidden-lg{display:none!important}th.hidden-xs.hidden-lg,td.hidden-xs.hidden-lg{display:none!important}}.hidden-sm{display:block!important}tr.hidden-sm{display:table-row!important}th.hidden-sm,td.hidden-sm{display:table-cell!important}@media(max-width:767px){.hidden-sm.hidden-xs{display:none!important}tr.hidden-sm.hidden-xs{display:none!important}th.hidden-sm.hidden-xs,td.hidden-sm.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}tr.hidden-sm{display:none!important}th.hidden-sm,td.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-sm.hidden-md{display:none!important}tr.hidden-sm.hidden-md{display:none!important}th.hidden-sm.hidden-md,td.hidden-sm.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-sm.hidden-lg{display:none!important}tr.hidden-sm.hidden-lg{display:none!important}th.hidden-sm.hidden-lg,td.hidden-sm.hidden-lg{display:none!important}}.hidden-md{display:block!important}tr.hidden-md{display:table-row!important}th.hidden-md,td.hidden-md{display:table-cell!important}@media(max-width:767px){.hidden-md.hidden-xs{display:none!important}tr.hidden-md.hidden-xs{display:none!important}th.hidden-md.hidden-xs,td.hidden-md.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-md.hidden-sm{display:none!important}tr.hidden-md.hidden-sm{display:none!important}th.hidden-md.hidden-sm,td.hidden-md.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}tr.hidden-md{display:none!important}th.hidden-md,td.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-md.hidden-lg{display:none!important}tr.hidden-md.hidden-lg{display:none!important}th.hidden-md.hidden-lg,td.hidden-md.hidden-lg{display:none!important}}.hidden-lg{display:block!important}tr.hidden-lg{display:table-row!important}th.hidden-lg,td.hidden-lg{display:table-cell!important}@media(max-width:767px){.hidden-lg.hidden-xs{display:none!important}tr.hidden-lg.hidden-xs{display:none!important}th.hidden-lg.hidden-xs,td.hidden-lg.hidden-xs{display:none!important}}@media(min-width:768px) and (max-width:991px){.hidden-lg.hidden-sm{display:none!important}tr.hidden-lg.hidden-sm{display:none!important}th.hidden-lg.hidden-sm,td.hidden-lg.hidden-sm{display:none!important}}@media(min-width:992px) and (max-width:1199px){.hidden-lg.hidden-md{display:none!important}tr.hidden-lg.hidden-md{display:none!important}th.hidden-lg.hidden-md,td.hidden-lg.hidden-md{display:none!important}}@media(min-width:1200px){.hidden-lg{display:none!important}tr.hidden-lg{display:none!important}th.hidden-lg,td.hidden-lg{display:none!important}}.visible-print{display:none!important}tr.visible-print{display:none!important}th.visible-print,td.visible-print{display:none!important}@media print{.visible-print{display:block!important}tr.visible-print{display:table-row!important}th.visible-print,td.visible-print{display:table-cell!important}.hidden-print{display:none!important}tr.hidden-print{display:none!important}th.hidden-print,td.hidden-print{display:none!important}} \ No newline at end of file diff --git a/app/css/category-list.css b/app/css/category-list.css new file mode 100644 index 0000000..60480d2 --- /dev/null +++ b/app/css/category-list.css @@ -0,0 +1,39 @@ +.st-categorylist { + z-index: 70; + position: absolute!important; /* to override the bootstrap */ + float: none; + text-align: left; + min-height: 24px; +} + + +.st-categories {background: #000; opacity: 0.7; border-radius: 0 3px 3px 3px; list-style: none; padding: 10px 0; margin-top: -4px;} +.st-categories li { margin-bottom: 3px;} +.st-categories li a { text-decoration: none; padding: 3px 20px; color: #AAAAAA; text-transform: uppercase;} + +.st-category_toggle:before {content: ''} +.st-category_toggle {opacity: 0.7; background: url('../img/st-cat-sprite.png') top left no-repeat; + background-color: #000; width: 35px; height: 35px; + color: #000; padding: 0px 10px; text-decoration: none; + border-radius: 3px 3px 0 0; display: inline-block } + +.st-category_toggle:hover {color: #fff; text-decoration: none; + background: url('../img/st-cat-sprite.png') top right no-repeat; + background-color: #fff; + } +.st-category_toggle:focus {color: #fff; text-decoration: none} +.st-category_toggle.expand:before { content: ''} +.st-category_toggle.expand { border-radius: 3px} + + +.st-categories.ng-hide-add, .st-categories.ng-hide-remove { + transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s; + display: block!important; +} + +.st-categories.ng-hide { height: 0; line-height: 0; opacity: 0; } +.st-categories.ng-hide-add { height: 100%; line-height: 1.5; } +.st-categories.ng-hide-add.ng-hide-adst-category_toggled-active { height: 0; line-height: 0; opacity: 0;} + +.st-categories.ng-hide-remove { height: 0; line-height: 0; } +.st-categories.ng-hide-remove.ng-hide-remove-active { height: 100%; line-height: 1.5;} \ No newline at end of file diff --git a/app/css/category-thumb-list.css b/app/css/category-thumb-list.css new file mode 100644 index 0000000..326d015 --- /dev/null +++ b/app/css/category-thumb-list.css @@ -0,0 +1,121 @@ +/* +To change this license header, choose License Headers in Project Properties. +To change this template file, choose Tools | Templates +and open the template in the editor. +*/ +/* + Created on : Nov 18, 2013, 5:34:35 PM + Author : zahid +*/ + +.anim-thumb.ng-hide-add, .anim-thumb.ng-hide-remove { + transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.7s; + display: block !important; +} + +.anim-thumb.ng-hide { height: 0; line-height: 0; opacity: 0; } +.anim-thumb.ng-hide-add { height: 0; line-height: 0; } +.anim-thumb.ng-hide-add.ng-hide-add-active { height: 0; line-height: 0; opacity: 0;} + +.anim-thumb.ng-hide-remove { height: 0; line-height: 0; } +.anim-thumb.ng-hide-remove.ng-hide-remove-active { height: 100%; line-height: 1.5;} + +.st_category_thumb{ + +} + +.st_category_thumb .st_wrapper{ + /* display:none;*/ + /*position: absolute;*/ + width:100%; + overflow: hidden; + top:50px; + left:0px; + height: 60px; + max-height: 60px; +} + +.st_category_thumb .st_thumbs_title { + background-color: black; + opacity: 1.0; + width: 100%; +} + +.st_category_thumb .st_thumbs_title span{ + margin-left: 15px; + background: #000; + color: #BAB7B0; + text-transform: uppercase; + text-align: left; + font-family: "Helvetica Neue",Helvetica,Arial,sans-serif; +} + +.st_category_thumb .st_thumbs{ + margin: 0; + float: left; +} + +.st_category_thumb .st_thumbs a { + float: left; + margin:3px; +} + +.st_category_thumb .st_thumbs img{ + border:none; + opacity:0.5; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=50); + min-width: 200px; +} + +.st_category_thumb .st_thumbs img:hover{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.st_category_thumb .st_thumbs_active{ + + margin: 0; + float: left; +} + +.st_category_thumb .st_thumbs_active img{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.st_category_thumb .album { + opacity: 0.7; + position: relative; + background-color: lightgrey; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=70); +} + +.st_category_thumb .nav_left,.st_category_thumb .nav_right { + position: absolute; + top: 0; + height: 100%; + text-decoration: none; + color: #fff; + line-height: 100%; + z-index: 110; +} + +.st_category_thumb .nav_left { + background: url('../img/thumb-back.png') no-repeat center; + left:0; +} + +.st_category_thumb .nav_left .st-thumb-nav-bg,.st_category_thumb .nav_right .st-thumb-nav-bg{ + background: #000; + width: 30px; + height: 100%; + opacity: 0.5; + display: block; +} + +.st_category_thumb .nav_right { + background: url('../img/thumb-forward.png') no-repeat center; + right: 0; +} \ No newline at end of file diff --git a/app/css/modal-ajax-loader.css b/app/css/modal-ajax-loader.css new file mode 100644 index 0000000..d2b6d48 --- /dev/null +++ b/app/css/modal-ajax-loader.css @@ -0,0 +1,23 @@ +.modal-ajax-loader { + position: fixed; + width: 100%; + height: 100%; + z-index: 999; +} + +.modal-ajax-loader .overlay { + background: #000; + position: absolute; + width: 100%; + height: 100%; + opacity: 0.6; + z-index: 1; +} + +.modal-ajax-loader .loader { + background: url('../img/ajax-loader.gif') no-repeat center center; + position: absolute; + width: 100%; + height: 100%; + z-index: 2; +} \ No newline at end of file diff --git a/app/css/product-details.css b/app/css/product-details.css new file mode 100644 index 0000000..c35def7 --- /dev/null +++ b/app/css/product-details.css @@ -0,0 +1,52 @@ +.st-product-details-title {font-family: 'Verdana'; font-size: 1.4em; text-align: left;} +product-details .st-product-full-title {display: none;} +product-details .st-product-details-price { font-family: 'Times New Roman' ;text-align: left; font-size: 1.2em; font-weight: normal} +product-details div.st-product-details-main-img-frame {position: absolute;width: 30%; height: 70%; z-index: 80; top: 12%; left: 30%} +product-details .st-product-details-main-img { position: absolute; width: 100%; height: 100%; background-size: contain; background-position: initial; background-clip: initial; background-repeat: no-repeat;} + +product-details .st-pdp-overlay { position: fixed; width: 100%; height: 100%; left: 0; top: 0; z-index: 10000} + +product-details .st-container { padding-left: 0;position: relative; width: 100%; padding-bottom: 50px;} + +product-details .st-pdp-img{ max-height: 400px; margin-top: 20px; margin-bottom: 10px; display: inline-block} + +/*only for chrome, force a scroll in the PDP to set max-height */ +@media screen and (-webkit-min-device-pixel-ratio:0) { + product-details .st-pdp-img{ max-height: 53%; margin-top: 20px; margin-bottom: 10px; display: inline-block} +} + +/* all browsers see this, but only IE thinks #IEroot exists + as an element */ + + +@-moz-document url-prefix() { + product-details .st-pdp-img{ max-height: 400px; margin-top: 20px; margin-bottom: 10px; display: inline-block} +} + +product-details .st-img-loader {margin-top: 8px; margin-left: 8px;} + +product-details button.st-btn-add2bag { font-family: 'Times New Roman'; padding: 5px 0 5px 20px; min-width: 160px; text-align: center;position: relative;text-transform: uppercase} +product-details button span.st-shopping-bag:before { content: url('../img/shopping-bag-icon.png'); padding-right: 4px; position: absolute; border-right: 1px solid #959595; display:inline-block; height: 26px; left: 0; top: 2.2px; padding-left: 2px} + + product-details .st-accordion-title span { font-family: Times New Roman; font-size: 18px;} +product-details st-accordion { position: relative;} + +//drag-up +product-details .drag-up.ng-hide{ display: block !important} + +product-details .drag-up.ng-hide-add, product-details .drag-up.ng-hide-remove{ + -webkit-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 1s; + transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 1s; + display: block !important; +} + +product-details .drag-up.ng-hide{margin-top: 30%; opacity: 0} +product-details .drag-up.ng-hide-add{margin-top: 30%; opacity: 0} +product-details .drag-up.ng-hide-active{margin-top: 30%; opacity: 0} + +product-details .drag-up.ng-hide-remove{ margin-top: 30%; opacity: 0} +product-details .drag-up.ng-hide-remove-active{ margin-top: 0; opacity: 1} + +@media only screen and (min-width: 0px) and (max-width: 479px) { + product-details .st-pdp-img {max-width: 100%} +} \ No newline at end of file diff --git a/app/css/product-full-list.css b/app/css/product-full-list.css new file mode 100644 index 0000000..bd000fa --- /dev/null +++ b/app/css/product-full-list.css @@ -0,0 +1,95 @@ +product-full-list { z-index: 1; position: absolute; top: 0; left: 0; height: 100%; width: 100%} +#product-full-list-last-image{ + position: fixed; + z-index: 0; + top: 0px; + left: 0px; + height: 100%; + width: 100%; +} + +.st-nav_left_ctrl_container,.st-nav_right_ctrl_container{ + width: 70px; + height: 100%; + position: fixed; + z-index: 49; + top: 0; + text-align: center; + padding-right: 20px; +} + +.st-nav_left_ctrl_container a,.st-nav_right_ctrl_container a{ + cursor: pointer; + margin-top: -20px; + position: absolute; + top: 50%; + z-index: 2; + /* margin-left: -10px; + width: 42px; + height: 42px;*/ + text-decoration: none; + color: #000; +} + +.st-nav_left_ctrl_container{ + left: 0; +} +/*.st-nav_left_ctrl_container { + background: url('../img/back.png') no-repeat center; +} +.st-nav_right_ctrl_container { + background: url('../img/forward.png') no-repeat center; +}*/ +.st-nav_right_ctrl_container{ + right: 0; +} + +.st-product-full-list-auto-play-toggle { position: absolute; top: 10px; right: 10px; z-index: 70; background: url('../img/play.png') no-repeat } +.st-product-full-list-auto-play-toggle.yes { background: url('../img/pause.png') no-repeat} + +product-full-list product-full { display: none; position: fixed} +product-full-list product-full.active { display: block !important;} + +product-full-list .anim-fade {opacity: 1} +product-full-list .anim-fade.ng-hide{ opacity: 0} + +product-full-list .anim-fade.ng-hide-add { + display: block !important; + -webkit-animation: fadeOut 0.5s both linear; + -moz-animation: fadeOut 0.5s both linear; + animation: fadeOut 0.5s both linear; +} + +product-full-list .anim-fade.ng-hide-remove { + display: block !important; + -webkit-animation: fadeIn 0.5s both linear; + -moz-animation: fadeIn 0.5s both linear; + animation: fadeIn 0.5s both linear; +} + +product-full-list .anim-slide-next.ng-hide-add { + display: block !important; + -webkit-animation: slideOutLeft 0.5s both linear; + -moz-animation: slideOutLeft 0.5s both linear; + animation: slideOutLeft 0.5s both linear; +} + +product-full-list .anim-slide-next.ng-hide-remove { + display: block !important; + -webkit-animation: slideInRight 0.5s both linear; + -moz-animation: slideInRight 0.5s both linear; + animation: slideInRight 0.5s both linear; +} + +product-full-list .anim-slide-prev.ng-hide-add { + display: block !important; + -webkit-animation: slideOutRight 0.5s both linear; + -moz-animation: slideOutRight 0.5s both linear; + animation: slideOutRight 0.5s both linear; +} + +product-full-list .anim-slide-prev.ng-hide-remove { + -webkit-animation: slideInLeft 0.5s both linear; + -moz-animation: slideInLeft 0.5s both linear; + animation: slideInLeft 0.5s both linear; +} \ No newline at end of file diff --git a/app/css/product-full.css b/app/css/product-full.css new file mode 100644 index 0000000..58939e8 --- /dev/null +++ b/app/css/product-full.css @@ -0,0 +1,38 @@ +product-full { + min-height: 100%; + left: 0; + overflow: hidden; + /*position: absolute;*/ + display: block; + top: 0; + width: 100%; + z-index: 1; +} + +.st-fitToSize { + background-size:contain; +} + + +.st-dontFitToSize { + background-size:cover; + background-attachment:fixed; + background-position: top; +} + +.st-product-full-img { + height: 100%; + left: 0; + overflow: hidden; + position: absolute; + top: 0; + width: 100%; + + background-repeat: no-repeat; + background-attachment: initial; + background-origin: initial; + background-clip: initial; + background-color: #fff; +} + +.st-buynow-button {position: absolute; bottom: 10px; left: 10px; z-index: 50} \ No newline at end of file diff --git a/app/css/product-thumb-list.css b/app/css/product-thumb-list.css new file mode 100644 index 0000000..c85a993 --- /dev/null +++ b/app/css/product-thumb-list.css @@ -0,0 +1,117 @@ +/* +To change this license header, choose License Headers in Project Properties. +To change this template file, choose Tools | Templates +and open the template in the editor. +*/ +/* + Created on : Nov 18, 2013, 5:34:35 PM + Author : zahid +*/ + +/* +.st_product_thumb{ + +} + +.st_product_thumb .st_wrapper{ + width:50%; + overflow: hidden; + top:50px; + left:0px; + margin-left: 12%; + margin-right: 12%; +} +*/ + +.st_product_thumb .st_thumbs_title { + background-color: black; + opacity: 1.0; + width: 100%; +} + +.st_product_thumb .st_thumbs_title span{ + margin-left: 15px; + background: #000; + color: #BAB7B0; + text-transform: uppercase; + text-align: left; + font-family: "Helvetica Neue",Helvetica,Arial,sans-serif; +} + +.st_product_thumb .st_thumbs{ + margin: 0 auto; + /* + float: left; + margin-left: 20px; + margin-right: 20px; + */ +} + +.st_product_thumb .st_thumbs a { + float: left; + margin:3px; +} + +.st_product_thumb .st_thumbs img{ + border:none; + opacity:0.5; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=50); +} + +.st_product_thumb .st_thumbs img:hover{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.st_product_thumb .st_thumbs_active{ + + margin: 0; + float: left; +} + +.st_product_thumb .st_thumbs_active img{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.st_product_thumb .album { + opacity: 0.7; + position: relative; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=70); +} + +.st_product_thumb .nav_left,.st_product_thumb .nav_right { + position: absolute; + top: 0; + height: 100%; + text-decoration: none; + color: #fff; + line-height: 100%; + z-index: 110; + display: none; +} + + +.st_product_thumb:hover .nav_left,.st_product_thumb:hover .nav_right { + display: inline; +} + +.st_product_thumb .nav_left { + background: url('../img/left-arrow.png') no-repeat center; + left:-30px; +} + +.st_product_thumb .nav_left .st-thumb-nav-bg,.st_product_thumb .nav_right .st-thumb-nav-bg{ + + width: 30px; + height: 100%; + opacity: 0.5; + display: block; +} + +.st_product_thumb .nav_right { + background: url('../img/right-arrow.png') no-repeat center; + right: -30px; +} \ No newline at end of file diff --git a/app/css/product-title.css b/app/css/product-title.css new file mode 100644 index 0000000..796a8d3 --- /dev/null +++ b/app/css/product-title.css @@ -0,0 +1,28 @@ +.st-product-full-title { position: absolute; bottom: 25%; right: 7%; color: #000;} + +.st-product-full-title a { text-decoration: none; color: inherit; text-transform: capitilize; color: #000; } +.st-product-full-title a:hover { text-decoration:underline; color: #d90202; } +.st-product-full-title a:focus { outline:0; color: #d90202; } + +product-title { + -webkit-transition:all 0.5s 1s linear; + -moz-transition:all 0.5s 1s linear; + -o-transition:all 0.5s 1s linear; + transition:all 0.5s 1s linear; +} + +.st-product-full-title.ng-hide-add, st-product-full-title.ng-hide-remove { + -webkit-transition:all 0.5s ease-in-out; + -moz-transition:all 0.5s ease-in-out; + -o-transition:all 0.5s ease-in-out; + transition:all 0.5s ease-in-out; + + display: block !important; +} + +.st-product-full-title.ng-hide { opacity: 0;} +.st-product-full-title.ng-hide-add { opacity: 1; } +.st-product-full-title.ng-hide-add.ng-hide-add-active { opacity: 0;} + +.st-product-full-title.ng-hide-remove { opacity: 0; } +.st-product-full-title.ng-hide-remove.ng-hide-remove-active { opacity: 1} \ No newline at end of file diff --git a/app/css/st-accordion.css b/app/css/st-accordion.css new file mode 100644 index 0000000..5d1edca --- /dev/null +++ b/app/css/st-accordion.css @@ -0,0 +1,7 @@ +st-accordion * { font-family: 'Times New Roman'} +st-accordion accordion .panel { background: none !important; border-right: 0 !important; border-left: 0 !important; border-top: 0 !important; box-shadow: none !important; border-radius: 0 !important} +st-accordion accordion .panel-heading { background: none !important; border: none !important; padding-left: 0; padding-right: 0;} +st-accordion accordion .panel-title { font-size: 1em !important;} +st-accordion accordion .panel-body { background: none !important; padding: 10px 0; font-size: 1.2em} +st-accordion accordion .accordion-toggle {text-decoration: none; cursor: pointer} +st-accordion .st-arrow-down:before { content: url('../img/arrow-down.png') } \ No newline at end of file diff --git a/app/css/static-block.css b/app/css/static-block.css new file mode 100644 index 0000000..a248da9 --- /dev/null +++ b/app/css/static-block.css @@ -0,0 +1,25 @@ + +.st-static-block-overlay { + height:100%; + width:100%; + position:fixed; + left:0; + top:0; + z-index: 70 !important; + background-color:black; + opacity: 0.75; +} +.st-static-block-overlay.ng-hide-add, .st-static-block-overlay.ng-hide-remove { + transition: 0.3s linear; + display: block!important; +} + +.st-static-block-overlay.ng-hide { opacity: 0 } +.st-static-block-overlay.ng-hide-add { opacity: 0.75 } +.st-static-block-overlay.ng-hide-add.ng-hide-add-active { opacity: 0;} + +.st-static-block-overlay.ng-hide-remove { opacity: 0 } +.st-static-block-overlay.ng-hide-remove.ng-hide-remove-active { opacity: 0.75} + +.st-static-block-content { color: #fff; background: #131313; + border-style:solid; border-color:white; border-width:5px; border-radius: 3px; padding: 25px; z-index: 72; position: relative } \ No newline at end of file diff --git a/app/css/styles.css b/app/css/styles.css new file mode 100644 index 0000000..35e7155 --- /dev/null +++ b/app/css/styles.css @@ -0,0 +1,2917 @@ +@import url("stStyle.css"); +@import url("bootstrap.min.css"); +/** + * Magento + * + * NOTICE OF LICENSE + * + * This source file is subject to the Academic Free License (AFL 3.0) + * that is bundled with this package in the file LICENSE_AFL.txt. + * It is also available through the world-wide-web at this URL: + * http://opensource.org/licenses/afl-3.0.php + * If you did not receive a copy of the license and are unable to + * obtain it through the world-wide-web, please send an email + * to license@magentocommerce.com so we can send you a copy immediately. + * + * DISCLAIMER + * + * Do not edit or add to this file if you wish to upgrade Magento to newer + * versions in the future. If you wish to customize Magento for your + * needs please refer to http://www.magentocommerce.com for more information. + * + * @category design + * @package default_modern + * @copyright Copyright (c) 2011 Magento Inc. (http://www.magentocommerce.com) + * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) + */ + +/* Reset ================================================================================= */ +/*! normalize.css 2012-03-11T12:53 UTC - http://github.com/necolas/normalize.css */ + +/* ============================================================================= + HTML5 display definitions + ========================================================================== */ + +/* + * Corrects block display not defined in IE6/7/8/9 & FF3 + */ + +article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary { display: block; } + +/* + * Corrects inline-block display not defined in IE6/7/8/9 & FF3 + */ + +audio, canvas, video { display: inline-block; *display: inline; *zoom: 1; } + +/* + * Prevents modern browsers from displaying 'audio' without controls + * Remove excess height in iOS5 devices + */ + +audio:not([controls]) { display: none; height: 0; } + +/* + * Addresses styling for 'hidden' attribute not present in IE7/8/9, FF3, S4 + * Known issue: no IE6 support + */ + +[hidden] { display: none; } + + +/* ============================================================================= + Base + ========================================================================== */ + +/* + * 1. Corrects text resizing oddly in IE6/7 when body font-size is set using em units + * http://clagnut.com/blog/348/#c790 + * 2. Prevents iOS text size adjust after orientation change, without disabling user zoom + * www.456bereastreet.com/archive/201012/controlling_text_size_in_safari_for_ios_without_disabling_user_zoom/ + */ + +html { font-size: 100%; /* 1 */ -webkit-text-size-adjust: 100%; /* 2 */ -ms-text-size-adjust: 100%; /* 2 */ } + +/* + * Addresses font-family inconsistency between 'textarea' and other form elements. + */ + +html, button, input, select, textarea { font-family: sans-serif; } + +/* + * Addresses margins handled incorrectly in IE6/7 + */ + +body { margin: 0; } + + +/* ============================================================================= + Links + ========================================================================== */ + +/* + * Addresses outline displayed oddly in Chrome + */ + +a:focus { outline: thin dotted; } + +/* + * Improves readability when focused and also mouse hovered in all browsers + * people.opera.com/patrickl/experiments/keyboard/test + */ + +a:hover, a:active { outline: 0; } + + + + +/* ============================================================================= + Typography + ========================================================================== */ + +/* + * Addresses font sizes and margins set differently in IE6/7 + * Addresses font sizes within 'section' and 'article' in FF4+, Chrome, S5 + +h1 { font-size: 2em; margin: 0.67em 0; } + +h2 { font-size: 1.5em; margin: 0.83em 0;} + +h3 { font-size: 1.17em; margin: 1em 0;} + +h4 { font-size: 1em; margin: 1.33em 0;} + +h5 { font-size: 0.83em; margin: 1.67em 0; } + +h6 { font-size: 0.75em; margin: 2.33em 0; } + +*/ + +/* + * Addresses styling not present in IE7/8/9, S5, Chrome + */ + +abbr[title] { border-bottom: 1px dotted; } + +/* + * Addresses style set to 'bolder' in FF3+, S4/5, Chrome +*/ + +b, strong { font-weight: bold; } + +blockquote { margin: 1em 40px; } + +/* + * Addresses styling not present in S5, Chrome + */ + +dfn { font-style: italic; } + +/* + * Addresses styling not present in IE6/7/8/9 + */ + +mark { background: #ff0; color: #000; } + +/* + * Addresses margins set differently in IE6/7 + */ + +p, pre { margin: 1em 0; } + +/* + * Corrects font family set oddly in IE6, S4/5, Chrome + * en.wikipedia.org/wiki/User:Davidgothberg/Test59 + */ + +pre, code, kbd, samp { font-family: monospace, serif; _font-family: 'courier new', monospace; font-size: 1em; } + +/* + * Improves readability of pre-formatted text in all browsers + */ + +pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; } + +/* + * 1. Addresses CSS quotes not supported in IE6/7 + * 2. Addresses quote property not supported in S4 + */ + +/* 1 */ + +q { quotes: none; } + +/* 2 */ + +q:before, q:after { content: ''; content: none; } + +small { font-size: 75%; } + +/* + * Prevents sub and sup affecting line-height in all browsers + * gist.github.com/413930 + */ + +sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } + +sup { top: -0.5em; } + +sub { bottom: -0.25em; } + + +/* ============================================================================= + Lists + ========================================================================== */ + +/* + * Addresses margins set differently in IE6/7 + + +dl, menu, ol, ul { margin: 1em 0; } + +dd { margin: 0 0 0 40px; } + +*/ + +/* + * Addresses paddings set differently in IE6/7 + +menu, ol, ul { padding: 0 0 0 40px; } + +*/ + +/* + * Corrects list images handled incorrectly in IE7 + +nav ul, nav ol { list-style: none; list-style-image: none; } + +*/ + + + +/* ============================================================================= + Embedded content + ========================================================================== */ + +/* + * 1. Removes border when inside 'a' element in IE6/7/8/9, FF3 + * 2. Improves image quality when scaled in IE7 + * code.flickr.com/blog/2008/11/12/on-ui-quality-the-little-things-client-side-image-resizing/ + */ + +img { border: 0; /* 1 */ -ms-interpolation-mode: bicubic; /* 2 */ } + +/* + * Corrects overflow displayed oddly in IE9 + */ + +svg:not(:root) { overflow: hidden; } + + +/* ============================================================================= + Figures + ========================================================================== */ + +/* + * Addresses margin not present in IE6/7/8/9, S5, O11 + */ + +figure { margin: 0; } + + +/* ============================================================================= + Forms + ========================================================================== */ + +/* + * Corrects margin displayed oddly in IE6/7 + */ + +form { margin: 0; } + +/* + * Define consistent border, margin, and padding + */ + +fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em; } + +/* + * 1. Corrects color not being inherited in IE6/7/8/9 + * 2. Corrects text not wrapping in FF3 + * 3. Corrects alignment displayed oddly in IE6/7 + */ + +legend { border: 0; /* 1 */ padding: 0; white-space: normal; /* 2 */ *margin-left: -7px; /* 3 */ } + +/* + * 1. Corrects font size not being inherited in all browsers + * 2. Addresses margins set differently in IE6/7, FF3+, S5, Chrome + * 3. Improves appearance and consistency in all browsers + */ + +button, input, select, textarea { font-size: 100%; /* 1 */ margin: 0; /* 2 */ vertical-align: baseline; /* 3 */ *vertical-align: middle; /* 3 */ } + +/* + * Addresses FF3/4 setting line-height on 'input' using !important in the UA stylesheet + */ + +button, input { line-height: normal; /* 1 */ } + +/* + * 1. Improves usability and consistency of cursor style between image-type 'input' and others + * 2. Corrects inability to style clickable 'input' types in iOS + * 3. Removes inner spacing in IE7 without affecting normal text inputs + * Known issue: inner spacing remains in IE6 + */ + +button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; /* 1 */ -webkit-appearance: button; /* 2 */ *overflow: visible; /* 3 */ } + +/* + * Re-set default cursor for disabled elements + */ + +button[disabled], input[disabled] { cursor: default; } + +/* + * 1. Addresses box sizing set to content-box in IE8/9 + * 2. Removes excess padding in IE8/9 + * 3. Removes excess padding in IE7 + Known issue: excess padding remains in IE6 + */ + +input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ *height: 13px; /* 3 */ *width: 13px; /* 3 */ } + +/* + * 1. Addresses appearance set to searchfield in S5, Chrome + * 2. Addresses box-sizing set to border-box in S5, Chrome (include -moz to future-proof) + */ + +input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; } + +/* + * Removes inner padding and search cancel button in S5, Chrome on OS X + */ + +input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button { -webkit-appearance: none; } + +/* + * Removes inner padding and border in FF3+ + * www.sitepen.com/blog/2008/05/14/the-devils-in-the-details-fixing-dojos-toolbar-buttons/ + */ + +button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; } + +/* + * 1. Removes default vertical scrollbar in IE6/7/8/9 + * 2. Improves readability and alignment in all browsers + */ + +textarea { overflow: auto; /* 1 */ vertical-align: top; /* 2 */ } + + +/* ============================================================================= + Tables + ========================================================================== */ + +/* + * Remove most spacing between table cells + */ + +table { border-collapse: collapse; border-spacing: 0; } + +/****** END Normalization *****************************************************************************/ + +/* Generated by Font Squirrel (http://www.fontsquirrel.com) on May 3, 2012 11:34:39 AM America/New_York */ + + + + + +body { font:75%/1.5 /*12/18*/ Tahoma, Helvetica, Arial, sans-serif; color:#000000; background:#F9F9F9;} + +img { border:0; vertical-align:top; } + +a { outline: 0; } +object, embed { outline: 0; } +a { text-decoration: none; color: inherit; text-transform: capitilize; color: #428bca; } +a:hover { text-decoration:underline; color: #d90202; } +a:focus { outline:0; color: #d90202; } + +/* Headings */ + +h1, h2, h3, h4, h5, h6 { padding: 0; margin: 0 0 18px; clear: both; } + +h1 { font-size: 30px; line-height: 1; font-family:'Karla', tahoma, arial, sans-serif; font-weight:normal;} /* 36/36 */ +h2 { font-size: 24px; line-height: 1.285714286; font-family: 'Karla', tahoma, arial, sans-serif; color:#749E4D; font-weight:normal;}/* 36/28 */ +h3 { font-size: 18px; line-height: 1.636363636; font-family: 'Karla', tahoma, arial, sans-serif; font-weight:normal; }/* 36/22 */ +h4 { font-size: 16px; line-height: 1; font-family: 'Karla', tahoma, arial, sans-serif; font-weight:normal; }/* 18/18 */ +h5 { font-size: 15px; line-height: 1.2; font-family: 'Karla', tahoma, arial, sans-serif; font-weight:normal;}/* 18/36 */ +h6 { font-size: 13px; line-height: 1.384615385; font-family: 'Karla', tahoma, arial, sans-serif; font-weight:normal;}/* 18/13 */ + + +/* Forms */ +form { display:inline; } +fieldset { border:0; } +legend { display:none; } + +/* Table */ +table { border:0; /*border-collapse:collapse;*/ border-spacing:0; empty-cells:show; font-size:100%; } +caption,th,td { vertical-align:top; text-align:left; font-weight:normal; } + +/* Content */ +p { margin:9px 0; } +strong { font-weight:bold; } +address { font-style:normal; } +cite { font-style:normal; } +q, +blockquote { quotes:none; } +q:before, +q:after { content:''; } + +/* +small { font-size:1em; } +big { font-size:1.15em; } +/*sup { font-size:1em; vertical-align:top; } + +/* Lists */ +ul,ol , dl, dt, dd { list-style:none; margin:0; padding: 0; } + +/* Tools */ +.hidden { display:block !important; border:0 !important; margin:0 !important; padding:0 !important; font-size:0 !important; line-height:0 !important; width:0 !important; height:0 !important; overflow:hidden !important; } +.nobr { white-space:nowrap !important; } +.wrap { white-space:normal !important; } +.a-left { text-align:left !important; } +.a-center { text-align:center !important; } +.a-right { text-align:right !important; } +.v-top { vertical-align:top; } +.v-middle { vertical-align:middle; } +.f-left, +.left { float:left !important; margin-right: 10px;} +.f-right, +.right { float:right !important; margin-left: 10px; } +.f-none { float:none !important; } +.f-fix { float:left; width:100%; } +.no-display { display:none; } +.no-margin { margin:0 !important; } +.no-padding { padding:0 !important; } +.no-bg { background:none !important; } + +/* ======================================================================================= */ + + +/* Default Layout: 980px. + Gutters: 20px. + Outer margins: 20px. +------------------------------------------------------------------------------- +cols 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 +px 40 100 160 220 280 340 400 460 520 580 640 700 760 820 880 940 */ +//border-top: 4px solid #000; +.page {position: absolute; margin: 0 auto; background: #F9F9F9; min-height: 100%; min-width: 100%; padding-bottom: 100px; } +.row { margin:0 auto; width:100%;} + .row .row { margin:0 -16px 0 -16px; width:auto; } + + .grid_1 { width:48px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_2 { width:128px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_3 { width:208px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_4 { width:288px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_5 { width:368px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_6 { width:448px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_7 { width:528px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_8 { width:608px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_9 { width:688px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_10 { width:768px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_11 { width:848px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + .grid_12 { width:928px; margin:0 16px 0 16px; overflow:hidden; float:left; display:inline; } + + .space_1 { margin-left:96px; } + .space_2 { margin-left:176px; } + .space_3 { margin-left:256px; } + .space_4 { margin-left:336px; } + .space_5 { margin-left:416px; } + .space_6 { margin-left:496px; } + .space_7 { margin-left:576px; } + .space_8 { margin-left:656px; } + .space_9 { margin-left:736px; } + .space_10 { margin-left:816px; } + .space_11 { margin-left:896px; } + +/* Baseline images overlay + +.page { background: url("../images/baseline18px.png") repeat scroll 0 0 #FFF; }*/ + +.main { padding: 40px 10px;background:none; } + +.col2-left-layout .col-left { float: left; width: 220px; } +.col2-left-layout .col-main { float: right; width: 700px; } +.col2-right-layout .col-right { float: right; width: 220px; margin-left: 20px; } +.col2-right-layout .col-main { float: left; width: 700px; } +.col1-layout .col-main { float: none; margin-left: 10%; width: 80%; } + + +/* content columns */ +.col2-set { clear:both; overflow:hidden; } +.col2-set .col-1 { float:left; width:48%; } +.col2-set .col-2 { float:right; width:48%; padding-left: 5px;} +.col2-set .narrow { width:33%; } +.col2-set .wide { width:65%; } + +/* ======================================================================================= */ + +.visuallyhidden { position: absolute; overflow: hidden; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; padding: 0; border: 0; } /* accessible hidden content http://snook.ca/archives/html_and_css/hiding-content-for-accessibility */ + + + +/************* Form Elements **********************************/ +fieldlset { margin: 9px 0; padding: 9px 5px; } +textarea { width:96%; height:108px; background: #F7F7F7; border:none; padding: 9px 10px; border: none; border-top: 1px solid #ccc; border-bottom: 1px solid #ddd; }4 +select { padding: 0;} +input {} +.input-box { clear: both; } +.input-box input.input-text { background: #F7F7F7; border: 1px solid #ccc; padding: 4px 9px; width: 89%; } +.input-box select { background: #F7F7F7; border: 1px solid #ccce; padding:8px 4px 7px; width: 96%; } +.input-box select.multiselect { min-height:90px; background:#F7F7F7; border:none; border: none; border-top: 1px solid #ccc; border-bottom: 1px solid #ddd; padding:5px; } +.input-text.qty { background:#F7F7F7; border:none; padding:3px 3px 4px; width: 20px; border: 1px solid #444; text-align: center; } +.form-alt li { margin: 9px 0; } +.form-list { width:90%; } +.form-list li { margin: 9px 0; } +.form-list li { display: inline-block; } +.form-list li, .form-list li .field { float:left; width:45%; margin-right:5%; } +.form-list li.fields, .form-list li.wide { display: inline-block; width:100%; } +.form-list li.wide .input-box input.input-text { width:90%; } + +.form-list li + li.control { margin-top:18px; } +.form-list li.control + li.control { margin-top:0; } +.form-list li.control { width:100%; margin:9px 0; } +.form-list li.control.use-billing { margin-bottom:18px; } +.form-list li.control .input-box { float:left; margin-right:10px; } + +.form-list li .input-range input#price, .form-list li .input-range input#price_to { float: left; margin-right: 3%; width: 40%; } +.form-list li .input-range span.separator { float: left; } +.form-list li .input-box input.range { overflow: hidden; } + + +.form-list li.control label { margin: 0 10px; } +.form-list li label { } +#checkoutSteps .form-list li label {margin-bottom:10px;display:inline-block; } +.form-list li label em { } + +#checkout-step-login .form-list li , #checkout-step-billing .form-list li, #checkout-step-shipping .form-list li, #checkout-opc-payment .form-list li, +.customer-account-login .form-list li , .shipping .form-list li, .checkout-multishipping-login .form-list li, .paypal-review-order .form-list li { width: 100%; } + +label.required em { color: red; } + +.form-guest { width: 460px; } + +.sidebar .form-subscribe .input-box {padding:10px;} +.sidebar #newsletter-validate-detail {display:inline-block;background:#F2F2F2;border:1px solid #ccc;width:100%} +.sidebar #newsletter-validate-detail .button {margin-left:10px;margin-bottom:10px;} +/********* Buttons Styling ***********************/ + +.button { + background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #808080), color-stop(1, #808080) ); + background:-moz-linear-gradient( center top, #808080 5%, #808080 100% ); + /* filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#F7F7F7', endColorstr='#dfdfdf'); */ + background-color:#808080; + -moz-border-radius:3px; + -webkit-border-radius:3px; + border-radius:3px; + border:none; + display:inline-block; + color:#fff; + font-weight:bold; + font-family:arial; + font-size:12px; + padding:3px 10px 5px; + text-decoration:none; + text-transform: lowercase; +}.button:hover { + background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #808080), color-stop(1, #808080) ); + background:-moz-linear-gradient( center top, #808080 5%, #808080 100% ); + /* filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#dfdfdf', endColorstr='#F7F7F7'); */ + background-color:#808080; +}.button:active { + position:relative; + top:1px; +} + +.buttons-set { padding: 9px 0;} +p.required { font-size: 10px; color: #ccc; } +p.back-link { clear: left; } +.button-set { padding: 9px 0; } +.buttons-set button, .buttons-set p.required { margin-right:10px; float: left; } +.form-list li label.required em { text-align: left; margin-right: 5px; } +.buttons-set p.required, .buttons-set a { } +#checkout-review-submit .button {float:right;margin-top:10px;} +/********** END FORM ELEMENTS ***********************************/ + +/* Form Validation */ +.validation-advice { clear:both; min-height:13px; margin:3px 0 0; padding-left:13px; font-size:11px; line-height:13px; background:url(../images/validation_advice_bg.gif) 2px 3px no-repeat; color:#eb340a; } +.validation-failed { border:1px solid #eb340a !important; background:#faebe7 !important; } +.validation-passed {} +p.required { font-size:11px; float: right; color:#EB340A; } +/* Expiration date and CVV number validation fix */ +.v-fix { float:left; } +.v-fix .validation-advice { display:block; width:12em; margin-right:-12em; position:relative; } + +/* Global Messages */ +.success { color:#3d6611; font-weight:bold; } +.error { color:#df280a; font-weight:bold; } +.notice { color:#e26703; } + +.messages, +.messages ul { list-style:none !important; margin:0 !important; padding:0 !important; } +.messages { width:100%; overflow:hidden; } +.messages li { } +.messages li li { } +.error-msg, +.success-msg, +.note-msg, +.notice-msg { border-style:solid !important; border-width:1px !important; font-size:11px !important; font-weight:bold !important; line-height: 1.63636363636; padding: 8px 10px; margin-bottom: 18px; } +.error-msg { border-color:#f16048; background-color:#faebe7; color:#df280a; } +.success-msg { border-color:#446423; background-color:#eff5ea; color:#3d6611; } +.note-msg, +.notice-msg { border-color:#fcd344; background-color:#fafaec; color:#3d6611; } + +/* BreadCrumbs */ +.breadcrumbs a { color:#7f7f7f; } +.breadcrumbs li { display:inline; } +.breadcrumbs li strong { font-weight:bold; } + +/* Page Heading */ +.page-title { width:100%; overflow:hidden; margin:0 0 18px; } +.page-title h1, +.page-title h2 { margin:0;} +.page-title .separator { } +.page-title .link-rss { float:right; } +.title-buttons { text-align:right; } +.title-buttons h1, +.title-buttons h2, +.title-buttons h3, +.title-buttons h4, +.title-buttons h5, +.title-buttons h6 { float:left; } + +.subtitle, +.sub-title { clear:both; font-weight:bold; } + +/* Pager */ +.pager { text-align:center; } +.pager .amount { float:left; margin:0; margin-right: 20px;} +.pager .pages { float: left; } +.pager .pages ol { display:inline; } +.pager .pages li { border: 1px solid #CCCCCC; float: left; margin:0 5px; padding:2px 8px; } +.pager .pages .current { background: #ccc; } +div.pages>strong { position: absolute; overflow: hidden; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; padding: 0; border: 0; } + +/* Sorter */ +.sorter { border-bottom: 1px dotted #CCCCCC; font-size: 11px; line-height: 1.63636; padding: 9px 8px 8px;} +.sorter .view-mode { float:left; margin:0; } +.sorter .limiter { float:right; } +.sorter .limiter label { vertical-align:middle; } +.sorter .limiter select { padding:0; margin:0 0 1px; vertical-align:middle; } +.sorter .sort-by { float:right; padding-right:36px; } +.sorter .sort-by label { vertical-align:middle; } +.sorter .sort-by select { padding:0; margin:0 0 1px; vertical-align:middle; } +.sorter .link-feed {} + +/* Toolbar */ +.toolbar { margin: 9px 0; } +.toolbar .pager { } +.toolbar .sorter {} +.toolbar-bottom {} +.toolbar label { } +.form-language {margin-top:10px !important;} + +/* Data Table */ +.data-table { width:100%; } +.data-table tr.odd { background:#fff } +.data-table tr.even { background:#fcfcfc; } +.data-table tr.last th, +.data-table tr.last td { border-bottom:0 !important; } +.data-table th { padding:9px 8px; font-size:10px; line-height: 1.8; text-transform:uppercase; white-space:nowrap; } +.data-table th.wrap { white-space:normal; } +.data-table th a { color:#fff; } +.data-table td { padding:9px 8px; } + +.data-table thead, +.data-table thead tr { background:#e9e9e9; } + +.data-table tfoot { border-bottom:1px solid #d9dde3; } +.data-table tfoot tr { background-color:#ccc !important; } +.data-table tbody th { padding:3px 8px; font-size:11px; font-weight:bold; text-transform:none; white-space:normal; } +.data-table tbody th, +.data-table tbody td {padding-bottom: 8px; } +.data-table tfoot strong { font-size:14px; line-height: 1.285714286; } +/* Bundle products tables */ +.data-table tbody.odd tr { background:#fff; } +.data-table tbody.even tr { background:#fcfcfc; } +.data-table tbody.odd tr td, +.data-table tbody.even tr td { border-bottom:0; } +.data-table tbody.odd tr.border td, +.data-table tbody.even tr.border td { border-bottom:1px solid #d9dde3; } + +.data-table tbody td .option-label { font-weight:bold; font-style:italic; } +.data-table tbody td .option-value { padding-left:10px; } + +/* Generic Info Box */ +.info-box { margin:0 0 15px; } +.info-box h2 { font-size:13px; font-weight:bold; border-bottom:1px solid #ddd; margin:0 0 8px; } + +.info-table th { font-weight:bold; padding:2px 15px 2px 0; } +.info-table td { padding:2px 0; } + +/* Shopping cart total summary row expandable to details */ +tr.summary-total { cursor:pointer; } +tr.summary-total td {} +tr.summary-total .summary-collapse { float:right; text-align:right; padding-left:20px; background:url(../images/bkg_collapse.gif) 0 4px no-repeat; cursor:pointer; } +tr.show-details .summary-collapse { background-position:0 -53px; } +tr.show-details td {} +tr.summary-details td { background-color:#dae1e4; color:#626465; } +tr.summary-details-first td { border-top:1px solid #d2d8db; } +tr.summary-details-excluded { font-style:italic; } + +/* Shopping cart tax info */ +.cart-tax-info { display:block; } +.cart-tax-info, +.cart-tax-info .cart-price { padding-right:20px; } +.cart-tax-total { display:block; padding-right:20px; background:url(../images/bkg_collapse.gif) 100% 4px no-repeat; cursor:pointer; } +.cart-tax-info .price, +.cart-tax-total .price { display:inline !important; font-weight:normal !important; } +.cart-tax-total-expanded { background-position:100% -53px; } + +/* Class: std - styles for admin-controlled content */ +.std .subtitle { padding:0; } +.std ol.ol { list-style:decimal outside; padding-left:1.5em; } +.std ul.disc { list-style:disc outside; padding-left:18px; margin:0 0 10px; } +.std dl dt { font-weight:bold; } +.std dl dd { margin:0 0 10px; } +/*.std ul, +.std ol, +.std dl, +.std p, +.std address, +.std blockquote { margin:0 0 1em; padding:0; } +.std ul { list-style:disc outside; padding-left:1.5em; } +.std ol { list-style:decimal outside; padding-left:1.5em; } +.std ul ul { list-style-type:circle; } +.std ul ul, +.std ol ol, +.std ul ol, +.std ol ul { margin:.5em 0; } +.std dt { font-weight:bold; } +.std dd { padding:0 0 0 1.5em; } +.std blockquote { font-style:italic; padding:0 0 0 1.5em; } +.std address { font-style:normal; } +.std b, +.std strong { font-weight:bold; } +.std i, +.std em { font-style:italic; }*/ + +/* Misc */ +.links li { display:inline; } +.links li.first { padding-left:0 !important; } +.links li.last { background:none !important; padding-right:0 !important; } + +.link-cart { font-weight:bold; color:#000; } +.link-wishlist { color:#444; } +.link-reorder {} +.link-compare { } +.link-print { /*background:url(../images/i_print.gif) 0 2px no-repeat; padding:3px 0 3px 25px;*/ } +.link-rss { background:url(../images/i_rss.gif) 0 1px no-repeat; padding-left:18px; line-height:14px; white-space:nowrap; } +.btn-remove { display:block; width:12px; height:12px; font-size:0; line-height:0; background:url(../images/btn_remove.gif) 0 0 no-repeat; text-indent:-999em; overflow:hidden; margin: 0 2px; } +.btn-remove2 { display:block; width:16px; height:16px; font-size:0; line-height:0; background:url(../images/btn_trash.gif) 0 0 no-repeat; text-indent:-999em; overflow:hidden; } +.btn-edit { display:block; width:12px; height:12px; font-size:0; line-height:0; background:url(../images/btn_edit.gif) 0 0 no-repeat; text-indent:-999em; overflow:hidden; } + +.cards-list dt { margin:5px 0 0; } +.cards-list .offset { padding:2px 0 2px 20px; } + +.separator { margin:0 0 0 3px; } + +.divider { clear:both; display:block; font-size:0; line-height:0; height:1px; background:#ccc; margin:10px 0; text-indent:-999em; overflow:hidden; } + +/* Noscript Notice */ +.noscript { border:1px solid #ddd; border-width:0 0 1px; background:#ffff90; font-size:12px; line-height:1.25; text-align:center; color:#2f2f2f; } +.noscript .noscript-inner { width:950px; margin:0 auto; padding:12px 0 12px; background:url(../images/i_notice.gif) 20px 50% no-repeat; } +.noscript p { margin:9px 0; } + +/* Demo Notice */ +.demo-notice { margin:0; padding:6px 10px; background:#d75f07; font-size:11px; line-height:1.15; text-align:center; color:#fff; } +/* ======================================================================================= */ + + +/* Header ================================================================================ */ +.logo { } +.header-container {background: none;} + +.header { margin:0; margin-left: 20px; text-align: center; position:relative;} +.header .logo { text-decoration:none !important; } +.header .logo strong { position:absolute; top:-999em; left:-999em; width:0; height:0; font-size:0; line-height:0; text-indent:-999em; overflow:hidden; } + +.header .top-promo { float:left; width:117px; height:30px; margin:12px 10px 0; background:url(../images/bkg_top-promo.gif) 0 0 no-repeat; text-indent:-999em; overflow:hidden; } + + +.header .topcart span { display: inline; } + +.quick-access { + float: right; + text-align: right; +} +.quick-access .show-on-phones {} +.quick-access .welcome-msg { display:inline; margin:0; color:#fff; } +.quick-access .welcome-msg a { color:#ddd; } +.quick-access .form-language, .quick-access .top-currency { float:right; margin:0 10px 9px 0; } +.quick-access .form-language label, .quick-access .top-currency label { overflow: hidden; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; padding: 0; border: 0; } +.quick-access .form-language select, .quick-access .top-currency select{ padding:0; } +.quick-access .form-language select.flags option { background-position:4px 50%; background-repeat:no-repeat; padding-left:25px; } +.quick-access .links { padding-left:8px; } +.quick-access .links, +.quick-access .links li { display:inline; } +.quick-access .links li { padding:0 4px 0 1px; } +.quick-access .links a { } +.quick-access .links a { padding:0 7px 0 0; background:url(../images/bkg_pipe1.gif) no-repeat 100% 50%; } +.quick-access .links li.last a { padding:0; background:none; } + +.top-bar { } +.top-bar .breadcrumbs { float:left; overflow:hidden;padding:10px 0;margin-left:10px;} +.form-search {background: none repeat scroll 0 0 #76B13F; + float: right; + padding: 5px 10px 10px; + margin:10px 0; +} +.form-search input.input-text { + float: left; + height: 18px; + margin-top: 5px; + width: 200px; +} +input.input-text, select, textarea { + background: none repeat scroll 0 0 #FFFFFF; + border: 1px solid #B6B6B6; +} +.form-search label { position: absolute; overflow: hidden; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; padding: 0; border: 0; } + +.form-search button.button { float:left; height: 24px; width: 63px; border: none; padding: 0; margin: 0; border-radius: 0; background: url(../images/search_btn.png) no-repeat;box-shadow: none;margin-top:4px;} +.form-search button.button span { } +.form-search .search-autocomplete { z-index:999; } +.form-search .search-autocomplete ul { border:1px solid #999; background-color:#f9f5f0; } +.form-search .search-autocomplete li { text-align:left; border-bottom:1px solid #f4eee7; padding:2px 8px 1px 8px; cursor:pointer; } +.form-search .search-autocomplete li .amount { float:right; font-weight:bold; } +.form-search .search-autocomplete li.odd { background-color:#f6f6f6; } +.form-search .search-autocomplete li.selected { background-color:#ecf9ea; } + +.header-container .top-container { padding:5px 12px; background:#fff; border:1px solid #bbb; border-width:0 1px 1px; text-align:right; } + + +/********** < Navigation */ +.nav-container {background:#35373B; width: 100%; margin:10px 0 0 0; height: 34px;position: relative; +} +.nav-container select { margin: 18px 0; } +.nav-container select { width: 100% } +#nav { float: left; + font-size: 12px; + margin: 0; } + +/* All Levels */ /* Style consistent throughout all nav levels */ +#nav li { position:relative;text-align:left; } +#nav li.over { z-index:998; } +#nav a, +#nav a:hover { display:block; text-decoration:none; text-transform:uppercase; } +#nav span { display:block; cursor:pointer; white-space:nowrap; } +#nav li ul span {white-space:normal; } + +/* 0 Level */ +#nav li { + float: left; + padding:8px 12px; +} +#nav li.active a { color:#76B13F; } +#nav a { color: #FFFFFF; + float: left; + font-weight: bold; + padding-right: 11px; font-family:Arial, Helvetica, sans-serif; } +#nav li.over a, +#nav a:hover { color:#76B13F; } + + +/* 1st Level */ +#nav ul li, +#nav ul li.active, +#nav ul li.over { float:none; border:none; background:none; margin:0; padding:0; padding-bottom:1px; text-transform:none; } +#nav ul li.parent { } +#nav ul li.last { padding-bottom:0; } +#nav ul li.active { margin:0; border:0; background:none; } +#nav ul a, +#nav ul a:hover { float:none; padding:0; background:none; } +#nav ul li a { font-weight:normal !important; } + +/* 2nd Level */ +#nav ul, +#nav div { position:absolute; width:15em; top:30px; left:-10000px; border:1px solid #bbb; padding:3px 8px; background:#fcfcfc; } +#nav div ul { position:static; width:auto; border:none; padding:0; } + +/* 3rd+ Level */ +#nav ul ul, +#nav ul div { top:5px; } + +#nav ul li a { padding:3px 0; color:#444 !important; } +#nav ul li a:hover { padding:3px 0;} + +/* Show menu */ +#nav li ul.shown-sub, +#nav li div.shown-sub { left:-1px; z-index:999; } +#nav li .shown-sub ul.shown-sub, +#nav li .shown-sub li div.shown-sub { left:100px; } +.flex-direction-nav {display:none;} +/********** Navigation > */ +/* ======================================================================================= */ + + +/* Sidebar =============================================================================== */ +.block { margin:0 0 18px 0; border: 1px solid #DDDDDD;;} +.block:first-child { margin-top: 0; } +.block .block-title { background: none repeat scroll 0 0 #2F2F31; + border-bottom: 1px solid #DDDDDD; + padding: 2px 10px; + vertical-align: middle; + padding:5px;} +.block .block-title strong { display:block; text-transform: uppercase; font-size: 14px; } +.block .block-title strong span {color:#fff;} +.block .block-title a { text-decoration:none !important; } +.block .block-subtitle { } +.block .block-content { + background: none repeat scroll 0 0 #F2F2F2; + padding: 10px 10px; +} +.block .block-content { } +.block .block-content li.item {margin-bottom: 18px; } +.block .block-content li.item.last { } +.block .block-content .product-name { color:#4f8100; margin-bottom: 0; } +.block .btn-remove, +.block .btn-edit { float:right; } +.block .actions { text-align:right; } +.block .actions a { float:left; } +.block .actions button.button { float:right; } +.block .empty { } +.block .price-box { } +.block button.button span { } +.form-subscribe-header {display:none;} +.sidebar .form-subscribe label { + background: none repeat scroll 0 0 #2F2F31; + border-bottom: 1px solid #DDDDDD; + color: #FFFFFF; + display: block; + font-size: 14px; + font-weight: bold; + padding: 5px; + text-transform: uppercase; + vertical-align: middle; +} +.sidebar .form-subscribe input[type="text"] {height:18px;border:1px solid #ccc;} +/*.block li.odd { background-color:#f4f3f3; } +.block li.even { background-color:#fafafa; }*/ + +/* Mini Products List */ +.mini-products-list .product-image { float:left; width:50px; } +.mini-products-list .product-details { margin-left:60px; } + +/* Block: Account */ +.block-account .block-title { /*background:#666; padding: 0 10px;*/} +.block-account .block-title strong { color:#fff; } +.block-account .block-content li a { display:block; color:#5f5d5c; text-decoration:none !important; } +.block-account .block-content li a:hover { color:#444; } +.block-account .block-content li.last a { } +.block-account .block-content li.current { } +.block-account .block-content li.current.last { } + +/* Block: Currency Switcher */ +.block-currency { background:#f4f4f4; } +.block-currency .block-title { border:0; background:none; text-transform:none; } +.block-currency .block-title strong { text-transform:none; } +.block-currency .block-content { } +.block-currency .block-content select { width:100%; padding:0; } + +/* Block: Layered Navigation */ +.block-layered-nav { } +.block-layered-nav .block-title { } +.block-layered-nav .block-content { } +.block-layered-nav .block-subtitle { } +.block-layered-nav p.block-subtitle { margin-bottom: 0; text-transform: uppercase; font: 12/1.5; display: none; } +.block-layered-nav dt { font-weight:bold; } +.block-layered-nav dd { } +.block-layered-nav dd li { margin: 9px 0; } +.block-layered-nav dd a { color:#444; } +.block-layered-nav .currently ol { } +.block-layered-nav .currently li { } +.block-layered-nav .currently .label { font-weight:bold; } +.block-layered-nav .currently .btn-remove { } +.block-layered-nav .actions { margin:0; } +.block-layered-nav .actions a { float:none; } + +/* Block: Cart */ +.block-cart .block-title { } +.block-cart .block-title strong { } +.block-cart .summary { padding:9px 3px; text-align:center; position:relative; z-index:1; background: #f5f4f4; -moz-box-shadow: inset 0 0 5px 5px #edeaea; -webkit-box-shadow: inset 0 0 5px 5px#edeaea; box-shadow: inset 0 0 5px 5px #edeaea; border-radius: 4px; } +.block-cart .amount { margin:0; } +.block-cart .amount a { font-weight:bold; } +.block-cart .subtotal { margin:9px } +.block-cart .subtotal .price { font-weight:bold; } +.block-cart .actions { display:none !important; } +.block-cart .actions .paypal-logo { float:left; width:100%; text-align:right; } + +/* Block: Wishlist */ +.block-wishlist .actions { text-align:right; } +.block-wishlist .actions a { float:none; } + +/* Block: Related */ +.block-related .block-subtitle { font-weight:bold; border:0; text-transform:none; } +.block-related input.checkbox { float:right; } +.block-related .product { margin-right:20px; } + +/* Block: Compare Products */ +.page-popup .link-print { background:url(../images/i_print.gif) 0 2px no-repeat; padding:3px 0 3px 25px; } +.compare-table { border:0; } +.compare-table thead, +.compare-table thead tr.first { background:#fff; } +.compare-table thead tr.first th, +.compare-table thead tr.first td { border:0; background:none; padding:0 0 4px; font-size:0; line-height:0; } +.compare-table .btn-remove { float:right; background-image:url(../images/btn_remove.gif); width:12px; height:12px; } +.compare-table tbody th { background:#e9e9e9; } +.compare-table tbody th, +.compare-table tbody td { padding:10px; border:0; border-top:1px solid #ccc; border-left:1px solid #ccc; } +.compare-table tbody td.last { border-right:1px solid #ccc; } +.compare-table tbody tr.last th, +.compare-table tbody tr.last td { border-bottom:1px solid #ccc !important; } +.compare-table tr.add-to-row td { background:#fffada; text-align:center; } +.compare-table tr.first td { text-align:center; } +.compare-table tr.first td .product-name { font-size:13px; font-weight:bold; margin:0 0 5px; color:#203548; } +.compare-table tr.first td .product-name a { color:#203548; } +.compare-table tr.first td .ratings { width:69px; margin:0 auto; } +.compare-table tr.first td p, +.compare-table tr.add-to-row td p { margin:9px 0; } +.compare-table .add-to-links li { background:none; padding:0; } + +/* Block: Recently Viewed */ +.block-viewed {} + +/* Block: Recently Compared */ +.block-compared {} + +/* Block: Poll */ +.block-poll .block-subtitle { font-size:12px; } +.block-poll label { color:#777; font-weight:bold; } +.block-poll input.radio { float:left; margin:1px -18px 0 0; } +.block-poll .label { display:block; margin-left:18px; } +.block-poll li { padding:3px 9px; } +.block-poll .actions { margin:5px 0 0; } +.block-poll .answer { font-weight:bold; } +.block-poll .votes { float:right; margin-left:10px; } + +/* Block: Tags */ +.block-tags .block-content .tags-list { border:0; background:none; padding:0; } +.block-tags .block-content li a { color:#444; } +.block-tags .actions { text-align:right; } +.block-tags .actions a { float:none; } + +/* Block: Reorder */ +.block-reorder input.checkbox { float:left; margin:2px -20px 0 0; } +.block-reorder .product-name { margin-left:20px; } +.block-reorder .validation-advice { margin:3px 9px 7px; } + +/* Block: Banner */ +.block-banner { border:0; } +.block-banner .block-content { padding:0; background:none; text-align:center; } + +/* Block: Login */ +.block-login .block-content { padding:5px 10px; } +.block-login label { font-weight:bold; color:#555; } +.block-login input.input-text { display:block; width:167px; margin:3px 0; } +.block-login .actions { background:none; padding:0; margin:3px 0 0; } + +/* Paypal */ +.sidebar .paypal-logo { display:block; margin:10px 0; text-align:center; } +.sidebar .paypal-logo a { float:none; } +/* ======================================================================================= */ + + +/* Category Page ========================================================================= */ +.category-title { } +.category-title h1 { } +.category-image { width:100%; overflow:hidden; margin:0 0 18px; text-align:center; } +.category-image img { max-width: 100%; } +.category-description { margin:0 0 18px; } +.category-products {} + +/* View Type: Grid */ +.products-grid { position:relative; } +.products-grid.last { border-bottom:0; } +ul.products-grid { margin: 18px -20px; } +.products-grid li.item { display: inline-block; vertical-align: top; width:195px; margin-left: 20px; padding-bottom:18px; border:1px solid #eaeaea;background:#fafafa;padding:10px;margin-bottom:15px;min-height:290px;} +.pro_topadst {min-height:320px;} +.products-grid li.item:hover {background:#e9e9e9;-webkit-transition: all 500ms ease-in-out; +-moz-transition: all 500ms ease-in-out; +-ms-transition: all 500ms ease-in-out; +-o-transition: all 500ms ease-in-out; +transition: all 500ms ease-in-out;} +.products-grid li.last { margin-right: 0; } +.products-grid .product-image { display: block; margin-bottom: 2px; } +.products-grid .product-image img { display:block; height: auto; max-width: 100%; width: auto; /* Prevents scaling problem in IE8; */ margin:0 0; } +.products-grid .product-image img:hover { opacity: 0.9; } +.products-grid.first .product-image { border-top:0; } +.products-grid li.last .product-image { border-right:0; } +.products-grid .product-name { font-size:12px; margin: 0; min-height:36px;} +.products-grid .product-name a { color:#444; text-transform: uppercase; letter-spacing: 0.1em; } +.products-grid .product-name a:hover { text-decoration:none; } +.products-grid .price-box { margin:9px 0; } +.products-grid .availability { line-height:21px; } +.products-grid .actions { bottom: 0; } +.col2-left-layout .products-grid, +.col2-right-layout .products-grid { } +.col1-layout .products-grid, +.page-empty .products-grid { } + +/* View Type: List */ +.products-list li.item { border-bottom:1px solid #d9ddd3; padding:12px 10px; } +.products-list li.item.last { border-bottom:0; } +.products-list .product-shop { margin-left:185px; } +.products-list .product-image { } +.products-list .product-image img { float:left; width:170px; height:170px; margin:0 0 10px; } +.products-list .product-name { font-size:12px; margin:0 0 6px; } +.products-list .product-name a { color:#444; text-decoration:underline; } +.products-list .product-name a:hover { text-decoration:none; } +.products-list .price-box { float:left; margin:4px 13px 0 0; } +.products-list .availability { float:left; margin:3px 0 0; } +.products-list .desc { clear:both; padding:6px 0 0; margin:0 0 13px; line-height:1.35; } +.products-list .add-to-links { clear:both; } +/* ======================================================================================= */ +/* ===================accordian */ +.faq_accordian{margin:0;padding:0;} +.faq_right{ + width:732px; + height:auto; + float:left; +} +.faq_banner{background:url(images/media_banner.png) no-repeat; + height:139px; + width:724px; + border-bottom:3px solid #fec00f; +} +.faq_banner h1 {font-family: quara-web; font-size:32px;color:#fec00f;margin-left:30px;margin-top:0px;padding-top:15px;font-weight:normal;text-transform:uppercase;} +.faq_banner p {width:330px;margin-left:30px;color:#cccccc;font-weight:bold;} +.faq_right h3 {padding-left:25px;font-weight:normal;} +.col-right { + float: right; +} + +.col3-layout .col-main {float:right;} +.col3-layout .col-wrapper {float:left;} +.col3-layout .grid_3 {margin:0;} +.col3-layout .grid_6 {width:490px;} +/*left menu */ + +.faq_accordian .arrowlistmenu{ +} + +.faq_accordian .arrowlistmenu .menuheader{ /*CSS class for menu headers in general (expanding or not!)*/ + background:url(../images/open_arrow.png) no-repeat scroll right 6px #FAFAFA; + color: #404040; + cursor: pointer; + font:bold 12px Arial, Helvetica, sans-serif; + margin: 10px 0 0; + padding:5px; + text-transform: none; + border:1px solid #eaeaea; + -webkit-border-radius: 5px; +-moz-border-radius: 5px; +border-radius: 5px; +} + + +.faq_accordian .arrowlistmenu .openheader{ /*CSS class to apply to expandable header when it's expanded*/ +background: url(../images/down_arrow.png) no-repeat scroll right 10px #fafafa; +border:1px solid #eaeaea; +color:#000; +} + +.faq_accordian .arrowlistmenu ul{ /*CSS for UL of each sub menu*/ +list-style-type: none; +margin: 0; +padding: 0; +margin-bottom: 8px; /*bottom spacing between each UL and rest of content*/ + background:#fff; + border:1px solid #eaeaea; + -webkit-border-radius: 5px; +-moz-border-radius: 5px; +border-radius: 5px; +padding:10px; +} + +.faq_accordian .arrowlistmenu ul li{ + color: #404040; + display: block; + font-family: Arial,Helvetica,sans-serif; + font-size: 12px; + text-decoration: none; + line-height:21px; +} +.faq_accordian .arrowlistmenu ul li p{ + display: block; + font-family: Arial,Helvetica,sans-serif; + font-size: 14px; + text-decoration: none; + line-height:21px;} + +.faq_accordian .arrowlistmenu ul li a{ +color:#666 !important; +} + +.faq_accordian .arrowlistmenu ul li a:visited{ +color:#cccccc; +} + +.faq_accordian .arrowlistmenu ul li a:hover{ /*hover state CSS*/ +color:#404040; +} + +/* Product View ========================================================================== */ +/* Rating */ +.no-rating { margin:0; } + +.ratings { margin:9px 0; } +.ratings strong { float:left; margin:0 3px 0 0; } +.ratings .rating-links { margin:0; } +.ratings .rating-links .separator { margin:0 2px; } +.ratings dt {} +.ratings dd {} +.rating-box { width:50px; height:10px; margin-bottom: 8px; font-size:0; line-height:0; background:url(../images/bkg_rating.gif) 0 0 repeat-x; text-indent:-999em; overflow:hidden; } +.rating-box .rating { float:left; height:10px; background:url(../images/bkg_rating.gif) 0 100% repeat-x; } +.ratings .rating-box { float:left; margin:5px 5px 0 0; } +.ratings .amount {} + +.ratings-table th, +.ratings-table td { font-size:11px; line-height:1.15; padding:3px 0; } +.ratings-table th { font-weight:bold; padding-right:8px; } +.ratings-table td { padding:4px 0 0; } + +/* Availability */ +.availability { margin:0; } +.availability span { font-weight:bold; } +.availability.in-stock span {} +.availability.out-of-stock span { color:#d83820; } + +.availability-only { margin:10px 0 7px; line-height:16px; background:url(../images/i_availability_only.gif) 0 50% no-repeat; padding-left:15px; } +.availability-only span, +.availability-only a { border-bottom:1px dashed #751d02; color:#000; } +.availability-only a { background:url(../images/i_availability_only_arrow.gif) 100% 0 no-repeat; cursor:pointer; padding-right:15px; text-decoration:none; } +.availability-only .expanded { background-position:100% -15px; } +.availability-only strong { color:#be2c00; } + +.availability-only-details { margin:0 0 7px; } +.availability-only-details th { background:#e9e9e9; font-size:10px; padding:0 8px; } +.availability-only-details td { border-bottom:1px solid #d9dde3; font-size:11px; padding:2px 8px 1px; } +.availability-only-details tr.odd { background:#fff; } +.availability-only-details tr.even { background:#fcfcfc; } +.availability-only-details tr.odd td.last { color:#396f00; font-weight:bold; } +.availability-only-details tr.last td { border-bottom:none; } + +.product-view .product-shop .availability { font-size:11px; line-height: 1.63636636363;} +.product-view .product-shop .availability span { font-weight:normal; } + +/* Email to a Friend */ +.email-friend { margin:0; } + +.clients-logo { + background: none repeat scroll 0 0 #FFFFFF; + border: 1px solid #D0CFCF; + margin: 10px auto; + padding: 10px; + text-align:center; + } + .f-gray { + background: none repeat scroll 0 0 #000000; + margin: 0 auto; + text-align: left !important; +} + +.f-gray p{ + font-family: Arial; + font-style:italic; + font-weight:bold; + font-size: 14px; + color: #D9D9D9; + margin: 0 auto; + text-align: center !important; +} + +.footer ul { + padding: 10px 0; + list-style-type:disc; +} +.f-gray h3 { + color: #FFFFFF; + margin:0 0 5px 0; +} +.f-gray-links li { + background: none repeat scroll 0 0 transparent; + line-height: 180%; +} +.footer a { + color: #B1B1B1 !important; +} +.f-gray-links1{ + margin : 10px 0; + text-align: center; +} +.f-gray-links1 li{ + list-style:none +} +.f-gray-links1 a { + margin-bottom:10px; + display:table; + display:inline-block; +} +.header .top-promo p { + color: #929292; + font-size: 12px; + font-weight: bold; + padding: 2px 18px 0 0; + width: 120px; +} +/* Alerts */ +.alert-price { margin:0; font-size:11px; } +.alert-stock { margin:0; font-size:11px; } + +/********** < Product Prices */ +.price { white-space:nowrap !important; } + +.price-box { margin:9px 0; } +.price-box .price { font-size:11px; font-weight:bold; line-height: 1.63636363636 } + +/* Regular price */ +.regular-price {} +.regular-price .price { font-size:13px; font-weight:bold;} + +/* Old price */ +.old-price { margin:0; } +.old-price .price-label { font-size:12px; font-weight:bold; white-space:nowrap; } +.old-price .price { font-weight:bold; font-size:13px; text-decoration:line-through; } + +/* Special price */ +.special-price { margin:0; } +.special-price .price-label { font-size:11px; font-weight:bold; text-transform:uppercase; white-space:nowrap; color:#000; } +.special-price .price { font-size:13px; font-weight:bold; } + +/* Minimal price (as low as) */ +.minimal-price { margin:0; } +.minimal-price .price-label { font-size:12px; font-weight:bold; white-space:nowrap; } + +.minimal-price-link { display:block; font-size:12px; text-decoration:underline; } +.minimal-price-link .label { } +.minimal-price-link .price { font-weight:normal; } + +/* Including tax */ +.price-including-tax { display:block; color:#888; } +.price-including-tax .label { font-size:10px; text-transform:uppercase; white-space:nowrap; color:#888; } +.price-including-tax .price { font-size:13px; font-weight:bold; color:#396f00; } + +/* Excluding tax */ +.price-excluding-tax { display:block; color:#888; } +.price-excluding-tax .label { font-size:10px; text-transform:uppercase; white-space:nowrap; color:#888; } +.price-excluding-tax .price { font-size:12px; font-weight:normal; color:#396f00; } + +/* Configured price */ +.configured-price { margin:0; } +.configured-price .price-label { font-weight:bold; white-space:nowrap; } +.configured-price .price { font-size:13px; font-weight:bold; } + +/* Incl tax (for order tables) */ +.price-incl-tax { display:block; } +.price-incl-tax .label { display:block; white-space:nowrap; } +.price-incl-tax .price { display:block; font-weight:bold; } + +/* Excl tax (for order tables) */ +.price-excl-tax { display:block; } +.price-excl-tax .label { display:block; white-space:nowrap; } +.price-excl-tax .price { display:block; font-weight:normal; } + +/* FPT */ +.weee { display:block; font-size:11px; color:#444; } +.weee .price { font-size:11px; font-weight:normal; } + +/* Price range */ +.price-from { margin:0; } +.price-from .price-label { font-size:12px; font-weight:bold; white-space:nowrap; } + +.price-to { margin:0; } +.price-to .price-label { font-size:12px; font-weight:bold; white-space:nowrap; } + +/* Price notice next to the options */ +.price-notice { padding-left:7px; } +.price-notice .price { font-weight:bold; } + +/* Price as configured */ +.price-as-configured { margin:0; } +.price-as-configured .price-label { font-weight:bold; white-space:nowrap; text-transform:uppercase; } + +.price-box-bundle { padding: 9px 0; } +.price-box-bundle .price-box { margin:0 !important; padding:0 !important; } +.price-box-bundle .price { color:#222; } +f/********** Product Prices > */ + +/* Tier Prices */ +.tier-prices { margin:10px 0; padding:10px; background:#f4f9ea; border:1px solid #ddd; } +.tier-prices .benefit { font-style:italic; font-weight:bold; } +.tier-prices .price { font-weight:bold;; } + +.tier-prices-grouped li .price { font-weight:bold; } + +/* Add to Links */ +.add-to-links { } +.add-to-links li { margin: 9px 0;float:left; } +.add-to-links li a { color:#444; } +.add-to-links .separator {} + +.product-options-bottom .add-to-cart{float:left;display:inline-block;} + +/* Add to Cart */ +.add-to-cart { padding: 9px 0;} +.add-to-cart label { margin-right:5px; font-weight:bold; line-height:20px; color:#555; } +.add-to-cart .qty { margin-right:5px; } +.add-to-cart button.button { margin: 0; } +.add-to-cart .paypal-logo { clear:left; margin:0; text-align:right; } +.add-to-cart .paypal-logo .paypal-or { clear:both; display:block; margin:5px 60px 5px 0; } + +/* Add to Links + Add to Cart */ +.add-to-box { margin:10px 0; } +.add-to-box .add-to-cart { margin:10px 0; border:1px solid #eee; background-color:#f8f8f8; padding:10px; text-align:right; } +.add-to-box .add-to-cart .paypal-logo { float:right; } +.add-to-box .or { display:none !important; } +.add-to-box .add-to-links { margin:10px 0; text-align:right; } +.add-to-box .add-to-links li .separator { display:none !important; } + + +.product-view {} + +.product-essential { padding:0 0 25px; } +.product-essential h2 { } + +.product-collateral {} +.product-collateral h2 { font-size:19px; font-weight:normal; line-height:1.15; } +.product-collateral .box-collateral {} + +/* Product Images */ +.col1-layout .product-view .product-img-box { float:left; width:460px; } +.col2-left-layout .product-view .product-img-box, .col2-right .product-view .product-img-box { width: 100%; } +.product-view .product-img-box .product-image { margin:0 0 10px; border:1px solid #cacaca; } +.product-view .product-img-box .product-image-zoom { position:relative; width:300px; height:300px; overflow:hidden; z-index:9; } +.product-view .product-img-box .product-image-zoom img { position:absolute; left:0; top:0; cursor:move; } +.product-view .product-img-box .zoom-notice { margin:0 0 10px; text-align:center; } +.product-view .product-img-box .zoom { position:relative; z-index:9; height:24px; margin:0 auto 13px; padding:0 28px; background:url(../images/slider_bg.gif) 50% 50% no-repeat; cursor:pointer; } +.product-view .product-img-box .zoom.disabled { -moz-opacity:.3; -webkit-opacity:.3; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=30)";/*IE8*/ opacity:.3; } +.product-view .product-img-box .zoom #track { position:relative; height:18px; } +.product-view .product-img-box .zoom #handle { position:absolute; left:0; top:3px; width:9px; height:18px; background:url(../images/magnifier_handle.gif) 0 0 no-repeat; } +.product-view .product-img-box .zoom .btn-zoom-out { position:absolute; left:10px; top:7px; } +.product-view .product-img-box .zoom .btn-zoom-in { position:absolute; right:10px; top:7px; } +.product-view .product-img-box .more-views h2 { font-size:10px; font-weight:normal; padding:0 0 2px; border-bottom:1px solid #ccc; margin:0 0 8px; text-transform:uppercase; } +.product-view .product-img-box .more-views ul { margin-left:-10px } +.product-view .product-img-box .more-views li { float:left; margin:0 0 8px 10px; } +.product-view .product-img-box .more-views li a { float:left; width:66px; height:66px; border:1px solid #ddd; overflow:hidden; } + +.product-image-popup { margin:0 auto; } +.product-image-popup .buttons-set { border:1px solid ##F2F2F2; margin:18px 0; padding:9px; } +.product-image-popup .nav { font-weight:bold; margin:0 100px; text-align:center; } +.product-image-popup .image { display:block; margin:10px 0; } +.product-image-popup .image-label { font-size:12px; font-weight:bold; margin:0 0 10px; color:#2f2f2f; } + +/* Product Shop */ +.col1-layout .product-view .product-shop { float:right; width:460px; } +.col2-left-layout .product-view .product-shop, .col2-right .product-view .product-shop { width: 100%; } +.product-view .product-shop .product-name { margin:0 0 5px; } +.product-view .product-shop .product-name h1 { font:bold 13px/1.384615385 ColaborateRegular, helvetica, arial, sans-serif; } +.product-view .product-shop .availability { margin:9px 0; } +.product-view .product-shop .short-description { margin:9px 0; } +.product-view .product-shop .price-box { margin:9px 0; } +.product-view .product-shop .add-to-links { margin:0; } +.product-view .product-shop .add-to-links { text-align:right; margin-top:5px;} +.product-view .product-shop .add-to-links li { display:inline; margin-left:12px; } +.product-view .product-shop .add-to-links li .separator { display:none !important; } +.product-view .product-shop .product-options-bottom .paypal-logo { float:left; } + +/* Product Options */ +.product-options { margin:18px 0 0; padding:0 15px 10px; background: #FAFAFA; position:relative; } +.product-options .toggle { cursor: pointer; } +.product-options dt { padding:10px 0 0; font-weight:normal; } +.product-options dt label { font-weight:bold; } +.product-options dt label.required em { color:#eb340a; margin-right:5px; } +.product-options dd .qty-holder { display:block; padding:10px 0 0; } +.product-options dd .qty-holder label { vertical-align:middle; } +.product-options dd .qty-disabled { background:none; border:0; padding:3px; color:#444; } +.product-options dd { padding:5px 10px 15px; margin:0 0 5px; border-bottom:1px solid #ddd; } +.product-options dl.last dd.last { border-bottom:0; padding-bottom:5px; margin-bottom:0; } +.product-options dd input.input-text { background: #fff; } +.product-options dd input.datetime-picker { width:150px; } +.product-options dd .time-picker { display:-moz-inline-box; display:inline-block; padding:2px 0; vertical-align:middle; } +.product-options dd textarea { height:8em; background: #fff; } +.product-options dd select { background: #fff; } +.product-options dd .multiselect option { border-bottom:1px dotted #d9e5ee; padding:2px 4px; } +.product-options ul.options-list { margin-right:5px; } +.product-options ul.options-list li { padding:2px 0; } +.product-options ul.options-list input.radio { float:left; margin-top:3px; } +.product-options ul.options-list input.checkbox { float:left; margin-top:2px; } +.product-options ul.options-list .label { display:block; margin-left:18px; } +.product-options ul.options-list label { font-weight:normal; } +.product-options ul.validation-failed { padding:0 7px; } +.product-options p.required { position:absolute; right:15px; top:0px; } + +.product-options-bottom { background-color:#eAEAEA; padding:15px 20px; border-top:1px solid #e4e4e4; } +.product-options-bottom .tier-prices { margin:0; padding:0 0 10px; border:0; background:0; } +.product-options-bottom .price-box { float:left; margin:0; } +.product-options-bottom .add-to-links {text-align:right; } +.product-options-bottom .price-label { padding-right:5px; } +.product-options-bottom .price-tax { float:left; } +.product-options-bottom .add-to-cart { float:right; margin:0; padding:9px 0; border:0; background:0; } +.product-options-bottom .add-to-links { float:right; display:inline;margin-right:10px;} + +.product-shop .product-options-bottom .price-box { float:none; margin:0; } +.product-shop .product-options-bottom .price-label { float:none; padding-right:0; } +.product-shop .product-options-bottom .price-tax { float:none; } +.product-shop .product-options-bottom .add-to-cart { clear:both; float:none; padding:12px 0 0; text-align:left; } + +/* Grouped Product */ +.product-view .grouped-items-table .price-box { margin:0; padding:0; } + +/* Product Tabs */ +ul.product-tabs{ border-bottom: 1px solid #DDDDDD; display: block; margin: 0 0 18px; padding: 0; } +.product-tabs li { display: block; float: left; height: 35px; margin-bottom: 0; padding: 0; width: auto; } +.product-tabs li.first { } +.product-tabs li.last { } +.product-tabs li.first a { border-top-left-radius: 2px; border-width: 1px 1px 0;} +.product-tabs li.last a { border-top-right-radius: 2px; } +.product-tabs a { background: #F5F5F5; border-color: #DDDDDD; border-style: solid; border-width: 1px 1px 0 0; display: block; font-size: 13px; height: 35px; +line-height: 36px; margin: 0; padding: 0 20px; text-decoration: none; width: auto;} +.product-tabs a:hover { background-color:#ddd; text-decoration:none; color:#444; } +.product-tabs li.active a, +.product-tabs li.active a:hover { background: none repeat scroll 0 0 #FFFFFF; border-left-width: 1px; border-top-left-radius: 2px; border-top-right-radius: 2px; color: #111111; height: 36px; margin: 0 0 0 -1px; padding-top: 4px; position: relative; top: -4px;} +.product-tabs-content h2 { display:none; font-size:12px; font-weight:bold; } + +/* Mini Products Grid */ +.mini-products-grid { margin: 18px -20px; } +.mini-products-grid li { float: left; margin-left: 20px; width: 160px; } +.mini-products-grid .product-image { display:block; margin:0 0 18px; } +.mini-products-grid .product-name { overflow:hidden; margin-bottom: 0;} +.mini-products-grid .product-name a { color:#444; text-decoration:underline; } +.mini-products-grid .product-name a:hover { text-decoration:none; } +.mini-products-grid li.empty {} +.mini-products-grid li.last { padding-right:0; } +.mini-products-grid .ratings .rating-box { float:none; display:block; margin:0 0 3px; } + +/* Block: Description */ +.product-view .box-description {} + +/* Block: Additional */ +.product-view .box-additional .data-table th, +.product-view .box-additional .data-table td { line-height:1.25; } + +/* Block: Upsell */ +.product-view .box-up-sell h2 { margin:0 0 8px; } +#product_tabs_upsell_products_contents h2 { display:block; } + +/* Block: Tags */ +.product-view .box-tags { margin:0; } +.product-view .box-tags h3 { font-size:12px; } +.product-view .box-tags .product-tags { display:block; margin:0 0 15px; } +.product-view .box-tags .product-tags li { display:inline; background:url(../images/bkg_pipe3.gif) 100% 4px no-repeat; padding:0 7px 0 4px; } +.product-view .box-tags .product-tags li.first { padding-left:0; } +.product-view .box-tags .product-tags li.last { background:none; padding-right:0; } +.product-view .box-tags .form-add label { display:block; font-size:12px; font-weight:bold; margin:0 0 3px; } +.product-view .box-tags .form-add .input-box { margin:9px 0; width: 460px; } +.product-view .box-tags .form-add { width:100%; } +.product-view .box-tags .form-add input.input-text { } +.product-view .box-tags .form-add button.button { clear: both; } +.product-view .box-tags .form-add button.button span { } +.product-view .box-tags .note { margin:2px 0 0; font-size:10px; } + +/* Block: Reviews */ +.product-view .box-reviews dl { margin:18px 0; } +.product-view .box-reviews dt a, +.product-view .box-reviews dt span { font-weight:bold; } +.product-view .box-reviews dd { margin:0 0 18px; } +.product-view .box-reviews dd small { font-style:italic; } +.product-view .box-reviews .form-add { margin:18px 0 0; } +.product-view .box-reviews .form-add h3 { font-size:13px; font-weight:normal; } +.product-view .box-reviews .form-add h3 span { font-weight:bold; } +.product-view .box-reviews .form-add h4 { font-size:12px; } +.product-view .box-reviews .form-add .data-table td { text-align:center; } +.product-view .box-reviews .form-add .form-list { } +.product-view .box-reviews .form-add .form-list .input-box { } +.product-view .box-reviews .form-add .form-list input.input-text, +.product-view .box-reviews .form-add .form-list textarea { } + +/* Send a Friend */ +.send-friend .form-list { overflow:hidden; } +.send-friend .form-list li { margin-right:-15px; } +.send-friend .form-list li p { margin:9px 0; } +.send-friend .buttons-set .limit { float:right; margin:0 7px 0 0; font-size:11px; line-height:25px; } +/* ======================================================================================= */ + + +/* Content Styles ================================================================= */ +.product-name { font-family: colaborateregular, helvetica, arial, sans-serif; font-size: 12px; font-weight: normal; line-height: 1.5;} +/*.product-name a { color:#444; }*/ + +/* Product Tags */ +.tags-list { display:block; font-size:13px; border:1px solid #ddd; background:#f6f6f6; padding:10px; } +.tags-list li { display:inline !important; margin:0 4px 0 0; } +.tags-list li a { color:#1b2d3b; } + +/* Advanced Search */ +.advanced-search .form-list label { } +.advanced-search .form-list .input-box, +.advanced-search .form-list .input-range {} +.advanced-search-amount { margin:0 0 10px; } +.advanced-search-summary { margin:10px 0; border:1px solid #ddd; background:#ecf9ea; padding:10px; } +.advanced-search-summary ul { float:left; width:49%; } +.advanced-search-summary strong { color:#E17C24; } +.advanced-search-summary li { margin:2px 0; } +.advanced-search-summary p { clear:both; font-weight:bold; margin:9px 0; } + +/* CMS Home Page */ +.cms-home .main { } +.cms-home .subtitle {} +.cms-index-index .subtitle {} +.cms-home .home-tabs { margin-top: 36px; clear: both; } +.cms-home .product-tabs { } +.cms-home .products-grid .product-name { display: block; font-family: ColaborateRegular, helvetica, arial, sans-serif; font-weight: normal; line-height: 18px; } +.cms-home .products-grid li.item { position: relative; } +.cms-home .products-grid .price-box { color: #000; } +.cms-home .products-grid .minimal-price-link { color: #fff; } +.cms-home .home-tabs .tabs-title { } +.cms-home .home-tabs .tabs-title strong { float: left; font-size: 36px; font-weight: normal; margin-right: 20px; font-family: ColaborateThinRegular, helvetica, arial, sans-serif; line-height: 36px;} + +/* Sitemap */ +.page-sitemap .links { text-align:right; margin:0 8px -22px 0; } +.page-sitemap .links a { text-decoration:none; position:relative; } +.page-sitemap .links a:hover { text-decoration:underline; } +.page-sitemap .sitemap { margin:12px; } +.page-sitemap .sitemap a { color:#444; } +.page-sitemap .sitemap li { margin:3px 0; } +.page-sitemap .sitemap li.level-0 { margin:10px 0 0; font-weight:bold; } +.page-sitemap .sitemap li.level-0 a { color:#4f8100; } + +/* RSS */ +.rss-title h1 { background:url(../images/i_rss-big.png) 0 3px no-repeat; padding-left:27px; } +.rss-table .link-rss { display:block; line-height:1.55; background-position:0 4px; } +/* ======================================================================================= */ + + +/* Shopping Cart ========================================================================= */ +.cart .page-title {} +.cart > .checkout-types { text-align: right;margin-bottom:10px; } +.chk_cartbtn {margin:10px 0;float:right;} +/* Checkout Types */ +.cart .page-title .checkout-types { display:none !important; } +.cart .checkout-types .paypal-or { margin:0 8px; line-height:2.3; } +.cart .totals .checkout-types .paypal-or { clear:both; display:block; padding:8px 55px 0 0; line-height:1.0; font-size:11px; } + +/* Shopping Cart Table */ +.cart-table-wrap { overflow: auto; } +.cart-table th { padding:9px 10px; } +.cart-table td { padding:9px; } +.cart-table .product-name { font-weight:bold; margin:0; color:#444; } +.cart-table .item-msg { margin:9px 0; font-size:11px; font-weight:bold; color:#df280a; line-height: 1.6363636363} +.cart-table tfoot td { padding:9px 10px; } +.cart-table .btn-continue { float:left; } +.cart-table .btn-continue span { } +.cart-table .btn-continue:hover span { } +.cart-table .btn-update span {} + +/* Shopping Cart Collateral boxes */ +.cart .cart-collaterals { padding:18px 0 0; } +.cart .cart-collaterals .col2-set .col-1 { width:222px; } +.cart .cart-collaterals .col2-set .col-2 { width:655px; background:#e6f7d7; } + + +ul.crosssell-products-list { margin: 10px auto; } +.cart .crosssell { border:1px solid #ddd; background:#f7f7f7; padding:10px; clear: both;} +.cart .crosssell h2 { font-size:12px; font-weight:bold; } +.cart .crosssell .product-image { float:left; width:120px; height:120px; } +.cart .crosssell .product-details { } +.cart .crosssell .product-name { font-weight:bold;min-height:36px; } +.cart .crosssell li.item { margin:0 0 8px; padding-bottom:5px; display: inline-block; vertical-align: top; width: 220px; } +.cart .crosssell li.last { border-bottom:0; padding-bottom:0; margin:0; } +.cart .crosssell .link-compare { font-weight:normal; } +.cart .no-crosssell { width:100%; overflow:hidden; } +.cart .no-crosssell img { display:block; margin:0 0 10px; } + +/* Discount Codes & Estimate Shipping and Tax Boxes */ +.collat-wrap { float: left; width: 100%; } + +.cart div.discount, +.cart div.shipping { } +.cart .discount h2, +.cart .shipping h2 { width:225px; font:normal 14px/16px Arial, Helvetica, sans-serif; text-transform: uppercase; font-weight: bold; } +.cart .discount .discount-form, +.cart .shipping .shipping-form { } +.cart .discount .buttons-set, +.cart .shipping .buttons-set { } +.cart .discount .buttons-set button.button, +.cart .shipping .buttons-set button.button { float:none; margin:0; } +.cart .discount .buttons-set button.button span, +.cart .shipping .buttons-set button.button span { } +.cart .discount .buttons-set button.button span span, +.cart .shipping .buttons-set button.button span span { } + +.cart .discount { border-bottom:1px solid #c0d2af ; margin-right: 24px; } +.cart .discount label { font-weight:bold; color:#555; } +.cart .discount .input-box { } +.cart .discount input.input-text { width: 85%; } + +.cart .shipping p { margin:9px 0; } +.cart .shipping .sp-methods { margin:10px 0 0; padding:6px 0 0; border-top:1px solid #c0d2af; } +.cart .shipping .form-list .input-box { } +.cart .shipping .form-list input.input-text { } +.cart .shipping .form-list select { } + +/* Shopping Cart Totals */ +.crosssell-wrap {} + +.cart .totals { width:265px !important;} +.cart .totals table { float:right; margin:9px 0; width: 100%; } +.cart .totals td { border-bottom: 1px solid; margin: 9px 0 8px 15px; padding: 9px 10px 8px 0; } +.cart .totals tr.last td {} +.cart .totals tfoot td {} +.cart .totals tfoot th strong, +.cart .totals tfoot td strong { font-size:14px; line-height: 1.285714286; font-weight:bold; } +.cart .totals .checkout-types { text-align:right; } +.cart .totals .checkout-types li { clear:both; margin:9px 0; } + +/* Options Tool Tip */ +.item-options dt { font-weight:bold; font-style:italic; } +.item-options dd { padding-left:10px; } +.truncated { cursor:help; } +.truncated a.dots { cursor:help; text-decoration:none !important; } +.truncated a.details { cursor:help; text-decoration:none !important; display:inline-block; border-bottom:1px dotted #4f8100; } +.truncated .truncated_full_value { position:relative; z-index:999; } +.truncated .truncated_full_value .item-options { position:absolute; top:-99999em; z-index:999; width:250px; padding:8px; border:2px solid #ddd; border-bottom-color:#666; background-color:#f6f6f6; } +.truncated .truncated_full_value .item-options dt { margin-top:0; } +.truncated .truncated_full_value .item-options > p { font-weight:bold; text-transform:uppercase; } +.truncated .show .item-options { top:-20px; left:50%; } +.col-left .truncated .show .item-options { left:30px; top:10px; } +.col-right .truncated .show .item-options { left:-240px; top:10px; } +/* ======================================================================================= */ + + +/* Checkout ============================================================================== */ +/********** < Common Checkout Styles */ +/* Shipping and Payment methods */ +.sp-methods { margin:0 0 8px; } +.sp-methods dt { margin:13px 0 5px; font-weight:bold; } +.sp-methods dd {} +.sp-methods dd li { margin:9px 0; } +.sp-methods label { font-weight:bold; color:#555; } +.sp-methods .price { font-weight:bold; } +.sp-methods .form-list { padding-left:20px; } +.sp-methods .form-list li { margin: 0 10px 8px 0; } +.sp-methods select.month { width:154px; margin-right:10px; } +.sp-methods select.year { width:96px; } +.sp-methods input.cvv { width:3em !important; } + +.sp-methods .checkmo-list li { margin:0 0 5px; } +.sp-methods .checkmo-list label { width:135px; padding-right:10px; text-align:right; } +.sp-methods .checkmo-list address { float:left; } + +.sp-methods .centinel-logos a { margin-right:3px; } +.sp-methods .centinel-logos img { vertical-align:middle; } + +.sp-methods .release-amounts { margin:1.5em 0 2em; } +.sp-methods .release-amounts button { float:left; margin:5px 10px 0 0; } + +.please-wait { float:right; } +.please-wait img { vertical-align:middle; } +.cvv-what-is-this { font-size:11px; cursor:help; margin-left:10px; } + +/* Tooltip */ +.tool-tip { border:2px solid #ddd; border-bottom-color:#666; background:#f6f6f6; padding:15px 20px; position:absolute; z-index:9999; } +.tool-tip .btn-close { margin:-9px -14px 0; text-align:right; } +.tool-tip .btn-close a { display:block; margin:0 0 0 auto; width:12px; height:12px; background:url(../images/btn_window_close.gif) 100% 0 no-repeat; text-align:left; text-indent:-999em; overflow:hidden; } +.tool-tip .tool-tip-content { padding:5px; } + +/* Gift Messages */ +.gift-messages h3 { font-size:12px; font-weight:bold; color:#e87403; } +.gift-messages p.control { color:#8e8d8b; } +.gift-messages-form { position:relative; } +.gift-messages-form label { float:none !important; position:static !important; } +.gift-messages-form h4 { font-size:12px; font-weight:bold; color:#e87403; } +.gift-messages-form .whole-order { margin:0 0 25px; } +.gift-messages-form .item { margin:0 0 10px; } +.gift-messages-form .item .product-img-box { float:left; width:75px; } +.gift-messages-form .item .product-image { margin:0 0 7px; } +.gift-messages-form .item .number { margin:0; font-weight:bold; text-align:center; color:#8a8987; } +.gift-messages-form .item .details { margin-left:90px; } +.gift-messages-form .item .details .product-name { font-size:13px; font-weight:bold; margin:0 0 10px; } +.gift-messages-form .item .details .form-list .field { width:255px; } +.gift-messages-form .item .details .form-list .input-box { width:240px; } +.gift-messages-form .item .details .form-list input.input-text { width:234px; } +.gift-messages-form .item .details .form-list li.wide .input-box { width:500px; } +.gift-messages-form .item .details .form-list li.wide textarea { width:494px; } + +.gift-message-link { font-size:11px; background:url(../images/bkg_collapse-gm.gif) 100% 6px no-repeat; padding-right:7px; } +.gift-message-link.expanded { background-position:100% -40px; } +.gift-message-row { background:#f2efe9; } +.gift-message-row .btn-close { float:right; width:12px; height:12px; background:url(../images/btn_remove.gif) 0 0 no-repeat; font-size:0; line-height:0; text-indent:-999em; overflow:hidden; } + +/* Checkout Agreements */ +.checkout-agreements li { margin:30px 0; } +.checkout-agreements .agreement-content { overflow:auto; height:12em; padding:10px; background:#fbfbfb; border:1px solid #e4e4e4; } +.checkout-agreements .agree { margin:0; padding:10px 0 10px 11px; } +.checkout-agreements .agree input.checkbox { margin-right:6px; } +.checkout-agreements .agree label { font-weight:bold; color:#555; } + +.opc .checkout-agreements { padding:5px 30px; } +.opc .checkout-agreements li { margin:20px 0 0; } +.opc .checkout-agreements .agreement-content { background:#fff; padding:5px; } +.opc .checkout-agreements .agree { padding-left:6px; } + +/* Centinel */ +.centinel {} +.centinel .authentication { border:1px solid #ddd; background:#fff; } +.centinel .authentication iframe { width:99%; height:400px; background:transparent !important; margin:0 !important; padding:0 !important; border:0 !important; } + +.opc .centinel { padding:10px 30px; } + +/* Generic Info Set */ +.info-set { background:#fbfbfb; border:1px solid #ddd; margin:0 0 25px; padding:20px; } +.info-set h2 { font-size:12px; font-weight:bold; margin:0 0 10px; } +.info-set h3, +.info-set h4 { font-size:12px; font-weight:bold; } +.info-set h2 a, +.info-set h3 a, +.info-set h4 a { font-weight:normal; } +.info-set h2.legend { margin:-20px -20px 15px; padding:3px 10px; background:#777; border-bottom:1px solid #777; position:relative; color:#fff; } +.info-set h2.legend a { color:#fff; } +.info-set h3.legend { margin:0 0 10px; } +.info-set .divider { margin:0 -20px; padding:25px 0; position:relative; } +.info-set .box { margin:0 0 15px; } +.info-set .box h2 { color:#e26703; } +.info-set .data-table .product-name { font-size:1em !important; font-weight:bold !important; color:#4f8100 !important; } +.info-set .data-table .product-name a { font-weight:bold !important; } +.info-set .data-table .item-options { margin:5px 0 0; } +/********** Common Checkout Styles > */ + +/* One Page Checkout */ + +.checkout-onepage-index .col-main { float: left; padding-left: 10px;} +.checkout-onepage-index .col-left { float: right; margin-left; 20px; } + + +.block-progress { /*border:0; margin:0;*/ } +.block-progress .block-title {/* background:none; border:0; padding:0;*/ } +.block-progress .block-title strong { font-size:12px; } +.block-progress .block-content { /*background:none; padding:0;*/ } +.block-progress dt { font-size:14px; line-height:1.285714286; margin:9px 0; text-transform:uppercase; } +.block-progress dt:before { content: "// "; } + +.block-progress dd { border-top:0; padding:9px 10px; margin:9px 0; } +.block-progress dt.complete {} +.block-progress dt.complete a { text-transform:none; } +.block-progress dd.complete {} +.block-progress p { margin:9px 0; } +.block-progress .cards-list dt { background:none; border:0 none; color:inherit; font-size:11px; line-height: 1.636363636; font-weight:bold; margin:9px 0; padding:0; text-transform:none; } +.block-progress .cards-list dd { border:0 none; margin:0; padding:0; } +.block-progress .cards-list .info-table th { font-weight:normal; } + +.opc .buttons-set { } +.opc .buttons-set p.required { margin:0; padding:0 10px 0; } +.opc .buttons-set.disabled button.button { display:none; } +.opc .buttons-set .please-wait { height:36px; line-height:36px; } +.opc .ul { list-style:disc outside; padding-left:18px; } + +.opc { position:relative; } +.opc li.section {} + +.opc .step-title { padding:9px 8px; text-align:right; border-bottom: 1px solid #ccc; } +.opc .step-title .number { float:left; padding:0 3px; margin:0 5px 0 0; font:normal 11px/1.63636363636 arial, helvetica, sans-serif; color:#444; position: relative; +top: 25px; } +.opc .step-title h2 { color: #999999; float: left; font-family: colaboratethinregular, helvetica, arial, sans-serif; font-size: 24px; letter-spacing: 0.1em; line-height: 1.5; margin: 0; text-transform: uppercase; margin-left: 20px;} +.opc .step-title a { display:none; float:right; font-size:11px; line-height:16px; } + +.opc .allow .step-title { cursor:pointer; } +.opc .allow .step-title .number {} +.opc .allow .step-title h2 { } +.opc .allow .step-title a { display:block; margin-top: 12px; text-transform:uppercase; } + +.opc .active .step-title { padding-bottom:9px; color:inherit; cursor:default; border-bottom: 1px solid #000; } +.opc .active .step-title .number {} +.opc .active .step-title h2 { color: #000; } +.opc .active .step-title a { display:none; } + +.opc .step { padding:18px 0; position:relative; } +.opc .step .tool-tip { right:30px; } + +#checkout-step-login .col2-set .col-1 { float: right; } +#checkout-step-login .col2-set .col-2 { float: left; } + +#opc-login h3 { font-size:13px; border-bottom:1px solid #e4e4e4; padding-bottom:2px; text-transform:uppercase; } +#opc-login h4 { font-size:1em; font-weight:bold; margin:0; color:#2f2f2f; } + +#opc-shipping_method .buttons-set { border-top:0; } +.opc .gift-messages-form { margin:0 -30px; background:#f4f4f4; border:1px solid #ddd; border-width:1px 0; padding:22px 24px 22px 30px; } +.opc .gift-messages-form .inner-box { padding:5px; height:260px; overflow:auto; } + +#opc-review .step { padding:0; } +#opc-review .product-name { font-weight:bold; } +#opc-review .item-options { margin:5px 0 0; } +#opc-review .buttons-set { border:1px solid ##F2F2F2; padding:9px; } +#opc-review .buttons-set p { margin:9px 5px 0 0; line-height:28px; } +#opc-review .buttons-set .please-wait { height:28px; line-height:28px; } +#opc-review .authentication { margin:0 auto; width:570px; } +#opc-review .warning-message { color:#222; font-weight:bold; text-align:center; padding:10px 10px 0; } + +/* Multiple Addresses Checkout */ +.checkout-progress { padding:0 90px; margin:0 0 20px; } +.checkout-progress li { float:left; width:19%; margin:0 3px 0 0; border-top:6px solid #999; padding:2px 0 0; font-weight:bold; text-align:center; color:#888; } +.checkout-progress li.active { border-top-color:#e96200; color:#e96200; } + +.multiple-checkout h2 { font-size:12px; font-weight:bold; margin:0 0 10px; } +.multiple-checkout h3, +.multiple-checkout h4 { font-size:12px; font-weight:bold; } +.multiple-checkout h2 a, +.multiple-checkout h3 a, +.multiple-checkout h4 a { font-weight:normal; } +.multiple-checkout .data-table .product-name { font-size:1em !important; font-weight:bold !important; color:#4f8100 !important; } +.multiple-checkout .data-table .product-name a { font-weight:bold !important; } +.multiple-checkout .data-table .item-options { margin:5px 0 0; } + +.multiple-checkout .gift-messages { margin:15px 0 0; } + +.multiple-checkout .tool-tip { top:50%; margin-top:-120px; right:20px; } + +.multiple-checkout .col2-set, +.multiple-checkout .col3-set { background:#fbfbfb; border:1px solid #ddd; margin:0 0 25px; padding:20px; } +.multiple-checkout .col2-set h2.legend { margin:-20px -20px 15px; padding:3px 10px; background:#777; border-bottom:1px solid #777; position:relative; color:#fff; } +.multiple-checkout .col2-set h3.legend { margin:0 0 10px; } +.multiple-checkout .col2-set .divider { margin:0 -20px; padding:25px 0; position:relative; } +.multiple-checkout .box { margin:0 0 15px; } + +.multiple-checkout .place-order .please-wait { float:right; padding:5px 10px 0 0; } +.multiple-checkout .place-order .grand-total { float:right; } +.multiple-checkout .place-order .grand-total .inner {} +.multiple-checkout .place-order .grand-total big { float:left; margin-right:12px; font-size:1.5em; font-weight:bold; line-height:28px; color:#e26703; } +.multiple-checkout .place-order .grand-total div { float:left; } + +/* Step 1 */ +#multiship-addresses-table td { padding:10px; } +#multiship-addresses-table tfoot td { padding:5px 10px; } + +/* Step 2 */ +.multiple-checkout .gift-messages-form .item .details .form-list { width:100%; overflow:hidden; } +.multiple-checkout .gift-messages-form .item .details .form-list li { margin-right:-15px; } +.multiple-checkout .gift-messages-form .item .details .form-list .field { width:230px; } +.multiple-checkout .gift-messages-form .item .details .form-list .input-box { width:215px; } +.multiple-checkout .gift-messages-form .item .details .form-list input.input-text { width:209px; } +.multiple-checkout .gift-messages-form .item .details .form-list li.wide .input-box { width:445px; } +.multiple-checkout .gift-messages-form .item .details .form-list li.wide textarea { width:439px; } +.checkout-multishipping-shipping .box-sp-methods { border:1px solid #ddd; background:#eee; padding:13px; position:relative; } +.checkout-multishipping-shipping .box-sp-methods .pointer { display:none; } + +/* Step 3 */ +.checkout-multishipping-billing .multiple-checkout { position:relative; } +/* ======================================================================================= */ + + +/* Account Login/Create Pages ============================================================ */ +.account-login .content { min-height:200px; padding:0 10px; } +.account-login .content h2 { font-size: 13px; line-height: 1.385; } +.account-login .buttons-set {} + +.account-create {} +/* Account Login/Create Pages ============================================================ */ + + +/* Remember Me Popup ===================================================================== */ +.window-overlay { background:url(../images/window_overlay.png) repeat; background:rgba(0, 0, 0, 0.35); position:absolute; top:0; left:0; height:100%; width:100%; z-index:990; } + +.remember-me label { float:none; margin:0 6px; } +.remember-me-popup { background:#fff; border:1px solid #888; border-bottom-color:#777; left:50%; top:50%; position:absolute; margin:-85px 0 0 -200px; width:400px; text-align:left; -moz-box-shadow:0 0 6px #999; -webkit-box-shadow:0 0 6px #999; box-shadow:0 0 6px #999; z-index:1000; } +.remember-me-popup h3 { background:#dedede; border-bottom:1px solid #ccc; color:#444; font-size:14px; margin:0; padding:7px 10px 5px; } +.remember-me-popup .remember-me-popup-head { position:relative; } +.remember-me-popup .remember-me-popup-head .remember-me-popup-close { background:url(../images/btn_window_close.gif) no-repeat; display:block; position:absolute; top:9px; right:7px; height:15px; width:15px; text-indent:-9999em; } +.remember-me-popup .remember-me-popup-body { border-top:1px solid #e6e6e6; padding:10px; } +.remember-me-popup .remember-me-popup-body a, +.remember-me-popup .remember-me-popup-body a span { display:inline-block; height:28px; background:transparent url(../images/bkg_btn.png) 0 0 no-repeat; padding:0 0 0 6px; font:bold 11px/25px Tahoma, Verdana, Arial, sans-serif; text-transform:uppercase; text-align:center; white-space:nowrap; color:#555; } +.remember-me-popup .remember-me-popup-body a span { background-position:100% 0; padding:0 15px 0 9px; } +/* Remember Me Popup ===================================================================== */ + + +/* My Account ============================================================================= */ +.my-account .title-buttons .link-rss { float:none; margin:0; } + +/********** < Dashboard */ +.dashboard .welcome-msg { margin:0 8em 1.5em 0; } +.dashboard .welcome-msg p { margin:9px 0; } +.dashboard .col2-set { margin:0 0 15px; } + +/* General Box */ +.box-account { margin:0 0 15px; } +.box-account .box-head { margin:0 0 5px; text-align:right; } +.box-account .box-head h2 { float:left; margin:0; font-size:14px; font-weight:bold; color:#4f8100; } +.box-account .box-head a { font-size:10px; text-transform:uppercase; } + +.dashboard .box .box-title { background:#f1f1f1; padding:2px 10px; margin:0 0 12px; text-align:right; } +.dashboard .box .box-title h3, +.dashboard .box .box-title h4 { float:left; margin:0; font-size:12px; font-weight:bold; line-height:1.35; } +.dashboard .box .box-title a { font-size:10px; text-transform:uppercase; } +.dashboard .box .box-content { padding:0 10px; } + +/* Block: Recent Orders */ +.dashboard .box-recent {} + +/* Block: Account Information */ +.dashboard .box-info {} +.dashboard .box-info h4 { font-size:11px; font-weight:bold; } + +/* Block: Reviews */ +.dashboard .box-reviews .box-head { background:#f1f1f1; padding:2px 10px; margin:0 0 12px; } +.dashboard .box-reviews .box-head h2 { font-size:12px; font-weight:bold; line-height:1.35; color:#444; } +.dashboard .box-reviews .number { display:none; float:left; font-size:10px; font-weight:bold; line-height:1; color:#fff; margin:3px -20px 0 0; padding:2px 3px; background:#0a263c; } +.dashboard .box-reviews .details { padding:0 10px; } +.dashboard .box-reviews li.item { margin:0 0 7px; } +.dashboard .box-reviews li.item.last { margin:0; } +.dashboard .box-reviews .ratings { margin:7px 0 0; } + +/* Block: Tags */ +.dashboard .box-tags .box-head { background:#f1f1f1; padding:2px 10px; margin:0 0 12px; } +.dashboard .box-tags .box-head h2 { font-size:12px; font-weight:bold; line-height:1.35; color:#444; } +.dashboard .box-tags .number { display:none; float:left; font-size:10px; font-weight:bold; line-height:1; color:#fff; margin:3px -20px 0 0; padding:2px 3px; background:#0a263c; } +.dashboard .box-tags .details { padding:0 10px; } +.dashboard .box-tags li.item { margin:0 0 7px; } +.dashboard .box-tags li.item.last { margin:0; } +.dashboard .box-tags .tags strong, +.dashboard .box-tags .tags ul, +.dashboard .box-tags .tags ul li { display:inline; } +/********** Dashboard > */ + +/* Address Book */ +.addresses-list h2 { background:#f1f1f1; padding:2px 10px; margin:0 0 12px; font-size:13px; font-weight:bold; line-height:1.25; } +.addresses-list h3 { font-weight:bold; font-size:12px; } +.addresses-list address { margin:0 0 3px; } +.addresses-list p { margin:9px 0; } +.addresses-list a { font-weight:bold; } +.addresses-list .link-remove {} +.addresses-list .separator { margin:0 3px; } +.addresses-list li.item { padding:0 10px; margin:0 0 12px; } +.addresses-list li.empty {} +.addresses-list li.empty p { font-weight:bold; } +.addresses-list .addresses-additional li.item {} + +/* Order View */ +.order-info dt { display:none; } +.order-info ul { margin-bottom:15px; border-bottom:1px solid #666; background:#f2f2f2 url(../images/bkg_tabs.gif) 0 100% repeat-x; } +.order-info li{ float:left; border-right:1px solid #a4a4a4; border-left:1px solid #fff; font-size:1.1em; line-height:1em; } +.order-info li.first { border-left:0; } +.order-info li.last { border-right:0; } +.order-info li a { display:block; padding:6px 15px; color:#444; } +.order-info li a:hover { background-color:#ddd; text-decoration:none; color:#444; } +.order-info li.current { background-color:#666; font-weight:bold; padding:6px 15px; color:#fff; } + +.order-date { margin:10px 0; } + +.order-info-box { margin:0 0 15px; } +.order-info-box h2 { font-size:13px; font-weight:bold; border-bottom:1px solid #ddd; margin:0 0 8px; } +.order-info-box .box-payment p { margin:9px 0; } +.order-info-box .box-payment th { font-weight:bold; padding-right:7px; } + +.order-items { width:100%; overflow-x:auto; } +.order-items h2, +.order-items h3 { clear:none; font-weight:bold; font-size:13px; padding:0; margin:0 0 .45em; } +.order-items h3 { font-size:12px; } +.order-items .product-name { font-weight:bold !important; } +.order-items .link-print { font-size:10px; text-transform:uppercase; } +.order-items .order-links { text-align:right; } +.order-items .order-links .link-print { font-weight:bold; font-size:11px; text-transform:none; } + +.order-additional { margin:15px 0; } +/* Order Gift Message */ +.gift-message dt strong { color:#555; } +.gift-message dd { font-size:13px; margin:5px 0 0; } +/* Order Comments */ +.order-about dt { font-weight:bold; } +.order-about dd { font-size:13px; margin:0 0 7px; } + +.tracking-table { margin:0 0 15px; } +.tracking-table th { font-weight:bold; white-space:nowrap; } + +.tracking-table-popup { width:100%; } +.tracking-table-popup th { font-weight:bold; white-space:nowrap; } +.tracking-table-popup th, +.tracking-table-popup td { padding:1px 8px; } + +/* Order Print Pages */ +.page-print .print-head { margin:0 0 15px; } +.page-print .print-head .logo { float:left; } +.page-print .print-head address { float:left; margin-left:15px; } +.page-print h1 { font-size:15px; font-weight:bold; font-family: colaborateregular, helvetica, arial, sans-serif; } +.page-print h2, +.page-print h3 { font-size:12px; font-weight:bold; } +.page-print h2.h2 { font-size:15px; font-weight:bold; text-align:right; } +.page-print .order-date { border-bottom:1px solid #ccc; padding:0 0 10px; margin:0 0 10px; } +.page-print .col2-set { margin:0 0 10px; } +/* Price Rewrites */ +.page-print .gift-message-link { display:none; } +.page-print .price-excl-tax, +.page-print .price-incl-tax { display:block; white-space:nowrap; } +.page-print .cart-price, +.page-print .price-excl-tax .label, +.page-print .price-incl-tax .label, +.page-print .price-excl-tax .price, +.page-print .price-incl-tax .price { display:inline; } + +/* My Wishlist */ +.my-wishlist .data-table td { padding:10px; } +.my-wishlist .product-image { display:block; width:113px; height:113px; margin:0 0 5px; } +.my-wishlist textarea { display:block; width:90%; height:109px; } +.my-wishlist .buttons-set { border:1px solid ##F2F2F2; padding:9px; margin:18px 0; box-shadow: 0 0 7px 5px #F2F2F2 inset; width: 90%; float: left; } +.my-wishlist .buttons-set button.button { float:none; } +.my-wishlist .buttons-set .btn-add span, +.my-wishlist .buttons-set .btn-share span {} +#wishlist-table .add-to-links { white-space:nowrap; } + +/* My Tags */ +.my-tag-edit { float:left; margin:0 0 10px; } +.my-tag-edit .btn-remove { float:right; margin:4px 0 0 5px; } +#my-tags-table { clear:both; } +#my-tags-table td { padding:10px; } +#my-tags-table .add-to-links { white-space:nowrap; } + +/* My Reviews */ +#my-reviews-table td { padding:10px; } +#my-reviews-table .rating-box { margin:3px 0 0; } + +.product-review .product-img-box { float:left; width:140px; } +.product-review .product-img-box .product-image { display:block; width:125px; height:125px; } +.product-review .product-img-box .label { font-size:11px; margin:0 0 3px; } +.product-review .product-img-box .ratings .rating-box { float:none; display:block; margin:0 0 3px; } +.product-review .product-details { margin-left:150px; } +.product-review .product-name { font-size:16px; font-weight:bold; margin:0 0 10px; } +.product-review h3 { font-size:12px; margin:0 0 3px; color:#2f2f2f; } +.product-review .ratings-table { margin:0 0 10px; } +.product-review dt { font-weight:bold; } +.product-review dd { font-size:13px; margin:5px 0 0; } + +/* Billing Agreements */ +.billing-agreements .info-box{ margin:15px 0; } +.billing-agreements .info-box p { margin:9px 0; } +.billing-agreements .form-list li select { float:left; margin:3px 10px 0 0; } +.billing-agreements .table-caption { font-weight:bold; font-size:13px; } +/* ======================================================================================= */ + + +/* MAP Popup============================================================================== */ +.cart-msrp-totals { color:red; font-size:12px !important; font-weight:bold; padding:40px 0 10px; text-align:right; text-transform:uppercase;} +.map-cart-sidebar-total { background:#f6f6f6; color:red; display:block; font-size:10px; line-height:14px; font-weight:bold; padding:5px; text-shadow:0 1px 0 #fff; box-shadow:0 0 3px #ccc; border-radius:5px; } + +.map-popup { background:#fff; border:1px solid #aaa; margin:12px 0 0; position:absolute; -moz-box-shadow:0 0 6px #ccc; -webkit-box-shadow:0 0 6px #ccc; box-shadow:0 0 6px #ccc; text-align:left; width:300px; z-index:100; } +.map-popup-heading { background:#efefef ; border-bottom:1px solid #ccc; padding:5px 30px 5px 10px; width:260px; } +.map-popup-heading h2 { font-size:16px; margin:0; text-shadow:0 1px 0 #f6f6f6; overflow:hidden; white-space:nowrap; word-wrap:break-word; text-align:left; text-overflow:ellipsis; } +.map-popup-arrow { background:url(../images/map_popup_arrow.gif) no-repeat; position:absolute; left:50%; top:-10px; height:10px; width:19px; } +.map-popup-close { background:url(../images/btn_window_close.gif) no-repeat; display:block; position:absolute; top:9px; right:10px; height:15px; width:15px; text-indent:-9999em; } +.map-popup-content { border-top:1px solid #eee; padding:10px; overflow:hidden; text-align:left; width:280px; } +.map-popup-checkout { display:inline; float:right; text-align:right; } +.map-popup-checkout span { display:block; padding-right:30px; } +.map-popup-checkout .paypal-logo { margin:0 0 5px; } +.map-popup-price .price-box, +.map-popup-price .price-box .special-price { margin:0; padding:0; } +.map-popup-price { margin:5px 0 0; } +.map-popup-text { clear:right; margin:0 10px; padding:10px 0; text-align:left; word-wrap:break-word; } +.map-popup-only-text { border-top:1px solid #ddd; } +/* ======================================================================================= */ + + +/* Footer ================================================================================ */ +.footer-container { bottom: 0; position: absolute; width: 100%;} +.footer ul.cards{display:none;} +.footer ul.links { + clear: both; + float: none; + list-style-type: none; + background:#000; + padding:10px; + /*border-radius:10px 10px 0 0; + -moz-border-radius:10px 10px 0 0; + -webkit-border-radius:10px 10px 0 0;*/ + display:inline-block; + width:98%; +} +.footer ul.links li { + float: left; + padding:10px 5px; +} +.footer {} +.footer a { color:#444; } +.footer strong { color:#444; text-transform: uppercase; letter-spacing: 0.1em; } + +.footer-right { float: right; width: 520px; } +.footer-left { float: left; margin-right: 20px; padding-right: 60px; width: 340px;} + +.footer .newsletter-footer {} +.footer .social { float: left; padding-bottom: 18px; } +.footer .social li { display: inline; margin-right: 20px; } + +.footer .help, .footer .search, .footer .store-options { float: left; width: 160px; margin-right: 20px; } +.footer .store-options { } +.footer .help { } +.footer .search { margin-right: 0; } + +.footer ul {} +.footer li {list-style-position:inside;color:#b1b1b1;} +.footer .links li.last { } +.footer .bugs { margin:0; color:#666; } +.footer .bugs a { font-weight:bold; color:#444; } +.footer address { clear: both; color:#b1b1b1; padding:10px; text-align:right; margin-bottom: 2px;font-size: 10px;} +.footer address a { color:#444; } +.store-switcher {float:right;display:inline-block;margin-top:-42px;position:relative;margin-right:10px;} +.footer .form-subscribe-header { text-transform: capitalize; margin: 9px 0; } +.footer .form-subscribe { margin-bottom: 18px;} +.footer .form-subscribe label, +.footer .form-subscribe .input-box, +.footer .form-subscribe button.button { float:left; } +.footer .form-subscribe label { position: absolute; overflow: hidden; clip: rect(0 0 0 0); height: 1px; width: 1px; margin: -1px; padding: 0; border: 0; } +.footer .form-subscribe .input-box { } +.footer .form-subscribe input.input-text { width:196px; background: #f7f7f7; border-top: 1px solid #cbcaca; } +.footer .form-subscribe button.button { width: 120px; } + +.footer .footer-callout { } + +.footer .show-on-phones { } +.footer .store-options{ color:#555; } +.footer .store-options label { font-weight:bold; display: block; } +.footer .store-options select { padding:0; vertical-align:middle; } + +.footer-container .bottom-container { margin:0 0 8px; text-align:right; } +/* ======================================================================================= */ + +/* Sample Data============================================================================ */ +.home-callout { margin-bottom:12px; } +.home-callout img { display:block } +/*.home-spot { float:left; width:470px; margin-left:20px; }*/ +.best-selling h3 { margin:12px 0 6px 0; color:#e25203; font-size:1.2em; } +.best-selling table { border-top:1px solid #ccc; } +.best-selling tr.odd { background:#eee url(../images/best_selling_tr_odd_bg.gif) 0 100% repeat-x; } +.best-selling tr.even { background:#fff url(../images/best_selling_tr_even_bg.gif) 0 100% repeat-x; } +.best-selling td { width:50%; border-bottom:1px solid #ccc; padding:8px 10px 8px 8px; font-size:11px; } +.best-selling .product-img { float:left; border:2px solid #dcdcdc; } +.best-selling .product-description { margin-left:107px; line-height:1.3em; } +.best-selling a.product-name, +.home-spot .best-selling a.product-name:hover { color:#203548; } +/* ======================================================================================= */ + + +/* + * jQuery FlexSlider v1.4 + * http://flex.madebymufffin.com + * + * Copyright 2011, Tyler Smith + * Free to use under the MIT license. + * http://www.opensource.org/licenses/mit-license.php + */ + +/* FlexSlider Necessary Styles +*********************************/ +.flexslider {width: 100%; margin: 0; padding: 0 0 3px;} +.flexslider .slides li {display: none;} /* Hide the slides before the JS is loaded. Avoids image jumping */ +.flexslider .slides img {max-width: 100%; display: block;} + + +/* FlexSlider Default Theme +*********************************/ +.flexslider {background: #fff ; position: relative; } +.flexslider .slides li {position: relative;} +/* Suggested container for "Slide" animation setups. Can replace this with your own, if you wish */ +.flexslider-container {position: relative;margin-bottom:20px;} + + +/* Caption style */ +.flex-caption {width: 96%; padding: 2%; position: absolute; left: 0; bottom: 0; background: url("../images/trans-03-16px.png") repeat; color: #fff; text-shadow: 0 -1px 0 rgba(0,0,0,.3); font-size: 15px; line-height: 18px;display:none;} + +/* Direction Nav */ +.flex-direction-nav li a {width: 52px; height: 52px; margin: -13px 0 0; display: block; background: url(../images/slider/bg_direction_nav.png) no-repeat 0 0; position: absolute; top: 50%; cursor: pointer; text-indent: -9999px;} /* set negative margin-top equal to half the height on the directional-nav for perfect vertical centering */ +.flex-direction-nav li a.next {background-position: -52px 0; right: -21px;} +.flex-direction-nav li a.prev {background-position: 0 0; left: -21px;} + +/* Control Nav */ +.flex-control-nav { position: absolute; bottom: 20px; right:5%;} /* set negative margin-left equal to half the width on the control-nav for perfect centering */ +.flex-control-nav li {margin: 0 0 0 5px; float: left;} +.flex-control-nav li:first-child {margin: 0;} +.flex-control-nav li a {width: 13px; height: 13px; display: block; background: url(../images/slider/bg_control_nav.png) no-repeat 0 0; cursor: pointer; text-indent: -9999px;} +.flex-control-nav li a:hover {background-position: 0 -13px;} +.flex-control-nav li a.active {background-position: 0 -26px; cursor: default;} + + +.header .top-promo1 { + background: url("../images/bkg_top-promo1.gif") repeat scroll 0 0 transparent; + float: right; + height: 44px; + margin: 0 0 0; + overflow: hidden; + width: 183px; +} +.header .top-promo { + background: url("../images/bkg_top-promo.png") repeat scroll 0 0 transparent; + float: right; + height: 44px; + margin: 0 5px 0; + overflow: hidden; + width: 203px; +} +.header .logo { + /*float: left;*/ + margin-top: 15px; + text-decoration: none !important; +} +.clear { + clear:both; + height:0; +} +/* Clears ================================================================================ */ +.clearer:after, +.header-container:after, +.header-container .top-container:after, +.header:after, +.top-bar:after, +.quick-access:after, +.form-search:after, +#nav:after, +.main:after, +.footer:after, +.footer .form-subscribe:after, +.footer-container .bottom-container:after, +.col-main:after, +.col2-set:after, +.col3-set:after, +.col4-set:after, +.search-autocomplete li:after, +.block .block-content:after, +.block .actions:after, +.block li.item:after, +.block-poll li:after, +.block-layered-nav .currently li:after, +.page-title:after, +.products-grid:after, +.products-list li.item:after, +.box-account .box-head:after, +.dashboard .box .box-title:after, +.order-info ul:after, +.box-reviews li.item:after, +.box-tags li.item:after, +.pager:after, +.sorter:after, +.ratings:after, +.add-to-box:after, +.add-to-cart:after, +.product-essential:after, +.product-collateral:after, +.product-tabs:after, +.product-view .product-img-box .more-views ul:after, +.product-view .box-tags .form-add:after, +.product-view .product-shop .short-description:after, +.product-view .box-description:after, +.product-options .options-list li:after, +.product-options-bottom:after, +.product-review:after, +.cart:after, +.cart-collaterals:after, +.cart .crosssell li.item:after, +.opc .step-title:after, +.checkout-progress:after, +.multiple-checkout .place-order:after, +.group-select li:after, +.form-list li:after, +.form-list .field:after, +.buttons-set:after, +.page-print .print-head:after, +.advanced-search-summary:after, +.gift-messages-form .item:after, +.send-friend .form-list li p:after, +#checkout-step-login .col2-set .col-1:after, +#checkout-step-login .col2-set .col-2:after { display:block; content:"."; clear:both; font-size:0; line-height:0; height:0; overflow:hidden; } +/* ======================================================================================= */ +.cellitem .product-image { + float:left; + height: 113px; + margin:0 10px 5px 0; + width: 113px; +} +.cellitem {border-bottom:1px solid #ccc;display:inline-block;padding-bottom:10px;margin-bottom:10px;} +.product-name {display:;} +.cellitem .cart-cell {float:left;width:150px;} +.cellitem .productdetailscell {float:left;width:350px;margin-right:10px;} +.deletecell {float:left;} +.headingcell {display:none;} +.store-switcher label {color:#fff;} +/* Tablet Layout: 768px. + Gutters: 20px. + Outer margins: 20px. + Inherits styles from: Default Layout. +------------------------------------------------------------------------------- +cols 1 2 3 4 5 6 7 8 9 10 11 12 +px 40 100 160 220 280 340 400 460 520 580 640 700 */ + +@media only screen and (min-width: 768px) and (max-width: 959px) { + + .page { + position: absolute; margin: 0 auto; background: #F9F9F9; min-height: 100%; min-width: 100%; padding-bottom: 100px; + } + .row { margin:0 auto; width:740px;padding:0 14px 0 14px; overflow:hidden; } + .row .row { margin:0 -14px 0 -14px; width:auto; display:inline-block; } + + .grid_1 { width:36px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_2 { width:100px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_3 { width:185px; margin:0 0; overflow:hidden; float:left; display:inline; } + .grid_4 { width:200px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_5 { width:292px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_6 { width:356px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_7 { width:420px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_8 { width:484px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_9 { width:548px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_10 { width:612px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_11 { width:676px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + .grid_12 { width:740px; margin:0 14px 0 14px; overflow:hidden; float:left; display:inline; } + + .space_1 { margin-left:78px; } + .space_2 { margin-left:142px; } + .space_3 { margin-left:206px; } + .space_4 { margin-left:270px; } + .space_5 { margin-left:334px; } + .space_6 { margin-left:398px; } + .space_7 { margin-left:462px; } + .space_8 { margin-left:526px; } + .space_9 { margin-left:590px; } + .space_10 { margin-left:654px; } + .space_11 { margin-left:718px; } + .checkout-onepage-index .sidebar {display:none;} + .col2-left-layout .col-main { width: 545px; } + .col2-left-layout .col-left { width: 160px; float: left; } + .checkout-onepage-index .col2-left-layout .col-left { width: 160px; float: left; margin-left: 20px; } + .col2-right-layout .col-main { width: 520px; } + .col2-right-layout .col-right { float: right; width: 160px; } + .show-on-phones{ +display: inline-block; + float: left; + margin: 0 10px 0 0 !important; } + .pro_topadst {min-height:275px;} + .add-to-links .separator {display:none;} + .add-to-links li {margin:9px 0 0 0;} + .products-grid li.item { } + .sorter .view-mode { display: visible; float: left; margin: 0; } + + .cart div.discount, .cart div.shipping { width: 220px; } + .cart .totals { width: 220px;} + .cart .crosssell li.item { width: 335px; } + + .col1-layout .product-view .product-img-box { width: 340px; } + .col1-layout .product-view .product-shop { width: 340px; } + + .product-view .product-shop .add-to-links li { display: block; } + + .cms-home ul.product-tabs { clear: both; } + .cms-home .home-tabs .tabs-title strong { font-size: 26px; line-height: 1.38415385; float: none; } + .cms-home .product-tabs li { float: none; border-right: none; border-bottom: 1px solid #ccc; } + .cms-home .product-tabs li.first a { border: 0; border-radius: 0; } + .cms-home .product-tabs li.last a { border: 1px 0; } + .cms-home .product-tabs a { border-width: 1px 0; } + .cms-home .product-tabs li.active a { border: 1px 0; border-radius: 0; color: #fff; background: #444; text-align: left; } + + .col2-left-layout .product-tabs li, .col2-right-layout .product-tabs li { float: none; border-right: none; border-bottom: 1px solid #ccc; } + .col2-left-layout .product-tabs li.first a, .col2-right-layout .product-tabs li.first a, { border: 0; border-radius: 0; } + .col2-left-layout .product-tabs li.last a, .col2-right-layout .product-tabs li.last a { border: 1px 0; } + .col2-left-layout .product-tabs a, .col2-right-layout .product-tabs a { border-width: 1px 0; } + .col2-left-layout .product-tabs li.active a, .col2-left-layout .product-tabs li.active a:hover, .col2-right-layout .product-tabs li.active a, + .col2-right-layout .product-tabs li.active a:hover { border: 1px 0; border-radius: 0; color: #fff; background: #444; } + + + .block-progress dt { font-size: 10px; line-height: 1.8; } + + .footer-left { width: 220px; padding: 0; } + .footer-right { width: 400px; } + .footer .help, .footer .search, .footer .store-options { width: 120px;} + .footer .form-subscribe input.input-text { width: 100%; } + .footer .form-subscribe label, .footer .form-subscribe .input-box, .footer .form-subscribe button.button { float: none; display: block; } + .footer .form-subscribe button.button { margin-top: 9px; color: #fff; } + .form-language {float:none !important;position:relative;top:10px;} + .products-grid li.item {width:140px} + .cart .discount .discount-form, .cart .shipping .shipping-form {width:210px;} + .cart .totals { width:235px !important;} + .col3-layout .grid_6 {width: 320px;} + +} + + + +/* Mobile Layout: 320px. + Gutters: 20px. + Outer margins: 20px. + Inherits styles from: Default Layout. +------------------------------------------------------------------------------- +cols 1 2 3 4 5 +px 40 100 160 220 280 */ + +@media only screen and (max-width: 767px) { + + .page { background:#fff; + + } + .row { margin:0 auto; width:300px; overflow:hidden; } + .row .row { margin:0; width:auto; display:inline-block; } + + + .col3-layout .grid_1, + .col3-layout .grid_2, + .col3-layout .grid_3, + .col3-layout .grid_4, + .col3-layout .grid_5, + .col3-layout .grid_6, + .col3-layout .grid_7, + .col3-layout .grid_8, + .col3-layout .grid_9, + .col3-layout .grid_10, + .col3-layout .grid_11, + .col3-layout .grid_12 { width:280px; margin:10px 0 0 0; overflow:hidden; float:left; display:inline; } + + + .grid_1, + .grid_2, + .grid_3, + .grid_4, + .grid_5, + .grid_6, + .grid_7, + .grid_8, + .grid_9, + .grid_10, + .grid_11, + .grid_12 { width:300px; margin:10px 0 0 0; overflow:hidden; float:left; display:inline; } + + .space_1, + .space_2, + .space_3, + .space_4, + .space_5, + .space_6, + .space_7, + .space_8, + .space_9, + .space_10, + .space_11, { margin-left:0; } + .col2-left-layout .col-left, .col2-left-layout .col-main { float: none !important; width: 100% !important; } + .col2-right-layout .col-right, .col2-right-layout .col-main { float: none !important; width: 100% !important; margin-left: 0; } + .col1-layout .col-main { float: none !important; width: 100% !important; } + .form-search {float:left;} + .top-promo1, .top-promo { } + .quick-access {float:left;} + .header .logo {float:none;margin-bottom:20px;display:inline-block;} + ul.products-grid {text-align:center;} + .products-grid li.item {margin-left:0;} + .ratings {width:150px;float:left;} + .add-to-links {display:inline-block;text-align:center;} + .sorter .sort-by {float:none;} + .top-bar .breadcrumbs {padding:0;} + .cart-table .a-center, .cart-table .a-right {display:none;} + .a-center.removeitem {display:block !important} + .checkout-progress {padding:0;} + .checkout-progress li {float:none;width:100%;} + #checkout-review-submit .button {margin-top:27px;margin-left:20px;} + .form-language label, .store-switcher label {display:none;} + .header .top-promo1 {float:left;} + /* form elements */ + + .form-list, .input-box select { width:96%; } + .form-list li, .form-list li .field { width:100%; margin-right:0; } + .form-list li .field + .field { margin-top:10px; } + .form-list li.street-address .input-box input.input-text { width:92%; } + .form-list li.select-address { width:100%; } + + .form-guest { width: 100%; } + + .buttons-set button { float:none; } + .buttons-set a { display:block; } + .cellitem .productdetailscell {width:280px;} + .my-wishlist .buttons-set button.button {margin-bottom:15px;} + #multiship-addresses-table select {width:75px;} + + /********************/ + + + .col2-set .col-2, .col2-set .col-1 { float: none !important; width: 100% !important;} + + .header { margin: 0; } + + .quick-access .show-on-phones { } + .quick-access { margin: 0; } + .quick-access .links, .quick-access .links li { float: none; margin: 0 2px;} + .quick-access .links { padding: 9px 0; display: inline-block; text-align: center; width: 100%; padding:0;} + .quick-access .links li { } + .quick-access .links a { } + .quick-access .links li.last a { } + + + .form-search { display: inline-block; position: static; margin: 18px 0; } + + .nav-container { height: auto; margin: 0; } + #nav ul ul, #nav ul div { display: none; } + + .products-grid li.item { width: 240px; } + .sorter .view-mode { display: none; float: left; margin: 0; } + .product-view .product-shop { clear: both; width: 100%; } + + .block { border: 1px solid #ccc;} + + .sorter .sort-by, .sorter .limiter { margin: 3px 0; } + .sorter .sort-by { } + .pager .pages { } + .pager .limiter { display: none; float: right; } + + .col1-layout .product-view .product-img-box { width: 240px; margin:0 7%;} + .col1-layout .product-view .product-shop { clear: both; float: left; width: 100%; } + .products-list .product-shop { margin-left: 0; } + .product-view .product-shop { clear: both; margin-top: 20px; float: none; } + .product-view .box-tags .form-add .input-box { width: 100%; } + + .cart-table .btn-continue { float: left; margin-bottom: 18px; } + .cart-table .btn-update { float: right; } + .cart div.discount, .cart div.shipping { float: none; } + .cart .totals { width: 100%; clear: both; } + + .opc .step-title h2 { font-size: 12px; font-family: Tahoma, Helvetica, Arial, sans-serif; } + .opc .step-title .number { top: 18px; } + .checkout-onepage-index .col-left { display: none; } + .checkout-onepage-index .col2-set .col-1 { float: none; width: 100%; } + .checkout-onepage-index .col2-set .col-2 { float: none; width: 100%; margin-top: 20px; } + .opc .step { border: none; padding: 15px 0; } + + + .product-view .product-shop .add-to-links li { display: block; } + + + .cms-home ul.product-tabs { clear: both; } + .cms-home .home-tabs .tabs-title strong { font-size: 26px; line-height: 1.38415385; float: none; } + + .products-grid li.item { position: relative; width: 240px; } + + .add-to-cart label { margin-right: 0; } + .add-to-cart button.button { } + + .product-tabs li { float: none; border-right: none; border-bottom: 1px solid #ccc; } + .product-tabs li.first a { border: 0; border-radius: 0; } + .product-tabs li.last a { border: 1px 0; } + .product-tabs a { border-width: 1px 0; } + .product-tabs li.active a, .product-tabs li.active a:hover { border: 1px 0; border-radius: 0; color: #fff; background: #444; } + + .product-options ul.options-list li { border: 1px solid #CCCCCC; margin: 9px 0; padding: 8px 5px; text-align: center; } + .product-options ul.options-list .label { margin-left: 0; } + + .flex-direction-nav li a { display: none; } + + .footer-left, .footer-right { float: none; width: 100%; } + .footer-right { clear: both; } + .footer .show-on-phones { display: block; } + .footer .help, .footer .search, .footer .store-switch { width: 150px;} + .footer .form-subscribe input.input-text { width: 100%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } + .footer .form-subscribe label, .footer .form-subscribe .input-box, .footer .form-subscribe button.button { float: none; display: block; } + .footer .form-subscribe button.button { margin-top: 9px; text-shadow: 1px 1px #444; } + + .page-sitemap .links { margin: 18px 0; text-align: left; } + .nav-container {background:none;} + +} + + + +/* Wide Mobile Layout: 480px. + Gutters: 20px. + Outer margins: 20px. + Inherits styles from: Default Layout, Mobile Layout. +------------------------------------------------------------------------------- +cols 1 2 3 4 5 6 +px 40 100 160 220 280 340 */ + +@media only screen and (min-width: 480px) and (max-width: 767px) { + + .page{ background:#fff; + + } + .row { margin:0 auto; width:456px; overflow:hidden; } + .row .row { margin:0; width:auto; display:inline-block; } + + .col3-layout .grid_1, + .col3-layout .grid_2, + .col3-layout .grid_3, + .col3-layout .grid_4, + .col3-layout .grid_5, + .col3-layout .grid_6, + .col3-layout .grid_7, + .col3-layout .grid_8, + .col3-layout .grid_9, + .col3-layout .grid_10, + .col3-layout .grid_11, + .col3-layout .grid_12 { width:436px; margin:10px 0 0 0; overflow:hidden; float:left; display:inline; } + + .grid_1, + .grid_2, + .grid_3, + .grid_4, + .grid_5, + .grid_6, + .grid_7, + .grid_8, + .grid_9, + .grid_10, + .grid_11, + .grid_12 { width:456px; margin:10px 0 0 0; overflow:hidden; float:left; display:inline; } + /* form elements */ + .f-gray .grid_3 {width:228px;} + .input-box select { width:97%; } + .form-list li.wide { width:100%; } + + .buttons-set button { float:left; } + .buttons-set a { display:inline; } + + /************/ + .form-search input.input-text {width:350px;} + .sorter .sort-by, .sorter .limiter { float: right; } + + .products-grid li.item { position: relative; width: 157px; } + + .sorter .view-mode { display: visible; float: left; margin: 0; } + + .col1-layout .product-view .product-img-box { width: 340px; margin:0 10%;} + + .products-list .product-shop { margin-left: 185px; } + + .add-to-cart button.button { float: none;} + + .product-tabs a { border-style: none; } + .nav-container {background:none;} + .products-grid li.item {margin:10px;} + .add-to-links li a {font-size:10px;} +} + +/********* END MEDIA QUERIES ************************************/ + +/******************** IE FIXES ************************************************/ + +/* IE 6 only */ +.lt-ie7 .validation-advice { height:13px; } +.lt-ie7 .main { height:350px; } +.lt-ie7 .account-login .content { height:200px; } +.lt-ie7 .block li.item, +.lt-ie7 .block-poll li, +.lt-ie7 .opc li.section { vertical-align:top; } + +.lt-ie7 button.button span { background-image:url(../images/bkg_btn.gif); } +.lt-ie7 .form-search button.button span, +.lt-ie7 .block button.button span, +.lt-ie7 .product-view .box-tags .form-add button.button span, +.lt-ie7 .footer .form-subscribe button.button span { background-image:url(../images/bkg_btn-small.gif); } +.lt-ie7 .window-overlay { background:#ccc; filter:alpha(opacity=50); } + +/* Doubled Margin Fixes */ +.lt-ie8 .product-view .product-img-box .more-views li, +.lt-ie8 .product-view .box-tags .form-add .input-box, +.lt-ie8 .sp-methods select.month, +.lt-ie8 .footer .form-subscribe .input-box { display:inline; } + +/* Forms */ +.lt-ie9 .input-box input.input-text { line-height: 34px; } +.lt-ie8 .button { padding: 7px 10px 7px; } +.lt-ie8 .footer .form-subscribe button.button { position: relative; top: 1px; } + +.input-box input.input-text + +/********** < Navigation styles */ +.lt-ie8 .header, .lt-ie8 .nav-container { z-index: 1; } +.lt-ie8 #nav ul, .lt-ie8 #nav div { z-index: 1000; } +.lt-ie8 #nav li a { zoom:1; } +.lt-ie8 #nav li { vertical-align:top; } +/********** < Navigation styles */ + + +.lt-ie8 .remember-me-popup .remember-me-popup-body a span, .lt-ie8 .truncated a.details, .lt-ie8 .cart .crosssell li.item, .lt-ie8 .product-options dd .time-picker, .lt-ie8 #nav, .lt-ie8 .form-list li.fields, .lt-ie8 .form-list li.wide, .lt-ie8 .form-list li , .lt-ie8 .form-search, .lt-ie8 .cart .crosssell li.item, .lt-ie8 #nav, .lt-ie8 .products-grid li.item, .lt-ie8 .mini-products-grid td { display: inline-block; zoom: 1; *display: inline; } + +.lt-ie8 table { scrollbar-face-color:expression(runtimeStyle.scrollbarFaceColor = '#fff', cellSpacing = 0); } + +.lt-ie8 .product-view .product-img-box .zoom.disabled { filter:alpha(opacity=30); } + +.lt-ie8 .gift-messages-form { position:relative; zoom:1; } + +.lt-ie8 .tool-tip .btn-close a { margin:0; } + +.lt-ie8 .product-view .box-tags .product-tags li { padding:0 4px 0 7px; } +.lt-ie8 .footer li { padding-right:2px; margin-right:6px; } + +.lt-ie8 .product-options dd .time-picker select { margin:0; padding:0; position:relative; top:-1px; } + +/* Clearer */ +.lt-ie8 .clearer { display:block; clear:both; font-size:0; line-height:0; height:0; overflow:hidden; } + +/* Clears and hasLayout fixes */ +.lt-ie8 .header-container, +.lt-ie8 .header-container .top-container, +.lt-ie8 .header, +.lt-ie8 .top-bar, +.lt-ie8 .quick-access, +.lt-ie8 .form-search, +.lt-ie8 #nav, +.lt-ie8 .main, +.lt-ie8 .footer, +.lt-ie8 .footer .form-subscribe, +.lt-ie8 .footer-container .bottom-container, +.lt-ie8 .col-main, +.lt-ie8 .col2-set, +.lt-ie8 .col3-set, +.lt-ie8 .col4-set, +.lt-ie8 .messages li, +.lt-ie8 .search-autocomplete li, +.lt-ie8 .block, +.lt-ie8 .block .block-content, +.lt-ie8 .block .actions, +.lt-ie8 .block li.item, +.lt-ie8 .block-poll li, +.lt-ie8 .block-poll .label, +.lt-ie8 .block-layered-nav .currently li, +.lt-ie8 .block-account .block-content li a, +.lt-ie8 .mini-products-list .product-details, +.lt-ie8 .page-title, +.lt-ie8 .rss-title h1, +.lt-ie8 .products-grid, +.lt-ie8 .products-list li.item, +.lt-ie8 .box-account .box-head, +.lt-ie8 .dashboard .box .box-title, +.lt-ie8 .order-info ul, +.lt-ie8 .box-reviews li.item, +.lt-ie8 .box-tags li.item, +.lt-ie8 .pager, +.lt-ie8 .sorter, +.lt-ie8 .ratings, +.lt-ie8 .add-to-box, +.lt-ie8 .add-to-cart, +.lt-ie8 .product-essential, +.lt-ie8 .product-collateral, +.lt-ie8 .product-tabs, +.lt-ie8 .product-view .product-img-box .more-views ul, +.lt-ie8 .product-view .box-tags .form-add, +.lt-ie8 .product-view .product-shop .short-description, +.lt-ie8 .product-view .box-description, +.lt-ie8 .product-options .options-list li, +.lt-ie8 .product-options, +.lt-ie8 .product-options-bottom, +.lt-ie8 .truncated, +.lt-ie8 .truncated .truncated_full_value, +.lt-ie8 .product-review, +.lt-ie8 .cart, +.lt-ie8 .cart-collaterals, +.lt-ie8 .cart .crosssell li.item, +.lt-ie8 .cart .discount, +.lt-ie8 .cart .discount .discount-form, +.lt-ie8 .cart .shipping .shipping-form, +.lt-ie8 .opc .step-title, +.lt-ie8 .opc .step, +.lt-ie8 .multiple-checkout, +.lt-ie8 .sp-methods, +.lt-ie8 .checkout-progress, +.lt-ie8 .multiple-checkout .place-order, +.lt-ie8 .form-list li, +.lt-ie8 .form-list .field, +.lt-ie8 .form-list .input-box, +.lt-ie8 .group-select li, +.lt-ie8 .buttons-set, +.lt-ie8 .page-print .print-head, +.lt-ie8 .cart-tax-total, +.lt-ie8 .advanced-search-summary, +.lt-ie8 .advanced-search-summary p, +.lt-ie8 .gift-messages-form .item, +.lt-ie8 .send-friend .form-list li p, +.lt-ie8 .centinel .authentication { zoom:1; } + +/* Hover Fix */ +.lt-ie8 iframe.hover-fix { position:absolute; left:-1px; top:-1px; z-index:-1; background:transparent; filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0); } + +/***** End IE Fix ******************************/ + + +/* ==|== print styles ======================================================= +Print styles. +Inlined to avoid required HTTP connection: h5bp.com/r +========================================================================== */ + +@media print { + * { background: transparent !important; color: black !important; box-shadow:none !important; text-shadow: none !important; } /* Black prints faster: h5bp.com/s */ + a, a:visited { text-decoration: underline; } + a[href]:after { content: " (" attr(href) ")"; } + abbr[title]:after { content: " (" attr(title) ")"; } + .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; } /* Don't show links for images, or javascript/internal links */ + pre, blockquote { border: 1px solid #999; page-break-inside: avoid; } + thead { display: table-header-group; } /* h5bp.com/t */ + tr, img { page-break-inside: avoid; } + img { max-width: 100% !important; } + @page { margin: 0.5cm; } + p, h2, h3 { orphans: 3; widows: 3; } + h2, h3 { page-break-after: avoid; } + + /** Print styles from Modern Theme *******/ + + /* * { background:none !important; text-align:left !important; } */ + html { margin:0 !important; padding:0 !important; } + body { background:#fff !important; font-size:9pt !important; padding:0 !important; margin:10px !important; } + a { color:#2976c9 !important; } + th,td { color:#2f2f2f !important; border-color:#ccc !important; } + + .header-container, + .nav-container, + .footer-container, + .pager, + .toolbar, + .actions, + .buttons-set { display:none !important; } + + .page-print .data-table .cart-tax-total { background-position:100% -54px; } + .page-print .data-table .cart-tax-info { display:block !important; } +} diff --git a/app/css/thumbnail-list.css b/app/css/thumbnail-list.css new file mode 100644 index 0000000..57e6bb2 --- /dev/null +++ b/app/css/thumbnail-list.css @@ -0,0 +1,121 @@ +/* +To change this license header, choose License Headers in Project Properties. +To change this template file, choose Tools | Templates +and open the template in the editor. +*/ +/* + Created on : Nov 18, 2013, 5:34:35 PM + Author : zahid +*/ + +/* Fade Animations */ + +.thumbnail-show, +.thumbnail-hide{ + -webkit-transition:all linear 2s; + -moz-transition:all linear 2s; + -o-transition:all linear 2s; + -ms-transition:all linear 2s; + transition:all linear 2s; +} + + +.thumbnail-show { height: 0; } /* starting animations for enter */ +.thumbnail-show-active { height: 60px; } /* terminal animations for enter */ +.thumbnail-hide { height: 60px;} /* starting animations for leave */ +.thumbnail-hide-active { height: 0px; } /* terminal animations for leave */ + +.st_wrapper{ + /* display:none;*/ + /*position: absolute;*/ + width:100%; + overflow: hidden; + top:50px; + left:0px; + height: 60px; + max-height: 60px; +} + +.st_thumbs_title { + background-color: black; + opacity: 1.0; + width: 100%; +} + +.st_thumbs_title span{ + margin-left: 15px; + background: #000; + color: #BAB7B0; + text-transform: uppercase; + text-align: left; + font-family: "Helvetica Neue",Helvetica,Arial,sans-serif; +} + +.st_thumbs{ + margin: 0; + float: left; +} + +.st_thumbs a { + float: left; + margin:3px; +} + +.st_thumbs img{ + border:none; + opacity:0.5; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=50); +} + +.st_thumbs img:hover{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.st_thumbs_active{ + + margin: 0; + float: left; +} + +.st_thumbs_active img{ + border:none; + opacity:1; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=100); +} + +.album { + opacity: 0.7; + position: relative; + background-color: lightgrey; + filter:progid:DXImageTransform.Microsoft.Alpha(opacity=70); +} + +.nav_left, .nav_right { + position: absolute; + top: 0; + height: 100%; + text-decoration: none; + color: #fff; + line-height: 100%; + z-index: 110; +} + +.nav_left { + background: url('../img/thumb-back.png') no-repeat center; + left:0; +} + +.nav_left .st-thumb-nav-bg, .nav_right .st-thumb-nav-bg{ + background: #000; + width: 30px; + height: 100%; + opacity: 0.5; + display: block; +} + +.nav_right { + background: url('../img/thumb-forward.png') no-repeat center; + right: 0; +} \ No newline at end of file diff --git a/app/env/dev.js b/app/env/dev.js new file mode 100644 index 0000000..0e55fe3 --- /dev/null +++ b/app/env/dev.js @@ -0,0 +1,16 @@ +angular.module('st.app').constant('APP_CONFIG',{ + baseUrl: '//www.mayameirav.com/', + defaultCategory: {id: 38, slug: 'collection', name: 'Collection'}, + magentoApiRest: '//www.mayameirav.com/magento/api/rest/', + prevNextLimit: 25, + productBasicDataLimit: 50, + dataProvider: '', + noBlock: 0, + block:'block', + cmsPage:'cmsPage', + category:'category' +}); + +angular.module('st.app').config(['$logProvider', function($logProvider){ + $logProvider.debugEnabled(false); +}]); \ No newline at end of file diff --git a/app/favicon.ico b/app/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..5ff3fd60f02a08b7514f2e4da28f339f1697d9d9 GIT binary patch literal 33110 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 ud^dz&`;J7$NEa literal 0 HcmV?d00001 diff --git a/app/fonts/glyphicons-halflings-regular.eot b/app/fonts/glyphicons-halflings-regular.eot new file mode 100644 index 0000000000000000000000000000000000000000..87eaa434234e2a984c261e0450a2f4ad837aa7b4 GIT binary patch literal 14079 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 literal 0 HcmV?d00001 diff --git a/app/fonts/glyphicons-halflings-regular.svg b/app/fonts/glyphicons-halflings-regular.svg new file mode 100644 index 0000000..5fee068 --- /dev/null +++ b/app/fonts/glyphicons-halflings-regular.svg @@ -0,0 +1,228 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/fonts/glyphicons-halflings-regular.ttf b/app/fonts/glyphicons-halflings-regular.ttf new file mode 100644 index 0000000000000000000000000000000000000000..be784dc1d5bcb92ab155f578f3723524a3dd9688 GIT binary patch literal 29512 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 DlhOCh literal 0 HcmV?d00001 diff --git a/app/fonts/glyphicons-halflings-regular.woff b/app/fonts/glyphicons-halflings-regular.woff new file mode 100644 index 0000000000000000000000000000000000000000..2cc3e4852a5a42e6aadd6284e067b66e14a57bc7 GIT binary patch literal 16448 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 literal 0 HcmV?d00001 diff --git a/app/img/arrow-down.png b/app/img/arrow-down.png new file mode 100644 index 0000000000000000000000000000000000000000..df7424ba0eed47c09b5faf60ab4b908e49938bde GIT binary patch literal 161 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`8J;eVAr-fhQx*sq@bNQ8G*&1I zOlSCLtn}5Bv5;Tj_~DoUo+B$A-ng_VDxCe@P+=zUU8%ZJ!a2YsnVY$$Eg|EWXvYnn zgR3N`GrnjucyOubJVT1JL_wxn3d0!zwwPI+h7Af5Y(NVIyClUH2?qWL+R5PQ>gTe~ HDWM4fa?>%b literal 0 HcmV?d00001 diff --git a/app/img/back.png b/app/img/back.png new file mode 100644 index 0000000000000000000000000000000000000000..44cd0ae703cb0810dc707f0da621708e14018fdd GIT binary patch literal 2629 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 literal 0 HcmV?d00001 diff --git a/app/img/bg-hover.png b/app/img/bg-hover.png new file mode 100644 index 0000000000000000000000000000000000000000..1ca2022e106454b787657cecabc88aa30eb744fb GIT binary patch literal 960 zcmaJ=zi-n(7 zAjH(pAXQ>uhk=EWfdwHkv9nb4AE>$^!N569(hez>&UfGGz4yKQ?z@BP?t`_}+p8SM ztyOl^8k?8cfY+|F|GW678*I8owI;2THXRy1<_Z>RVNh|54z6Lt8a?@r^Bi{t+Knb{ z>JMd;IJ^;I_|Wkfo8$7^p=X#qOhF5GY*&FNpT9t0TMB$6=}7lVxNGl>eOw>!Hq3F) z%vo^zKFEhM6L2s!Kx7u<|El+c?NP%5SJy{Tj!y!LR^2F~5VlJ19 zG!lt8L&SrTON}t@2C45$K`)3YNu-dxrVre$IU6GFoiL>@&) zngMnF|4_%7qXSyQ=YAIo2aS=3g&GdXz&F{&wPR5#PcHe`pu}$w(w|ka+9i|(UE+aK zT>`pc+HMq2@VYKn+<+Rci7ToCnF4RymRwAUITfX|DK%XdMGa-kSv4ymNs~$_iIRmG zS0(1a!7iO~t#fYfQf|}=j>j^q*tefztLzg8OpYwu3%rzzny5)>mFblhdpYA;3%pFZ z+NE59nGvFky>QX9E!I8Ja^AKqm^VIlS-1PFtsBDQ59~>#Dr%t-{%oypZ2bN4m0J!E zj==He{_pE|UcB5t0moZ+Pj7CXt{g7ET{`;pE!O|DvcAW?dA{}R(0czmdQ%l`SN&Mr Gd-V^>d@1<= literal 0 HcmV?d00001 diff --git a/app/img/button-tray-down.png b/app/img/button-tray-down.png new file mode 100644 index 0000000000000000000000000000000000000000..99b92aef122f08800dd80bd79b92fd7d2293a692 GIT binary patch literal 1506 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 literal 0 HcmV?d00001 diff --git a/app/img/forward.png b/app/img/forward.png new file mode 100644 index 0000000000000000000000000000000000000000..e2084ab3fafe805cc4fa302bc4d2723932fba46f GIT binary patch literal 2614 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 B7G?kd literal 0 HcmV?d00001 diff --git a/app/img/glyphicons-halflings.png b/app/img/glyphicons-halflings.png new file mode 100644 index 0000000000000000000000000000000000000000..a9969993201f9cee63cf9f49217646347297b643 GIT binary patch literal 12799 zcma*OWmH^Ivn@*S;K3nSf_t!#;0f+&pm7Po8`nk}2q8f5;M%x$SdAkd9FAvlc$ zx660V9e3Ox@4WZ^?7jZ%QFGU-T~%||Ug4iK6bbQY@zBuF2$hxOw9wF=A)nUSxR_5@ zEX>HBryGrjyuOFFv$Y4<+|3H@gQfEqD<)+}a~mryD|1U9*I_FOG&F%+Ww{SJ-V2BR zjt<81Ek$}Yb*95D4RS0HCps|uLyovt;P05hchQb-u2bzLtmog&f2}1VlNhxXV);S9 zM2buBg~!q9PtF)&KGRgf3#z7B(hm5WlNClaCWFs!-P!4-u*u5+=+D|ZE9e`KvhTHT zJBnLwGM%!u&vlE%1ytJ=!xt~y_YkFLQb6bS!E+s8l7PiPGSt9xrmg?LV&&SL?J~cI zS(e9TF1?SGyh+M_p@o1dyWu7o7_6p;N6hO!;4~ z2B`I;y`;$ZdtBpvK5%oQ^p4eR2L)BH>B$FQeC*t)c`L71gXHPUa|vyu`Bnz)H$ZcXGve(}XvR!+*8a>BLV;+ryG1kt0=)ytl zNJxFUN{V7P?#|Cp85QTa@(*Q3%K-R(Pkv1N8YU*(d(Y}9?PQ(j;NzWoEVWRD-~H$=f>j9~PN^BM2okI(gY-&_&BCV6RP&I$FnSEM3d=0fCxbxA6~l>54-upTrw zYgX@%m>jsSGi`0cQt6b8cX~+02IghVlNblR7eI;0ps}mpWUcxty1yG56C5rh%ep(X z?)#2d?C<4t-KLc*EAn>>M8%HvC1TyBSoPNg(4id~H8JwO#I)Bf;N*y6ai6K9_bA`4 z_g9(-R;qyH&6I$`b42v|0V3Z8IXN*p*8g$gE98+JpXNY+jXxU0zsR^W$#V=KP z3AEFp@OL}WqwOfsV<)A^UTF4&HF1vQecz?LWE@p^Z2){=KEC_3Iopx_eS42>DeiDG zWMXGbYfG~W7C8s@@m<_?#Gqk;!&)_Key@^0xJxrJahv{B&{^!>TV7TEDZlP|$=ZCz zmX=ZWtt4QZKx**)lQQoW8y-XLiOQy#T`2t}p6l*S`68ojyH@UXJ-b~@tN`WpjF z%7%Yzv807gsO!v=!(2uR)16!&U5~VPrPHtGzUU?2w(b1Xchq}(5Ed^G|SD7IG+kvgyVksU) z(0R)SW1V(>&q2nM%Z!C9=;pTg!(8pPSc%H01urXmQI6Gi^dkYCYfu6b4^tW))b^U+ z$2K&iOgN_OU7n#GC2jgiXU{caO5hZt0(>k+c^(r><#m|#J^s?zA6pi;^#*rp&;aqL zRcZi0Q4HhVX3$ybclxo4FFJW*`IV`)Bj_L3rQe?5{wLJh168Ve1jZv+f1D}f0S$N= zm4i|9cEWz&C9~ZI3q*gwWH^<6sBWuphgy@S3Qy?MJiL>gwd|E<2h9-$3;gT9V~S6r z)cAcmE0KXOwDA5eJ02-75d~f?3;n7a9d_xPBJaO;Z)#@s7gk5$Qn(Fc^w@9c5W0zY z59is0?Mt^@Rolcn{4%)Ioat(kxQH6}hIykSA)zht=9F_W*D#<}N(k&&;k;&gKkWIL z0Of*sP=X(Uyu$Pw;?F@?j{}=>{aSHFcii#78FC^6JGrg-)!)MV4AKz>pXnhVgTgx8 z1&5Y=>|8RGA6++FrSy=__k_imx|z-EI@foKi>tK0Hq2LetjUotCgk2QFXaej!BWYL zJc{fv(&qA7UUJ|AXLc5z*_NW#yWzKtl(c8mEW{A>5Hj^gfZ^HC9lQNQ?RowXjmuCj4!!54Us1=hY z0{@-phvC}yls!PmA~_z>Y&n&IW9FQcj}9(OLO-t^NN$c0o}YksCUWt|DV(MJB%%Sr zdf}8!9ylU2TW!=T{?)g-ojAMKc>3pW;KiZ7f0;&g)k}K^#HBhE5ot)%oxq$*$W@b# zg4p<Ou`ME|Kd1WHK@8 zzLD+0(NHWa`B{em3Ye?@aVsEi>y#0XVZfaFuq#;X5C3{*ikRx7UY4FF{ZtNHNO?A_ z#Q?hwRv~D8fPEc%B5E-ZMI&TAmikl||EERumQCRh7p;)>fdZMxvKq;ky0}7IjhJph zW*uuu*(Y6)S;Od--8uR^R#sb$cmFCnPcj9PPCWhPN;n`i1Q#Qn>ii z{WR|0>8F`vf&#E(c2NsoH=I7Cd-FV|%(7a`i}gZw4N~QFFG2WtS^H%@c?%9UZ+kez z;PwGgg_r6V>Kn5n(nZ40P4qMyrCP3bDkJp@hp6&X3>gzC>=f@Hsen<%I~7W+x@}b> z0}Et*vx_50-q@PIV=(3&Tbm}}QRo*FP2@)A#XX-8jYspIhah`9ukPBr)$8>Tmtg&R z?JBoH17?+1@Y@r>anoKPQ}F8o9?vhcG79Cjv^V6ct709VOQwg{c0Q#rBSsSmK3Q;O zBpNihl3S0_IGVE)^`#94#j~$;7+u870yWiV$@={|GrBmuz4b)*bCOPkaN0{6$MvazOEBxFdKZDlbVvv{8_*kJ zfE6C`4&Kkz<5u%dEdStd85-5UHG5IOWbo8i9azgg#zw-(P1AA049hddAB*UdG3Vn0 zX`OgM+EM|<+KhJ<=k?z~WA5waVj?T9eBdfJGebVifBKS1u<$#vl^BvSg)xsnT5Aw_ZY#}v*LXO#htB>f}x3qDdDHoFeb zAq7;0CW;XJ`d&G*9V)@H&739DpfWYzdQt+Kx_E1K#Cg1EMtFa8eQRk_JuUdHD*2;W zR~XFnl!L2A?48O;_iqCVr1oxEXvOIiN_9CUVTZs3C~P+11}ebyTRLACiJuMIG#`xP zKlC|E(S@QvN+%pBc6vPiQS8KgQAUh75C0a2xcPQDD$}*bM&z~g8+=9ltmkT$;c;s z5_=8%i0H^fEAOQbHXf0;?DN5z-5+1 zDxj50yYkz4ox9p$HbZ|H?8ukAbLE^P$@h}L%i6QVcY>)i!w=hkv2zvrduut%!8>6b zcus3bh1w~L804EZ*s96?GB&F7c5?m?|t$-tp2rKMy>F*=4;w*jW}^;8v`st&8)c; z2Ct2{)?S(Z;@_mjAEjb8x=qAQvx=}S6l9?~H?PmP`-xu;ME*B8sm|!h@BX4>u(xg_ zIHmQzp4Tgf*J}Y=8STR5_s)GKcmgV!$JKTg@LO402{{Wrg>#D4-L%vjmtJ4r?p&$F!o-BOf7ej~ z6)BuK^^g1b#(E>$s`t3i13{6-mmSp7{;QkeG5v}GAN&lM2lQT$@(aQCcFP(%UyZbF z#$HLTqGT^@F#A29b0HqiJsRJAlh8kngU`BDI6 zJUE~&!cQ*&f95Ot$#mxU5+*^$qg_DWNdfu+1irglB7yDglzH()2!@#rpu)^3S8weW z_FE$=j^GTY*|5SH95O8o8W9FluYwB=2PwtbW|JG6kcV^dMVmX(wG+Otj;E$%gfu^K z!t~<3??8=()WQSycsBKy24>NjRtuZ>zxJIED;YXaUz$@0z4rl+TW zWxmvM$%4jYIpO>j5k1t1&}1VKM~s!eLsCVQ`TTjn3JRXZD~>GM z$-IT~(Y)flNqDkC%DfbxaV9?QuWCV&-U1yzrV@0jRhE;)ZO0=r-{s@W?HOFbRHDDV zq;eLo+wOW;nI|#mNf(J?RImB9{YSO2Y`9825Lz#u4(nk3)RGv3X8B(A$TsontJ8L! z9JP^eWxtKC?G8^xAZa1HECx*rp35s!^%;&@Jyk)NexVc)@U4$^X1Dag6`WKs|(HhZ#rzO2KEw3xh~-0<;|zcs0L>OcO#YYX{SN8m6`9pp+ zQG@q$I)T?aoe#AoR@%om_#z=c@ych!bj~lV13Qi-xg$i$hXEAB#l=t7QWENGbma4L zbBf*X*4oNYZUd_;1{Ln_ZeAwQv4z?n9$eoxJeI?lU9^!AB2Y~AwOSq67dT9ADZ)s@ zCRYS7W$Zpkdx$3T>7$I%3EI2ik~m!f7&$Djpt6kZqDWZJ-G{*_eXs*B8$1R4+I}Kf zqniwCI64r;>h2Lu{0c(#Atn)%E8&)=0S4BMhq9$`vu|Ct;^ur~gL`bD>J@l)P$q_A zO7b3HGOUG`vgH{}&&AgrFy%K^>? z>wf**coZ2vdSDcNYSm~dZ(vk6&m6bVKmVgrx-X<>{QzA!)2*L+HLTQz$e8UcB&Djq zl)-%s$ZtUN-R!4ZiG=L0#_P=BbUyH+YPmFl_ogkkQ$=s@T1v}rNnZ^eMaqJ|quc+6 z*ygceDOrldsL30w`H;rNu+IjlS+G~p&0SawXCA1+D zC%cZtjUkLNq%FadtHE?O(yQTP486A{1x<{krq#rpauNQaeyhM3*i0%tBpQHQo-u)x z{0{&KS`>}vf2_}b160XZO2$b)cyrHq7ZSeiSbRvaxnKUH{Q`-P(nL&^fcF2){vhN- zbX&WEjP7?b4A%0y6n_=m%l00uZ+}mCYO(!x?j$+O$*TqoD_Q5EoyDJ?w?^UIa491H zE}87(bR`X;@u#3Qy~9wWdWQIg1`cXrk$x9=ccR|RY1~%{fAJ@uq@J3e872x0v$hmv ze_KcL(wM|n0EOp;t{hKoohYyDmYO;!`7^Lx;0k=PWPGZpI>V5qYlzjSL_(%|mud50 z7#{p97s`U|Sn$WYF>-i{i4`kzlrV6a<}=72q2sAT7Zh{>P%*6B;Zl;~0xWymt10Mo zl5{bmR(wJefJpNGK=fSRP|mpCI-)Nf6?Pv==FcFmpSwF1%CTOucV{yqxSyx4Zws3O z8hr5Uyd%ezIO7?PnEO0T%af#KOiXD$e?V&OX-B|ZX-YsgSs%sv-6U+sLPuz{D4bq| zpd&|o5tNCmpT>(uIbRf?8c}d3IpOb3sn6>_dr*26R#ev<_~vi)wleW$PX|5)$_ z+_|=pi(0D(AB_sjQ;sQQSM&AWqzDO1@NHw;C9cPdXRKRI#@nUW)CgFxzQ1nyd!+h& zcjU!U=&u|>@}R(9D$%lu2TlV>@I2-n@fCr5PrZNVyKWR7hm zWjoy^p7v8m#$qN0K#8jT- zq`mSirDZDa1Jxm;Rg3rAPhC)LcI4@-RvKT+@9&KsR3b0_0zuM!Fg7u>oF>3bzOxZPU&$ab$Z9@ zY)f7pKh22I7ZykL{YsdjcqeN++=0a}elQM-4;Q)(`Ep3|VFHqnXOh14`!Bus& z9w%*EWK6AiAM{s$6~SEQS;A>ey$#`7)khZvamem{P?>k)5&7Sl&&NXKk}o!%vd;-! zpo2p-_h^b$DNBO>{h4JdGB=D>fvGIYN8v&XsfxU~VaefL?q} z3ekM?iOKkCzQHkBkhg=hD!@&(L}FcHKoa zbZ7)H1C|lHjwEb@tu=n^OvdHOo7o+W`0-y3KdP#bb~wM=Vr_gyoEq|#B?$&d$tals ziIs-&7isBpvS|CjC|7C&3I0SE?~`a%g~$PI%;au^cUp@ER3?mn-|vyu!$7MV6(uvt z+CcGuM(Ku2&G0tcRCo7#D$Dirfqef2qPOE5I)oCGzmR5G!o#Q~(k~)c=LpIfrhHQk zeAva6MilEifE7rgP1M7AyWmLOXK}i8?=z2;N=no)`IGm#y%aGE>-FN zyXCp0Sln{IsfOBuCdE*#@CQof%jzuU*jkR*Su3?5t}F(#g0BD0Zzu|1MDes8U7f9; z$JBg|mqTXt`muZ8=Z`3wx$uizZG_7>GI7tcfOHW`C2bKxNOR)XAwRkLOaHS4xwlH4 zDpU29#6wLXI;H?0Se`SRa&I_QmI{zo7p%uveBZ0KZKd9H6@U?YGArbfm)D*^5=&Rp z`k{35?Z5GbZnv>z@NmJ%+sx=1WanWg)8r}C_>EGR8mk(NR$pW<-l8OTU^_u3M@gwS z7}GGa1)`z5G|DZirw;FB@VhH7Dq*0qc=|9lLe{w2#`g+_nt>_%o<~9(VZe=zI*SSz4w43-_o>4E4`M@NPKTWZuQJs)?KXbWp1M zimd5F;?AP(LWcaI-^Sl{`~>tmxsQB9Y$Xi*{Zr#py_+I$vx7@NY`S?HFfS!hUiz$a z{>!&e1(16T!Om)m)&k1W#*d#GslD^4!TwiF2WjFBvi=Ms!ADT)ArEW6zfVuIXcXVk z>AHjPADW+mJzY`_Ieq(s?jbk4iD2Rb8*V3t6?I+E06(K8H!!xnDzO%GB;Z$N-{M|B zeT`jo%9)s%op*XZKDd6*)-^lWO{#RaIGFdBH+;XXjI(8RxpBc~azG1H^2v7c^bkFE zZCVPE+E*Q=FSe8Vm&6|^3ki{9~qafiMAf7i4APZg>b%&5>nT@pHH z%O*pOv(77?ZiT{W zBibx}Q12tRc7Py1NcZTp`Q4ey%T_nj@1WKg5Fz_Rjl4wlJQj)rtp8yL3r!Shy zvZvnmh!tH4T6Js-?vI0<-rzzl{mgT*S0d_7^AU_8gBg^03o-J=p(1o6kww2hx|!%T z-jqp}m^G*W?$!R#M%Ef?&2jYxmx+lXWZszpI4d$pUN`(S)|*c^CgdwY>Fa>> zgGBJhwe8y#Xd*q0=@SLEgPF>+Qe4?%E*v{a`||luZ~&dqMBrRfJ{SDMaJ!s_;cSJp zSqZHXIdc@@XteNySUZs^9SG7xK`8=NBNM)fRVOjw)D^)w%L2OPkTQ$Tel-J)GD3=YXy+F4in(ILy*A3m@3o73uv?JC}Q>f zrY&8SWmesiba0|3X-jmlMT3 z*ST|_U@O=i*sM_*48G)dgXqlwoFp5G6qSM3&%_f_*n!PiT>?cNI)fAUkA{qWnqdMi+aNK_yVQ&lx4UZknAc9FIzVk% zo6JmFH~c{_tK!gt4+o2>)zoP{sR}!!vfRjI=13!z5}ijMFQ4a4?QIg-BE4T6!#%?d&L;`j5=a`4is>U;%@Rd~ zXC~H7eGQhhYWhMPWf9znDbYIgwud(6$W3e>$W4$~d%qoJ z+JE`1g$qJ%>b|z*xCKenmpV$0pM=Gl-Y*LT8K+P)2X#;XYEFF4mRbc~jj?DM@(1e`nL=F4Syv)TKIePQUz)bZ?Bi3@G@HO$Aps1DvDGkYF50O$_welu^cL7;vPiMGho74$;4fDqKbE{U zd1h{;LfM#Fb|Z&uH~Rm_J)R~Vy4b;1?tW_A)Iz#S_=F|~pISaVkCnQ0&u%Yz%o#|! zS-TSg87LUfFSs{tTuM3$!06ZzH&MFtG)X-l7>3)V?Txuj2HyG*5u;EY2_5vU0ujA? zHXh5G%6e3y7v?AjhyX79pnRBVr}RmPmtrxoB7lkxEzChX^(vKd+sLh?SBic=Q)5nA zdz7Mw3_iA>;T^_Kl~?1|5t%GZ;ki_+i>Q~Q1EVdKZ)$Sh3LM@ea&D~{2HOG++7*wF zAC6jW4>fa~!Vp5+$Z{<)Qxb|{unMgCv2)@%3j=7)Zc%U<^i|SAF88s!A^+Xs!OASYT%7;Jx?olg_6NFP1475N z#0s<@E~FI}#LNQ{?B1;t+N$2k*`K$Hxb%#8tRQi*Z#No0J}Pl;HWb){l7{A8(pu#@ zfE-OTvEreoz1+p`9sUI%Y{e5L-oTP_^NkgpYhZjp&ykinnW;(fu1;ttpSsgYM8ABX4dHe_HxU+%M(D=~) zYM}XUJ5guZ;=_ZcOsC`_{CiU$zN3$+x&5C`vX-V3`8&RjlBs^rf00MNYZW+jCd~7N z%{jJuUUwY(M`8$`B>K&_48!Li682ZaRknMgQ3~dnlp8C?__!P2z@=Auv;T^$yrsNy zCARmaA@^Yo2sS%2$`031-+h9KMZsIHfB>s@}>Y(z988e!`%4=EDoAQ0kbk>+lCoK60Mx9P!~I zlq~wf7kcm_NFImt3ZYlE(b3O1K^QWiFb$V^a2Jlwvm(!XYx<`i@ZMS3UwFt{;x+-v zhx{m=m;4dgvkKp5{*lfSN3o^keSpp9{hlXj%=}e_7Ou{Yiw(J@NXuh*;pL6@$HsfB zh?v+r^cp@jQ4EspC#RqpwPY(}_SS$wZ{S959`C25777&sgtNh%XTCo9VHJC-G z;;wi9{-iv+ETiY;K9qvlEc04f;ZnUP>cUL_T*ms``EtGoP^B#Q>n2dSrbAg8a>*Lg zd0EJ^=tdW~7fbcLFsqryFEcy*-8!?;n%;F+8i{eZyCDaiYxghr z$8k>L|2&-!lhvuVdk!r-kpSFl`5F5d4DJr%M4-qOy3gdmQbqF1=aBtRM7)c_Ae?$b8 zQg4c8*KQ{XJmL)1c7#0Yn0#PTMEs4-IHPjkn0!=;JdhMXqzMLeh`yOylXROP- zl#z3+fwM9l3%VN(6R77ua*uI9%hO7l7{+Hcbr(peh;afUK?B4EC09J{-u{mv)+u#? zdKVBCPt`eU@IzL)OXA`Ebu`Xp?u0m%h&X41}FNfnJ*g1!1wcbbpo%F4x!-#R9ft!8{5`Ho}04?FI#Kg zL|k`tF1t_`ywdy8(wnTut>HND(qNnq%Sq=AvvZbXnLx|mJhi!*&lwG2g|edBdVgLy zjvVTKHAx(+&P;P#2Xobo7_RttUi)Nllc}}hX>|N?-u5g7VJ-NNdwYcaOG?NK=5)}` zMtOL;o|i0mSKm(UI_7BL_^6HnVOTkuPI6y@ZLR(H?c1cr-_ouSLp{5!bx^DiKd*Yb z{K78Ci&Twup zTKm)ioN|wcYy%Qnwb)IzbH>W!;Ah5Zdm_jRY`+VRJ2 zhkspZ9hbK3iQD91A$d!0*-1i#%x81|s+SPRmD}d~<1p6!A13(!vABP2kNgqEG z?AMgl^P+iRoIY(9@_I?n1829lGvAsRnHwS~|5vD2+Zi53j<5N4wNn0{q>>jF9*bI) zL$kMXM-awNOElF>{?Jr^tOz1glbwaD-M0OKOlTeW3C!1ZyxRbB>8JDof(O&R1bh%3x#>y2~<>OXO#IIedH0Q`(&&?eo-c~ z>*Ah#3~09unym~UC-UFqqI>{dmUD$Y4@evG#ORLI*{ZM)Jl=e1it!XzY($S3V zLG!Y6fCjE>x6r@5FG1n|8ompSZaJ>9)q6jqU;XxCQk9zV(?C9+i*>w z21+KYt1gXX&0`x3E)hS7I5}snbBzox9C@Xzcr|{B8Hw;SY1$}&BoYKXH^hpjW-RgJ z-Fb}tannKCv>y~^`r|(1Q9;+sZlYf3XPSX|^gR01UFtu$B*R;$sPZdIZShRr>|b@J z;#G{EdoY+O;REEjQ}X7_YzWLO+Ey3>a_KDe1CjSe| z6arqcEZ)CX!8r(si`dqbF$uu&pnf^Np{1f*TdJ`r2;@SaZ z#hb4xlaCA@Pwqj#LlUEe5L{I$k(Zj$d3(~)u(F%&xb8={N9hKxlZIO1ABsM{Mt|)2 zJ^t9Id;?%4PfR4&Ph9B9cFK~@tG3wlFW-0fXZS_L4U*EiAA%+`h%q2^6BCC;t0iO4V=s4Qug{M|iDV@s zC7|ef-dxiR7T&Mpre!%hiUhHM%3Qxi$Lzw6&(Tvlx9QA_7LhYq<(o~=Y>3ka-zrQa zhGpfFK@)#)rtfz61w35^sN1=IFw&Oc!Nah+8@qhJ0UEGr;JplaxOGI82OVqZHsqfX ze1}r{jy;G?&}Da}a7>SCDsFDuzuseeCKof|Dz2BPsP8? zY;a)Tkr2P~0^2BeO?wnzF_Ul-ekY=-w26VnU%U3f19Z-pj&2 z4J_a|o4Dci+MO)mPQIM>kdPG1xydiR9@#8m zh27D7GF{p|a{8({Q-Pr-;#jV{2zHR>lGoFtIfIpoMo?exuQyX_A;;l0AP4!)JEM$EwMInZkj+8*IHP4vKRd zKx_l-i*>A*C@{u%ct`y~s6MWAfO{@FPIX&sg8H{GMDc{4M3%$@c8&RAlw0-R<4DO3 trJqdc$mBpWeznn?E0M$F`|3v=`3%T2A17h;rxP7$%JLd=6(2u;`(N3pt&so# literal 0 HcmV?d00001 diff --git a/app/img/icon-instagram.png b/app/img/icon-instagram.png new file mode 100644 index 0000000000000000000000000000000000000000..150ee4ac15dbc311907146bb99f27653c6516ecf GIT binary patch literal 3362 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 literal 0 HcmV?d00001 diff --git a/app/img/left-arrow.png b/app/img/left-arrow.png new file mode 100644 index 0000000000000000000000000000000000000000..b44ddbf4c4594227fb1e7f1eec41c77e502466d4 GIT binary patch literal 1038 zcmeAS@N?(olHy`uVBq!ia0vp^!ayv?!3HGHol_M8Qk(@Ik;M!Q0yzu}eES%iLSL6N zFff&8hD4M^`1)8S=jZArrsOB3>Q&?x097+E*i={nnYpPYi3%0DIeEoa6}C!X6;?nt zNLXJ<0j#7X+g2&UH$cHTzbI9~RL@Y)NXd>%K|#T$C?(A*$i)q+9mum)$|xx*u+rBr zFE7_CH`dE9O4m2Ew6xSWFw!?N(gmu}Ew0QfNvzP#D^`XW0yD=YwK%ybv!En1KTiQ< zZemh?X^E|p638MrfVi_HGYw%=UNO{LKo9DJWb_U74D{h<1GUYEzafYqbOAZ&x^ibT?7XlZD!Zv@kYEQ78Kp(!*kv&7B_Y7v?+x-RGZ+=8Oi z;$n~s4WU|)#n9FJ7iFdb!xHQxn0jO}boBul`6ccI#cPMH&OqD;3ZdO+2rcJU6!A|Z2!mh*0AW%^Ep$03OqN~+kLF> zsDjmN86DPI=Bf=z&KFD<_#X^nH(-fnyvcFItc>Ai0FQQ)Q-tA@e?~CvKx~pkzmGa$gb(1^Z!5n7JruHZK z>#V+CV&VGM%6aFBR)B#;Uj8bF-q2>dFxIvWNd|4Ajhbhe_ATrPzj##On9{w58=CVI zdcrTZvL+{T-HCVAp2j4e7y0AlK^B?Cn_b>bSbstj=%Kki-F1^@*I0R;sC1qJ{H z1po#H00svE1_c2I1_1^K0tN*D2L%8J1_1{K|NsC0|NsC0|NsC0|NsC0|NsC0|NsC0 z|NsC0|NsC0|NsC0A^8LW0018VEC2ui0LTDh000I5;3tk`X`X1Ru59bRa4gSsZQppV z?|kq7z@TtQEES$ZnKEwa~CRSj4F@S|zc{BlrGIfYP1ptI1i;pw~Y&4QqnTdyIHjY4!oh5Y(HI|K{ zo_B+jE`qQ(a*QKxs&}(2Y;~orD{;0jwYfTHT`HA*yDU>y3cxOIdzY*|2B5 zU>dQH3%z*;EtU}YYvDW*##%HH1}RVhfG4{D9qcG0A_*xdJ$?k4tq{nNHPn;<^Dc$2 zU>QtREJ%ya)C(xCZdUG?=(ZnMM^G;NzF{FWv0zX(CMecUHr$$+irSPru zEX6YiZ!osC+xk6$lNG9wP@R9?1mKkaW%1E<-3$VBQ3-)@EU*VBVF*K?6LB2GM`9cL z^Gb#tZ86+Qd-X;he6~3PfC2Y(w26J5;Di8DQh<1yWF2Z}p)2(q96oWUiw$a@;`5TFr(W+`M=jIxj@MjLu* z!##dNagRBhnxI`nO}dw9aPJM`lBZRy+JbgF1`!#o{%ir&MhzOb&7rgfB5MnSw8tTt z?mZ&Oio64N>c@mb3_FDXu{6k03MRr>nCcIs=I54$ldfj&x#*^=?z-%@>+ZYo z#w%|g)(U}ZPH65}?^9R4w`P$tpjPW&j!ZaeS;6``mQI)m6l1JG1mM|D=`wy}V*C1JI`D61piuJYl}l0Jf>E>wf0U>r}HOx=`%gc5dhS*LtOfJ(|%rY!Zf5zEVVA;HCl;l99D`NN6m3g{)zVz91gV z-Roh3=L~5IZc+K?~FDH=rMB!%qqkzFEvywl}5cp%Y;T<&X~XW_m9;hBqsvD9nzhI-`^3Gz!v zGPMv$_GS{?Rm|0p6=PT??d!<@tMu6kLo%4knUf#TL~^|HV8IZ!nGoSlU@U0hZae}s zo?4jpKq?qQ5@SJG53mKi$E7ENk|9rKa*;YMJc3#zpcVY67bo28Vs(uukOdPx4@{Wb>O|VWc&Dh{FnnP>`#%48@c(AHRRaL`YH&8 zQ{7KDgeySQ4)P@b2cm#`wosq+nnNStEum7|kXcKhltnm1~g}h zYs4f-QYoS<8b>NzITU|Jw22dyLkhKco+(hNN{VeuN3U}w5epcn%aj8}IYLos5j0&ZJT&W5?7||MYYauzNNU2BcQzWnp zr`h`UP^nqNMue&mNI5lj6G6V@Z?ECOrut|&;h19)0c9x>`A1C`JPHmQ1k3`7#|4Uh zpc1JPggp~^1zFBY1Q`5{5B4cjEbf4KZZIkP06D3)4F)x~a)?3?dX&li;|MW*&`)U) zvWRHLUNO1ZIDUbL6BWZ32EY;y1Rz&RG?j8@8fv@_M!D@NBA>ey!YF4qFCy&0mMz*J zw%h}F)_OqZ3t!PI}+R~c#w5UyOJwgBgJ6`!h AApigX literal 0 HcmV?d00001 diff --git a/app/img/maya-logo.jpg b/app/img/maya-logo.jpg new file mode 100644 index 0000000000000000000000000000000000000000..b4a2f6b4354b9422cc631d2d09da137a31701d0f GIT binary patch literal 7705 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 O{QF;k|F6k=F!^7n+mbr~ literal 0 HcmV?d00001 diff --git a/app/img/nav-bg.png b/app/img/nav-bg.png new file mode 100644 index 0000000000000000000000000000000000000000..800f904ddc7d1f2bbd2b82d7eb20d23fdfdf406f GIT binary patch literal 995 zcmaJ=O=#0l9FHH9IT@liJ8OWxM7B`+qgYqo>< zfrp`@;6+4FdJ>%AX|SOl1QCazhaEh4^5_S6R`8{3I}g^t%X|OF@AvzEzSZL7nf|`x zeH_R28xwko?R(f7>OH{zk57I?Y&%BtRaz!>7Rp!M<0TVT&ACB4w{#VnPtQR*wA*l09_MoJ*T zyeMU}*;pf)OfWT9c$a94U+kd z@`?uc&h#8KZv9>#*gUj<=H`v}*~3SV+}XIcwRIxbw|#bM_`%&Lmrh?-r}g_w>t7x| n|JJ*DVdLqqo~_Ln_3gwf?oD|*`uX|YTKw#c{G`4%K6CXCqme#T literal 0 HcmV?d00001 diff --git a/app/img/nav-dot.png b/app/img/nav-dot.png new file mode 100644 index 0000000000000000000000000000000000000000..a28a50789f37f6afc9abc8b1495c76cacf7a1889 GIT binary patch literal 1901 zcmaJ?c~BEq9F8ecjRB?=6-CH4K`|PVYzX8a!6E^TArTTRp-N$stPo+dFWN~D-B{56QMxm`@BQ9<-}gJ;Y<{$2 zsT*kyi9jH@Nta2K_)5lKzbUTx_uRJbAMj;17NN#e=o%~&GQor}9jbu=DFP+KN*K~* zt-A<|2!wa2`dBrlmPZM-D8huC7^Vd=;%ovzwAf;Vw5c!#Xy9bMK};R`zK#m$bz*8< zken?yhQlfPW!WZJm92=?W~XWeI_lz3Kx7f(0tk#jfCWi2n1vQG^|h`L-#d?4RNyrP zOBGZ92}&)G2EtJj3c8F+FMkoQjYJO~=GkJkozsK#Xr>4d$^j;RRz^AR`N8vYjc71LgAnha$)uv>8*v zZ{z(>VRLMj5oRf2Gn#JF;*DEFbGkAL!%Z-Rp{7_AO&hObbP9^0<`mQjgsXx8Ii%Ga zoc3$HTrQLv%ot?Q!cvKtiYqYndYv$w%L@}of(6`24hVt~Y<@5p5dpHfk&*mJ{t`~u zI9Gyd(-GK!jdOKxxnUD>ouhylanBOiq|bnLktP%YUZ*V7PaF$xLcKArZsJ(@6LML2 zFf3C$dv*=2P{nz*4ppDK z)A4Lcz?9|tv4hb*g^VlJ{I2Iq0*Qg(gQEP$lfCBk=cT2|TF#uU%el~{8|v*j(?q%Q zG0-CD;S?=a?w$dCp-gYjAnu~r9C_W{8z~v6YECI53m{>oZ|U$YyU}-`Wo=LYq?xMT66iRh>FTzEDswtL2^j1KQD& zX@2)qg)P0+(oeQ3)+2~xR_22n=Y}<+=;Mdix|dwF>`P>@PA2xm58phKo13e0ZBk@l z*rlV3=sk0bT1fBbyOb~^V#w>_g9iqrD_*{Q=~E1adXk=wB)WQN(rH!8!)MyoYG1r) zXlU?o5qs@uwO9NI@BZ>$r!^yFuVU4qM*W_$9qJO#yq}8w;^!YraKzbdVCjeqzn8m? zm>MZES$?xR>TX8_IEUtuMQ=p*K(B7xPkZ=KyL3pQ$O|}O5xom5zq|Tp?}Hi#ukPOS zM{YY>r{@fxtv!9Gp)Y$&LPA2__U+sE`Nx!Nvim*?Nesc>%eDWu#3qaQ-e!IQ(H zpFKFVKKj*YtvqRv1M^+16;T(`oBB<@6+u$T=F{DdjNNig`^uGr1MwVV^Tv2Rg7oAN74>GDw(&R^?^n+5#*Erib(8UmaWl&gm5G*|b$?*AZobNpuS1TD{U&t-;+`8GKsL z&hpE>L|NJS4z7CPB-sX6*+Mlbcb>O8yK*((ejvxT!CrilBqK9s*LM&}$rWTuh5ICX ztgH1oBgOB0M`F^&(K_`)qKvA(eSRl6O$OSFo2*ps(;57)a_Y%vW8xsG4Se)vT>bP> zf9<8w7s-yhLyB^Dm+-GAS27BUKku8!fmFF4%j9K@hFec{A?d)l#Wn}~2 z-rjI&dw2ID%^gvB+tS{wz9Npp-k_jE*6KH$-AYAEs@Rc5T4P;_~~mwSN(WVQd$ zBT!EeODQdtMrpB?Q=smbU5ww+P0S{U`Uc08l`KGHH|W(2p89m>9z|*@Pj!YwMl|Cf zqqP()&{1ehDTS;ORjGy;S?_RIKnF-B9X)5*oWoNKx*T4++cZTkKv0&aew#{*?PMHU zfDHK=pTdM0GR*qfU~ME4*-i!+mZ6yd%?5mIgbM~Zh9Qd|g|k^|4<`xD#auYzsSH9U zN7MOy-k%Tpq18*X(P-4w2n2i>;j{Y z1!M%R6ok1_727iqK|2FYGTsp)MOo1dH(tPtB9}C5BpV7y3Ot1s{F@GW)yIxLyj5|n=EmyB*VpW= zB|OaWCEhM#>C4%!`I=Q1`i2LdjU5`Dv^%|<-hcTT{Kq1`*u;Blzw2cG3mV9I5$5!*gJl3!)*Ih@Oi_}p^CNli{4^$ ZE4zq&)l;5ihI!yV|74;~xY^Wo;umj`cl`hW literal 0 HcmV?d00001 diff --git a/app/img/play.png b/app/img/play.png new file mode 100644 index 0000000000000000000000000000000000000000..16e53f8674546f9d1530ef1b29a8559eaa948386 GIT binary patch literal 1562 zcmaJ>eM}Q)96mrN;!uJJbu;F;#^|u^-4)u>h9YgR*vbyDR6!ibaXsKB*DKe97Fnif zG%bFjGEwKZLzzl~I(2kv7RBLoo2ELQi4J8Zn4ufQZ-(xQ6!!=2lDqf)y?LJJ_q^}> zJn#bqiA8SaKkr4rm%*{9iHUOl|aytleF~x($R4HxOLVx+rLLhC^ zLb(bY!5s#wj5aOdsGKF4R&vQ=Qf-4~rGhDLjUd2KJOR3ya=TOG)&T2bPxTSWdIH-V8PLiV? zJk8p{fFe=MR`Oa%aQbEojAK~V?i@NM;lN-w;eb&Y64+7@h~xhcWtd^KlebWB{f;Q? zv{pMP*g`qkN{$pRu0$MY<lZDwg>7#JdSJ3 zb|+8RNy?0AAwfY#(>9IXkc_I-iX;`5oQ|SKBpF3fy+WC&Ga{HyZcqlf7)w?%l${T9 zZEv}XcX9(!U>rhcjN<4j%9hTt3^=%D4LyRFL`2Pd?VmSDeT}V3@h_%0}6aYfknK7N!eXFMt&zh(cE&ClenR5J_ zroZpaRp_!_MZB&ZGvVH7S@+d_DB9ckJqCU=YE49Jetw3bUR1x~V4mNa|L|zf(U=6! zN=tm2&-d{8c>9`O@wG?C?H9}YY_2=Ew_f(YXh{pN-B&esdD*X2nOI#E{DBDQyIVw`bH%TDnNKrAQK^*Qq4Z=5r-+JJh1*RTFFCGOP_QNWQM?O4!lwqT~x5eZDRD z`NE$rNE*-qE@JBL-7}hgCgq`o1^@s6 literal 0 HcmV?d00001 diff --git a/app/img/progress-back.png b/app/img/progress-back.png new file mode 100644 index 0000000000000000000000000000000000000000..68cd45b6706bc9b1870d83842c89fc3423429a67 GIT binary patch literal 929 zcmaJ=J#W)M7nbtU%MX+CVll+;eBB^*UbBr^75UlS{}&pls=6EUD} zY%Kf*M*aW;BVuJj%6lLE#b9-Xn5o>q% zzWCP<-#5kfn74+!PcQf!Gomy@IwHV}@tE`o4i{HnNkdWY!e}t$L;r;p&{)M1qvmlc z*ox9P$x|Fm2?rxGjuIRG`t%usD74|rijVx%A(QBA$w+_M83fB|V21GIDQM)D5QquK zAdfGT%*t)J(zV1{UTYAnAbe`Wo1lh%7dVs=P*G7SKve{)x~i9tYqi=FU?3f7$k247 zq}QynVIc(89~9nLcwzP2_S%=QY&hXOwKQ!$pR4n-O4(S`P1BSbhEWoTQnpAq&Pz#l zR4BM43s{u$h$cWP;t`#38;VG8Qi#)yY?7_ZBnqbGIMs9&$&?D9@Bbef#~XCUd*n9W ze+p-VMM|_D$>@v)qHz~T(p73Xj9^aLfYQsNiroq2G@H;AIQ zBp{w^L!qEXQD_-v)2tdb_t-^kU2ma!yYAL2sM4x9sEo?Zg6q;?7L$Y*-0+s$+RBxq z5U0YkOIY-Zgl$G+uu9pAw#Rb1Rd3A=x5wgaXGL*2lKm;pN&$wwzUX_W*k_SSa*Ucq ziDWBE^*Bq2KcNB)=qQYB`0MKh1Yuyq=cb3eq)x}-$%51FqSf;k6WpuoQ@> zARvp*;}mB$T3Bv{jCvza<8sf>>_-LkA)!!U{xQB3EtAXza^ z57r6}O?@6FB4jbh70G~2g$-q-S1ClvMmA1YWs(KcGLmSzit?1!K+pR>G>SIpRCMTd zy#EwVd-H^99h$N!_hsXT2f3>R*EuDE@g8I6>ngU#Ot5s!5>W4&z$1Pb=k^lsdDx9p zL1Le}jt!-P8ioNjteSOXRP;j!HFdp#D$R;hF_GCY>!^fEwKdma{xqVoSaXAGuCbMy zk3y74&kp6`YZ^2;i@-8v9Bz%J+}x_S;s)DeL0h?+3`WZv`&XmaS8{st<7RB7u^D_C z%W3CwtY3UOdn%vAJ=dxAvLA!rmzNiXyM;SHA1F6(D{sCRPTxQK@-crjZlmRVe*E(7 E9|9d3=>Px# literal 0 HcmV?d00001 diff --git a/app/img/progress.gif b/app/img/progress.gif new file mode 100644 index 0000000000000000000000000000000000000000..f3e45e0569c02ae3fe7114691e5b5aba892e9ef4 GIT binary patch literal 2608 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 literal 0 HcmV?d00001 diff --git a/app/img/shopping-bag-icon-big.png b/app/img/shopping-bag-icon-big.png new file mode 100644 index 0000000000000000000000000000000000000000..ad4e2c58932ca511ec195e0e97a591b242b47425 GIT binary patch literal 1320 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 LNkvXXu0mjf-9n(} literal 0 HcmV?d00001 diff --git a/app/img/st-cat-sprite.png b/app/img/st-cat-sprite.png new file mode 100644 index 0000000000000000000000000000000000000000..4cb45d916f7311b3466d5e5ea22bb14450068626 GIT binary patch literal 2901 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 literal 0 HcmV?d00001 diff --git a/app/img/thumb-back.png b/app/img/thumb-back.png new file mode 100644 index 0000000000000000000000000000000000000000..3c969ebd5276c73df8c1e8f4fb205731f00a0793 GIT binary patch literal 2122 zcmaJ?c~nzZ9uA6tAO&O@w$bDPts-QD5Qw1~NCFW;k$n>h$pZppA$eg_Jc2BOkPJjc z7z?D-kwKJ2kRmp?P#Dy*iY+MXwCFjC!k{b)GA}B2{;>1TdGFreJ>U2JzI*R?&dc}p z@zB*a*G3=^x(rXMA3R#BUM&syE7F}f4G(4zEd=rx#6T%55s0901koUp!DGdOejtmJ zmed215s1wIHy{KGVS1C;0v?*B!k|-mLYR#}koTnuS?mN5LPmqJT)r#tvb_U9ayhO* zFoB6>3f;jtu4lRk^iTH*V5cXrT{ytLuaV?b5-h+2Ar>-~m&g~BQeA=fx+Hk6TE+m# z_Yf$-75HE(gz1ZP7l=S40gbh1W1X-_Cmb5*;7BAA?T~mZ4vWF!F*v+Ej!1IAldxFi z#|MDBi8wJNKPvrWFSv3A;vh&!!eCNTQqU<5Xn`megL83lQEA}u_AtU;oW_S(srG!a z)rJBU6thKKA;cB%kt#)2v_Jy60NJN z@jju&kRSMm-_Ht*1JZ;b#t#$=BqBC^aWPh^Rzi}y2xLJ5QGh^@xN(ZUaRNvnjuQxx z?*0TMlf~xpRrPy3lSyLm#Sn|n1{qXW09HVAxf~L~2}ht49q4!FBjkt||&VA>5e?inz%jhb|KEkngul;(o>pok+kF z33LLi=lFRqAGn;)c=^b6`cp0jHiJ=J?EhT!#uA(!)$~(r;o?*9K|Y*z5gcnNYUvmP zp{`_5DFLaYbwS}?>|mqFC-G<#2SVfJQdS){%+Nyzusz$Tou&6q+pH0jr8h0`t<;!j zXus~!^xAKyyD2pWfY(+daPJFZ-ZlU#?wlSqz&P z-A0ajK08YZ4Kt>V0=rMPFh7P6)3J2IOWW#m^YX$i%*{t+S7FR#CUt|MlfpUmXqz43wO^Z&LL1nxfX$TE5lOdU~>~ENx_H$f3UDjf=k4 zs=R0}-$!d`XlTOa(3NC)kEq`6G-wt*pmig?#c_0G#N|Tev%%h8>Dhtj7urlt+@DSE zSgvhqI;1b&-_aaFsZpui$GH&;op1oVo$m$P%XO97*DXdR31z`aQt_LQdx216`(zEXP>SfgYpzSQIIG6`|ssv zEH}@Gn9j_^u-NR)AsYBT+MYzGaGF?rb#rT9Qd>k@ZeHbJbyZcBUl*g`d?-N6)RZ2a zTAFwmB^LWzd7uzmiKR_-inx|**MjWO=yy!AhJx|P*N7LkS|6xmkiSVYPg67CvA(Rk z5$&RDy{VagSEL?4x-0M9kaza^gF9+=1Tp-s*hS$YMYd|=l|hrw?Jh@TAtNrk?%s>4 zwk^FUL%EfgeV5VyAH!Rnd--I^>5Xh=KSdE2AHzvUXp zdi(lhiCI00+FVZ z_}=EGB)b}ynqr=N)I;sT@Gz^$SS`7*nUX%p$tnO(l;60taNaySY~6h4&cnCNM$0%^ zr%NVR0gb;5SR0v~*)Ne0&K>M3=?UmsIrn06>Fq_SOeTNObhflqt}(S6kgh%Ne7Vrp zIR7*#mQF6tmM>^g4e>Q~S_2`|U6$GoXZkxkI}3XokA#lKCHAu+2r7sT>?f}sKWdQV zXwtVVU7UNH!IyQ5sl9gg_CG4o<3ZbPB@`wafj(bp(Vg9b)V(Nam*}Etk8ylN=#!;-Sto+>mnClsy zz!1LHc|e3iI_vbvDp=c{-fH~)?Vk$&L9MzQdn>B{)YfT=VEpM3^_iKO)upzU{B-|g z@vBo1X@Nu{#WxsvhnyhSo@(ys*lBKI@#uQ9^u<5JO%<(rKWc?T(|xaBj%bYaMp_LF xtS2ovX^j0adwo)T{R_FB(gRpQTdeN6iAXqGEl}=_>r?&R88jd26}PCY{{nWXZV&(f literal 0 HcmV?d00001 diff --git a/app/img/thumb-forward.png b/app/img/thumb-forward.png new file mode 100644 index 0000000000000000000000000000000000000000..afe451c75d0d6072a77a67f5ebbbf862dda8e3c4 GIT binary patch literal 2118 zcmaJ?dpKKZ8jo=)hE%KVpqXx@jMheOB*;n?afyl{(G{vwksPEXCzpc=k6PDKw8g5@ zr{gk))-^6ei?%x2t}Zngx?>krqok%!m6mQ@W=}fR*+15v=Q-#5-tYPSe((Fe@9%j| zmY=Vup}v_u0)a4Oc+pw#ic-J2I`CI&I8_KQrjR=aVuRsO99Ie;T=-xZfMy7}5daI| z^5Z3afD;0ti4g>FAP&=q$^(Tst{Q`r3&k)SfpBt`i@Cfg078cW5dskn^Rn|c1})&z zFo9$yfhl$aA_ZOwDZp0v2JjS7JV!pp`3TxcPK5=80K`Shh0!7zRZhda*QLUH^)ViU zeh-17XqexM;xPTtZlDxElW_za9)UtYQ;0aCt)0ESJr+$O5D9n!2~Q;15bde9Br1V` z{_tSnY*KzWl|}dXkPD7zm`Df`Q}Ot?xHw##Ee@1M;E9foj%p1O$p%K)$l^s1S8gMc z9o$l&12UdeAch2>2(4D+hJi5<4FgyD+ZBZ3kFp}!hc>|t!^^p1JP}7wUug@-Wd47s zQ1}rogIK`t_5M#`SwOrPz_S1u7$fDug9|^XP9>(gNdYbdN&`SJdaH|mkst)hB0(|Q zjZH=~xjcbL9lysjnN)^I2606^fI+8WU#x-D4#%1*W$>NB@pxpRXNa@Jb z)URDtRkP_6qQ+(p7C=4NYq2})d%4qQ9NOqDz~}R0WU}Ru4NAt_H@M&mlH1m>^sMJ!Zfd=LlI`_*+EAHJEqt~3h`3;QG%V@_DYnwWI3 zt8#Fy!S!te0|T*kAk;aLZZ>Uvv#_XWjN!m2>^DA$ zPM#JD>qq5wmrCX_x+%wB-S%}ZbA5oU_vbwcC03>w3r5hx ztN`nnhouf{C)2)Jd?$85We@iP@1}zL_v=8bmdJs$l^B$NqC_HzoMoP_0?TinF(Q`cH8D7&#v1SHZi8=Yth7Ch{^FwjilzD~$Zuh13M?+=u z)IR@-M>VL63*E2nZ|3CX`ARZShrAp2l1#Jj6?oeu)wNyB4JABTUfamD2nT>!+U(II z<~PXSDV370*4EeKUfQ|G*NUIzGIdve{nwkgn3#>4tf5%rmEauJSwCf0SJ#|$^d$9< z4;L(RQZ4?z`p*)Ai%*IMa%FWL?m?vrDjBArUbsX^ng=HDF2g+^Xub6= + + + + + + My AngularJS App + + + + + +
+ +
Angular seed app: v
+ + + diff --git a/app/index.html b/app/index.html new file mode 100644 index 0000000..f402588 --- /dev/null +++ b/app/index.html @@ -0,0 +1,82 @@ + + + + + + Maya Meirav + + + + + + + + +
+ +
+ +
+ + +
+
+ + +
+
+ + + +
+
+
+
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/index.html02052014 b/app/index.html02052014 new file mode 100644 index 0000000..748cfab --- /dev/null +++ b/app/index.html02052014 @@ -0,0 +1,80 @@ + + + + + + Maya Meirav + + + + + + + + +
+ +
+ +
+ + +
+
+ + +
+
+ + + +
+
+
+
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/index.html13052014 b/app/index.html13052014 new file mode 100644 index 0000000..19b99eb --- /dev/null +++ b/app/index.html13052014 @@ -0,0 +1,80 @@ + + + + + + Maya Meirav + + + + + + + + +
+ +
+ +
+ + +
+
+ + +
+
+ + + +
+
+
+
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/js/app.js b/app/js/app.js new file mode 100644 index 0000000..fc33cca --- /dev/null +++ b/app/js/app.js @@ -0,0 +1,11 @@ +'use strict'; + +// Make sure to include the `ui.router` module as a dependency +var myApp = angular.module('myApp', ['ui.router','ui.bootstrap']) +.run( + [ '$rootScope', '$state', '$stateParams', + function ($rootScope, $state, $stateParams) { + $rootScope.$state = $state; + $rootScope.$stateParams = $stateParams; + + }]); \ No newline at end of file diff --git a/app/js/controllers/AccordionCtrl.js b/app/js/controllers/AccordionCtrl.js new file mode 100644 index 0000000..bbfae26 --- /dev/null +++ b/app/js/controllers/AccordionCtrl.js @@ -0,0 +1,29 @@ +'use strict' + +angular.module('st.app').controller('AccordionCtrl', ['$scope', '$log', '$sce', + function($scope, $log, $sce) { + $scope.accordionGroups = []; + $scope.oneAtATime = true; + + $scope.$watch('attrSrc', function(n, o) { + $scope.accordionGroups = []; + for (var i in $scope.fields) { + try { + if (typeof n[$scope.fields[i]] != 'undefined') { + try { + n[$scope.fields[i]].content = $sce.trustAsHtml( + n[$scope.fields[i]].content); + } catch (e) { + } + var group = n[$scope.fields[i]]; + group.isopen = false; + $scope.accordionGroups.push(group); + } + } catch (e) { + $log.error(e); + } + + } + }); + + }]); \ No newline at end of file diff --git a/app/js/controllers/AjaxLoaderCtrl.js b/app/js/controllers/AjaxLoaderCtrl.js new file mode 100644 index 0000000..a232842 --- /dev/null +++ b/app/js/controllers/AjaxLoaderCtrl.js @@ -0,0 +1,7 @@ +'use strict'; + +/* CategoryList Controller */ + +angular.module('st.app').controller("AjaxLoaderCtrl", ['$scope', function($scope) { + $scope.overlay = false; +}]); \ No newline at end of file diff --git a/app/js/controllers/CMSPageController.js b/app/js/controllers/CMSPageController.js new file mode 100644 index 0000000..09f9ed1 --- /dev/null +++ b/app/js/controllers/CMSPageController.js @@ -0,0 +1,36 @@ +'use strict' +/** + * CMSPage controller/directive is for when the block needs to occupy the whole page, with footer and header showing + */ +angular.module('st.app').controller('CMSPageCtrl', ['$scope', '$log', + '$injector', '$sce', 'APP_CONFIG', function($scope, $log, $injector, $sce, + APP_CONFIG) { + $scope.block = {}; + var ContentModel = $injector.get(APP_CONFIG.dataProvider + + 'ContentModel'); + + /** + * watch the blockId. If <> 0, show the block + */ + $scope.$watch('cmsPageId', function(n, o) { + if (n == APP_CONFIG.noBlock || typeof n == 'undefined') { + $scope.display = false; + $scope.block = {}; + } else { + ContentModel.getStaticBlock(n, function(block) { + block.html = $sce.trustAsHtml(block.html); + $scope.pageContents = block.html; + $scope.display = true; + }); + } + }); + + /* + * remove the block and send an event so that the users could go back to last category + */ + $scope.removeBlock = function() { + $scope.display = false; + $scope.blockId = 0;// reset id + $scope.$emit('staticBlockExit'); + }; + }]); \ No newline at end of file diff --git a/app/js/controllers/CartIconController.js b/app/js/controllers/CartIconController.js new file mode 100644 index 0000000..9b6026f --- /dev/null +++ b/app/js/controllers/CartIconController.js @@ -0,0 +1,72 @@ +'use strict'; + +/* Main app Controller */ + +angular.module('st.app').controller("cartIconCtrl", ['$scope','$element','$timeout', + '$log', '$location', '$injector','APP_CONFIG',function($scope,element, $timeout,console, location,$injector,APP_CONFIG) { + + $scope.itemCount = 0; + $scope.showDescription = false; + + // initial data load + var cartModel = $injector.get(APP_CONFIG.dataProvider + 'CartModel'); + console.log('cart ctrl',cartModel); + cartModel.getCartDetails(function(itemCount) { + console.log('cart loaded',itemCount); + $scope.itemCount = parseInt(itemCount); + }) + + /** + * Description: + * It will show description by setting showDescription Flag and registers + * a timeout event that will hide description after 5 seconds. + * + * @returns {undefined} + */ + $scope.makeDescriptionVisible = function() { + if ($scope.descriptionAnimPromise != null) { + // save mouse position and canel already registered timeout event + $timeout.cancel($scope.descriptionAnimPromise); + $scope.descriptionAnimPromise = null; + } + + $scope.descriptionAnimPromise = $timeout(function() { + + $scope.showDescription = false; + $scope.descriptionAnimPromise = null; + $scope.$digest(); + + }, 5000); + $scope.showDescription = true; + }; + $scope.$on('st-app-mousemove', function() { + $scope.makeDescriptionVisible(); + }); + /** + * an item was added to the cart + */ + $scope.$on('st-item-added',function(ev) { + $scope.itemCount++; + var icon = element.find('img'); + var orig_width = icon.width(), + orig_height = icon.height(); + + // pulse + icon.animate({ + height: orig_height*1.1 + }, 250, function() { + // back to normal + icon.animate({ + height: orig_height + }) + }); + }); + + $scope.itemCountText = function() { + if ($scope.itemCount) + return '' + $scope.itemCount + ''; + else return ''; + } +}]) + + diff --git a/app/js/controllers/CategoryListController.js b/app/js/controllers/CategoryListController.js new file mode 100644 index 0000000..1867abc --- /dev/null +++ b/app/js/controllers/CategoryListController.js @@ -0,0 +1,77 @@ +'use strict'; + +/* CategoryList Controller */ +angular.module('st.app').controller("CategoryListCtrl", ['$scope', + '$injector', '$location', '$log', 'APP_CONFIG', function($scope, $injector, + $location, $log, APP_CONFIG) { + $scope.catgories = []; + $scope.loading = true; + $scope.showCategories = false; + var TAG = 'CategoryListCtrl'; + + var CategoryModel = $injector.get(APP_CONFIG.dataProvider + + 'CategoryModel'); + + /** + * Getting categories from API w.r.t root category + */ + CategoryModel.getCategories($scope.rootCat, function(categories) { + // convert blockId to type and add one cms page + var addCmsPage = function() { + for(var i=0;i 0) + { + var thumbLastItem = + $scope.thumbsDatasource[$scope.thumbsDatasource.length - + 1]; + + if (thumbLastItem == null) + return; + // fetch thumbnails for rank + ProductsService.getProductsBasicData($scope.thumbnailsCatId, + thumbLastItem.entity_id, thumbLastItem.rank, 10, + 'created_at', 'desc', 'next', false, false, function( + thumbnails) { + + // No item found. + if (thumbnails == null || thumbnails.length == 0) + return; + + var tempItem = thumbnails[thumbnails.length - 1]; + + if (tempItem == null) + return; + + // item already fetched. No need to add. Just ignore it + if (thumbLastItem != null && thumbLastItem.rank == + tempItem.rank) + return; + + // concatinate newly fetched data in datasource + $scope.thumbsDatasource = + $scope.thumbsDatasource.concat(thumbnails); + + }); + } + + }; + /* + * description: + * loadPrevThumbnails will be called when user open bookmarked url and press prev button to scroll towards + * left. It will fetch previous items. + * + * @param {type} isAppend + * @param {type} callback + * @returns {undefined} + * + */ + + $scope.loadPrev = function(isAppend, callback) { + + if ($scope.thumbsDatasource != null && + $scope.thumbsDatasource.length > 0) + { + var thumbFirstItem = $scope.getFirstNonNullItem( + $scope.thumbsDatasource); + if (thumbFirstItem == null) + return; + + // check if more items are avaiable. Previous to current first item + if (thumbFirstItem.rank > 1) + { + ProductsService.getProductsBasicData( + $scope.thumbnailsCatId, + thumbFirstItem.entity_id, thumbFirstItem.rank, + 10, 'created_at', 'desc', 'prev', false, false, + function(thumbnails) { + + // No item found + if (thumbnails == null || thumbnails.length == + 0) + return; + + var thumbs = $.map(thumbnails, function(value, + key) { + return value; + }); + // concatinate prevous item at the start + $scope.thumbsDatasource = thumbs.concat( + $scope.thumbsDatasource); + }); + } + } + + }; + + /** + * Description: + * We need to check valid items exist in datasource. So we find first non null item in + * datasource and return. + * + * @param {type} sourceArr + * @returns {unresolved} + * + */ + + $scope.getFirstNonNullItem = function(sourceArr) { + + for (var i = 0; i < sourceArr.length; ++i) + { + var item = sourceArr[i]; + if (item != null) + return item; + } + + return null; + }; + + /** + * + * @returns {undefined} + */ + + $scope.getWindowWidth = function() { + return $window.innerWidth; + }; + + /** + * description: + * onItemClicked method will be called when thumbnail item is clicked. Location + * will be changed and full product will show current active item + * + * @param {type} itemId + * @returns {undefined} + */ + + $scope.onItemClicked = function(item) { + $scope.activeProdId = item.entity_id; + }; + + /** + * description: + * This method will be called by GenralThumbListController at the time of item creation. + * Current controller knows about its datasource structure. It extracts data from item, build + * path and return. + * + * @param {type} item + * @returns {String} + */ + + $scope.buildHREFForItem = function(item) { + return "#" + $scope.catId + "/" + $scope.selectedCategory.slug + + "/" + item.entity_id + "/" + item.slug; + }; + + + /** + * description: + * This method will be called by GeneralThumbListController. It makes unique id and return + * + * @param {type} item + * @returns {String} + */ + + $scope.buildFQIdForItem = function(item) { + return "thumb_" + $scope.catId + "_" + item.entity_id; + }; + + /** + * + * @returns {Boolean} + */ + + $scope.shouldHideThumbList = function() { + return true; + }; + + /** + * + * @param {type} blnFlag + * @returns {undefined} + */ + + $scope.showHideThumbs = function(blnFlag) { + //$scope.$parent.$parent.state = blnFlag; + $scope.offset = $element.css('bottom'); + $scope.thumbState = blnFlag; + }; + + + }]); \ No newline at end of file diff --git a/app/js/controllers/DynamicBlockController.js b/app/js/controllers/DynamicBlockController.js new file mode 100644 index 0000000..3ca7fdd --- /dev/null +++ b/app/js/controllers/DynamicBlockController.js @@ -0,0 +1,34 @@ +/** + * dynamic content retriever: + * use for cases when the data block contains directives + */ +angular.module('st.app').controller("dynamicBlockCtrl", ['$scope', '$element', + '$log', 'APP_CONFIG', '$compile', '$injector', '$attrs',function($scope, $element, + console, APP_CONFIG, $compile,$injector,$attrs) { + + /** + * observe the scope attribute + * (dont use watch cause that would mean an isolated scope) + */ + $attrs.$observe('blockId',function(n,o) { + if (n == APP_CONFIG.noBlock || typeof n == 'undefined') { + //noop + } else{ + var blockId = n; + // get the right content model + var contentModel = $injector.get(APP_CONFIG.dataProvider+'ContentModel'); + // get the data + contentModel.getBlockHtml(blockId,function(data) { + // compile the content + $compile(data.html)($scope,function(clone){ + // put it on the element + $element.html(clone); + }); + + }); + } + + }); + + +}]); \ No newline at end of file diff --git a/app/js/controllers/GeneralThumbListController.js b/app/js/controllers/GeneralThumbListController.js new file mode 100644 index 0000000..3defc05 --- /dev/null +++ b/app/js/controllers/GeneralThumbListController.js @@ -0,0 +1,611 @@ + +'use strict'; + +/* General Thumb List Controller */ + +angular.module('st.app').controller("GeneralThumbListController", ['$rootScope', '$scope', '$timeout' ,'ProductModel', + 'ProductsService','$location','$log','$element','APP_CONFIG','$window','$document', + function($rootScope, $scope, $timeout, ProductModel, ProductsService, + $location,$log,$element,APP_CONFIG,$window,$document) { + + + $scope.isMouseUpOnNav = true; + $scope.isItemLoaded = false; + $scope.thumbActiveItemId = null; + + $scope.showThumbnails = true; + $scope.showNavCtrls = true; + // $scope.thumbHideAnim is used controll thumbnail hide animation + $scope.thumbHideAnim = null; + $scope.mouseMovePosX; + $scope.mouseMovePosY; + + // Constants + + $scope.SCROLL_DIRECTION_LEFT = "left"; + $scope.SCROLL_DIRECTION_RIGHT = "right"; + $scope.THUMBNAIL_LIST_TAG = 'thumbnail-list'; + $scope.THUMBNAIL_WRAPPER_CLASS = '.st_thumbs_wrapper'; + $scope.ALBUM_CLASS = '.album'; + $scope.THUMBS_CLASS = '.st_thumbs'; + + + var TAG = "GeneralThumbListController"; + var scrollFactor = 10; + var scrollDuration = 30; + + $scope.$watch('datasource',function(n,o){ + + // if(n != null && n.length == 0) + // $scope.showThumbnails = false; + + $scope.buildThumbs(); + }); + + /** + * description: + * Upon product change we need to select active item in thumbnail list. + * We need to identify user has pressed left or right button on main screen + */ + $scope.$watch('activeItemId', function(n, o) { + + /* + * get rank from product id. If new product rank is greater than old product rank + * it means user is moving towards right. If new proudct rank is less than old + * porduct rank it means user is moving towards left + */ + + var oldProdRank = ProductsService.getProductRank($scope.uniqueId,o); + var newProdRank = ProductsService.getProductRank($scope.uniqueId,n); + + if(newProdRank > oldProdRank){ + $scope.selectNextItem(n); + } + else if(newProdRank < oldProdRank){ + $scope.selectPrevItem(n); + } + + }); + + /** + * description: + * If item is already loaded in thumbnail list and is not visible on the screen + * (currently item is off the screen),just set its position so that user can view it. + * It should be displayed at left side. Also apply active item class. + * Otherwise fetch it from ProductsService and load into thumbnail lis + * + */ + $scope.selectPrevItem = function(item_id) { + + if($scope.isMouseUpOnNav == false) // scrolling thumbnails list. No need to set position + return; + var wrapper = $scope.getThumbWrapper(); + + // make item id + var id = "#thumb_" + $scope.uniqueId + "_" + item_id; + var elm = $scope.searchElementById(id); + var pos = elm.position(); + + var winWidth = $scope.getWindowWidth(); + var itemWidth = elm.width(); + + if (pos != null) + { + // if pos.left is less than 0 it mean item is off the screen on left side + if (pos.left < 0) { + + // scroll to main product active item so that it should be visible + var xPos = wrapper.scrollLeft(); + xPos = xPos - itemWidth; + wrapper.scrollLeft(xPos - scrollFactor); + } + // if pos.left > screenWidth it mean item is off the screen on right side + else if (pos.left > 0 && pos.left > winWidth) { + // set xPos so that item is visible + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + + } + else { + // item does not exist in thumbnail list. So load it from cache + + if($scope.$parent.loadPrev == null) + return; + + $scope.$parent.loadPrev(false, function(newWidth) { + $scope.highlightActiveItem(id); + }); + } + + $scope.isItemLoaded = true; + + }; + + /** + * description: + * If item is already loaded in thumbnail list and is not visible on the screen + * just set is position so that user can view it. It should be displayed + * at right side. Also apply active item class. + * Otherwise fetch it from ProductsService and load into thumbnail list + * + * @param {type} item_id + * @returns {undefined} + */ + + $scope.selectNextItem = function(item_id) { + + + if($scope.isMouseUpOnNav == false) // scrolling thumbnails list. No need to set position + return; + + var wrapper = $scope.getThumbWrapper(); + + var id = "#thumb_" + $scope.uniqueId + "_" + item_id; + + var elm = $scope.searchElementById(id); + var pos = elm.position(); + + var winWidth = $scope.getWindowWidth(); + + var itemWidth = elm.width(); + + if (pos != null) { + + // if left > screen width it mean item is off the screen on right side + if (pos.left > 0 && pos.left > winWidth) { + + // scroll to main product active item + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + // if left < 0 it mean item is off the screen on left side + else if (pos.left < 0) { + var xPos = pos.left + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + } + else { + // item not exist in thumbnail list. Fetch it from cache + if($scope.$parent.loadNext == null) + return; + + $scope.$parent.loadNext(true); + + $scope.highlightActiveItem(id); + } + + $scope.isItemLoaded = true; + }; + + /** + * description: + * Apply class on required item. Also remove class from previous + * selected item. + * + * @param {type} itemId + * @returns {undefined} + * + * + */ + + $scope.highlightActiveItem = function(itemId){ + + var elm = $scope.searchElementById(itemId); + elm.addClass("st_thumbs_active"); + + if($scope.thumbActiveItemId != null && itemId != $scope.thumbActiveItemId){ + var activeElm = $scope.searchElementById($scope.thumbActiveItemId); + activeElm.removeClass("st_thumbs_active"); + } + + $scope.thumbActiveItemId = itemId; + }; + + /** + * description: + * Adjust width of thumbnails container so that items can be displayed in a single row. + * If item is not loaded yet, take minimum thumbnail width and adjust container width + * + * @returns {undefined} + */ + + $scope.buildThumbs = function() { + + var wrapper = $scope.getThumbWrapper(); + + var width = 0; + + $scope.$parent.thumbnailItemWidth = $scope.$parent.thumbnailItemMinWidth; + + if($scope.datasource == null) + return; + //if(width < $scope.datasource.length * $scope.$parent.thumbnailItemMinWidth){ + width = ($scope.datasource.length * $scope.$parent.thumbnailItemMinWidth); + // Adjust width with margin 6 px: 3px left + 3px right + + width += $scope.datasource.length * 6; + //} + + width = width + $scope.$parent.thumbnailItemWidth; + + var thumbs = wrapper.children($scope.THUMBS_CLASS); + thumbs.css('width', width + 'px'); + + }; + + /** + * + * @param {type} oldWidth + * @returns {undefined} + * + * + */ + + $scope.addThumbs = function(oldWidth) { + var wrapper = $scope.getThumbWrapper(); + + var thumbs = wrapper.children($scope.THUMBS_CLASS); + + $scope.buildThumbs(); + + var newItemsWidth = ($scope.datasource.length + 2) * $scope.$parent.thumbnailItemMinWidth - oldWidth; + return newItemsWidth; + }; + + /** + * description: + * It returns width of thumbs container + * + * @returns {undefined} + */ + $scope.thumbsContainerWidth = function(){ + + var wrapper = $scope.getThumbWrapper(); + + var thumbs = wrapper.children($scope.THUMBS_CLASS); + return thumbs.width(); + }; + + /* + * description: + * scrollLeft will be called when user press left thumbnail navigation button. + * + * @returns {undefined} + * + */ + $scope.scrollLeft = function() { + var wrapper = $scope.getThumbWrapper(); + + var xPos = wrapper.scrollLeft(); + if (xPos == 0) { + + if($scope.$parent.loadPrev == null) + return; + + $scope.$parent.loadPrev(false, function(newWidth) { + + }); + $timeout(function() { + $scope.scrollLeft(); + }, scrollDuration); + } else { + wrapper.scrollLeft(xPos - scrollFactor); + $timeout(function() { + if ($scope.isMouseUpOnNav == false) + $scope.scrollLeft(); + }, scrollDuration); + } + + }; + + /* + * description: + * scrollRight will be called when user press right thumbnail navigation button. + * + * @returns {undefined} + * + */ + $scope.scrollRight = function() { + + var wrapper = $scope.getThumbWrapper(); + var wrapperWidth = wrapper.width(); + + var thumbsWidth = wrapper.children($scope.THUMBS_CLASS).width(); + + var xPos = wrapper.scrollLeft(); + if ((xPos + (2 * wrapperWidth)) >= thumbsWidth) { + if($scope.$parent.loadNext != null) + $scope.$parent.loadNext(true); + } + + var winWidth = $scope.getWindowWidth(); + // if reached at last item. No need to scroll more. + + if($scope.$parent.loadNext != null){ + if ((xPos + $scope.$parent.thumbnailItemWidth <= thumbsWidth - winWidth) || (wrapperWidth < winWidth)) + wrapper.scrollLeft(xPos + scrollFactor); + } + else{ + var calculatedWidth = ($scope.datasource.length * $scope.$parent.thumbnailItemWidth) + + ($scope.datasource.length * 6) - $scope.$parent.thumbnailItemWidth; + + if((xPos + $scope.$parent.thumbnailItemWidth) < calculatedWidth) + wrapper.scrollLeft(xPos + scrollFactor); + + } + + $timeout(function() { + if ($scope.isMouseUpOnNav == false) + $scope.scrollRight(); + }, scrollDuration); + }; + + /* + * description: + * getThumbWrapper return wrapper element which is children of thumbnail-list element + * + * @returns {undefined} + * + */ + // extract thumbnail wrapper binded with current controller + $scope.getThumbWrapper = function() { + + var div = $element.children('div'); + // extract thumbnail wrapper element + var album = div.children($scope.ALBUM_CLASS); + var wrapper = album.children($scope.THUMBNAIL_WRAPPER_CLASS); + return wrapper; + }; + + /** + * + * @returns {undefined} + */ + + $scope.getWindowWidth = function(){ + return $window.innerWidth; + }; + + /** + * + * @param {type} id + * @returns {unresolved} + */ + + $scope.searchElementById = function(id){ + return angular.element($document[0].querySelector(id)); + }; + + + + // handle mouse down event on thumbnnails left navigation bar + $scope.onMouseDownOnNavLeft = function($event) { + $scope.isMouseUpOnNav = false; + $scope.scrollLeft(); + }; + + // handle mouse up event on thumbnails left navigation bar + $scope.onMouseUpOnLeftNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumnails left navigation bar + $scope.onMouseLeftLeftNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse down event on thumbnnails right navigation bar + $scope.onMouseDownOnNavRight = function($event) { + + $scope.isMouseUpOnNav = false; + $scope.scrollRight(); + }; + + // handle mouse up event on thumbnails right navigation bar + $scope.onMouseUpOnRightNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumnails right navigation bar + $scope.onMouseLeftRightNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumbnails-list + $scope.onMouseLeft = function($event) { + + var mouseXPos = $event.screenX; + var screenWidth = $event.view.outerWidth; + + if($scope.$parent.showHideThumbs != null && $scope.showThumbnails) + $scope.$parent.showHideThumbs(false); + + if (mouseXPos > 0 && mouseXPos < screenWidth){ + + if($scope.$parent.shouldHideThumbList != null && $scope.$parent.shouldHideThumbList() == true) + $scope.showThumbnails = false; + } + }; + // handle mouse enter event on thumnails-list + $scope.onMouseEnter = function($event) { + + if($scope.$parent.showHideThumbs != null && !$scope.showThumbnails) + $scope.$parent.showHideThumbs(true); + + $scope.showThumbnails = true; + $scope.showHideNavigationCtrls(); + + if ($scope.isItemLoaded) { + $scope.scrollToActiveItem(); + $scope.isItemLoaded = false; + } + }; + // handle mouse move on thumbnails-list + $scope.onMouseMove = function($event){ + + /** + * Issue work around: + * Issue : When mouse is still on thumb list Mouse move event is still be fired + * Solution: Save mouse xPosition and yPosition when moved last time. If mouse + * xPosition and yPosition is same then no need to proceed. + */ + if($event.screenX == $scope.mouseMovePosX && $event.screenY == $scope.mouseMovePosY) + return; + + + if ($scope.thumbHideAnim != null) { + + // save mouse position and canel already registered timeout event + $scope.mouseMovePosX = $event.screenX; + $scope.mouseMovePosY = $event.screenY; + $timeout.cancel($scope.thumbHideAnim); + $scope.thumbHideAnim = null; + } + + // hide thumblist after 5 seconds + $scope.thumbHideAnim = $timeout(function() { + + // check if thumb list was shown and can hide. + if($scope.$parent.shouldHideThumbList != null && $scope.$parent.shouldHideThumbList() == true){ + $scope.showThumbnails = false; + if($scope.$parent.showHideThumbs != null) + $scope.$parent.showHideThumbs(false); + $scope.$digest(); + } + + }, 5000); + }; + + $scope.showHideNavigationCtrls = function(){ + var wrapper = $scope.getThumbWrapper(); + var elm = wrapper.find('.st_thumbs a'); + var width = wrapper.width(); + var expectedWidth = elm.length * $scope.$parent.thumbnailItemMinWidth; + + if(expectedWidth < wrapper.width()) + $scope.showNavCtrls = false; + else + $scope.showNavCtrls = true; + + }; + + + /* + * description: + * scrollToActiveItem will be called when thumbnails state change from hidden to visible + * When user click on prev/next button we cannot scroll to item as these are hidden. + * When user moves on thumbnails-list we find active item and scroll to that item. + * + * @returns {undefined} + * + */ + + $scope.scrollToActiveItem = function() { + + $timeout(function() { + + if($scope.activeProdId == null) + return; + + // fetch thumb wrapper associated with current controller + var wrapper = $scope.getThumbWrapper(); + + // make thumbitem id and get its position + var id = "#thumb_" + $scope.uniqueId + "_" + $scope.activeProdId; + var elm = $scope.searchElementById(id); + var pos = elm.position(); + + var winWidth = $scope.getWindowWidth(); + var itemWidth = elm.width(); + + if (pos != null) { + + // item found and it is off the screen on write side + if (pos.left > 0 && pos.left > winWidth) { + + // scroll to main product active item + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + else if(pos.left > 0 && pos.left < $scope.$parent.thumbnailItemMinWidth){ + // scroll to required position + var xPos = $scope.$parent.thumbnailItemMinWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + // item found and its off the screen on left side + else if (pos.left < 0) { + + // scroll to required position + var xPos = pos.left + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos - scrollFactor); + } + + $scope.highlightActiveItem(id); + } + + }, 30); + }; + + /** + * description: Thumbnail list is being show at the start. We hide thumbnails list + * after 5 seconds + * + * @returns {undefined} + */ + + $scope.showHideThumbnails = function(){ + + $timeout(function() { + if($scope.$parent.shouldHideThumbList != null && $scope.$parent.shouldHideThumbList() == true) + $scope.showThumbnails = false; + else + $scope.showThumbnails = true; + + $scope.$digest(); + },2000); + + }; + + /** + * description: + * onThumbnailClick method will be called when thumbnail is clicked. Location + * will be changed and full product will show current active item + * + * @param {type} itemId + * @returns {undefined} + */ + + $scope.onThumbnailClick = function(item){ + + var id = $scope.makeItemFQId(item); + $scope.highlightActiveItem(id); + + if($scope.$parent.onItemClicked != null) + $scope.$parent.onItemClicked(item); + }; + + /** + * + * @returns {undefined} + */ + + $scope.getHREFValue = function(item){ + + if($scope.$parent.buildHREFForItem != null) + return $scope.$parent.buildHREFForItem(item); + }; + + $scope.makeItemFQId = function(item){ + + if($scope.$parent.buildFQIdForItem != null) + return $scope.$parent.buildFQIdForItem(item); + }; + + $scope.showHideThumbnails(); + + }]); \ No newline at end of file diff --git a/app/js/controllers/HeaderController.js b/app/js/controllers/HeaderController.js new file mode 100644 index 0000000..31f46f4 --- /dev/null +++ b/app/js/controllers/HeaderController.js @@ -0,0 +1,14 @@ +/* + * Controller for header.phtml + * in site + */ +angular.module('st.app').controller("HeaderCtrl", ['$scope', '$rootScope', + '$log', 'APP_CONFIG', '$location', '$injector', '$sce', '$animate', + '$timeout', function($scope, $rootScope, $log, APP_CONFIG, $location, + $injector, $sce, $animate, $timeout) { + + $scope.baseUrl = APP_CONFIG.baseUrl; + +}]); + + diff --git a/app/js/controllers/MainController.js b/app/js/controllers/MainController.js new file mode 100644 index 0000000..390f633 --- /dev/null +++ b/app/js/controllers/MainController.js @@ -0,0 +1,179 @@ +'use strict'; + +/* Main app Controller */ + +angular.module('st.app').controller("MainCtrl", ['$scope', '$rootScope', + '$log', 'APP_CONFIG', '$location', '$injector', '$sce', '$animate', + '$timeout', function($scope, $rootScope, $log, APP_CONFIG, $location, + $injector, $sce, $animate, $timeout) { + $scope.showNav = true; + $scope.bodyClass = ''; + $scope.pageType = 'catalog'; + $rootScope.pageTitle = 'Home'; + $scope.currentProdId = 0; + $scope.currentCategory = APP_CONFIG.defaultCategory; + $scope.displayCurrentBlock = false; + $scope.topLinks = ''; + $scope.showCtrls = true; + $scope.showFooter = false; + $scope.state = false; + $scope.offset = null; + $scope.headerHtml = ''; + $scope.footerHtml = ''; + $scope.blockId = APP_CONFIG.noBlock; + $scope.baseUrl = APP_CONFIG.baseUrl; + + var TAG = 'MainCtrl'; + + //disables animation of first load and then enable it after 1s + $animate.enabled(false); + $timeout(function() { + $animate.enabled(true); + }, 3000); + + var ContentModel = $injector.get(APP_CONFIG.dataProvider + + 'ContentModel'); + + ContentModel.getBlockHtml('header', function(header) { + if (typeof header.html != 'undefined' && header.html != null && + header.html.length > 0) { + $scope.headerHtml = $sce.trustAsHtml(header.html); + } + }); + + ContentModel.getBlockHtml('footer', function(footer) { + if (typeof footer.html != 'undefined' && footer.html != null && + footer.html.length > 0) { + $scope.footerHtml = $sce.trustAsHtml(footer.html); + } + }); + + /** + * listener to angular's event for location change + * extract the params + */ + $scope.$on('$locationChangeSuccess', function(event, n, o) { + + try { + $scope.showFooter = false; + var url = $location.path(); //new url + $log.debug(TAG, "locationChange: " + url); + + var categoryPattern = new RegExp( + '^/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var productPattern = new RegExp( + '^/(\\d+)+/([a-zA-Z0-9\\-_]+)+/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var productDetailsPattern = new RegExp( + '^/productdetails/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var pagePattern = new RegExp('^/page/(\\d+)+$'); + var cmsPagePattern = new RegExp('^/cmspage/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + + var categoryParams = categoryPattern.exec(url); + var productParams = productPattern.exec(url); + var productDetailsParams = productDetailsPattern.exec(url); + var pageParams = pagePattern.exec(url); + var cmsPageParams = cmsPagePattern.exec(url); + + // $scope.currentProdId = 0; Lior remarked: dont change, it creates unncessary loadProducts, and we also need the id for static blocks + if (categoryParams != null) { + //category + $scope.bodyClass = 'catalog-page'; + $scope.pageType = 'catalog'; + $scope.currentCategory.id = categoryParams[1]; + $scope.currentCategory.slug = categoryParams[2]; + $scope.showCtrls = true; + } else if (productParams != null) { + //product + $scope.bodyClass = 'catalog-page'; + $scope.pageType = 'catalog'; + $scope.currentCategory.id = productParams[1]; + $scope.currentCategory.slug = productParams[2]; + $scope.currentProdId = productParams[3]; + $scope.showCtrls = true; + } else if (productDetailsParams != null) { + //product / cms page + $scope.bodyClass = 'pdp-page'; + $scope.pageType = 'pdp'; + $scope.currentProdId = productDetailsParams[1]; + $scope.showFooter = true; + } + else if (cmsPageParams!=null) { + //product / cms page + $scope.bodyClass = 'cmspage-page'; + $scope.pageType = 'cmspage'; + $scope.currentCmsPageId = cmsPageParams[1]; + $scope.showFooter = true; + }else if (pageParams != null) { + //block + $scope.blockId = pageParams[1]; + $scope.showCtrls = true; + } else if (url == '/') { + $location.path($scope.currentCategory.id + '/' + + $scope.currentCategory.slug); + } + + } catch (e) { + $log.error(e); + } + }); + + /** + * block hidden, go back to previous or default path + */ + $scope.$on('staticBlockExit', function(event, n, o) { + + var restoredPath = $scope.currentCategory.id + '/' + + $scope.currentCategory.slug; + if ($scope.currentProdId) + restoredPath += '/' + $scope.currentProdId; + + $location.path(restoredPath); + + }) + + $scope.$watch('currentProdId', function(n, o) { + // no op + }); + + + $scope.$watch('currentCategory', function(n, o) { + /** + * if the current and old categories aren't same then it means that + * we need to get new product list for new category so we have to + * set active product id to 0 + */ + if (n.id !== o.id) + $scope.currentProdId = 0; + },true); + + /** + * + * @param {type} $event + */ + $scope.onMouseMove = function($event){ + if(!($event.screenX == $scope.mouseMovePosX && $event.screenY == $scope.mouseMovePosY)) { + $scope.$broadcast('st-app-mousemove'); + } + // save mouse position and canel already registered timeout event + $scope.mouseMovePosX = $event.screenX; + $scope.mouseMovePosY = $event.screenY; + } + + $scope.onTouch= function() { + $scope.$broadcast('st-app-mousemove'); + } + + /* + * Hide the navigation [+] + */ + $scope.hideNav = function() { + setTimeout(function(callback) { + if ($scope.showNav != true) { + callback(false); + } + }, 100); + + return callback; + }; + + }]); diff --git a/app/js/controllers/ModalAjaxLoaderCtrl.js b/app/js/controllers/ModalAjaxLoaderCtrl.js new file mode 100644 index 0000000..c9bb83e --- /dev/null +++ b/app/js/controllers/ModalAjaxLoaderCtrl.js @@ -0,0 +1,8 @@ +'use strict'; + +/* CategoryList Controller */ + +myApp.controller("ModalAjaxLoaderCtrl", ['$scope','$rootScope', function($scope, $rootScope) { + $scope.show = false; + +}]); \ No newline at end of file diff --git a/app/js/controllers/ProductDetailsCtrl.js b/app/js/controllers/ProductDetailsCtrl.js new file mode 100644 index 0000000..bd28aa2 --- /dev/null +++ b/app/js/controllers/ProductDetailsCtrl.js @@ -0,0 +1,157 @@ +'use strict' + +angular.module('st.app').controller('ProductDetailsCtrl', ['$scope', '$log', + 'ProductsService', '$rootScope', '$injector', 'APP_CONFIG', + function($scope, $log, ProductsService, $rootScope, $injector, + APP_CONFIG) { + + var CartModel = $injector.get(APP_CONFIG.dataProvider + + 'CartModel'); + + $scope.product = {}; + $scope.main_img = ''; + $scope.price = ''; + $scope.loading = false; + $scope.addingProduct = false; + $scope.attributes = []; + $scope.options = []; + $scope.attributes = []; + $scope.showCtrls = false; + $scope.productSize = ''; + $scope.alerts = []; + + /** + * Validates product options/attributes before adding + * product to bag/cart + * + * @returns {Boolean} + */ + $scope._validateOptions = function() { + for (var optionIndex in $scope.options) { + var option = $scope.options[optionIndex]; + if (typeof option.selectedVal == 'undefined') { + $scope.alerts.push({type: 'warning', + msg: 'Please select some value for "' + option.label + + '"'}); + return false; + } + } + + return true; + }; + + /** + * Closes the alert upon clicking the close icon. An index argument is + * passed if we want to close relevant alert when displaying multiple + * alerts on same page. + * + * @param {type} index + * @returns {undefined} + */ + $scope.closeAlert = function(index) { + $scope.alerts.splice(index, 1); + }; + + /** + * Validates the product and then add it to bag/cart + * + * @returns {undefined} + */ + $scope.add2bag = function() { + if ($scope.addingProduct) + return; + + $scope.alerts = []; + if ($scope.product && $scope._validateOptions()) { + var options = []; + + for (var optionIndex in $scope.options) { + options.push({ + id: $scope.options[optionIndex].id, + value: $scope.options[optionIndex].selectedVal, + isSuper: $scope.options[optionIndex].is_super + }); + } + + $scope.addingProduct = true; + + CartModel.addToCart($scope.prodId, options, 1, function( + response) { + if (response != '') { + $scope.alerts.push({type: 'danger', + msg: response + }); + } else { + $scope.alerts.push({type: 'success', + msg: 'Thanks! Your product is added in the cart.' + }); + $rootScope.$broadcast('st-item-added'); + } + $scope.addingProduct = false; + + $log.debug(response); + }); + } + }; + + /** + * Its an event listener which looks for the selected thumb and then + * it displays in the main area. + * + */ + $scope.$on('product_image_selected', function(event, item) { + $scope.main_img = item.original_image; + if (typeof $scope.ez != 'undefined') { + //reloads the image for elevateZoom + $scope.ez.swaptheimage(item.original_image, + item.original_image); + } + }); + + /** + * Used for two way data binding if any change in prodId is observed + * then it will load particular product detail on the page. + * + */ + $scope.$watch('prodId', function(n, o) { + if ($scope.loading) + return; + + $scope.loading = true; + + if (n != 0) { + ProductsService.get(n, function(product) { + if (product != null) { + $scope.product = product; + $scope.main_img = product.image_url; + $scope.price = product.final_price; + $scope.loading = false; + $rootScope.pageTitle = product.name; + + if (typeof product.attributes == 'undefined' || + product.attributes == null) { + ProductsService.getProductAttributes($scope.prodId, + function(attributes) { + $scope.product.attributes = attributes; + $scope.attributes = attributes; + }); + } else { + $scope.attributes = product.attributes; + } + + if (typeof product.options == 'undefined' || + product.options == null) { + ProductsService.getProductOptions($scope.prodId, + function(options) { + $scope.product.options = options; + $scope.options = options; + }); + } else { + $scope.options = product.options; + } + } + }); + } + }); + + }]); \ No newline at end of file diff --git a/app/js/controllers/ProductFullController.js b/app/js/controllers/ProductFullController.js new file mode 100644 index 0000000..5fb46de --- /dev/null +++ b/app/js/controllers/ProductFullController.js @@ -0,0 +1,118 @@ +'use strict'; + +/* ProductFull Controller */ +angular.module('st.app').controller("ProductFullCtrl", ['$scope', + 'ProductsService', '$rootScope', '$log', '$sce', '$timeout', function( + $scope, ProductsService, $rootScope, $log, $sce, $timeout) { + $scope.product = {}; + $scope.descriptionAnimPromise = null; + $scope.showDescription = false; + $scope.mouseMovePosX; + $scope.mouseMovePosY; + + // set class for the image. called by ng-class on the partial + $scope.fitToSizeClass = function() { + return $scope.fitToSize ? "st-fitToSize" : "st-dontFitToSize"; + } + + /** + * This event is used by other controllers to load product image in + * the browsesr cache on request for given product id. + */ + $scope.$on('load_product_image', function(event, prodId) { + if ($scope.prodId == prodId && $scope.product) { + var img = new Image(); + img.src = $scope.product.image_url; + + //create a message to be broadcasted to its listeners + var message = {id: prodId, name: $scope.product.name, + image_url: $scope.product.image_url}; + + /** + * when image loading is done in browser's cache then broadcast the message to its listeners + * + */ + img.onload = function() { + $rootScope.$broadcast('image_loaded', message); + } + + img.onerror = function() { + $rootScope.$broadcast('product_load_failed', + message) + } + + } + }); + + /** + * received when a mouse has moved + */ + $scope.$on('st-app-mousemove', function() { + $scope.makeDescriptionVisible(); + }); + + $scope.$watch('prodId', function(n, o) { + var prod_id = parseInt(n); + if (!isNaN(prod_id)) { + $scope.makeDescriptionVisible(); + //retrieve the information related to product from Service + ProductsService.get(prod_id, function(product) { + if (product != null) { + //when Product data is retreived then load the image of product in browser's cache + var img = new Image(); + img.src = product.image_url; + + //create a message to be broadcasted to its listeners + var message = {id: prod_id, name: product.name, + image_url: product.image_url}; + + //when image loading is done in browser's cache then broadcast the message to its listeners + img.onload = function() { + $rootScope.$broadcast('image_loaded', message); + } + + img.onerror = function() { + $rootScope.$broadcast('product_load_failed', + message) + } + //load the product in product-full scope + try { + product.title = $sce.trustAsHtml(product.title); + } catch (e) { + } + $scope.product = product; + } else { + //create a message to be broadcasted to its listeners + var message = {id: prod_id}; + $rootScope.$broadcast('product_load_failed', message); + } + }); + } + }); + + + + /** + * Description: + * It will show description by setting showDescription Flag and registers + * a timeout event that will hide description after 5 seconds. + * + * @returns {undefined} + */ + $scope.makeDescriptionVisible = function() { + if ($scope.descriptionAnimPromise != null) { + // save mouse position and canel already registered timeout event + $timeout.cancel($scope.descriptionAnimPromise); + $scope.descriptionAnimPromise = null; + } + + $scope.descriptionAnimPromise = $timeout(function() { + + $scope.showDescription = false; + $scope.descriptionAnimPromise = null; + $scope.$digest(); + + }, 5000); + $scope.showDescription = true; + }; + }]); \ No newline at end of file diff --git a/app/js/controllers/ProductFullListController.js b/app/js/controllers/ProductFullListController.js new file mode 100644 index 0000000..c841713 --- /dev/null +++ b/app/js/controllers/ProductFullListController.js @@ -0,0 +1,404 @@ +'use strict'; + +/* ProductFull Controller */ +angular.module('st.app').controller("ProductFullListCtrl", ['$scope', + '$location', 'ProductsService', '$rootScope', '$log', '$document', + function($scope, $location, ProductsService, $rootScope, console, $document) { + /* ProductFullList Flow: + 1.MainCtrl takes prod id and cat id from URL, sets in currentProdId and currentCategory + 2. ProductFullList directive receives as an atrtibute the ids + 3. calls ProductService to get product ids into productsBasicData + 4. creates 3 ProductFulls using a repeater on productsBasicData + 5. Each ProductFull download its image and then broadcasts an image_loaded event. + a. for first product, animateProducts is called on this event, fading in the product + b. other productFull's are being hidden from view by default + 4. On next (or prev), next_slide is called. it + a. finds next product in productsBasicData + b. puts next product in $scope.activeProdId + c. puts next product in URL + */ + + $scope.productsBasicData = [ + ]; //Product ids to generate product-full directive + $scope.hasProducts = + false; //a flag which is used to show/hide the prev/next navigation if products are there. + $scope.effect = + 'fade'; // animation effect, fade/slide + $scope.loading = false; + $scope.showActiveProd = false; + $scope.oldProdId = 0; + + var TAG = 'ProductFullListCtrl'; + + // autoAnim is used to stop animation + var autoAnim = null; + var shouldResetAnim = true; + + /* LM remarked since thought there few issues here: + a. it is not needed: the product is already here, why duplicate it? ideally we can change next/prev product position and put it using z-layers on top, and then animate + b. on any case, when adding divs, we need to compile the div, before appending so we can use angular directives inside it. + // if($('#product-full-list-last-image').length == 0){ + // $('product-full-list').prepend('
'); + // } + */ + //image_loaded listener to display the image only when its loaded in the browser's cache + $scope.$on('image_loaded', function(event, product) { + try { + if ($scope.activeProdId == product.id) { + $rootScope.pageTitle = product.name; +// animateProducts($scope, product.image_url); + $scope.showActiveProd = true; + $scope.loading = false; + $rootScope.loading = false; + $rootScope.$digest(); + } + } catch (e) { + } + }); + + $scope.$on('product_load_failed', function(event, product) { + console.log(TAG + ' product_load_failed') + if ($scope.activeProdId == product.id) { + $scope.loading = false; + $rootScope.loading = false; + $rootScope.$digest(); + } + }); + + $scope.$on('st-open-product-details', function(event, link) { + angular.element($document[0].querySelector( + 'category-thumb-list')).fadeOut(); + $location.path(link); + }); + + $scope.getAnimClass = function() { + if ($scope.animate) { + if ($scope.effect == 'slide') + return 'anim-' + $scope.effect + '-' + $rootScope.navdir; + else + return 'anim-' + $scope.effect; + } + }; + + $scope.setDirection = function() { + var oldProdRank = ProductsService.getProductRank($scope.catId, + $scope.oldProdId); + var newProdRank = ProductsService.getProductRank($scope.catId, + $scope.activeProdId); + + if (newProdRank > oldProdRank) { + $rootScope.navdir = 'next'; + } + else if (newProdRank < oldProdRank) { + $rootScope.navdir = 'prev'; + } + } + + /** + * loadProductList, is used to load product list w.r.t given prodId + * But prodId can be null as well to get product w.r.t catId + * + * @param {type} $scope + * @param {type} prodId + * @returns {undefined} + */ + function loadProductList($scope, prodId) { + try { + //productId is null if we are navigating through category id only + var productId = parseInt(prodId); + var rank = ProductsService.getProductRank($scope.catId, + productId); + + $scope.loading = true; + + //retrieve the 3 product ids from the service on the basis of cateogry and productId + ProductsService.getProductsBasicData($scope.catId, + productId, rank, 3, 'created_at', 'desc', + $rootScope.navdir, true, true, function( + productsBasicData) { + if (productsBasicData != null) { + if (productsBasicData.length) + $scope.hasProducts = true; + else { + $scope.hasProducts = false; + $scope.loading = false; + } + + //make the activeProdId product, if productId already given then make it + // as activeProdId otherwise find the first prodcut from the list and make it as activeProdId + if (productId) { + $scope.activeProdId = productId; + } else { + for (var index in productsBasicData) { + $scope.activeProdId = + productsBasicData[index].entity_id; + break; + } + } + + $rootScope.$broadcast('load_product_image', + $scope.activeProdId); + + $scope.productsBasicData = productsBasicData; + } else { + $scope.hasProducts = false; + $scope.loading = false; + } + }); + } catch (e) { + console.error(e); + } + } + + /** + * Monitor any change in the category id from the parent upon which + * new list will be loaded in the scope. + */ + $scope.$watch('catId', function(n, o) { + if (!$scope.loading) { + $scope.scheduleAnimation(); + } + + }); + + $scope.$watch('activeProdId', function(n, o) { + + $scope.oldProdId = o; + $scope.setDirection(); + + if (!$scope.loading) { + + loadProductList($scope, n); + + /** shouldResetAnim == true means item change is not invoked from + * auto animation. So we should reset animation period so that + * selected item can be displayed for full time + */ + + if (shouldResetAnim == true) + $scope.scheduleAnimation(); + } + + }); + + /** + * + * @param {type} $scope + * @param {type} prodId + * @returns {Number} + */ + function getProductIndex($scope, prodId) { + for (var index in $scope.productsBasicData) { + if (prodId == $scope.productsBasicData[index].entity_id) + return parseInt(index); + } + + return -1; + } + + function updateLocation(product_id) { + ProductsService.get(product_id, function(product) { + if (product != null) { + var path = $location.path(); + var productPattern = new RegExp( + '^/(\\d+)+/([a-zA-Z0-9\\-_]+)+/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var productParams = productPattern.exec(path); + if (productParams != null) { + $location.path(productParams[1] + '/' + + productParams[2] + '/' + product_id + + '/' + product.slug); + } else { + $location.path(path + '/' + product_id + + '/' + product.slug); + } + } + }); + } + + /** + * listener to angular's event for location change + * extract the params + * TBD: better logic for stopping the animation + */ + $scope.$on('$locationChangeSuccess', function(event, n, o) { + + try { + + var url = $location.path();; //new url + + var productDetailsPattern = new RegExp( + '^/productdetails/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var productDetailsParams = productDetailsPattern.exec(url); + var cmsPagePattern = new RegExp('^/cmspage/(\\d+)+/([a-zA-Z0-9\\-_]+)+$'); + var cmsPageParams = cmsPagePattern.exec(url); + + // if non-product full list, stop the animation + if (productDetailsParams != null || cmsPageParams != null) { + + if ($scope.autoPlay == true){ + shouldResetAnim = false; + $scope.unInitAnimation(); + } + } else + { + if ($scope.autoPlay == true) + { + shouldResetAnim = true; + $scope.unInitAnimation(); + $scope.initAnimation(); + } + } + + } catch (e) { + console.error(e); + } + }); + + /** + * prev_slide function to redirect to the previous slide. + * + * @returns {undefined} + */ + $scope.prev_slide = function() { + $rootScope.navdir = + 'prev'; //stores the navigation direction in scope + + console.debug(TAG + ':prev_slide: called'); + + //finds the previous product id and redirect the page on that product url + var prod_index = getProductIndex($scope, $scope.activeProdId); + console.debug(TAG + ':prev_slide: prod_index: ' + prod_index); + + if (prod_index != -1 && (typeof $scope.productsBasicData[prod_index + - 1] != 'undefined')) { + + var prod_id = parseInt($scope.productsBasicData[prod_index + - 1].entity_id); + + console.debug(TAG + ':prev_slide: previous prod_id: ' + prod_id); + + if (!isNaN(prod_id)) { + $scope.activeProdId = prod_id; + updateLocation(prod_id); + + } + } else { + console.debug(TAG + ':prev_slide: No previous product found'); + } + }; + + /** + * next_slide function to redirect to the previous slide. + * + * @returns {undefined} + */ + $scope.next_slide = function() { + $rootScope.navdir = + 'next'; //stores the navigation direction in scope + + //finds the next product id and redirect the page on that product url + var prod_index = getProductIndex($scope, $scope.activeProdId); + if (prod_index != -1 && (typeof $scope.productsBasicData[prod_index + + 1] != 'undefined')) { + var prod_id = parseInt($scope.productsBasicData[prod_index + + 1].entity_id); + + if (!isNaN(prod_id)) { + + $scope.activeProdId = prod_id; + updateLocation(prod_id); + + } + } + }; + + /** + * description: + * This function will be called for undefine time. It's call be will be + * repeat every 5 seconds. If it reaches at last item then gets first item + * and keeps on moving to next item + * + * @returns {undefined} + */ + + $scope.initAnimation = function() { + + // keep setTimeout reference to stop it + autoAnim = setTimeout(function() { + + // get next item id and animate to next item + var prod_index = getProductIndex($scope, $scope.activeProdId); + if (prod_index != -1 && + (typeof $scope.productsBasicData[prod_index + + 1] != 'undefined')) { + shouldResetAnim = false; + // move to next item + $scope.next_slide(); + $scope.$digest(); + $scope.initAnimation(); + shouldResetAnim = true; + } + else { + // reach at last item. Fetch first one + ProductsService.getFirstProduct($scope.catId, function( + product) { + + if (product != null) { + var prod_id = parseInt(product.entity_id); + + if (!isNaN(prod_id)) { + shouldResetAnim = false; + // set first item as active + $scope.activeProdId = prod_id; + updateLocation(prod_id); + + + $scope.$digest(); + + shouldResetAnim = true; + } + } + + $scope.initAnimation(); + + }); + + } + }, 5000); + }; + + /** + * description: + * Stop animation if it is being played. This method will be called when we want to stop animation + * + * @returns {undefined} + */ + $scope.unInitAnimation = function() { + if (autoAnim != null) { + clearTimeout(autoAnim); + autoAnim = null; + } + }; + + /** + * description: + * When user change category this method will be called. We stop existing + * animation and schedule new animation. We need to stop and restart animation + * to display new category first item for 5 seconds otherwise it will be displayed + * for less time. + * + * @returns {undefined} + */ + + $scope.scheduleAnimation = function() { + if ($scope.autoPlay == true) { + $scope.unInitAnimation(); + $scope.initAnimation(); + } + }; + + if ($scope.autoPlay == true) { + $scope.initAnimation(); + } + + }]); diff --git a/app/js/controllers/ProductOptionCtrl.js b/app/js/controllers/ProductOptionCtrl.js new file mode 100644 index 0000000..9318638 --- /dev/null +++ b/app/js/controllers/ProductOptionCtrl.js @@ -0,0 +1,26 @@ +'use strict' + +angular.module('st.app').controller('ProductOptionCtrl', ['$scope', '$log', + 'ProductsService', function($scope, $log, ProductsService) { + + $scope.selectedVal = ''; + $scope.selectedLabel = ''; + + if ($scope.prodId && $scope.optionLabel) { + ProductsService.getProductOptions($scope.prodId, function( + options) { + for (var optionIndex in options) { + var option = options[optionIndex]; + if (option.label == $scope.optionLabel) + $scope.option = option; + } + }); + } + + $scope._click = function(value) { + $scope.selectedLabel = value.label; + $scope.selectedVal = value.value; + $scope.option.selectedVal = value.value; + }; + + }]); \ No newline at end of file diff --git a/app/js/controllers/ProductThumbListController.js b/app/js/controllers/ProductThumbListController.js new file mode 100644 index 0000000..04db426 --- /dev/null +++ b/app/js/controllers/ProductThumbListController.js @@ -0,0 +1,122 @@ +'use strict'; + +/* Product Thumb List Controller */ + +angular.module('st.app').controller("ProductThumbListController", ['$rootScope', '$scope', 'ProductModel', + 'ProductsService','$location','$log','$element','$window','APP_CONFIG', + function($rootScope, $scope, ProductModel, ProductsService, + $location,$log,$element,$window,APP_CONFIG) { + + $scope.thumbsDatasource = []; + $scope.thumbnailItemWidth = 0; + $scope.thumbnailItemMinWidth = 80; + + var TAG = "ProductThumbListController"; + + /** + * description: + * Initiate thumbnails data fetching from ProductsService + * + * @returns {undefined} + */ + + $scope.initController = function(){ + + $scope.fetchProductImages(); + + }; + + $scope.$watch('activeProd',function(n,o){ + + if(n != null){ + $scope.initController(); + } + }); + + /** + * description: + * Fetch items for bookmarked url from ProductsService and load into + * thumbnails list + * + * @returns {undefined} + */ + + $scope.fetchProductImages = function() { + var productId = (typeof $scope.activeProd == 'undefined') ? null : $scope.activeProd.entity_id; + + if(productId != null){ + var minH = $scope.getPDPImageMinHeight(); + console.log("PDP Image Min Height : "+minH); + ProductsService.getProductImages(productId,minH,function(images) { + + if (images != null) { + // save first and last thumbnails to move prev and next + $scope.thumbsDatasource = images; + } + else{ + $scope.thumbsDatasource = []; + } + + }); + } + + }; + + /** + * + * @returns {undefined} + */ + + $scope.getPDPImageMinHeight = function(){ + var minH = 960; + return minH; + }; + + /** + * description: + * onItemClicked method will be called when thumbnail is clicked. Location + * will be changed and full product will show current active item + * + * @param {type} itemId + * @returns {undefined} + */ + + $scope.onItemClicked = function(item){ + $rootScope.$broadcast('product_image_selected',item); + }; + + /** + * description: + * This method will be called by GenralThumbListController at the time of item creation. + * Current controller knows about its datasource structure. It extracts data from item, build + * path and return. + * + * @param {type} item + * @returns {String} + */ + + $scope.buildHREFForItem = function(item){ + return "#/productdetails/"+$scope.activeProd.entity_id+"/"+$scope.activeProd.slug; + }; + + /** + * description: + * This method will be called by GeneralThumbListController. It makes unique id and return + * + * @param {type} item + * @returns {String} + */ + $scope.buildFQIdForItem = function(item){ + return "thumb_"+$scope.activeProd.entity_id+"_"+item.id; + }; + + /** + * + * @returns {Boolean} + */ + + $scope.shouldHideThumbList = function(){ + return false; + }; + + }]); \ No newline at end of file diff --git a/app/js/controllers/ProductTitleController.js b/app/js/controllers/ProductTitleController.js new file mode 100644 index 0000000..bca670c --- /dev/null +++ b/app/js/controllers/ProductTitleController.js @@ -0,0 +1,202 @@ +'use strict'; + +/* Product Title Controller */ + +angular.module('st.app').controller("ProductTitleController", ['$rootScope', + '$scope', '$element', '$document', '$window', 'APP_CONFIG', '$timeout', + function($rootScope, $scope, $element, $document, $window, APP_CONFIG, + $timeout) { + + $scope.isPosAdjusted = false; + $scope.thumbOffset = ""; + + var THUMB_LIST_HEIGHT = 60; + var adjustingTitle = false; + var shouldAdjustTitle = false; + + /** + * Sets the bottom offset of product-title on the basis of category-thumblist + * + * @param {type} blnShow + * @param {type} bottomOffset + * @param {type} bottomOffsetNum + * @returns {undefined} + */ + $scope.setTitleOffset = function(blnShow, bottomOffset, + bottomOffsetNum) { + if (blnShow) { + + $scope.isPosAdjusted = true; + + // bottom offset is in percentage + if (bottomOffset.indexOf("%") != -1) { + $element.css("bottom", bottomOffsetNum + 1 + "%"); + } + else if (bottomOffset.indexOf("px") != + -1) { // bottom offset is in pixels + $element.css("bottom", bottomOffsetNum + + THUMB_LIST_HEIGHT + "px"); + } + else { + $element.css("bottom", bottomOffsetNum + + THUMB_LIST_HEIGHT + "px"); + } + + } + else { + + $scope.isPosAdjusted = false; + + // bottom offset is in percentage + if (bottomOffset.indexOf("%") != -1) { + $element.css("bottom", bottomOffsetNum - 1 + "%"); + } + else if (bottomOffset.indexOf("px") != + -1) { // bottom offset is in pixels + $element.css("bottom", bottomOffsetNum - + THUMB_LIST_HEIGHT + "px"); + } + else { // Assume bottom offset is pixels + $element.css("bottom", bottomOffsetNum - + THUMB_LIST_HEIGHT + "px"); + } + } + } + + /** + * description: + * This method will be called when there need to displace description div. + * When thumb list will be shown, description shall be moved above and wisevres. + * If thumb list bottom offset is in % then we add 1% in its bottom offset. + * If it is set in pixels then we add THUMB_LIST_HEIGHT pixcels in its bottom offset. + * + * @param {type} blnShow + * @returns {undefined} + */ + + $scope.adjustTitlePos = function(blnShow) { + + if (adjustingTitle) + { + shouldAdjustTitle = true; + return; + } + + var bottomOffset = $element.css('bottom'); + var bottomOffsetNum = parseInt(bottomOffset); + + adjustingTitle = true; + $scope.setTitleOffset(blnShow, bottomOffset, bottomOffsetNum); + + $timeout(function() { + if (bottomOffset.indexOf("%") === -1) { + adjustingTitle = false; + var beforeTimout = bottomOffsetNum; + + bottomOffset = $element.css('bottom'); + bottomOffsetNum = parseInt(bottomOffset); + + if (Math.abs(beforeTimout - bottomOffsetNum) > 5) { + if (shouldAdjustTitle === true) { + $scope.setTitleOffset(!blnShow, bottomOffset, + bottomOffsetNum); + shouldAdjustTitle = false; + } + } + } + + }, 1500); + + }; + + /** + * descroption: + * Watch thumbState value. If values was changed check if there is need to + * displace description div. If thumb list and description not overlaping + * then no need to displace description div. + */ + $scope.$watch('thumbState', function(n, o) { + // For the time being stop title movement + /*if ($scope.isOverlapped(n) == true || $scope.isPosAdjusted) + $scope.adjustTitlePos(n); + */ + }); + + $scope.$watch('offset', function(n, o) { + + if (n != null) + $scope.thumbOffset = n; + + }); + + /** + * description: + * If thumb list and description have equal bottom offset it mean thumblist and + * descriptoin div are overlaying. + * + * @param {type} blnShow + * @returns {Boolean} + */ + + $scope.isOverlapped = function(blnShow) { + + //var thumbBottomOffset = angular.element('category-thumb-list').css('bottom'); + //var elm = angular.element($document[0].querySelector('st_category_thumb')); + var thumbBottomOffset = $scope.thumbOffset; + + var bottomOffset = $element.css('bottom'); + + var thumbPos = $scope.getPosition(thumbBottomOffset); + if (isNaN(thumbPos)) + thumbPos = $scope.getPosition("10%"); + var descPos = $scope.getPosition(bottomOffset); + + if (blnShow == true) { + if (thumbPos + THUMB_LIST_HEIGHT > descPos) + return true; + else + return false; + } + else + { + if (thumbPos - THUMB_LIST_HEIGHT > descPos) + return true; + else + return false; + } + + }; + + /** + * + * @returns {undefined} + */ + + $scope.getWindowHeight = function() { + return $window.innerHeight; + }; + + /** + * description: + * + * If offset is in percentage then calcualte its absolute position wrt to + * screen height. + * + * @param {type} offset + * @returns {Number|@var;winHeight} + */ + + $scope.getPosition = function(offset) { + + var winHeight = $scope.getWindowHeight(); + + if (offset.indexOf("%") != -1) { + var h = (winHeight * parseInt(offset)) / 100; + return h; + } + else { + return parseInt(offset); + } + }; + + }]); \ No newline at end of file diff --git a/app/js/controllers/StaticBlockController.js b/app/js/controllers/StaticBlockController.js new file mode 100644 index 0000000..2dd2a3a --- /dev/null +++ b/app/js/controllers/StaticBlockController.js @@ -0,0 +1,38 @@ +'use strict' + +angular.module('st.app').controller('StaticBlockCtrl', ['$scope', '$log', + '$injector', '$sce', 'APP_CONFIG', function($scope, $log, $injector, $sce, + APP_CONFIG) { + $scope.block = {}; + var ContentModel = $injector.get(APP_CONFIG.dataProvider + + 'ContentModel'); + + /** + * watch the blockId. If <> 0, show the block + */ + $scope.$watch('blockId', function(n, o) { + if (n == APP_CONFIG.noBlock || typeof n == 'undefined') { + $scope.display = false; + $scope.block = {}; + } else { + ContentModel.getStaticBlock(n, function(block) { + if (block) { + block.html = $sce.trustAsHtml(block.html); + $scope.block = block; + $scope.display = true; + } else { + $scope.display = false; + } + }); + } + }); + + /* + * remove the block and send an event so that the users could go back to last category + */ + $scope.removeBlock = function() { + $scope.display = false; + $scope.blockId = 0;// reset id + $scope.$emit('staticBlockExit'); + }; + }]); \ No newline at end of file diff --git a/app/js/controllers/ThumbnailController.js b/app/js/controllers/ThumbnailController.js new file mode 100644 index 0000000..f884266 --- /dev/null +++ b/app/js/controllers/ThumbnailController.js @@ -0,0 +1,802 @@ +'use strict'; + +/* Thumbnail Controller */ + +angular.module('st.app').controller("ThumbnailController", ['$rootScope', '$scope', 'ProductModel', + 'ProductsService','$location','$log','$element','APP_CONFIG', + function($rootScope, $scope, ProductModel, ProductsService, + $location,$log,$element,APP_CONFIG) { + + $scope.thumbnailsDatasource = []; + $scope.thumbnailItemWidth = 0; + $scope.thumbnailItemMinWidth = 200; + $scope.isMouseUpOnNav = true; + $scope.thumbFirstItem = null; + $scope.thumbLastItem = null; + $scope.prevCatId = -1; + $scope.thumbnailsCatId = -1; + $scope.isItemLoaded = false; + $scope.thumbActiveItemId = null; + $scope.categoryName = ""; + $scope.showThumbnails = false; + + + + // Constants + + $scope.SCROLL_DIRECTION_LEFT = "left"; + $scope.SCROLL_DIRECTION_RIGHT = "right"; + $scope.THUMBNAIL_LIST_TAG = 'thumbnail-list'; + $scope.THUMBNAIL_WRAPPER_CLASS = '.st_thumbs_wrapper'; + $scope.ALBUM_CLASS = '.album'; + $scope.THUMBS_CLASS = '.st_thumbs'; + + + var TAG = "ThumbnailController"; + var scrollFactor = 10; + var scrollDuration = 30; + + /** + * description: + * If item is already loaded in thumbnail list and is not visible on the screen + * (currently item is off the screen),just set its position so that user can view it. + * It should be displayed at left side. Also apply active item class. + * Otherwise fetch it from ProductsService and load into thumbnail lis + * + */ + $scope.selectPrevItem = function(item_id) { + + if($scope.isMouseUpOnNav == false) // scrolling thumbnails list. No need to set position + return; + $scope.getThumbWrapper(function(wrapper) { + + // make item id + var id = "#thumb_" + $scope.thumbnailsCatId + "_" + item_id; + var pos = $(id).position(); + + var winWidth = $(window).width(); + var itemWidth = $(id).width(); + + if (pos != null) + { + // if pos.left is less than 0 it mean item is off the screen on left side + if (pos.left < 0) { + + // scroll to main product active item so that it should be visible + var xPos = wrapper.scrollLeft(); + xPos = xPos - itemWidth; + wrapper.scrollLeft(xPos - scrollFactor); + } + // if pos.left > screenWidth it mean item is off the screen on right side + else if (pos.left > 0 && pos.left > winWidth) { + // set xPos so that item is visible + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + + } + else { + // item does not exist in thumbnail list. So load it from cache + $scope.loadPrevThumbnails(false, function(newWidth) { + var xPos = newWidth; + wrapper.scrollLeft(xPos - $scope.thumbnailItemWidth); + + $scope.highlightActiveItem(id); + }); + } + + $scope.isItemLoaded = true; + + }); + }; + + /** + * description: + * If item is already loaded in thumbnail list and is not visible on the screen + * just set is position so that user can view it. It should be displayed + * at right side. Also apply active item class. + * Otherwise fetch it from ProductsService and load into thumbnail list + * + * @param {type} item_id + * @returns {undefined} + */ + + $scope.selectNextItem = function(item_id) { + + + if($scope.isMouseUpOnNav == false) // scrolling thumbnails list. No need to set position + return; + + $scope.getThumbWrapper(function(wrapper) { + + var id = "#thumb_" + $scope.thumbnailsCatId + "_" + item_id; + var pos = $(id).position(); + + var winWidth = $(window).width(); + + var itemWidth = $(id).width(); + + if (pos != null) { + + // if left > screen width it mean item is off the screen on right side + if (pos.left > 0 && pos.left > winWidth) { + + // scroll to main product active item + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + // if left < 0 it mean item is off the screen on left side + else if (pos.left < 0) { + var xPos = pos.left + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + } + else { + // item not exist in thumbnail list. Fetch it from cache + $scope.loadNextThumbnails(true); + var xPos = wrapper.scrollLeft(); + wrapper.scrollLeft(xPos + $scope.thumbnailItemWidth); + + $scope.highlightActiveItem(id); + } + + $scope.isItemLoaded = true; + }); + }; + + /** + * Monitory any change in the category id from the parent upon which + * new items will be loaded in the thumbnail list + */ + $scope.$watch('catId', function(n, o) { + /** + * if the current and old categories aren't same then it means that + * we need to get new product list for new category so we have to + * set active product id to 0 + */ + + if(n == null) + $scope.thumbnailsCatId = APP_CONFIG.defaultCategory.id; + else + $scope.thumbnailsCatId = n; + + $scope.initController(); + + }); + + /** + * description: + * Upon product change we need to select active item in thumbnail list. + * We need to identify user has pressed left or right button on main screen + */ + $scope.$watch('activeProdId', function(n, o) { + + /* + * get rank from product id. If new product rank is greater than old product rank + * it means user is moving towards right. If new proudct rank is less than old + * porduct rank it means user is moving towards left + */ + + var oldProdRank = ProductsService.getProductRank($scope.thumbnailsCatId,o); + var newProdRank = ProductsService.getProductRank($scope.thumbnailsCatId,n); + + if(newProdRank > oldProdRank){ + $scope.selectNextItem(n); + } + else if(newProdRank < oldProdRank){ + $scope.selectPrevItem(n); + } + + }); + + /** + * description: + * categoryName is binded span. It will display category name as soon as its + * value is changed + */ + + $scope.$watch('selectedCategory', function(n, o) { + if(n != null){ + $scope.categoryName = n.name; + } + }); + + /** + * description: + * Initiate thumbnails data fetching from ProductsService + * + * @returns {undefined} + */ + + $scope.initController = function(){ + // check if thumbnails items are already loaded and displayed + if ($scope.thumbFirstItem == null && $scope.thumbLastItem == null) { + + // fetch and load items for book marked url + $scope.prevCatId = $scope.thumbnailsCatId; + + $log.debug(TAG + ':initController: --- fetching bookmarks'); + $scope.fetchThumbnailsForBookmarks(); + + $scope.hideThumbnails(); + } + else { + // category changed from category menu + if ($scope.prevCatId != $scope.thumbnailsCatId) { + + $log.debug(TAG + ':initController: --- cateogry changed'); + // category changed. Need to refresh thumbnails items + $scope.thumbFirstItem = null; + $scope.thumbLastItem = null; + + $scope.prevCatId = $scope.thumbnailsCatId; + + // remove thumbnails associate with previous cateogry as we need to load thumbs for new category + $scope.getThumbWrapper(function(wrapper) { + + wrapper.find('.st_thumbs a').each(function() { + $(this).remove(); + }); + + $scope.thumbnailsDatasource = $scope.thumbnailsDatasource.splice(0,$scope.thumbnailsDatasource.length); + + wrapper.scrollLeft(0); + + $log.debug(TAG + ':initController: --- fetching thumbnails'); + // fetch and load items for normal site open + $scope.fetchThumbnails($scope.thumbnailsCatId); + + $scope.hideThumbnails(); + }); + } + } + }; + + /** + * description: + * Apply class on required item. Also remove class from previous + * selected item. + * + * @param {type} itemId + * @returns {undefined} + * + * + */ + + $scope.highlightActiveItem = function(itemId){ + + $(itemId).addClass("st_thumbs_active"); + + if($scope.thumbActiveItemId != null && itemId != $scope.thumbActiveItemId){ + $($scope.thumbActiveItemId).removeClass("st_thumbs_active"); + } + + $scope.thumbActiveItemId = itemId; + }; + + /** + * description: + * Fetch items for bookmarked url from ProductsService and load into + * thumbnails list + * + * @returns {undefined} + */ + + + $scope.fetchThumbnailsForBookmarks = function() { + + + var productId = (typeof $scope.activeProdId == 'undefined') ? null : $scope.activeProdId; + var rank = ProductsService.getProductRank($scope.thumbnailsCatId, productId); + + var size = parseInt($(window).width()/$scope.thumbnailItemMinWidth) * 2; + + //retrieve the 3 product ids from the service on the basis of cateogry and productId + ProductsService.getProductsBasicData($scope.thumbnailsCatId, + productId, rank, size, 'created_at', 'desc', 'prevnext', true, true, + function(thumbnails) { + + if (thumbnails != null) { + // save first and last thumbnails to move prev and next + $scope.thumbFirstItem = thumbnails[0]; + $scope.thumbLastItem = thumbnails[thumbnails.length - 1]; + $scope.thumbnailsDatasource = thumbnails; + + setTimeout(function(){ + + // load fetched thumbnails + $scope.loadThumbs(function(newWidth){ + $scope.scrollToActiveItem(); + }); + },150); + + } + }); + + }; + + /** + * description: + * Fetch data from ProductsService and load into thumbnails list + * + * @param {type} categoryId + * @returns {undefined} + */ + $scope.fetchThumbnails = function(categoryId) { + + var size = parseInt($(window).width()/$scope.thumbnailItemMinWidth) * 2; + + // fetch thumbnails from cache + ProductsService.getProductsBasicData(categoryId, 0, 0, size, + 'created_at', 'desc', 'prevnext', true, true, + function(thumbnails) { + if (thumbnails != null) { + // save first and last thumbnails data to move prev and next + $scope.thumbFirstItem = thumbnails[0]; + $scope.thumbLastItem = thumbnails[thumbnails.length - 1]; + $scope.thumbnailsDatasource = thumbnails; + // load fetched thumbnails + setTimeout(function(){ + + // load fetched thumbnails + $scope.loadThumbs(function(newWidth){ + $scope.scrollToActiveItem(); + }); + },150); + } + }); + + }; + + /** + * description: + * Adjust width of thumbnails container so that items can be displayed in a single row. + * If item is not loaded yet, take minimum thumbnail width and adjust container width + * + * @returns {undefined} + */ + + $scope.buildThumbs = function() { + + $scope.getThumbWrapper(function(wrapper) { + + var width = 0; + + var tempWidth = -1; + wrapper.find('.st_thumbs a').each(function() { + if ($(this).outerWidth(true) >= $scope.thumbnailItemMinWidth) + width += $(this).outerWidth(true); + else + width += $scope.thumbnailItemMinWidth + 6 ; // margin 6 px: 3px left + 3px right + }); + + $scope.thumbnailItemWidth = $scope.thumbnailItemMinWidth; + + if(width < $scope.thumbnailsDatasource.length * $scope.thumbnailItemMinWidth){ + width = ($scope.thumbnailsDatasource.length * $scope.thumbnailItemMinWidth); + // Adjust width with margin 6 px: 3px left + 3px right + width += $scope.thumbnailsDatasource.length * 6; + } + + width = width + $scope.thumbnailItemWidth; + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + thumbs.css('width', width + 'px'); + + }); + }; + + /** + * + * @param {type} callback + * @returns {undefined} + */ + $scope.loadThumbs = function(callback) { + + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + var newItemsWidth = thumbs.width(); + + var newItemsWidth = thumbs.width(); + + $scope.buildThumbs(); + + newItemsWidth = thumbs.width() - newItemsWidth; + + if (callback != null) + callback(newItemsWidth); + }); + }; + + /** + * description: + * onThumbnailClick method will be called when thumbnail is clicked. Location + * will be changed and full product will show current active item + * + * @param {type} itemId + * @returns {undefined} + */ + + $scope.onThumbnailClick = function(itemId){ + + $scope.activeProdId = itemId; + $location.search('c', $scope.thumbnailsCatId); + $location.search('p', itemId); + + var id = "#thumb_" + $scope.thumbnailsCatId + "_" + itemId; + $scope.highlightActiveItem(id); + }; + + /** + * + * @param {type} oldWidth + * @param {type} callback + * @returns {undefined} + * + * + */ + + $scope.addThumbs = function(oldWidth,callback) { + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + + $scope.buildThumbs(); + + var newItemsWidth = ($scope.thumbnailsDatasource.length + 2) * $scope.thumbnailItemMinWidth - oldWidth; + + if (callback != null) + callback(newItemsWidth); + + }); + }; + + /** + * description: + * It returns width of thumbs container + * + * @param {type} callback + * @returns {undefined} + */ + $scope.thumbsContainerWidth = function(callback){ + + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + var newItemsWidth = thumbs.width(); + if (callback != null) + callback(newItemsWidth); + + }); + }; + + /* + * description: + * loadNextThumbnails will be called when there is need to fetch and add thumbnails in thumbnails list + * It will fetch items next to last fetched item + * + * @param {type} isAppend + * @returns {undefined} + * + * + */ + $scope.loadNextThumbnails = function(isAppend) { + + if($scope.thumbLastItem == null) + return; + // fetch thumbnails for rank + ProductsService.getProductsBasicData($scope.thumbnailsCatId, + $scope.thumbLastItem.entity_id, $scope.thumbLastItem.rank, 10, + 'created_at', 'desc', 'next', false, false, function(thumbnails) { + + // No item found. + if (thumbnails == null || thumbnails.length == 0) + return; + + var tempItem = thumbnails[thumbnails.length - 1]; + + if(tempItem == null) + return; + + // item already fetched. No need to add. Just ignore it + if ($scope.thumbLastItem != null && $scope.thumbLastItem.rank == tempItem.rank) + return; + + $scope.thumbnailsDatasource = $scope.thumbnailsDatasource.concat(thumbnails); + + + // load newly fetched items + $scope.thumbLastItem = tempItem; + + setTimeout(function(){ + $scope.addThumbs(); + $scope.$digest(); + },10); + + }); + + }; + + /* + * description: + * loadPrevThumbnails will be called when user open bookmarked url and press prev button to scroll towards + * left. It will fetch previous items. + * + * @param {type} isAppend + * @param {type} callback + * @returns {undefined} + * + */ + + $scope.loadPrevThumbnails = function(isAppend, callback) { + + if($scope.thumbFirstItem == null) + return; + + // check if more items are avaiable. Previous to current first item + if ($scope.thumbFirstItem.rank > 1) + { + ProductsService.getProductsBasicData($scope.thumbnailsCatId, + $scope.thumbFirstItem.entity_id, $scope.thumbFirstItem.rank, + 10, 'created_at', 'desc', 'prev', false, false, + function(thumbnails) { + + // No item found + if (thumbnails == null || thumbnails.length == 0) + return; + + for(var i = 0 ; i < thumbnails.length; ++i) + { + $scope.thumbFirstItem = thumbnails[i]; + if($scope.thumbFirstItem != null) + break; + } + + $scope.thumbsContainerWidth(function(thumbsWidth){ + + var thumbs = $.map(thumbnails, function (value, key) { return value; }); + $scope.thumbnailsDatasource = thumbs.concat($scope.thumbnailsDatasource); + + // Load fetched items + $scope.addThumbs(thumbsWidth,function(newPos) { + $scope.$digest(); + if (callback != null) + callback(newPos); + }); + + }); + + }); + } + + }; + + /* + * description: + * scrollLeft will be called when user press left thumbnail navigation button. + * + * @returns {undefined} + * + */ + $scope.scrollLeft = function() { + $scope.getThumbWrapper(function(wrapper) { + + var xPos = wrapper.scrollLeft(); + if (xPos == 0) { + $scope.loadPrevThumbnails(false, function(newWidth) { + xPos += newWidth; + + wrapper.scrollLeft(xPos); + setTimeout(function() { + $scope.scrollLeft(); + }, scrollDuration); + }); + } else { + wrapper.scrollLeft(xPos - scrollFactor); + setTimeout(function() { + if ($scope.isMouseUpOnNav == false) + $scope.scrollLeft(); + }, scrollDuration); + } + }); + + }; + + /* + * description: + * scrollRight will be called when user press right thumbnail navigation button. + * + * @returns {undefined} + * + */ + $scope.scrollRight = function() { + + $scope.getThumbWrapper(function(wrapper) { + var wrapperWidth = wrapper.width(); + + var thumbsWidth = $(wrapper).children($scope.THUMBS_CLASS).width(); + + var xPos = wrapper.scrollLeft(); + if ((xPos + (2 * wrapperWidth)) >= thumbsWidth) { + $scope.loadNextThumbnails(true); + } + + var tempWidth = $(window).width(); + // if reached at last item. No need to scroll more. + if (xPos + $scope.thumbnailItemWidth <= thumbsWidth - tempWidth) + wrapper.scrollLeft(xPos + scrollFactor); + setTimeout(function() { + if ($scope.isMouseUpOnNav == false) + $scope.scrollRight(); + }, scrollDuration); + }); + }; + + /* + * description: + * getThumbWrapper return wrapper element which is children of thumbnail-list element + * + * @param {type} callback + * @returns {undefined} + * + */ + // extract thumbnail wrapper binded with current controller + $scope.getThumbWrapper = function(callback) { + + var div = $element.children('div'); + // extract thumbnail wrapper element + var album = $(div).children($scope.ALBUM_CLASS); + var wrapper = $(album).children($scope.THUMBNAIL_WRAPPER_CLASS); + + callback(wrapper); + }; + + // handle mouse down event on thumbnnails left navigation bar + $scope.onMouseDownOnNavLeft = function($event) { + $scope.isMouseUpOnNav = false; + $scope.scrollLeft(); + }; + + // handle mouse up event on thumbnails left navigation bar + $scope.onMouseUpOnLeftNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumnails left navigation bar + $scope.onMouseLeftLeftNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse down event on thumbnnails right navigation bar + $scope.onMouseDownOnNavRight = function($event) { + + $scope.isMouseUpOnNav = false; + $scope.scrollRight(); + }; + + // handle mouse up event on thumbnails right navigation bar + $scope.onMouseUpOnRightNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumnails right navigation bar + $scope.onMouseLeftRightNav = function($event) { + $scope.isMouseUpOnNav = true; + }; + + // handle mouse leave event on thumbnails-list + $scope.onMouseLeft = function($event) { + //console.log('mouselef TC');return; + var mouseXPos = $event.screenX; + var screenWidth = $event.view.outerWidth; + + if (mouseXPos > 0 && mouseXPos < screenWidth){ + $scope.showThumbnails = false; + $scope.getThumbWrapper(function(wrapper) { + + $(wrapper).stop(); + wrapper.hide("0.25"); + }); + } + }; + // handle mouse enter event on thumnails-list + $scope.onMouseEnter = function($event) { + //console.log('mosueenter TC');return; + $scope.showThumbnails = true; + $scope.getThumbWrapper(function(wrapper) { + + var elm = wrapper.find('.st_thumbs a'); + // no item is loaded for current category. Try to reload items + if(elm.length == 0){ + $scope.initController(); + } + + $(wrapper).stop(); + wrapper.show("0.25"); + + if ($scope.isItemLoaded) { + $scope.scrollToActiveItem(); + $scope.isItemLoaded = false; + } + }); + }; + + /** + * description: Thumbnail list is being show at the start. We hide thumbnails list + * after 5 seconds + * + * @returns {undefined} + */ + + $scope.hideThumbnails = function(){ + + setTimeout(function() { + $scope.getThumbWrapper(function(wrapper) { + if($scope.showThumbnails == false){ + wrapper.stop(); + wrapper.hide("0.5"); + } + }); + },1000); + + }; + + /* + * description: + * scrollToActiveItem will be called when thumbnails state change from hidden to visible + * When user click on prev/next button we cannot scroll to item as these are hidden. + * When user moves on thumbnails-list we find active item and scroll to that item. + * + * @returns {undefined} + * + */ + + $scope.scrollToActiveItem = function() { + + setTimeout(function() { + + // fetch thumb wrapper associated with current controller + $scope.getThumbWrapper(function(wrapper) { + + // make thumbitem id and get its position + var id = "#thumb_" + $scope.thumbnailsCatId + "_" + $scope.activeProdId; + var pos = $(id).position(); + + var winWidth = $(window).width(); + var itemWidth = $(id).width(); + + if (pos != null) { + + // item found and it is off the screen on write side + if (pos.left > 0 && pos.left > winWidth) { + + // scroll to main product active item + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + else if(pos.left > 0 && pos.left < $scope.thumbnailItemMinWidth){ + // scroll to required position + var xPos = $scope.thumbnailItemMinWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + // item found and its off the screen on left side + else if (pos.left < 0) { + + // scroll to required position + var xPos = pos.left + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos - scrollFactor); + } + + $scope.highlightActiveItem(id); + } + + }); + }, 30); + }; + + }]); diff --git a/app/js/controllers/ThumbnailController1.js b/app/js/controllers/ThumbnailController1.js new file mode 100644 index 0000000..62c9898 --- /dev/null +++ b/app/js/controllers/ThumbnailController1.js @@ -0,0 +1,412 @@ +'use strict'; + +/* Thumbnail Controller */ + +myApp.controller("ThumbnailController", ['$rootScope', '$scope', 'ProductModel', + 'ProductsService', '$stateParams', '$location', '$window','$log', + function($rootScope, $scope, ProductModel, ProductsService, $stateParams, + $location, $window,$log) { + + $scope.thumbnailItemWidth = 0; + $scope.thumbnailItemMinWidth = 200; + $scope.isMouseUpOnNav = false; + $scope.showThumbnails = false; + $scope.thumbFirstItem = null; + $scope.thumbLastItem = null; + $scope.prevCatId = -1; + $scope.thumbnailsCatId = -1; + $scope.isItemLoaded = false; + $scope.thumbActiveItemId = null; + + // Constants + + $scope.SCROLL_DIRECTION_LEFT = "left"; + $scope.SCROLL_DIRECTION_RIGHT = "right"; + $scope.THUMBNAIL_LIST_TAG = 'thumbnail-list'; + $scope.THUMBNAIL_WRAPPER_CLASS = '.st_thumbs_wrapper'; + $scope.ALBUM_CLASS = '.album'; + $scope.THUMBS_CLASS = '.st_thumbs'; + + + var TAG = "ThumbnailController"; + + // handle event move to previous proudct + $scope.$on('moveToPreviousProduct', function(event, cat_id, item_id) { + + // check controller context + if (cat_id != $scope.thumbnailsCatId) + return; + + /* if thumbnaisl are hidden we cannot scroll thumbnails item. To move on next item we show it + * and set its opacity 0. So user will not be able to see. When user move curson on thumbnails + * item we set its opacity 1 + */ + if ($scope.showThumbnails == false) { + $scope.showThumbnails = true; + $scope.updateThumbsOpacity(0); + } + + // get thumbnail-list wrapper bined with current cat-id/controller + $scope.getThumbWrapper(function(wrapper) { + + // make item id + var id = "#thumb_" + cat_id + "_" + item_id; + var pos = $(id).position(); + var winWidth = $(window).width(); + var itemWidth = $(id).width(); + + if (pos != null) + { + // if pos.left is less than 0 it mean item is off the screen on left side + if (pos.left < 0) { + + // scroll to main product active item so that it should be visible + var xPos = wrapper.scrollLeft(); + xPos = xPos - itemWidth; + wrapper.scrollLeft(xPos - 5); + } + // if pos.left > screenWidth it mean item is off the screen on right side + else if (pos.left > 0 && pos.left > winWidth) { + // set xPos so that item is visible + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + + } + else { + // item does not exist in thumbnail list. So load it from cache + $scope.loadPrevThumbnails(false, function(newWidth) { + var xPos = newWidth; + wrapper.scrollLeft(xPos - $scope.thumbnailItemWidth); + $scope.isItemLoaded = true; + + $scope.highlightActiveItem(id); + }); + } + + }); + }); + + // hanlde event move to next product + + $scope.$on('moveToNextProduct', function(event, cat_id, item_id) { + + if (cat_id != $scope.thumbnailsCatId) + return; + + /* if thumbnaisl are hidden we cannot scroll thumbnails item. To move on next item we show it + * and set its opacity 0. So user will not be able to see. When user move curson on thumbnails + * item we set its opacity 1 + */ + if ($scope.showThumbnails == false) { + $scope.showThumbnails = true; + $scope.updateThumbsOpacity(0); + } + // fetch thumber wrapper associated with this controller + $scope.getThumbWrapper(function(wrapper) { + + var id = "#thumb_" + cat_id + "_" + item_id; + var pos = $(id).position(); + + var winWidth = $(window).width(); + var itemWidth = $(id).width(); + + if (pos != null) { + + // if left > screen width it mean item is off the screen on right side + if (pos.left > 0 && pos.left > winWidth) { + + // scroll to main product active item + var xPos = pos.left - winWidth + itemWidth + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + // if left < 0 it mean item is off the screen on left side + else if (pos.left < 0) { + var xPos = pos.left + wrapper.scrollLeft(); + wrapper.scrollLeft(xPos); + } + + $scope.highlightActiveItem(id); + } + else { + // item not exist in thumbnail list. Fetch it from cache + $scope.loadNextThumbnails(true); + var xPos = wrapper.scrollLeft(); + wrapper.scrollLeft(xPos + $scope.thumbnailItemWidth); + $scope.isItemLoaded = true; + + $scope.highlightActiveItem(id); + } + }); + }); + + // fetch thumbnails if category is changed + $rootScope.$on('$viewContentLoaded', function() { + + $log.debug(TAG + ':$viewContentLoaded: --- '); + + $scope.initController(); + }); + + /** + * description: initiate thumbnails fetching process + * + * + * @returns {undefined} + */ + + $scope.initController = function(){ + // check if thumbnails items are already loaded and displayed + if ($scope.thumbFirstItem == null && $scope.thumbLastItem == null) { + + // fetch and load items for book marked url + //if($scope.catId == $stateParams.categoryId){ + $scope.prevCatId = $stateParams.categoryId; + $scope.thumbnailsCatId = $stateParams.categoryId; + $scope.updateThumbWrapper($stateParams.categoryId); + $log.debug(TAG + ':initController: --- fetching bookmarks'); + $scope.fetchThumbnailsForBookmarks(); + /*} + else // fetch and load items for normal site open + $scope.fetchThumbnails($scope.catId); + */ + } + else { + // category changed from category menu + if ($scope.prevCatId != $stateParams.categoryId) { + + $log.debug(TAG + ':initController: --- cateogry changed'); + // category changed. Need to refresh thumbnails items + $scope.thumbFirstItem = null; + $scope.thumbLastItem = null; + + // update cateogry id + $scope.updateThumbWrapper($stateParams.categoryId); + $scope.thumbnailsCatId = $stateParams.categoryId; + $scope.prevCatId = $stateParams.categoryId; + + // remove thumbnails associate with previous cateogry as we need to load thumbs for new category + $scope.getThumbWrapper(function(wrapper) { + + wrapper.find('.st_thumbs a').each(function() { + $(this).remove(); + }); + $log.debug(TAG + ':initController: --- fetching thumbnails'); + // fetch and load items for normal site open + $scope.fetchThumbnails($scope.thumbnailsCatId); + }); + } + else{ + + $log.debug(TAG + ':initController: --- highlighting item'); + // get cateogry and product id + var cat_id = $stateParams.categoryId; + var item_id = $stateParams.prodId; + + // make thumbitem id and get its position + var id = "#thumb_" + cat_id + "_" + item_id; + + $scope.highlightActiveItem(id); + } + } + }; + + /** + * description: apply class on required item. Also remove class from previous + * selected item. + * + * @param {type} itemId + * @returns {undefined} + * + * + */ + + $scope.highlightActiveItem = function(itemId){ + + $(itemId).addClass("st_thumbs_active"); + + if($scope.thumbActiveItemId != null && itemId != $scope.thumbActiveItemId){ + $($scope.thumbActiveItemId).removeClass("st_thumbs_active"); + } + + $scope.thumbActiveItemId = itemId; + }; + + /** + * fetch items for bookmarked url + * @returns {undefined} + */ + + + $scope.fetchThumbnailsForBookmarks = function() { + + + var productId = (typeof $stateParams.prodId == 'undefined') ? null : $stateParams.prodId; + var rank = ProductsService.getProductRank($stateParams.categoryId, productId); + + //retrieve the 3 product ids from the service on the basis of cateogry and productId + ProductsService.getProductsBasicData($stateParams.categoryId, + productId, rank, 14, 'created_at', 'desc', 'prevnext', true, true, + function(thumbnails) { + + if (thumbnails != null) { + // save first and last thumbnails to move prev and next + $scope.thumbFirstItem = thumbnails[0]; + $scope.thumbLastItem = thumbnails[thumbnails.length - 1]; + // load fetched thumbnails + $scope.loadThumbs(0, thumbnails, true, function(newWidth){ + $scope.scrollToActiveItem(); + }); + } + // }); + }); + + }; + + /** + * + * @param {type} categoryId + * @returns {undefined} + */ + $scope.fetchThumbnails = function(categoryId) { + + // fetch thumbnails from cache + ProductsService.getProductsBasicData(categoryId, 0, 0, 14, + 'created_at', 'desc', 'prevnext', true, true, + function(thumbnails) { + if (thumbnails != null) { + // save first and last thumbnails data to move prev and next + $scope.thumbFirstItem = thumbnails[0]; + $scope.thumbLastItem = thumbnails[thumbnails.length - 1]; + // load fetched thumbnails + $scope.loadThumbs(0, thumbnails, true, function(w) { + $scope.scrollToActiveItem(); + }); + } + }); + + }; + + $scope.bindEvents = function() { + + $scope.thumbnailsCatId = $scope.catId; + $($scope.THUMBNAIL_WRAPPER_CLASS).animate({ + scrollLeft: 0 + }); + + }; + + /** + * + * @returns {undefined} + */ + + $scope.buildThumbs = function() { + + $scope.getThumbWrapper(function(wrapper) { + + var width = 0; + + var tempWidth = -1; + wrapper.find('.st_thumbs a').each(function() { + if ($(this).outerWidth(true) >= $scope.thumbnailItemMinWidth) + width += $(this).outerWidth(true); + else + width += $scope.thumbnailItemMinWidth; + }); + + var winWidth = $(window).width(); + + $scope.thumbnailItemWidth = $scope.thumbnailItemMinWidth; + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + thumbs.css('width', width + $scope.thumbnailItemWidth + 'px'); + + }); + }; + + /** + * + * @param {type} offset + * @param {type} thumbnails + * @param {type} isAppend + * @param {type} callback + * @returns {undefined} + */ + $scope.loadThumbs = function(offset, thumbnails, isAppend, callback) { + + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + var newItemsWidth = thumbs.width(); + + var newItemsWidth = thumbs.width(); + + var slug = $scope.slug; + + if (slug == null) + slug = "category"; + + // append items + while (offset < thumbnails.length) { + + var thumbnailItem = thumbnails[offset]; + var thumbId = "thumb_" + $scope.thumbnailsCatId + "_" + + thumbnailItem.entity_id; + if (isAppend) + thumbs.append(''); + else + thumbs.prepend(''); + offset++; + } + + $scope.buildThumbs(); + + newItemsWidth = thumbs.width() - newItemsWidth; + + if (callback != null) + callback(newItemsWidth); + }); + }; + + /** + * + * @param {type} isAppend + * @param {type} thumbnails + * @param {type} callback + * @returns {undefined} + * + * + */ + + $scope.addThumbs = function(isAppend, thumbnails, callback) { + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + var newItemsWidth = thumbs.width(); + + var slug = $scope.slug; + + if (slug == null) + slug = "category"; + + var index = 0; + if (isAppend) { + while (index < thumbnails.length) { + var thumbnailItem = thumbnails[index]; + var thumbId = "thumb_" + $scope.thumbnailsCatId + "_" + + thumbnailItem.entity_id; + thumbs.append(''); + else + thumbs.prepend(''); + offset++; + } + + $scope.buildThumbs(); + + newItemsWidth = thumbs.width() - newItemsWidth; + + if (callback != null) + callback(newItemsWidth); + }); + }; + + /** + * + * @param {type} isAppend + * @param {type} thumbnails + * @param {type} callback + * @returns {undefined} + * + * + */ + + $scope.addThumbs = function(isAppend, thumbnails, callback) { + $scope.getThumbWrapper(function(wrapper) { + + var thumbs = $(wrapper).children($scope.THUMBS_CLASS); + var newItemsWidth = thumbs.width(); + + var slug = $scope.slug; + + if (slug == null) + slug = "category"; + + var index = 0; + if (isAppend) { + while (index < thumbnails.length) { + var thumbnailItem = thumbnails[index]; + var thumbId = "thumb_" + $scope.thumbnailsCatId + "_" + + thumbnailItem.entity_id; + thumbs.append('' + + }; +}]); + +/** + * dynamic content retriever: + * use for cases when the data block contains directives + */ +angular.module('st.app').directive('dynamicBlock', function( + ) { + return { + restrict: 'AE', + controller: 'dynamicBlockCtrl', + scope: false + }; +}); + +angular.module('st.app').directive('onTouch', function() { + return { + restrict: 'A', + link: function(scope, elm, attrs) { + var ontouchFn = scope.$eval(attrs.onTouch); + elm.bind('touchstart', function(evt) { + scope.$apply(function() { + ontouchFn.call(scope, evt.which); + }); + }); + } + }; +}); \ No newline at end of file diff --git a/app/js/filters.js b/app/js/filters.js new file mode 100644 index 0000000..a482ed7 --- /dev/null +++ b/app/js/filters.js @@ -0,0 +1,10 @@ +'use strict'; + +/* Filters */ + +angular.module('st.app.filters', []). + filter('interpolate', ['version', function(version) { + return function(text) { + return String(text).replace(/\%VERSION\%/mg, version); + } + }]); diff --git a/app/js/jquery-2.0.3.min.js b/app/js/jquery-2.0.3.min.js new file mode 100644 index 0000000..2be209d --- /dev/null +++ b/app/js/jquery-2.0.3.min.js @@ -0,0 +1,6 @@ +/*! jQuery v2.0.3 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license +//@ sourceMappingURL=jquery-2.0.3.min.map +*/ +(function(e,undefined){var t,n,r=typeof undefined,i=e.location,o=e.document,s=o.documentElement,a=e.jQuery,u=e.$,l={},c=[],p="2.0.3",f=c.concat,h=c.push,d=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,x=function(e,n){return new x.fn.init(e,n,t)},b=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^-ms-/,N=/-([\da-z])/gi,E=function(e,t){return t.toUpperCase()},S=function(){o.removeEventListener("DOMContentLoaded",S,!1),e.removeEventListener("load",S,!1),x.ready()};x.fn=x.prototype={jquery:p,constructor:x,init:function(e,t,n){var r,i;if(!e)return this;if("string"==typeof e){if(r="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:T.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof x?t[0]:t,x.merge(this,x.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:o,!0)),C.test(r[1])&&x.isPlainObject(t))for(r in t)x.isFunction(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=o.getElementById(r[2]),i&&i.parentNode&&(this.length=1,this[0]=i),this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?n.ready(e):(e.selector!==undefined&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return d.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,t,n,r,i,o,s=arguments[0]||{},a=1,u=arguments.length,l=!1;for("boolean"==typeof s&&(l=s,s=arguments[1]||{},a=2),"object"==typeof s||x.isFunction(s)||(s={}),u===a&&(s=this,--a);u>a;a++)if(null!=(e=arguments[a]))for(t in e)n=s[t],r=e[t],s!==r&&(l&&r&&(x.isPlainObject(r)||(i=x.isArray(r)))?(i?(i=!1,o=n&&x.isArray(n)?n:[]):o=n&&x.isPlainObject(n)?n:{},s[t]=x.extend(l,o,r)):r!==undefined&&(s[t]=r));return s},x.extend({expando:"jQuery"+(p+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=a),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){(e===!0?--x.readyWait:x.isReady)||(x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(o,[x]),x.fn.trigger&&x(o).trigger("ready").off("ready")))},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray,isWindow:function(e){return null!=e&&e===e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if("object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(t){return!1}return!0},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:JSON.parse,parseXML:function(e){var t,n;if(!e||"string"!=typeof e)return null;try{n=new DOMParser,t=n.parseFromString(e,"text/xml")}catch(r){t=undefined}return(!t||t.getElementsByTagName("parsererror").length)&&x.error("Invalid XML: "+e),t},noop:function(){},globalEval:function(e){var t,n=eval;e=x.trim(e),e&&(1===e.indexOf("use strict")?(t=o.createElement("script"),t.text=e,o.head.appendChild(t).parentNode.removeChild(t)):n(e))},camelCase:function(e){return e.replace(k,"ms-").replace(N,E)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,s=j(e);if(n){if(s){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(s){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:function(e){return null==e?"":v.call(e)},makeArray:function(e,t){var n=t||[];return null!=e&&(j(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:g.call(t,e,n)},merge:function(e,t){var n=t.length,r=e.length,i=0;if("number"==typeof n)for(;n>i;i++)e[r++]=t[i];else while(t[i]!==undefined)e[r++]=t[i++];return e.length=r,e},grep:function(e,t,n){var r,i=[],o=0,s=e.length;for(n=!!n;s>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,s=j(e),a=[];if(s)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(a[a.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(a[a.length]=r);return f.apply([],a)},guid:1,proxy:function(e,t){var n,r,i;return"string"==typeof t&&(n=e[t],t=e,e=n),x.isFunction(e)?(r=d.call(arguments,2),i=function(){return e.apply(t||this,r.concat(d.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):undefined},access:function(e,t,n,r,i,o,s){var a=0,u=e.length,l=null==n;if("object"===x.type(n)){i=!0;for(a in n)x.access(e,t,a,n[a],!0,o,s)}else if(r!==undefined&&(i=!0,x.isFunction(r)||(s=!0),l&&(s?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(x(e),n)})),t))for(;u>a;a++)t(e[a],n,s?r:r.call(e[a],a,t(e[a],n)));return i?e:l?t.call(e):u?t(e[0],n):o},now:Date.now,swap:function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=s[o];return i}}),x.ready.promise=function(t){return n||(n=x.Deferred(),"complete"===o.readyState?setTimeout(x.ready):(o.addEventListener("DOMContentLoaded",S,!1),e.addEventListener("load",S,!1))),n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function j(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}t=x(o),function(e,undefined){var t,n,r,i,o,s,a,u,l,c,p,f,h,d,g,m,y,v="sizzle"+-new Date,b=e.document,w=0,T=0,C=st(),k=st(),N=st(),E=!1,S=function(e,t){return e===t?(E=!0,0):0},j=typeof undefined,D=1<<31,A={}.hasOwnProperty,L=[],q=L.pop,H=L.push,O=L.push,F=L.slice,P=L.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",W="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",$=W.replace("w","w#"),B="\\["+M+"*("+W+")"+M+"*(?:([*^$|!~]?=)"+M+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+$+")|)|)"+M+"*\\]",I=":("+W+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+B.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=RegExp("^"+M+"*,"+M+"*"),X=RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=RegExp(M+"*[+~]"),Y=RegExp("="+M+"*([^\\]'\"]*)"+M+"*\\]","g"),V=RegExp(I),G=RegExp("^"+$+"$"),J={ID:RegExp("^#("+W+")"),CLASS:RegExp("^\\.("+W+")"),TAG:RegExp("^("+W.replace("w","w*")+")"),ATTR:RegExp("^"+B),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:RegExp("^(?:"+R+")$","i"),needsContext:RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Q=/^[^{]+\{\s*\[native \w/,K=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,Z=/^(?:input|select|textarea|button)$/i,et=/^h\d$/i,tt=/'|\\/g,nt=RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),rt=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{O.apply(L=F.call(b.childNodes),b.childNodes),L[b.childNodes.length].nodeType}catch(it){O={apply:L.length?function(e,t){H.apply(e,F.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function ot(e,t,r,i){var o,s,a,u,l,f,g,m,x,w;if((t?t.ownerDocument||t:b)!==p&&c(t),t=t||p,r=r||[],!e||"string"!=typeof e)return r;if(1!==(u=t.nodeType)&&9!==u)return[];if(h&&!i){if(o=K.exec(e))if(a=o[1]){if(9===u){if(s=t.getElementById(a),!s||!s.parentNode)return r;if(s.id===a)return r.push(s),r}else if(t.ownerDocument&&(s=t.ownerDocument.getElementById(a))&&y(t,s)&&s.id===a)return r.push(s),r}else{if(o[2])return O.apply(r,t.getElementsByTagName(e)),r;if((a=o[3])&&n.getElementsByClassName&&t.getElementsByClassName)return O.apply(r,t.getElementsByClassName(a)),r}if(n.qsa&&(!d||!d.test(e))){if(m=g=v,x=t,w=9===u&&e,1===u&&"object"!==t.nodeName.toLowerCase()){f=gt(e),(g=t.getAttribute("id"))?m=g.replace(tt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",l=f.length;while(l--)f[l]=m+mt(f[l]);x=U.test(e)&&t.parentNode||t,w=f.join(",")}if(w)try{return O.apply(r,x.querySelectorAll(w)),r}catch(T){}finally{g||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,r,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>i.cacheLength&&delete t[e.shift()],t[n]=r}return t}function at(e){return e[v]=!0,e}function ut(e){var t=p.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function lt(e,t){var n=e.split("|"),r=e.length;while(r--)i.attrHandle[n[r]]=t}function ct(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function pt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return at(function(t){return t=+t,at(function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))})})}s=ot.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},n=ot.support={},c=ot.setDocument=function(e){var t=e?e.ownerDocument||e:b,r=t.defaultView;return t!==p&&9===t.nodeType&&t.documentElement?(p=t,f=t.documentElement,h=!s(t),r&&r.attachEvent&&r!==r.top&&r.attachEvent("onbeforeunload",function(){c()}),n.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ut(function(e){return e.appendChild(t.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=ut(function(e){return e.innerHTML="
",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),n.getById=ut(function(e){return f.appendChild(e).id=v,!t.getElementsByName||!t.getElementsByName(v).length}),n.getById?(i.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){return e.getAttribute("id")===t}}):(delete i.find.ID,i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),i.find.TAG=n.getElementsByTagName?function(e,t){return typeof t.getElementsByTagName!==j?t.getElementsByTagName(e):undefined}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},i.find.CLASS=n.getElementsByClassName&&function(e,t){return typeof t.getElementsByClassName!==j&&h?t.getElementsByClassName(e):undefined},g=[],d=[],(n.qsa=Q.test(t.querySelectorAll))&&(ut(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||d.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll(":checked").length||d.push(":checked")}),ut(function(e){var n=t.createElement("input");n.setAttribute("type","hidden"),e.appendChild(n).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&d.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||d.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),d.push(",.*:")})),(n.matchesSelector=Q.test(m=f.webkitMatchesSelector||f.mozMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&ut(function(e){n.disconnectedMatch=m.call(e,"div"),m.call(e,"[s!='']:x"),g.push("!=",I)}),d=d.length&&RegExp(d.join("|")),g=g.length&&RegExp(g.join("|")),y=Q.test(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},S=f.compareDocumentPosition?function(e,r){if(e===r)return E=!0,0;var i=r.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(r);return i?1&i||!n.sortDetached&&r.compareDocumentPosition(e)===i?e===t||y(b,e)?-1:r===t||y(b,r)?1:l?P.call(l,e)-P.call(l,r):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,n){var r,i=0,o=e.parentNode,s=n.parentNode,a=[e],u=[n];if(e===n)return E=!0,0;if(!o||!s)return e===t?-1:n===t?1:o?-1:s?1:l?P.call(l,e)-P.call(l,n):0;if(o===s)return ct(e,n);r=e;while(r=r.parentNode)a.unshift(r);r=n;while(r=r.parentNode)u.unshift(r);while(a[i]===u[i])i++;return i?ct(a[i],u[i]):a[i]===b?-1:u[i]===b?1:0},t):p},ot.matches=function(e,t){return ot(e,null,null,t)},ot.matchesSelector=function(e,t){if((e.ownerDocument||e)!==p&&c(e),t=t.replace(Y,"='$1']"),!(!n.matchesSelector||!h||g&&g.test(t)||d&&d.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(i){}return ot(t,p,null,[e]).length>0},ot.contains=function(e,t){return(e.ownerDocument||e)!==p&&c(e),y(e,t)},ot.attr=function(e,t){(e.ownerDocument||e)!==p&&c(e);var r=i.attrHandle[t.toLowerCase()],o=r&&A.call(i.attrHandle,t.toLowerCase())?r(e,t,!h):undefined;return o===undefined?n.attributes||!h?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null:o},ot.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},ot.uniqueSort=function(e){var t,r=[],i=0,o=0;if(E=!n.detectDuplicates,l=!n.sortStable&&e.slice(0),e.sort(S),E){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return e},o=ot.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=o(t);return n},i=ot.selectors={cacheLength:50,createPseudo:at,match:J,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(nt,rt),e[3]=(e[4]||e[5]||"").replace(nt,rt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ot.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ot.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return J.CHILD.test(e[0])?null:(e[3]&&e[4]!==undefined?e[2]=e[4]:n&&V.test(n)&&(t=gt(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(nt,rt).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&C(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=ot.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,p,f,h,d,g=o!==s?"nextSibling":"previousSibling",m=t.parentNode,y=a&&t.nodeName.toLowerCase(),x=!u&&!a;if(m){if(o){while(g){p=t;while(p=p[g])if(a?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;d=g="only"===e&&!d&&"nextSibling"}return!0}if(d=[s?m.firstChild:m.lastChild],s&&x){c=m[v]||(m[v]={}),l=c[e]||[],h=l[0]===w&&l[1],f=l[0]===w&&l[2],p=h&&m.childNodes[h];while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[w,h,f];break}}else if(x&&(l=(t[v]||(t[v]={}))[e])&&l[0]===w)f=l[1];else while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if((a?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(x&&((p[v]||(p[v]={}))[e]=[w,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=i.pseudos[e]||i.setFilters[e.toLowerCase()]||ot.error("unsupported pseudo: "+e);return r[v]?r(t):r.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?at(function(e,n){var i,o=r(e,t),s=o.length;while(s--)i=P.call(e,o[s]),e[i]=!(n[i]=o[s])}):function(e){return r(e,0,n)}):r}},pseudos:{not:at(function(e){var t=[],n=[],r=a(e.replace(z,"$1"));return r[v]?at(function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:at(function(e){return function(t){return ot(e,t).length>0}}),contains:at(function(e){return function(t){return(t.textContent||t.innerText||o(t)).indexOf(e)>-1}}),lang:at(function(e){return G.test(e||"")||ot.error("unsupported lang: "+e),e=e.replace(nt,rt).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===p.activeElement&&(!p.hasFocus||p.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return et.test(e.nodeName)},input:function(e){return Z.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},i.pseudos.nth=i.pseudos.eq;for(t in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})i.pseudos[t]=pt(t);for(t in{submit:!0,reset:!0})i.pseudos[t]=ft(t);function dt(){}dt.prototype=i.filters=i.pseudos,i.setFilters=new dt;function gt(e,t){var n,r,o,s,a,u,l,c=k[e+" "];if(c)return t?0:c.slice(0);a=e,u=[],l=i.preFilter;while(a){(!n||(r=_.exec(a)))&&(r&&(a=a.slice(r[0].length)||a),u.push(o=[])),n=!1,(r=X.exec(a))&&(n=r.shift(),o.push({value:n,type:r[0].replace(z," ")}),a=a.slice(n.length));for(s in i.filter)!(r=J[s].exec(a))||l[s]&&!(r=l[s](r))||(n=r.shift(),o.push({value:n,type:s,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ot.error(e):k(e,u).slice(0)}function mt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function yt(e,t,n){var i=t.dir,o=n&&"parentNode"===i,s=T++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,n,a){var u,l,c,p=w+" "+s;if(a){while(t=t[i])if((1===t.nodeType||o)&&e(t,n,a))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[v]||(t[v]={}),(l=c[i])&&l[0]===p){if((u=l[1])===!0||u===r)return u===!0}else if(l=c[i]=[p],l[1]=e(t,n,a)||r,l[1]===!0)return!0}}function vt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,s=[],a=0,u=e.length,l=null!=t;for(;u>a;a++)(o=e[a])&&(!n||n(o,r,i))&&(s.push(o),l&&t.push(a));return s}function bt(e,t,n,r,i,o){return r&&!r[v]&&(r=bt(r)),i&&!i[v]&&(i=bt(i,o)),at(function(o,s,a,u){var l,c,p,f=[],h=[],d=s.length,g=o||Ct(t||"*",a.nodeType?[a]:a,[]),m=!e||!o&&t?g:xt(g,f,e,a,u),y=n?i||(o?e:d||r)?[]:s:m;if(n&&n(m,y,a,u),r){l=xt(y,h),r(l,[],a,u),c=l.length;while(c--)(p=l[c])&&(y[h[c]]=!(m[h[c]]=p))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(p=y[c])&&l.push(m[c]=p);i(null,y=[],l,u)}c=y.length;while(c--)(p=y[c])&&(l=i?P.call(o,p):f[c])>-1&&(o[l]=!(s[l]=p))}}else y=xt(y===s?y.splice(d,y.length):y),i?i(null,s,y,u):O.apply(s,y)})}function wt(e){var t,n,r,o=e.length,s=i.relative[e[0].type],a=s||i.relative[" "],l=s?1:0,c=yt(function(e){return e===t},a,!0),p=yt(function(e){return P.call(t,e)>-1},a,!0),f=[function(e,n,r){return!s&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;o>l;l++)if(n=i.relative[e[l].type])f=[yt(vt(f),n)];else{if(n=i.filter[e[l].type].apply(null,e[l].matches),n[v]){for(r=++l;o>r;r++)if(i.relative[e[r].type])break;return bt(l>1&&vt(f),l>1&&mt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&wt(e.slice(l,r)),o>r&&wt(e=e.slice(r)),o>r&&mt(e))}f.push(n)}return vt(f)}function Tt(e,t){var n=0,o=t.length>0,s=e.length>0,a=function(a,l,c,f,h){var d,g,m,y=[],v=0,x="0",b=a&&[],T=null!=h,C=u,k=a||s&&i.find.TAG("*",h&&l.parentNode||l),N=w+=null==C?1:Math.random()||.1;for(T&&(u=l!==p&&l,r=n);null!=(d=k[x]);x++){if(s&&d){g=0;while(m=e[g++])if(m(d,l,c)){f.push(d);break}T&&(w=N,r=++n)}o&&((d=!m&&d)&&v--,a&&b.push(d))}if(v+=x,o&&x!==v){g=0;while(m=t[g++])m(b,y,l,c);if(a){if(v>0)while(x--)b[x]||y[x]||(y[x]=q.call(f));y=xt(y)}O.apply(f,y),T&&!a&&y.length>0&&v+t.length>1&&ot.uniqueSort(f)}return T&&(w=N,u=C),b};return o?at(a):a}a=ot.compile=function(e,t){var n,r=[],i=[],o=N[e+" "];if(!o){t||(t=gt(e)),n=t.length;while(n--)o=wt(t[n]),o[v]?r.push(o):i.push(o);o=N(e,Tt(i,r))}return o};function Ct(e,t,n){var r=0,i=t.length;for(;i>r;r++)ot(e,t[r],n);return n}function kt(e,t,r,o){var s,u,l,c,p,f=gt(e);if(!o&&1===f.length){if(u=f[0]=f[0].slice(0),u.length>2&&"ID"===(l=u[0]).type&&n.getById&&9===t.nodeType&&h&&i.relative[u[1].type]){if(t=(i.find.ID(l.matches[0].replace(nt,rt),t)||[])[0],!t)return r;e=e.slice(u.shift().value.length)}s=J.needsContext.test(e)?0:u.length;while(s--){if(l=u[s],i.relative[c=l.type])break;if((p=i.find[c])&&(o=p(l.matches[0].replace(nt,rt),U.test(u[0].type)&&t.parentNode||t))){if(u.splice(s,1),e=o.length&&mt(u),!e)return O.apply(r,o),r;break}}}return a(e,f)(o,t,!h,r,U.test(e)),r}n.sortStable=v.split("").sort(S).join("")===v,n.detectDuplicates=E,c(),n.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(p.createElement("div"))}),ut(function(e){return e.innerHTML="
","#"===e.firstChild.getAttribute("href")})||lt("type|href|height|width",function(e,t,n){return n?undefined:e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ut(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||lt("value",function(e,t,n){return n||"input"!==e.nodeName.toLowerCase()?undefined:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||lt(R,function(e,t,n){var r;return n?undefined:(r=e.getAttributeNode(t))&&r.specified?r.value:e[t]===!0?t.toLowerCase():null}),x.find=ot,x.expr=ot.selectors,x.expr[":"]=x.expr.pseudos,x.unique=ot.uniqueSort,x.text=ot.getText,x.isXMLDoc=ot.isXML,x.contains=ot.contains}(e);var D={};function A(e){var t=D[e]={};return x.each(e.match(w)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?D[e]||A(e):x.extend({},e);var t,n,r,i,o,s,a=[],u=!e.once&&[],l=function(p){for(t=e.memory&&p,n=!0,s=i||0,i=0,o=a.length,r=!0;a&&o>s;s++)if(a[s].apply(p[0],p[1])===!1&&e.stopOnFalse){t=!1;break}r=!1,a&&(u?u.length&&l(u.shift()):t?a=[]:c.disable())},c={add:function(){if(a){var n=a.length;(function s(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&c.has(n)||a.push(n):n&&n.length&&"string"!==r&&s(n)})})(arguments),r?o=a.length:t&&(i=n,l(t))}return this},remove:function(){return a&&x.each(arguments,function(e,t){var n;while((n=x.inArray(t,a,n))>-1)a.splice(n,1),r&&(o>=n&&o--,s>=n&&s--)}),this},has:function(e){return e?x.inArray(e,a)>-1:!(!a||!a.length)},empty:function(){return a=[],o=0,this},disable:function(){return a=u=t=undefined,this},disabled:function(){return!a},lock:function(){return u=undefined,t||c.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!a||n&&!u||(t=t||[],t=[e,t.slice?t.slice():t],r?u.push(t):l(t)),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!n}};return c},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var s=o[0],a=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=a&&a.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[s+"With"](this===r?n.promise():this,a?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add(function(){n=a},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=d.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),s=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?d.call(arguments):r,n===a?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},a,u,l;if(r>1)for(a=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(s(t,l,n)).fail(o.reject).progress(s(t,u,a)):--i;return i||o.resolveWith(l,n),o.promise()}}),x.support=function(t){var n=o.createElement("input"),r=o.createDocumentFragment(),i=o.createElement("div"),s=o.createElement("select"),a=s.appendChild(o.createElement("option"));return n.type?(n.type="checkbox",t.checkOn=""!==n.value,t.optSelected=a.selected,t.reliableMarginRight=!0,t.boxSizingReliable=!0,t.pixelPosition=!1,n.checked=!0,t.noCloneChecked=n.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!a.disabled,n=o.createElement("input"),n.value="t",n.type="radio",t.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),r.appendChild(n),t.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,t.focusinBubbles="onfocusin"in e,i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===i.style.backgroundClip,x(function(){var n,r,s="padding:0;margin:0;border:0;display:block;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box",a=o.getElementsByTagName("body")[0];a&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",a.appendChild(n).appendChild(i),i.innerHTML="",i.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%",x.swap(a,null!=a.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===i.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(i,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(i,null)||{width:"4px"}).width,r=i.appendChild(o.createElement("div")),r.style.cssText=i.style.cssText=s,r.style.marginRight=r.style.width="0",i.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),a.removeChild(n))}),t):t}({});var L,q,H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,O=/([A-Z])/g;function F(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=x.expando+Math.random()}F.uid=1,F.accepts=function(e){return e.nodeType?1===e.nodeType||9===e.nodeType:!0},F.prototype={key:function(e){if(!F.accepts(e))return 0;var t={},n=e[this.expando];if(!n){n=F.uid++;try{t[this.expando]={value:n},Object.defineProperties(e,t)}catch(r){t[this.expando]=n,x.extend(e,t)}}return this.cache[n]||(this.cache[n]={}),n},set:function(e,t,n){var r,i=this.key(e),o=this.cache[i];if("string"==typeof t)o[t]=n;else if(x.isEmptyObject(o))x.extend(this.cache[i],t);else for(r in t)o[r]=t[r];return o},get:function(e,t){var n=this.cache[this.key(e)];return t===undefined?n:n[t]},access:function(e,t,n){var r;return t===undefined||t&&"string"==typeof t&&n===undefined?(r=this.get(e,t),r!==undefined?r:this.get(e,x.camelCase(t))):(this.set(e,t,n),n!==undefined?n:t)},remove:function(e,t){var n,r,i,o=this.key(e),s=this.cache[o];if(t===undefined)this.cache[o]={};else{x.isArray(t)?r=t.concat(t.map(x.camelCase)):(i=x.camelCase(t),t in s?r=[t,i]:(r=i,r=r in s?[r]:r.match(w)||[])),n=r.length;while(n--)delete s[r[n]]}},hasData:function(e){return!x.isEmptyObject(this.cache[e[this.expando]]||{})},discard:function(e){e[this.expando]&&delete this.cache[e[this.expando]]}},L=new F,q=new F,x.extend({acceptData:F.accepts,hasData:function(e){return L.hasData(e)||q.hasData(e)},data:function(e,t,n){return L.access(e,t,n)},removeData:function(e,t){L.remove(e,t)},_data:function(e,t,n){return q.access(e,t,n)},_removeData:function(e,t){q.remove(e,t)}}),x.fn.extend({data:function(e,t){var n,r,i=this[0],o=0,s=null;if(e===undefined){if(this.length&&(s=L.get(i),1===i.nodeType&&!q.get(i,"hasDataAttrs"))){for(n=i.attributes;n.length>o;o++)r=n[o].name,0===r.indexOf("data-")&&(r=x.camelCase(r.slice(5)),P(i,r,s[r]));q.set(i,"hasDataAttrs",!0)}return s}return"object"==typeof e?this.each(function(){L.set(this,e)}):x.access(this,function(t){var n,r=x.camelCase(e);if(i&&t===undefined){if(n=L.get(i,e),n!==undefined)return n;if(n=L.get(i,r),n!==undefined)return n;if(n=P(i,r,undefined),n!==undefined)return n}else this.each(function(){var n=L.get(this,r);L.set(this,r,t),-1!==e.indexOf("-")&&n!==undefined&&L.set(this,e,t)})},null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){L.remove(this,e)})}});function P(e,t,n){var r;if(n===undefined&&1===e.nodeType)if(r="data-"+t.replace(O,"-$1").toLowerCase(),n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:H.test(n)?JSON.parse(n):n}catch(i){}L.set(e,t,n)}else n=undefined;return n}x.extend({queue:function(e,t,n){var r;return e?(t=(t||"fx")+"queue",r=q.get(e,t),n&&(!r||x.isArray(n)?r=q.access(e,t,x.makeArray(n)):r.push(n)),r||[]):undefined},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),s=function(){x.dequeue(e,t) +};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return q.get(e,n)||q.access(e,n,{empty:x.Callbacks("once memory").add(function(){q.remove(e,[t+"queue",n])})})}}),x.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),n>arguments.length?x.queue(this[0],e):t===undefined?this:this.each(function(){var n=x.queue(this,e,t);x._queueHooks(this,e),"fx"===e&&"inprogress"!==n[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=x.Deferred(),o=this,s=this.length,a=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=undefined),e=e||"fx";while(s--)n=q.get(o[s],e+"queueHooks"),n&&n.empty&&(r++,n.empty.add(a));return a(),i.promise(t)}});var R,M,W=/[\t\r\n\f]/g,$=/\r/g,B=/^(?:input|select|textarea|button)$/i;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[x.propFix[e]||e]})},addClass:function(e){var t,n,r,i,o,s=0,a=this.length,u="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,s=0,a=this.length,u=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,i=0,o=x(this),s=e.match(w)||[];while(t=s[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===r||"boolean"===n)&&(this.className&&q.set(this,"__className__",this.className),this.className=this.className||e===!1?"":q.get(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(W," ").indexOf(t)>=0)return!0;return!1},val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=x.isFunction(e),this.each(function(n){var i;1===this.nodeType&&(i=r?e.call(this,n,x(this).val()):e,null==i?i="":"number"==typeof i?i+="":x.isArray(i)&&(i=x.map(i,function(e){return null==e?"":e+""})),t=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&t.set(this,i,"value")!==undefined||(this.value=i))});if(i)return t=x.valHooks[i.type]||x.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&(n=t.get(i,"value"))!==undefined?n:(n=i.value,"string"==typeof n?n.replace($,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,s=o?null:[],a=o?i+1:r.length,u=0>i?a:o?i:0;for(;a>u;u++)if(n=r[u],!(!n.selected&&u!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),s=i.length;while(s--)r=i[s],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,t,n){var i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===r?x.prop(e,t,n):(1===s&&x.isXMLDoc(e)||(t=t.toLowerCase(),i=x.attrHooks[t]||(x.expr.match.bool.test(t)?M:R)),n===undefined?i&&"get"in i&&null!==(o=i.get(e,t))?o:(o=x.find.attr(e,t),null==o?undefined:o):null!==n?i&&"set"in i&&(o=i.set(e,n,t))!==undefined?o:(e.setAttribute(t,n+""),n):(x.removeAttr(e,t),undefined))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)&&(e[r]=!1),e.removeAttribute(n)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,t,n){var r,i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return o=1!==s||!x.isXMLDoc(e),o&&(t=x.propFix[t]||t,i=x.propHooks[t]),n!==undefined?i&&"set"in i&&(r=i.set(e,n,t))!==undefined?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){return e.hasAttribute("tabindex")||B.test(e.nodeName)||e.href?e.tabIndex:-1}}}}),M={set:function(e,t,n){return t===!1?x.removeAttr(e,n):e.setAttribute(n,n),n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,t){var n=x.expr.attrHandle[t]||x.find.attr;x.expr.attrHandle[t]=function(e,t,r){var i=x.expr.attrHandle[t],o=r?undefined:(x.expr.attrHandle[t]=undefined)!=n(e,t,r)?t.toLowerCase():null;return x.expr.attrHandle[t]=i,o}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,t){return x.isArray(t)?e.checked=x.inArray(x(e).val(),t)>=0:undefined}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var I=/^key/,z=/^(?:mouse|contextmenu)|click/,_=/^(?:focusinfocus|focusoutblur)$/,X=/^([^.]*)(?:\.(.+)|)$/;function U(){return!0}function Y(){return!1}function V(){try{return o.activeElement}catch(e){}}x.event={global:{},add:function(e,t,n,i,o){var s,a,u,l,c,p,f,h,d,g,m,y=q.get(e);if(y){n.handler&&(s=n,n=s.handler,o=s.selector),n.guid||(n.guid=x.guid++),(l=y.events)||(l=y.events={}),(a=y.handle)||(a=y.handle=function(e){return typeof x===r||e&&x.event.triggered===e.type?undefined:x.event.dispatch.apply(a.elem,arguments)},a.elem=e),t=(t||"").match(w)||[""],c=t.length;while(c--)u=X.exec(t[c])||[],d=m=u[1],g=(u[2]||"").split(".").sort(),d&&(f=x.event.special[d]||{},d=(o?f.delegateType:f.bindType)||d,f=x.event.special[d]||{},p=x.extend({type:d,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&x.expr.match.needsContext.test(o),namespace:g.join(".")},s),(h=l[d])||(h=l[d]=[],h.delegateCount=0,f.setup&&f.setup.call(e,i,g,a)!==!1||e.addEventListener&&e.addEventListener(d,a,!1)),f.add&&(f.add.call(e,p),p.handler.guid||(p.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,p):h.push(p),x.event.global[d]=!0);e=null}},remove:function(e,t,n,r,i){var o,s,a,u,l,c,p,f,h,d,g,m=q.hasData(e)&&q.get(e);if(m&&(u=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(a=X.exec(t[l])||[],h=g=a[1],d=(a[2]||"").split(".").sort(),h){p=x.event.special[h]||{},h=(r?p.delegateType:p.bindType)||h,f=u[h]||[],a=a[2]&&RegExp("(^|\\.)"+d.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=f.length;while(o--)c=f[o],!i&&g!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(f.splice(o,1),c.selector&&f.delegateCount--,p.remove&&p.remove.call(e,c));s&&!f.length&&(p.teardown&&p.teardown.call(e,d,m.handle)!==!1||x.removeEvent(e,h,m.handle),delete u[h])}else for(h in u)x.event.remove(e,h+t[l],n,r,!0);x.isEmptyObject(u)&&(delete m.handle,q.remove(e,"events"))}},trigger:function(t,n,r,i){var s,a,u,l,c,p,f,h=[r||o],d=y.call(t,"type")?t.type:t,g=y.call(t,"namespace")?t.namespace.split("."):[];if(a=u=r=r||o,3!==r.nodeType&&8!==r.nodeType&&!_.test(d+x.event.triggered)&&(d.indexOf(".")>=0&&(g=d.split("."),d=g.shift(),g.sort()),c=0>d.indexOf(":")&&"on"+d,t=t[x.expando]?t:new x.Event(d,"object"==typeof t&&t),t.isTrigger=i?2:3,t.namespace=g.join("."),t.namespace_re=t.namespace?RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=undefined,t.target||(t.target=r),n=null==n?[t]:x.makeArray(n,[t]),f=x.event.special[d]||{},i||!f.trigger||f.trigger.apply(r,n)!==!1)){if(!i&&!f.noBubble&&!x.isWindow(r)){for(l=f.delegateType||d,_.test(l+d)||(a=a.parentNode);a;a=a.parentNode)h.push(a),u=a;u===(r.ownerDocument||o)&&h.push(u.defaultView||u.parentWindow||e)}s=0;while((a=h[s++])&&!t.isPropagationStopped())t.type=s>1?l:f.bindType||d,p=(q.get(a,"events")||{})[t.type]&&q.get(a,"handle"),p&&p.apply(a,n),p=c&&a[c],p&&x.acceptData(a)&&p.apply&&p.apply(a,n)===!1&&t.preventDefault();return t.type=d,i||t.isDefaultPrevented()||f._default&&f._default.apply(h.pop(),n)!==!1||!x.acceptData(r)||c&&x.isFunction(r[d])&&!x.isWindow(r)&&(u=r[c],u&&(r[c]=null),x.event.triggered=d,r[d](),x.event.triggered=undefined,u&&(r[c]=u)),t.result}},dispatch:function(e){e=x.event.fix(e);var t,n,r,i,o,s=[],a=d.call(arguments),u=(q.get(this,"events")||{})[e.type]||[],l=x.event.special[e.type]||{};if(a[0]=e,e.delegateTarget=this,!l.preDispatch||l.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),t=0;while((i=s[t++])&&!e.isPropagationStopped()){e.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(o.namespace))&&(e.handleObj=o,e.data=o.data,r=((x.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,a),r!==undefined&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return l.postDispatch&&l.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!==this;u=u.parentNode||this)if(u.disabled!==!0||"click"!==e.type){for(r=[],n=0;a>n;n++)o=t[n],i=o.selector+" ",r[i]===undefined&&(r[i]=o.needsContext?x(i,this).index(u)>=0:x.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return t.length>a&&s.push({elem:this,handlers:t.slice(a)}),s},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,t){var n,r,i,s=t.button;return null==e.pageX&&null!=t.clientX&&(n=e.target.ownerDocument||o,r=n.documentElement,i=n.body,e.pageX=t.clientX+(r&&r.scrollLeft||i&&i.scrollLeft||0)-(r&&r.clientLeft||i&&i.clientLeft||0),e.pageY=t.clientY+(r&&r.scrollTop||i&&i.scrollTop||0)-(r&&r.clientTop||i&&i.clientTop||0)),e.which||s===undefined||(e.which=1&s?1:2&s?3:4&s?2:0),e}},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,s=e,a=this.fixHooks[i];a||(this.fixHooks[i]=a=z.test(i)?this.mouseHooks:I.test(i)?this.keyHooks:{}),r=a.props?this.props.concat(a.props):this.props,e=new x.Event(s),t=r.length;while(t--)n=r[t],e[n]=s[n];return e.target||(e.target=o),3===e.target.nodeType&&(e.target=e.target.parentNode),a.filter?a.filter(e,s):e},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==V()&&this.focus?(this.focus(),!1):undefined},delegateType:"focusin"},blur:{trigger:function(){return this===V()&&this.blur?(this.blur(),!1):undefined},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&x.nodeName(this,"input")?(this.click(),!1):undefined},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==undefined&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)},x.Event=function(e,t){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.getPreventDefault&&e.getPreventDefault()?U:Y):this.type=e,t&&x.extend(this,t),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,undefined):new x.Event(e,t)},x.Event.prototype={isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=U,e&&e.preventDefault&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=U,e&&e.stopPropagation&&e.stopPropagation()},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=U,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,t,n,r,i){var o,s;if("object"==typeof e){"string"!=typeof t&&(n=n||t,t=undefined);for(s in e)this.on(s,t,n,e[s],i);return this}if(null==n&&null==r?(r=t,n=t=undefined):null==r&&("string"==typeof t?(r=n,n=undefined):(r=n,n=t,t=undefined)),r===!1)r=Y;else if(!r)return this;return 1===i&&(o=r,r=function(e){return x().off(e),o.apply(this,arguments)},r.guid=o.guid||(o.guid=x.guid++)),this.each(function(){x.event.add(this,e,r,n,t)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,x(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return(t===!1||"function"==typeof t)&&(n=t,t=undefined),n===!1&&(n=Y),this.each(function(){x.event.remove(this,e,n,t)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];return n?x.event.trigger(e,t,n,!0):undefined}});var G=/^.[^:#\[\.,]*$/,J=/^(?:parents|prev(?:Until|All))/,Q=x.expr.match.needsContext,K={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t=x(e,this),n=t.length;return this.filter(function(){var e=0;for(;n>e;e++)if(x.contains(this,t[e]))return!0})},not:function(e){return this.pushStack(et(this,e||[],!0))},filter:function(e){return this.pushStack(et(this,e||[],!1))},is:function(e){return!!et(this,"string"==typeof e&&Q.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],s=Q.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(s?s.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?g.call(x(e),this[0]):g.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function Z(e,t){while((e=e[t])&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return Z(e,"nextSibling")},prev:function(e){return Z(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return e.contentDocument||x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(K[e]||x.unique(i),J.test(e)&&i.reverse()),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,t,n){var r=[],i=n!==undefined;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&x(e).is(n))break;r.push(e)}return r},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function et(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(G.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return g.call(t,e)>=0!==n})}var tt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,nt=/<([\w:]+)/,rt=/<|&#?\w+;/,it=/<(?:script|style|link)/i,ot=/^(?:checkbox|radio)$/i,st=/checked\s*(?:[^=]|=\s*.checked.)/i,at=/^$|\/(?:java|ecma)script/i,ut=/^true\/(.*)/,lt=/^\s*\s*$/g,ct={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ct.optgroup=ct.option,ct.tbody=ct.tfoot=ct.colgroup=ct.caption=ct.thead,ct.th=ct.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===undefined?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(mt(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&dt(mt(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++)1===e.nodeType&&(x.cleanData(mt(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var t=this[0]||{},n=0,r=this.length;if(e===undefined&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!it.test(e)&&!ct[(nt.exec(e)||["",""])[1].toLowerCase()]){e=e.replace(tt,"<$1>");try{for(;r>n;n++)t=this[n]||{},1===t.nodeType&&(x.cleanData(mt(t,!1)),t.innerHTML=e);t=0}catch(i){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=f.apply([],e);var r,i,o,s,a,u,l=0,c=this.length,p=this,h=c-1,d=e[0],g=x.isFunction(d);if(g||!(1>=c||"string"!=typeof d||x.support.checkClone)&&st.test(d))return this.each(function(r){var i=p.eq(r);g&&(e[0]=d.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(r=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),i=r.firstChild,1===r.childNodes.length&&(r=i),i)){for(o=x.map(mt(r,"script"),ft),s=o.length;c>l;l++)a=r,l!==h&&(a=x.clone(a,!0,!0),s&&x.merge(o,mt(a,"script"))),t.call(this[l],a,l);if(s)for(u=o[o.length-1].ownerDocument,x.map(o,ht),l=0;s>l;l++)a=o[l],at.test(a.type||"")&&!q.access(a,"globalEval")&&x.contains(u,a)&&(a.src?x._evalUrl(a.src):x.globalEval(a.textContent.replace(lt,"")))}return this}}),x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=[],i=x(e),o=i.length-1,s=0;for(;o>=s;s++)n=s===o?this:this.clone(!0),x(i[s])[t](n),h.apply(r,n.get());return this.pushStack(r)}}),x.extend({clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=x.contains(e.ownerDocument,e);if(!(x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(s=mt(a),o=mt(e),r=0,i=o.length;i>r;r++)yt(o[r],s[r]);if(t)if(n)for(o=o||mt(e),s=s||mt(a),r=0,i=o.length;i>r;r++)gt(o[r],s[r]);else gt(e,a);return s=mt(a,"script"),s.length>0&&dt(s,!u&&mt(e,"script")),a},buildFragment:function(e,t,n,r){var i,o,s,a,u,l,c=0,p=e.length,f=t.createDocumentFragment(),h=[];for(;p>c;c++)if(i=e[c],i||0===i)if("object"===x.type(i))x.merge(h,i.nodeType?[i]:i);else if(rt.test(i)){o=o||f.appendChild(t.createElement("div")),s=(nt.exec(i)||["",""])[1].toLowerCase(),a=ct[s]||ct._default,o.innerHTML=a[1]+i.replace(tt,"<$1>")+a[2],l=a[0];while(l--)o=o.lastChild;x.merge(h,o.childNodes),o=f.firstChild,o.textContent=""}else h.push(t.createTextNode(i));f.textContent="",c=0;while(i=h[c++])if((!r||-1===x.inArray(i,r))&&(u=x.contains(i.ownerDocument,i),o=mt(f.appendChild(i),"script"),u&&dt(o),n)){l=0;while(i=o[l++])at.test(i.type||"")&&n.push(i)}return f},cleanData:function(e){var t,n,r,i,o,s,a=x.event.special,u=0;for(;(n=e[u])!==undefined;u++){if(F.accepts(n)&&(o=n[q.expando],o&&(t=q.cache[o]))){if(r=Object.keys(t.events||{}),r.length)for(s=0;(i=r[s])!==undefined;s++)a[i]?x.event.remove(n,i):x.removeEvent(n,i,t.handle);q.cache[o]&&delete q.cache[o]}delete L.cache[n[L.expando]]}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}});function pt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ft(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function ht(e){var t=ut.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function dt(e,t){var n=e.length,r=0;for(;n>r;r++)q.set(e[r],"globalEval",!t||q.get(t[r],"globalEval"))}function gt(e,t){var n,r,i,o,s,a,u,l;if(1===t.nodeType){if(q.hasData(e)&&(o=q.access(e),s=q.set(t,o),l=o.events)){delete s.handle,s.events={};for(i in l)for(n=0,r=l[i].length;r>n;n++)x.event.add(t,i,l[i][n])}L.hasData(e)&&(a=L.access(e),u=x.extend({},a),L.set(t,u))}}function mt(e,t){var n=e.getElementsByTagName?e.getElementsByTagName(t||"*"):e.querySelectorAll?e.querySelectorAll(t||"*"):[];return t===undefined||t&&x.nodeName(e,t)?x.merge([e],n):n}function yt(e,t){var n=t.nodeName.toLowerCase();"input"===n&&ot.test(e.type)?t.checked=e.checked:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}x.fn.extend({wrapAll:function(e){var t;return x.isFunction(e)?this.each(function(t){x(this).wrapAll(e.call(this,t))}):(this[0]&&(t=x(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this)},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var vt,xt,bt=/^(none|table(?!-c[ea]).+)/,wt=/^margin/,Tt=RegExp("^("+b+")(.*)$","i"),Ct=RegExp("^("+b+")(?!px)[a-z%]+$","i"),kt=RegExp("^([+-])=("+b+")","i"),Nt={BODY:"block"},Et={position:"absolute",visibility:"hidden",display:"block"},St={letterSpacing:0,fontWeight:400},jt=["Top","Right","Bottom","Left"],Dt=["Webkit","O","Moz","ms"];function At(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=Dt.length;while(i--)if(t=Dt[i]+n,t in e)return t;return r}function Lt(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function qt(t){return e.getComputedStyle(t,null)}function Ht(e,t){var n,r,i,o=[],s=0,a=e.length;for(;a>s;s++)r=e[s],r.style&&(o[s]=q.get(r,"olddisplay"),n=r.style.display,t?(o[s]||"none"!==n||(r.style.display=""),""===r.style.display&&Lt(r)&&(o[s]=q.access(r,"olddisplay",Rt(r.nodeName)))):o[s]||(i=Lt(r),(n&&"none"!==n||!i)&&q.set(r,"olddisplay",i?n:x.css(r,"display"))));for(s=0;a>s;s++)r=e[s],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[s]||"":"none"));return e}x.fn.extend({css:function(e,t){return x.access(this,function(e,t,n){var r,i,o={},s=0;if(x.isArray(t)){for(r=qt(e),i=t.length;i>s;s++)o[t[s]]=x.css(e,t[s],!1,r);return o}return n!==undefined?x.style(e,t,n):x.css(e,t)},e,t,arguments.length>1)},show:function(){return Ht(this,!0)},hide:function(){return Ht(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){Lt(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=vt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=x.camelCase(t),u=e.style;return t=x.cssProps[a]||(x.cssProps[a]=At(u,a)),s=x.cssHooks[t]||x.cssHooks[a],n===undefined?s&&"get"in s&&(i=s.get(e,!1,r))!==undefined?i:u[t]:(o=typeof n,"string"===o&&(i=kt.exec(n))&&(n=(i[1]+1)*i[2]+parseFloat(x.css(e,t)),o="number"),null==n||"number"===o&&isNaN(n)||("number"!==o||x.cssNumber[a]||(n+="px"),x.support.clearCloneStyle||""!==n||0!==t.indexOf("background")||(u[t]="inherit"),s&&"set"in s&&(n=s.set(e,n,r))===undefined||(u[t]=n)),undefined)}},css:function(e,t,n,r){var i,o,s,a=x.camelCase(t);return t=x.cssProps[a]||(x.cssProps[a]=At(e.style,a)),s=x.cssHooks[t]||x.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),i===undefined&&(i=vt(e,t,r)),"normal"===i&&t in St&&(i=St[t]),""===n||n?(o=parseFloat(i),n===!0||x.isNumeric(o)?o||0:i):i}}),vt=function(e,t,n){var r,i,o,s=n||qt(e),a=s?s.getPropertyValue(t)||s[t]:undefined,u=e.style;return s&&(""!==a||x.contains(e.ownerDocument,e)||(a=x.style(e,t)),Ct.test(a)&&wt.test(t)&&(r=u.width,i=u.minWidth,o=u.maxWidth,u.minWidth=u.maxWidth=u.width=a,a=s.width,u.width=r,u.minWidth=i,u.maxWidth=o)),a};function Ot(e,t,n){var r=Tt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function Ft(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;for(;4>o;o+=2)"margin"===n&&(s+=x.css(e,n+jt[o],!0,i)),r?("content"===n&&(s-=x.css(e,"padding"+jt[o],!0,i)),"margin"!==n&&(s-=x.css(e,"border"+jt[o]+"Width",!0,i))):(s+=x.css(e,"padding"+jt[o],!0,i),"padding"!==n&&(s+=x.css(e,"border"+jt[o]+"Width",!0,i)));return s}function Pt(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=qt(e),s=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=vt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Ct.test(i))return i;r=s&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+Ft(e,t,n||(s?"border":"content"),r,o)+"px"}function Rt(e){var t=o,n=Nt[e];return n||(n=Mt(e,t),"none"!==n&&n||(xt=(xt||x("