diff --git a/CHANGELOG.md b/CHANGELOG.md
index 4dff18dd67b5277c060ab2df7ffb8e0725eb78bb..547218c2a2430f34900a8db688dcf9d22e5fe4fc 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,32 @@
+2.0.0.0-dev60
+=============
+* Fixed bugs:
+  * Fixed an issue with exceeding the memory limit when uploading very big images
+  * Fixed an issue in moving a category when $afterCategoryId is null
+  * Fixed an issue when products from a non-default website were not available as bundle items
+  * Fixed an issue when orders placed via Authorize.net had the wrong statuses
+  * Fixed an issue where orders placed via PayPal Express Checkout could not be placed if HTTPS was used on the frontend
+  * Fixed a security issue with a user session during registration
+  * Removed a CSRF vulnerability in checkout
+  * Fixed an issue with JavaScript static testing framework not handling corrupted paths in white/black lists properly
+  * Fixed an issue with Google Shopping synchronization
+  * Fixed the contextual help tooltip design
+  * Fixed an issue with the Authorize.net CC section UI on the Onepage Checkout page
+  * Fixed UI issues on the order pages in the backend
+  * Fixed UI issues in the backend for IE9
+  * Fixed UI issues on the Edit Customer page in the backend
+  * Fixed a UI issue with the image preview placeholder on the Edit Product page for IE9
+  * Fixed UI issues with forms in the backend
+  * Fixed UI issues with buttons in the backend
+  * Fixed an issue with a product status after a virtual product was duplicated
+  * Fixed a fatal error with attribute file from the customer account page in the backend
+  * Fixed a security issue when CURLOPT_SSL_VERIFYPEER and CURLOPT_SSL_VERIFYHOST where used with improper values sometimes
+  * Updated the field descriptions for Secure Base URL settings in the backend
+  * Fixed an issue in product duplication for multiple store views
+  * Consolidated several 3rd-party JavaScript libraries in the pub/lib directory, and fixed license notice texts to conform to the open source license requirements
+* Service Layer implementation:
+  * Implemented the initial set of services for the Customer module
+
 2.0.0.0-dev59
 =============
 * Fixed bugs:
@@ -103,6 +132,10 @@
   * Fixed date resetting to 1 Jan 1970 after saving a design change in the admin panel in case date format is DD/MM/YY
   * Fixed CAPTCHA on multi-address checkout flow
   * Fixed view files population tool
+  * Fixed DHL functionality of generation shipping labels
+  * Fixed target rule if it is applied for specific customer segment
+  * Fixed product importing that cleared price and weight
+  * Fixed fatal error when a file reference is added to HTML head
 * GitHub requests:
   * [#122](https://github.com/magento/magento2/pull/122) -- Added support of federal units of Brazil with 27 states
   * [#184](https://github.com/magento/magento2/issues/184) -- Removed unused blocks and methods in Magento_Wishlist module
diff --git a/app/code/Magento/Authorizenet/Model/Directpost/Observer.php b/app/code/Magento/Authorizenet/Model/Directpost/Observer.php
index a9091ad238770b4db0e217bfc653031ff5651880..3933a7ce5802d354afa42f2a27610ba7812dc681 100644
--- a/app/code/Magento/Authorizenet/Model/Directpost/Observer.php
+++ b/app/code/Magento/Authorizenet/Model/Directpost/Observer.php
@@ -57,9 +57,9 @@ class Observer
     protected $_authorizenetData;
 
     /**
-     * @var \Magento\Authorizenet\Model\DirectpostFactory
+     * @var \Magento\Authorizenet\Model\Directpost
      */
-    protected $_modelFactory;
+    protected $_payment;
 
     /**
      * @var \Magento\Authorizenet\Model\Directpost\Session
@@ -75,7 +75,7 @@ class Observer
      * @param \Magento\Authorizenet\Helper\Data $authorizenetData
      * @param \Magento\Core\Helper\Data $coreData
      * @param \Magento\Core\Model\Registry $coreRegistry
-     * @param \Magento\Authorizenet\Model\DirectpostFactory $modelFactory
+     * @param \Magento\Authorizenet\Model\Directpost $payment
      * @param \Magento\Authorizenet\Model\Directpost\Session $session
      * @param \Magento\Core\Model\StoreManagerInterface $storeManager
      */
@@ -83,14 +83,14 @@ class Observer
         \Magento\Authorizenet\Helper\Data $authorizenetData,
         \Magento\Core\Helper\Data $coreData,
         \Magento\Core\Model\Registry $coreRegistry,
-        \Magento\Authorizenet\Model\DirectpostFactory $modelFactory,
+        \Magento\Authorizenet\Model\Directpost $payment,
         \Magento\Authorizenet\Model\Directpost\Session $session,
         \Magento\Core\Model\StoreManagerInterface $storeManager
     ) {
         $this->_coreRegistry = $coreRegistry;
         $this->_authorizenetData = $authorizenetData;
         $this->_coreData = $coreData;
-        $this->_modelFactory = $modelFactory;
+        $this->_payment = $payment;
         $this->_session = $session;
         $this->_storeManager = $storeManager;
     }
@@ -123,9 +123,11 @@ class Observer
 
         if ($order && $order->getId()) {
             $payment = $order->getPayment();
-            if ($payment && $payment->getMethod() == $this->_modelFactory->create()->getCode()) {
-                $request = $observer->getEvent()->getRequest();
-                $response = $observer->getEvent()->getResponse();
+            if ($payment && $payment->getMethod() == $this->_payment->getCode()) {
+                /** @var \Magento\Checkout\Controller\Action $controller */
+                $controller = $observer->getEvent()->getData('controller_action');
+                $request = $controller->getRequest();
+                $response = $controller->getResponse();
                 $result = $this->_coreData->jsonDecode($response->getBody('default'));
 
                 if (empty($result['error'])) {
diff --git a/app/code/Magento/Backend/App/Response/Http/FileFactory.php b/app/code/Magento/Backend/App/Response/Http/FileFactory.php
index bdd5467f3eea403e0d0880f2f7d62bb6b19ac704..1d31691362280c1cfb59d95849c3742847b7d3ce 100644
--- a/app/code/Magento/Backend/App/Response/Http/FileFactory.php
+++ b/app/code/Magento/Backend/App/Response/Http/FileFactory.php
@@ -104,15 +104,21 @@ class FileFactory extends \Magento\App\Response\Http\FileFactory
      * @param string $fileName
      * @param string|array $content set to null to avoid starting output, $contentLength should be set explicitly in
      * that case
+     * @param string $baseDir
      * @param string $contentType
      * @param int $contentLength    explicit content length, if strlen($content) isn't applicable
      * @return \Magento\App\ResponseInterface
      */
-    public function create($fileName, $content, $contentType = 'application/octet-stream', $contentLength = null)
-    {
+    public function create(
+        $fileName,
+        $content,
+        $baseDir = \Magento\Filesystem::ROOT,
+        $contentType = 'application/octet-stream',
+        $contentLength = null
+    ) {
         if ($this->_auth->getAuthStorage()->isFirstPageAfterLogin()) {
             return $this->_redirect($this->_backendUrl->getStartupPageUrl());
         }
-        return parent::create($fileName, $content, $contentType, $contentLength);
+        return parent::create($fileName, $content, $baseDir, $contentType, $contentLength);
     }
 }
diff --git a/app/code/Magento/Backend/Block/Widget/Grid/Column/Renderer/Currency.php b/app/code/Magento/Backend/Block/Widget/Grid/Column/Renderer/Currency.php
index 8f7f5c740d4782464931bd1118c06116236391ea..d27929d23a4736d1fe474264b4fdf961fed230b8 100644
--- a/app/code/Magento/Backend/Block/Widget/Grid/Column/Renderer/Currency.php
+++ b/app/code/Magento/Backend/Block/Widget/Grid/Column/Renderer/Currency.php
@@ -63,21 +63,30 @@ class Currency
      */
     protected $_currencyLocator;
 
+    /**
+     * @var \Magento\Directory\Model\Currency
+     */
+    protected $_baseCurrency;
+
     /**
      * @param \Magento\Backend\Block\Context $context
      * @param \Magento\Core\Model\StoreManagerInterface $storeManager
      * @param \Magento\Directory\Model\Currency\DefaultLocator $currencyLocator
+     * @param \Magento\Directory\Model\CurrencyFactory $currencyFactory
      * @param array $data
      */
     public function __construct(
         \Magento\Backend\Block\Context $context,
         \Magento\Core\Model\StoreManagerInterface $storeManager,
         \Magento\Directory\Model\Currency\DefaultLocator $currencyLocator,
+        \Magento\Directory\Model\CurrencyFactory $currencyFactory,
         array $data = array()
     ) {
         parent::__construct($context, $data);
         $this->_storeManager = $storeManager;
         $this->_currencyLocator = $currencyLocator;
+        $baseCurrencyCode = $this->_app->getBaseCurrencyCode();
+        $this->_baseCurrency = $currencyFactory->create()->load($baseCurrencyCode);
     }
 
     /**
@@ -131,7 +140,7 @@ class Currency
         if ($rate = $row->getData($this->getColumn()->getRateField())) {
             return floatval($rate);
         }
-        return $this->_storeManager->getStore()->getBaseCurrency()->getRate($this->_getCurrencyCode($row));
+        return $this->_baseCurrency->getRate($this->_getCurrencyCode($row));
     }
 
     /**
diff --git a/app/code/Magento/Backend/Controller/Adminhtml/System/Config.php b/app/code/Magento/Backend/Controller/Adminhtml/System/Config.php
index 87dc52fe4cf44566df64c01f24fbf09cd6c93679..f52eeafb16267372aef95844497d2d3774132f81 100644
--- a/app/code/Magento/Backend/Controller/Adminhtml/System/Config.php
+++ b/app/code/Magento/Backend/Controller/Adminhtml/System/Config.php
@@ -132,6 +132,6 @@ class Config extends \Magento\Backend\Controller\Adminhtml\System\AbstractConfig
         }
         $gridBlock->setWebsiteId($website->getId())->setConditionName($conditionName);
         $content = $gridBlock->getCsvFile();
-        return $this->_fileFactory->create($fileName, $content);
+        return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
     }
 }
diff --git a/app/code/Magento/Backend/etc/adminhtml/system.xml b/app/code/Magento/Backend/etc/adminhtml/system.xml
index 116468e20ffd92b0aca0ef6818a07da5e9957f3d..51b94714722eeda27321f430e61df074691c6557 100644
--- a/app/code/Magento/Backend/etc/adminhtml/system.xml
+++ b/app/code/Magento/Backend/etc/adminhtml/system.xml
@@ -551,7 +551,7 @@
             </group>
             <group id="secure" translate="label" type="text" sortOrder="20" showInDefault="1" showInWebsite="1" showInStore="1">
                 <label>Base URLs (Secure)</label>
-                <comment>Any of the fields allow fully qualified URLs that end with '/' (slash) e.g. http://example.com/magento/</comment>
+                <comment>Any of the fields allow fully qualified URLs that end with '/' (slash) e.g. https://example.com/magento/</comment>
                 <field id="base_url" translate="label comment" type="text" sortOrder="10" showInDefault="1" showInWebsite="1" showInStore="1">
                     <label>Secure Base URL</label>
                     <backend_model>Magento\Backend\Model\Config\Backend\Baseurl</backend_model>
@@ -586,11 +586,13 @@
                     <label>Use Secure URLs in Frontend</label>
                     <source_model>Magento\Backend\Model\Config\Source\Yesno</source_model>
                     <backend_model>Magento\Backend\Model\Config\Backend\Secure</backend_model>
+                    <comment>Enter https protocol to use Secure URLs in Frontend.</comment>
                 </field>
                 <field id="use_in_adminhtml" translate="label" type="select" sortOrder="60" showInDefault="1" showInWebsite="0" showInStore="0">
                     <label>Use Secure URLs in Admin</label>
                     <source_model>Magento\Backend\Model\Config\Source\Yesno</source_model>
                     <backend_model>Magento\Backend\Model\Config\Backend\Secure</backend_model>
+                    <comment>Enter https protocol to use Secure URLs in Admin.</comment>
                 </field>
                 <field id="offloader_header" translate="label" type="text" sortOrder="70" showInDefault="1" showInWebsite="0" showInStore="0">
                     <label>Offloader header</label>
diff --git a/app/code/Magento/Backend/view/adminhtml/admin/login.phtml b/app/code/Magento/Backend/view/adminhtml/admin/login.phtml
index 870740c2c7d1dcb535e31e11b1f08f2f9bb7f6d0..6ab6f9a707dc23fbdde47047d217d52ba138ac54 100644
--- a/app/code/Magento/Backend/view/adminhtml/admin/login.phtml
+++ b/app/code/Magento/Backend/view/adminhtml/admin/login.phtml
@@ -26,7 +26,6 @@
 ?>
 <!doctype html>
 <html lang="en">
-
 <head>
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     <title><?php echo __('Log into Magento Admin Page') ?></title>
@@ -38,10 +37,12 @@
     <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('mui/base.css') ?>" media="all" />
     <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('mui/elements.css') ?>" media="all" />
     <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('mui/form.css') ?>" media="all" />
-    <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('css/styles.css') ?>" media="all" />
+    <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('css/admin.css') ?>" media="all" />
+    <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('css/header.css') ?>" media="all" />
+    <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('css/pages.css') ?>" media="all" />
+    <?php /* <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('css/styles.css') ?>" media="all" /> */?>
     <link rel="stylesheet" href="<?php echo $this->getViewFileUrl('mui/utils.css') ?>" media="all" />
 
-
     <script src="<?php echo $this->getViewFileUrl('jquery/jquery.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('mage/jquery-no-conflict.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('jquery/jquery-ui.js') ?>"></script>
@@ -55,9 +56,9 @@
     <script src="<?php echo $this->getViewFileUrl('prototype/prototype.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('scriptaculous/effects.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('mage/captcha.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('lib/modernizr.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('js/head.js') ?>"></script>
-
+    <script src="<?php echo $this->getViewFileUrl('modernizr/modernizr.js') ?>"></script>
+    <script src="<?php echo $this->getViewFileUrl('headjs/head.min.js') ?>"></script>
+</head>
 <body id="page-login" class="page-login" onload="document.forms['login-form'].username.focus();">
     <div class="wrapper">
         <div class="wrapper-inner">
diff --git a/app/code/Magento/Backend/view/adminhtml/layout/default.xml b/app/code/Magento/Backend/view/adminhtml/layout/default.xml
index 2617de104d60a57b35fa944584d1c408c9746ad8..6ac8380a4c0c8fb0ac9db59a8284f3fad672abfd 100644
--- a/app/code/Magento/Backend/view/adminhtml/layout/default.xml
+++ b/app/code/Magento/Backend/view/adminhtml/layout/default.xml
@@ -46,7 +46,7 @@
             </block>
             <block class="Magento\Theme\Block\Html\Head\Script" name="head-load-min-js">
                 <arguments>
-                    <argument name="file" xsi:type="string">head.load.min.js</argument>
+                    <argument name="file" xsi:type="string">headjs/head.load.min.js</argument>
                 </arguments>
             </block>
             <block class="Magento\Theme\Block\Html\Head\Script" name="underscore-js">
@@ -300,4 +300,4 @@
         </block>
         <container name="before_body_end" as="before_body_end" label="Before Body End"/>
     </block>
-</layout>
\ No newline at end of file
+</layout>
diff --git a/app/code/Magento/Backend/view/adminhtml/layout/editor.xml b/app/code/Magento/Backend/view/adminhtml/layout/editor.xml
index c3b4b1594a8d0534a285e6f16f1f44bfef97dcc7..da3199561ac85f8984225f9fb06c8d758c44b093 100644
--- a/app/code/Magento/Backend/view/adminhtml/layout/editor.xml
+++ b/app/code/Magento/Backend/view/adminhtml/layout/editor.xml
@@ -40,7 +40,7 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="lib-flex-js">
             <arguments>
-                <argument name="file" xsi:type="string">lib/flex.js</argument>
+                <argument name="file" xsi:type="string">mage/flex.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="lib-fabridge-js">
diff --git a/app/code/Magento/Backup/Controller/Adminhtml/Index.php b/app/code/Magento/Backup/Controller/Adminhtml/Index.php
index 55e5ab38d71a89608e48b30ed7f46b94661ea2dc..7eaac4b66cdd891eb41f9b240b43b2d7fcfad2ce 100644
--- a/app/code/Magento/Backup/Controller/Adminhtml/Index.php
+++ b/app/code/Magento/Backup/Controller/Adminhtml/Index.php
@@ -212,7 +212,13 @@ class Index extends \Magento\Backend\App\Action
         $fileName = $this->_objectManager->get('Magento\Backup\Helper\Data')
             ->generateBackupDownloadName($backup);
 
-        $response = $this->_fileFactory->create($fileName, null, 'application/octet-stream', $backup->getSize());
+        $response = $this->_fileFactory->create(
+            $fileName,
+            null,
+            \Magento\Filesystem::VAR_DIR,
+            'application/octet-stream',
+            $backup->getSize()
+        );
 
         $response->sendHeaders();
 
diff --git a/app/code/Magento/Bundle/Block/Adminhtml/Catalog/Product/Edit/Tab/Bundle/Option/Search/Grid.php b/app/code/Magento/Bundle/Block/Adminhtml/Catalog/Product/Edit/Tab/Bundle/Option/Search/Grid.php
index 145af9ddf9f3009605c0cacb27649625a5cd2390..e16dc110396acbd01aeec50465d2137299c7b7ac 100644
--- a/app/code/Magento/Bundle/Block/Adminhtml/Catalog/Product/Edit/Tab/Bundle/Option/Search/Grid.php
+++ b/app/code/Magento/Bundle/Block/Adminhtml/Catalog/Product/Edit/Tab/Bundle/Option/Search/Grid.php
@@ -115,7 +115,6 @@ class Grid
     {
         $collection = $this->_productFactory->create()->getCollection()
             ->setOrder('id')
-            ->setStore($this->getStore())
             ->addAttributeToSelect('name')
             ->addAttributeToSelect('sku')
             ->addAttributeToSelect('price')
@@ -123,7 +122,7 @@ class Grid
             ->addAttributeToFilter('entity_id', array('nin' => $this->_getSelectedProducts()))
             ->addAttributeToFilter('type_id', array('in' => $this->getAllowedSelectionTypes()))
             ->addFilterByRequiredOptions()
-            ->addStoreFilter();
+            ->addStoreFilter(\Magento\Core\Model\Store::DEFAULT_STORE_ID);
 
         if ($this->getFirstShow()) {
             $collection->addIdFilter('-1');
@@ -169,8 +168,6 @@ class Grid
             'header'    => __('Price'),
             'align'     => 'center',
             'type'      => 'currency',
-            'currency_code' => $this->getStore()->getCurrentCurrencyCode(),
-            'rate'      => $this->getStore()->getBaseCurrency()->getRate($this->getStore()->getCurrentCurrencyCode()),
             'index'     => 'price',
             'header_css_class'=> 'col-price',
             'column_css_class'=> 'col-price'
@@ -208,11 +205,6 @@ class Grid
         }
     }
 
-    public function getStore()
-    {
-        return $this->_storeManager->getStore();
-    }
-
     /**
      * Retrieve array of allowed product types for bundle selection product
      *
diff --git a/app/code/Magento/Catalog/Block/Adminhtml/Product/Grid.php b/app/code/Magento/Catalog/Block/Adminhtml/Product/Grid.php
index c62e6b71d6ea3bf86be1f1b93db08bf9879d8724..ace24f16369238a9a67c7c6ce1c8990d42c6e800 100644
--- a/app/code/Magento/Catalog/Block/Adminhtml/Product/Grid.php
+++ b/app/code/Magento/Catalog/Block/Adminhtml/Product/Grid.php
@@ -135,15 +135,18 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
             ->addAttributeToSelect('sku')
             ->addAttributeToSelect('name')
             ->addAttributeToSelect('attribute_set_id')
-            ->addAttributeToSelect('type_id');
+            ->addAttributeToSelect('type_id')
+            ->setStore($store);
 
         if ($this->_catalogData->isModuleEnabled('Magento_CatalogInventory')) {
-            $collection->joinField('qty',
+            $collection->joinField(
+                'qty',
                 'cataloginventory_stock_item',
                 'qty',
                 'product_id=entity_id',
                 '{{table}}.stock_id=1',
-                'left');
+                'left'
+            );
         }
         if ($store->getId()) {
             //$collection->setStoreId($store->getId());
@@ -188,8 +191,7 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'left',
                 $store->getId()
             );
-        }
-        else {
+        } else {
             $collection->addAttributeToSelect('price');
             $collection->joinAttribute('status', 'catalog_product/status', 'entity_id', null, 'inner');
             $collection->joinAttribute('visibility', 'catalog_product/visibility', 'entity_id', null, 'inner');
@@ -206,12 +208,14 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
     {
         if ($this->getCollection()) {
             if ($column->getId() == 'websites') {
-                $this->getCollection()->joinField('websites',
+                $this->getCollection()->joinField(
+                    'websites',
                     'catalog_product_website',
                     'website_id',
                     'product_id=entity_id',
                     null,
-                    'left');
+                    'left'
+                );
             }
         }
         return parent::_addColumnFilterToCollection($column);
@@ -219,7 +223,8 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
 
     protected function _prepareColumns()
     {
-        $this->addColumn('entity_id',
+        $this->addColumn(
+            'entity_id',
             array(
                 'header'=> __('ID'),
                 'width' => '50px',
@@ -227,28 +232,34 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'index' => 'entity_id',
                 'header_css_class'  => 'col-id',
                 'column_css_class'  => 'col-id'
-        ));
-        $this->addColumn('name',
+            )
+        );
+        $this->addColumn(
+            'name',
             array(
                 'header'=> __('Name'),
                 'index' => 'name',
                 'class' => 'xxx',
                 'header_css_class'  => 'col-name',
                 'column_css_class'  => 'col-name'
-        ));
+            )
+        );
 
         $store = $this->_getStore();
         if ($store->getId()) {
-            $this->addColumn('custom_name',
+            $this->addColumn(
+                'custom_name',
                 array(
                     'header'=> __('Name in %1', $store->getName()),
                     'index' => 'custom_name',
                     'header_css_class'  => 'col-name',
                     'column_css_class'  => 'col-name'
-            ));
+                )
+            );
         }
 
-        $this->addColumn('type',
+        $this->addColumn(
+            'type',
             array(
                 'header'=> __('Type'),
                 'width' => '60px',
@@ -257,14 +268,16 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'options' => $this->_type->getOptionArray(),
                 'header_css_class'  => 'col-type',
                 'column_css_class'  => 'col-type'
-        ));
+            )
+        );
 
         $sets = $this->_setsFactory->create()
             ->setEntityTypeFilter($this->_productFactory->create()->getResource()->getTypeId())
             ->load()
             ->toOptionHash();
 
-        $this->addColumn('set_name',
+        $this->addColumn(
+            'set_name',
             array(
                 'header'=> __('Attribute Set'),
                 'width' => '100px',
@@ -273,19 +286,23 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'options' => $sets,
                 'header_css_class'  => 'col-attr-name',
                 'column_css_class'  => 'col-attr-name'
-        ));
+            )
+        );
 
-        $this->addColumn('sku',
+        $this->addColumn(
+            'sku',
             array(
                 'header'=> __('SKU'),
                 'width' => '80px',
                 'index' => 'sku',
                 'header_css_class'  => 'col-sku',
                 'column_css_class'  => 'col-sku'
-        ));
+            )
+        );
 
         $store = $this->_getStore();
-        $this->addColumn('price',
+        $this->addColumn(
+            'price',
             array(
                 'header'=> __('Price'),
                 'type'  => 'price',
@@ -293,10 +310,12 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'index' => 'price',
                 'header_css_class'  => 'col-price',
                 'column_css_class'  => 'col-price'
-        ));
+            )
+        );
 
         if ($this->_catalogData->isModuleEnabled('Magento_CatalogInventory')) {
-            $this->addColumn('qty',
+            $this->addColumn(
+                'qty',
                 array(
                     'header'=> __('Quantity'),
                     'width' => '100px',
@@ -304,10 +323,12 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                     'index' => 'qty',
                     'header_css_class'  => 'col-qty',
                     'column_css_class'  => 'col-qty'
-            ));
+                )
+            );
         }
 
-        $this->addColumn('visibility',
+        $this->addColumn(
+            'visibility',
             array(
                 'header'=> __('Visibility'),
                 'width' => '70px',
@@ -316,9 +337,11 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'options' => $this->_visibility->getOptionArray(),
                 'header_css_class'  => 'col-visibility',
                 'column_css_class'  => 'col-visibility'
-        ));
+            )
+        );
 
-        $this->addColumn('status',
+        $this->addColumn(
+            'status',
             array(
                 'header'=> __('Status'),
                 'width' => '70px',
@@ -327,10 +350,12 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'options' => $this->_status->getOptionArray(),
                 'header_css_class'  => 'col-status',
                 'column_css_class'  => 'col-status'
-        ));
+            )
+        );
 
         if (!$this->_storeManager->isSingleStoreMode()) {
-            $this->addColumn('websites',
+            $this->addColumn(
+                'websites',
                 array(
                     'header'=> __('Websites'),
                     'width' => '100px',
@@ -340,10 +365,12 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                     'options'   => $this->_websiteFactory->create()->getCollection()->toOptionHash(),
                     'header_css_class'  => 'col-websites',
                     'column_css_class'  => 'col-websites'
-            ));
+                )
+            );
         }
 
-        $this->addColumn('edit',
+        $this->addColumn(
+            'edit',
             array(
                 'header'    => __('Edit'),
                 'width'     => '50px',
@@ -364,7 +391,8 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
                 'index'     => 'stores',
                 'header_css_class'  => 'col-action',
                 'column_css_class'  => 'col-action'
-        ));
+            )
+        );
 
         if ($this->_catalogData->isModuleEnabled('Magento_Rss')) {
             $this->addRssList('rss/catalog/notifystock', __('Notify Low Stock RSS'));
@@ -402,7 +430,7 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
              )
         ));
 
-        if ($this->_authorization->isAllowed('Magento_Catalog::update_attributes')){
+        if ($this->_authorization->isAllowed('Magento_Catalog::update_attributes')) {
             $this->getMassactionBlock()->addItem('attributes', array(
                 'label' => __('Update Attributes'),
                 'url'   => $this->getUrl('catalog/product_action_attribute/edit', array('_current'=>true))
@@ -420,9 +448,12 @@ class Grid extends \Magento\Backend\Block\Widget\Grid\Extended
 
     public function getRowUrl($row)
     {
-        return $this->getUrl('catalog/*/edit', array(
-            'store'=>$this->getRequest()->getParam('store'),
-            'id'=>$row->getId())
+        return $this->getUrl(
+            'catalog/*/edit',
+            array(
+                'store'=>$this->getRequest()->getParam('store'),
+                'id'=>$row->getId()
+            )
         );
     }
 }
diff --git a/app/code/Magento/Catalog/Model/Category.php b/app/code/Magento/Catalog/Model/Category.php
index abc1bf0c2ef8bf2222e72c7ff063a3ab42d83d72..857a2c412eedd2ceb21f596d99f6f06588fc04a4 100644
--- a/app/code/Magento/Catalog/Model/Category.php
+++ b/app/code/Magento/Catalog/Model/Category.php
@@ -291,7 +291,7 @@ class Category extends \Magento\Catalog\Model\AbstractModel
      * Move category
      *
      * @param   int $parentId new parent category id
-     * @param   int $afterCategoryId category id after which we have put current category
+     * @param   null|int $afterCategoryId category id after which we have put current category
      * @return  \Magento\Catalog\Model\Category
      * @throws \Magento\Core\Exception|\Exception
      */
diff --git a/app/code/Magento/Catalog/Model/Product.php b/app/code/Magento/Catalog/Model/Product.php
index 63e0bae368b224ad28fe1b0e60af1583c799d21a..c1516b3bf3d49b715483a81aff701f64aa528aae 100644
--- a/app/code/Magento/Catalog/Model/Product.php
+++ b/app/code/Magento/Catalog/Model/Product.php
@@ -241,7 +241,7 @@ class Product extends \Magento\Catalog\Model\AbstractModel
      * @param \Magento\Data\CollectionFactory $collectionFactory
      * @param \Magento\Filesystem $filesystem
      * @param array $data
-     * 
+     *
      * @SuppressWarnings(PHPMD.ExcessiveParameterList)
      */
     public function __construct(
@@ -1184,7 +1184,7 @@ class Product extends \Magento\Catalog\Model\AbstractModel
             ->setCreatedAt(null)
             ->setUpdatedAt(null)
             ->setId(null)
-            ->setStoreId($this->_storeManager->getStore()->getId());
+            ->setStoreId(\Magento\Core\Model\Store::DEFAULT_STORE_ID);
 
         $this->_eventManager->dispatch(
             'catalog_model_product_duplicate',
diff --git a/app/code/Magento/Catalog/Model/Resource/Category.php b/app/code/Magento/Catalog/Model/Resource/Category.php
index 48fa74ffe6b9c5ecb84d3d18b70116353f45ac3c..6ad68ce9e380887a2beaf5abbab8f5f7de57a05e 100644
--- a/app/code/Magento/Catalog/Model/Resource/Category.php
+++ b/app/code/Magento/Catalog/Model/Resource/Category.php
@@ -920,32 +920,19 @@ class Category extends \Magento\Catalog\Model\Resource\AbstractResource
                 ->from($table, 'position')
                 ->where('entity_id = :entity_id');
             $position = $adapter->fetchOne($select, array('entity_id' => $afterCategoryId));
-
-            $bind = array(
-                'position' => new \Zend_Db_Expr($positionField . ' + 1')
-            );
-            $where = array(
-                'parent_id = ?' => $newParent->getId(),
-                $positionField . ' > ?' => $position
-            );
-            $adapter->update($table, $bind, $where);
-        } elseif ($afterCategoryId !== null) {
-            $position = 0;
-            $bind = array(
-                'position' => new \Zend_Db_Expr($positionField . ' + 1')
-            );
-            $where = array(
-                'parent_id = ?' => $newParent->getId(),
-                $positionField . ' > ?' => $position
-            );
-            $adapter->update($table, $bind, $where);
+            $position += 1;
         } else {
-            $select = $adapter->select()
-                ->from($table, array('position' => new \Zend_Db_Expr('MIN(' . $positionField . ')')))
-                ->where('parent_id = :parent_id');
-            $position = $adapter->fetchOne($select, array('parent_id' => $newParent->getId()));
+            $position = 1;
         }
-        $position += 1;
+
+        $bind = array(
+            'position' => new \Zend_Db_Expr($positionField . ' + 1')
+        );
+        $where = array(
+            'parent_id = ?' => $newParent->getId(),
+            $positionField . ' >= ?' => $position
+        );
+        $adapter->update($table, $bind, $where);
 
         return $position;
     }
diff --git a/app/code/Magento/Checkout/Controller/Onepage.php b/app/code/Magento/Checkout/Controller/Onepage.php
index 10389798c247d855b44839f4e31a8875a207d58c..5e0eb30d8633782c8b8c8e7dd51127ff39f9a0ae 100644
--- a/app/code/Magento/Checkout/Controller/Onepage.php
+++ b/app/code/Magento/Checkout/Controller/Onepage.php
@@ -52,17 +52,25 @@ class Onepage extends \Magento\Checkout\Controller\Action
      */
     protected $_coreRegistry = null;
 
+    /**
+     * @var \Magento\Core\App\Action\FormKeyValidator
+     */
+    protected $_formKeyValidator;
+
     /**
      * @param \Magento\App\Action\Context $context
      * @param \Magento\Customer\Model\Session $customerSession
      * @param \Magento\Core\Model\Registry $coreRegistry
+     * @param \Magento\Core\App\Action\FormKeyValidator $formKeyValidator
      */
     public function __construct(
         \Magento\App\Action\Context $context,
         \Magento\Customer\Model\Session $customerSession,
-        \Magento\Core\Model\Registry $coreRegistry
+        \Magento\Core\Model\Registry $coreRegistry,
+        \Magento\Core\App\Action\FormKeyValidator $formKeyValidator
     ) {
         $this->_coreRegistry = $coreRegistry;
+        $this->_formKeyValidator = $formKeyValidator;
         parent::__construct($context, $customerSession);
     }
 
@@ -534,6 +542,11 @@ class Onepage extends \Magento\Checkout\Controller\Action
      */
     public function saveOrderAction()
     {
+        if (!$this->_formKeyValidator->validate($this->getRequest())) {
+            $this->_redirect('*/*/');
+            return;
+        }
+
         if ($this->_expireAjax()) {
             return;
         }
diff --git a/app/code/Magento/Checkout/view/frontend/onepage/payment.phtml b/app/code/Magento/Checkout/view/frontend/onepage/payment.phtml
index 07d27b92b3395ce1eed728162dc89b05bc65f626..1ac3170f3c5b5e0f03be0907f1508f7dd0d426ab 100644
--- a/app/code/Magento/Checkout/view/frontend/onepage/payment.phtml
+++ b/app/code/Magento/Checkout/view/frontend/onepage/payment.phtml
@@ -23,6 +23,7 @@
  */
 ?>
 <form id="co-payment-form" class="form payments">
+    <?php echo $this->getBlockHtml('formkey') ?>
     <fieldset class="fieldset">
         <?php echo $this->getChildChildHtml('methods_additional') ?>
         <div id="checkout-payment-method-load"><?php echo $this->getChildHtml('methods') ?></div>
diff --git a/app/code/Magento/Core/Model/App.php b/app/code/Magento/Core/Model/App.php
index 57bede32828d2459c0f8b145e6ce9d29d149bc16..ccc76fe963684eb77b68196e4c9d6029e983cac6 100644
--- a/app/code/Magento/Core/Model/App.php
+++ b/app/code/Magento/Core/Model/App.php
@@ -53,7 +53,7 @@ class App implements \Magento\Core\Model\AppInterface
     /**
      * Magento version
      */
-    const VERSION = '2.0.0.0-dev59';
+    const VERSION = '2.0.0.0-dev60';
 
 
     /**
@@ -804,7 +804,7 @@ class App implements \Magento\Core\Model\AppInterface
             'revision'  => '0',
             'patch'     => '0',
             'stability' => 'dev',
-            'number'    => '59',
+            'number'    => '60',
         );
     }
 }
diff --git a/app/code/Magento/Core/view/adminhtml/prototype/magento.css b/app/code/Magento/Core/view/adminhtml/prototype/magento.css
index e0e01a343585dd9995771b59684d1114cba73cb0..602c127772f365d991cff3b037e91dfcb035a8d1 100644
--- a/app/code/Magento/Core/view/adminhtml/prototype/magento.css
+++ b/app/code/Magento/Core/view/adminhtml/prototype/magento.css
@@ -171,8 +171,8 @@
 .popup-window .page-actions {
     padding: 0;
     position: absolute;
-    right: 19px;
-    top: 29px;
+    right: 43px;
+    top: 30px;
     z-index: 2;
 }
 
@@ -185,90 +185,6 @@
     margin: 5px 0 0;
 }
 
-/*
-    Styles for tables in popup window
--------------------------------------- */
-
-.popup-window .data {
-    border-collapse: inherit; /* do not remove this! without this rule in FF when table has only 1 row bottom and side borders disappear */
-    width: 100%;
-}
-
-.popup-window .grid .data {
-    border-left: 1px solid #c0bbaf;
-    border-right: 1px solid #c0bbaf;
-}
-
-.popup-window .grid .data td:first-child {
-    border-left-width: 0;
-}
-
-.popup-window .grid .data td:last-child {
-    border-left-width: 0;
-    border-right-width: 0;
-}
-
-.popup-window .grid .data tr:last-child td {
-    border-bottom-color: #c0bbaf;
-}
-
-.popup-window .grid tr.headings th,
-.popup-window .grid tr.filter th {
-    background: #fff;
-    border-color: #c9c2b8;
-    border-width: 0 0 1px;
-    color: #666;
-    padding: 3px 7px;
-}
-
-.popup-window .grid tr.headings th a {
-    color: #666;
-}
-
-.popup-window .data tr.headings th:hover > span {
-    border-color: #cac2b5;
-}
-
-.popup-window .grid tr.headings th a:after {
-    color: #dbd6ce;
-}
-
-.popup-window .grid tr.headings th a:hover:after {
-    color: #cac2b5;
-}
-
-.popup-window .grid .filter input.input-text,
-.popup-window .grid .filter select {
-    background: #fff;
-    border: 1px solid #ccc;
-    color: #666;
-}
-
-.popup-window .grid tr th:first-child {
-    border: 0;
-}
-
-.popup-window .grid tbody tr:first-child td {
-    border-top: 1px solid #eae8e4;
-}
-
-.popup-window .grid tbody tr td,
-.popup-window .grid tbody tr td:hover {
-    border-bottom: 1px solid #eae8e4;
-    padding: 3px 7px;
-}
-
-.popup-window .grid tbody tr:nth-child(odd) td,
-.popup-window .grid tbody tr:nth-child(odd):hover td {
-    background: #fbfaf6;
-}
-
-.popup-window .grid tr.on-mouse td,
-.popup-window .grid table tbody tr.on-mouse:hover td,
-.popup-window .grid table tbody tr.on-mouse:nth-child(odd):hover td {
-    background-color: #f3efea;
-}
-
 .popup-window .data .col-id {
     width: 35px;
 }
@@ -325,6 +241,10 @@
     margin: 0 5px 0 0;
 }
 
+.magento_message #contents-uploader {
+    margin: 0 0 18px;
+}
+
 .magento_message .fileinput-button {
     display: inline-block;
     cursor: pointer;
@@ -332,6 +252,18 @@
     vertical-align: middle;
 }
 
+.magento_message .fileinput-button span {
+    display: none;
+}
+
+.magento_message .fileinput-button input {
+    position: static;
+    border: none;
+    opacity: 1;
+    filter: alpha(opacity=1);
+    -moz-transform: none;
+}
+
 .magento_message .file-row {
     background: #fff;
     border: 1px solid #cac2b5;
@@ -422,7 +354,8 @@
 
 .ui-dialog .ui-dialog-title {
     color: #676056;
-    font: normal 20px/1 'CallunaSans';
+    font-size: 20px;
+    line-height: 1;
     display: block;
     padding: 19px 0 19px 20px;
     cursor: move;
@@ -464,10 +397,6 @@
     border: none;
 }
 
-.ui-dialog .ui-dialog-content {
-    padding: 10px 10px 0;
-}
-
 .ui-dialog .ui-dialog-content .fieldset {
     border-radius: 0;
     border: none;
@@ -475,7 +404,7 @@
 
 .ui-dialog .ui-dialog-content {
     overflow: auto;
-    padding: 25px 25px 0;
+    padding: 25px 25px 20px;
 }
 
 .ui-dialog .ui-dialog-content label.mage-error {
@@ -489,7 +418,7 @@
 
 .ui-dialog .ui-dialog-buttonpane {
     margin: 0;
-    padding: 25px;
+    padding: 0 25px 25px;
     border: none;
 }
 
diff --git a/app/code/Magento/Customer/Block/Adminhtml/Form/Element/File.php b/app/code/Magento/Customer/Block/Adminhtml/Form/Element/File.php
index 16efc3174897d09f696fa004850cbb0ccb6ac5c4..78309d6b9d3cc2db63eae84059fa06b5c29ecc9e 100644
--- a/app/code/Magento/Customer/Block/Adminhtml/Form/Element/File.php
+++ b/app/code/Magento/Customer/Block/Adminhtml/Form/Element/File.php
@@ -194,7 +194,7 @@ class File extends \Magento\Data\Form\Element\AbstractElement
     protected function _getPreviewUrl()
     {
         return $this->_adminhtmlData->getUrl('customer/index/viewfile', array(
-            'file' => $this->_escaper->urlEncode($this->getValue()),
+            'file' => $this->_adminhtmlData->urlEncode($this->getValue()),
         ));
     }
 
diff --git a/app/code/Magento/Customer/Block/Adminhtml/Grid/Renderer/Multiaction.php b/app/code/Magento/Customer/Block/Adminhtml/Grid/Renderer/Multiaction.php
index ba91bb791fbd7a97132aaf7210e9d8c160235e3c..d56732b70273932a7877d1e19158674a0c736da0 100644
--- a/app/code/Magento/Customer/Block/Adminhtml/Grid/Renderer/Multiaction.php
+++ b/app/code/Magento/Customer/Block/Adminhtml/Grid/Renderer/Multiaction.php
@@ -71,7 +71,7 @@ class Multiaction
      *
      * @param  array $action
      * @param  \Magento\Object $row
-     * @return string
+     * @return bool|string
      */
     protected function _toLinkHtml($action, \Magento\Object $row)
     {
@@ -81,12 +81,10 @@ class Multiaction
             if ($product->canConfigure()) {
                 $style = '';
                 $onClick = sprintf('onclick="return %s.configureItem(%s)"', $action['control_object'], $row->getId());
+                return sprintf('<a href="%s" %s %s>%s</a>', $action['url'], $style, $onClick, $action['caption']);
             } else {
-                $style = 'style="color: #CCC;"';
-                $onClick = '';
+                return false;
             }
-
-            return sprintf('<a href="%s" %s %s>%s</a>', $action['url'], $style, $onClick, $action['caption']);
         } else {
             return parent::_toLinkHtml($action, $row);
         }
diff --git a/app/code/Magento/Customer/Controller/Adminhtml/Index.php b/app/code/Magento/Customer/Controller/Adminhtml/Index.php
index 59ef90046cd89a3c22ccb96ad4d1f8bdc990f549..fa3cbeada28de9f770b55e3c28ebbf3aa32ba916 100644
--- a/app/code/Magento/Customer/Controller/Adminhtml/Index.php
+++ b/app/code/Magento/Customer/Controller/Adminhtml/Index.php
@@ -472,7 +472,7 @@ class Index extends \Magento\Backend\App\Action
         $fileName = 'customers.csv';
         $content = $this->_view->getLayout()->createBlock('Magento\Customer\Block\Adminhtml\Grid')->getCsvFile();
 
-        return $this->_fileFactory->create($fileName, $content);
+        return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -482,7 +482,7 @@ class Index extends \Magento\Backend\App\Action
     {
         $fileName = 'customers.xml';
         $content = $this->_view->getLayout()->createBlock('Magento\Customer\Block\Adminhtml\Grid')->getExcelFile();
-        return $this->_fileFactory->create($fileName, $content);
+        return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -851,8 +851,8 @@ class Index extends \Magento\Backend\App\Action
 
         /** @var \Magento\Filesystem $filesystem */
         $filesystem = $this->_objectManager->get('Magento\Filesystem');
-        $directory = $filesystem->getDirectoryRead(\Magento\Filesystem:: MEDIA);
-        $fileName = 'customer/' . $file;
+        $directory = $filesystem->getDirectoryRead(\Magento\Filesystem::MEDIA);
+        $fileName = 'customer' . '/' . ltrim($file, '/');
         $path = $directory->getAbsolutePath($fileName);
         if (!$directory->isFile($fileName)
             && !$this->_objectManager->get('Magento\Core\Helper\File\Storage')
@@ -877,7 +877,7 @@ class Index extends \Magento\Backend\App\Action
                     $contentType = 'application/octet-stream';
                     break;
             }
-            $stat = $directory->stat($fileName);
+            $stat = $directory->stat($path);
             $contentLength = $stat['size'];
             $contentModify = $stat['mtime'];
 
@@ -893,10 +893,14 @@ class Index extends \Magento\Backend\App\Action
             echo $directory->readFile($fileName);
         } else {
             $name = pathinfo($path, PATHINFO_BASENAME);
-            $this->_fileFactory->create($name, array(
-                'type'  => 'filename',
-                'value' => $fileName
-            ))->sendResponse();
+            $this->_fileFactory->create(
+                $name,
+                array(
+                    'type'  => 'filename',
+                    'value' => $fileName
+                ),
+                \Magento\Filesystem::MEDIA
+            )->sendResponse();
         }
 
         exit();
diff --git a/app/code/Magento/Customer/Model/Address.php b/app/code/Magento/Customer/Model/Address.php
index 5c717ae04860cf7d8852a2079200882f39120029..4165b79e5662bb0743a6f81fec5fa59e3f4d709c 100644
--- a/app/code/Magento/Customer/Model/Address.php
+++ b/app/code/Magento/Customer/Model/Address.php
@@ -160,7 +160,7 @@ class Address extends \Magento\Customer\Model\Address\AbstractAddress
     /**
      * Retrieve address entity attributes
      *
-     * @return array
+     * @return \Magento\Customer\Model\Attribute[]
      */
     public function getAttributes()
     {
@@ -174,6 +174,16 @@ class Address extends \Magento\Customer\Model\Address\AbstractAddress
         return $attributes;
     }
 
+    /**
+     * Get attributes created by default
+     *
+     * @return string[]
+     */
+    public function getDefaultAttributeCodes()
+    {
+        return $this->_getResource()->getDefaultAttributes();
+    }
+
     public function __clone()
     {
         $this->setId(null);
diff --git a/app/code/Magento/Customer/Model/Converter.php b/app/code/Magento/Customer/Model/Converter.php
new file mode 100644
index 0000000000000000000000000000000000000000..a3f039a7fc27c3f76d2412e73f3086e2ca9ca4aa
--- /dev/null
+++ b/app/code/Magento/Customer/Model/Converter.php
@@ -0,0 +1,165 @@
+<?php
+/**
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Model;
+
+use Magento\Customer\Service\Entity\V1\Exception;
+use Magento\Customer\Service\V1\CustomerMetadataServiceInterface;
+
+/**
+ * Customer Model converter.
+ *
+ * Converts a Customer Model to a DTO.
+ *
+ * TODO: Remove this class after service refactoring is done and the model
+ * TODO: is no longer needed outside of service.  Then this function could
+ * TODO: be moved to the service.
+ */
+class Converter
+{
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\CustomerBuilder
+     */
+    protected $_customerBuilder;
+
+    /**
+     * @var CustomerFactory
+     */
+    protected $_customerFactory;
+
+    /**
+     * @param CustomerFactory $customerFactory
+     * @param \Magento\Customer\Service\V1\Dto\CustomerBuilder $customerBuilder
+     */
+    public function __construct(
+        \Magento\Customer\Service\V1\Dto\CustomerBuilder $customerBuilder,
+        \Magento\Customer\Model\CustomerFactory $customerFactory
+    ) {
+        $this->_customerBuilder = $customerBuilder;
+        $this->_customerFactory = $customerFactory;
+    }
+
+    /**
+     * Convert a customer model to a customer entity
+     *
+     * @param \Magento\Customer\Model\Customer $customerModel
+     * @throws \InvalidArgumentException
+     * @return \Magento\Customer\Service\V1\Dto\Customer
+     */
+    public function createCustomerFromModel($customerModel)
+    {
+        if (!($customerModel instanceof \Magento\Customer\Model\Customer)) {
+            throw new \InvalidArgumentException('customer model is invalid');
+        }
+        $this->_convertAttributesFromModel($this->_customerBuilder, $customerModel);
+        $this->_customerBuilder->setCustomerId($customerModel->getId());
+        $this->_customerBuilder->setFirstname($customerModel->getFirstname());
+        $this->_customerBuilder->setLastname($customerModel->getLastname());
+        $this->_customerBuilder->setEmail($customerModel->getEmail());
+        return $this->_customerBuilder->create();
+    }
+
+
+    /**
+     * @param int $customerId
+     * @throws Exception If customerId is not found or other error occurs.
+     * @return Customer
+     */
+    public function getCustomerModel($customerId)
+    {
+        try {
+            $customer = $this->_customerFactory->create()->load($customerId);
+        } catch (\Exception $e) {
+            throw new Exception($e->getMessage(), $e->getCode(), $e);
+        }
+
+        if (!$customer->getId()) {
+            // customer does not exist
+            throw new Exception(
+                'No customer with customerId ' . $customerId . ' exists.',
+                Exception::CODE_INVALID_CUSTOMER_ID
+            );
+        } else {
+            return $customer;
+        }
+    }
+
+
+    /**
+     * Creates a customer model from a customer entity.
+     *
+     * @param \Magento\Customer\Service\V1\Dto\Customer $customer
+     * @return Customer
+     */
+    public function createCustomerModel(\Magento\Customer\Service\V1\Dto\Customer $customer)
+    {
+        $customerModel = $this->_customerFactory->create();
+
+        $attributes = $customer->getAttributes();
+        foreach ($attributes as $attributeCode => $attributeValue) {
+            // avoid setting password through set attribute
+            if ($attributeCode == 'password') {
+                continue;
+            } else {
+                $customerModel->setData($attributeCode, $attributeValue);
+            }
+        }
+
+        $customerId = $customer->getCustomerId();
+        if ($customerId) {
+            $customerModel->setId($customerId);
+        }
+
+        // Need to use attribute set or future updates can cause data loss
+        if (!$customerModel->getAttributeSetId()) {
+            $customerModel->setAttributeSetId(CustomerMetadataServiceInterface::CUSTOMER_ATTRIBUTE_SET_ID);
+            return $customerModel;
+        }
+
+        return $customerModel;
+    }
+
+    /**
+     * Loads the values from a customer model
+     *
+     * @param \Magento\Customer\Service\V1\Dto\CustomerBuilder $customerBuilder
+     * @param \Magento\Customer\Model\Customer $customerModel
+     */
+    protected function _convertAttributesFromModel($customerBuilder, $customerModel)
+    {
+        $attributes = [];
+        foreach ($customerModel->getAttributes() as $attribute) {
+            $attrCode = $attribute->getAttributeCode();
+            $value = $customerModel->getData($attrCode);
+            if (null == $value) {
+                continue;
+            }
+            $attributes[$attrCode] = $value;
+        }
+
+        $customerBuilder->populateWithArray($attributes);
+    }
+
+}
diff --git a/app/code/Magento/Customer/Model/Customer.php b/app/code/Magento/Customer/Model/Customer.php
index f50926cd4c704c065ae45f6ea679b23fe21d71ce..ea8c6f2d5af197902915df67d4fc6c7c4f0822db 100644
--- a/app/code/Magento/Customer/Model/Customer.php
+++ b/app/code/Magento/Customer/Model/Customer.php
@@ -30,6 +30,7 @@ namespace Magento\Customer\Model;
  * Customer model
  *
  * @method int getWebsiteId() getWebsiteId()
+ * @method \Magento\Customer\Model\Customer setWebsiteId(int)
  * @method int getStoreId() getStoreId()
  * @method string getEmail() getEmail()
  * @method \Magento\Customer\Model\Resource\Customer _getResource()
@@ -170,14 +171,14 @@ class Customer extends \Magento\Core\Model\AbstractModel
     protected $_emailInfoFactory;
 
     /**
-     * @var \Magento\Customer\Model\GroupFactory
+     * @var \Magento\Customer\Model\AttributeFactory
      */
-    protected $_groupFactory;
+    protected $_attributeFactory;
 
     /**
-     * @var \Magento\Customer\Model\AttributeFactory
+     * @var \Magento\Customer\Service\V1\CustomerGroupServiceInterface
      */
-    protected $_attributeFactory;
+    protected $_groupService;
 
     /**
      * @var \Magento\Encryption\EncryptorInterface
@@ -208,7 +209,7 @@ class Customer extends \Magento\Core\Model\AbstractModel
      * @param \Magento\Customer\Model\Resource\Address\CollectionFactory $addressesFactory
      * @param \Magento\Email\Model\Template\MailerFactory $mailerFactory
      * @param \Magento\Email\Model\InfoFactory $emailInfoFactory
-     * @param \Magento\Customer\Model\GroupFactory $groupFactory
+     * @param \Magento\Customer\Service\V1\CustomerGroupServiceInterface $groupService
      * @param \Magento\Customer\Model\AttributeFactory $attributeFactory
      * @param \Magento\Encryption\EncryptorInterface $encryptor
      * @param \Magento\Math\Random $mathRandom
@@ -230,7 +231,7 @@ class Customer extends \Magento\Core\Model\AbstractModel
         \Magento\Customer\Model\Resource\Address\CollectionFactory $addressesFactory,
         \Magento\Email\Model\Template\MailerFactory $mailerFactory,
         \Magento\Email\Model\InfoFactory $emailInfoFactory,
-        \Magento\Customer\Model\GroupFactory $groupFactory,
+        \Magento\Customer\Service\V1\CustomerGroupServiceInterface $groupService,
         \Magento\Customer\Model\AttributeFactory $attributeFactory,
         \Magento\Encryption\EncryptorInterface $encryptor,
         \Magento\Math\Random $mathRandom,
@@ -248,7 +249,7 @@ class Customer extends \Magento\Core\Model\AbstractModel
         $this->_addressesFactory = $addressesFactory;
         $this->_mailerFactory = $mailerFactory;
         $this->_emailInfoFactory = $emailInfoFactory;
-        $this->_groupFactory = $groupFactory;
+        $this->_groupService = $groupService;
         $this->_attributeFactory = $attributeFactory;
         $this->_encryptor = $encryptor;
         $this->mathRandom = $mathRandom;
@@ -296,9 +297,9 @@ class Customer extends \Magento\Core\Model\AbstractModel
             );
         }
         $this->_eventManager->dispatch('customer_customer_authenticated', array(
-           'model'    => $this,
-           'password' => $password,
-        ));
+                'model'    => $this,
+                'password' => $password,
+            ));
 
         return true;
     }
@@ -445,14 +446,14 @@ class Customer extends \Magento\Core\Model\AbstractModel
     /**
      * Retrieve all customer attributes
      *
-     * @return array
+     * @return \Magento\Customer\Model\Attribute[]
      */
     public function getAttributes()
     {
         if ($this->_attributes === null) {
             $this->_attributes = $this->_getResource()
-            ->loadAllAttributes($this)
-            ->getSortedAttributes();
+                ->loadAllAttributes($this)
+                ->getSortedAttributes();
         }
         return $this->_attributes;
     }
@@ -821,7 +822,7 @@ class Customer extends \Magento\Core\Model\AbstractModel
     {
         if (!$this->hasData('group_id')) {
             $storeId = $this->getStoreId() ? $this->getStoreId() : $this->_storeManager->getStore()->getId();
-            $groupId = $this->_coreStoreConfig->getConfig(\Magento\Customer\Model\Group::XML_PATH_DEFAULT_ID, $storeId);
+            $groupId = $this->_groupService->getDefaultGroup($storeId)->getId();
             $this->setData('group_id', $groupId);
         }
         return $this->getData('group_id');
@@ -835,7 +836,8 @@ class Customer extends \Magento\Core\Model\AbstractModel
     public function getTaxClassId()
     {
         if (!$this->getData('tax_class_id')) {
-            $this->setTaxClassId($this->_createCustomerGroup()->getTaxClassId($this->getGroupId()));
+            $groupTaxClassId = $this->_groupService->getGroup($this->getGroupId())->getTaxClassId();
+            $this->setData('tax_class_id', $groupTaxClassId);
         }
         return $this->getData('tax_class_id');
     }
@@ -1256,14 +1258,6 @@ class Customer extends \Magento\Core\Model\AbstractModel
         return $this->_emailInfoFactory->create();
     }
 
-    /**
-     * @return \Magento\Customer\Model\Group
-     */
-    protected function _createCustomerGroup()
-    {
-        return $this->_groupFactory->create();
-    }
-
     /**
      * @return \Magento\Customer\Model\Attribute
      */
diff --git a/app/code/Magento/Customer/Model/Metadata/ElementFactory.php b/app/code/Magento/Customer/Model/Metadata/ElementFactory.php
new file mode 100644
index 0000000000000000000000000000000000000000..6c7b83f39c7458bb04b72d770bb1ba28cc1bf052
--- /dev/null
+++ b/app/code/Magento/Customer/Model/Metadata/ElementFactory.php
@@ -0,0 +1,91 @@
+<?php
+/**
+ * Customer Form Element Factory
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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    Magento
+ * @package     Magento_Customer
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Model\Metadata;
+
+class ElementFactory
+{
+    /**
+     * @var \Magento\ObjectManager
+     */
+    protected $_objectManager;
+
+    /**
+     * @var \Magento\Stdlib\String
+     */
+    protected $_string;
+
+    /**
+     * @param \Magento\ObjectManager $objectManager
+     * @param \Magento\Stdlib\String $string
+     */
+    public function __construct(\Magento\ObjectManager $objectManager, \Magento\Stdlib\String $string)
+    {
+        $this->_objectManager = $objectManager;
+        $this->_string = $string;
+    }
+
+    /**
+     * Create Form Element
+     *
+     * @param \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata $attribute
+     * @param $value
+     * @param $entityTypeCode
+     * @param bool $isAjax
+     * @return \Magento\Customer\Model\Metadata\Form\AbstractData
+     */
+    public function create(
+        \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata $attribute,
+        $value,
+        $entityTypeCode,
+        $isAjax = false
+    ) {
+        $dataModelClass = $attribute->getDataModel();
+        $params = [
+            'entityTypeCode' => $entityTypeCode,
+            'value' => is_null($value) ? false : $value,
+            'isAjax' => $isAjax,
+            'attribute' => $attribute
+        ];
+        /** TODO fix when Validation is implemented MAGETWO-17341 */
+        if ($dataModelClass == 'Magento\Customer\Model\Attribute\Data\Postcode') {
+            $dataModelClass = 'Magento\Customer\Model\Metadata\Form\Text';
+        }
+        if (!empty($dataModelClass)) {
+            $dataModel = $this->_objectManager->create($dataModelClass, $params);
+        } else {
+            $dataModelClass = sprintf(
+                'Magento\Customer\Model\Metadata\Form\%s',
+                $this->_string->upperCaseWords($attribute->getFrontendInput())
+            );
+            $dataModel = $this->_objectManager->create($dataModelClass, $params);
+        }
+
+        return $dataModel;
+    }
+}
diff --git a/app/code/Magento/Customer/Model/Metadata/Form/AbstractData.php b/app/code/Magento/Customer/Model/Metadata/Form/AbstractData.php
new file mode 100644
index 0000000000000000000000000000000000000000..2dde4619fea813693240a4fbf61f125dc6a77a07
--- /dev/null
+++ b/app/code/Magento/Customer/Model/Metadata/Form/AbstractData.php
@@ -0,0 +1,559 @@
+<?php
+/**
+ * Form Element Abstract Data Model
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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    Magento
+ * @package     Magento_Eav
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Model\Metadata\Form;
+
+abstract class AbstractData
+{
+    /**
+     * Request Scope name
+     *
+     * @var string
+     */
+    protected $_requestScope;
+
+    /**
+     * Scope visibility flag
+     *
+     * @var boolean
+     */
+    protected $_requestScopeOnly    = true;
+
+    /**
+     * Is AJAX request flag
+     *
+     * @var boolean
+     */
+    protected $_isAjax              = false;
+
+    /**
+     * Array of full extracted data
+     * Needed for depends attributes
+     *
+     * @var array
+     */
+    protected $_extractedData       = array();
+
+    /**
+     * \Magento\Core\Model\LocaleInterface FORMAT
+     *
+     * @var string
+     */
+    protected $_dateFilterFormat;
+
+    /**
+     * @var \Magento\Core\Model\LocaleInterface
+     */
+    protected $_locale;
+
+    /**
+     * @var \Magento\Logger
+     */
+    protected $_logger;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata
+     */
+    protected $_attribute;
+
+    /**
+     * @var string
+     */
+    protected $_value;
+
+    /** @var  string */
+    protected $_entityTypeCode;
+
+    /**
+     * @param \Magento\Core\Model\LocaleInterface $locale
+     * @param \Magento\Logger $logger
+     * @param \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata $attribute
+     * @param string $value
+     * @param $entityTypeCode
+     * @param bool $isAjax
+     */
+    public function __construct(
+        \Magento\Core\Model\LocaleInterface $locale,
+        \Magento\Logger $logger,
+        \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata $attribute,
+        $value = null,
+        $entityTypeCode,
+        $isAjax = false
+    ) {
+        $this->_locale = $locale;
+        $this->_logger = $logger;
+        $this->_attribute = $attribute;
+        $this->_value = $value;
+        $this->_entityTypeCode = $entityTypeCode;
+        $this->_isAjax = $isAjax;
+    }
+
+    /**
+     * Return Attribute instance
+     *
+     * @throws \Magento\Core\Exception
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata
+     */
+    public function getAttribute()
+    {
+        if (!$this->_attribute) {
+            throw new \Magento\Core\Exception(__('Attribute object is undefined'));
+        }
+        return $this->_attribute;
+    }
+
+    /**
+     * Set Request scope
+     *
+     * @param string $scope
+     * @return string
+     */
+    public function setRequestScope($scope)
+    {
+        $this->_requestScope = $scope;
+        return $this;
+    }
+
+    /**
+     * Set scope visibility
+     * Search value only in scope or search value in scope and global
+     *
+     * @param boolean $flag
+     * @return \Magento\Customer\Model\Metadata\Form\AbstractData
+     */
+    public function setRequestScopeOnly($flag)
+    {
+        $this->_requestScopeOnly = (bool)$flag;
+        return $this;
+    }
+
+    /**
+     * Returns entity instance
+     *
+     * @return \Magento\Customer\Service\V1\Dto\Eav\EntityInterface
+     */
+    public function getEntity()
+    {
+        if (!$this->_entity) {
+            throw new \Magento\Core\Exception(__('Entity object is undefined'));
+        }
+        return $this->_entity;
+    }
+
+    /**
+     * Set array of full extracted data
+     *
+     * @param array $data
+     * @return \Magento\Customer\Model\Metadata\Form\AbstractData
+     */
+    public function setExtractedData(array $data)
+    {
+        $this->_extractedData = $data;
+        return $this;
+    }
+
+    /**
+     * Return extracted data
+     *
+     * @param string $index
+     * @return mixed
+     */
+    public function getExtractedData($index = null)
+    {
+        if (!is_null($index)) {
+            if (isset($this->_extractedData[$index])) {
+                return $this->_extractedData[$index];
+            }
+            return null;
+        }
+        return $this->_extractedData;
+    }
+
+    /**
+     * Apply attribute input filter to value
+     *
+     * @param string $value
+     * @return string
+     */
+    protected function _applyInputFilter($value)
+    {
+        if ($value === false) {
+            return false;
+        }
+
+        $filter = $this->_getFormFilter();
+        if ($filter) {
+            $value = $filter->inputFilter($value);
+        }
+
+        return $value;
+    }
+
+    /**
+     * Return Data Form Input/Output Filter
+     *
+     * @return \Magento\Data\Form\Filter\FilterInterface|false
+     */
+    protected function _getFormFilter()
+    {
+        $filterCode = $this->getAttribute()->getInputFilter();
+        if ($filterCode) {
+            $filterClass = 'Magento\Data\Form\Filter\\' . ucfirst($filterCode);
+            if ($filterCode == 'date') {
+                $filter = new $filterClass($this->_dateFilterFormat(), $this->_locale->getLocale());
+            } else {
+                $filter = new $filterClass();
+            }
+            return $filter;
+        }
+        return false;
+    }
+
+    /**
+     * Get/Set/Reset date filter format
+     *
+     * @param string|null|false $format
+     * @return \Magento\Customer\Model\Metadata\Form\AbstractData|string
+     */
+    protected function _dateFilterFormat($format = null)
+    {
+        if (is_null($format)) {
+            // get format
+            if (is_null($this->_dateFilterFormat)) {
+                $this->_dateFilterFormat = \Magento\Core\Model\LocaleInterface::FORMAT_TYPE_SHORT;
+            }
+            return $this->_locale->getDateFormat($this->_dateFilterFormat);
+        } else if ($format === false) {
+            // reset value
+            $this->_dateFilterFormat = null;
+            return $this;
+        }
+
+        $this->_dateFilterFormat = $format;
+        return $this;
+    }
+
+    /**
+     * Apply attribute output filter to value
+     *
+     * @param string $value
+     * @return string
+     */
+    protected function _applyOutputFilter($value)
+    {
+        $filter = $this->_getFormFilter();
+        if ($filter) {
+            $value = $filter->outputFilter($value);
+        }
+
+        return $value;
+    }
+
+    /**
+     * Validate value by attribute input validation rule
+     *
+     * @param string $value
+     * @return string|bool
+     */
+    protected function _validateInputRule($value)
+    {
+        // skip validate empty value
+        if (empty($value)) {
+            return true;
+        }
+
+        $label         = $this->getAttribute()->getStoreLabel();
+        $validateRules = $this->getAttribute()->getValidationRules();
+
+        if (!empty($validateRules['input_validation'])) {
+            switch ($validateRules['input_validation']) {
+                case 'alphanumeric':
+                    $validator = new \Zend_Validate_Alnum(true);
+                    $validator->setMessage(
+                        __('"%1" invalid type entered.', $label),
+                        \Zend_Validate_Alnum::INVALID
+                    );
+                    $validator->setMessage(
+                        __('"%1" contains non-alphabetic or non-numeric characters.', $label),
+                        \Zend_Validate_Alnum::NOT_ALNUM
+                    );
+                    $validator->setMessage(
+                        __('"%1" is an empty string.', $label),
+                        \Zend_Validate_Alnum::STRING_EMPTY
+                    );
+                    if (!$validator->isValid($value)) {
+                        return $validator->getMessages();
+                    }
+                    break;
+                case 'numeric':
+                    $validator = new \Zend_Validate_Digits();
+                    $validator->setMessage(
+                        __('"%1" invalid type entered.', $label),
+                        \Zend_Validate_Digits::INVALID
+                    );
+                    $validator->setMessage(
+                        __('"%1" contains non-numeric characters.', $label),
+                        \Zend_Validate_Digits::NOT_DIGITS
+                    );
+                    $validator->setMessage(
+                        __('"%1" is an empty string.', $label),
+                        \Zend_Validate_Digits::STRING_EMPTY
+                    );
+                    if (!$validator->isValid($value)) {
+                        return $validator->getMessages();
+                    }
+                    break;
+                case 'alpha':
+                    $validator = new \Zend_Validate_Alpha(true);
+                    $validator->setMessage(
+                        __('"%1" invalid type entered.', $label),
+                        \Zend_Validate_Alpha::INVALID
+                    );
+                    $validator->setMessage(
+                        __('"%1" contains non-alphabetic characters.', $label),
+                        \Zend_Validate_Alpha::NOT_ALPHA
+                    );
+                    $validator->setMessage(
+                        __('"%1" is an empty string.', $label),
+                        \Zend_Validate_Alpha::STRING_EMPTY
+                    );
+                    if (!$validator->isValid($value)) {
+                        return $validator->getMessages();
+                    }
+                    break;
+                case 'email':
+        /**
+        __("'%value%' appears to be a DNS hostname but the given punycode notation cannot be decoded")
+        __("Invalid type given. String expected")
+        __("'%value%' appears to be a DNS hostname but contains a dash in an invalid position")
+        __("'%value%' does not match the expected structure for a DNS hostname")
+        __("'%value%' appears to be a DNS hostname but cannot match against hostname schema for TLD '%tld%'")
+        __("'%value%' does not appear to be a valid local network name")
+        __("'%value%' does not appear to be a valid URI hostname")
+        __("'%value%' appears to be an IP address, but IP addresses are not allowed")
+        __("'%value%' appears to be a local network name but local network names are not allowed")
+        __("'%value%' appears to be a DNS hostname but cannot extract TLD part")
+        __("'%value%' appears to be a DNS hostname but cannot match TLD against known list")
+        */
+                    $validator = new \Zend_Validate_EmailAddress();
+                    $validator->setMessage(
+                        __('"%1" invalid type entered.', $label),
+                        \Zend_Validate_EmailAddress::INVALID
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid email address.', $label),
+                        \Zend_Validate_EmailAddress::INVALID_FORMAT
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid hostname.', $label),
+                        \Zend_Validate_EmailAddress::INVALID_HOSTNAME
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid hostname.', $label),
+                        \Zend_Validate_EmailAddress::INVALID_MX_RECORD
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid hostname.', $label),
+                        \Zend_Validate_EmailAddress::INVALID_MX_RECORD
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid email address.', $label),
+                        \Zend_Validate_EmailAddress::DOT_ATOM
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid email address.', $label),
+                        \Zend_Validate_EmailAddress::QUOTED_STRING
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid email address.', $label),
+                        \Zend_Validate_EmailAddress::INVALID_LOCAL_PART
+                    );
+                    $validator->setMessage(
+                        __('"%1" exceeds the allowed length.', $label),
+                        \Zend_Validate_EmailAddress::LENGTH_EXCEEDED
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be an IP address, but IP addresses are not allowed."),
+                        \Zend_Validate_Hostname::IP_ADDRESS_NOT_ALLOWED
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a DNS hostname but cannot match TLD against known list."),
+                        \Zend_Validate_Hostname::UNKNOWN_TLD
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a DNS hostname but contains a dash in an invalid position."),
+                        \Zend_Validate_Hostname::INVALID_DASH
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a DNS hostname but cannot match against hostname schema for TLD '%tld%'."),
+                        \Zend_Validate_Hostname::INVALID_HOSTNAME_SCHEMA
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a DNS hostname but cannot extract TLD part."),
+                        \Zend_Validate_Hostname::UNDECIPHERABLE_TLD
+                    );
+                    $validator->setMessage(
+                        __("'%value%' does not appear to be a valid local network name."),
+                        \Zend_Validate_Hostname::INVALID_LOCAL_NAME
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a local network name but local network names are not allowed."),
+                        \Zend_Validate_Hostname::LOCAL_NAME_NOT_ALLOWED
+                    );
+                    $validator->setMessage(
+                        __("'%value%' appears to be a DNS hostname but the given punycode notation cannot be decoded."),
+                        \Zend_Validate_Hostname::CANNOT_DECODE_PUNYCODE
+                    );
+                    if (!$validator->isValid($value)) {
+                        return array_unique($validator->getMessages());
+                    }
+                    break;
+                case 'url':
+                    $parsedUrl = parse_url($value);
+                    if ($parsedUrl === false || empty($parsedUrl['scheme']) || empty($parsedUrl['host'])) {
+                        return array(__('"%1" is not a valid URL.', $label));
+                    }
+                    $validator = new \Zend_Validate_Hostname();
+                    if (!$validator->isValid($parsedUrl['host'])) {
+                        return array(__('"%1" is not a valid URL.', $label));
+                    }
+                    break;
+                case 'date':
+                    $validator = new \Zend_Validate_Date(\Magento\Stdlib\DateTime::DATE_INTERNAL_FORMAT);
+                    $validator->setMessage(
+                        __('"%1" invalid type entered.', $label),
+                        \Zend_Validate_Date::INVALID
+                    );
+                    $validator->setMessage(
+                        __('"%1" is not a valid date.', $label),
+                        \Zend_Validate_Date::INVALID_DATE
+                    );
+                    $validator->setMessage(
+                        __('"%1" does not fit the entered date format.', $label),
+                        \Zend_Validate_Date::FALSEFORMAT
+                    );
+                    if (!$validator->isValid($value)) {
+                       return array_unique($validator->getMessages());
+                    }
+
+                    break;
+            }
+        }
+        return true;
+    }
+
+    /**
+     * Return is AJAX Request
+     *
+     * @return boolean
+     */
+    public function getIsAjaxRequest()
+    {
+        return $this->_isAjax;
+    }
+
+    /**
+     * Return Original Attribute value from Request
+     *
+     * @param \Magento\App\RequestInterface $request
+     * @return mixed
+     */
+    protected function _getRequestValue(\Magento\App\RequestInterface $request)
+    {
+        $attrCode  = $this->getAttribute()->getAttributeCode();
+        if ($this->_requestScope) {
+            if (strpos($this->_requestScope, '/') !== false) {
+                $params = $request->getParams();
+                $parts = explode('/', $this->_requestScope);
+                foreach ($parts as $part) {
+                    if (isset($params[$part])) {
+                        $params = $params[$part];
+                    } else {
+                        $params = array();
+                    }
+                }
+            } else {
+                $params = $request->getParam($this->_requestScope);
+            }
+
+            if (isset($params[$attrCode])) {
+                $value = $params[$attrCode];
+            } else {
+                $value = false;
+            }
+
+            if (!$this->_requestScopeOnly && $value === false) {
+                $value = $request->getParam($attrCode, false);
+            }
+        } else {
+            $value = $request->getParam($attrCode, false);
+        }
+        return $value;
+    }
+
+    /**
+     * Extract data from request and return value
+     *
+     * @param \Magento\App\RequestInterface $request
+     * @return array|string
+     */
+    abstract public function extractValue(\Magento\App\RequestInterface $request);
+
+    /**
+     * Validate data
+     *
+     * @param array|string $value
+     * @throws \Magento\Core\Exception
+     * @return boolean
+     */
+    abstract public function validateValue($value);
+
+    /**
+     * Export attribute value to entity model
+     *
+     * @param array|string $value
+     * @return string|bool
+     */
+    abstract public function compactValue($value);
+
+    /**
+     * Restore attribute value from SESSION to entity model
+     *
+     * @param array|string $value
+     * @return string|bool
+     */
+    abstract public function restoreValue($value);
+
+    /**
+     * Return formated attribute value from entity model
+     *
+     * @param string $format
+     * @return string|array
+     */
+    abstract public function outputValue($format = \Magento\Eav\Model\AttributeDataFactory::OUTPUT_FORMAT_TEXT);
+}
diff --git a/app/code/Magento/Customer/Model/Metadata/Validator.php b/app/code/Magento/Customer/Model/Metadata/Validator.php
new file mode 100644
index 0000000000000000000000000000000000000000..b727a6e85fb95ff3fd5073cc45675f3af244fe24
--- /dev/null
+++ b/app/code/Magento/Customer/Model/Metadata/Validator.php
@@ -0,0 +1,94 @@
+<?php
+/**
+ * Attribute data validator
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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    Magento
+ * @package     Magento_Customer
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Model\Metadata;
+
+class Validator extends \Magento\Eav\Model\Validator\Attribute\Data
+{
+    /**
+     * @var string
+     */
+    protected $_entityType;
+
+    /**
+     * @param \Magento\Customer\Model\Metadata\ElementFactory $attrDataFactory
+     */
+    public function __construct(\Magento\Customer\Model\Metadata\ElementFactory $attrDataFactory)
+    {
+        $this->_attrDataFactory = $attrDataFactory;
+    }
+
+    /**
+     * Validate EAV model attributes with data models
+     *
+     * @param \Magento\Core\Model\AbstractModel $entity
+     * @return bool
+     */
+    public function isValid($entity)
+    {
+        $data = array();
+        if ($this->_data) {
+            $data = $this->_data;
+        } elseif ($entity instanceof \Magento\Object) {
+            $data = $entity->getData();
+        }
+        $this->validateData($data, $this->_attributes, $this->_entityType);
+    }
+
+    public function validateData($data, $attributes, $entityType)
+    {
+        foreach ($attributes as $attribute) {
+            $attributeCode = $attribute->getAttributeCode();
+            if (!$attribute->getDataModel() && !$attribute->getFrontendInput()) {
+                continue;
+            }
+            if (!isset($data[$attributeCode])) {
+                $data[$attributeCode] = null;
+            }
+            $dataModel = $this->_attrDataFactory->create(
+                $attribute, $entityType, $data[$attributeCode]
+            );
+            $dataModel->setExtractedData($data);
+            $result = $dataModel->validateValue($data[$attributeCode]);
+            if (true !== $result) {
+                $this->_addErrorMessages($attributeCode, (array)$result);
+            }
+        }
+        return count($this->_messages) == 0;
+    }
+
+    /**
+     * Set type of the entity
+     *
+     * @param string $entityType
+     * @return null
+     */
+    public function setEntityType($entityType)
+    {
+        $this->_entityType = $entityType;
+    }
+}
diff --git a/app/code/Magento/Customer/Model/Session.php b/app/code/Magento/Customer/Model/Session.php
index f0171b5904e89bb9e109d00f6893cb6c39a3e734..6c971a51859f434f6ac0997efafae69401398d49 100644
--- a/app/code/Magento/Customer/Model/Session.php
+++ b/app/code/Magento/Customer/Model/Session.php
@@ -292,16 +292,20 @@ class Session extends \Magento\Session\SessionManager
 
         if ($customer->authenticate($username, $password)) {
             $this->setCustomerAsLoggedIn($customer);
-            $this->regenerateId();
             return true;
         }
         return false;
     }
 
+    /**
+     * @param \Magento\Customer\Model\Customer $customer
+     * @return $this
+     */
     public function setCustomerAsLoggedIn($customer)
     {
         $this->setCustomer($customer);
         $this->_eventManager->dispatch('customer_login', array('customer' => $customer));
+        $this->regenerateId();
         return $this;
     }
 
@@ -316,7 +320,6 @@ class Session extends \Magento\Session\SessionManager
         $customer = $this->_createCustomer()->load($customerId);
         if ($customer->getId()) {
             $this->setCustomerAsLoggedIn($customer);
-            $this->regenerateId();
             return true;
         }
         return false;
diff --git a/app/code/Magento/Customer/Service/Customer.php b/app/code/Magento/Customer/Service/Customer.php
index 110cd07febab1365ef4fd2db0003d00a0067c1eb..ff922d06d93cdda283771f37933eb227a658b8f8 100644
--- a/app/code/Magento/Customer/Service/Customer.php
+++ b/app/code/Magento/Customer/Service/Customer.php
@@ -386,7 +386,8 @@ class Customer
                 $address = $customer->getAddressItemById($addressId);
                 if (!$address || !$address->getId()) {
                     throw new \Magento\Core\Exception(
-                        __('The address with the specified ID not found.'));
+                        __('The address with the specified ID not found.')
+                    );
                 }
             } else {
                 $address = $this->_addressFactory->create();
diff --git a/app/code/Magento/Customer/Service/Entity/V1/AggregateException.php b/app/code/Magento/Customer/Service/Entity/V1/AggregateException.php
new file mode 100644
index 0000000000000000000000000000000000000000..aff94b4f4f51576e2df6f3bb904247f8d15e4078
--- /dev/null
+++ b/app/code/Magento/Customer/Service/Entity/V1/AggregateException.php
@@ -0,0 +1,58 @@
+<?php
+/**
+ * Aggregate of multiple service exceptions
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\Entity\V1;
+
+class AggregateException extends Exception
+{
+    protected $_listOfExceptions = [];
+
+    /**
+     * Returns the list of exceptions.
+     * @return array of exceptions that are stored
+     */
+    public function getExceptions()
+    {
+        return $this->_listOfExceptions;
+    }
+
+    /**
+     * Add an exception to the aggregate list.
+     * @param Exception $exception
+     */
+    public function pushException(Exception $exception)
+    {
+        $this->_listOfExceptions[] = $exception;
+    }
+
+    /**
+     * Returns true if the aggregate list contains exceptions.
+     * @return bool
+     */
+    public function hasExceptions()
+    {
+        return !empty($this->_listOfExceptions);
+    }
+}
\ No newline at end of file
diff --git a/app/code/Magento/Customer/Service/Entity/V1/Exception.php b/app/code/Magento/Customer/Service/Entity/V1/Exception.php
new file mode 100644
index 0000000000000000000000000000000000000000..97596d6121a9e9666b0265fc8df6ea54494c903b
--- /dev/null
+++ b/app/code/Magento/Customer/Service/Entity/V1/Exception.php
@@ -0,0 +1,46 @@
+<?php
+/**
+ * Base service exception
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\Entity\V1;
+
+class Exception extends \Exception
+{
+    /** Error codes */
+    const CODE_UNKNOWN                              = 0;
+    const CODE_ACCT_ALREADY_ACTIVE                  = 1;
+    const CODE_INVALID_RESET_TOKEN                  = 2;
+    const CODE_RESET_TOKEN_EXPIRED                  = 3;
+    const CODE_EMAIL_NOT_FOUND                      = 4;
+    const CODE_CONFIRMATION_NOT_NEEDED              = 5;
+    const CODE_CUSTOMER_ID_MISMATCH                 = 6;
+    const CODE_EMAIL_NOT_CONFIRMED                  = 7;
+    const CODE_INVALID_EMAIL_OR_PASSWORD            = 8;
+    const CODE_EMAIL_EXISTS                         = 9;
+    const CODE_INVALID_RESET_PASSWORD_LINK_TOKEN    = 10;
+    const CODE_ADDRESS_NOT_FOUND                    = 11;
+    const CODE_INVALID_ADDRESS_ID                   = 12;
+    const CODE_VALIDATION_FAILED                    = 13;
+    const CODE_INVALID_CUSTOMER_ID                  = 14;
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerAccountService.php b/app/code/Magento/Customer/Service/V1/CustomerAccountService.php
new file mode 100644
index 0000000000000000000000000000000000000000..bf3f4e52e5c929ed5a7a2ddd32b36d4fbba9e219
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerAccountService.php
@@ -0,0 +1,341 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+/**
+ * Manipulate Customer Address Entities *
+ */
+class CustomerAccountService implements CustomerAccountServiceInterface
+{
+
+    /** @var \Magento\Customer\Model\CustomerFactory */
+    private $_customerFactory;
+    /**
+     * Core event manager proxy
+     *
+     * @var \Magento\Event\ManagerInterface
+     */
+    private $_eventManager = null;
+
+    /** @var \Magento\Core\Model\StoreManagerInterface */
+    private $_storeManager;
+
+    /**
+     * @var \Magento\Math\Random
+     */
+    private $_mathRandom;
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+    /**
+     * @var \Magento\Customer\Model\Metadata\Validator
+     */
+    private $_validator;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\Response\CreateCustomerAccountResponseBuilder
+     */
+    private $_createCustomerAccountResponseBuilder;
+
+    /**
+     * @var CustomerServiceInterface
+     */
+    private $_customerService;
+
+    /**
+     * @var CustomerAddressServiceInterface
+     */
+    private $_customerAddressService;
+
+    /**
+     * Constructor
+     *
+     * @param \Magento\Customer\Model\CustomerFactory $customerFactory
+     * @param \Magento\Customer\Model\AddressFactory $addressFactory
+     * @param \Magento\Customer\Service\V1\CustomerMetadataServiceInterface $eavMetadataService
+     * @param \Magento\Event\ManagerInterface $eventManager
+     * @param \Magento\Core\Model\StoreManagerInterface $storeManager
+     * @param \Magento\Math\Random $mathRandom
+     * @param \Magento\Customer\Model\Converter $converter
+     * @param \Magento\Customer\Model\Metadata\Validator $validator
+     * @param \Magento\Customer\Service\V1\Dto\RegionBuilder $regionBuilder
+     * @param \Magento\Customer\Service\V1\Dto\AddressBuilder $addressBuilder
+     * @param \Magento\Customer\Service\V1\Dto\Response\CreateCustomerAccountResponseBuilder $createCustomerAccountResponseBuilder
+     */
+    public function __construct(
+        \Magento\Customer\Model\CustomerFactory $customerFactory,
+        \Magento\Event\ManagerInterface $eventManager,
+        \Magento\Core\Model\StoreManagerInterface $storeManager,
+        \Magento\Math\Random $mathRandom,
+        \Magento\Customer\Model\Converter $converter,
+        \Magento\Customer\Model\Metadata\Validator $validator,
+        Dto\Response\CreateCustomerAccountResponseBuilder $createCustomerAccountResponseBuilder,
+        CustomerServiceInterface $customerService,
+        CustomerAddressServiceInterface $customerAddressService
+    ) {
+        $this->_customerFactory = $customerFactory;
+        $this->_eventManager = $eventManager;
+        $this->_storeManager = $storeManager;
+        $this->_mathRandom = $mathRandom;
+        $this->_converter = $converter;
+        $this->_validator = $validator;
+        $this->_createCustomerAccountResponseBuilder = $createCustomerAccountResponseBuilder;
+        $this->_customerService = $customerService;
+        $this->_customerAddressService = $customerAddressService;
+    }
+
+
+    /**
+     * @inheritdoc
+     */
+    public function sendConfirmation($email)
+    {
+        $customer = $this->_customerFactory->create();
+        $customer->setWebsiteId($this->_storeManager->getStore()->getWebsiteId())->loadByEmail($email);
+        if (!$customer->getId()) {
+            throw new Exception('Wrong email.', Exception::CODE_EMAIL_NOT_FOUND);
+        }
+        if ($customer->getConfirmation()) {
+            $customer->sendNewAccountEmail('confirmation', '', $this->_storeManager->getStore()->getId());
+        } else {
+            throw new Exception(
+                'This email does not require confirmation.',
+                Exception::CODE_CONFIRMATION_NOT_NEEDED
+            );
+        }
+    }
+
+
+    /**
+     * @inheritdoc
+     */
+    public function activateAccount($customerId, $key)
+    {
+        // load customer by id
+        $customer = $this->_converter->getCustomerModel($customerId);
+
+        // check if customer is inactive
+        if ($customer->getConfirmation()) {
+            if ($customer->getConfirmation() !== $key) {
+                throw new \Magento\Core\Exception('Wrong confirmation key.');
+            }
+
+            // activate customer
+            try {
+                $customer->setConfirmation(null);
+                $customer->save();
+            } catch (\Exception $e) {
+                throw new \Magento\Core\Exception('Failed to confirm customer account.');
+            }
+            $customer->sendNewAccountEmail('confirmed', '', $this->_storeManager->getStore()->getId());
+        } else {
+            throw new Exception(
+                'Customer account is already active.',
+                Exception::CODE_ACCT_ALREADY_ACTIVE
+            );
+        }
+
+        return $this->_converter->createCustomerFromModel($customer);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function authenticate($username, $password)
+    {
+        $customerModel = $this->_customerFactory->create();
+        $customerModel->setWebsiteId($this->_storeManager->getStore()->getWebsiteId());
+        try {
+            $customerModel->authenticate($username, $password);
+        } catch (\Magento\Core\Exception $e) {
+            switch ($e->getCode()) {
+                case \Magento\Customer\Model\Customer::EXCEPTION_EMAIL_NOT_CONFIRMED:
+                    $code = Exception::CODE_EMAIL_NOT_CONFIRMED;
+                    break;
+                case \Magento\Customer\Model\Customer::EXCEPTION_INVALID_EMAIL_OR_PASSWORD:
+                    $code = Exception::CODE_INVALID_EMAIL_OR_PASSWORD;
+                    break;
+                default:
+                    $code = Exception::CODE_UNKNOWN;
+            }
+            throw new Exception($e->getMessage(), $code, $e);
+        }
+
+        $this->_eventManager->dispatch('customer_login', array('customer'=>$customerModel));
+
+        return $this->_converter->createCustomerFromModel($customerModel);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function validateResetPasswordLinkToken($customerId, $resetPasswordLinkToken)
+    {
+        $this->_validateResetPasswordToken($customerId, $resetPasswordLinkToken);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function sendPasswordResetLink($email, $websiteId)
+    {
+        $customer = $this->_customerFactory->create()
+            ->setWebsiteId($websiteId)
+            ->loadByEmail($email);
+
+        if (!$customer->getId()) {
+            throw new Exception(
+                'No customer found for the provided email and website ID.', Exception::CODE_EMAIL_NOT_FOUND);
+        }
+        try {
+            $newPasswordToken = $this->_mathRandom->getUniqueHash();
+            $customer->changeResetPasswordLinkToken($newPasswordToken);
+            $customer->sendPasswordResetConfirmationEmail();
+        } catch (\Exception $exception) {
+            throw new Exception($exception->getMessage(), Exception::CODE_UNKNOWN, $exception);
+        }
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function resetPassword($customerId, $password, $resetToken)
+    {
+        $customerModel = $this->_validateResetPasswordToken($customerId, $resetToken);
+        $customerModel->setRpToken(null);
+        $customerModel->setRpTokenCreatedAt(null);
+        $customerModel->setPassword($password);
+        $customerModel->save();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function createAccount(
+        Dto\Customer $customer,
+        array $addresses,
+        $password = null,
+        $confirmationBackUrl = '',
+        $registeredBackUrl = '',
+        $storeId = 0
+    ) {
+        $customerId = $customer->getCustomerId();
+        if ($customerId) {
+            $customerModel = $this->_converter->getCustomerModel($customerId);
+            if ($customerModel->isInStore($storeId)) {
+                return $this->_createCustomerAccountResponseBuilder->setCustomerId($customerId)
+                    ->setStatus('')
+                    ->create();
+            }
+        }
+        $customerId = $this->_customerService->saveCustomer($customer, $password);
+        $this->_customerAddressService->saveAddresses($customerId, $addresses);
+
+        $customerModel = $this->_converter->getCustomerModel($customerId);
+
+        $newLinkToken = $this->_mathRandom->getUniqueHash();
+        $customerModel->changeResetPasswordLinkToken($newLinkToken);
+
+        if (!$storeId) {
+            $storeId = $this->_storeManager->getStore()->getId();
+        }
+
+        if ($customerModel->isConfirmationRequired()) {
+            $customerModel->sendNewAccountEmail('confirmation', $confirmationBackUrl, $storeId);
+            return $this->_createCustomerAccountResponseBuilder->setCustomerId($customerId)
+                ->setStatus(self::ACCOUNT_CONFIRMATION)
+                ->create();
+        } else {
+            $customerModel->sendNewAccountEmail('registered', $registeredBackUrl, $storeId);
+            return $this->_createCustomerAccountResponseBuilder->setCustomerId($customerId)
+                ->setStatus(self::ACCOUNT_REGISTERED)
+                ->create();
+        }
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function validateCustomerData(Dto\Customer $customer, array $attributes)
+    {
+        $customerErrors = $this->_validator->validateData(
+            $customer->__toArray(),
+            $attributes,
+            'customer'
+        );
+
+        if ($customerErrors !== true) {
+            return array(
+                'error'     => -1,
+                'message'   => implode(', ', $customerErrors)
+            );
+        }
+
+        $customerModel = $this->_converter->createCustomerModel($customer);
+
+        $result = $customerModel->validate();
+        if (true !== $result && is_array($result)) {
+            return array(
+                'error'   => -1,
+                'message' => implode(', ', $result)
+            );
+        }
+        return true;
+    }
+
+
+    /**
+     * @param $customerId
+     * @param $resetPasswordLinkToken
+     * @return \Magento\Customer\Model\Customer
+     * @throws Exception
+     */
+    private function _validateResetPasswordToken($customerId, $resetPasswordLinkToken)
+    {
+        if (!is_int($customerId)
+            || !is_string($resetPasswordLinkToken)
+            || empty($resetPasswordLinkToken)
+            || empty($customerId)
+            || $customerId < 0
+        ) {
+            throw new Exception('Invalid password reset token.', Exception::CODE_INVALID_RESET_TOKEN);
+        }
+
+        $customerModel = $this->_converter->getCustomerModel($customerId);
+
+        $customerToken = $customerModel->getRpToken();
+        if (strcmp($customerToken, $resetPasswordLinkToken) !== 0
+            || $customerModel->isResetPasswordLinkTokenExpired($customerId)
+        ) {
+            throw new Exception('Your password reset link has expired.', Exception::CODE_RESET_TOKEN_EXPIRED);
+        }
+
+        return $customerModel;
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerAccountServiceInterface.php b/app/code/Magento/Customer/Service/V1/CustomerAccountServiceInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..510cb3a97423b1a09f491f18e7a763f8adb3b112
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerAccountServiceInterface.php
@@ -0,0 +1,127 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+/**
+ * Manipulate Customer Address Entities *
+ */
+interface CustomerAccountServiceInterface
+{
+    /** account response status */
+    const ACCOUNT_CONFIRMATION = "confirmation";
+    const ACCOUNT_REGISTERED = "registered";
+
+    // Constants for the type of new account email to be sent
+    const NEW_ACCOUNT_EMAIL_REGISTERED = 'registered';     // welcome email, when confirmation is disabled
+    const NEW_ACCOUNT_EMAIL_CONFIRMED = 'confirmed';       // welcome email, when confirmation is enabled
+    const NEW_ACCOUNT_EMAIL_CONFIRMATION = 'confirmation'; // email with confirmation link
+
+    /**
+     * Create Customer Account
+     *
+     * @param \Magento\Customer\Service\V1\Dto\Customer $customer
+     * @param \Magento\Customer\Service\V1\Dto\Address[] $addresses
+     * @param string $password
+     * @param string $confirmationBackUrl
+     * @param string $registeredBackUrl
+     * @param int $storeId
+     * @return Dto\Response\CreateCustomerAccountResponse
+     */
+    public function createAccount(
+        Dto\Customer $customer,
+        array $addresses,
+        $password = null,
+        $confirmationBackUrl = '',
+        $registeredBackUrl = '',
+        $storeId = 0
+    );
+
+    /**
+     * Used to activate a customer account using a key that was sent in a confirmation e-mail.
+     *
+     * @param int $customerId
+     * @param string $key
+     * @throws \Magento\Customer\Service\Entity\V1\Exception If customerId is invalid, does not exist, or customer account was already active
+     * @throws \Magento\Core\Exception If there is an issue with supplied $customerId or $key
+     * @return \Magento\Customer\Service\V1\Dto\Customer
+     */
+    public function activateAccount($customerId, $key);
+
+    /**
+     * Login a customer account using username and password
+     *
+     * @param string $username username in plain-text
+     * @param string $password password in plain-text
+     * @throws \Magento\Customer\Service\Entity\V1\Exception if unable to login due to issue with username or password or others
+     * @return \Magento\Customer\Service\V1\Dto\Customer
+     */
+    public function authenticate($username, $password);
+
+    /**
+     * Check if password reset token is valid
+     *
+     * @param int $customerId
+     * @param string $resetPasswordLinkToken
+     * @throws \Magento\Customer\Service\Entity\V1\Exception if expired or invalid
+     */
+    public function validateResetPasswordLinkToken($customerId, $resetPasswordLinkToken);
+
+    /**
+     * Send an email to the customer with a password reset link.
+     *
+     * @param string $email
+     * @param int $websiteId
+     * @throws \Magento\Customer\Service\Entity\V1\Exception
+     */
+    public function sendPasswordResetLink($email, $websiteId);
+
+
+    /**
+     * Reset customer password.
+     *
+     * @param int $customerId
+     * @param string $password
+     * @param string $resetToken
+     */
+    public function resetPassword($customerId, $password, $resetToken);
+
+    /*
+     * Send Confirmation email
+     *
+     * @param string $email email address of customer
+     * @throws Entity\V1\Exception if error occurs getting customerId
+     */
+    public function sendConfirmation($email);
+
+    /**
+     * Validate customer entity
+     *
+     * @param \Magento\Customer\Service\V1\Dto\Customer $customer
+     * @param \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata[] $attributes
+     * @return array|bool
+     */
+    public function validateCustomerData(Dto\Customer $customer, array $attributes);
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerAddressService.php b/app/code/Magento/Customer/Service/V1/CustomerAddressService.php
new file mode 100644
index 0000000000000000000000000000000000000000..cc385b75d36308eb23588a209e175ebc677f01f1
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerAddressService.php
@@ -0,0 +1,323 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\Entity\V1\AggregateException;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+class CustomerAddressService implements CustomerAddressServiceInterface
+{
+    /** @var \Magento\Customer\Model\AddressFactory */
+    private $_addressFactory;
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\RegionBuilder
+     */
+    private $_regionBuilder;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private $_addressBuilder;
+
+
+    /**
+     * Constructor
+     *
+     * @param \Magento\Customer\Model\CustomerFactory $customerFactory
+     * @param \Magento\Customer\Model\AddressFactory $addressFactory
+     * @param \Magento\Customer\Service\V1\CustomerMetadataServiceInterface $eavMetadataService
+     * @param \Magento\Event\ManagerInterface $eventManager
+     * @param \Magento\Core\Model\StoreManagerInterface $storeManager
+     * @param \Magento\Math\Random $mathRandom
+     * @param \Magento\Customer\Model\Converter $converter
+     * @param \Magento\Customer\Model\Metadata\Validator $validator
+     * @param \Magento\Customer\Service\V1\Dto\RegionBuilder $regionBuilder
+     * @param \Magento\Customer\Service\V1\Dto\AddressBuilder $addressBuilder
+     * @param \Magento\Customer\Service\V1\Dto\Response\CreateCustomerAccountResponseBuilder $createCustomerAccountResponseBuilder
+     */
+    public function __construct(
+        \Magento\Customer\Model\AddressFactory $addressFactory,
+        \Magento\Customer\Model\Converter $converter,
+        Dto\RegionBuilder $regionBuilder,
+        Dto\AddressBuilder $addressBuilder
+    ) {
+        $this->_addressFactory = $addressFactory;
+        $this->_converter = $converter;
+        $this->_regionBuilder = $regionBuilder;
+        $this->_addressBuilder = $addressBuilder;
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getAddresses($customerId)
+    {
+        //TODO: use cache MAGETWO-16862
+        $customer = $this->_converter->getCustomerModel($customerId);
+        $addresses = $customer->getAddresses();
+        $defaultBillingId = $customer->getDefaultBilling();
+        $defaultShippingId = $customer->getDefaultShipping();
+
+        $result = array();
+        /** @var $address \Magento\Customer\Model\Address */
+        foreach ($addresses as $address) {
+            $result[] = $this->_createAddress(
+                $address,
+                $defaultBillingId,
+                $defaultShippingId
+            );
+        }
+        return $result;
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getDefaultBillingAddress($customerId)
+    {
+        //TODO: use cache MAGETWO-16862
+        $customer = $this->_converter->getCustomerModel($customerId);
+        $address = $customer->getDefaultBillingAddress();
+        if ($address === false) {
+            return null;
+        }
+        return $this->_createAddress(
+            $address,
+            $customer->getDefaultBilling(),
+            $customer->getDefaultShipping()
+        );
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getDefaultShippingAddress($customerId)
+    {
+        //TODO: use cache MAGETWO-16862
+        $customer = $this->_converter->getCustomerModel($customerId);
+        $address = $customer->getDefaultShippingAddress();
+        if ($address === false) {
+            return null;
+        }
+        return $this->_createAddress($address,
+            $customer->getDefaultBilling(),
+            $customer->getDefaultShipping()
+        );
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getAddressById($customerId, $addressId)
+    {
+        //TODO: use cache MAGETWO-16862
+        $customer = $this->_converter->getCustomerModel($customerId);
+        $address = $customer->getAddressById($addressId);
+        if (!$address->getId()) {
+            throw new Exception(
+                'Address id ' . $addressId . ' not found',
+                Exception::CODE_ADDRESS_NOT_FOUND
+            );
+        }
+        return $this->_createAddress(
+            $address,
+            $customer->getDefaultBilling(),
+            $customer->getDefaultShipping()
+        );
+    }
+
+    /**
+     * Create address based on model
+     *
+     * @param \Magento\Customer\Model\Address $addressModel
+     * @param int $defaultBillingId
+     * @param int $defaultShippingId
+     * @return \Magento\Customer\Service\V1\Dto\Address
+     */
+    private function _createAddress(\Magento\Customer\Model\Address $addressModel,
+                                      $defaultBillingId, $defaultShippingId
+    ) {
+        $addressId = $addressModel->getId();
+        $validAttributes = array_merge(
+            $addressModel->getDefaultAttributeCodes(),
+            [
+                'id', 'region_id', 'region', 'street', 'vat_is_valid',
+                'default_billing', 'default_shipping',
+                //TODO: create VAT object at MAGETWO-16860
+                'vat_request_id', 'vat_request_date', 'vat_request_success'
+            ]
+        );
+        $addressData = [];
+        foreach ($addressModel->getAttributes() as $attribute) {
+            $code = $attribute->getAttributeCode();
+            if (!in_array($code, $validAttributes) && $addressModel->getData($code) !== null) {
+                $addressData[$code] = $addressModel->getData($code);
+            }
+        }
+
+        $region = $this->_regionBuilder->setRegionCode($addressModel->getRegionCode())
+            ->setRegion($addressModel->getRegion())
+            ->setRegionId($addressModel->getRegionId())
+            ->create();
+        $this->_addressBuilder->populateWithArray(array_merge($addressData, [
+            'street' => $addressModel->getStreet(),
+            'id' => $addressId,
+            'default_billing' => $addressId === $defaultBillingId,
+            'default_shipping' => $addressId === $defaultShippingId,
+            'customer_id' => $addressModel->getCustomerId(),
+            'region' => $region
+        ]));
+
+        $retValue = $this->_addressBuilder->create();
+        return $retValue;
+    }
+
+
+    /**
+     * @inheritdoc
+     */
+    public function deleteAddressFromCustomer($customerId, $addressId)
+    {
+        if (!$addressId) {
+            throw new Exception('Invalid addressId', Exception::CODE_INVALID_ADDRESS_ID);
+        }
+
+        $address = $this->_addressFactory->create();
+        $address->load($addressId);
+
+        if (!$address->getId()) {
+            throw new Exception(
+                'Address id ' . $addressId . ' not found',
+                Exception::CODE_ADDRESS_NOT_FOUND
+            );
+        }
+
+        // Validate address_id <=> customer_id
+        if ($address->getCustomerId() != $customerId) {
+            throw new Exception(
+                'The address does not belong to this customer',
+                Exception::CODE_CUSTOMER_ID_MISMATCH
+            );
+        }
+
+        $address->delete();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function saveAddresses($customerId, array $addresses)
+    {
+        $customerModel = $this->_converter->getCustomerModel($customerId);
+        $addressModels = [];
+
+        $aggregateException = new AggregateException("All validation exceptions for all addresses.",
+            Exception::CODE_VALIDATION_FAILED);
+        foreach ($addresses as $address) {
+            $addressModel = null;
+            if ($address->getId()) {
+                $addressModel = $customerModel->getAddressItemById($address->getId());
+            }
+            if (is_null($addressModel)) {
+                $addressModel = $this->_addressFactory->create();
+                $addressModel->setCustomer($customerModel);
+            }
+            $this->_updateAddressModel($addressModel, $address);
+
+            $validationErrors = $addressModel->validate();
+            if ($validationErrors !== true) {
+                $aggregateException->pushException(
+                    new Exception(
+                        'There were one or more errors validating the address with id ' . $address->getId(),
+                        Exception::CODE_VALIDATION_FAILED,
+                        new \Magento\Validator\ValidatorException([$validationErrors])
+                    )
+                );
+                continue;
+            }
+            $addressModels[] = $addressModel;
+        }
+        if ($aggregateException->hasExceptions()) {
+            throw $aggregateException;
+        }
+        $addressIds = [];
+
+        foreach ($addressModels as $addressModel) {
+            try {
+                $addressModel->save();
+                $addressIds[] = $addressModel->getId();
+            } catch (\Exception $e) {
+                switch ($e->getCode()) {
+                    case \Magento\Customer\Model\Customer::EXCEPTION_EMAIL_EXISTS:
+                        $code = Exception::CODE_EMAIL_EXISTS;
+                        break;
+                    default:
+                        $code = Exception::CODE_UNKNOWN;
+                }
+                throw new Exception($e->getMessage(), $code, $e);
+            }
+        }
+
+        return $addressIds;
+    }
+
+    /**
+     * Updates an Address Model based on information from an Address DTO.
+     *
+     * @param \Magento\Customer\Model\Address $addressModel
+     * @param \Magento\Customer\Service\V1\Dto\Address $address
+     * return null
+     */
+    private function _updateAddressModel(\Magento\Customer\Model\Address $addressModel, Dto\Address $address)
+    {
+        // Set all attributes
+        foreach ($address->getAttributes() as $attributeCode => $attributeData) {
+            if ('region' == $attributeCode
+                && $address->getRegion() instanceof Dto\Region
+            ) {
+                $addressModel->setData('region', $address->getRegion()->getRegion());
+                $addressModel->setData('region_code', $address->getRegion()->getRegionCode());
+                $addressModel->setData('region_id', $address->getRegion()->getRegionId());
+            } else {
+                $addressModel->setData($attributeCode, $attributeData);
+            }
+        }
+        // Set customer related data
+        $isBilling = $address->isDefaultBilling();
+        $addressModel->setIsDefaultBilling($isBilling);
+        $addressModel->setIsDefaultShipping($address->isDefaultShipping());
+        // Need to use attribute set or future updates can cause data loss
+        if (!$addressModel->getAttributeSetId()) {
+            $addressModel->setAttributeSetId(CustomerMetadataServiceInterface::ADDRESS_ATTRIBUTE_SET_ID);
+        }
+    }
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerAddressServiceInterface.php b/app/code/Magento/Customer/Service/V1/CustomerAddressServiceInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..7f4a619a0b7c261e5b2a1de2b22b0ba239912531
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerAddressServiceInterface.php
@@ -0,0 +1,101 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+use Magento\Customer\Service\Entity\V1\AggregateException;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+/**
+ * Manipulate Customer Address Entities *
+ */
+interface CustomerAddressServiceInterface
+{
+    /**
+     * Retrieve all Customer Addresses
+     *
+     * @param int $customerId,
+     * @return \Magento\Customer\Service\V1\Dto\Address[]
+     * @throws Exception
+     */
+    public function getAddresses($customerId);
+
+    /**
+     * Retrieve default billing address
+     *
+     * @param int $customerId
+     * @return \Magento\Customer\Service\V1\Dto\Address
+     * @throws Exception
+     */
+    public function getDefaultBillingAddress($customerId);
+
+    /**
+     * Retrieve default shipping address
+     *
+     * @param int $customerId
+     * @return \Magento\Customer\Service\V1\Dto\Address
+     * @throws Exception
+     */
+    public function getDefaultShippingAddress($customerId);
+
+    /**
+     * Retrieve address by id
+     *
+     * @param int $customerId
+     * @param int $addressId
+     * @return \Magento\Customer\Service\V1\Dto\Address
+     * @throws Exception
+     */
+    public function getAddressById($customerId, $addressId);
+
+    /**
+     * Removes an address by id.
+     *
+     * @param int $customerId
+     * @param int $addressId
+     * @throws Exception if the address does not belong to the given customer
+     */
+    public function deleteAddressFromCustomer($customerId, $addressId);
+
+    /**
+     * Insert and/or update a list of addresses.
+     *
+     * This will add the addresses to the provided customerId.
+     * Only one address can be the default billing or shipping
+     * so if more than one is set, or if one was already set
+     * then the last address in this provided list will take
+     * over as the new default.
+     *
+     * This doesn't support partial updates to addresses, meaning
+     * that a full set of data must be provided with each Address
+     *
+     * @param int                 $customerId
+     * @param \Magento\Customer\Service\V1\Dto\Address[] $addresses
+     *
+     * @throws AggregateException if there are validation errors.
+     * @throws Exception If customerId is not found or other error occurs.
+     * @return int[] address ids
+     */
+    public function saveAddresses($customerId, array $addresses);
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerGroupService.php b/app/code/Magento/Customer/Service/V1/CustomerGroupService.php
new file mode 100644
index 0000000000000000000000000000000000000000..e001c415359271f42a994f2a97d3c96911174973
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerGroupService.php
@@ -0,0 +1,203 @@
+<?php
+/**
+ * Customer service is responsible for customer business workflow encapsulation
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1\Dto\SearchCriteria;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+class CustomerGroupService implements CustomerGroupServiceInterface
+{
+    /**
+     * @var \Magento\Customer\Model\GroupFactory
+     */
+    private $_groupFactory;
+
+    /**
+     * @var \Magento\Core\Model\Store\Config
+     */
+    private $_storeConfig;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\SearchResultsBuilder
+     */
+    private $_searchResultsBuilder;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\CustomerGroupBuilder
+     */
+    private $_customerGroupBuilder;
+
+    /**
+     * @param \Magento\Customer\Model\GroupFactory $groupFactory
+     * @param \Magento\Core\Model\Store\Config $storeConfig
+     * @param \Magento\Customer\Service\V1\Dto\SearchResultsBuilder $searchResultsBuilder
+     * @param \Magento\Customer\Service\V1\Dto\CustomerGroupBuilder $customerGroupBuilder
+     */
+    public function __construct(
+        \Magento\Customer\Model\GroupFactory $groupFactory,
+        \Magento\Core\Model\Store\Config $storeConfig,
+        Dto\SearchResultsBuilder $searchResultsBuilder,
+        Dto\CustomerGroupBuilder $customerGroupBuilder
+    ) {
+        $this->_groupFactory = $groupFactory;
+        $this->_storeConfig = $storeConfig;
+        $this->_searchResultsBuilder = $searchResultsBuilder;
+        $this->_customerGroupBuilder = $customerGroupBuilder;
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getGroups($includeNotLoggedIn = true, $taxClassId = null)
+    {
+        $groups = array();
+        /** @var \Magento\Customer\Model\Resource\Group\Collection $collection */
+        $collection = $this->_groupFactory->create()->getCollection();
+        if (!$includeNotLoggedIn) {
+            $collection->setRealGroupsFilter();
+        }
+        if (!is_null($taxClassId)) {
+            $collection->addFieldToFilter('tax_class_id', $taxClassId);
+        }
+        /** @var \Magento\Customer\Model\Group $group */
+        foreach ($collection as $group) {
+            $this->_customerGroupBuilder->setId($group->getId())
+                ->setCode($group->getCode())
+                ->setTaxClassId($group->getTaxClassId());
+            $groups[] = $this->_customerGroupBuilder->create();
+        }
+        return $groups;
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function searchGroups(SearchCriteria $searchCriteria)
+    {
+        $this->_searchResultsBuilder->setSearchCriteria($searchCriteria);
+
+        $groups = array();
+        /** @var \Magento\Customer\Model\Resource\Group\Collection $collection */
+        $collection = $this->_groupFactory->create()->getCollection();
+        foreach ($searchCriteria->getFilters() as $filter) {
+            $collection->addFilter($filter->getField(), $filter->getValue(), $filter->getConditionType());
+        }
+        $this->_searchResultsBuilder->setTotalCount($collection->getSize());
+        foreach ($searchCriteria->getSortOrders() as $field => $direction) {
+            switch($field) {
+                case 'id' :
+                    $field = 'customer_group_id';
+                    break;
+                case 'code':
+                    $field = 'customer_group_code';
+                    break;
+                case "tax_class_id":
+                default:
+                    break;
+            }
+            $collection->addOrder($field, $direction == SearchCriteria::SORT_ASC ? 'ASC' : 'DESC');
+        }
+        $collection->setCurPage($searchCriteria->getCurrentPage());
+        $collection->setPageSize($searchCriteria->getPageSize());
+
+        /** @var \Magento\Customer\Model\Group $group */
+        foreach ($collection as $group) {
+            $this->_customerGroupBuilder->setId($group->getId())
+                ->setCode($group->getCode())
+                ->setTaxClassId($group->getTaxClassId());
+            $groups[] = $this->_customerGroupBuilder->create();
+        }
+        $this->_searchResultsBuilder->setItems($groups);
+        return $this->_searchResultsBuilder->create();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getGroup($groupId)
+    {
+        $customerGroup = $this->_groupFactory->create();
+        $customerGroup->load($groupId);
+        // Throw exception if a customer group does not exist
+        if (is_null($customerGroup->getId())) {
+            throw new Exception(__('groupId ' . $groupId . ' does not exist.'));
+        }
+        $this->_customerGroupBuilder->setId($customerGroup->getId())
+            ->setCode($customerGroup->getCode())
+            ->setTaxClassId($customerGroup->getTaxClassId());
+        return $this->_customerGroupBuilder->create();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getDefaultGroup($storeId)
+    {
+        $groupId = $this->_storeConfig->getConfig(\Magento\Customer\Model\Group::XML_PATH_DEFAULT_ID, $storeId);
+        return $this->getGroup($groupId);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function canDelete($groupId)
+    {
+        $customerGroup = $this->_groupFactory->create();
+        $customerGroup->load($groupId);
+        return $groupId > 0 && !$customerGroup->usesAsDefault();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function saveGroup(Dto\CustomerGroup $group)
+    {
+        $customerGroup = $this->_groupFactory->create();
+        if ($group->getId()) {
+            $customerGroup->load($group->getId());
+        }
+        $customerGroup->setCode($group->getCode());
+        $customerGroup->setTaxClassId($group->getTaxClassId());
+        $customerGroup->save();
+        return $customerGroup->getId();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function deleteGroup($groupId)
+    {
+        try {
+            // Get group so we can throw an exception if it doesn't exist
+            $this->getGroup($groupId);
+            $customerGroup = $this->_groupFactory->create();
+            $customerGroup->setId($groupId);
+            $customerGroup->delete();
+        } catch (\Exception $e) {
+            throw new Exception($e->getMessage(), $e->getCode(), $e);
+        }
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerGroupServiceInterface.php b/app/code/Magento/Customer/Service/V1/CustomerGroupServiceInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..fae88d4d955353f1a60f4a8462589fc2f712971c
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerGroupServiceInterface.php
@@ -0,0 +1,94 @@
+<?php
+/**
+ * Customer Service Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1\Dto\CustomerGroup;
+use Magento\Customer\Service\V1\Dto\SearchCriteria;
+use Magento\Validator\Test\True;
+
+interface CustomerGroupServiceInterface
+{
+    const NOT_LOGGED_IN_ID          = 0;
+    const CUST_GROUP_ALL            = 32000;
+    const GROUP_CODE_MAX_LENGTH     = 32;
+
+    /**
+     * Retrieve Customer Groups
+     *
+     * The list of groups can be filtered to exclude the NOT_LOGGED_IN group using the first parameter and/or it can
+     * be filtered by tax class.
+     *
+     * @param boolean $includeNotLoggedIn
+     * @param int $taxClassId
+     *
+     * @return \Magento\Customer\Service\V1\Dto\CustomerGroup[]
+     */
+    public function getGroups($includeNotLoggedIn = true, $taxClassId = null);
+
+    /**
+     * @param \Magento\Customer\Service\V1\Dto\SearchCriteria $searchCriteria
+     *
+     * @return \Magento\Customer\Service\V1\Dto\SearchResults
+     */
+    public function searchGroups(Dto\SearchCriteria $searchCriteria);
+
+    /**
+     * Get a customer group by group ID.
+     *
+     * @param int $groupId
+     * @throws \Magento\Customer\Service\Entity\V1\Exception if groupId is not found
+     * @return \Magento\Customer\Service\V1\Dto\CustomerGroup
+     */
+    public function getGroup($groupId);
+
+    /**
+     * @param int $storeId
+     *
+     * @return \Magento\Customer\Service\V1\Dto\CustomerGroup
+     */
+    public function getDefaultGroup($storeId);
+
+    /**
+     * @param int $groupId
+     *
+     * @return boolean true, if this group can be deleted
+     */
+    public function canDelete($groupId);
+
+    /**
+     * @param \Magento\Customer\Service\V1\Dto\CustomerGroup $group
+     *
+     * @return int customer group ID
+     */
+    public function saveGroup(CustomerGroup $group);
+
+    /**
+     * @param int $groupId
+     *
+     * @return null
+     */
+    public function deleteGroup($groupId);
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerMetadataService.php b/app/code/Magento/Customer/Service/V1/CustomerMetadataService.php
new file mode 100644
index 0000000000000000000000000000000000000000..695b5cf701b62039e3d719ea7b6260774402ede2
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerMetadataService.php
@@ -0,0 +1,241 @@
+<?php
+/**
+ * EAV attribute metadata service
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1\CustomerMetadataServiceInterface;
+use Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata;
+use Magento\Customer\Service\V1\Dto\Eav\OptionBuilder;
+
+class CustomerMetadataService implements CustomerMetadataServiceInterface
+{
+    /**
+     * @var \Magento\Eav\Model\Config
+     */
+    private $_eavConfig;
+
+    /** @var array Cache of DTOs - entityType => attributeCode => DTO */
+    private $_cache;
+
+    /**
+     * @var \Magento\Customer\Model\Resource\Form\Attribute\Collection
+     */
+    private $_attrFormCollection;
+
+    /**
+     * @var \Magento\Core\Model\StoreManager
+     */
+    private $_storeManager;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder
+     */
+    private $_optionBuilder;
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder
+     */
+    private $_attributeMetadataBuilder;
+
+    /**
+     * @param \Magento\Eav\Model\Config $eavConfig
+     * @param \Magento\Customer\Model\Resource\Form\Attribute\Collection $attrFormCollection
+     * @param \Magento\Core\Model\StoreManager $storeManager
+     * @param \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder $optionBuilder
+     * @param \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder $attributeMetadataBuilder
+     */
+    public function __construct(
+        \Magento\Eav\Model\Config $eavConfig,
+        \Magento\Customer\Model\Resource\Form\Attribute\Collection $attrFormCollection,
+        \Magento\Core\Model\StoreManager $storeManager,
+        \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder $optionBuilder,
+        \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder $attributeMetadataBuilder
+    ) {
+        $this->_eavConfig = $eavConfig;
+        $this->_cache = [];
+        $this->_attrFormCollection = $attrFormCollection;
+        $this->_storeManager = $storeManager;
+        $this->_optionBuilder = $optionBuilder;
+        $this->_attributeMetadataBuilder = $attributeMetadataBuilder;
+    }
+
+    /**
+     * Retrieve EAV attribute metadata
+     *
+     * @param   mixed $entityType
+     * @param   mixed $attributeCode
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata
+     */
+    public function getAttributeMetadata($entityType, $attributeCode)
+    {
+        $dtoCache = $this->_getEntityCache($entityType);
+        if (isset($dtoCache[$attributeCode])) {
+            return $dtoCache[$attributeCode];
+        }
+
+        /** @var \Magento\Eav\Model\Entity\Attribute\AbstractAttribute $attribute */
+        $attribute = $this->_eavConfig->getAttribute($entityType, $attributeCode);
+        $attributeMetadata = $this->_createMetadataAttribute($attribute);
+        $dtoCache[$attributeCode] = $attributeMetadata;
+        return $attributeMetadata;
+    }
+
+    /**
+     * Returns all known attributes metadata for a given entity type and attribute set
+     *
+     * @param string $entityType
+     * @param int $attributeSetId
+     * @param int $storeId
+     * @return AttributeMetadata[]
+     */
+    public function getAllAttributeSetMetadata($entityType, $attributeSetId = 0, $storeId = null)
+    {
+        if (null === $storeId) {
+            $storeId = $this->_storeManager->getStore()->getId();
+        }
+        $object = new \Magento\Object([
+            'store_id'          => $storeId,
+            'attribute_set_id'  => $attributeSetId,
+        ]);
+        $attributeCodes = $this->_eavConfig->getEntityAttributeCodes($entityType, $object);
+
+        $attributesMetadata = [];
+        foreach ($attributeCodes as $attributeCode) {
+            $attributesMetadata[] = $this->getAttributeMetadata($entityType, $attributeCode);
+        }
+        return $attributesMetadata;
+    }
+
+    /**
+     * Retrieve all attributes for entityType filtered by form code
+     *
+     * @param $entityType
+     * @param $formCode
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata[]
+     */
+    public function getAttributes($entityType, $formCode)
+    {
+        $attributes = [];
+        $this->_loadAttributesCollection($entityType, $formCode);
+        foreach ($this->_attrFormCollection as $attribute) {
+            $attributes[$attribute->getAttributeCode()] = $this->_createMetadataAttribute($attribute);
+        }
+        return $attributes;
+    }
+
+    /**
+     * Load collection with filters applied
+     *
+     * @param $entityType
+     * @param $formCode
+     * @return null
+     */
+    private function _loadAttributesCollection($entityType, $formCode)
+    {
+         $this->_attrFormCollection
+            ->setStore($this->_storeManager->getStore())
+            ->setEntityType($entityType)
+            ->addFormCodeFilter($formCode)
+            ->setSortOrder()
+            ->load();
+    }
+
+    /**
+     * @param \Magento\Eav\Model\Entity\Attribute\AbstractAttribute $attribute
+     * @return AttributeMetadata
+     */
+    private function _createMetadataAttribute($attribute)
+    {
+        $options = [];
+        try {
+            foreach ($attribute->getSource()->getAllOptions() as $option) {
+                $options[$option['label']] = $this->_optionBuilder->setLabel($option['label'])
+                    ->setValue($option['value'])
+                    ->create();
+            }
+        } catch (\Exception $e) {
+            // There is no source for this attribute
+        }
+        $this->_attributeMetadataBuilder->setAttributeCode($attribute->getAttributeCode())
+            ->setFrontendInput($attribute->getFrontendInput())
+            ->setInputFilter($attribute->getInputFilter())
+            ->setStoreLabel($attribute->getStoreLabel())
+            ->setValidationRules($attribute->getValidateRules())
+            ->setIsVisible($attribute->getIsVisible())
+            ->setIsRequired($attribute->getIsRequired())
+            ->setMultilineCount($attribute->getMultilineCount())
+            ->setDataModel($attribute->getDataModel())
+            ->setOptions($options);
+
+        return $this->_attributeMetadataBuilder->create();
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getCustomerAttributeMetadata($attributeCode)
+    {
+        return $this->getAttributeMetadata('customer', $attributeCode);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getAllCustomerAttributeMetadata()
+    {
+        return $this->getAllAttributeSetMetadata('customer', self::CUSTOMER_ATTRIBUTE_SET_ID);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getAddressAttributeMetadata($attributeCode)
+    {
+        return $this->getAttributeMetadata('customer_address', $attributeCode);
+    }
+
+    /**
+     * @inheritdoc
+     */
+    public function getAllAddressAttributeMetadata()
+    {
+        return $this->getAllAttributeSetMetadata('customer_address', self::ADDRESS_ATTRIBUTE_SET_ID);
+    }
+
+
+    /**
+     * Helper for getting access to an entity types DTO cache.
+     *
+     * @param $entityType
+     * @return \ArrayAccess
+     */
+    private function _getEntityCache($entityType)
+    {
+        if (!isset($this->_cache[$entityType])) {
+            $this->_cache[$entityType] = new \ArrayObject();
+        }
+        return $this->_cache[$entityType];
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerMetadataServiceInterface.php b/app/code/Magento/Customer/Service/V1/CustomerMetadataServiceInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..d0619bb0da4d83b521a4546f102a4d7e28eeec8f
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerMetadataServiceInterface.php
@@ -0,0 +1,95 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata;
+
+/**
+ * Manipulate Customer Metadata Attributes *
+ */
+interface CustomerMetadataServiceInterface
+{
+    const CUSTOMER_ATTRIBUTE_SET_ID = 1;
+    const ADDRESS_ATTRIBUTE_SET_ID = 2;
+
+    /**
+     * Retrieve Attribute Metadata
+     *
+     * @param   mixed $entityType
+     * @param   mixed $attributeCode
+     * @return AttributeMetadata
+     */
+    public function getAttributeMetadata($entityType, $attributeCode);
+
+    /**
+     * Returns all known attributes metadata for a given entity type
+     *
+     * @param string $entityType
+     * @param int $attributeSetId
+     * @param int $storeId
+     * @return AttributeMetadata[]
+     */
+    public function getAllAttributeSetMetadata($entityType, $attributeSetId = 0, $storeId = null);
+
+    /**
+     * Retrieve all attributes for entityType filtered by form code
+     *
+     * @param $entityType
+     * @param $formCode
+     * @return AttributeMetadata[]
+     */
+    public function getAttributes($entityType, $formCode);
+
+    /**
+     * Retrieve Customer EAV attribute metadata
+     *
+     * @param string $attributeCode
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata
+     */
+    public function getCustomerAttributeMetadata($attributeCode);
+
+    /**
+     * Returns all attribute metadata for customers
+     *
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata[]
+     */
+    public function getAllCustomerAttributeMetadata();
+
+    /**
+     * Retrieve Customer Addresses EAV attribute metadata
+     *
+     * @param string $attributeCode
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata
+     */
+    public function getAddressAttributeMetadata($attributeCode);
+
+    /**
+     * Returns all attribute metadata for Addresses
+     *
+     * @return \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata[]
+     */
+    public function getAllAddressAttributeMetadata();
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerService.php b/app/code/Magento/Customer/Service/V1/CustomerService.php
new file mode 100644
index 0000000000000000000000000000000000000000..7f53131bfe711410341d2877666524aba14b2deb
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerService.php
@@ -0,0 +1,120 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\Entity\V1\Exception;
+use Magento\Customer\Model\Customer;
+use Magento\Validator\ValidatorException;
+
+/**
+ * Manipulate Customer Address Entities *
+ */
+class CustomerService implements CustomerServiceInterface
+{
+
+    /** @var array Cache of DTOs */
+    private $_cache = [];
+
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+
+    /**
+     * Constructor
+     *
+     * @param \Magento\Customer\Model\CustomerFactory $customerFactory
+     * @param \Magento\Customer\Model\AddressFactory $addressFactory
+     * @param \Magento\Customer\Service\V1\CustomerMetadataServiceInterface $eavMetadataService
+     * @param \Magento\Event\ManagerInterface $eventManager
+     * @param \Magento\Core\Model\StoreManagerInterface $storeManager
+     * @param \Magento\Math\Random $mathRandom
+     * @param \Magento\Customer\Model\Converter $converter
+     * @param \Magento\Customer\Model\Metadata\Validator $validator
+     * @param \Magento\Customer\Service\V1\Dto\RegionBuilder $regionBuilder
+     * @param \Magento\Customer\Service\V1\Dto\AddressBuilder $addressBuilder
+     * @param \Magento\Customer\Service\V1\Dto\Response\CreateCustomerAccountResponseBuilder $createCustomerAccountResponseBuilder
+     */
+    public function __construct(
+        \Magento\Customer\Model\Converter $converter
+    ) {
+        $this->_converter = $converter;
+    }
+
+
+    /**
+     * @inheritdoc
+     */
+    public function getCustomer($customerId)
+    {
+        if (!isset($this->_cache[$customerId])) {
+            $customerModel = $this->_converter->getCustomerModel($customerId);
+            $customerEntity = $this->_converter->createCustomerFromModel($customerModel);
+            $this->_cache[$customerId] = $customerEntity;
+        }
+
+        return $this->_cache[$customerId];
+    }
+
+
+    /**
+     * @inheritdoc
+     */
+    public function saveCustomer(Dto\Customer $customer, $password = null)
+    {
+        $customerModel = $this->_converter->createCustomerModel($customer);
+
+        if ($password) {
+            $customerModel->setPassword($password);
+        }
+
+        $validationErrors = $customerModel->validate();
+        if ($validationErrors !== true) {
+            throw new Exception(
+                'There were one or more errors validating the customer object.',
+                Exception::CODE_VALIDATION_FAILED,
+                new ValidatorException([$validationErrors])
+            );
+        }
+
+        try {
+            $customerModel->save();
+            unset($this->_cache[$customerModel->getId()]);
+        } catch (\Exception $e) {
+            switch ($e->getCode()) {
+                case Customer::EXCEPTION_EMAIL_EXISTS:
+                    $code = Exception::CODE_EMAIL_EXISTS;
+                    break;
+                default:
+                    $code = Exception::CODE_UNKNOWN;
+            }
+            throw new Exception($e->getMessage(), $code, $e);
+        }
+
+        return $customerModel->getId();
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/CustomerServiceInterface.php b/app/code/Magento/Customer/Service/V1/CustomerServiceInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..6d12afb3c3dbcb1fdb9fcecffb6a212d129d4d7d
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/CustomerServiceInterface.php
@@ -0,0 +1,50 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+/**
+ * Manipulate Customer Address Entities *
+ */
+interface CustomerServiceInterface
+{
+    /**
+     * Create or update customer information
+     *
+     * @param \Magento\Customer\Service\V1\Dto\Customer $customer
+     * @param string $password
+     * @throws \Magento\Customer\Service\Entity\V1\Exception
+     * @return int customer ID
+     */
+    public function saveCustomer(Dto\Customer $customer, $password = null);
+
+    /**
+     * Retrieve Customer
+     *
+     * @param int $customerId
+     * @return \Magento\Customer\Service\V1\Dto\Customer
+     */
+    public function getCustomer($customerId);
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Address.php b/app/code/Magento/Customer/Service/V1/Dto/Address.php
new file mode 100644
index 0000000000000000000000000000000000000000..771209452dc0c729dd6141757e364e2f47f77c3b
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Address.php
@@ -0,0 +1,214 @@
+<?php
+/**
+ * Address class acts as a DTO for the Customer Service
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Region;
+
+class Address extends \Magento\Service\Entity\AbstractDto implements Eav\EntityInterface
+{
+    /**
+     * @var array
+     */
+    private static $_nonAttributes = ['id', 'customer_id', 'region', 'default_billing', 'default_shipping'];
+
+    /**
+     * @return int|null
+     */
+    public function getId()
+    {
+        return $this->_get('id');
+    }
+
+    /**
+     * @return boolean|null
+     */
+    public function isDefaultShipping()
+    {
+        return $this->_get('default_shipping');
+    }
+
+    /**
+     * @return boolean|null
+     */
+    public function isDefaultBilling()
+    {
+        return $this->_get('default_billing');
+    }
+
+    /**
+     * @return string[]
+     */
+    public function getAttributes()
+    {
+        $attributes = $this->_data;
+        foreach (self::$_nonAttributes as $keyName) {
+            unset ($attributes[$keyName]);
+        }
+
+        /** This triggers some code in _updateAddressModel in CustomerV1 Service */
+        if (!is_null($this->getRegion())) {
+            $attributes['region_id'] = $this->getRegion()->getRegionId();
+
+            $attributes['region'] = $this->getRegion()->getRegion();
+        }
+
+        return $attributes;
+    }
+
+    /**
+     * @param string $attributeCode
+     * @return string|null
+     */
+    public function getAttribute($attributeCode)
+    {
+        $attributes = $this->getAttributes();
+        if (isset($attributes[$attributeCode])
+            && !in_array($attributeCode, self::$_nonAttributes)) {
+            return $attributes[$attributeCode];
+        }
+        return null;
+    }
+
+    /**
+     * @return Region
+     */
+    public function getRegion()
+    {
+        return $this->_get('region');
+    }
+
+    /**
+     * @return int|null
+     */
+    public function getCountryId()
+    {
+        return $this->_get('country_id');
+    }
+
+    /**
+     * @return \string[]|null
+     */
+    public function getStreet()
+    {
+        return $this->_get('street');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getCompany()
+    {
+        return $this->_get('company');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getTelephone()
+    {
+        return $this->_get('telephone');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getFax()
+    {
+        return $this->_get('fax');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getPostcode()
+    {
+        return $this->_get('postcode');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getCity()
+    {
+        return $this->_get('city');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getFirstname()
+    {
+        return $this->_get('firstname');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getLastname()
+    {
+        return $this->_get('lastname');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getMiddlename()
+    {
+        return $this->_get('middlename');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getPrefix()
+    {
+        return $this->_get('prefix');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getSuffix()
+    {
+        return $this->_get('suffix');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getVatId()
+    {
+        return $this->_get('vat_id');
+    }
+
+    /**
+     * @return string|null
+     */
+    public function getCustomerId()
+    {
+        return $this->_get('customer_id');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/AddressBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/AddressBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..e5b6eb54f060b8f31b2945b5f46ac7fca5a62819
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/AddressBuilder.php
@@ -0,0 +1,226 @@
+<?php
+/**
+ * Address class acts as a DTO for the Customer Service
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Region;
+
+class AddressBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    protected $_regionBuilder;
+
+    /**
+     * @param \Magento\Customer\Service\V1\Dto\RegionBuilder $regionBuilder
+     */
+    public function __construct(
+      \Magento\Customer\Service\V1\Dto\RegionBuilder $regionBuilder
+    ) {
+        parent::__construct();
+        $this->_regionBuilder = $regionBuilder;
+        $this->_data['region'] = $regionBuilder->create();
+    }
+
+    /**
+     * @param int $id
+     * @return AddressBuilder
+     */
+    public function setId($id)
+    {
+        return $this->_set('id', (string)$id);
+    }
+
+    /**
+     * @param boolean $defaultShipping
+     * @return AddressBuilder
+     */
+    public function setDefaultShipping($defaultShipping)
+    {
+        return $this->_set('default_shipping', (bool)$defaultShipping);
+    }
+
+    /**
+     * @param boolean $defaultBilling
+     * @return AddressBuilder
+     */
+    public function setDefaultBilling($defaultBilling)
+    {
+        return $this->_set('default_billing', (bool)$defaultBilling);
+    }
+
+    /**
+     * @param string[] $data
+     * @return AddressBuilder
+     */
+    public function populateWithArray(array $data)
+    {
+        unset($data['region_id']);
+        if (isset($data['region'])) {
+            $region = $data['region'];
+            if (!($region instanceof Region)) {
+                unset($data['region']);
+            }
+        }
+
+        parent::populateWithArray($data);
+
+        return $this;
+    }
+
+    /**
+     * @param Region $region
+     * @return AddressBuilder
+     */
+    public function setRegion(Region $region)
+    {
+        return $this->_set('region', $region);
+    }
+
+    /**
+     * @param int $countryId
+     * @return AddressBuilder
+     */
+    public function setCountryId($countryId)
+    {
+        return $this->_set('country_id', $countryId);
+    }
+
+    /**
+     * @param \string[] $street
+     * @return AddressBuilder
+     */
+    public function setStreet($street)
+    {
+        return $this->_set('street', $street);
+    }
+
+    /**
+     * @param string $company
+     * @return AddressBuilder
+     */
+    public function setCompany($company)
+    {
+        return $this->_set('company', $company);
+    }
+
+    /**
+     * @param string $telephone
+     * @return AddressBuilder
+     */
+    public function setTelephone($telephone)
+    {
+        return $this->_set('telephone', $telephone);
+    }
+
+    /**
+     * @param string $fax
+     * @return AddressBuilder
+     */
+    public function setFax($fax)
+    {
+        return $this->_set('fax', $fax);
+    }
+
+    /**
+     * @param string $postcode
+     * @return AddressBuilder
+     */
+    public function setPostcode($postcode)
+    {
+        return $this->_set('postcode', $postcode);
+    }
+
+    /**
+     * @param string $city
+     * @return AddressBuilder
+     */
+    public function setCity($city)
+    {
+        return $this->_set('city', $city);
+    }
+
+    /**
+     * @param string $firstname
+     * @return AddressBuilder
+     */
+    public function setFirstname($firstname)
+    {
+        return $this->_set('firstname', $firstname);
+    }
+
+    /**
+     * @param string $lastname
+     * @return AddressBuilder
+     */
+    public function setLastname($lastname)
+    {
+        return $this->_set('lastname', $lastname);
+    }
+
+    /**
+     * @param string $middlename
+     * @return AddressBuilder
+     */
+    public function setMiddlename($middlename)
+    {
+        return $this->_set('middlename', $middlename);
+    }
+
+    /**
+     * @param string $prefix
+     * @return AddressBuilder
+     */
+    public function setPrefix($prefix)
+    {
+        return $this->_set('prefix', $prefix);
+    }
+
+    /**
+     * @param string $suffix
+     * @return AddressBuilder
+     */
+    public function setSuffix($suffix)
+    {
+        return $this->_set('suffix', $suffix);
+    }
+
+    /**
+     * @param string $vatId
+     * @return AddressBuilder
+     */
+    public function setVatId($vatId)
+    {
+        return $this->_set('vat_id', $vatId);
+    }
+
+    /**
+     * @param string $customerId
+     * @return AddressBuilder
+     */
+    public function setCustomerId($customerId)
+    {
+        /** XXX: (string) Needed for tests to pass */
+        return $this->_set('customer_id', (string)$customerId);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Customer.php b/app/code/Magento/Customer/Service/V1/Dto/Customer.php
new file mode 100644
index 0000000000000000000000000000000000000000..323759306b7da14a2fd5bb483ccce5ee5ccf6961
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Customer.php
@@ -0,0 +1,248 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+/**
+ * Class Customer
+ * Uses array to hold data, setters return $this so they can be chained.
+ *
+ * @package Magento\Customer\Service\Entity\V1
+ */
+class Customer extends \Magento\Service\Entity\AbstractDto implements Eav\EntityInterface
+{
+
+    /**
+     * @var array  Special attribute codes which cannot be set or gotten
+     * they are used by the model but should not be exposed in the DTO
+     */
+    private static $_nonAttributes = [self::ID];
+
+    /**
+     * name of field containing entity id, used to exclude this field from list of attributes.
+     */
+    const ID = 'id';
+
+    /**
+     * constants defined for keys of array, makes typos less likely
+     */
+    const CONFIRMATION = 'confirmation';
+    const CREATED_AT = 'created_at';
+    const CREATED_IN = 'created_in';
+    const DOB = 'dob';
+    const EMAIL = 'email';
+    const FIRSTNAME = 'firstname';
+    const GENDER = 'gender';
+    const GROUP_ID = 'group_id';
+    const LASTNAME = 'lastname';
+    const MIDDLENAME = 'middlename';
+    const PREFIX = 'prefix';
+    const STORE_ID = 'store_id';
+    const SUFFIX = 'suffix';
+    const TAXVAT = 'taxvat';
+    const WEBSITE_ID = 'website_id';
+    const DEFAULT_BILLING = 'default_billing';
+    const DEFAULT_SHIPPING = 'default_shipping';
+
+    /**
+     * Retrieve array of all attributes, in the form of 'attribute code' => <attribute value'
+     *
+     * @return array|\ArrayAccess|\string[]
+     */
+    public function getAttributes()
+    {
+        $attributes = $this->__toArray();
+        foreach (self::$_nonAttributes as $keyName) {
+            unset ($attributes[$keyName]);
+        }
+        return $attributes;
+    }
+
+    /**
+     * Gets an attribute value.
+     *
+     * @param string $attributeCode
+     * @return mixed The attribute value or null if the attribute has not been set
+     */
+    public function getAttribute($attributeCode)
+    {
+        if (isset($this->_data[$attributeCode])) {
+            return $this->_data[$attributeCode];
+        } else {
+            return null;
+        }
+    }
+
+    /**
+     * @return string
+     */
+    public function getDefaultBilling()
+    {
+        return $this->_get(self::DEFAULT_BILLING);
+    }
+
+    /**
+     * @return string
+     */
+    public function getDefaultShipping()
+    {
+        return $this->_get(self::DEFAULT_SHIPPING);
+    }
+
+    /**
+     * @return string
+     */
+    public function getConfirmation()
+    {
+        return $this->_get(self::CONFIRMATION);
+    }
+
+    /**
+     * @param string $confirmation
+     * @return Customer
+     */
+    public function setConfirmation($confirmation)
+    {
+        return $this->_set(self::CONFIRMATION, $confirmation);
+    }
+
+    /**
+     * @return string
+     */
+    public function getCreatedAt()
+    {
+        return $this->_get(self::CREATED_AT);
+    }
+
+    /**
+     * @return string
+     */
+    public function getCreatedIn()
+    {
+        return $this->_get(self::CREATED_IN);
+    }
+
+    /**
+     * @return string
+     */
+    public function getDob()
+    {
+        return $this->_get(self::DOB);
+    }
+
+    /**
+     * @return string
+     */
+    public function getEmail()
+    {
+        return $this->_get(self::EMAIL);
+    }
+
+    /**
+     * @return string
+     */
+    public function getFirstname()
+    {
+        return $this->_get(self::FIRSTNAME);
+    }
+
+    /**
+     * @return string
+     */
+    public function getGender()
+    {
+        return $this->_get(self::GENDER);
+    }
+
+    /**
+     * @return string
+     */
+    public function getGroupId()
+    {
+        return $this->_get(self::GROUP_ID);
+    }
+
+    /**
+     * @return int
+     */
+    public function getCustomerId()
+    {
+        return $this->_get(self::ID);
+    }
+
+    /**
+     * @return string
+     */
+    public function getLastname()
+    {
+        return $this->_get(self::LASTNAME);
+    }
+
+    /**
+     * @return string
+     */
+    public function getMiddlename()
+    {
+        return $this->_get(self::MIDDLENAME);
+    }
+
+    /**
+     * @return string
+     */
+    public function getPrefix()
+    {
+        return $this->_get(self::PREFIX);
+    }
+
+    /**
+     * @return int
+     */
+    public function getStoreId()
+    {
+        return $this->_get(self::STORE_ID);
+    }
+
+    /**
+     * @return string
+     */
+    public function getSuffix()
+    {
+        return $this->_get(self::SUFFIX);
+    }
+
+    /**
+     * @return string
+     */
+    public function getTaxvat()
+    {
+        return $this->_get(self::TAXVAT);
+    }
+
+    /**
+     * @return int
+     */
+    public function getWebsiteId()
+    {
+        return $this->_get(self::WEBSITE_ID, 0);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/CustomerBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/CustomerBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..150e4a474ff06a515941daeef69005c70cbbad03
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/CustomerBuilder.php
@@ -0,0 +1,179 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+use Magento\Customer\Service\V1\Dto\Customer;
+
+/**
+ * Class Customer
+ * Uses array to hold data, setters return $this so they can be chained.
+ *
+ * @package Magento\Customer\Service\Entity\V1
+ */
+class CustomerBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+
+    /**
+     * @param string $confirmation
+     * @return CustomerBuilder
+     */
+    public function setConfirmation($confirmation)
+    {
+        return $this->_set(Customer::CONFIRMATION, $confirmation);
+    }
+
+    /**
+     * @param string $createdAt
+     * @return CustomerBuilder
+     */
+    public function setCreatedAt($createdAt)
+    {
+        return $this->_set(Customer::CREATED_AT, $createdAt);
+    }
+
+    /**
+     * @param string $createdIn
+     * @return CustomerBuilder
+     */
+    public function setCreatedIn($createdIn)
+    {
+        return $this->_set(Customer::CREATED_IN, $createdIn);
+    }
+
+    /**
+     * @param string $dob
+     * @return CustomerBuilder
+     */
+    public function setDob($dob)
+    {
+        return $this->_set(Customer::DOB, $dob);
+    }
+
+    /**
+     * @param string $email
+     * @return CustomerBuilder
+     */
+    public function setEmail($email)
+    {
+        return $this->_set(Customer::EMAIL, $email);
+    }
+
+    /**
+     * @param string $firstname
+     * @return CustomerBuilder
+     */
+    public function setFirstname($firstname)
+    {
+        return $this->_set(Customer::FIRSTNAME, $firstname);
+    }
+
+    /**
+     * @param string $gender
+     * @return CustomerBuilder
+     */
+    public function setGender($gender)
+    {
+        return $this->_set(Customer::GENDER, $gender);
+    }
+
+    /**
+     * @param string $groupId
+     * @return CustomerBuilder
+     */
+    public function setGroupId($groupId)
+    {
+        return $this->_set(Customer::GROUP_ID, $groupId);
+    }
+
+    /**
+     * @param int $id
+     * @return CustomerBuilder
+     */
+    public function setCustomerId($id)
+    {
+        return $this->_set(Customer::ID, $id);
+    }
+
+    /**
+     * @param string $lastname
+     * @return CustomerBuilder
+     */
+    public function setLastname($lastname)
+    {
+        return $this->_set(Customer::LASTNAME, $lastname);
+    }
+
+    /**
+     * @param string $middlename
+     * @return CustomerBuilder
+     */
+    public function setMiddlename($middlename)
+    {
+        return $this->_set(Customer::MIDDLENAME, $middlename);
+    }
+
+    /**
+     * @param string $prefix
+     * @return CustomerBuilder
+     */
+    public function setPrefix($prefix)
+    {
+        return $this->_set(Customer::PREFIX, $prefix);
+    }
+
+    /**
+     * @param int $storeId
+     * @return CustomerBuilder
+     */
+    public function setStoreId($storeId)
+    {
+        return $this->_set(Customer::STORE_ID, $storeId);
+    }
+
+    /**
+     * @param string $suffix
+     * @return CustomerBuilder
+     */
+    public function setSuffix($suffix)
+    {
+        return $this->_set(Customer::SUFFIX, $suffix);
+    }
+
+    /**
+     * @param string $taxvat
+     * @return CustomerBuilder
+     */
+    public function setTaxvat($taxvat)
+    {
+        return $this->_set(Customer::TAXVAT, $taxvat);
+    }
+
+    /**
+     * @param int $websiteId
+     * @return CustomerBuilder
+     */
+    public function setWebsiteId($websiteId)
+    {
+        return $this->_set(Customer::WEBSITE_ID, $websiteId);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/CustomerGroup.php b/app/code/Magento/Customer/Service/V1/Dto/CustomerGroup.php
new file mode 100644
index 0000000000000000000000000000000000000000..550278599f494fd4e2857d8f058ff9162b8e999e
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/CustomerGroup.php
@@ -0,0 +1,53 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class CustomerGroup extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * @return int
+     */
+    public function getId()
+    {
+        return $this->_get('id');
+    }
+
+    /**
+     * @return string
+     */
+    public function getCode()
+    {
+        return $this->_get('code');
+    }
+
+    /**
+     * @return int
+     */
+    public function getTaxClassId()
+    {
+        return $this->_get('tax_class_id');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/CustomerGroupBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/CustomerGroupBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..0c81be242f5a9d76ceda41fe3c355aa27bfe4210
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/CustomerGroupBuilder.php
@@ -0,0 +1,59 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class CustomerGroupBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param string $id
+     *
+     * @return CustomerGroupBuilder
+     */
+    public function setId($id)
+    {
+        return $this->_set('id', $id);
+    }
+
+    /**
+     * @param string $code
+     *
+     * @return CustomerGroupBuilder
+     */
+    public function setCode($code)
+    {
+        return $this->_set('code', $code);
+    }
+
+    /**
+     * @param string $taxClassId
+     *
+     * @return CustomerGroupBuilder
+     */
+    public function setTaxClassId($taxClassId)
+    {
+        return $this->_set('tax_class_id', $taxClassId);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/Attribute.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/Attribute.php
new file mode 100644
index 0000000000000000000000000000000000000000..1b475810b8c676f9281ecea6857f4ec90708bb4e
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/Attribute.php
@@ -0,0 +1,51 @@
+<?php
+/**
+ * Eav Attribute
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+class Attribute extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * Constants used as keys into $_data
+     */
+    const ATTRIBUTE_CODE = 'attribute_code';
+    const VALUE = 'value';
+
+    /**
+     * @return string the attribute code
+     */
+    public function getAttributeCode()
+    {
+        return $this->_get(self::ATTRIBUTE_CODE);
+    }
+
+    /**
+     * @return string the attribute value
+     */
+    public function getValue()
+    {
+        return $this->_get(self::VALUE);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..0f067c1f21d97c512847e42b77b36106281f1395
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeBuilder.php
@@ -0,0 +1,49 @@
+<?php
+/**
+ * Eav Attribute
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+use Magento\Customer\Service\V1\Dto\Eav\Attribute;
+
+class AttributeBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param string $attributeCode
+     * @return AttributeBuilder
+     */
+    public function setAttributeCode($attributeCode)
+    {
+        return $this->_set(Attribute::ATTRIBUTE_CODE, $attributeCode);
+    }
+
+    /**
+     * @param string $value
+     * @return AttributeBuilder
+     */
+    public function setValue($value)
+    {
+        return $this->_set(Attribute::VALUE, $value);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadata.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadata.php
new file mode 100644
index 0000000000000000000000000000000000000000..7c1c05328af526ff1d8414a84f51aa932bbac97d
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadata.php
@@ -0,0 +1,125 @@
+<?php
+/**
+ * Eav Attribute Metadata
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+use Magento\Customer\Service\V1\Dto\Eav\Option;
+
+class AttributeMetadata extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * Constants used as keys into $_data
+     */
+    const ATTRIBUTE_CODE = 'attribute_code';
+    const FRONT_END_INPUT = 'front_end_input';
+    const INPUT_FILTER = 'input_filter';
+    const STORE_LABEL = 'store_label';
+    const VALIDATION_RULES = 'validation_rules';
+    const OPTIONS = 'options';
+    const VISIBLE = 'is_visible';
+    const REQUIRED = 'is_required';
+    const MULTILINE_COUNT = 'multiline_count';
+    const DATA_MODEL = 'data_model';
+
+    /**
+     * @return string
+     */
+    public function getAttributeCode()
+    {
+        return $this->_get(self::ATTRIBUTE_CODE);
+    }
+
+    /**
+     * @return string
+     */
+    public function getFrontendInput()
+    {
+        return $this->_get(self::FRONT_END_INPUT);
+    }
+
+    /**
+     * @return string
+     */
+    public function getInputFilter()
+    {
+        return $this->_get(self::INPUT_FILTER);
+    }
+
+    /**
+     * @return string
+     */
+    public function getStoreLabel()
+    {
+        return $this->_get(self::STORE_LABEL);
+    }
+
+    /**
+     * @return string
+     */
+    public function getValidationRules()
+    {
+        return $this->_get(self::VALIDATION_RULES);
+    }
+
+    /**
+     * @return int
+     */
+    public function getMultilineCount()
+    {
+        return $this->_get(self::MULTILINE_COUNT);
+    }
+
+    /**
+     * @return boolean
+     */
+    public function getIsVisible()
+    {
+        return $this->_get(self::VISIBLE);
+    }
+
+    /**
+     * @return boolean
+     */
+    public function getIsRequired()
+    {
+        return $this->_get(self::REQUIRED);
+    }
+
+    /**
+     * @return string
+     */
+    public function getDataModel()
+    {
+        return $this->_get(self::DATA_MODEL);
+    }
+
+    /**
+     * @return Option[]
+     */
+    public function getOptions()
+    {
+        return $this->_get(self::OPTIONS);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..72792c4292fd73664acbce60e0844fe5f15f37bd
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataBuilder.php
@@ -0,0 +1,131 @@
+<?php
+/**
+ * Eav Attribute Metadata
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+use Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata;
+
+class AttributeMetadataBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * Initializes builder.
+     */
+    public function __construct()
+    {
+        parent::__construct();
+        $this->_data[AttributeMetadata::OPTIONS] = array();
+    }
+
+    /**
+     * @param $attributeCode
+     * @return AttributeMetadataBuilder
+     */
+    public function setAttributeCode($attributeCode)
+    {
+        return $this->_set(AttributeMetadata::ATTRIBUTE_CODE, $attributeCode);
+    }
+
+    /**
+     * @param $frontendInput
+     * @return AttributeMetadataBuilder
+     */
+    public function setFrontendInput($frontendInput)
+    {
+        return $this->_set(AttributeMetadata::FRONT_END_INPUT, $frontendInput);
+    }
+
+    /**
+     * @param $inputFilter
+     * @return AttributeMetadataBuilder
+     */
+    public function setInputFilter($inputFilter)
+    {
+        return $this->_set(AttributeMetadata::INPUT_FILTER, $inputFilter);
+    }
+
+    /**
+     * @param $storeLabel
+     * @return AttributeMetadataBuilder
+     */
+    public function setStoreLabel($storeLabel)
+    {
+        return $this->_set(AttributeMetadata::STORE_LABEL, $storeLabel);
+    }
+
+    /**
+     * @param string $validationRules
+     * @return AttributeMetadataBuilder
+     */
+    public function setValidationRules($validationRules)
+    {
+        return $this->_set(AttributeMetadata::VALIDATION_RULES, $validationRules);
+    }
+
+    /**
+     * @param \Magento\Customer\Service\V1\Dto\Eav\Option[] $options
+     * @return AttributeMetadataBuilder
+     */
+    public function setOptions($options)
+    {
+        $this->_set(AttributeMetadata::OPTIONS, $options);
+    }
+
+    /**
+     * @param boolean $visible
+     * @return AttributeMetadataBuilder
+     */
+    public function setIsVisible($visible)
+    {
+        return $this->_set(AttributeMetadata::VISIBLE, $visible);
+    }
+
+    /**
+     * @param boolean $required
+     * @return AttributeMetadataBuilder
+     */
+    public function setIsRequired($required)
+    {
+        return $this->_set(AttributeMetadata::REQUIRED, $required);
+    }
+
+
+    /**
+     * @param int $count
+     * @return AttributeMetadataBuilder
+     */
+    public function setMultilineCount($count)
+    {
+        return $this->_set(AttributeMetadata::MULTILINE_COUNT, $count);
+    }
+
+    /**
+     * @param string
+     * @return AttributeMetadataBuilder
+     */
+    public function setDataModel($dataModel)
+    {
+        return $this->_set(AttributeMetadata::DATA_MODEL, $dataModel);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/EntityInterface.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/EntityInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..9375c6d00e4e7257d57853093a348d3a3a41d5ea
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/EntityInterface.php
@@ -0,0 +1,41 @@
+<?php
+/**
+ * Eav Attribute
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+interface EntityInterface
+{
+    /**
+     * @return string[]
+     */
+    public function getAttributes();
+
+    /**
+     * @param string $attributeCode
+     * @return string|null
+     */
+    public function getAttribute($attributeCode);
+
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/Option.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/Option.php
new file mode 100644
index 0000000000000000000000000000000000000000..077539ae37c63c44c0aa68485879bccadc9909f3
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/Option.php
@@ -0,0 +1,55 @@
+<?php
+/**
+ * Eav attribute option
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+class Option extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * Constants used as keys into $_data
+     */
+    const LABEL = 'label';
+    const VALUE = 'value';
+
+    /**
+     * Get option label
+     *
+     * @return string
+     */
+    public function getLabel()
+    {
+        return $this->_get(self::LABEL);
+    }
+
+    /**
+     * Get option value
+     *
+     * @return string
+     */
+    public function getValue()
+    {
+        return $this->_get(self::VALUE);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Eav/OptionBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/Eav/OptionBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..045cfad463ad0ea4251f3f091265307adedbf466
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Eav/OptionBuilder.php
@@ -0,0 +1,51 @@
+<?php
+/**
+ * Eav attribute option
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+use Magento\Customer\Service\V1\Dto\Eav\Option;
+
+class OptionBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * Set option label
+     *
+     * @return OptionBuilder
+     */
+    public function setLabel($label)
+    {
+        return $this->_set(Option::LABEL, $label);
+    }
+
+    /**
+     * Set option value
+     *
+     * @return OptionBuilder
+     */
+    public function setValue($value)
+    {
+        return $this->_set(Option::VALUE, $value);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Filter.php b/app/code/Magento/Customer/Service/V1/Dto/Filter.php
new file mode 100644
index 0000000000000000000000000000000000000000..be4afba2ec1cf93cac16dd3500ded24bac53103b
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Filter.php
@@ -0,0 +1,53 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class Filter extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * @return string
+     */
+    public function getField()
+    {
+        return $this->_get('field');
+    }
+
+    /**
+     * @return string
+     */
+    public function getValue()
+    {
+        return $this->_get('value');
+    }
+
+    /**
+     * @return string
+     */
+    public function getConditionType()
+    {
+        return $this->_get('condition_type');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/FilterBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/FilterBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..f6f1c37619dcf3119221f86f9728c91f7eb97702
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/FilterBuilder.php
@@ -0,0 +1,70 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class FilterBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * Initializes the builder.
+     */
+    public function __construct()
+    {
+        parent::__construct();
+
+        /* XXX: special constructor to set default values */
+        $this->_data['condition_type'] = 'and';
+    }
+
+    /**
+     * @param string $field
+     * @return FilterBuilder
+     */
+    public function setField($field)
+    {
+        $this->_data['field'] = $field;
+        return $this;
+    }
+
+    /**
+     * @param string $value
+     * @return FilterBuilder
+     */
+    public function setValue($value)
+    {
+        $this->_data['value'] = $value;
+        return $this;
+    }
+
+    /**
+     * @param string $conditionType
+     * @return FilterBuilder
+     */
+    public function setConditionType($conditionType)
+    {
+        $this->_data['condition_type'] = $conditionType;
+        return $this;
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Region.php b/app/code/Magento/Customer/Service/V1/Dto/Region.php
new file mode 100644
index 0000000000000000000000000000000000000000..475602a5e774d50d3d7c05aceb8c96b2ab083ee4
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Region.php
@@ -0,0 +1,53 @@
+<?php
+/**
+ * Class Region
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class Region extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * @return string
+     */
+    public function getRegionCode()
+    {
+        return $this->_get('region_code');
+    }
+
+    /**
+     * @return string
+     */
+    public function getRegion()
+    {
+        return $this->_get('region');
+    }
+
+    /**
+     * @return int
+     */
+    public function getRegionId()
+    {
+        return $this->_get('region_id');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/RegionBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/RegionBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..1f1d0bbdde0f25be112ff4e892a5bbb4b1c1f13f
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/RegionBuilder.php
@@ -0,0 +1,59 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+class RegionBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param string $regionCode
+     * @return RegionBuilder
+     */
+    public function setRegionCode($regionCode)
+    {
+        $this->_data['region_code'] = $regionCode;
+        return $this;
+    }
+
+    /**
+     * @param string $regionName
+     * @return RegionBuilder
+     */
+    public function setRegion($regionName)
+    {
+        $this->_data['region'] = $regionName;
+        return $this;
+    }
+
+    /**
+     * @param string $regionId
+     * @return RegionBuilder
+     */
+    public function setRegionId($regionId)
+    {
+        $this->_data['region_id'] = $regionId;
+        return $this;
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponse.php b/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponse.php
new file mode 100644
index 0000000000000000000000000000000000000000..e9b88ac826c1edef220f6dafa76317f3b7dc8ca9
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponse.php
@@ -0,0 +1,45 @@
+<?php
+/**
+ * Class CreateCustomerAccountResponse
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Response;
+
+class CreateCustomerAccountResponse extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * @return int
+     */
+    public function getCustomerId()
+    {
+        return $this->_get('customer_id');
+    }
+
+    /**
+     * @return string
+     */
+    public function getStatus()
+    {
+        return $this->_get('status');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponseBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponseBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..4e5236b66f5a42fb6d75412b6085af06e817a109
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/Response/CreateCustomerAccountResponseBuilder.php
@@ -0,0 +1,47 @@
+<?php
+/**
+ * Class CreateCustomerAccountResponse
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto\Response;
+
+class CreateCustomerAccountResponseBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param int $customerId
+     * @return CreateCustomerAccountResponseBuilder
+     */
+    public function setCustomerId($customerId)
+    {
+        return $this->_set('customer_id', $customerId);
+    }
+
+    /**
+     * @param string $status
+     * @return CreateCustomerAccountResponseBuilder
+     */
+    public function setStatus($status)
+    {
+        return $this->_set('status', $status);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/SearchCriteria.php b/app/code/Magento/Customer/Service/V1/Dto/SearchCriteria.php
new file mode 100644
index 0000000000000000000000000000000000000000..87136556f6fd8ba359328b9ffe46472995acfe0e
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/SearchCriteria.php
@@ -0,0 +1,66 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Filter;
+
+class SearchCriteria extends \Magento\Service\Entity\AbstractDto
+{
+    const SORT_ASC = 1;
+    const SORT_DESC = -1;
+
+    /**
+     * @return Filter[]
+     */
+    public function getFilters()
+    {
+        return $this->_get('filters', $this->_createArray());
+    }
+
+    /**
+     * @return array
+     */
+    public function getSortOrders()
+    {
+        return $this->_get('sort_orders', $this->_createArray());
+    }
+
+    /**
+     * @return int
+     */
+    public function getPageSize()
+    {
+        return $this->_get('page_size');
+    }
+
+    /**
+     * @return int
+     */
+    public function getCurrentPage()
+    {
+        return $this->_get('current_page');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/SearchCriteriaBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/SearchCriteriaBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..559135790f3eac1bbdf6b6de1b318b7503bd1d37
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/SearchCriteriaBuilder.php
@@ -0,0 +1,82 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Filter;
+
+class SearchCriteriaBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param Filter $filter
+     *
+     * @return SearchCriteriaBuilder
+     */
+    public function addFilter($filter)
+    {
+        if (!isset($this->_data['filters'])) {
+            $this->_data['filters'] = array();
+        }
+
+        $this->_data['filters'][] = $filter;
+        return $this;
+    }
+
+    /**
+     * @param string $field
+     * @param int $direction
+     *
+     * @return SearchCriteriaBuilder
+     */
+    public function addSortOrder($field, $direction)
+    {
+        if (!isset($this->_data['sort_orders'])) {
+            $this->_data['sort_orders'] = array();
+        }
+
+        $this->_data['sort_orders'][$field] = $direction;
+        return $this;
+    }
+
+    /**
+     * @param int $pageSize
+     *
+     * @return SearchCriteriaBuilder
+     */
+    public function setPageSize($pageSize)
+    {
+        return $this->_set('page_size', $pageSize);
+    }
+
+    /**
+     * @param int $currentPage
+     *
+     * @return SearchCriteriaBuilder
+     */
+    public function setCurrentPage($currentPage)
+    {
+        return $this->_set('current_page', $currentPage);
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/SearchResults.php b/app/code/Magento/Customer/Service/V1/Dto/SearchResults.php
new file mode 100644
index 0000000000000000000000000000000000000000..27f53ba92e5af8348641401fa177cdafc534b490
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/SearchResults.php
@@ -0,0 +1,56 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+
+use Magento\Customer\Service\V1\Dto\SearchCriteria;
+
+class SearchResults extends \Magento\Service\Entity\AbstractDto
+{
+    /**
+     * @return array
+     */
+    public function getItems()
+    {
+        return $this->_get('items');
+    }
+
+    /**
+     * @return SearchCriteria
+     */
+    public function getSearchCriteria()
+    {
+        return $this->_get('search_criteria');
+    }
+
+    /**
+     * @return int
+     */
+    public function getTotalCount()
+    {
+        return $this->_get('total_count');
+    }
+}
diff --git a/app/code/Magento/Customer/Service/V1/Dto/SearchResultsBuilder.php b/app/code/Magento/Customer/Service/V1/Dto/SearchResultsBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..356703d11c54e49fb7522dd15a54518d5c4d482b
--- /dev/null
+++ b/app/code/Magento/Customer/Service/V1/Dto/SearchResultsBuilder.php
@@ -0,0 +1,61 @@
+<?php
+/**
+ * Customer Service Address Interface
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\SearchCriteria;
+
+class SearchResultsBuilder extends \Magento\Service\Entity\AbstractDtoBuilder
+{
+    /**
+     * @param \Magento\Customer\Service\V1\Dto\SearchCriteria $searchCriteria
+     *
+     * @return SearchResultsBuilder
+     */
+    public function setSearchCriteria(SearchCriteria $searchCriteria)
+    {
+        return $this->_set('search_criteria', $searchCriteria);
+    }
+
+    /**
+     * @param int $totalCount
+     *
+     * @return SearchResultsBuilder
+     */
+    public function setTotalCount($totalCount)
+    {
+        return $this->_set('total_count', $totalCount);
+    }
+
+    /**
+     * @param array $items
+     *
+     * @return SearchResultsBuilder
+     */
+    public function setItems($items)
+    {
+        return $this->_set('items', $items);
+    }
+}
diff --git a/app/code/Magento/Customer/etc/di.xml b/app/code/Magento/Customer/etc/di.xml
index 95daf16f147a1ce500600fb7bf3cff4cc084cbb7..dfb7026534a0e9f723c0b35307557e52d4ba9366 100644
--- a/app/code/Magento/Customer/etc/di.xml
+++ b/app/code/Magento/Customer/etc/di.xml
@@ -24,6 +24,16 @@
  */
 -->
 <config>
+    <preference for="Magento\Customer\Service\V1\CustomerServiceInterface"
+                type="Magento\Customer\Service\V1\CustomerService" />
+    <preference for="Magento\Customer\Service\V1\CustomerAddressServiceInterface"
+                type="Magento\Customer\Service\V1\CustomerAddressService" />
+    <preference for="Magento\Customer\Service\V1\CustomerGroupServiceInterface"
+                type="Magento\Customer\Service\V1\CustomerGroupService" />
+    <preference for="Magento\Customer\Service\V1\CustomerAccountServiceInterface"
+                type="Magento\Customer\Service\V1\CustomerAccountService" />
+    <preference for="Magento\Customer\Service\V1\CustomerMetadataServiceInterface"
+                type="Magento\Customer\Service\V1\CustomerMetadataService" />
     <type name="Magento\Customer\Model\Session">
         <param name="configShare">
             <instance type="Magento\Customer\Model\Config\Share\Proxy" />
@@ -60,4 +70,15 @@
             <instance type="Magento\Customer\Helper\Data\Proxy" />
         </param>
     </type>
+    <type name="Magento\Customer\Service\V1\Dto\AddressBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\CustomerBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\CustomerGroupBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\Eav\AttributeBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\Eav\OptionBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\FilterBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\RegionBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\Response\CreateCustomerAccountResponseBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\SearchCriteriaBuilder" shared="false" />
+    <type name="Magento\Customer\Service\V1\Dto\SearchResultsBuilder" shared="false" />
 </config>
diff --git a/app/code/Magento/Customer/etc/validation.xml b/app/code/Magento/Customer/etc/validation.xml
index 6e0813f81bc2aaa27d227b0c6b0c83947ffe4ac7..9bd9094cc9a465d9147be8575998d71370788529 100644
--- a/app/code/Magento/Customer/etc/validation.xml
+++ b/app/code/Magento/Customer/etc/validation.xml
@@ -33,6 +33,11 @@
                     <constraint alias="eav_data_validator" class="Magento\Eav\Model\Validator\Attribute\Data" />
                 </entity_constraints>
             </rule>
+            <rule name="metadata_form_data">
+                <entity_constraints>
+                    <constraint alias="metadata_data_validator" class="Magento\Customer\Model\Metadata\Validator" />
+                </entity_constraints>
+            </rule>
         </rules>
         <groups>
             <group name="save">
@@ -40,6 +45,11 @@
                     <use rule="check_eav"/>
                 </uses>
             </group>
+            <group name="form">
+                <uses>
+                    <use rule="metadata_form_data"/>
+                </uses>
+            </group>
         </groups>
     </entity>
 
diff --git a/app/code/Magento/Directory/Model/Currency/DefaultLocator.php b/app/code/Magento/Directory/Model/Currency/DefaultLocator.php
index 65980fc452475c18ffd2603296f03afa22126946..c7293304413c9292871255c75fb190713b597137 100644
--- a/app/code/Magento/Directory/Model/Currency/DefaultLocator.php
+++ b/app/code/Magento/Directory/Model/Currency/DefaultLocator.php
@@ -63,7 +63,7 @@ class DefaultLocator
             $group = $request->getParam('group');
             $currencyCode =  $this->_app->getGroup($group)->getWebsite()->getBaseCurrencyCode();
         } else {
-            $currencyCode = $this->_app->getStore()->getBaseCurrencyCode();
+            $currencyCode = $this->_app->getBaseCurrencyCode();
         }
 
         return $currencyCode;
diff --git a/app/code/Magento/Eav/Model/Resource/Entity/Attribute/Collection.php b/app/code/Magento/Eav/Model/Resource/Entity/Attribute/Collection.php
index 27de52a584350e036315e016ee1d72778c4ffb70..f9c2abcfecd8e6eece40b9b9e768ce90ec57b17f 100644
--- a/app/code/Magento/Eav/Model/Resource/Entity/Attribute/Collection.php
+++ b/app/code/Magento/Eav/Model/Resource/Entity/Attribute/Collection.php
@@ -135,7 +135,7 @@ class Collection extends \Magento\Core\Model\Resource\Db\Collection\AbstractColl
                 'entity_attribute.attribute_id = main_table.attribute_id'
             );
             $this->addFieldToFilter('entity_attribute.attribute_set_id', $setId);
-            $this->setOrder('sort_order', self::SORT_ORDER_ASC);
+            $this->setOrder('entity_attribute.sort_order', self::SORT_ORDER_ASC);
         }
 
         return $this;
diff --git a/app/code/Magento/GiftMessage/view/adminhtml/sales/order/create/giftoptions.phtml b/app/code/Magento/GiftMessage/view/adminhtml/sales/order/create/giftoptions.phtml
index 875818a9e24b1697281e995ab698094468338274..3525079772c20c177d0f0e2b3c431c833d415eec 100644
--- a/app/code/Magento/GiftMessage/view/adminhtml/sales/order/create/giftoptions.phtml
+++ b/app/code/Magento/GiftMessage/view/adminhtml/sales/order/create/giftoptions.phtml
@@ -31,7 +31,7 @@
     <?php if ($_childHtml): ?>
         <tr class="border">
             <td colspan="8">
-                <a class="action-link" href="#" id="gift_options_link_<?php echo $_item->getId() ?>"><?php echo __('Gift Options') ?></a></strong>
+                <a class="action-link" href="#" id="gift_options_link_<?php echo $_item->getId() ?>"><?php echo __('Gift Options') ?></a>
                 <script type="text/javascript">
                     giftOptionsTooltip.addTargetLink('gift_options_link_<?php echo $_item->getId() ?>', <?php echo $_item->getId() ?>);
                 </script>
diff --git a/app/code/Magento/GoogleShopping/Model/Observer.php b/app/code/Magento/GoogleShopping/Model/Observer.php
index 44826071f98b32d62e28363dfe26832e6218446c..7a71ecaf6b78553e199a6bbedf6978d9d997bae5 100644
--- a/app/code/Magento/GoogleShopping/Model/Observer.php
+++ b/app/code/Magento/GoogleShopping/Model/Observer.php
@@ -165,13 +165,13 @@ class Observer
      */
     public function checkSynchronizationOperations(\Magento\Event\Observer $observer)
     {
-        $flag = $this->_flag->loadSelf();
-        if ($flag->isExpired()) {
+        $this->_flag->loadSelf();
+        if ($this->_flag->isExpired()) {
             $this->_inboxFactory->create()->addMajor(
                 __('Google Shopping operation has expired.'),
                 __('One or more google shopping synchronization operations failed because of timeout.')
             );
-            $flag->unlock();
+            $this->_flag->unlock();
         }
         return $this;
     }
diff --git a/app/code/Magento/ImportExport/Controller/Adminhtml/Export.php b/app/code/Magento/ImportExport/Controller/Adminhtml/Export.php
index 770832a391450e7fdc239197e7ba0778d5b46ee6..1f423a0a46e9533554e6c85d9ad01fa28005d662 100644
--- a/app/code/Magento/ImportExport/Controller/Adminhtml/Export.php
+++ b/app/code/Magento/ImportExport/Controller/Adminhtml/Export.php
@@ -91,6 +91,7 @@ class Export extends \Magento\Backend\App\Action
 
                 return $this->_fileFactory->create(
                     $model->getFileName(),
+                    \Magento\Filesystem::VAR_DIR,
                     $model->export(),
                     $model->getContentType()
                 );
diff --git a/app/code/Magento/Install/view/install/page.phtml b/app/code/Magento/Install/view/install/page.phtml
index 0869785b199e8a9105f97678541bb94f00baa6f9..60bd43b8308e796a66a7bd5e395445dfd7d59528 100644
--- a/app/code/Magento/Install/view/install/page.phtml
+++ b/app/code/Magento/Install/view/install/page.phtml
@@ -40,7 +40,7 @@
 
     <script type="text/javascript" src="<?php echo $this->getViewFileUrl('jquery/jquery.js') ?>"></script>
     <script type="text/javascript" src="<?php echo $this->getViewFileUrl('jquery/jquery-ui.js') ?>"></script>
-    <script type="text/javascript" src="<?php echo $this->getViewFileUrl('head.load.min.js') ?>"></script>
+    <script type="text/javascript" src="<?php echo $this->getViewFileUrl('headjs/head.load.min.js') ?>"></script>
     <script type="text/javascript" src="<?php echo $this->getViewFileUrl('mage/mage.js') ?>"></script>
     <script type="text/javascript" src="<?php echo $this->getViewFileUrl('mage/translate.js') ?>"></script>
 
diff --git a/app/code/Magento/Newsletter/Controller/Adminhtml/Subscriber.php b/app/code/Magento/Newsletter/Controller/Adminhtml/Subscriber.php
index 1016c5d79a8662484380a26964cf7ac6258eeb45..1735bdb1359e6277d745d0269591d988518b9f1b 100644
--- a/app/code/Magento/Newsletter/Controller/Adminhtml/Subscriber.php
+++ b/app/code/Magento/Newsletter/Controller/Adminhtml/Subscriber.php
@@ -82,7 +82,7 @@ class Subscriber extends \Magento\Backend\App\Action
         $fileName = 'subscribers.csv';
         $content = $this->_view->getLayout()->getChildBlock('adminhtml.newslettrer.subscriber.grid', 'grid.export');
 
-        return $this->_fileFactory->create($fileName, $content->getCsvFile($fileName));
+        return $this->_fileFactory->create($fileName, $content->getCsvFile($fileName), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -93,7 +93,7 @@ class Subscriber extends \Magento\Backend\App\Action
         $this->_view->loadLayout();
         $fileName = 'subscribers.xml';
         $content = $this->_view->getLayout()->getChildBlock('adminhtml.newslettrer.subscriber.grid', 'grid.export');
-        return $this->_fileFactory->create($fileName, $content->getExcelFile($fileName));
+        return $this->_fileFactory->create($fileName, $content->getExcelFile($fileName), \Magento\Filesystem::VAR_DIR);
     }
 
     public function massUnsubscribeAction()
diff --git a/app/code/Magento/Paygate/view/frontend/info/cc.phtml b/app/code/Magento/Paygate/view/frontend/info/cc.phtml
index 5c722a71191d794149a78077679285ecfa13de9d..6d818bec2cabd0bf9478715adf3b436d83e86ad8 100644
--- a/app/code/Magento/Paygate/view/frontend/info/cc.phtml
+++ b/app/code/Magento/Paygate/view/frontend/info/cc.phtml
@@ -27,30 +27,28 @@
 
 <?php if (!$this->getHideTitle()): ?>
     <p><strong><?php echo $this->escapeHtml($this->getMethod()->getTitle()) ?></strong></p>
-<?php endif;?>
+<?php endif; ?>
 
 <?php
     $cards = $this->getCards();
     $showCount = count($cards) > 1;
 ?>
 
-<dl class="cards-list">
+<dl class="cards items">
 <?php foreach ($cards as $key => $card): ?>
+
     <?php if ($showCount): ?>
         <dt><?php echo sprintf(__('Credit Card %s'), $key + 1); ?></dt>
-    <?php endif;?>
+    <?php endif; ?>
 
-    <dd <?php if ($showCount):?> class="offset"<?php endif;?>>
-    <table class="info-table">
-        <tbody>
-        <?php foreach ($card as $_label => $_value):?>
-        <tr>
-            <th><?php echo $this->escapeHtml($_label)?>:</th>
-            <td><?php echo nl2br(implode($this->getValueAsArray($_value, true), "\n"))?></td>
-        </tr>
+    <dd>
+        <dl class="card item">
+        <?php foreach ($card as $_label => $_value): ?>
+            <dt><?php echo $this->escapeHtml($_label); ?>:</dt>
+            <dd><?php echo nl2br(implode($this->getValueAsArray($_value, true), "\n")); ?></dd>
         <?php endforeach; ?>
-        </tbody>
-    </table>
+        </dl>
     </dd>
+
 <?php endforeach; ?>
 </dl>
diff --git a/app/code/Magento/Payment/view/adminhtml/form/cc.phtml b/app/code/Magento/Payment/view/adminhtml/form/cc.phtml
index 740d205c29e2618d70d9618ff3cf0b90e8e69db4..a959fe651697589bbccb3985e587fc2eaef6dfe7 100644
--- a/app/code/Magento/Payment/view/adminhtml/form/cc.phtml
+++ b/app/code/Magento/Payment/view/adminhtml/form/cc.phtml
@@ -25,93 +25,95 @@
  */
 ?>
 <?php $_code=$this->getMethodCode() ?>
-<ul id="payment_form_<?php echo $_code ?>" style="display:none">
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_type"><?php echo __('Credit Card Type') ?> <span class="required">*</span></label><br/>
+<fieldset class="fieldset payment method" id="payment_form_<?php echo $_code ?>" style="display:none">
+    <div class="field field-type required">
+        <label class="label" for="<?php echo $_code ?>_cc_type"><span><?php echo __('Credit Card Type') ?></span></label>
+        <div class="control">
             <select id="<?php echo $_code ?>_cc_type" name="payment[cc_type]" class="required-entry validate-cc-type-select">
-            <?php $_ccType = $this->getInfoData('cc_type') ?>
+                <?php $_ccType = $this->getInfoData('cc_type') ?>
                 <option value=""></option>
-            <?php foreach ($this->getCcAvailableTypes() as $_typeCode => $_typeName): ?>
-                <option value="<?php echo $_typeCode ?>" <?php if($_typeCode==$_ccType): ?>selected="selected"<?php endif ?>><?php echo $_typeName ?></option>
-            <?php endforeach ?>
+                <?php foreach ($this->getCcAvailableTypes() as $_typeCode => $_typeName): ?>
+                    <option value="<?php echo $_typeCode ?>" <?php if($_typeCode==$_ccType): ?>selected="selected"<?php endif ?>><?php echo $_typeName ?></option>
+                <?php endforeach ?>
             </select>
         </div>
-    </li>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_number"><?php echo __('Credit Card Number') ?> <span class="required">*</span></label><br/>
+    </div>
+    <div class="field field-number required">
+        <label  class="label" for="<?php echo $_code ?>_cc_number"><span><?php echo __('Credit Card Number') ?></span></label>
+        <div class="control">
             <input type="text" id="<?php echo $_code ?>_cc_number" name="payment[cc_number]" title="<?php echo __('Credit Card Number') ?>" class="input-text validate-cc-number" value="<?php echo $this->getInfoData('cc_number')?>"/>
         </div>
-    </li>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_expiration"><?php echo __('Expiration Date') ?> <span class="required">*</span></label><br/>
+    </div>
+    <div class="field field-date required">
+        <label class="label" for="<?php echo $_code ?>_expiration"><span><?php echo __('Expiration Date') ?></span></label>
+        <div class="control">
             <select id="<?php echo $_code ?>_expiration" style="width:140px;" name="payment[cc_exp_month]" class="validate-cc-exp required-entry">
-            <?php $_ccExpMonth = $this->getInfoData('cc_exp_month') ?>
-            <?php foreach ($this->getCcMonths() as $k=>$v): ?>
-                <option value="<?php echo $k ?>" <?php if($k==$_ccExpMonth): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
-            <?php endforeach ?>
+                <?php $_ccExpMonth = $this->getInfoData('cc_exp_month') ?>
+                <?php foreach ($this->getCcMonths() as $k=>$v): ?>
+                    <option value="<?php echo $k ?>" <?php if($k==$_ccExpMonth): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
+                <?php endforeach ?>
             </select>
             <?php $_ccExpYear = $this->getInfoData('cc_exp_year') ?>
             <select id="<?php echo $_code ?>_expiration_yr" style="width:103px;" name="payment[cc_exp_year]" class="required-entry">
-            <?php foreach ($this->getCcYears() as $k=>$v): ?>
-                <option value="<?php echo $k ? $k : '' ?>" <?php if($k==$_ccExpYear): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
-            <?php endforeach ?>
+                <?php foreach ($this->getCcYears() as $k=>$v): ?>
+                    <option value="<?php echo $k ? $k : '' ?>" <?php if($k==$_ccExpYear): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
+                <?php endforeach ?>
             </select>
         </div>
-    </li>
+    </div>
+
     <?php if($this->hasVerification()): ?>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_cid"><?php echo __('Card Verification Number') ?> <span class="required">*</span></label><br/>
-            <input type="text" title="<?php echo __('Card Verification Number') ?>" class="required-entry input-text validate-cc-cvn" id="<?php echo $_code ?>_cc_cid" name="payment[cc_cid]" style="width:3em;" value="<?php echo $this->getInfoData('cc_cid')?>"/>
+        <div class="field field-number required">
+            <label class="label" for="<?php echo $_code ?>_cc_cid"><span><?php echo __('Card Verification Number') ?></span></label>
+            <div class="control">
+                <input type="text" title="<?php echo __('Card Verification Number') ?>" class="required-entry input-text validate-cc-cvn" id="<?php echo $_code ?>_cc_cid" name="payment[cc_cid]" style="width:3em;" value="<?php echo $this->getInfoData('cc_cid')?>"/>
+            </div>
         </div>
-    </li>
     <?php endif; ?>
 
     <?php if ($this->hasSsCardType()): ?>
-    <li id="<?php echo $_code ?>_cc_type_ss_div">
-        <ul class="inner-form">
-            <li class="form-alt"><label for="<?php echo $_code ?>_cc_issue" class="required"><em>*</em><?php echo __('Switch/Solo/Maestro Only') ?></label></li>
-            <li>
-                <label for="<?php echo $_code ?>_cc_issue"><?php echo __('Issue Number') ?>:</label>
-                <span class="input-box">
+        <div id="<?php echo $_code ?>_cc_type_ss_div">
+            <div class="field field-type required">
+                <label class="label" for="<?php echo $_code ?>_cc_issue"><span><?php echo __('Switch/Solo/Maestro Only') ?></span></label>
+            </div>
+            <div class="field field-issue">
+                <label class="label" for="<?php echo $_code ?>_cc_issue"><span><?php echo __('Issue Number') ?>:</span></label>
+                <div class="control">
                     <input type="text" title="<?php echo __('Issue Number') ?>" class="input-text validate-cc-ukss cvv" id="<?php echo $_code ?>_cc_issue" name="payment[cc_ss_issue]" value="" />
-                </span>
-            </li>
-
-            <li>
-                <label for="<?php echo $_code ?>_start_month"><?php echo __('Start Date') ?>:</label>
-                <div class="input-box">
-                        <select id="<?php echo $_code ?>_start_month" name="payment[cc_ss_start_month]" class="validate-cc-ukss month">
+                </div>
+            </div>
+            <div class="field field-date">
+                <label class="label" for="<?php echo $_code ?>_start_month"><span><?php echo __('Start Date') ?>:</span></label>
+                <div class="control">
+                    <select id="<?php echo $_code ?>_start_month" name="payment[cc_ss_start_month]" class="validate-cc-ukss month">
                         <?php foreach ($this->getCcMonths() as $k=>$v): ?>
                             <option value="<?php echo $k?$k:'' ?>"<?php if($k==$this->getInfoData('cc_ss_start_month')): ?> selected="selected"<?php endif ?>><?php echo $v ?></option>
                         <?php endforeach ?>
-                        </select>
-                        <select id="<?php echo $_code ?>_start_year" name="payment[cc_ss_start_year]" class="validate-cc-ukss year">
+                    </select>
+                    <select id="<?php echo $_code ?>_start_year" name="payment[cc_ss_start_year]" class="validate-cc-ukss year">
                         <?php foreach ($this->getSsStartYears() as $k=>$v): ?>
                             <option value="<?php echo $k?$k:'' ?>"<?php if($k==$this->getInfoData('cc_ss_start_year')): ?> selected="selected"<?php endif ?>><?php echo $v ?></option>
                         <?php endforeach ?>
-                        </select>
+                    </select>
                 </div>
-            </li>
-            <li class="adv-container">&nbsp;</li>
-        </ul>
-        <script type="text/javascript">
-        //<![CDATA[
-        var SSChecked<?php echo $_code ?> = function() {
-            var elm = $('<?php echo $_code ?>_cc_type');
-            if (['SS','SM','SO'].indexOf(elm.value) != -1) {
-                $('<?php echo $_code ?>_cc_type_ss_div').show();
-            } else {
-                $('<?php echo $_code ?>_cc_type_ss_div').hide();
-            }
-        };
-        Event.observe($('<?php echo $_code ?>_cc_type'), 'change', SSChecked<?php echo $_code ?>);
-        SSChecked<?php echo $_code ?>();
-        //]]>
-        </script>
-    </li>
+            </div>
+
+            <div class="adv-container">&nbsp;</div>
+
+            <script type="text/javascript">
+                //<![CDATA[
+                var SSChecked<?php echo $_code ?> = function() {
+                    var elm = $('<?php echo $_code ?>_cc_type');
+                    if (['SS','SM','SO'].indexOf(elm.value) != -1) {
+                        $('<?php echo $_code ?>_cc_type_ss_div').show();
+                    } else {
+                        $('<?php echo $_code ?>_cc_type_ss_div').hide();
+                    }
+                };
+                Event.observe($('<?php echo $_code ?>_cc_type'), 'change', SSChecked<?php echo $_code ?>);
+                SSChecked<?php echo $_code ?>();
+                //]]>
+            </script>
+        </div>
     <?php endif; ?>
-</ul>
+</fieldset>
diff --git a/app/code/Magento/Payment/view/adminhtml/form/ccsave.phtml b/app/code/Magento/Payment/view/adminhtml/form/ccsave.phtml
index 02ed20f1d74647a73827ca6f82433c88cce8e42e..f6d632f930b6732e2255a1cd30b07906fdac166e 100644
--- a/app/code/Magento/Payment/view/adminhtml/form/ccsave.phtml
+++ b/app/code/Magento/Payment/view/adminhtml/form/ccsave.phtml
@@ -25,98 +25,106 @@
  */
 ?>
 <?php $_code=$this->getMethodCode() ?>
-<ul id="payment_form_<?php echo $_code ?>" style="display:none">
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_owner"><?php echo __('Name on Card') ?> <span class="required">*</span></label><br/>
+<fieldset class="fieldset payment method" id="payment_form_<?php echo $_code ?>" style="display:none">
+    <div class="field field-name required">
+        <label class="label" for="<?php echo $_code ?>_cc_owner"><span><?php echo __('Name on Card') ?></span></label>
+        <div class="control">
             <input type="text" title="<?php echo __('Name on Card') ?>" class="required-entry input-text" id="<?php echo $_code ?>_cc_owner" name="payment[cc_owner]" value="<?php echo $this->getInfoData('cc_owner') ?>"/>
         </div>
-    </li>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_type"><?php echo __('Credit Card Type') ?> <span class="required">*</span></label><br/>
+    </div>
+
+    <div class="field field-type required">
+        <label class="label" for="<?php echo $_code ?>_cc_type"><span><?php echo __('Credit Card Type') ?></span></label>
+        <div class="control">
             <select id="<?php echo $_code ?>_cc_type" name="payment[cc_type]" class="required-entry validate-cc-type-select">
-            <?php $_ccType = $this->getInfoData('cc_type') ?>
+                <?php $_ccType = $this->getInfoData('cc_type') ?>
                 <option value=""></option>
-            <?php foreach ($this->getCcAvailableTypes() as $_typeCode => $_typeName): ?>
-                <option value="<?php echo $_typeCode ?>" <?php if($_typeCode==$_ccType): ?>selected="selected"<?php endif ?>><?php echo $_typeName ?></option>
-            <?php endforeach ?>
+                <?php foreach ($this->getCcAvailableTypes() as $_typeCode => $_typeName): ?>
+                    <option value="<?php echo $_typeCode ?>" <?php if($_typeCode==$_ccType): ?>selected="selected"<?php endif ?>><?php echo $_typeName ?></option>
+                <?php endforeach ?>
             </select>
         </div>
-    </li>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_number"><?php echo __('Credit Card Number') ?> <span class="required">*</span></label><br/>
+    </div>
+
+    <div class="field field-number required">
+        <label class="label" for="<?php echo $_code ?>_cc_number"><span><?php echo __('Credit Card Number') ?></span></label>
+        <div class="control">
             <input type="text" id="<?php echo $_code ?>_cc_number" name="payment[cc_number]" title="<?php echo __('Credit Card Number') ?>" class="input-text validate-cc-number" value="<?php echo $this->getInfoData('cc_number')?>"/>
         </div>
-    </li>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_expiration"><?php echo __('Expiration Date') ?> <span class="required">*</span></label><br/>
+    </div>
+
+    <div class="field field-date required">
+        <label class="label" for="<?php echo $_code ?>_expiration"><span><?php echo __('Expiration Date') ?></span></label>
+        <div class="control">
             <select id="<?php echo $_code ?>_expiration" style="width:140px;" name="payment[cc_exp_month]" class="validate-cc-exp required-entry">
-            <?php $_ccExpMonth = $this->getInfoData('cc_exp_month') ?>
-            <?php foreach ($this->getCcMonths() as $k=>$v): ?>
-                <option value="<?php echo $k ?>" <?php if($k==$_ccExpMonth): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
-            <?php endforeach ?>
+                <?php $_ccExpMonth = $this->getInfoData('cc_exp_month') ?>
+                <?php foreach ($this->getCcMonths() as $k=>$v): ?>
+                    <option value="<?php echo $k ?>" <?php if($k==$_ccExpMonth): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
+                <?php endforeach ?>
             </select>
             <?php $_ccExpYear = $this->getInfoData('cc_exp_year') ?>
             <select id="<?php echo $_code ?>_expiration_yr" style="width:103px;" name="payment[cc_exp_year]" class="required-entry">
-            <?php foreach ($this->getCcYears() as $k=>$v): ?>
-                <option value="<?php echo $k ? $k : '' ?>" <?php if($k==$_ccExpYear): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
-            <?php endforeach ?>
+                <?php foreach ($this->getCcYears() as $k=>$v): ?>
+                    <option value="<?php echo $k ? $k : '' ?>" <?php if($k==$_ccExpYear): ?>selected="selected"<?php endif ?>><?php echo $v ?></option>
+                <?php endforeach ?>
             </select>
         </div>
-    </li>
+    </div>
+
     <?php if($this->hasVerification()): ?>
-    <li>
-        <div class="input-box">
-            <label for="<?php echo $_code ?>_cc_cid"><?php echo __('Card Verification Number') ?> <span class="required">*</span></label><br/>
-            <input type="text" title="<?php echo __('Card Verification Number') ?>" class="required-entry input-text validate-cc-cvn" id="<?php echo $_code ?>_cc_cid" name="payment[cc_cid]" style="width:3em;" value="<?php echo $this->getInfoData('cc_cid')?>"/>
+        <div class="field field-number required">
+            <label class="label" for="<?php echo $_code ?>_cc_cid"><span><?php echo __('Card Verification Number') ?></span></label>
+            <div class="control">
+                <input type="text" title="<?php echo __('Card Verification Number') ?>" class="required-entry input-text validate-cc-cvn" id="<?php echo $_code ?>_cc_cid" name="payment[cc_cid]" style="width:3em;" value="<?php echo $this->getInfoData('cc_cid')?>"/>
+            </div>
         </div>
-    </li>
     <?php endif; ?>
+
     <?php if ($this->hasSsCardType()): ?>
-    <li id="<?php echo $_code ?>_cc_type_ss_div">
-        <ul class="inner-form">
-            <li class="form-alt"><label for="<?php echo $_code ?>_cc_issue" class="required"><em>*</em><?php echo __('Switch/Solo/Maestro Only') ?></label></li>
-            <li>
-                <label for="<?php echo $_code ?>_cc_issue"><?php echo __('Issue Number') ?>:</label>
-                <span class="input-box">
+        <div id="<?php echo $_code ?>_cc_type_ss_div">
+            <div class="field field-type required">
+                <label for="<?php echo $_code ?>_cc_issue"><span><?php echo __('Switch/Solo/Maestro Only') ?></span></label>
+            </div>
+
+            <div class="field field-issue">
+                <label class="label" for="<?php echo $_code ?>_cc_issue"><span><?php echo __('Issue Number') ?>:</span></label>
+                <div class="control">
                     <input type="text" title="<?php echo __('Issue Number') ?>" class="input-text validate-cc-ukss cvv" id="<?php echo $_code ?>_cc_issue" name="payment[cc_ss_issue]" value="" />
-                </span>
-            </li>
+                </div>
+            </div>
 
-            <li>
-                <label for="<?php echo $_code ?>_start_month"><?php echo __('Start Date') ?>:</label>
-                <div class="input-box">
-                        <select id="<?php echo $_code ?>_start_month" name="payment[cc_ss_start_month]" class="validate-cc-ukss month">
+            <div class="field field-date">
+                <label class="label" for="<?php echo $_code ?>_start_month"><span><?php echo __('Start Date') ?>:</span></label>
+                <div class="control">
+                    <select id="<?php echo $_code ?>_start_month" name="payment[cc_ss_start_month]" class="validate-cc-ukss month">
                         <?php foreach ($this->getCcMonths() as $k=>$v): ?>
                             <option value="<?php echo $k?$k:'' ?>"<?php if($k==$this->getInfoData('cc_ss_start_month')): ?> selected="selected"<?php endif ?>><?php echo $v ?></option>
                         <?php endforeach ?>
-                        </select>
-                        <select id="<?php echo $_code ?>_start_year" name="payment[cc_ss_start_year]" class="validate-cc-ukss year">
+                    </select>
+                    <select id="<?php echo $_code ?>_start_year" name="payment[cc_ss_start_year]" class="validate-cc-ukss year">
                         <?php foreach ($this->getSsStartYears() as $k=>$v): ?>
                             <option value="<?php echo $k?$k:'' ?>"<?php if($k==$this->getInfoData('cc_ss_start_year')): ?> selected="selected"<?php endif ?>><?php echo $v ?></option>
                         <?php endforeach ?>
-                        </select>
+                    </select>
                 </div>
-            </li>
-            <li class="adv-container">&nbsp;</li>
-        </ul>
-        <script type="text/javascript">
-        //<![CDATA[
-        var SSChecked<?php echo $_code ?> = function() {
-            var elm = $('<?php echo $_code ?>_cc_type');
-            if (['SS','SM','SO'].indexOf(elm.value) != -1) {
-                $('<?php echo $_code ?>_cc_type_ss_div').show();
-            } else {
-                $('<?php echo $_code ?>_cc_type_ss_div').hide();
-            }
-        };
-        Event.observe($('<?php echo $_code ?>_cc_type'), 'change', SSChecked<?php echo $_code ?>);
-        SSChecked<?php echo $_code ?>();
-        //]]>
-        </script>
-    </li>
+            </div>
+
+            <div class="adv-container">&nbsp;</div>
+
+            <script type="text/javascript">
+                //<![CDATA[
+                var SSChecked<?php echo $_code ?> = function() {
+                    var elm = $('<?php echo $_code ?>_cc_type');
+                    if (['SS','SM','SO'].indexOf(elm.value) != -1) {
+                        $('<?php echo $_code ?>_cc_type_ss_div').show();
+                    } else {
+                        $('<?php echo $_code ?>_cc_type_ss_div').hide();
+                    }
+                };
+                Event.observe($('<?php echo $_code ?>_cc_type'), 'change', SSChecked<?php echo $_code ?>);
+                SSChecked<?php echo $_code ?>();
+                //]]>
+            </script>
+        </div>
     <?php endif; ?>
-</ul>
+</fieldset>
diff --git a/app/code/Magento/Payment/view/adminhtml/form/checkmo.phtml b/app/code/Magento/Payment/view/adminhtml/form/checkmo.phtml
index e4d1417abdf5567822f0e6a0ae62a78bda38d637..9f5d0cc4517fd21b32069b878a63993158381ab1 100644
--- a/app/code/Magento/Payment/view/adminhtml/form/checkmo.phtml
+++ b/app/code/Magento/Payment/view/adminhtml/form/checkmo.phtml
@@ -24,18 +24,16 @@
  * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
  */
 ?>
-<ul id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none">
-    <li>
-        <div class="input-box">
-            <?php if ($this->getMethod()->getPayableTo()): ?>
-                <?php echo __('<label>Make Check payable to:</label> %1', $this->escapeHtml($this->getMethod()->getPayableTo())) ?><br />
-            <?php endif; ?>
-            <?php if ($this->getMethod()->getMailingAddress()): ?>
-                <label><?php echo __('Send Check to:') ?></label>
-                <div class="checkmo-mailing-address">
-                    <?php echo nl2br($this->escapeHtml($this->getMethod()->getMailingAddress())) ?>
-                </div>
-            <?php endif; ?>
+<fieldset class="fieldset payment method" id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none">
+    <?php if ($this->getMethod()->getPayableTo()): ?>
+        <?php echo __('<label class="label"><span>Make Check payable to:</span></label> %1', $this->escapeHtml($this->getMethod()->getPayableTo())) ?>
+    <?php endif; ?>
+    <?php if ($this->getMethod()->getMailingAddress()): ?>
+        <div class="field field-check">
+            <label class="label"><span><?php echo __('Send Check to:') ?></span></label>
+            <div class="control checkmo-mailing-address">
+                <?php echo nl2br($this->escapeHtml($this->getMethod()->getMailingAddress())) ?>
+            </div>
         </div>
-    </li>
-</ul>
+    <?php endif; ?>
+</fieldset>
diff --git a/app/code/Magento/Payment/view/adminhtml/form/purchaseorder.phtml b/app/code/Magento/Payment/view/adminhtml/form/purchaseorder.phtml
index 907cff225fd257e716f8add2b328c3fca38e942f..51675035d87ff5b3e7b5a80205890da6b3f61cc0 100644
--- a/app/code/Magento/Payment/view/adminhtml/form/purchaseorder.phtml
+++ b/app/code/Magento/Payment/view/adminhtml/form/purchaseorder.phtml
@@ -24,11 +24,11 @@
  * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
  */
 ?>
-<ul id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none">
-    <li>
-        <div class="input-box">
-            <label for="po_number"><?php echo __('Purchase Order Number') ?> <span class="required">*</span></label><br/>
+<fieldset class="fieldset payment method" id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none">
+    <div class="field field-number required">
+        <label for="po_number" class="label"><span><?php echo __('Purchase Order Number') ?></span></label>
+        <div class="control">
             <input type="text" id="po_number" name="payment[po_number]" title="<?php echo __("Purchase Order Number") ?>" class="required-entry input-text" value="<?php echo $this->getInfoData('po_number') ?>"/>
         </div>
-    </li>
-</ul>
+    </div>
+</fieldset>
\ No newline at end of file
diff --git a/app/code/Magento/Reports/Controller/Adminhtml/Index.php b/app/code/Magento/Reports/Controller/Adminhtml/Index.php
index 3b320b9e8ee6c7254540d13aa45a3d84bcd71a6b..bfe3bf7a9bccf34693ce194729b7d9098b9ee215 100644
--- a/app/code/Magento/Reports/Controller/Adminhtml/Index.php
+++ b/app/code/Magento/Reports/Controller/Adminhtml/Index.php
@@ -79,7 +79,7 @@ class Index extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $content = $this->_view->getLayout()->getChildBlock('adminhtml.report.search.grid', 'grid.export');
-        return $this->_fileFactory->create('search.csv', $content->getCsvFile());
+        return $this->_fileFactory->create('search.csv', $content->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -89,7 +89,7 @@ class Index extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $content = $this->_view->getLayout()->getChildBlock('adminhtml.report.search.grid', 'grid.export');
-        return $this->_fileFactory->create('search.xml', $content->getExcelFile());
+        return $this->_fileFactory->create('search.xml', $content->getExcelFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     protected function _isAllowed()
diff --git a/app/code/Magento/Reports/Controller/Adminhtml/Report/Customer.php b/app/code/Magento/Reports/Controller/Adminhtml/Report/Customer.php
index 0edf0e421c85756815ac0d65962bcfc581677e1b..84a840000f8947647c595bc60d8d9875735b2de0 100644
--- a/app/code/Magento/Reports/Controller/Adminhtml/Report/Customer.php
+++ b/app/code/Magento/Reports/Controller/Adminhtml/Report/Customer.php
@@ -94,7 +94,7 @@ class Customer extends \Magento\Backend\App\Action
         $fileName = 'new_accounts.csv';
         /** @var \Magento\Backend\Block\Widget\Grid\ExportInterface $exportBlock  */
         $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.report.grid', 'grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile());
+        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -106,7 +106,11 @@ class Customer extends \Magento\Backend\App\Action
         $fileName = 'new_accounts.xml';
         /** @var \Magento\Backend\Block\Widget\Grid\ExportInterface $exportBlock  */
         $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.report.grid', 'grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile($fileName));
+        return $this->_fileFactory->create(
+            $fileName,
+            $exportBlock->getExcelFile($fileName),
+            \Magento\Filesystem::VAR_DIR
+        );
     }
 
     public function ordersAction()
diff --git a/app/code/Magento/Reports/Controller/Adminhtml/Report/Review.php b/app/code/Magento/Reports/Controller/Adminhtml/Report/Review.php
index 6ef34439d8cc919986c4c4efc2df7ef0cf2d41d4..91d9307fed24da63d85092cd84ad97cc71cdece6 100644
--- a/app/code/Magento/Reports/Controller/Adminhtml/Report/Review.php
+++ b/app/code/Magento/Reports/Controller/Adminhtml/Report/Review.php
@@ -86,8 +86,10 @@ class Review extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $fileName = 'review_customer.csv';
-        $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.block.report.review.customer.grid','grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile());
+        $exportBlock = $this->_view
+            ->getLayout()
+            ->getChildBlock('adminhtml.block.report.review.customer.grid', 'grid.export');
+        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -97,8 +99,10 @@ class Review extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $fileName = 'review_customer.xml';
-        $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.block.report.review.customer.grid','grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile());
+        $exportBlock = $this->_view
+            ->getLayout()
+            ->getChildBlock('adminhtml.block.report.review.customer.grid', 'grid.export');
+        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile(), \Magento\Filesystem::VAR_DIR);
 
     }
 
@@ -109,9 +113,9 @@ class Review extends \Magento\Backend\App\Action
         $this->_initAction()
             ->_setActiveMenu('Magento_Review::report_review_product')
             ->_addBreadcrumb(
-            __('Products Report'),
-            __('Products Report')
-        );
+                __('Products Report'),
+                __('Products Report')
+            );
             $this->_view->renderLayout();
     }
 
@@ -122,8 +126,10 @@ class Review extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $fileName = 'review_product.csv';
-        $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.block.report.review.product.grid','grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile());
+        $exportBlock = $this->_view
+            ->getLayout()
+            ->getChildBlock('adminhtml.block.report.review.product.grid', 'grid.export');
+        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -133,8 +139,10 @@ class Review extends \Magento\Backend\App\Action
     {
         $this->_view->loadLayout(false);
         $fileName = 'review_product.xml';
-        $exportBlock = $this->_view->getLayout()->getChildBlock('adminhtml.block.report.review.product.grid','grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile());
+        $exportBlock = $this->_view
+            ->getLayout()
+            ->getChildBlock('adminhtml.block.report.review.product.grid', 'grid.export');
+        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     public function productDetailAction()
@@ -160,7 +168,7 @@ class Review extends \Magento\Backend\App\Action
         $content    = $this->_view->getLayout()->createBlock('Magento\Reports\Block\Adminhtml\Review\Detail\Grid')
             ->getCsv();
 
-        return $this->_fileFactory->create($fileName, $content);
+        return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -172,7 +180,7 @@ class Review extends \Magento\Backend\App\Action
         $content    = $this->_view->getLayout()->createBlock('Magento\Reports\Block\Adminhtml\Review\Detail\Grid')
             ->getExcel($fileName);
 
-        return $this->_fileFactory->create($fileName, $content);
+        return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
     }
 
     protected function _isAllowed()
diff --git a/app/code/Magento/Reports/Model/Resource/Report/Collection/AbstractCollection.php b/app/code/Magento/Reports/Model/Resource/Report/Collection/AbstractCollection.php
index 9ebf45ed5554175db9463cda31f91356518d6d6b..be5030fb15657a2757fa579ebd557862afd675c1 100644
--- a/app/code/Magento/Reports/Model/Resource/Report/Collection/AbstractCollection.php
+++ b/app/code/Magento/Reports/Model/Resource/Report/Collection/AbstractCollection.php
@@ -185,8 +185,6 @@ class AbstractCollection extends \Magento\Core\Model\Resource\Db\Collection\Abst
             $nullCheck = true;
         }
 
-        $storeIds[0] = ($storeIds[0] == '') ? 0 : $storeIds[0];
-
         if ($nullCheck) {
             $select->where('store_id IN(?) OR store_id IS NULL', $storeIds);
         } else {
diff --git a/app/code/Magento/Sales/Controller/Adminhtml/Creditmemo/AbstractCreditmemo.php b/app/code/Magento/Sales/Controller/Adminhtml/Creditmemo/AbstractCreditmemo.php
index 18092ade67288aa7604a1b2c624c3e739dcef46c..9b703cfebe4409c166b937f87e6b85d4e679c80f 100644
--- a/app/code/Magento/Sales/Controller/Adminhtml/Creditmemo/AbstractCreditmemo.php
+++ b/app/code/Magento/Sales/Controller/Adminhtml/Creditmemo/AbstractCreditmemo.php
@@ -124,11 +124,16 @@ class AbstractCreditmemo extends \Magento\Backend\App\Action
                 $pdf = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Creditmemo')->getPdf($invoices);
             } else {
                 $pages = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Creditmemo')->getPdf($invoices);
-                $pdf->pages = array_merge ($pdf->pages, $pages->pages);
+                $pdf->pages = array_merge($pdf->pages, $pages->pages);
             }
             $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
 
-            return $this->_fileFactory->create('creditmemo' . $date . '.pdf', $pdf->render(), 'application/pdf');
+            return $this->_fileFactory->create(
+                'creditmemo' . $date . '.pdf',
+                $pdf->render(),
+                \Magento\Filesystem::VAR_DIR,
+                'application/pdf'
+            );
         }
         $this->_redirect('sales/*/');
     }
@@ -143,7 +148,12 @@ class AbstractCreditmemo extends \Magento\Backend\App\Action
                 $pdf = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Creditmemo')
                     ->getPdf(array($creditmemo));
                 $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
-                return $this->_fileFactory->create('creditmemo' . $date . '.pdf', $pdf->render(), 'application/pdf');
+                return $this->_fileFactory->create(
+                    'creditmemo' . $date . '.pdf',
+                    $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
+                    'application/pdf'
+                );
             }
         } else {
             $this->_forward('noroute');
diff --git a/app/code/Magento/Sales/Controller/Adminhtml/Invoice/AbstractInvoice.php b/app/code/Magento/Sales/Controller/Adminhtml/Invoice/AbstractInvoice.php
index ff57034fb879fd92092d7ae1807f1bb0c44150ba..282aa1dc44e03e1d2d0145b3fd454b909fbfe695 100644
--- a/app/code/Magento/Sales/Controller/Adminhtml/Invoice/AbstractInvoice.php
+++ b/app/code/Magento/Sales/Controller/Adminhtml/Invoice/AbstractInvoice.php
@@ -130,7 +130,12 @@ class AbstractInvoice
             if ($invoice) {
                 $pdf = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Invoice')->getPdf(array($invoice));
                 $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
-                return $this->_fileFactory->create('invoice' . $date . '.pdf', $pdf->render(), 'application/pdf');
+                return $this->_fileFactory->create(
+                    'invoice' . $date . '.pdf',
+                    $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
+                    'application/pdf'
+                );
             }
         } else {
             $this->_forward('noroute');
@@ -153,7 +158,12 @@ class AbstractInvoice
             }
             $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
 
-            return $this->_fileFactory->create('invoice' . $date . '.pdf', $pdf->render(), 'application/pdf');
+            return $this->_fileFactory->create(
+                'invoice' . $date . '.pdf',
+                $pdf->render(),
+                \Magento\Filesystem::VAR_DIR,
+                'application/pdf'
+            );
         }
         $this->_redirect('sales/*/');
     }
diff --git a/app/code/Magento/Sales/Controller/Adminhtml/Order.php b/app/code/Magento/Sales/Controller/Adminhtml/Order.php
index d1849e99f048c6344103576d162517d3e707b712..e580e81b29eaa239b68cdc0406086cf86edbbb9c 100644
--- a/app/code/Magento/Sales/Controller/Adminhtml/Order.php
+++ b/app/code/Magento/Sales/Controller/Adminhtml/Order.php
@@ -62,7 +62,7 @@ class Order extends \Magento\Backend\App\Action
     protected $_translator;
 
     /**
-     * @param \Magento\Backend\App\Action\Context $context
+     * @param Action\Context $context
      * @param \Magento\Core\Model\Registry $coreRegistry
      * @param \Magento\App\Response\Http\FileFactory $fileFactory
      * @param \Magento\Core\Model\Translate $translator
@@ -529,6 +529,7 @@ class Order extends \Magento\Backend\App\Action
                 return $this->_fileFactory->create(
                     'invoice' . $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s') . '.pdf',
                     $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
                     'application/pdf'
                 );
             } else {
@@ -567,6 +568,7 @@ class Order extends \Magento\Backend\App\Action
                 return $this->_fileFactory->create(
                     'packingslip' . $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s') . '.pdf',
                     $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
                     'application/pdf'
                 );
             } else {
@@ -605,6 +607,7 @@ class Order extends \Magento\Backend\App\Action
                 return $this->_fileFactory->create(
                     'creditmemo' . $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s') . '.pdf',
                     $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
                     'application/pdf'
                 );
             } else {
@@ -669,6 +672,7 @@ class Order extends \Magento\Backend\App\Action
                 return $this->_fileFactory->create(
                     'docs' . $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s') . '.pdf',
                     $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
                     'application/pdf'
                 );
             } else {
@@ -757,7 +761,7 @@ class Order extends \Magento\Backend\App\Action
         $fileName = 'orders.csv';
         /** @var \Magento\Backend\Block\Widget\Grid\ExportInterface $exportBlock  */
         $exportBlock = $this->_view->getLayout()->getChildBlock('sales.order.grid', 'grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile());
+        return $this->_fileFactory->create($fileName, $exportBlock->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -769,7 +773,11 @@ class Order extends \Magento\Backend\App\Action
         $fileName = 'orders.xml';
         /** @var \Magento\Backend\Block\Widget\Grid\ExportInterface $exportBlock  */
         $exportBlock = $this->_view->getLayout()->getChildBlock('sales.order.grid', 'grid.export');
-        return $this->_fileFactory->create($fileName, $exportBlock->getExcelFile($fileName));
+        return $this->_fileFactory->create(
+            $fileName,
+            $exportBlock->getExcelFile($fileName),
+            \Magento\Filesystem::VAR_DIR
+        );
     }
 
     /**
diff --git a/app/code/Magento/Sales/Controller/Adminhtml/Order/Shipment.php b/app/code/Magento/Sales/Controller/Adminhtml/Order/Shipment.php
index 5514f6a2ef7a0b0c07ff9ab802072824ed75842a..051f034840df5e2e4dea29257cb9a76406706818 100644
--- a/app/code/Magento/Sales/Controller/Adminhtml/Order/Shipment.php
+++ b/app/code/Magento/Sales/Controller/Adminhtml/Order/Shipment.php
@@ -584,6 +584,7 @@ class Shipment extends \Magento\Sales\Controller\Adminhtml\Shipment\AbstractShip
                 return $this->_fileFactory->create(
                     'ShippingLabel(' . $shipment->getIncrementId() . ').pdf',
                     $pdfContent,
+                    \Magento\Filesystem::VAR_DIR,
                     'application/pdf'
                 );
             }
@@ -612,6 +613,7 @@ class Shipment extends \Magento\Sales\Controller\Adminhtml\Shipment\AbstractShip
             return $this->_fileFactory->create(
                 'packingslip' . $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s') . '.pdf',
                 $pdf->render(),
+                \Magento\Filesystem::VAR_DIR,
                 'application/pdf'
             );
         } else {
@@ -662,7 +664,12 @@ class Shipment extends \Magento\Sales\Controller\Adminhtml\Shipment\AbstractShip
 
         if (!empty($labelsContent)) {
             $outputPdf = $this->_combineLabelsPdf($labelsContent);
-            return $this->_fileFactory->create('ShippingLabels.pdf', $outputPdf->render(), 'application/pdf');
+            return $this->_fileFactory->create(
+                'ShippingLabels.pdf',
+                $outputPdf->render(),
+                \Magento\Filesystem::VAR_DIR,
+                'application/pdf'
+            );
         }
 
         if ($createdFromOrders) {
diff --git a/app/code/Magento/Sales/Controller/Adminhtml/Shipment/AbstractShipment.php b/app/code/Magento/Sales/Controller/Adminhtml/Shipment/AbstractShipment.php
index c30f0fecdc1c2fa570f2138967ad936d1cff8cf2..15456ce7a7eaa4d28a3cfe8775a27122c53d41da 100644
--- a/app/code/Magento/Sales/Controller/Adminhtml/Shipment/AbstractShipment.php
+++ b/app/code/Magento/Sales/Controller/Adminhtml/Shipment/AbstractShipment.php
@@ -99,10 +99,15 @@ class AbstractShipment extends \Magento\Backend\App\Action
                 $pdf = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Shipment')->getPdf($shipments);
             } else {
                 $pages = $this->_objectManager->create('Magento\Sales\Model\Order\Pdf\Shipment')->getPdf($shipments);
-                $pdf->pages = array_merge ($pdf->pages, $pages->pages);
+                $pdf->pages = array_merge($pdf->pages, $pages->pages);
             }
             $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
-            return $this->_fileFactory->create('packingslip' . $date . '.pdf', $pdf->render(), 'application/pdf');
+            return $this->_fileFactory->create(
+                'packingslip' . $date . '.pdf',
+                $pdf->render(),
+                \Magento\Filesystem::VAR_DIR,
+                'application/pdf'
+            );
         }
         $this->_redirect('sales/*/');
     }
@@ -118,7 +123,10 @@ class AbstractShipment extends \Magento\Backend\App\Action
                     ->getPdf(array($shipment));
                 $date = $this->_objectManager->get('Magento\Core\Model\Date')->date('Y-m-d_H-i-s');
                 return $this->_fileFactory->create(
-                    'packingslip' . $date . '.pdf', $pdf->render(), 'application/pdf'
+                    'packingslip' . $date . '.pdf',
+                    $pdf->render(),
+                    \Magento\Filesystem::VAR_DIR,
+                    'application/pdf'
                 );
             }
         } else {
diff --git a/app/code/Magento/Sales/Controller/Download.php b/app/code/Magento/Sales/Controller/Download.php
index 9753e8f62a77d7bd25c47bafffe77df3d4005bc6..14c38e37d5fc5facfa7b0729a6c3ac8271f45fd2 100644
--- a/app/code/Magento/Sales/Controller/Download.php
+++ b/app/code/Magento/Sales/Controller/Download.php
@@ -93,10 +93,14 @@ class Download extends \Magento\App\Action\Action
                     throw new \Exception();
                 }
             }
-            $this->_fileResponseFactory->create($info['title'], array(
-               'value' => $filePath,
-               'type'  => 'filename'
-            ));
+            $this->_fileResponseFactory->create(
+                $info['title'],
+                array(
+                    'value' => $filePath,
+                    'type'  => 'filename'
+                ),
+                \Magento\Filesystem::ROOT
+            );
         } catch (\Exception $e) {
             $this->_forward('noroute');
         }
diff --git a/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/form.phtml b/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/form.phtml
index d55a002445a2a3f460a2ab23e3105a7b508f30b3..10a7347f03ff5805aeda481961cfd3d4734a7677 100644
--- a/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/form.phtml
+++ b/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/form.phtml
@@ -27,13 +27,19 @@
 <form id="edit_form" method="post" action="<?php echo $this->getSaveUrl() ?>">
     <?php echo $this->getBlockHtml('formkey')?>
     <?php  $_order = $this->getCreditmemo()->getOrder() ?>
+
     <?php echo $this->getChildHtml('order_info') ?>
+
+    <?php if (!$_order->getIsVirtual()): ?>
     <div class="clearfix">
+    <?php endif; ?>
+
         <?php if (!$_order->getIsVirtual()): ?>
         <div class="order-payment-method">
         <?php else: ?>
         <div class="order-payment-method order-payment-method-virtual">
         <?php endif; ?>
+
             <?php /* Billing Address */ ?>
             <div class="fieldset-wrapper">
                 <div class="fieldset-wrapper-title">
@@ -46,7 +52,9 @@
                 <label for="creditmemo_do_refund" class="normal"><?php echo __('Refund Amount') ?></label>
                 <?php endif;*/ ?>
             </div>
+
         </div>
+
         <?php if (!$_order->getIsVirtual()): ?>
         <div class="order-shipping-address">
             <?php /* Shipping Address */ ?>
@@ -75,9 +83,10 @@
             </div>
         </div>
         <?php endif; ?>
-    </div>
+
+    </div><?php /* opening div can be in app\code\Magento\Sales\view\adminhtml\order\view\info.phtml or above */?>
 
     <div id="creditmemo_item_container">
-      <?php echo $this->getChildHtml('order_items') ?>
+        <?php echo $this->getChildHtml('order_items') ?>
     </div>
 </form>
diff --git a/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/items.phtml b/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/items.phtml
index c3f9ed7e23c769fccd411e440c0481b4485933e7..784a7669f9b53621d11999f910ed4d8fc3098cd4 100644
--- a/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/items.phtml
+++ b/app/code/Magento/Sales/view/adminhtml/order/creditmemo/create/items.phtml
@@ -25,10 +25,12 @@
  */
 ?>
 <?php $_items = $this->getCreditmemo()->getAllItems() ?>
+
 <div class="fieldset-wrapper">
     <div class="fieldset-wrapper-title">
         <span class="title"><?php echo __('Items to Refund') ?></span>
     </div>
+
     <?php if (count($_items)) : ?>
     <div class="grid">
         <table cellspacing="0" class="data order-tables">
@@ -67,16 +69,21 @@
             <?php endforeach; ?>
         </table>
     </div>
-
     <?php else : ?>
     <div class="no-items">
         <?php echo __('No Items To Refund') ?>
     </div>
-<?php endif; ?>
+    <?php endif; ?>
 </div>
+
+<?php $orderTotalBar = $this->getChildHtml('order_totalbar'); ?>
+
+<?php if (!empty($orderTotalBar)): ?>
 <div class="fieldset-wrapper">
-    <?php echo $this->getChildHtml('order_totalbar') ?>
+    <?php echo $orderTotalBar; ?>
 </div>
+<?php endif; ?>
+
 <div class="clearfix">
     <input type="hidden" name="creditmemo[do_offline]" id="creditmemo_do_offline" value="0" />
     <div class="order-comments-history">
diff --git a/app/code/Magento/Sales/view/adminhtml/order/invoice/create/items.phtml b/app/code/Magento/Sales/view/adminhtml/order/invoice/create/items.phtml
index cce963b9c96aeca35d4c9b9ca3c8462a1adbf568..925d811bc5dd918641ee1da4dcb65b9bf74853c6 100644
--- a/app/code/Magento/Sales/view/adminhtml/order/invoice/create/items.phtml
+++ b/app/code/Magento/Sales/view/adminhtml/order/invoice/create/items.phtml
@@ -24,6 +24,7 @@
  * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
  */
 ?>
+
 <div class="fieldset-wrapper">
     <div class="fieldset-wrapper-title">
         <?php $_itemsGridLabel = $this->getForcedShipmentCreate()?'Items to Invoice and Ship':'Items to Invoice'; ?>
@@ -63,9 +64,15 @@
         </table>
     </div>
 </div>
+
+<?php $orderTotalBar = $this->getChildHtml('order_totalbar'); ?>
+
+<?php if (!empty($orderTotalBar)): ?>
 <div class="fieldset-wrapper">
-    <?php echo $this->getChildHtml('order_totalbar') ?>
+    <?php echo $orderTotalBar; ?>
 </div>
+<?php endif; ?>
+
 <div class="clearfix">
     <div class="order-comments-history">
         <div class="fieldset-wrapper">
@@ -78,6 +85,7 @@
             </div>
         </div>
     </div>
+
     <div class="order-totals">
         <div class="fieldset-wrapper" id="invoice_totals">
             <div class="fieldset-wrapper-title">
diff --git a/app/code/Magento/Sales/view/adminhtml/order/view/info.phtml b/app/code/Magento/Sales/view/adminhtml/order/view/info.phtml
index 17e539db5d18f9e69a2b5158180f566a450f6a92..68cafe39a1500232199ec6b6e13d2c69530daefc 100644
--- a/app/code/Magento/Sales/view/adminhtml/order/view/info.phtml
+++ b/app/code/Magento/Sales/view/adminhtml/order/view/info.phtml
@@ -183,4 +183,11 @@ $orderStoreDate = $this->formatDate($_order->getCreatedAtStoreDate(), 'medium',
 </div>
     <?php endif; ?>
 
-<?php /* closing div of this opening div are in app\code\Magento\Sales\view\adminhtml\order\invoice\view\form.phtml */?>
+<?php
+/*
+    closing div of this opening div are in
+    app\code\Magento\Sales\view\adminhtml\order\invoice\view\form.phtml
+    or
+    app\code\Magento\Sales\view\adminhtml\order\view\tab\info.phtml
+*/
+?>
\ No newline at end of file
diff --git a/app/code/Magento/Sales/view/adminhtml/order/view/tab/info.phtml b/app/code/Magento/Sales/view/adminhtml/order/view/tab/info.phtml
index 3cee82a4fee82e7c8e45e27e5d064f687aef1b90..d602315e91b7c3308fc74c9b16872ef48bab9591 100644
--- a/app/code/Magento/Sales/view/adminhtml/order/view/tab/info.phtml
+++ b/app/code/Magento/Sales/view/adminhtml/order/view/tab/info.phtml
@@ -26,14 +26,18 @@
 ?>
 <?php /** @var $this \Magento\Sales\Block\Adminhtml\Order\View\Tab\Info */ ?>
 <?php $_order = $this->getOrder() ?>
+
 <div id="order-messages">
-        <?php echo $this->getChildHtml('order_messages') ?>
-    </div>
-    <?php echo $this->getChildHtml('order_info') ?>
-    <input type="hidden" name="order_id" value="<?php echo $_order->getId() ?>"/>
+    <?php echo $this->getChildHtml('order_messages') ?>
+</div>
+
+<?php echo $this->getChildHtml('order_info') ?>
+<input type="hidden" name="order_id" value="<?php echo $_order->getId() ?>"/>
+
 <?php if (!$_order->getIsVirtual()): ?>
 <div class="clearfix">
 <?php endif; ?>
+
     <div class="order-payment-method<?php if ($_order->getIsVirtual()): ?> order-payment-method-virtual<?php endif; ?>">
         <?php /* Payment Method */ ?>
         <div class="fieldset-wrapper">
@@ -44,6 +48,11 @@
             <div class="order-payment-currency"><?php echo __('The order was placed using %1.', $_order->getOrderCurrencyCode()) ?></div>
         </div>
     </div>
+
+<?php if ($_order->getIsVirtual()): ?>
+</div><?php /* opening div is in app\code\Magento\Sales\view\adminhtml\order\view\info.phtml */ ?>
+<?php endif; ?>
+
     <?php if (!$_order->getIsVirtual()): ?>
     <div class="order-shipping-method">
         <!--Shipping Method-->
@@ -76,16 +85,20 @@
         </div>
     </div>
     <?php endif; ?>
+
 <?php if (!$_order->getIsVirtual()): ?>
 </div>
 <?php endif; ?>
-    <?php echo $this->getGiftOptionsHtml() ?>
-    <div class="fieldset-wrapper">
-        <div class="fieldset-wrapper-title">
-            <span class="title"><?php echo __('Items Ordered') ?></span>
-        </div>
-        <?php echo $this->getItemsHtml() ?>
+
+<?php echo $this->getGiftOptionsHtml() ?>
+
+<div class="fieldset-wrapper">
+    <div class="fieldset-wrapper-title">
+        <span class="title"><?php echo __('Items Ordered') ?></span>
     </div>
+    <?php echo $this->getItemsHtml() ?>
+</div>
+
 <div class="clearfix">
     <div class="order-comments-history">
         <div class="fieldset-wrapper">
@@ -95,6 +108,7 @@
             <fieldset><?php echo $this->getChildHtml('order_history') ?></fieldset>
         </div>
     </div>
+
     <div class="order-totals">
         <div class="fieldset-wrapper">
             <div class="fieldset-wrapper-title">
@@ -104,7 +118,9 @@
         </div>
     </div>
 </div>
+
 <?php echo $this->getChildHtml('popup_window');?>
+
 <script type="text/javascript">
 //<![CDATA[
     /**
diff --git a/app/code/Magento/SalesRule/Controller/Adminhtml/Promo/Quote.php b/app/code/Magento/SalesRule/Controller/Adminhtml/Promo/Quote.php
index 191d1f16fd2afd7a4a0df666b5c1e87a05c2fdac..7caa6a9e2356e9fb1f810f11bf4aeb2f0f8bfd54 100644
--- a/app/code/Magento/SalesRule/Controller/Adminhtml/Promo/Quote.php
+++ b/app/code/Magento/SalesRule/Controller/Adminhtml/Promo/Quote.php
@@ -332,7 +332,7 @@ class Quote extends \Magento\Backend\App\Action
             $content = $this->_view->getLayout()
                 ->createBlock('Magento\SalesRule\Block\Adminhtml\Promo\Quote\Edit\Tab\Coupons\Grid')
                 ->getExcelFile($fileName);
-            return $this->_fileFactory->create($fileName, $content);
+            return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
         } else {
             $this->_redirect('sales_rule/*/detail', array('_current' => true));
             return;
@@ -353,7 +353,7 @@ class Quote extends \Magento\Backend\App\Action
             $content = $this->_view->getLayout()
                 ->createBlock('Magento\SalesRule\Block\Adminhtml\Promo\Quote\Edit\Tab\Coupons\Grid')
                 ->getCsvFile();
-            return $this->_fileFactory->create($fileName, $content);
+            return $this->_fileFactory->create($fileName, $content, \Magento\Filesystem::VAR_DIR);
         } else {
             $this->_redirect('sales_rule/*/detail', array('_current' => true));
             return;
diff --git a/app/code/Magento/Tax/Controller/Adminhtml/Rate.php b/app/code/Magento/Tax/Controller/Adminhtml/Rate.php
index cd9fc0d5055d32ba04d803178a8b194a90375819..74976baf8936d773ba6e92d35fd70bbfb6c7ffef 100644
--- a/app/code/Magento/Tax/Controller/Adminhtml/Rate.php
+++ b/app/code/Magento/Tax/Controller/Adminhtml/Rate.php
@@ -299,8 +299,8 @@ class Rate extends \Magento\Backend\App\Action
     public function exportCsvAction()
     {
         $this->_view->loadLayout(false);
-        $content = $this->_view->getLayout()->getChildBlock('adminhtml.tax.rate.grid','grid.export');
-        return $this->_fileFactory->create('rates.csv', $content->getCsvFile());
+        $content = $this->_view->getLayout()->getChildBlock('adminhtml.tax.rate.grid', 'grid.export');
+        return $this->_fileFactory->create('rates.csv', $content->getCsvFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -309,8 +309,8 @@ class Rate extends \Magento\Backend\App\Action
     public function exportXmlAction()
     {
         $this->_view->loadLayout(false);
-        $content = $this->_view->getLayout()->getChildBlock('adminhtml.tax.rate.grid','grid.export');
-        return $this->_fileFactory->create('rates.xml', $content->getExcelFile());
+        $content = $this->_view->getLayout()->getChildBlock('adminhtml.tax.rate.grid', 'grid.export');
+        return $this->_fileFactory->create('rates.xml', $content->getExcelFile(), \Magento\Filesystem::VAR_DIR);
     }
 
     /**
@@ -431,7 +431,7 @@ class Rate extends \Magento\Backend\App\Action
             $content .= $rate->toString($template) . "\n";
         }
         $this->_view->loadLayout();
-        return $this->_fileFactory->create('tax_rates.csv', $content);
+        return $this->_fileFactory->create('tax_rates.csv', $content, \Magento\Filesystem::VAR_DIR);
     }
 
     protected function _isAllowed()
diff --git a/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Theme.php b/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Theme.php
index 04d57ed4518e9521607d9bb018a2e3fc1b37e4a3..0df09c9d81267a9bf7db8f9ec9262abc72762ce3 100644
--- a/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Theme.php
+++ b/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Theme.php
@@ -296,7 +296,8 @@ class Theme extends \Magento\Backend\App\Action
                     array(
                         'type'  => 'filename',
                         'value' => $customCssFile->getFullPath()
-                    )
+                    ),
+                    \Magento\Filesystem::ROOT
                 );
             }
         } catch (\Exception $e) {
@@ -331,10 +332,14 @@ class Theme extends \Magento\Backend\App\Action
                 );
             }
 
-            return $this->_fileFactory->create($fileName, array(
-                'type'  => 'filename',
-                'value' => $themeCss[$fileName]['path']
-            ));
+            return $this->_fileFactory->create(
+                $fileName,
+                array(
+                    'type'  => 'filename',
+                    'value' => $themeCss[$fileName]['path']
+                ),
+                \Magento\Filesystem::ROOT
+            );
         } catch (\Exception $e) {
             $this->messageManager->addException($e, __('We cannot find file "%1".', $fileName));
             $this->getResponse()->setRedirect($this->_redirect->getRefererUrl());
diff --git a/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Wysiwyg/Files.php b/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Wysiwyg/Files.php
index 50aabe0721908f24cfddd6ef0e0937cd829677af..c8999ca2272d59d018d629042ad6425360b5c116 100644
--- a/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Wysiwyg/Files.php
+++ b/app/code/Magento/Theme/Controller/Adminhtml/System/Design/Wysiwyg/Files.php
@@ -147,10 +147,14 @@ class Files extends \Magento\Backend\App\Action
         /** @var $helper \Magento\Theme\Helper\Storage */
         $helper = $this->_objectManager->get('Magento\Theme\Helper\Storage');
         try {
-            return $this->_fileFactory->create($file, array(
-                'type'  => 'filename',
-                'value' => $helper->getThumbnailPath($file)
-            ));
+            return $this->_fileFactory->create(
+                $file,
+                array(
+                    'type'  => 'filename',
+                    'value' => $helper->getThumbnailPath($file)
+                ),
+                \Magento\Filesystem::MEDIA
+            );
         } catch (\Exception $e) {
             $this->_objectManager->get('Magento\Logger')->logException($e);
             $this->_redirect('core/index/notfound');
diff --git a/app/code/Magento/Theme/view/frontend/layout/default_head_blocks.xml b/app/code/Magento/Theme/view/frontend/layout/default_head_blocks.xml
index 425c9c0a056b1ec37a9d7464f3282951cbf6a826..5f553e70450bb1d5661fb551902442daf6b164ad 100644
--- a/app/code/Magento/Theme/view/frontend/layout/default_head_blocks.xml
+++ b/app/code/Magento/Theme/view/frontend/layout/default_head_blocks.xml
@@ -45,7 +45,7 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="head-load-min-js">
             <arguments>
-                <argument name="file" xsi:type="string">head.load.min.js</argument>
+                <argument name="file" xsi:type="string">headjs/head.load.min.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="magento-magento-js">
diff --git a/app/code/Magento/Usa/Model/Shipping/Carrier/Dhl.php b/app/code/Magento/Usa/Model/Shipping/Carrier/Dhl.php
index 364c94ac5caa2b12f4666ce8da8695cc8e397bf8..a580b1e8681c1410f9e2612ed3e605dc0071db88 100644
--- a/app/code/Magento/Usa/Model/Shipping/Carrier/Dhl.php
+++ b/app/code/Magento/Usa/Model/Shipping/Carrier/Dhl.php
@@ -637,8 +637,8 @@ class Dhl
                 $ch = curl_init();
                 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                 curl_setopt($ch, CURLOPT_URL, $url);
-                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 1);
-                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
+                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
+                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
                 curl_setopt($ch, CURLOPT_POSTFIELDS, $request);
                 $responseBody = curl_exec($ch);
                 curl_close($ch);
@@ -1135,8 +1135,8 @@ class Dhl
             $ch = curl_init();
             curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
             curl_setopt($ch, CURLOPT_URL, $url);
-            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 1);
-            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
+            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
+            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
             curl_setopt($ch, CURLOPT_POSTFIELDS, $request);
             $responseBody = curl_exec($ch);
             $debugData['result'] = $responseBody;
diff --git a/app/code/Magento/Usa/Model/Shipping/Carrier/Fedex.php b/app/code/Magento/Usa/Model/Shipping/Carrier/Fedex.php
index 58068a67492fe5eba70ede5f6eb95469c78ba572..9209bb6d86fa4a5426ccaba6bf57d4d2db9ec134 100644
--- a/app/code/Magento/Usa/Model/Shipping/Carrier/Fedex.php
+++ b/app/code/Magento/Usa/Model/Shipping/Carrier/Fedex.php
@@ -699,8 +699,8 @@ class Fedex
                 $ch = curl_init();
                 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
                 curl_setopt($ch, CURLOPT_URL, $url);
-                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 1);
-                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
+                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
+                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
                 curl_setopt($ch, CURLOPT_POSTFIELDS, $request);
                 $responseBody = curl_exec($ch);
                 curl_close ($ch);
diff --git a/app/code/Magento/User/sql/user_setup/install-1.6.0.0.php b/app/code/Magento/User/sql/user_setup/install-1.6.0.0.php
index 80eef8ffd62aea020c8e031eefa133554594edd1..3b0504e8bdf9227d7f6b8b8db3420c02ec479dcb 100644
--- a/app/code/Magento/User/sql/user_setup/install-1.6.0.0.php
+++ b/app/code/Magento/User/sql/user_setup/install-1.6.0.0.php
@@ -171,7 +171,8 @@ if (!$installer->getConnection()->isTableExists($installer->getTable('admin_user
             ), 'User Password')
         ->addColumn('created', \Magento\DB\Ddl\Table::TYPE_TIMESTAMP, null, array(
             'nullable'  => false,
-            ), 'User Created Time')
+            'default'   => \Magento\DB\Ddl\Table::TIMESTAMP_INIT,
+        ), 'User Created Time')
         ->addColumn('modified', \Magento\DB\Ddl\Table::TYPE_TIMESTAMP, null, array(
             ), 'User Modified Time')
         ->addColumn('logdate', \Magento\DB\Ddl\Table::TYPE_TIMESTAMP, null, array(
diff --git a/app/code/Magento/User/view/adminhtml/admin/forgotpassword.phtml b/app/code/Magento/User/view/adminhtml/admin/forgotpassword.phtml
index 83e28865b458b34ebd1bbcb82d6fd7ce1a7ea92b..bf1630a5ec8210f3d08c0d37bee861ee4d733422 100644
--- a/app/code/Magento/User/view/adminhtml/admin/forgotpassword.phtml
+++ b/app/code/Magento/User/view/adminhtml/admin/forgotpassword.phtml
@@ -54,8 +54,8 @@
     <script src="<?php echo $this->getViewFileUrl('mage/adminhtml/events.js'); ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('scriptaculous/effects.js'); ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('mage/captcha.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('lib/modernizr.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('js/head.js') ?>"></script>
+    <script src="<?php echo $this->getViewFileUrl('modernizr/modernizr.js') ?>"></script>
+    <script src="<?php echo $this->getViewFileUrl('headjs/head.min.js') ?>"></script>
 
 <body id="page-login" class="page-login page-forgotpassword">
     <div class="wrapper">
diff --git a/app/code/Magento/User/view/adminhtml/admin/resetforgottenpassword.phtml b/app/code/Magento/User/view/adminhtml/admin/resetforgottenpassword.phtml
index 0ac89ee2e3e9d0c8ce9e763f5a43ed63f7bf8dae..fbc2eb909b07cb4f785085f33e603b3d6e461d28 100644
--- a/app/code/Magento/User/view/adminhtml/admin/resetforgottenpassword.phtml
+++ b/app/code/Magento/User/view/adminhtml/admin/resetforgottenpassword.phtml
@@ -52,8 +52,8 @@
     <script src="<?php echo $this->getViewFileUrl('prototype/prototype.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('scriptaculous/effects.js') ?>"></script>
     <script src="<?php echo $this->getViewFileUrl('mage/captcha.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('lib/modernizr.js') ?>"></script>
-    <script src="<?php echo $this->getViewFileUrl('js/head.js') ?>"></script>
+    <script src="<?php echo $this->getViewFileUrl('modernizr/modernizr.js') ?>"></script>
+    <script src="<?php echo $this->getViewFileUrl('headjs/head.min.js') ?>"></script>
 
 <body id="page-login" class="page-login page-resetpass">
     <div class="wrapper">
diff --git a/app/code/Magento/Wishlist/Controller/Index.php b/app/code/Magento/Wishlist/Controller/Index.php
index 9fa8deae722d88c17219b984a7c210f55d2fe898..29465301b4e7b17714c4943a79d88c28ec037992 100644
--- a/app/code/Magento/Wishlist/Controller/Index.php
+++ b/app/code/Magento/Wishlist/Controller/Index.php
@@ -256,8 +256,7 @@ class Index
             $helper = $this->_objectManager->get('Magento\Wishlist\Helper\Data')->calculate();
             $message = __('%1 has been added to your wishlist. Click <a href="%2">here</a> to continue shopping.', $this->_objectManager->get('Magento\Escaper')->escapeHtml($product->getName()), $this->_objectManager->get('Magento\Escaper')->escapeUrl($referer));
             $this->messageManager->addSuccess($message);
-        }
-        catch (\Magento\Core\Exception $e) {
+        } catch (\Magento\Core\Exception $e) {
             $this->messageManager->addError(
                 __('An error occurred while adding item to wish list: %1', $e->getMessage())
             );
@@ -354,8 +353,11 @@ class Index
                 ->save();
 
             $this->_objectManager->get('Magento\Wishlist\Helper\Data')->calculate();
-            $this->_eventManager->dispatch('wishlist_update_item', array(
-                'wishlist' => $wishlist, 'product' => $product, 'item' => $wishlist->getItem($id))
+            $this->_eventManager->dispatch(
+                'wishlist_update_item',
+                array(
+                    'wishlist' => $wishlist, 'product' => $product, 'item' => $wishlist->getItem($id)
+                )
             );
 
             $this->_objectManager->get('Magento\Wishlist\Helper\Data')->calculate();
@@ -446,8 +448,7 @@ class Index
                 try {
                     $wishlist->save();
                     $this->_objectManager->get('Magento\Wishlist\Helper\Data')->calculate();
-                }
-                catch (\Exception $e) {
+                } catch (\Exception $e) {
                     $this->messageManager->addError(__('Can\'t update wish list'));
                 }
             }
@@ -554,14 +555,14 @@ class Index
 
             if ($this->_objectManager->get('Magento\Checkout\Helper\Cart')->getShouldRedirectToCart()) {
                 $redirectUrl = $this->_objectManager->get('Magento\Checkout\Helper\Cart')->getCartUrl();
-            } else if ($this->_redirect->getRefererUrl()) {
+            } elseif ($this->_redirect->getRefererUrl()) {
                 $redirectUrl = $this->_redirect->getRefererUrl();
             }
             $this->_objectManager->get('Magento\Wishlist\Helper\Data')->calculate();
         } catch (\Magento\Core\Exception $e) {
             if ($e->getCode() == \Magento\Wishlist\Model\Item::EXCEPTION_CODE_NOT_SALABLE) {
                 $this->messageManager->addError(__('This product(s) is out of stock.'));
-            } else if ($e->getCode() == \Magento\Wishlist\Model\Item::EXCEPTION_CODE_HAS_REQUIRED_OPTIONS) {
+            } elseif ($e->getCode() == \Magento\Wishlist\Model\Item::EXCEPTION_CODE_HAS_REQUIRED_OPTIONS) {
                 $this->messageManager->addNotice($e->getMessage());
                 $redirectUrl = $this->_url->getUrl('*/*/configure/', array('id' => $item->getId()));
             } else {
@@ -594,7 +595,7 @@ class Index
         $cart = $this->_objectManager->get('Magento\Checkout\Model\Cart');
         $session = $this->_objectManager->get('Magento\Checkout\Model\Session');
 
-        try{
+        try {
             $item = $cart->getQuote()->getItemById($itemId);
             if (!$item) {
                 throw new \Magento\Core\Exception(
@@ -623,7 +624,9 @@ class Index
             $this->messageManager->addException($e, __('We can\'t move the item to the wish list.'));
         }
 
-        return $this->getResponse()->setRedirect($this->_objectManager->get('Magento\Checkout\Helper\Cart')->getCartUrl());
+        return $this->getResponse()->setRedirect(
+            $this->_objectManager->get('Magento\Checkout\Helper\Cart')->getCartUrl()
+        );
     }
 
     /**
@@ -704,7 +707,10 @@ class Index
                     ->toHtml();
                 $message .= $rss_url;
             }
-            $wishlistBlock = $this->_view->getLayout()->createBlock('Magento\Wishlist\Block\Share\Email\Items')->toHtml();
+            $wishlistBlock = $this->_view
+                ->getLayout()
+                ->createBlock('Magento\Wishlist\Block\Share\Email\Items')
+                ->toHtml();
 
             $emails = array_unique($emails);
             /* @var $emailModel \Magento\Email\Model\Template */
@@ -715,8 +721,12 @@ class Index
             try {
                 foreach ($emails as $email) {
                     $emailModel->sendTransactional(
-                        $this->_objectManager->get('Magento\Core\Model\Store\Config')->getConfig('wishlist/email/email_template'),
-                        $this->_objectManager->get('Magento\Core\Model\Store\Config')->getConfig('wishlist/email/email_identity'),
+                        $this->_objectManager
+                            ->get('Magento\Core\Model\Store\Config')
+                            ->getConfig('wishlist/email/email_template'),
+                        $this->_objectManager
+                            ->get('Magento\Core\Model\Store\Config')
+                            ->getConfig('wishlist/email/email_identity'),
                         $email,
                         null,
                         array(
@@ -767,7 +777,11 @@ class Index
 
         $optionId = null;
         if (strpos($option->getCode(), \Magento\Catalog\Model\Product\Type\AbstractType::OPTION_PREFIX) === 0) {
-            $optionId = str_replace(\Magento\Catalog\Model\Product\Type\AbstractType::OPTION_PREFIX, '', $option->getCode());
+            $optionId = str_replace(
+                \Magento\Catalog\Model\Product\Type\AbstractType::OPTION_PREFIX,
+                '',
+                $option->getCode()
+            );
             if ((int)$optionId != $optionId) {
                 return $this->_forward('noroute');
             }
@@ -789,13 +803,17 @@ class Index
             $secretKey = $this->getRequest()->getParam('key');
 
             if ($secretKey == $info['secret_key']) {
-                $this->_fileResponseFactory->create($info['title'], array(
-                    'value' => $filePath,
-                    'type'  => 'filename'
-                ));
+                $this->_fileResponseFactory->create(
+                    $info['title'],
+                    array(
+                        'value' => $filePath,
+                        'type'  => 'filename'
+                    ),
+                    \Magento\Filesystem::ROOT
+                );
             }
 
-        } catch(\Exception $e) {
+        } catch (\Exception $e) {
             $this->_forward('noroute');
         }
         exit(0);
diff --git a/app/design/adminhtml/magento_backend/Magento_Backend/layout/default.xml b/app/design/adminhtml/magento_backend/Magento_Backend/layout/default.xml
index 2c6ba794548164c23119fec250183eae82445e83..ddb75229007bd366caee5f8217350ad3f7d6ecfd 100644
--- a/app/design/adminhtml/magento_backend/Magento_Backend/layout/default.xml
+++ b/app/design/adminhtml/magento_backend/Magento_Backend/layout/default.xml
@@ -50,10 +50,33 @@
                 <argument name="file" xsi:type="string">mui/components.css</argument>
             </arguments>
         </block>
-        <block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-css">
+        <!--<block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-css">
             <arguments>
                 <argument name="file" xsi:type="string">css/styles.css</argument>
             </arguments>
+        </block>-->
+        <block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-admin">
+            <arguments>
+                <argument name="file" xsi:type="string">css/admin.css</argument>
+            </arguments>
+        </block>
+        <block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-header">
+            <arguments>
+                <argument name="file" xsi:type="string">css/header.css</argument>
+            </arguments>
+        </block>
+        <block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-pages">
+            <arguments>
+                <argument name="file" xsi:type="string">css/pages.css</argument>
+            </arguments>
+        </block>
+        <block class="Magento\Theme\Block\Html\Head\Css" name="css-styles-ie8">
+            <arguments>
+                <argument name="file" xsi:type="string">css/styles-ie8.css</argument>
+                <argument name="properties" xsi:type="array">
+                    <item name="ie_condition" xsi:type="string">lt IE 9</item>
+                </argument>
+            </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Css" name="jquery-farbtastic-css-farbtastic-css">
             <arguments>
@@ -81,12 +104,12 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="lib-modernizr-js">
             <arguments>
-                <argument name="file" xsi:type="string">lib/modernizr.js</argument>
+                <argument name="file" xsi:type="string">modernizr/modernizr.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-head-js">
             <arguments>
-                <argument name="file" xsi:type="string">js/head.js</argument>
+                <argument name="file" xsi:type="string">headjs/head.min.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="magento-dropdown-js">
@@ -109,9 +132,14 @@
                 <argument name="file" xsi:type="string">js/theme.js</argument>
             </arguments>
         </block>
+        <block class="Magento\Theme\Block\Html\Head\Script" name="js-modernizr-details-js">
+            <arguments>
+                <argument name="file" xsi:type="string">modernizr/modernizr.details.js</argument>
+            </arguments>
+        </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-jquery-details-js">
             <arguments>
-                <argument name="file" xsi:type="string">js/jquery.details.js</argument>
+                <argument name="file" xsi:type="string">jquery/jquery.details.js</argument>
             </arguments>
         </block>
     </referenceBlock>
diff --git a/app/design/adminhtml/magento_backend/css/admin.css b/app/design/adminhtml/magento_backend/css/admin.css
new file mode 100644
index 0000000000000000000000000000000000000000..1a9e681520953945522358424367d4c8ec0eff35
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/css/admin.css
@@ -0,0 +1,6720 @@
+/**
+  * 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.
+  *
+  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+  */
+@font-face {
+  font-family: 'admin-icons';
+  src: url('../fonts/icons/admin-icons.eot');
+  src: url('../fonts/icons/admin-icons.eot?#iefix') format('embedded-opentype'), url('../fonts/icons/admin-icons.svg#admin-icons') format('svg'), url('../fonts/icons/admin-icons.woff') format('woff'), url('../fonts/icons/admin-icons.ttf') format('truetype');
+  font-weight: normal;
+  font-style: normal;
+}
+@font-face {
+  font-family: 'MUI-Icons';
+  src: url('../mui/fonts/MUI-Icons.eot');
+  src: url('../mui/fonts/MUI-Icons.eot?#iefix') format('embedded-opentype'), url('../mui/fonts/MUI-Icons.svg#MUI-Icons') format('svg'), url('../mui/fonts/MUI-Icons.woff') format('woff'), url('../mui/fonts/MUI-Icons.ttf') format('truetype');
+  font-weight: normal;
+  font-style: normal;
+}
+/* @import url(http://fonts.googleapis.com/css?family=Open+Sans:400italic,400,600,700 <http://fonts.googleapis.com/css?family=Open+Sans:400italic%2c400%2c600%2c700>); */
+@font-face {
+  font-family: 'Open Sans';
+  font-style: normal;
+  font-weight: 400;
+  src: local('Open Sans'), local('OpenSans'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/cJZKeOuBrn4kERxqtaUH3T8E0i7KZn-EPnyo3HZu7kw.woff) format('woff');
+}
+@font-face {
+  font-family: 'Open Sans';
+  font-style: normal;
+  font-weight: 600;
+  src: local('Open Sans Semibold'), local('OpenSans-Semibold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/MTP_ySUJH_bn48VBG8sNSnhCUOGz7vYGh680lGh-uXM.woff) format('woff');
+}
+@font-face {
+  font-family: 'Open Sans';
+  font-style: normal;
+  font-weight: 700;
+  src: local('Open Sans Bold'), local('OpenSans-Bold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/k3k702ZOKiLJc3WVjuplzHhCUOGz7vYGh680lGh-uXM.woff) format('woff');
+}
+@font-face {
+  font-family: 'Open Sans';
+  font-style: italic;
+  font-weight: 400;
+  src: local('Open Sans Italic'), local('OpenSans-Italic'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/xjAJXh38I15wypJXxuGMBobN6UDyHWBl620a-IRfuBk.woff) format('woff');
+}
+body,
+html {
+  min-height: 100%;
+  height: 100%;
+}
+body {
+  color: #676056;
+  font: 400 14px/1.33 'Open Sans', sans-serif;
+  background: #f2ebde;
+  position: relative;
+  height: auto;
+}
+h1 {
+  color: #676056;
+  font: 400 28px/1.2 'Open Sans', sans-serif;
+}
+h2 {
+  color: #676056;
+  font: 400 20px/1.2 'Open Sans', sans-serif;
+}
+h3 {
+  color: #676056;
+  font: 600 16px/1.2 'Open Sans', sans-serif;
+}
+h4 {
+  color: #676056;
+  font: 600 14px/1.2 'Open Sans', sans-serif;
+}
+h5 {
+  color: #676056;
+  font: 600 13px/1.2 'Open Sans', sans-serif;
+}
+h6 {
+  color: #676056;
+  font: 600 12px/1.2 'Open Sans', sans-serif;
+}
+a {
+  display: inline;
+  color: #026294;
+  text-decoration: none;
+}
+a:visited,
+a:active {
+  color: #026294;
+}
+a:focus,
+a:hover {
+  color: #026294;
+  text-decoration: underline;
+}
+.DefaultButton,
+.PrimaryButton,
+input[type=button],
+input[type=submit],
+input[type=reset],
+button,
+[class^="action-"],
+.popup-window .add-widget,
+.PrimaryAddButton,
+.PrimarySplitButton > .action-toggle.primary,
+input[type=button].primary,
+input[type=submit].primary,
+input[type=reset].primary,
+button.primary,
+[class^="action-"].primary,
+.popup-window .add-widget.primary,
+.PrimarySplitButton.btn-round .action-default.primary,
+.sales-order-index .page-actions .add,
+.adminhtml-rma-index .page-actions .add,
+.adminhtml-catalog-event-index .page-actions .add,
+.adminhtml-urlrewrite-index .page-actions .add,
+.catalog-search-index .page-actions .add,
+.catalog-product-review-index .page-actions .add,
+.catalog-rule-promo-catalog-index .page-actions .add,
+.sales-rule-promo-quote-index .page-actions .add,
+.adminhtml-reminder-index .page-actions .add,
+.newsletter-template-index .page-actions .add,
+.adminhtml-system-email-template-index .page-actions .add,
+.adminhtml-sitemap-index .page-actions .add,
+.adminhtml-googleshopping-types-index .page-actions .add,
+.customer-index-index .page-actions .add,
+.adminhtml-cms-page-index .page-actions .add,
+.cms-block-index .page-actions .add,
+.adminhtml-banner-index .page-actions .add,
+.adminhtml-widget-instance-index .page-actions .add,
+.cms-page-index .page-actions .add,
+.adminhtml-webapi-user-index .page-actions .add,
+.adminhtml-webapi-role-index .page-actions .add,
+.adminhtml-system-variable-index .page-actions .add,
+.adminhtml-user-index .page-actions .add,
+.adminhtml-user-role-index .page-actions .add,
+.adminhtml-integration-index .page-actions .add,
+.adminhtml-system-design-theme-index .page-actions .add,
+.adminhtml-system-design-index .page-actions .add,
+.adminhtml-customer-attribute-index .page-actions .add,
+.adminhtml-customer-address-attribute-index .page-actions .add,
+.rating-index-index .page-actions .add,
+.tax-rule-index .page-actions .add,
+.tax-rate-index .page-actions .add,
+.adminhtml-rma-item-attribute-index .page-actions .add,
+.adminhtml-reward-rate-index .page-actions .add,
+.customer-group-index .page-actions .add,
+.checkout-agreement-index .page-actions .add,
+.catalog-product-attribute-index .page-actions .add,
+.catalog-product-set-index .page-actions .add,
+.catalog-product-new .actions-split > .action-toggle.primary,
+.catalog-product-edit .actions-split > .action-toggle.primary,
+.catalog-product-index .actions-split > .action-toggle.primary,
+.adminhtml-integration-new .actions-split > .action-toggle.primary,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary {
+  font: 14px/19px 'Open Sans', sans-serif;
+  font-weight: 500;
+  background: #f2ebde;
+  border: 1px solid #ada89e;
+  color: #676056;
+  display: inline-block;
+  padding: 5px 14px;
+  text-align: center;
+  text-decoration: none;
+  vertical-align: top;
+  cursor: pointer;
+  border-radius: 2px;
+  -webkit-touch-callout: none;
+  -webkit-user-select: none;
+  -moz-user-select: none;
+  -ms-user-select: none;
+  user-select: none;
+}
+.DefaultButton:hover,
+.DefaultButton:focus,
+.DefaultButton:active,
+.PrimaryButton:hover,
+.PrimaryButton:focus,
+.PrimaryButton:active,
+input[type=button]:hover,
+input[type=button]:focus,
+input[type=button]:active,
+input[type=submit]:hover,
+input[type=submit]:focus,
+input[type=submit]:active,
+input[type=reset]:hover,
+input[type=reset]:focus,
+input[type=reset]:active,
+button:hover,
+button:focus,
+button:active,
+[class^="action-"]:hover,
+[class^="action-"]:focus,
+[class^="action-"]:active,
+.popup-window .add-widget:hover,
+.popup-window .add-widget:focus,
+.popup-window .add-widget:active,
+.PrimaryAddButton:hover,
+.PrimaryAddButton:focus,
+.PrimaryAddButton:active,
+.PrimarySplitButton > .action-toggle.primary:hover,
+.PrimarySplitButton > .action-toggle.primary:focus,
+.PrimarySplitButton > .action-toggle.primary:active,
+input[type=button].primary:hover,
+input[type=button].primary:focus,
+input[type=button].primary:active,
+input[type=submit].primary:hover,
+input[type=submit].primary:focus,
+input[type=submit].primary:active,
+input[type=reset].primary:hover,
+input[type=reset].primary:focus,
+input[type=reset].primary:active,
+button.primary:hover,
+button.primary:focus,
+button.primary:active,
+[class^="action-"].primary:hover,
+[class^="action-"].primary:focus,
+[class^="action-"].primary:active,
+.popup-window .add-widget.primary:hover,
+.popup-window .add-widget.primary:focus,
+.popup-window .add-widget.primary:active,
+.PrimarySplitButton.btn-round .action-default.primary:hover,
+.PrimarySplitButton.btn-round .action-default.primary:focus,
+.PrimarySplitButton.btn-round .action-default.primary:active,
+.sales-order-index .page-actions .add:hover,
+.sales-order-index .page-actions .add:focus,
+.sales-order-index .page-actions .add:active,
+.adminhtml-rma-index .page-actions .add:hover,
+.adminhtml-rma-index .page-actions .add:focus,
+.adminhtml-rma-index .page-actions .add:active,
+.adminhtml-catalog-event-index .page-actions .add:hover,
+.adminhtml-catalog-event-index .page-actions .add:focus,
+.adminhtml-catalog-event-index .page-actions .add:active,
+.adminhtml-urlrewrite-index .page-actions .add:hover,
+.adminhtml-urlrewrite-index .page-actions .add:focus,
+.adminhtml-urlrewrite-index .page-actions .add:active,
+.catalog-search-index .page-actions .add:hover,
+.catalog-search-index .page-actions .add:focus,
+.catalog-search-index .page-actions .add:active,
+.catalog-product-review-index .page-actions .add:hover,
+.catalog-product-review-index .page-actions .add:focus,
+.catalog-product-review-index .page-actions .add:active,
+.catalog-rule-promo-catalog-index .page-actions .add:hover,
+.catalog-rule-promo-catalog-index .page-actions .add:focus,
+.catalog-rule-promo-catalog-index .page-actions .add:active,
+.sales-rule-promo-quote-index .page-actions .add:hover,
+.sales-rule-promo-quote-index .page-actions .add:focus,
+.sales-rule-promo-quote-index .page-actions .add:active,
+.adminhtml-reminder-index .page-actions .add:hover,
+.adminhtml-reminder-index .page-actions .add:focus,
+.adminhtml-reminder-index .page-actions .add:active,
+.newsletter-template-index .page-actions .add:hover,
+.newsletter-template-index .page-actions .add:focus,
+.newsletter-template-index .page-actions .add:active,
+.adminhtml-system-email-template-index .page-actions .add:hover,
+.adminhtml-system-email-template-index .page-actions .add:focus,
+.adminhtml-system-email-template-index .page-actions .add:active,
+.adminhtml-sitemap-index .page-actions .add:hover,
+.adminhtml-sitemap-index .page-actions .add:focus,
+.adminhtml-sitemap-index .page-actions .add:active,
+.adminhtml-googleshopping-types-index .page-actions .add:hover,
+.adminhtml-googleshopping-types-index .page-actions .add:focus,
+.adminhtml-googleshopping-types-index .page-actions .add:active,
+.customer-index-index .page-actions .add:hover,
+.customer-index-index .page-actions .add:focus,
+.customer-index-index .page-actions .add:active,
+.adminhtml-cms-page-index .page-actions .add:hover,
+.adminhtml-cms-page-index .page-actions .add:focus,
+.adminhtml-cms-page-index .page-actions .add:active,
+.cms-block-index .page-actions .add:hover,
+.cms-block-index .page-actions .add:focus,
+.cms-block-index .page-actions .add:active,
+.adminhtml-banner-index .page-actions .add:hover,
+.adminhtml-banner-index .page-actions .add:focus,
+.adminhtml-banner-index .page-actions .add:active,
+.adminhtml-widget-instance-index .page-actions .add:hover,
+.adminhtml-widget-instance-index .page-actions .add:focus,
+.adminhtml-widget-instance-index .page-actions .add:active,
+.cms-page-index .page-actions .add:hover,
+.cms-page-index .page-actions .add:focus,
+.cms-page-index .page-actions .add:active,
+.adminhtml-webapi-user-index .page-actions .add:hover,
+.adminhtml-webapi-user-index .page-actions .add:focus,
+.adminhtml-webapi-user-index .page-actions .add:active,
+.adminhtml-webapi-role-index .page-actions .add:hover,
+.adminhtml-webapi-role-index .page-actions .add:focus,
+.adminhtml-webapi-role-index .page-actions .add:active,
+.adminhtml-system-variable-index .page-actions .add:hover,
+.adminhtml-system-variable-index .page-actions .add:focus,
+.adminhtml-system-variable-index .page-actions .add:active,
+.adminhtml-user-index .page-actions .add:hover,
+.adminhtml-user-index .page-actions .add:focus,
+.adminhtml-user-index .page-actions .add:active,
+.adminhtml-user-role-index .page-actions .add:hover,
+.adminhtml-user-role-index .page-actions .add:focus,
+.adminhtml-user-role-index .page-actions .add:active,
+.adminhtml-integration-index .page-actions .add:hover,
+.adminhtml-integration-index .page-actions .add:focus,
+.adminhtml-integration-index .page-actions .add:active,
+.adminhtml-system-design-theme-index .page-actions .add:hover,
+.adminhtml-system-design-theme-index .page-actions .add:focus,
+.adminhtml-system-design-theme-index .page-actions .add:active,
+.adminhtml-system-design-index .page-actions .add:hover,
+.adminhtml-system-design-index .page-actions .add:focus,
+.adminhtml-system-design-index .page-actions .add:active,
+.adminhtml-customer-attribute-index .page-actions .add:hover,
+.adminhtml-customer-attribute-index .page-actions .add:focus,
+.adminhtml-customer-attribute-index .page-actions .add:active,
+.adminhtml-customer-address-attribute-index .page-actions .add:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add:focus,
+.adminhtml-customer-address-attribute-index .page-actions .add:active,
+.rating-index-index .page-actions .add:hover,
+.rating-index-index .page-actions .add:focus,
+.rating-index-index .page-actions .add:active,
+.tax-rule-index .page-actions .add:hover,
+.tax-rule-index .page-actions .add:focus,
+.tax-rule-index .page-actions .add:active,
+.tax-rate-index .page-actions .add:hover,
+.tax-rate-index .page-actions .add:focus,
+.tax-rate-index .page-actions .add:active,
+.adminhtml-rma-item-attribute-index .page-actions .add:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add:focus,
+.adminhtml-rma-item-attribute-index .page-actions .add:active,
+.adminhtml-reward-rate-index .page-actions .add:hover,
+.adminhtml-reward-rate-index .page-actions .add:focus,
+.adminhtml-reward-rate-index .page-actions .add:active,
+.customer-group-index .page-actions .add:hover,
+.customer-group-index .page-actions .add:focus,
+.customer-group-index .page-actions .add:active,
+.checkout-agreement-index .page-actions .add:hover,
+.checkout-agreement-index .page-actions .add:focus,
+.checkout-agreement-index .page-actions .add:active,
+.catalog-product-attribute-index .page-actions .add:hover,
+.catalog-product-attribute-index .page-actions .add:focus,
+.catalog-product-attribute-index .page-actions .add:active,
+.catalog-product-set-index .page-actions .add:hover,
+.catalog-product-set-index .page-actions .add:focus,
+.catalog-product-set-index .page-actions .add:active,
+.catalog-product-new .actions-split > .action-toggle.primary:hover,
+.catalog-product-new .actions-split > .action-toggle.primary:focus,
+.catalog-product-new .actions-split > .action-toggle.primary:active,
+.catalog-product-edit .actions-split > .action-toggle.primary:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary:focus,
+.catalog-product-edit .actions-split > .action-toggle.primary:active,
+.catalog-product-index .actions-split > .action-toggle.primary:hover,
+.catalog-product-index .actions-split > .action-toggle.primary:focus,
+.catalog-product-index .actions-split > .action-toggle.primary:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:focus,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-new .actions-split.btn-round .action-default.primary:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-index .actions-split.btn-round .action-default.primary:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:focus,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:active {
+  text-decoration: none;
+  background: #cac3b4;
+  color: #676056;
+}
+.DefaultButton:active,
+.PrimaryButton:active,
+input[type=button]:active,
+input[type=submit]:active,
+input[type=reset]:active,
+button:active,
+[class^="action-"]:active,
+.popup-window .add-widget:active,
+.PrimaryAddButton:active,
+.PrimarySplitButton > .action-toggle.primary:active,
+input[type=button].primary:active,
+input[type=submit].primary:active,
+input[type=reset].primary:active,
+button.primary:active,
+[class^="action-"].primary:active,
+.popup-window .add-widget.primary:active,
+.PrimarySplitButton.btn-round .action-default.primary:active,
+.sales-order-index .page-actions .add:active,
+.adminhtml-rma-index .page-actions .add:active,
+.adminhtml-catalog-event-index .page-actions .add:active,
+.adminhtml-urlrewrite-index .page-actions .add:active,
+.catalog-search-index .page-actions .add:active,
+.catalog-product-review-index .page-actions .add:active,
+.catalog-rule-promo-catalog-index .page-actions .add:active,
+.sales-rule-promo-quote-index .page-actions .add:active,
+.adminhtml-reminder-index .page-actions .add:active,
+.newsletter-template-index .page-actions .add:active,
+.adminhtml-system-email-template-index .page-actions .add:active,
+.adminhtml-sitemap-index .page-actions .add:active,
+.adminhtml-googleshopping-types-index .page-actions .add:active,
+.customer-index-index .page-actions .add:active,
+.adminhtml-cms-page-index .page-actions .add:active,
+.cms-block-index .page-actions .add:active,
+.adminhtml-banner-index .page-actions .add:active,
+.adminhtml-widget-instance-index .page-actions .add:active,
+.cms-page-index .page-actions .add:active,
+.adminhtml-webapi-user-index .page-actions .add:active,
+.adminhtml-webapi-role-index .page-actions .add:active,
+.adminhtml-system-variable-index .page-actions .add:active,
+.adminhtml-user-index .page-actions .add:active,
+.adminhtml-user-role-index .page-actions .add:active,
+.adminhtml-integration-index .page-actions .add:active,
+.adminhtml-system-design-theme-index .page-actions .add:active,
+.adminhtml-system-design-index .page-actions .add:active,
+.adminhtml-customer-attribute-index .page-actions .add:active,
+.adminhtml-customer-address-attribute-index .page-actions .add:active,
+.rating-index-index .page-actions .add:active,
+.tax-rule-index .page-actions .add:active,
+.tax-rate-index .page-actions .add:active,
+.adminhtml-rma-item-attribute-index .page-actions .add:active,
+.adminhtml-reward-rate-index .page-actions .add:active,
+.customer-group-index .page-actions .add:active,
+.checkout-agreement-index .page-actions .add:active,
+.catalog-product-attribute-index .page-actions .add:active,
+.catalog-product-set-index .page-actions .add:active,
+.catalog-product-new .actions-split > .action-toggle.primary:active,
+.catalog-product-edit .actions-split > .action-toggle.primary:active,
+.catalog-product-index .actions-split > .action-toggle.primary:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:active {
+  border: 1px solid #989287;
+}
+.DefaultButton:visited,
+.PrimaryButton:visited,
+input[type=button]:visited,
+input[type=submit]:visited,
+input[type=reset]:visited,
+button:visited,
+[class^="action-"]:visited,
+.popup-window .add-widget:visited,
+.PrimaryAddButton:visited,
+.PrimarySplitButton > .action-toggle.primary:visited,
+input[type=button].primary:visited,
+input[type=submit].primary:visited,
+input[type=reset].primary:visited,
+button.primary:visited,
+[class^="action-"].primary:visited,
+.popup-window .add-widget.primary:visited,
+.PrimarySplitButton.btn-round .action-default.primary:visited,
+.sales-order-index .page-actions .add:visited,
+.adminhtml-rma-index .page-actions .add:visited,
+.adminhtml-catalog-event-index .page-actions .add:visited,
+.adminhtml-urlrewrite-index .page-actions .add:visited,
+.catalog-search-index .page-actions .add:visited,
+.catalog-product-review-index .page-actions .add:visited,
+.catalog-rule-promo-catalog-index .page-actions .add:visited,
+.sales-rule-promo-quote-index .page-actions .add:visited,
+.adminhtml-reminder-index .page-actions .add:visited,
+.newsletter-template-index .page-actions .add:visited,
+.adminhtml-system-email-template-index .page-actions .add:visited,
+.adminhtml-sitemap-index .page-actions .add:visited,
+.adminhtml-googleshopping-types-index .page-actions .add:visited,
+.customer-index-index .page-actions .add:visited,
+.adminhtml-cms-page-index .page-actions .add:visited,
+.cms-block-index .page-actions .add:visited,
+.adminhtml-banner-index .page-actions .add:visited,
+.adminhtml-widget-instance-index .page-actions .add:visited,
+.cms-page-index .page-actions .add:visited,
+.adminhtml-webapi-user-index .page-actions .add:visited,
+.adminhtml-webapi-role-index .page-actions .add:visited,
+.adminhtml-system-variable-index .page-actions .add:visited,
+.adminhtml-user-index .page-actions .add:visited,
+.adminhtml-user-role-index .page-actions .add:visited,
+.adminhtml-integration-index .page-actions .add:visited,
+.adminhtml-system-design-theme-index .page-actions .add:visited,
+.adminhtml-system-design-index .page-actions .add:visited,
+.adminhtml-customer-attribute-index .page-actions .add:visited,
+.adminhtml-customer-address-attribute-index .page-actions .add:visited,
+.rating-index-index .page-actions .add:visited,
+.tax-rule-index .page-actions .add:visited,
+.tax-rate-index .page-actions .add:visited,
+.adminhtml-rma-item-attribute-index .page-actions .add:visited,
+.adminhtml-reward-rate-index .page-actions .add:visited,
+.customer-group-index .page-actions .add:visited,
+.checkout-agreement-index .page-actions .add:visited,
+.catalog-product-attribute-index .page-actions .add:visited,
+.catalog-product-set-index .page-actions .add:visited,
+.catalog-product-new .actions-split > .action-toggle.primary:visited,
+.catalog-product-edit .actions-split > .action-toggle.primary:visited,
+.catalog-product-index .actions-split > .action-toggle.primary:visited,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:visited,
+.catalog-product-new .actions-split.btn-round .action-default.primary:visited,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:visited,
+.catalog-product-index .actions-split.btn-round .action-default.primary:visited,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:visited {
+  color: #676056;
+}
+.DefaultButton[disabled],
+.DefaultButton.disabled,
+.PrimaryButton[disabled],
+.PrimaryButton.disabled,
+input[type=button][disabled],
+input[type=button].disabled,
+input[type=submit][disabled],
+input[type=submit].disabled,
+input[type=reset][disabled],
+input[type=reset].disabled,
+button[disabled],
+button.disabled,
+[class^="action-"][disabled],
+[class^="action-"].disabled,
+.popup-window .add-widget[disabled],
+.popup-window .add-widget.disabled,
+.PrimaryAddButton[disabled],
+.PrimaryAddButton.disabled,
+.PrimarySplitButton > .action-toggle.primary[disabled],
+.PrimarySplitButton > .action-toggle.primary.disabled,
+input[type=button].primary[disabled],
+input[type=button].primary.disabled,
+input[type=submit].primary[disabled],
+input[type=submit].primary.disabled,
+input[type=reset].primary[disabled],
+input[type=reset].primary.disabled,
+button.primary[disabled],
+button.primary.disabled,
+[class^="action-"].primary[disabled],
+[class^="action-"].primary.disabled,
+.popup-window .add-widget.primary[disabled],
+.popup-window .add-widget.primary.disabled,
+.PrimarySplitButton.btn-round .action-default.primary[disabled],
+.PrimarySplitButton.btn-round .action-default.primary.disabled,
+.sales-order-index .page-actions .add[disabled],
+.sales-order-index .page-actions .add.disabled,
+.adminhtml-rma-index .page-actions .add[disabled],
+.adminhtml-rma-index .page-actions .add.disabled,
+.adminhtml-catalog-event-index .page-actions .add[disabled],
+.adminhtml-catalog-event-index .page-actions .add.disabled,
+.adminhtml-urlrewrite-index .page-actions .add[disabled],
+.adminhtml-urlrewrite-index .page-actions .add.disabled,
+.catalog-search-index .page-actions .add[disabled],
+.catalog-search-index .page-actions .add.disabled,
+.catalog-product-review-index .page-actions .add[disabled],
+.catalog-product-review-index .page-actions .add.disabled,
+.catalog-rule-promo-catalog-index .page-actions .add[disabled],
+.catalog-rule-promo-catalog-index .page-actions .add.disabled,
+.sales-rule-promo-quote-index .page-actions .add[disabled],
+.sales-rule-promo-quote-index .page-actions .add.disabled,
+.adminhtml-reminder-index .page-actions .add[disabled],
+.adminhtml-reminder-index .page-actions .add.disabled,
+.newsletter-template-index .page-actions .add[disabled],
+.newsletter-template-index .page-actions .add.disabled,
+.adminhtml-system-email-template-index .page-actions .add[disabled],
+.adminhtml-system-email-template-index .page-actions .add.disabled,
+.adminhtml-sitemap-index .page-actions .add[disabled],
+.adminhtml-sitemap-index .page-actions .add.disabled,
+.adminhtml-googleshopping-types-index .page-actions .add[disabled],
+.adminhtml-googleshopping-types-index .page-actions .add.disabled,
+.customer-index-index .page-actions .add[disabled],
+.customer-index-index .page-actions .add.disabled,
+.adminhtml-cms-page-index .page-actions .add[disabled],
+.adminhtml-cms-page-index .page-actions .add.disabled,
+.cms-block-index .page-actions .add[disabled],
+.cms-block-index .page-actions .add.disabled,
+.adminhtml-banner-index .page-actions .add[disabled],
+.adminhtml-banner-index .page-actions .add.disabled,
+.adminhtml-widget-instance-index .page-actions .add[disabled],
+.adminhtml-widget-instance-index .page-actions .add.disabled,
+.cms-page-index .page-actions .add[disabled],
+.cms-page-index .page-actions .add.disabled,
+.adminhtml-webapi-user-index .page-actions .add[disabled],
+.adminhtml-webapi-user-index .page-actions .add.disabled,
+.adminhtml-webapi-role-index .page-actions .add[disabled],
+.adminhtml-webapi-role-index .page-actions .add.disabled,
+.adminhtml-system-variable-index .page-actions .add[disabled],
+.adminhtml-system-variable-index .page-actions .add.disabled,
+.adminhtml-user-index .page-actions .add[disabled],
+.adminhtml-user-index .page-actions .add.disabled,
+.adminhtml-user-role-index .page-actions .add[disabled],
+.adminhtml-user-role-index .page-actions .add.disabled,
+.adminhtml-integration-index .page-actions .add[disabled],
+.adminhtml-integration-index .page-actions .add.disabled,
+.adminhtml-system-design-theme-index .page-actions .add[disabled],
+.adminhtml-system-design-theme-index .page-actions .add.disabled,
+.adminhtml-system-design-index .page-actions .add[disabled],
+.adminhtml-system-design-index .page-actions .add.disabled,
+.adminhtml-customer-attribute-index .page-actions .add[disabled],
+.adminhtml-customer-attribute-index .page-actions .add.disabled,
+.adminhtml-customer-address-attribute-index .page-actions .add[disabled],
+.adminhtml-customer-address-attribute-index .page-actions .add.disabled,
+.rating-index-index .page-actions .add[disabled],
+.rating-index-index .page-actions .add.disabled,
+.tax-rule-index .page-actions .add[disabled],
+.tax-rule-index .page-actions .add.disabled,
+.tax-rate-index .page-actions .add[disabled],
+.tax-rate-index .page-actions .add.disabled,
+.adminhtml-rma-item-attribute-index .page-actions .add[disabled],
+.adminhtml-rma-item-attribute-index .page-actions .add.disabled,
+.adminhtml-reward-rate-index .page-actions .add[disabled],
+.adminhtml-reward-rate-index .page-actions .add.disabled,
+.customer-group-index .page-actions .add[disabled],
+.customer-group-index .page-actions .add.disabled,
+.checkout-agreement-index .page-actions .add[disabled],
+.checkout-agreement-index .page-actions .add.disabled,
+.catalog-product-attribute-index .page-actions .add[disabled],
+.catalog-product-attribute-index .page-actions .add.disabled,
+.catalog-product-set-index .page-actions .add[disabled],
+.catalog-product-set-index .page-actions .add.disabled,
+.catalog-product-new .actions-split > .action-toggle.primary[disabled],
+.catalog-product-new .actions-split > .action-toggle.primary.disabled,
+.catalog-product-edit .actions-split > .action-toggle.primary[disabled],
+.catalog-product-edit .actions-split > .action-toggle.primary.disabled,
+.catalog-product-index .actions-split > .action-toggle.primary[disabled],
+.catalog-product-index .actions-split > .action-toggle.primary.disabled,
+.adminhtml-integration-new .actions-split > .action-toggle.primary[disabled],
+.adminhtml-integration-new .actions-split > .action-toggle.primary.disabled,
+.catalog-product-new .actions-split.btn-round .action-default.primary[disabled],
+.catalog-product-new .actions-split.btn-round .action-default.primary.disabled,
+.catalog-product-edit .actions-split.btn-round .action-default.primary[disabled],
+.catalog-product-edit .actions-split.btn-round .action-default.primary.disabled,
+.catalog-product-index .actions-split.btn-round .action-default.primary[disabled],
+.catalog-product-index .actions-split.btn-round .action-default.primary.disabled,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary[disabled],
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary.disabled {
+  cursor: not-allowed;
+  opacity: 0.5;
+  filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50);
+}
+.DefaultButton[disabled]:hover,
+.DefaultButton.disabled:hover,
+.DefaultButton[disabled]:active,
+.DefaultButton.disabled:active,
+.PrimaryButton[disabled]:hover,
+.PrimaryButton.disabled:hover,
+.PrimaryButton[disabled]:active,
+.PrimaryButton.disabled:active,
+input[type=button][disabled]:hover,
+input[type=button].disabled:hover,
+input[type=button][disabled]:active,
+input[type=button].disabled:active,
+input[type=submit][disabled]:hover,
+input[type=submit].disabled:hover,
+input[type=submit][disabled]:active,
+input[type=submit].disabled:active,
+input[type=reset][disabled]:hover,
+input[type=reset].disabled:hover,
+input[type=reset][disabled]:active,
+input[type=reset].disabled:active,
+button[disabled]:hover,
+button.disabled:hover,
+button[disabled]:active,
+button.disabled:active,
+[class^="action-"][disabled]:hover,
+[class^="action-"].disabled:hover,
+[class^="action-"][disabled]:active,
+[class^="action-"].disabled:active,
+.popup-window .add-widget[disabled]:hover,
+.popup-window .add-widget.disabled:hover,
+.popup-window .add-widget[disabled]:active,
+.popup-window .add-widget.disabled:active,
+.PrimaryAddButton[disabled]:hover,
+.PrimaryAddButton.disabled:hover,
+.PrimaryAddButton[disabled]:active,
+.PrimaryAddButton.disabled:active,
+.PrimarySplitButton > .action-toggle.primary[disabled]:hover,
+.PrimarySplitButton > .action-toggle.primary.disabled:hover,
+.PrimarySplitButton > .action-toggle.primary[disabled]:active,
+.PrimarySplitButton > .action-toggle.primary.disabled:active,
+input[type=button].primary[disabled]:hover,
+input[type=button].primary.disabled:hover,
+input[type=button].primary[disabled]:active,
+input[type=button].primary.disabled:active,
+input[type=submit].primary[disabled]:hover,
+input[type=submit].primary.disabled:hover,
+input[type=submit].primary[disabled]:active,
+input[type=submit].primary.disabled:active,
+input[type=reset].primary[disabled]:hover,
+input[type=reset].primary.disabled:hover,
+input[type=reset].primary[disabled]:active,
+input[type=reset].primary.disabled:active,
+button.primary[disabled]:hover,
+button.primary.disabled:hover,
+button.primary[disabled]:active,
+button.primary.disabled:active,
+[class^="action-"].primary[disabled]:hover,
+[class^="action-"].primary.disabled:hover,
+[class^="action-"].primary[disabled]:active,
+[class^="action-"].primary.disabled:active,
+.popup-window .add-widget.primary[disabled]:hover,
+.popup-window .add-widget.primary.disabled:hover,
+.popup-window .add-widget.primary[disabled]:active,
+.popup-window .add-widget.primary.disabled:active,
+.PrimarySplitButton.btn-round .action-default.primary[disabled]:hover,
+.PrimarySplitButton.btn-round .action-default.primary.disabled:hover,
+.PrimarySplitButton.btn-round .action-default.primary[disabled]:active,
+.PrimarySplitButton.btn-round .action-default.primary.disabled:active,
+.sales-order-index .page-actions .add[disabled]:hover,
+.sales-order-index .page-actions .add.disabled:hover,
+.sales-order-index .page-actions .add[disabled]:active,
+.sales-order-index .page-actions .add.disabled:active,
+.adminhtml-rma-index .page-actions .add[disabled]:hover,
+.adminhtml-rma-index .page-actions .add.disabled:hover,
+.adminhtml-rma-index .page-actions .add[disabled]:active,
+.adminhtml-rma-index .page-actions .add.disabled:active,
+.adminhtml-catalog-event-index .page-actions .add[disabled]:hover,
+.adminhtml-catalog-event-index .page-actions .add.disabled:hover,
+.adminhtml-catalog-event-index .page-actions .add[disabled]:active,
+.adminhtml-catalog-event-index .page-actions .add.disabled:active,
+.adminhtml-urlrewrite-index .page-actions .add[disabled]:hover,
+.adminhtml-urlrewrite-index .page-actions .add.disabled:hover,
+.adminhtml-urlrewrite-index .page-actions .add[disabled]:active,
+.adminhtml-urlrewrite-index .page-actions .add.disabled:active,
+.catalog-search-index .page-actions .add[disabled]:hover,
+.catalog-search-index .page-actions .add.disabled:hover,
+.catalog-search-index .page-actions .add[disabled]:active,
+.catalog-search-index .page-actions .add.disabled:active,
+.catalog-product-review-index .page-actions .add[disabled]:hover,
+.catalog-product-review-index .page-actions .add.disabled:hover,
+.catalog-product-review-index .page-actions .add[disabled]:active,
+.catalog-product-review-index .page-actions .add.disabled:active,
+.catalog-rule-promo-catalog-index .page-actions .add[disabled]:hover,
+.catalog-rule-promo-catalog-index .page-actions .add.disabled:hover,
+.catalog-rule-promo-catalog-index .page-actions .add[disabled]:active,
+.catalog-rule-promo-catalog-index .page-actions .add.disabled:active,
+.sales-rule-promo-quote-index .page-actions .add[disabled]:hover,
+.sales-rule-promo-quote-index .page-actions .add.disabled:hover,
+.sales-rule-promo-quote-index .page-actions .add[disabled]:active,
+.sales-rule-promo-quote-index .page-actions .add.disabled:active,
+.adminhtml-reminder-index .page-actions .add[disabled]:hover,
+.adminhtml-reminder-index .page-actions .add.disabled:hover,
+.adminhtml-reminder-index .page-actions .add[disabled]:active,
+.adminhtml-reminder-index .page-actions .add.disabled:active,
+.newsletter-template-index .page-actions .add[disabled]:hover,
+.newsletter-template-index .page-actions .add.disabled:hover,
+.newsletter-template-index .page-actions .add[disabled]:active,
+.newsletter-template-index .page-actions .add.disabled:active,
+.adminhtml-system-email-template-index .page-actions .add[disabled]:hover,
+.adminhtml-system-email-template-index .page-actions .add.disabled:hover,
+.adminhtml-system-email-template-index .page-actions .add[disabled]:active,
+.adminhtml-system-email-template-index .page-actions .add.disabled:active,
+.adminhtml-sitemap-index .page-actions .add[disabled]:hover,
+.adminhtml-sitemap-index .page-actions .add.disabled:hover,
+.adminhtml-sitemap-index .page-actions .add[disabled]:active,
+.adminhtml-sitemap-index .page-actions .add.disabled:active,
+.adminhtml-googleshopping-types-index .page-actions .add[disabled]:hover,
+.adminhtml-googleshopping-types-index .page-actions .add.disabled:hover,
+.adminhtml-googleshopping-types-index .page-actions .add[disabled]:active,
+.adminhtml-googleshopping-types-index .page-actions .add.disabled:active,
+.customer-index-index .page-actions .add[disabled]:hover,
+.customer-index-index .page-actions .add.disabled:hover,
+.customer-index-index .page-actions .add[disabled]:active,
+.customer-index-index .page-actions .add.disabled:active,
+.adminhtml-cms-page-index .page-actions .add[disabled]:hover,
+.adminhtml-cms-page-index .page-actions .add.disabled:hover,
+.adminhtml-cms-page-index .page-actions .add[disabled]:active,
+.adminhtml-cms-page-index .page-actions .add.disabled:active,
+.cms-block-index .page-actions .add[disabled]:hover,
+.cms-block-index .page-actions .add.disabled:hover,
+.cms-block-index .page-actions .add[disabled]:active,
+.cms-block-index .page-actions .add.disabled:active,
+.adminhtml-banner-index .page-actions .add[disabled]:hover,
+.adminhtml-banner-index .page-actions .add.disabled:hover,
+.adminhtml-banner-index .page-actions .add[disabled]:active,
+.adminhtml-banner-index .page-actions .add.disabled:active,
+.adminhtml-widget-instance-index .page-actions .add[disabled]:hover,
+.adminhtml-widget-instance-index .page-actions .add.disabled:hover,
+.adminhtml-widget-instance-index .page-actions .add[disabled]:active,
+.adminhtml-widget-instance-index .page-actions .add.disabled:active,
+.cms-page-index .page-actions .add[disabled]:hover,
+.cms-page-index .page-actions .add.disabled:hover,
+.cms-page-index .page-actions .add[disabled]:active,
+.cms-page-index .page-actions .add.disabled:active,
+.adminhtml-webapi-user-index .page-actions .add[disabled]:hover,
+.adminhtml-webapi-user-index .page-actions .add.disabled:hover,
+.adminhtml-webapi-user-index .page-actions .add[disabled]:active,
+.adminhtml-webapi-user-index .page-actions .add.disabled:active,
+.adminhtml-webapi-role-index .page-actions .add[disabled]:hover,
+.adminhtml-webapi-role-index .page-actions .add.disabled:hover,
+.adminhtml-webapi-role-index .page-actions .add[disabled]:active,
+.adminhtml-webapi-role-index .page-actions .add.disabled:active,
+.adminhtml-system-variable-index .page-actions .add[disabled]:hover,
+.adminhtml-system-variable-index .page-actions .add.disabled:hover,
+.adminhtml-system-variable-index .page-actions .add[disabled]:active,
+.adminhtml-system-variable-index .page-actions .add.disabled:active,
+.adminhtml-user-index .page-actions .add[disabled]:hover,
+.adminhtml-user-index .page-actions .add.disabled:hover,
+.adminhtml-user-index .page-actions .add[disabled]:active,
+.adminhtml-user-index .page-actions .add.disabled:active,
+.adminhtml-user-role-index .page-actions .add[disabled]:hover,
+.adminhtml-user-role-index .page-actions .add.disabled:hover,
+.adminhtml-user-role-index .page-actions .add[disabled]:active,
+.adminhtml-user-role-index .page-actions .add.disabled:active,
+.adminhtml-integration-index .page-actions .add[disabled]:hover,
+.adminhtml-integration-index .page-actions .add.disabled:hover,
+.adminhtml-integration-index .page-actions .add[disabled]:active,
+.adminhtml-integration-index .page-actions .add.disabled:active,
+.adminhtml-system-design-theme-index .page-actions .add[disabled]:hover,
+.adminhtml-system-design-theme-index .page-actions .add.disabled:hover,
+.adminhtml-system-design-theme-index .page-actions .add[disabled]:active,
+.adminhtml-system-design-theme-index .page-actions .add.disabled:active,
+.adminhtml-system-design-index .page-actions .add[disabled]:hover,
+.adminhtml-system-design-index .page-actions .add.disabled:hover,
+.adminhtml-system-design-index .page-actions .add[disabled]:active,
+.adminhtml-system-design-index .page-actions .add.disabled:active,
+.adminhtml-customer-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-customer-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-customer-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-customer-attribute-index .page-actions .add.disabled:active,
+.adminhtml-customer-address-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-customer-address-attribute-index .page-actions .add.disabled:active,
+.rating-index-index .page-actions .add[disabled]:hover,
+.rating-index-index .page-actions .add.disabled:hover,
+.rating-index-index .page-actions .add[disabled]:active,
+.rating-index-index .page-actions .add.disabled:active,
+.tax-rule-index .page-actions .add[disabled]:hover,
+.tax-rule-index .page-actions .add.disabled:hover,
+.tax-rule-index .page-actions .add[disabled]:active,
+.tax-rule-index .page-actions .add.disabled:active,
+.tax-rate-index .page-actions .add[disabled]:hover,
+.tax-rate-index .page-actions .add.disabled:hover,
+.tax-rate-index .page-actions .add[disabled]:active,
+.tax-rate-index .page-actions .add.disabled:active,
+.adminhtml-rma-item-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-rma-item-attribute-index .page-actions .add.disabled:active,
+.adminhtml-reward-rate-index .page-actions .add[disabled]:hover,
+.adminhtml-reward-rate-index .page-actions .add.disabled:hover,
+.adminhtml-reward-rate-index .page-actions .add[disabled]:active,
+.adminhtml-reward-rate-index .page-actions .add.disabled:active,
+.customer-group-index .page-actions .add[disabled]:hover,
+.customer-group-index .page-actions .add.disabled:hover,
+.customer-group-index .page-actions .add[disabled]:active,
+.customer-group-index .page-actions .add.disabled:active,
+.checkout-agreement-index .page-actions .add[disabled]:hover,
+.checkout-agreement-index .page-actions .add.disabled:hover,
+.checkout-agreement-index .page-actions .add[disabled]:active,
+.checkout-agreement-index .page-actions .add.disabled:active,
+.catalog-product-attribute-index .page-actions .add[disabled]:hover,
+.catalog-product-attribute-index .page-actions .add.disabled:hover,
+.catalog-product-attribute-index .page-actions .add[disabled]:active,
+.catalog-product-attribute-index .page-actions .add.disabled:active,
+.catalog-product-set-index .page-actions .add[disabled]:hover,
+.catalog-product-set-index .page-actions .add.disabled:hover,
+.catalog-product-set-index .page-actions .add[disabled]:active,
+.catalog-product-set-index .page-actions .add.disabled:active,
+.catalog-product-new .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-new .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-new .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-new .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-edit .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-edit .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-index .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-index .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-index .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-index .actions-split > .action-toggle.primary.disabled:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary[disabled]:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary.disabled:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary[disabled]:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary.disabled:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary.disabled:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary.disabled:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary[disabled]:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary.disabled:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary[disabled]:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary.disabled:active {
+  color: #676056;
+  background: #f2ebde;
+  border: 1px solid #ada89e;
+}
+.PrimaryButton,
+.PrimaryAddButton,
+.PrimarySplitButton > .action-toggle.primary,
+input[type=button].primary,
+input[type=submit].primary,
+input[type=reset].primary,
+button.primary,
+[class^="action-"].primary,
+.popup-window .add-widget.primary,
+.PrimarySplitButton.btn-round .action-default.primary,
+.sales-order-index .page-actions .add,
+.adminhtml-rma-index .page-actions .add,
+.adminhtml-catalog-event-index .page-actions .add,
+.adminhtml-urlrewrite-index .page-actions .add,
+.catalog-search-index .page-actions .add,
+.catalog-product-review-index .page-actions .add,
+.catalog-rule-promo-catalog-index .page-actions .add,
+.sales-rule-promo-quote-index .page-actions .add,
+.adminhtml-reminder-index .page-actions .add,
+.newsletter-template-index .page-actions .add,
+.adminhtml-system-email-template-index .page-actions .add,
+.adminhtml-sitemap-index .page-actions .add,
+.adminhtml-googleshopping-types-index .page-actions .add,
+.customer-index-index .page-actions .add,
+.adminhtml-cms-page-index .page-actions .add,
+.cms-block-index .page-actions .add,
+.adminhtml-banner-index .page-actions .add,
+.adminhtml-widget-instance-index .page-actions .add,
+.cms-page-index .page-actions .add,
+.adminhtml-webapi-user-index .page-actions .add,
+.adminhtml-webapi-role-index .page-actions .add,
+.adminhtml-system-variable-index .page-actions .add,
+.adminhtml-user-index .page-actions .add,
+.adminhtml-user-role-index .page-actions .add,
+.adminhtml-integration-index .page-actions .add,
+.adminhtml-system-design-theme-index .page-actions .add,
+.adminhtml-system-design-index .page-actions .add,
+.adminhtml-customer-attribute-index .page-actions .add,
+.adminhtml-customer-address-attribute-index .page-actions .add,
+.rating-index-index .page-actions .add,
+.tax-rule-index .page-actions .add,
+.tax-rate-index .page-actions .add,
+.adminhtml-rma-item-attribute-index .page-actions .add,
+.adminhtml-reward-rate-index .page-actions .add,
+.customer-group-index .page-actions .add,
+.checkout-agreement-index .page-actions .add,
+.catalog-product-attribute-index .page-actions .add,
+.catalog-product-set-index .page-actions .add,
+.catalog-product-new .actions-split > .action-toggle.primary,
+.catalog-product-edit .actions-split > .action-toggle.primary,
+.catalog-product-index .actions-split > .action-toggle.primary,
+.adminhtml-integration-new .actions-split > .action-toggle.primary,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary,
+.PrimaryAddButton,
+.PrimarySplitButton > .action-toggle.primary,
+input[type=button].primary,
+input[type=submit].primary,
+input[type=reset].primary,
+button.primary,
+[class^="action-"].primary,
+.popup-window .add-widget.primary,
+.PrimarySplitButton.btn-round .action-default.primary,
+.sales-order-index .page-actions .add,
+.adminhtml-rma-index .page-actions .add,
+.adminhtml-catalog-event-index .page-actions .add,
+.adminhtml-urlrewrite-index .page-actions .add,
+.catalog-search-index .page-actions .add,
+.catalog-product-review-index .page-actions .add,
+.catalog-rule-promo-catalog-index .page-actions .add,
+.sales-rule-promo-quote-index .page-actions .add,
+.adminhtml-reminder-index .page-actions .add,
+.newsletter-template-index .page-actions .add,
+.adminhtml-system-email-template-index .page-actions .add,
+.adminhtml-sitemap-index .page-actions .add,
+.adminhtml-googleshopping-types-index .page-actions .add,
+.customer-index-index .page-actions .add,
+.adminhtml-cms-page-index .page-actions .add,
+.cms-block-index .page-actions .add,
+.adminhtml-banner-index .page-actions .add,
+.adminhtml-widget-instance-index .page-actions .add,
+.cms-page-index .page-actions .add,
+.adminhtml-webapi-user-index .page-actions .add,
+.adminhtml-webapi-role-index .page-actions .add,
+.adminhtml-system-variable-index .page-actions .add,
+.adminhtml-user-index .page-actions .add,
+.adminhtml-user-role-index .page-actions .add,
+.adminhtml-integration-index .page-actions .add,
+.adminhtml-system-design-theme-index .page-actions .add,
+.adminhtml-system-design-index .page-actions .add,
+.adminhtml-customer-attribute-index .page-actions .add,
+.adminhtml-customer-address-attribute-index .page-actions .add,
+.rating-index-index .page-actions .add,
+.tax-rule-index .page-actions .add,
+.tax-rate-index .page-actions .add,
+.adminhtml-rma-item-attribute-index .page-actions .add,
+.adminhtml-reward-rate-index .page-actions .add,
+.customer-group-index .page-actions .add,
+.checkout-agreement-index .page-actions .add,
+.catalog-product-attribute-index .page-actions .add,
+.catalog-product-set-index .page-actions .add,
+.catalog-product-new .actions-split > .action-toggle.primary,
+.catalog-product-edit .actions-split > .action-toggle.primary,
+.catalog-product-index .actions-split > .action-toggle.primary,
+.adminhtml-integration-new .actions-split > .action-toggle.primary,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary {
+  color: #fff;
+  background: #007dbd;
+  border: 1px solid #0574ad;
+}
+.PrimaryButton:focus,
+.PrimaryButton:hover,
+.PrimaryAddButton:focus,
+.PrimaryAddButton:hover,
+.PrimarySplitButton > .action-toggle.primary:focus,
+.PrimarySplitButton > .action-toggle.primary:hover,
+input[type=button].primary:focus,
+input[type=button].primary:hover,
+input[type=submit].primary:focus,
+input[type=submit].primary:hover,
+input[type=reset].primary:focus,
+input[type=reset].primary:hover,
+button.primary:focus,
+button.primary:hover,
+[class^="action-"].primary:focus,
+[class^="action-"].primary:hover,
+.popup-window .add-widget.primary:focus,
+.popup-window .add-widget.primary:hover,
+.PrimarySplitButton.btn-round .action-default.primary:focus,
+.PrimarySplitButton.btn-round .action-default.primary:hover,
+.sales-order-index .page-actions .add:focus,
+.sales-order-index .page-actions .add:hover,
+.adminhtml-rma-index .page-actions .add:focus,
+.adminhtml-rma-index .page-actions .add:hover,
+.adminhtml-catalog-event-index .page-actions .add:focus,
+.adminhtml-catalog-event-index .page-actions .add:hover,
+.adminhtml-urlrewrite-index .page-actions .add:focus,
+.adminhtml-urlrewrite-index .page-actions .add:hover,
+.catalog-search-index .page-actions .add:focus,
+.catalog-search-index .page-actions .add:hover,
+.catalog-product-review-index .page-actions .add:focus,
+.catalog-product-review-index .page-actions .add:hover,
+.catalog-rule-promo-catalog-index .page-actions .add:focus,
+.catalog-rule-promo-catalog-index .page-actions .add:hover,
+.sales-rule-promo-quote-index .page-actions .add:focus,
+.sales-rule-promo-quote-index .page-actions .add:hover,
+.adminhtml-reminder-index .page-actions .add:focus,
+.adminhtml-reminder-index .page-actions .add:hover,
+.newsletter-template-index .page-actions .add:focus,
+.newsletter-template-index .page-actions .add:hover,
+.adminhtml-system-email-template-index .page-actions .add:focus,
+.adminhtml-system-email-template-index .page-actions .add:hover,
+.adminhtml-sitemap-index .page-actions .add:focus,
+.adminhtml-sitemap-index .page-actions .add:hover,
+.adminhtml-googleshopping-types-index .page-actions .add:focus,
+.adminhtml-googleshopping-types-index .page-actions .add:hover,
+.customer-index-index .page-actions .add:focus,
+.customer-index-index .page-actions .add:hover,
+.adminhtml-cms-page-index .page-actions .add:focus,
+.adminhtml-cms-page-index .page-actions .add:hover,
+.cms-block-index .page-actions .add:focus,
+.cms-block-index .page-actions .add:hover,
+.adminhtml-banner-index .page-actions .add:focus,
+.adminhtml-banner-index .page-actions .add:hover,
+.adminhtml-widget-instance-index .page-actions .add:focus,
+.adminhtml-widget-instance-index .page-actions .add:hover,
+.cms-page-index .page-actions .add:focus,
+.cms-page-index .page-actions .add:hover,
+.adminhtml-webapi-user-index .page-actions .add:focus,
+.adminhtml-webapi-user-index .page-actions .add:hover,
+.adminhtml-webapi-role-index .page-actions .add:focus,
+.adminhtml-webapi-role-index .page-actions .add:hover,
+.adminhtml-system-variable-index .page-actions .add:focus,
+.adminhtml-system-variable-index .page-actions .add:hover,
+.adminhtml-user-index .page-actions .add:focus,
+.adminhtml-user-index .page-actions .add:hover,
+.adminhtml-user-role-index .page-actions .add:focus,
+.adminhtml-user-role-index .page-actions .add:hover,
+.adminhtml-integration-index .page-actions .add:focus,
+.adminhtml-integration-index .page-actions .add:hover,
+.adminhtml-system-design-theme-index .page-actions .add:focus,
+.adminhtml-system-design-theme-index .page-actions .add:hover,
+.adminhtml-system-design-index .page-actions .add:focus,
+.adminhtml-system-design-index .page-actions .add:hover,
+.adminhtml-customer-attribute-index .page-actions .add:focus,
+.adminhtml-customer-attribute-index .page-actions .add:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add:focus,
+.adminhtml-customer-address-attribute-index .page-actions .add:hover,
+.rating-index-index .page-actions .add:focus,
+.rating-index-index .page-actions .add:hover,
+.tax-rule-index .page-actions .add:focus,
+.tax-rule-index .page-actions .add:hover,
+.tax-rate-index .page-actions .add:focus,
+.tax-rate-index .page-actions .add:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add:focus,
+.adminhtml-rma-item-attribute-index .page-actions .add:hover,
+.adminhtml-reward-rate-index .page-actions .add:focus,
+.adminhtml-reward-rate-index .page-actions .add:hover,
+.customer-group-index .page-actions .add:focus,
+.customer-group-index .page-actions .add:hover,
+.checkout-agreement-index .page-actions .add:focus,
+.checkout-agreement-index .page-actions .add:hover,
+.catalog-product-attribute-index .page-actions .add:focus,
+.catalog-product-attribute-index .page-actions .add:hover,
+.catalog-product-set-index .page-actions .add:focus,
+.catalog-product-set-index .page-actions .add:hover,
+.catalog-product-new .actions-split > .action-toggle.primary:focus,
+.catalog-product-new .actions-split > .action-toggle.primary:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary:focus,
+.catalog-product-edit .actions-split > .action-toggle.primary:hover,
+.catalog-product-index .actions-split > .action-toggle.primary:focus,
+.catalog-product-index .actions-split > .action-toggle.primary:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:focus,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-new .actions-split.btn-round .action-default.primary:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-index .actions-split.btn-round .action-default.primary:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:focus,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:hover {
+  color: #fff;
+  background: #026294;
+  border: 1px solid #026294;
+}
+.PrimaryButton:active,
+.PrimaryAddButton:active,
+.PrimarySplitButton > .action-toggle.primary:active,
+input[type=button].primary:active,
+input[type=submit].primary:active,
+input[type=reset].primary:active,
+button.primary:active,
+[class^="action-"].primary:active,
+.popup-window .add-widget.primary:active,
+.PrimarySplitButton.btn-round .action-default.primary:active,
+.sales-order-index .page-actions .add:active,
+.adminhtml-rma-index .page-actions .add:active,
+.adminhtml-catalog-event-index .page-actions .add:active,
+.adminhtml-urlrewrite-index .page-actions .add:active,
+.catalog-search-index .page-actions .add:active,
+.catalog-product-review-index .page-actions .add:active,
+.catalog-rule-promo-catalog-index .page-actions .add:active,
+.sales-rule-promo-quote-index .page-actions .add:active,
+.adminhtml-reminder-index .page-actions .add:active,
+.newsletter-template-index .page-actions .add:active,
+.adminhtml-system-email-template-index .page-actions .add:active,
+.adminhtml-sitemap-index .page-actions .add:active,
+.adminhtml-googleshopping-types-index .page-actions .add:active,
+.customer-index-index .page-actions .add:active,
+.adminhtml-cms-page-index .page-actions .add:active,
+.cms-block-index .page-actions .add:active,
+.adminhtml-banner-index .page-actions .add:active,
+.adminhtml-widget-instance-index .page-actions .add:active,
+.cms-page-index .page-actions .add:active,
+.adminhtml-webapi-user-index .page-actions .add:active,
+.adminhtml-webapi-role-index .page-actions .add:active,
+.adminhtml-system-variable-index .page-actions .add:active,
+.adminhtml-user-index .page-actions .add:active,
+.adminhtml-user-role-index .page-actions .add:active,
+.adminhtml-integration-index .page-actions .add:active,
+.adminhtml-system-design-theme-index .page-actions .add:active,
+.adminhtml-system-design-index .page-actions .add:active,
+.adminhtml-customer-attribute-index .page-actions .add:active,
+.adminhtml-customer-address-attribute-index .page-actions .add:active,
+.rating-index-index .page-actions .add:active,
+.tax-rule-index .page-actions .add:active,
+.tax-rate-index .page-actions .add:active,
+.adminhtml-rma-item-attribute-index .page-actions .add:active,
+.adminhtml-reward-rate-index .page-actions .add:active,
+.customer-group-index .page-actions .add:active,
+.checkout-agreement-index .page-actions .add:active,
+.catalog-product-attribute-index .page-actions .add:active,
+.catalog-product-set-index .page-actions .add:active,
+.catalog-product-new .actions-split > .action-toggle.primary:active,
+.catalog-product-edit .actions-split > .action-toggle.primary:active,
+.catalog-product-index .actions-split > .action-toggle.primary:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:active {
+  color: #fff;
+  background: #026294;
+  border: 1px solid #004c74;
+}
+.PrimaryButton:visited,
+.PrimaryAddButton:visited,
+.PrimarySplitButton > .action-toggle.primary:visited,
+input[type=button].primary:visited,
+input[type=submit].primary:visited,
+input[type=reset].primary:visited,
+button.primary:visited,
+[class^="action-"].primary:visited,
+.popup-window .add-widget.primary:visited,
+.PrimarySplitButton.btn-round .action-default.primary:visited,
+.sales-order-index .page-actions .add:visited,
+.adminhtml-rma-index .page-actions .add:visited,
+.adminhtml-catalog-event-index .page-actions .add:visited,
+.adminhtml-urlrewrite-index .page-actions .add:visited,
+.catalog-search-index .page-actions .add:visited,
+.catalog-product-review-index .page-actions .add:visited,
+.catalog-rule-promo-catalog-index .page-actions .add:visited,
+.sales-rule-promo-quote-index .page-actions .add:visited,
+.adminhtml-reminder-index .page-actions .add:visited,
+.newsletter-template-index .page-actions .add:visited,
+.adminhtml-system-email-template-index .page-actions .add:visited,
+.adminhtml-sitemap-index .page-actions .add:visited,
+.adminhtml-googleshopping-types-index .page-actions .add:visited,
+.customer-index-index .page-actions .add:visited,
+.adminhtml-cms-page-index .page-actions .add:visited,
+.cms-block-index .page-actions .add:visited,
+.adminhtml-banner-index .page-actions .add:visited,
+.adminhtml-widget-instance-index .page-actions .add:visited,
+.cms-page-index .page-actions .add:visited,
+.adminhtml-webapi-user-index .page-actions .add:visited,
+.adminhtml-webapi-role-index .page-actions .add:visited,
+.adminhtml-system-variable-index .page-actions .add:visited,
+.adminhtml-user-index .page-actions .add:visited,
+.adminhtml-user-role-index .page-actions .add:visited,
+.adminhtml-integration-index .page-actions .add:visited,
+.adminhtml-system-design-theme-index .page-actions .add:visited,
+.adminhtml-system-design-index .page-actions .add:visited,
+.adminhtml-customer-attribute-index .page-actions .add:visited,
+.adminhtml-customer-address-attribute-index .page-actions .add:visited,
+.rating-index-index .page-actions .add:visited,
+.tax-rule-index .page-actions .add:visited,
+.tax-rate-index .page-actions .add:visited,
+.adminhtml-rma-item-attribute-index .page-actions .add:visited,
+.adminhtml-reward-rate-index .page-actions .add:visited,
+.customer-group-index .page-actions .add:visited,
+.checkout-agreement-index .page-actions .add:visited,
+.catalog-product-attribute-index .page-actions .add:visited,
+.catalog-product-set-index .page-actions .add:visited,
+.catalog-product-new .actions-split > .action-toggle.primary:visited,
+.catalog-product-edit .actions-split > .action-toggle.primary:visited,
+.catalog-product-index .actions-split > .action-toggle.primary:visited,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:visited,
+.catalog-product-new .actions-split.btn-round .action-default.primary:visited,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:visited,
+.catalog-product-index .actions-split.btn-round .action-default.primary:visited,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:visited {
+  color: #fff;
+}
+.PrimaryButton[disabled]:hover,
+.PrimaryButton.disabled:hover,
+.PrimaryButton[disabled]:active,
+.PrimaryButton.disabled:active,
+.PrimaryAddButton[disabled]:hover,
+.PrimaryAddButton.disabled:hover,
+.PrimaryAddButton[disabled]:active,
+.PrimaryAddButton.disabled:active,
+.PrimarySplitButton > .action-toggle.primary[disabled]:hover,
+.PrimarySplitButton > .action-toggle.primary.disabled:hover,
+.PrimarySplitButton > .action-toggle.primary[disabled]:active,
+.PrimarySplitButton > .action-toggle.primary.disabled:active,
+input[type=button].primary[disabled]:hover,
+input[type=button].primary.disabled:hover,
+input[type=button].primary[disabled]:active,
+input[type=button].primary.disabled:active,
+input[type=submit].primary[disabled]:hover,
+input[type=submit].primary.disabled:hover,
+input[type=submit].primary[disabled]:active,
+input[type=submit].primary.disabled:active,
+input[type=reset].primary[disabled]:hover,
+input[type=reset].primary.disabled:hover,
+input[type=reset].primary[disabled]:active,
+input[type=reset].primary.disabled:active,
+button.primary[disabled]:hover,
+button.primary.disabled:hover,
+button.primary[disabled]:active,
+button.primary.disabled:active,
+[class^="action-"].primary[disabled]:hover,
+[class^="action-"].primary.disabled:hover,
+[class^="action-"].primary[disabled]:active,
+[class^="action-"].primary.disabled:active,
+.popup-window .add-widget.primary[disabled]:hover,
+.popup-window .add-widget.primary.disabled:hover,
+.popup-window .add-widget.primary[disabled]:active,
+.popup-window .add-widget.primary.disabled:active,
+.PrimarySplitButton.btn-round .action-default.primary[disabled]:hover,
+.PrimarySplitButton.btn-round .action-default.primary.disabled:hover,
+.PrimarySplitButton.btn-round .action-default.primary[disabled]:active,
+.PrimarySplitButton.btn-round .action-default.primary.disabled:active,
+.sales-order-index .page-actions .add[disabled]:hover,
+.sales-order-index .page-actions .add.disabled:hover,
+.sales-order-index .page-actions .add[disabled]:active,
+.sales-order-index .page-actions .add.disabled:active,
+.adminhtml-rma-index .page-actions .add[disabled]:hover,
+.adminhtml-rma-index .page-actions .add.disabled:hover,
+.adminhtml-rma-index .page-actions .add[disabled]:active,
+.adminhtml-rma-index .page-actions .add.disabled:active,
+.adminhtml-catalog-event-index .page-actions .add[disabled]:hover,
+.adminhtml-catalog-event-index .page-actions .add.disabled:hover,
+.adminhtml-catalog-event-index .page-actions .add[disabled]:active,
+.adminhtml-catalog-event-index .page-actions .add.disabled:active,
+.adminhtml-urlrewrite-index .page-actions .add[disabled]:hover,
+.adminhtml-urlrewrite-index .page-actions .add.disabled:hover,
+.adminhtml-urlrewrite-index .page-actions .add[disabled]:active,
+.adminhtml-urlrewrite-index .page-actions .add.disabled:active,
+.catalog-search-index .page-actions .add[disabled]:hover,
+.catalog-search-index .page-actions .add.disabled:hover,
+.catalog-search-index .page-actions .add[disabled]:active,
+.catalog-search-index .page-actions .add.disabled:active,
+.catalog-product-review-index .page-actions .add[disabled]:hover,
+.catalog-product-review-index .page-actions .add.disabled:hover,
+.catalog-product-review-index .page-actions .add[disabled]:active,
+.catalog-product-review-index .page-actions .add.disabled:active,
+.catalog-rule-promo-catalog-index .page-actions .add[disabled]:hover,
+.catalog-rule-promo-catalog-index .page-actions .add.disabled:hover,
+.catalog-rule-promo-catalog-index .page-actions .add[disabled]:active,
+.catalog-rule-promo-catalog-index .page-actions .add.disabled:active,
+.sales-rule-promo-quote-index .page-actions .add[disabled]:hover,
+.sales-rule-promo-quote-index .page-actions .add.disabled:hover,
+.sales-rule-promo-quote-index .page-actions .add[disabled]:active,
+.sales-rule-promo-quote-index .page-actions .add.disabled:active,
+.adminhtml-reminder-index .page-actions .add[disabled]:hover,
+.adminhtml-reminder-index .page-actions .add.disabled:hover,
+.adminhtml-reminder-index .page-actions .add[disabled]:active,
+.adminhtml-reminder-index .page-actions .add.disabled:active,
+.newsletter-template-index .page-actions .add[disabled]:hover,
+.newsletter-template-index .page-actions .add.disabled:hover,
+.newsletter-template-index .page-actions .add[disabled]:active,
+.newsletter-template-index .page-actions .add.disabled:active,
+.adminhtml-system-email-template-index .page-actions .add[disabled]:hover,
+.adminhtml-system-email-template-index .page-actions .add.disabled:hover,
+.adminhtml-system-email-template-index .page-actions .add[disabled]:active,
+.adminhtml-system-email-template-index .page-actions .add.disabled:active,
+.adminhtml-sitemap-index .page-actions .add[disabled]:hover,
+.adminhtml-sitemap-index .page-actions .add.disabled:hover,
+.adminhtml-sitemap-index .page-actions .add[disabled]:active,
+.adminhtml-sitemap-index .page-actions .add.disabled:active,
+.adminhtml-googleshopping-types-index .page-actions .add[disabled]:hover,
+.adminhtml-googleshopping-types-index .page-actions .add.disabled:hover,
+.adminhtml-googleshopping-types-index .page-actions .add[disabled]:active,
+.adminhtml-googleshopping-types-index .page-actions .add.disabled:active,
+.customer-index-index .page-actions .add[disabled]:hover,
+.customer-index-index .page-actions .add.disabled:hover,
+.customer-index-index .page-actions .add[disabled]:active,
+.customer-index-index .page-actions .add.disabled:active,
+.adminhtml-cms-page-index .page-actions .add[disabled]:hover,
+.adminhtml-cms-page-index .page-actions .add.disabled:hover,
+.adminhtml-cms-page-index .page-actions .add[disabled]:active,
+.adminhtml-cms-page-index .page-actions .add.disabled:active,
+.cms-block-index .page-actions .add[disabled]:hover,
+.cms-block-index .page-actions .add.disabled:hover,
+.cms-block-index .page-actions .add[disabled]:active,
+.cms-block-index .page-actions .add.disabled:active,
+.adminhtml-banner-index .page-actions .add[disabled]:hover,
+.adminhtml-banner-index .page-actions .add.disabled:hover,
+.adminhtml-banner-index .page-actions .add[disabled]:active,
+.adminhtml-banner-index .page-actions .add.disabled:active,
+.adminhtml-widget-instance-index .page-actions .add[disabled]:hover,
+.adminhtml-widget-instance-index .page-actions .add.disabled:hover,
+.adminhtml-widget-instance-index .page-actions .add[disabled]:active,
+.adminhtml-widget-instance-index .page-actions .add.disabled:active,
+.cms-page-index .page-actions .add[disabled]:hover,
+.cms-page-index .page-actions .add.disabled:hover,
+.cms-page-index .page-actions .add[disabled]:active,
+.cms-page-index .page-actions .add.disabled:active,
+.adminhtml-webapi-user-index .page-actions .add[disabled]:hover,
+.adminhtml-webapi-user-index .page-actions .add.disabled:hover,
+.adminhtml-webapi-user-index .page-actions .add[disabled]:active,
+.adminhtml-webapi-user-index .page-actions .add.disabled:active,
+.adminhtml-webapi-role-index .page-actions .add[disabled]:hover,
+.adminhtml-webapi-role-index .page-actions .add.disabled:hover,
+.adminhtml-webapi-role-index .page-actions .add[disabled]:active,
+.adminhtml-webapi-role-index .page-actions .add.disabled:active,
+.adminhtml-system-variable-index .page-actions .add[disabled]:hover,
+.adminhtml-system-variable-index .page-actions .add.disabled:hover,
+.adminhtml-system-variable-index .page-actions .add[disabled]:active,
+.adminhtml-system-variable-index .page-actions .add.disabled:active,
+.adminhtml-user-index .page-actions .add[disabled]:hover,
+.adminhtml-user-index .page-actions .add.disabled:hover,
+.adminhtml-user-index .page-actions .add[disabled]:active,
+.adminhtml-user-index .page-actions .add.disabled:active,
+.adminhtml-user-role-index .page-actions .add[disabled]:hover,
+.adminhtml-user-role-index .page-actions .add.disabled:hover,
+.adminhtml-user-role-index .page-actions .add[disabled]:active,
+.adminhtml-user-role-index .page-actions .add.disabled:active,
+.adminhtml-integration-index .page-actions .add[disabled]:hover,
+.adminhtml-integration-index .page-actions .add.disabled:hover,
+.adminhtml-integration-index .page-actions .add[disabled]:active,
+.adminhtml-integration-index .page-actions .add.disabled:active,
+.adminhtml-system-design-theme-index .page-actions .add[disabled]:hover,
+.adminhtml-system-design-theme-index .page-actions .add.disabled:hover,
+.adminhtml-system-design-theme-index .page-actions .add[disabled]:active,
+.adminhtml-system-design-theme-index .page-actions .add.disabled:active,
+.adminhtml-system-design-index .page-actions .add[disabled]:hover,
+.adminhtml-system-design-index .page-actions .add.disabled:hover,
+.adminhtml-system-design-index .page-actions .add[disabled]:active,
+.adminhtml-system-design-index .page-actions .add.disabled:active,
+.adminhtml-customer-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-customer-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-customer-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-customer-attribute-index .page-actions .add.disabled:active,
+.adminhtml-customer-address-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-customer-address-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-customer-address-attribute-index .page-actions .add.disabled:active,
+.rating-index-index .page-actions .add[disabled]:hover,
+.rating-index-index .page-actions .add.disabled:hover,
+.rating-index-index .page-actions .add[disabled]:active,
+.rating-index-index .page-actions .add.disabled:active,
+.tax-rule-index .page-actions .add[disabled]:hover,
+.tax-rule-index .page-actions .add.disabled:hover,
+.tax-rule-index .page-actions .add[disabled]:active,
+.tax-rule-index .page-actions .add.disabled:active,
+.tax-rate-index .page-actions .add[disabled]:hover,
+.tax-rate-index .page-actions .add.disabled:hover,
+.tax-rate-index .page-actions .add[disabled]:active,
+.tax-rate-index .page-actions .add.disabled:active,
+.adminhtml-rma-item-attribute-index .page-actions .add[disabled]:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add.disabled:hover,
+.adminhtml-rma-item-attribute-index .page-actions .add[disabled]:active,
+.adminhtml-rma-item-attribute-index .page-actions .add.disabled:active,
+.adminhtml-reward-rate-index .page-actions .add[disabled]:hover,
+.adminhtml-reward-rate-index .page-actions .add.disabled:hover,
+.adminhtml-reward-rate-index .page-actions .add[disabled]:active,
+.adminhtml-reward-rate-index .page-actions .add.disabled:active,
+.customer-group-index .page-actions .add[disabled]:hover,
+.customer-group-index .page-actions .add.disabled:hover,
+.customer-group-index .page-actions .add[disabled]:active,
+.customer-group-index .page-actions .add.disabled:active,
+.checkout-agreement-index .page-actions .add[disabled]:hover,
+.checkout-agreement-index .page-actions .add.disabled:hover,
+.checkout-agreement-index .page-actions .add[disabled]:active,
+.checkout-agreement-index .page-actions .add.disabled:active,
+.catalog-product-attribute-index .page-actions .add[disabled]:hover,
+.catalog-product-attribute-index .page-actions .add.disabled:hover,
+.catalog-product-attribute-index .page-actions .add[disabled]:active,
+.catalog-product-attribute-index .page-actions .add.disabled:active,
+.catalog-product-set-index .page-actions .add[disabled]:hover,
+.catalog-product-set-index .page-actions .add.disabled:hover,
+.catalog-product-set-index .page-actions .add[disabled]:active,
+.catalog-product-set-index .page-actions .add.disabled:active,
+.catalog-product-new .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-new .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-new .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-new .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-edit .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-edit .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-edit .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-index .actions-split > .action-toggle.primary[disabled]:hover,
+.catalog-product-index .actions-split > .action-toggle.primary.disabled:hover,
+.catalog-product-index .actions-split > .action-toggle.primary[disabled]:active,
+.catalog-product-index .actions-split > .action-toggle.primary.disabled:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary[disabled]:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary.disabled:hover,
+.adminhtml-integration-new .actions-split > .action-toggle.primary[disabled]:active,
+.adminhtml-integration-new .actions-split > .action-toggle.primary.disabled:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-new .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-new .actions-split.btn-round .action-default.primary.disabled:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-edit .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-edit .actions-split.btn-round .action-default.primary.disabled:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary[disabled]:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary.disabled:hover,
+.catalog-product-index .actions-split.btn-round .action-default.primary[disabled]:active,
+.catalog-product-index .actions-split.btn-round .action-default.primary.disabled:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary[disabled]:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary.disabled:hover,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary[disabled]:active,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary.disabled:active {
+  color: #fff;
+  background: #007dbd;
+  border: 1px solid #0574ad;
+}
+.PrimaryAddButton,
+.PrimarySplitButton.btn-round .action-default.primary,
+.sales-order-index .page-actions .add,
+.adminhtml-rma-index .page-actions .add,
+.adminhtml-catalog-event-index .page-actions .add,
+.adminhtml-urlrewrite-index .page-actions .add,
+.catalog-search-index .page-actions .add,
+.catalog-product-review-index .page-actions .add,
+.catalog-rule-promo-catalog-index .page-actions .add,
+.sales-rule-promo-quote-index .page-actions .add,
+.adminhtml-reminder-index .page-actions .add,
+.newsletter-template-index .page-actions .add,
+.adminhtml-system-email-template-index .page-actions .add,
+.adminhtml-sitemap-index .page-actions .add,
+.adminhtml-googleshopping-types-index .page-actions .add,
+.customer-index-index .page-actions .add,
+.adminhtml-cms-page-index .page-actions .add,
+.cms-block-index .page-actions .add,
+.adminhtml-banner-index .page-actions .add,
+.adminhtml-widget-instance-index .page-actions .add,
+.cms-page-index .page-actions .add,
+.adminhtml-webapi-user-index .page-actions .add,
+.adminhtml-webapi-role-index .page-actions .add,
+.adminhtml-system-variable-index .page-actions .add,
+.adminhtml-user-index .page-actions .add,
+.adminhtml-user-role-index .page-actions .add,
+.adminhtml-integration-index .page-actions .add,
+.adminhtml-system-design-theme-index .page-actions .add,
+.adminhtml-system-design-index .page-actions .add,
+.adminhtml-customer-attribute-index .page-actions .add,
+.adminhtml-customer-address-attribute-index .page-actions .add,
+.rating-index-index .page-actions .add,
+.tax-rule-index .page-actions .add,
+.tax-rate-index .page-actions .add,
+.adminhtml-rma-item-attribute-index .page-actions .add,
+.adminhtml-reward-rate-index .page-actions .add,
+.customer-group-index .page-actions .add,
+.checkout-agreement-index .page-actions .add,
+.catalog-product-attribute-index .page-actions .add,
+.catalog-product-set-index .page-actions .add,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary,
+.PrimarySplitButton.btn-round .action-default.primary,
+.sales-order-index .page-actions .add,
+.adminhtml-rma-index .page-actions .add,
+.adminhtml-catalog-event-index .page-actions .add,
+.adminhtml-urlrewrite-index .page-actions .add,
+.catalog-search-index .page-actions .add,
+.catalog-product-review-index .page-actions .add,
+.catalog-rule-promo-catalog-index .page-actions .add,
+.sales-rule-promo-quote-index .page-actions .add,
+.adminhtml-reminder-index .page-actions .add,
+.newsletter-template-index .page-actions .add,
+.adminhtml-system-email-template-index .page-actions .add,
+.adminhtml-sitemap-index .page-actions .add,
+.adminhtml-googleshopping-types-index .page-actions .add,
+.customer-index-index .page-actions .add,
+.adminhtml-cms-page-index .page-actions .add,
+.cms-block-index .page-actions .add,
+.adminhtml-banner-index .page-actions .add,
+.adminhtml-widget-instance-index .page-actions .add,
+.cms-page-index .page-actions .add,
+.adminhtml-webapi-user-index .page-actions .add,
+.adminhtml-webapi-role-index .page-actions .add,
+.adminhtml-system-variable-index .page-actions .add,
+.adminhtml-user-index .page-actions .add,
+.adminhtml-user-role-index .page-actions .add,
+.adminhtml-integration-index .page-actions .add,
+.adminhtml-system-design-theme-index .page-actions .add,
+.adminhtml-system-design-index .page-actions .add,
+.adminhtml-customer-attribute-index .page-actions .add,
+.adminhtml-customer-address-attribute-index .page-actions .add,
+.rating-index-index .page-actions .add,
+.tax-rule-index .page-actions .add,
+.tax-rate-index .page-actions .add,
+.adminhtml-rma-item-attribute-index .page-actions .add,
+.adminhtml-reward-rate-index .page-actions .add,
+.customer-group-index .page-actions .add,
+.checkout-agreement-index .page-actions .add,
+.catalog-product-attribute-index .page-actions .add,
+.catalog-product-set-index .page-actions .add,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary {
+  width: 36px;
+  height: 31px;
+  overflow: hidden;
+  position: relative;
+  z-index: 1;
+  padding: 0;
+}
+.PrimaryAddButton:focus,
+.PrimarySplitButton.btn-round .action-default.primary:focus,
+.sales-order-index .page-actions .add:focus,
+.adminhtml-rma-index .page-actions .add:focus,
+.adminhtml-catalog-event-index .page-actions .add:focus,
+.adminhtml-urlrewrite-index .page-actions .add:focus,
+.catalog-search-index .page-actions .add:focus,
+.catalog-product-review-index .page-actions .add:focus,
+.catalog-rule-promo-catalog-index .page-actions .add:focus,
+.sales-rule-promo-quote-index .page-actions .add:focus,
+.adminhtml-reminder-index .page-actions .add:focus,
+.newsletter-template-index .page-actions .add:focus,
+.adminhtml-system-email-template-index .page-actions .add:focus,
+.adminhtml-sitemap-index .page-actions .add:focus,
+.adminhtml-googleshopping-types-index .page-actions .add:focus,
+.customer-index-index .page-actions .add:focus,
+.adminhtml-cms-page-index .page-actions .add:focus,
+.cms-block-index .page-actions .add:focus,
+.adminhtml-banner-index .page-actions .add:focus,
+.adminhtml-widget-instance-index .page-actions .add:focus,
+.cms-page-index .page-actions .add:focus,
+.adminhtml-webapi-user-index .page-actions .add:focus,
+.adminhtml-webapi-role-index .page-actions .add:focus,
+.adminhtml-system-variable-index .page-actions .add:focus,
+.adminhtml-user-index .page-actions .add:focus,
+.adminhtml-user-role-index .page-actions .add:focus,
+.adminhtml-integration-index .page-actions .add:focus,
+.adminhtml-system-design-theme-index .page-actions .add:focus,
+.adminhtml-system-design-index .page-actions .add:focus,
+.adminhtml-customer-attribute-index .page-actions .add:focus,
+.adminhtml-customer-address-attribute-index .page-actions .add:focus,
+.rating-index-index .page-actions .add:focus,
+.tax-rule-index .page-actions .add:focus,
+.tax-rate-index .page-actions .add:focus,
+.adminhtml-rma-item-attribute-index .page-actions .add:focus,
+.adminhtml-reward-rate-index .page-actions .add:focus,
+.customer-group-index .page-actions .add:focus,
+.checkout-agreement-index .page-actions .add:focus,
+.catalog-product-attribute-index .page-actions .add:focus,
+.catalog-product-set-index .page-actions .add:focus,
+.catalog-product-new .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-index .actions-split.btn-round .action-default.primary:focus,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:focus {
+  outline: none;
+}
+.PrimaryAddButton > span,
+.PrimarySplitButton.btn-round .action-default.primary > span,
+.sales-order-index .page-actions .add > span,
+.adminhtml-rma-index .page-actions .add > span,
+.adminhtml-catalog-event-index .page-actions .add > span,
+.adminhtml-urlrewrite-index .page-actions .add > span,
+.catalog-search-index .page-actions .add > span,
+.catalog-product-review-index .page-actions .add > span,
+.catalog-rule-promo-catalog-index .page-actions .add > span,
+.sales-rule-promo-quote-index .page-actions .add > span,
+.adminhtml-reminder-index .page-actions .add > span,
+.newsletter-template-index .page-actions .add > span,
+.adminhtml-system-email-template-index .page-actions .add > span,
+.adminhtml-sitemap-index .page-actions .add > span,
+.adminhtml-googleshopping-types-index .page-actions .add > span,
+.customer-index-index .page-actions .add > span,
+.adminhtml-cms-page-index .page-actions .add > span,
+.cms-block-index .page-actions .add > span,
+.adminhtml-banner-index .page-actions .add > span,
+.adminhtml-widget-instance-index .page-actions .add > span,
+.cms-page-index .page-actions .add > span,
+.adminhtml-webapi-user-index .page-actions .add > span,
+.adminhtml-webapi-role-index .page-actions .add > span,
+.adminhtml-system-variable-index .page-actions .add > span,
+.adminhtml-user-index .page-actions .add > span,
+.adminhtml-user-role-index .page-actions .add > span,
+.adminhtml-integration-index .page-actions .add > span,
+.adminhtml-system-design-theme-index .page-actions .add > span,
+.adminhtml-system-design-index .page-actions .add > span,
+.adminhtml-customer-attribute-index .page-actions .add > span,
+.adminhtml-customer-address-attribute-index .page-actions .add > span,
+.rating-index-index .page-actions .add > span,
+.tax-rule-index .page-actions .add > span,
+.tax-rate-index .page-actions .add > span,
+.adminhtml-rma-item-attribute-index .page-actions .add > span,
+.adminhtml-reward-rate-index .page-actions .add > span,
+.customer-group-index .page-actions .add > span,
+.checkout-agreement-index .page-actions .add > span,
+.catalog-product-attribute-index .page-actions .add > span,
+.catalog-product-set-index .page-actions .add > span,
+.catalog-product-new .actions-split.btn-round .action-default.primary > span,
+.catalog-product-edit .actions-split.btn-round .action-default.primary > span,
+.catalog-product-index .actions-split.btn-round .action-default.primary > span,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary > span {
+  text-indent: -999em;
+  display: block;
+  width: 34px;
+  height: 29px;
+}
+.PrimaryAddButton > span:before,
+.PrimarySplitButton.btn-round .action-default.primary > span:before,
+.sales-order-index .page-actions .add > span:before,
+.adminhtml-rma-index .page-actions .add > span:before,
+.adminhtml-catalog-event-index .page-actions .add > span:before,
+.adminhtml-urlrewrite-index .page-actions .add > span:before,
+.catalog-search-index .page-actions .add > span:before,
+.catalog-product-review-index .page-actions .add > span:before,
+.catalog-rule-promo-catalog-index .page-actions .add > span:before,
+.sales-rule-promo-quote-index .page-actions .add > span:before,
+.adminhtml-reminder-index .page-actions .add > span:before,
+.newsletter-template-index .page-actions .add > span:before,
+.adminhtml-system-email-template-index .page-actions .add > span:before,
+.adminhtml-sitemap-index .page-actions .add > span:before,
+.adminhtml-googleshopping-types-index .page-actions .add > span:before,
+.customer-index-index .page-actions .add > span:before,
+.adminhtml-cms-page-index .page-actions .add > span:before,
+.cms-block-index .page-actions .add > span:before,
+.adminhtml-banner-index .page-actions .add > span:before,
+.adminhtml-widget-instance-index .page-actions .add > span:before,
+.cms-page-index .page-actions .add > span:before,
+.adminhtml-webapi-user-index .page-actions .add > span:before,
+.adminhtml-webapi-role-index .page-actions .add > span:before,
+.adminhtml-system-variable-index .page-actions .add > span:before,
+.adminhtml-user-index .page-actions .add > span:before,
+.adminhtml-user-role-index .page-actions .add > span:before,
+.adminhtml-integration-index .page-actions .add > span:before,
+.adminhtml-system-design-theme-index .page-actions .add > span:before,
+.adminhtml-system-design-index .page-actions .add > span:before,
+.adminhtml-customer-attribute-index .page-actions .add > span:before,
+.adminhtml-customer-address-attribute-index .page-actions .add > span:before,
+.rating-index-index .page-actions .add > span:before,
+.tax-rule-index .page-actions .add > span:before,
+.tax-rate-index .page-actions .add > span:before,
+.adminhtml-rma-item-attribute-index .page-actions .add > span:before,
+.adminhtml-reward-rate-index .page-actions .add > span:before,
+.customer-group-index .page-actions .add > span:before,
+.checkout-agreement-index .page-actions .add > span:before,
+.catalog-product-attribute-index .page-actions .add > span:before,
+.catalog-product-set-index .page-actions .add > span:before,
+.catalog-product-new .actions-split.btn-round .action-default.primary > span:before,
+.catalog-product-edit .actions-split.btn-round .action-default.primary > span:before,
+.catalog-product-index .actions-split.btn-round .action-default.primary > span:before,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary > span:before {
+  text-indent: 0;
+  font-family: 'MUI-Icons';
+  font-weight: normal;
+  font-size: 22px;
+  content: '\e02d';
+  color: #fff;
+  position: absolute;
+  width: 34px;
+  height: 29px;
+  line-height: 29px;
+  text-align: center;
+  vertical-align: middle;
+  top: 0;
+  left: 0;
+  overflow: hidden;
+}
+.eq-ie9 .PrimaryAddButton > span:before,
+.eq-ie9 .PrimarySplitButton.btn-round .action-default.primary > span:before,
+.eq-ie9 .sales-order-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-rma-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-catalog-event-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-urlrewrite-index .page-actions .add > span:before,
+.eq-ie9 .catalog-search-index .page-actions .add > span:before,
+.eq-ie9 .catalog-product-review-index .page-actions .add > span:before,
+.eq-ie9 .catalog-rule-promo-catalog-index .page-actions .add > span:before,
+.eq-ie9 .sales-rule-promo-quote-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-reminder-index .page-actions .add > span:before,
+.eq-ie9 .newsletter-template-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-system-email-template-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-sitemap-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-googleshopping-types-index .page-actions .add > span:before,
+.eq-ie9 .customer-index-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-cms-page-index .page-actions .add > span:before,
+.eq-ie9 .cms-block-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-banner-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-widget-instance-index .page-actions .add > span:before,
+.eq-ie9 .cms-page-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-webapi-user-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-webapi-role-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-system-variable-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-user-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-user-role-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-integration-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-system-design-theme-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-system-design-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-customer-attribute-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-customer-address-attribute-index .page-actions .add > span:before,
+.eq-ie9 .rating-index-index .page-actions .add > span:before,
+.eq-ie9 .tax-rule-index .page-actions .add > span:before,
+.eq-ie9 .tax-rate-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-rma-item-attribute-index .page-actions .add > span:before,
+.eq-ie9 .adminhtml-reward-rate-index .page-actions .add > span:before,
+.eq-ie9 .customer-group-index .page-actions .add > span:before,
+.eq-ie9 .checkout-agreement-index .page-actions .add > span:before,
+.eq-ie9 .catalog-product-attribute-index .page-actions .add > span:before,
+.eq-ie9 .catalog-product-set-index .page-actions .add > span:before,
+.eq-ie9 .catalog-product-new .actions-split.btn-round .action-default.primary > span:before,
+.eq-ie9 .catalog-product-edit .actions-split.btn-round .action-default.primary > span:before,
+.eq-ie9 .catalog-product-index .actions-split.btn-round .action-default.primary > span:before,
+.eq-ie9 .adminhtml-integration-new .actions-split.btn-round .action-default.primary > span:before {
+  line-height: 31px;
+}
+.PrimarySplitButton.btn-round .action-default.primary,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary,
+.catalog-product-new .actions-split.btn-round .action-default.primary,
+.catalog-product-edit .actions-split.btn-round .action-default.primary,
+.catalog-product-index .actions-split.btn-round .action-default.primary,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary {
+  border-radius: 2px 0 0 2px;
+}
+.PrimarySplitButton.btn-round .action-default.primary:focus,
+.catalog-product-new .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-edit .actions-split.btn-round .action-default.primary:focus,
+.catalog-product-index .actions-split.btn-round .action-default.primary:focus,
+.adminhtml-integration-new .actions-split.btn-round .action-default.primary:focus {
+  outline: none;
+}
+.PrimarySplitButton > .action-default.primary,
+.catalog-product-new .actions-split > .action-default.primary,
+.catalog-product-edit .actions-split > .action-default.primary,
+.catalog-product-index .actions-split > .action-default.primary,
+.adminhtml-integration-new .actions-split > .action-default.primary {
+  border-radius: 2px 0 0 2px;
+}
+.PrimarySplitButton > .action-default.primary:focus,
+.catalog-product-new .actions-split > .action-default.primary:focus,
+.catalog-product-edit .actions-split > .action-default.primary:focus,
+.catalog-product-index .actions-split > .action-default.primary:focus,
+.adminhtml-integration-new .actions-split > .action-default.primary:focus {
+  outline: none;
+}
+.PrimarySplitButton > .action-toggle.primary,
+.catalog-product-new .actions-split > .action-toggle.primary,
+.catalog-product-edit .actions-split > .action-toggle.primary,
+.catalog-product-index .actions-split > .action-toggle.primary,
+.adminhtml-integration-new .actions-split > .action-toggle.primary,
+.catalog-product-new .actions-split > .action-toggle.primary,
+.catalog-product-edit .actions-split > .action-toggle.primary,
+.catalog-product-index .actions-split > .action-toggle.primary,
+.adminhtml-integration-new .actions-split > .action-toggle.primary {
+  overflow: hidden;
+  z-index: 1;
+  padding: 0;
+  border-radius: 0 2px 2px 0;
+  font-size: 15px;
+  width: 30px;
+  height: 31px;
+  line-height: 30px;
+  margin-left: -1px;
+  position: relative;
+  z-index: 2;
+  filter: none;
+}
+.PrimarySplitButton > .action-toggle.primary:focus,
+.catalog-product-new .actions-split > .action-toggle.primary:focus,
+.catalog-product-edit .actions-split > .action-toggle.primary:focus,
+.catalog-product-index .actions-split > .action-toggle.primary:focus,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:focus {
+  outline: none;
+}
+.PrimarySplitButton > .action-toggle.primary:before,
+.catalog-product-new .actions-split > .action-toggle.primary:before,
+.catalog-product-edit .actions-split > .action-toggle.primary:before,
+.catalog-product-index .actions-split > .action-toggle.primary:before,
+.adminhtml-integration-new .actions-split > .action-toggle.primary:before {
+  text-align: center;
+}
+.PrimarySplitButton .dropdown-menu,
+.catalog-product-new .actions-split .dropdown-menu,
+.catalog-product-edit .actions-split .dropdown-menu,
+.catalog-product-index .actions-split .dropdown-menu,
+.adminhtml-integration-new .actions-split .dropdown-menu {
+  left: 0;
+  right: auto;
+  z-index: 1;
+}
+.PrimarySplitButton .dropdown-menu > li > .item,
+.catalog-product-new .actions-split .dropdown-menu > li > .item,
+.catalog-product-edit .actions-split .dropdown-menu > li > .item,
+.catalog-product-index .actions-split .dropdown-menu > li > .item,
+.adminhtml-integration-new .actions-split .dropdown-menu > li > .item {
+  padding: 9px 10px 10px;
+}
+.PrimarySplitButton.active > .action-toggle.primary,
+.PrimarySplitButton.active > .action-toggle.primary:hover,
+.catalog-product-new .actions-split.active > .action-toggle.primary,
+.catalog-product-new .actions-split.active > .action-toggle.primary:hover,
+.catalog-product-edit .actions-split.active > .action-toggle.primary,
+.catalog-product-edit .actions-split.active > .action-toggle.primary:hover,
+.catalog-product-index .actions-split.active > .action-toggle.primary,
+.catalog-product-index .actions-split.active > .action-toggle.primary:hover,
+.adminhtml-integration-new .actions-split.active > .action-toggle.primary,
+.adminhtml-integration-new .actions-split.active > .action-toggle.primary:hover {
+  background: #026294;
+  border: 1px solid #004c74;
+}
+.dont-use-this-class-big-size {
+  font-size: 18px;
+  line-height: 24px;
+  padding: 8px 19px;
+}
+/*
+    Reset 'button view' for actions
+-------------------------------------- */
+.customer-current-activity .action-refresh,
+.pager .action-next,
+.pager .action-previous,
+.pager .action-next:hover,
+.pager .action-previous:hover,
+.pager .action-next.disabled:focus,
+.pager .action-previous.disabled:focus,
+.pager .action-next.disabled:active,
+.pager .action-previous.disabled:active,
+.data-table .action-.delete,
+.data-table .action-.delete:hover,
+.data-table .action-.delete:active,
+.data-table .action-.delete.active,
+.data-table .action-delete,
+.data-table .action-delete:hover,
+.data-table .action-delete:active,
+.data-table .action-delete.active,
+.data-table .action-locked,
+.data-table .action-locked:hover,
+.data-table .action-locked:active,
+.data-table .action-locked.active,
+.data-table .action-locked[disabled],
+#product-variations-matrix .action-choose,
+#product-variations-matrix .action-choose:hover,
+#product-variations-matrix .action-choose:active,
+#product-variations-matrix .action-choose.active,
+#product-variations-matrix .action-choose[disabled],
+.action-manage-images,
+.action-manage-images:hover,
+.action-manage-images:active,
+.action-manage-images.active,
+.action-manage-images[disabled],
+.image-panel .action-close,
+.image-panel .action-close:hover,
+.image-panel .action-close:active,
+.image-panel .action-close.active,
+.image-panel .action-close[disabled],
+.image-panel-controls .action-remove,
+.image-panel-controls .action-remove:hover,
+.image-panel-controls .action-remove:active,
+.image-panel-controls .action-remove.active,
+.image-panel-controls .action-remove[disabled],
+.vde-image-sizing .action-connect,
+.vde-image-sizing .action-connect:hover,
+.vde-image-sizing .action-connect:active,
+.vde-image-sizing .action-connect.active,
+.vde-image-sizing .action-connect[disabled],
+.suggest-expandable .action-show-all,
+.suggest-expandable .action-show-all:hover,
+.suggest-expandable .action-show-all:active,
+.suggest-expandable .action-show-all.active,
+.suggest-expandable .action-show-all[disabled],
+.custom-file > .action-add,
+.custom-file > .action-add:hover,
+.custom-file > .action-add:active,
+.custom-file > .action-add.active,
+.custom-file > .action-add[disabled],
+.vde-tools-header .action-close,
+.vde-tools-header .action-close:hover,
+.vde-tools-header .action-close:active,
+.vde-tools-header .action-close.active,
+.image .action-delete,
+.image .action-delete:hover,
+.image .action-delete:active,
+.image .action-delete.active,
+.fieldset-wrapper-title .actions .action-delete,
+.fieldset-wrapper-title .actions .action-delete:hover,
+.fieldset-wrapper-title .actions .action-delete:active,
+.fieldset-wrapper-title .actions .action-delete.active,
+.address-list-item-actions .action-delete,
+.address-list-item-actions .action-delete:hover,
+.address-list-item-actions .action-delete:active,
+.address-list-item-actions .action-delete.active,
+.notification .action-close,
+.notification .action-close:hover,
+.notification .action-close:active,
+.notification .action-close.active,
+.page-login .action-forgotpassword,
+.page-login .action-forgotpassword:hover,
+.page-login .action-forgotpassword:active,
+.page-login .action-forgotpassword.active,
+.page-login .action-back,
+.page-login .action-back:hover,
+.page-login .action-back:active,
+.page-login .action-back.active,
+.attribute-popup .page-actions #reset,
+.attribute-popup .page-actions #reset:hover,
+.attribute-popup .page-actions #reset:active,
+.attribute-popup .page-actions #reset.active,
+.attribute-popup .page-actions #reset[disabled] {
+  border: none;
+  border-radius: 0;
+  background: none;
+  margin: 0;
+  padding: 0;
+  box-shadow: none;
+  text-shadow: none;
+  filter: none;
+}
+.attribute-popup .messages {
+  margin: 0 15px;
+}
+.data-table .action-.delete[disabled],
+.data-table .action-delete[disabled],
+.data-table .action-locked[disabled],
+#product-variations-matrix .action-choose[disabled],
+.image-panel .action-close[disabled],
+.image-panel-controls .action-remove[disabled],
+.suggest-expandable .action-show-all[disabled],
+#store-view-window [class^='action-close'],
+#store-view-window [class^='action-close']:hover,
+#store-view-window [class^='action-close']:active,
+#store-view-window [class^='action-close'].active,
+#store-view-window [class^='action-close'][disabled],
+.custom-file > .action-add[disabled],
+.image .action-delete,
+.image .action-delete:hover,
+.image .action-delete:active,
+.image .action-delete.active,
+.fieldset-wrapper-title .actions .action-delete,
+.fieldset-wrapper-title .actions .action-delete:hover,
+.fieldset-wrapper-title .actions .action-delete:active,
+.fieldset-wrapper-title .actions .action-delete.active,
+.address-list-item-actions .action-delete,
+.address-list-item-actions .action-delete:hover,
+.address-list-item-actions .action-delete:active,
+.address-list-item-actions .action-delete.active,
+.notification .action-close,
+.notification .action-close:hover,
+.notification .action-close:active,
+.notification .action-close.active {
+  border: none;
+  border-radius: 0;
+  background: none;
+  margin: 0;
+  padding: 0;
+  box-shadow: none;
+  text-shadow: none;
+  filter: none;
+}
+.fade.critical-notification {
+  display: block;
+}
+.fade.critical-notification .popup {
+  top: 200px;
+}
+.data-table .action-.delete[disabled],
+.data-table .action-delete[disabled],
+.data-table .action-locked[disabled],
+#product-variations-matrix .action-choose[disabled],
+.image-panel .action-close[disabled],
+.image-panel-controls .action-remove[disabled],
+.suggest-expandable .action-show-all[disabled],
+#store-view-window [class^='action-close'],
+#store-view-window [class^='action-close']:hover,
+#store-view-window [class^='action-close']:active,
+#store-view-window [class^='action-close'].active,
+#store-view-window [class^='action-close'][disabled],
+.custom-file > .action-add[disabled],
+.vde-tools-header .action-close[disabled],
+.vde-image-sizing .action-reset,
+.vde-image-sizing .action-reset:hover,
+.vde-image-sizing .action-reset:active,
+.vde-image-sizing .action-reset.active,
+.vde-image-sizing .action-reset[disabled],
+.image .action-delete[disabled],
+.fieldset-wrapper-title .actions .action-delete[disabled],
+.address-list-item-actions .action-delete[disabled],
+[class^=" catalog-product-"] .page-actions .action-back,
+[class^=" catalog-product-"] .page-actions .action-back:hover,
+[class^=" catalog-product-"] .page-actions .action-back:active,
+[class^=" catalog-product-"] .page-actions .action-back.active,
+[class^=" catalog-product-"] .page-actions .action-back[disabled],
+[class^=" newsletter-"] .page-actions .action-back,
+[class^=" newsletter-"] .page-actions .action-back:hover,
+[class^=" newsletter-"] .page-actions .action-back:active,
+[class^=" newsletter-"] .page-actions .action-back.active,
+[class^=" newsletter-"] .page-actions .action-back[disabled],
+.notifications [class^="action-"],
+.notifications [class^="action-"]:hover,
+.notifications [class^="action-"]:active,
+.notifications [class^="action-"].active,
+.notifications [class^="action-"][disabled],
+.notification .action-close,
+.notification .action-close:hover,
+.notification .action-close:active,
+.notification .action-close.active,
+.notification .action-close[disabled],
+.sales-order-create-index .page-actions-inner .cancel,
+.sales-order-create-index .page-actions-inner .cancel:hover,
+.sales-order-create-index .page-actions-inner .cancel:active,
+.sales-order-create-index .page-actions-inner .cancel.active,
+.sales-order-create-index .page-actions-inner .cancel[disabled] {
+  border: 0;
+  border-radius: 0;
+  background: none;
+  margin: 0;
+  padding: 0;
+  box-shadow: none;
+  text-shadow: none;
+  filter: none;
+}
+.vde-image-sizing .action-connect,
+.vde-image-sizing .action-connect:hover,
+.vde-image-sizing .action-connect:active,
+.vde-image-sizing .action-connect.active,
+.vde-image-sizing .action-connect[disabled],
+.vde-tab-data .action-download,
+.vde-tab-data .action-download:hover,
+.vde-tab-data .action-download:active,
+.vde-tab-data .action-download.active,
+.vde-tab-data .action-download[disabled],
+.vde-tab-data .action-delete,
+.vde-tab-data .action-delete:hover,
+.vde-tab-data .action-delete:active,
+.vde-tab-data .action-delete.active,
+.vde-tab-data .action-delete[disabled],
+.vde-tab-data .action-edit,
+.vde-tab-data .action-edit:hover,
+.vde-tab-data .action-edit:active,
+.vde-tab-data .action-edit.active,
+.vde-tab-data .action-edit[disabled] {
+  border: none;
+  border-radius: 0;
+  background: none;
+  margin: 0;
+  padding: 0;
+  box-shadow: none;
+  text-shadow: none;
+}
+/*
+    Actions as links
+-------------------------------------- */
+.notification-entry-dialog .action-cancel,
+.attribute-popup .page-actions #reset {
+  background: none;
+  border: none;
+  color: #6d665e;
+  font-weight: normal;
+  font-size: 12px;
+  cursor: pointer;
+  text-decoration: underline;
+}
+.notification-entry-dialog .action-cancel:hover,
+.attribute-popup .page-actions #reset:hover {
+  color: #000;
+  border-bottom-color: #000;
+  filter: none;
+}
+/*
+    Fileupload button
+-------------------------------------- */
+.action-upload {
+  position: relative;
+}
+.action-upload > input[type="file"] {
+  position: absolute;
+  left: 0;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  opacity: 0;
+  font-size: 10em;
+}
+/*
+    Dropdown menu
+-------------------------------------- */
+.dropdown-menu,
+.ui-autocomplete {
+  position: absolute;
+  display: none;
+  list-style: none;
+  min-width: 100px;
+  margin: 3px 0 0 0;
+  padding: 0;
+  right: 0;
+  top: 100%;
+  border: 1px solid #cac2b5;
+  border-radius: 3px;
+  background: #fff;
+  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
+  z-index: 990;
+}
+.dropdown-menu > li,
+.ui-autocomplete > li {
+  padding: 5px;
+  border-bottom: 1px solid #e5e5e5;
+}
+.dropdown-menu > li.selected,
+.ui-autocomplete > li.selected {
+  background: #eef8fc;
+}
+.dropdown-menu > li:hover,
+.ui-autocomplete > li:hover {
+  background: #eef8fc;
+}
+.dropdown-menu > li:last-child,
+.ui-autocomplete > li:last-child {
+  border-bottom: none;
+}
+.dropdown-menu > li > .item,
+.ui-autocomplete > li > .item {
+  cursor: pointer;
+}
+.dropdown-menu-top {
+  margin: 0 0 3px 0;
+  top: auto;
+  bottom: 100%;
+}
+.ui-autocomplete {
+  right: auto;
+}
+.ui-autocomplete > li {
+  padding: 0;
+}
+.ui-autocomplete > li > a {
+  display: block;
+  padding: 5px;
+}
+.ui-autocomplete > li > a.level-0 {
+  padding-left: 5px !important;
+}
+.ui-autocomplete .ui-state-focus {
+  background: #f5f5f5;
+}
+/*
+    Suggest
+-------------------------------------- */
+.mage-suggest {
+  position: relative;
+  display: inline-block;
+  vertical-align: top;
+  width: 100%;
+  background-color: #fff;
+  border: 1px solid #ccc;
+  border-radius: 3px;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  -moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.mage-suggest:after {
+  position: absolute;
+  top: 0;
+  right: 3px;
+  bottom: 0;
+  width: 22px;
+  text-align: center;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e01f';
+  /* search icon */
+
+  font-size: 20px;
+  color: #b2b2b2;
+}
+.mage-suggest input[type="search"],
+.mage-suggest input.search {
+  width: 100%;
+  border: none;
+  background: none;
+  padding-right: 30px;
+}
+.mage-suggest-dropdown {
+  position: absolute;
+  left: 0;
+  right: 0;
+  top: 100%;
+  margin: 3px -1px 0 -1px;
+  border: 1px solid #cac2b5;
+  border-radius: 3px;
+  background: #fff;
+  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
+  z-index: 990;
+}
+.mage-suggest-dropdown ul {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+}
+.mage-suggest-dropdown li {
+  border-bottom: 1px solid #e5e5e5;
+  padding: 0;
+}
+.field-category_ids .mage-suggest-dropdown,
+.field-new_category_parent .mage-suggest-dropdown {
+  max-height: 200px;
+  overflow: auto;
+}
+.mage-suggest-dropdown li a {
+  display: block;
+}
+.mage-suggest-dropdown li a,
+.mage-suggest-dropdown .jstree li a:hover,
+.mage-suggest-dropdown .jstree .jstree-hovered,
+.mage-suggest-dropdown .jstree .jstree-clicked {
+  padding: 6px 12px 5px;
+  text-decoration: none;
+  color: #333;
+}
+.mage-suggest-dropdown .jstree li a:hover,
+.mage-suggest-dropdown .jstree .jstree-hovered,
+.mage-suggest-dropdown .jstree .jstree-clicked {
+  border: none;
+}
+.mage-suggest-dropdown li a.ui-state-focus {
+  background: #f5f5f5;
+}
+.mage-suggest-dropdown .jstree li {
+  border-bottom: 0;
+}
+.mage-suggest-dropdown .jstree li a {
+  display: inline-block;
+}
+.mage-suggest-dropdown .jstree .mage-suggest-selected > a {
+  color: #000000;
+  background: #F1FFEB;
+}
+.mage-suggest-dropdown .jstree .mage-suggest-selected > a:hover,
+.mage-suggest-dropdown .jstree .mage-suggest-selected > .jstree-hovered,
+.mage-suggest-dropdown .jstree .mage-suggest-selected > .jstree-clicked,
+.mage-suggest-dropdown .jstree .mage-suggest-selected.mage-suggest-not-active > .jstree-hovered,
+.mage-suggest-dropdown .jstree .mage-suggest-selected.mage-suggest-not-active > .jstree-clicked {
+  background: #E5FFD9;
+}
+.mage-suggest-dropdown .jstree .mage-suggest-not-active > a {
+  color: #D4D4D4;
+}
+.mage-suggest-dropdown .jstree .mage-suggest-not-active > a:hover,
+.mage-suggest-dropdown .jstree .mage-suggest-not-active > .jstree-hovered,
+.mage-suggest-dropdown .jstree .mage-suggest-not-active > .jstree-clicked {
+  background: #F5F5F5;
+}
+.mage-suggest-dropdown .category-path {
+  font-size: 11px;
+  margin-left: 10px;
+  color: #9ba8b5;
+}
+.suggest-expandable .actions-split .action-toggle {
+  display: inline-block;
+  max-width: 500px;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+  background: none;
+  border: none;
+  box-shadow: none;
+  color: #676056;
+  font-size: 12px;
+  padding: 5px 4px;
+  filter: none;
+}
+.suggest-expandable .actions-split .action-toggle span {
+  display: inline;
+}
+.suggest-expandable .actions-split .action-toggle:before {
+  display: inline-block;
+  float: right;
+  margin-left: 4px;
+  font-size: 13px;
+  color: #b2b0ad;
+}
+.suggest-expandable .actions-split .action-toggle:hover:before {
+  color: #7e7e7e;
+}
+.suggest-expandable .dropdown-menu {
+  margin: 1px 0 0;
+  left: 0;
+  right: auto;
+  width: 221px;
+}
+.suggest-expandable .mage-suggest {
+  border: none;
+}
+.suggest-expandable .mage-suggest:after {
+  top: 6px;
+  right: 6px;
+}
+.suggest-expandable .mage-suggest-inner .title {
+  margin: 0;
+  padding: 0 10px 4px;
+  text-transform: uppercase;
+  color: #a6a098;
+  font-size: 12px;
+  border-bottom: 1px solid #e5e5e5;
+}
+.suggest-expandable .mage-suggest-inner > input[type="search"],
+.suggest-expandable .mage-suggest-inner > input.search {
+  position: relative;
+  margin: 6px 5px 5px;
+  padding-right: 20px;
+  border: 1px solid #ccc;
+  width: 211px;
+  z-index: 1;
+}
+.suggest-expandable .mage-suggest-inner > input.ui-autocomplete-loading,
+.suggest-expandable .mage-suggest-inner > input.mage-suggest-state-loading {
+  background: #ffffff url(../mui/images/ajax-loader-small.gif) no-repeat 190px 50%;
+}
+.suggest-expandable .mage-suggest {
+  border-radius: 3px 3px 0 0;
+}
+.suggest-expandable .mage-suggest-dropdown {
+  margin-top: 0;
+  border-top: 0;
+  border-radius: 0 0 3px 3px;
+  max-height: 300px;
+  overflow: auto;
+  width: 100%;
+  float: left;
+}
+.suggest-expandable .mage-suggest-dropdown ul {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+}
+.suggest-expandable .action-show-all,
+.suggest-expandable .action-show-all:hover,
+.suggest-expandable .action-show-all:active,
+.suggest-expandable .action-show-all:focus,
+.suggest-expandable .action-show-all[disabled] {
+  border-top: 1px solid #e5e5e5;
+  display: block;
+  width: 100%;
+  padding: 8px 10px 10px;
+  text-align: left;
+  font: 12px/1.333 Arial, Verdana, sans-serif;
+  color: #676056;
+}
+.page-actions .suggest-expandable {
+  max-width: 500px;
+  float: left;
+  margin-top: 1px;
+}
+.page-actions.fixed #product-template-suggest-container {
+  display: none;
+}
+/*
+    Actions Split
+-------------------------------------- */
+.actions-split {
+  text-align: left;
+  position: relative;
+  display: inline-block;
+}
+.actions-split > [class^='action-'] {
+  float: left;
+  border-radius: 0;
+}
+.actions-split > .action-default {
+  border-radius: 5px 0 0 5px;
+}
+.actions-split > .action-toggle {
+  border-left: 1px solid #c5c0b9;
+  border-radius: 0 5px 5px 0;
+  margin-left: -1px;
+  padding: 4px 7px;
+}
+.actions-split > .action-toggle > span {
+  display: none;
+}
+.actions-split > .action-toggle:before {
+  display: block;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02c';
+  /* arrow down */
+
+  font-size: 11px;
+}
+.actions-split > .action-toggle.active:before {
+  content: '\e029';
+  /* arrow up */
+
+}
+.actions-split > .action-toggle.primary {
+  border-left: 1px solid #e1721d;
+}
+.actions-split > .action-toggle.primary:hover {
+  background: #e2701a;
+  margin-left: -1px;
+}
+.actions-split.active .dropdown-menu {
+  display: block;
+  white-space: nowrap;
+}
+.actions-split.active .dropdown-menu > li {
+  padding: 0;
+}
+.actions-split .dropdown-menu > li > .item {
+  display: block;
+  padding: 6px 10px 5px;
+  color: #333;
+  text-decoration: none;
+}
+/* Variations Image Uploader */
+.actions-image-uploader > img {
+  float: left;
+  border: solid #b7b2a7;
+  border-width: 1px 0 1px 1px;
+  width: 32px;
+  height: 31px;
+}
+.actions-image-uploader .action-toggle,
+.actions-image-uploader .action-toggle:hover,
+.actions-image-uploader .action-toggle:active,
+.actions-image-uploader .action-toggle:focus,
+.actions-image-uploader .action-toggle[disabled] {
+  position: relative;
+  height: 33px;
+  padding-left: 2px;
+  padding-right: 2px;
+  background: #fff;
+  filter: none;
+  color: #888;
+}
+.actions-image-uploader.active .action-toggle {
+  border-radius: 0 5px 0 0;
+}
+.actions-image-uploader.active .action-toggle:after {
+  position: absolute;
+  left: 0;
+  right: 0;
+  bottom: -1px;
+  height: 1px;
+  background: #fff;
+  z-index: 991;
+  content: '';
+}
+.actions-image-uploader .dropdown-menu {
+  margin-top: -1px;
+  border-radius: 3px 0 3px 3px;
+}
+/*
+    Action delete icon
+-------------------------------------- */
+/* TODO: replase ".action-.delete" to ".action-delete" after buttons refactoring */
+.data-table .action-.delete span,
+.data-table .action-delete span,
+.data-table .action-locked span,
+.image .action-delete span,
+.fieldset-wrapper-title .actions .action-delete span,
+.address-list-item-actions .action-delete span {
+  display: none;
+}
+.data-table .action-.delete:before,
+.data-table .action-delete:before,
+.image .action-delete:before,
+.fieldset-wrapper-title .actions .action-delete:before,
+.address-list-item-actions .action-delete:before {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  font-size: 18px;
+  -webkit-font-smoothing: antialiased;
+  content: '\e07f';
+  /* delete icon */
+
+  color: #b7b3ad;
+}
+/*
+    Locked action icon
+-------------------------------------- */
+.data-table .action-locked:before {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  font-size: 20px;
+  -webkit-font-smoothing: antialiased;
+  content: '\e03e';
+  /* lock icon */
+
+  color: #b7b3ad;
+}
+.data-table .action-.delete:hover:before,
+.data-table .action-delete:hover:before,
+.data-table .action-locked:hover:before,
+.image .action-delete:hover:before,
+.fieldset-wrapper-title .actions .action-delete:hover:before,
+.address-list-item-actions .action-delete:hover:before {
+  color: #7e7e7e;
+}
+.data-table input.action-.delete[type="button"],
+.data-table input.action-.delete[type="submit"],
+.data-table input.action-.delete[type="reset"],
+.data-table button.action-.delete,
+.data-table input.action-.delete[type="button"]:visited,
+.data-table input.action-.delete[type="submit"]:visited,
+.data-table input.action-.delete[type="reset"]:visited,
+.data-table button.action-.delete:visited,
+.data-table input.action-.delete[type="button"]:hover,
+.data-table input.action-.delete[type="submit"]:hover,
+.data-table input.action-.delete[type="reset"]:hover,
+.data-table button.action-.delete:hover,
+.data-table input.action-.delete[type="button"]:active,
+.data-table input.action-.delete[type="submit"]:active,
+.data-table input.action-.delete[type="reset"]:active,
+.data-table button.action-.delete:active {
+  background: transparent;
+  padding: 3px 7px 0;
+}
+.data-table input.action-.delete[type=button]:hover:before,
+.data-table input.action-.delete[type=submit]:hover:before,
+.data-table input.action-.delete[type=reset]:hover:before,
+.data-table button.action-.delete:hover:before,
+.data-table input.action-.delete[type=button]:focus:before,
+.data-table input.action-.delete[type=submit]:focus:before,
+.data-table input.action-.delete[type=reset]:focus:before,
+.data-table button.action-.delete:focus:before {
+  background: transparent;
+  color: #a5a29d;
+}
+/*
+    Forms
+-------------------------------------- */
+fieldset {
+  border: 1px solid #ccc;
+  padding: 20px;
+}
+legend {
+  padding: 0 10px;
+  margin: 0 -10px;
+}
+fieldset legend + br {
+  display: none;
+}
+label {
+  display: inline-block;
+}
+label > input[type="radio"],
+label > input[type="checkbox"] {
+  margin: -3px 3px 0 0;
+  vertical-align: middle;
+}
+input[type=text],
+input[type=password],
+input[type=datetime],
+input[type=datetime-local],
+input[type=date],
+input[type=month],
+input[type=time],
+input[type=week],
+input[type=number],
+input[type=range],
+input[type=email],
+input[type=url],
+input[type=search],
+input.search,
+input[type=tel],
+input[type=color],
+textarea,
+.input-text {
+  display: inline-block;
+  padding: 4px;
+  margin: 0;
+  background-color: #fff;
+  height: 28px;
+  color: #676056;
+  font-size: 14px;
+  font-weight: 400;
+  border: 1px solid #ccc;
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+  border-radius: 4px;
+  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+}
+textarea,
+.input-text {
+  height: auto;
+}
+textarea {
+  resize: vertical;
+}
+select {
+  height: 28px;
+  padding: 4px 4px 5px;
+  margin: 0 0 8px;
+  border: 1px solid #ccc;
+  border-radius: 4px;
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  -ms-box-sizing: border-box;
+  box-sizing: border-box;
+}
+select[multiple],
+select[size] {
+  height: auto;
+}
+input[type=text]:focus,
+input[type=password]:focus,
+input[type=datetime]:focus,
+input[type=datetime-local]:focus,
+input[type=date]:focus,
+input[type=month]:focus,
+input[type=time]:focus,
+input[type=week]:focus,
+input[type=number]:focus,
+input[type=range]:focus,
+input[type=email]:focus,
+input[type=url]:focus,
+input[type=search]:focus,
+input.search:focus,
+input[type=tel]:focus,
+input[type=color]:focus,
+textarea:focus,
+select:focus {
+  outline: 0;
+  border-color: #75b9f0;
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(82, 168, 236, 0.6);
+}
+input[type="radio"],
+input[type="checkbox"] {
+  margin: 3px 0;
+  line-height: normal;
+}
+input[disabled],
+select[disabled],
+textarea[disabled],
+input[readonly],
+select[readonly],
+textarea[readonly] {
+  cursor: not-allowed;
+  background-color: #fff;
+  border-color: #eee;
+  box-shadow: none;
+  color: #999;
+}
+select[disabled].multiselect > option[selected] {
+  color: #fff;
+  background: #6d6d6d;
+}
+textarea:-moz-placeholder,
+input:-moz-placeholder {
+  color: #999 !important;
+  font-style: italic;
+}
+option.placeholder {
+  color: #999 !important;
+  font-style: italic !important;
+}
+:-ms-input-placeholder {
+  color: #999 !important;
+  font-style: italic;
+}
+::-webkit-input-placeholder {
+  color: #999 !important;
+}
+:-moz-placeholder {
+  color: #999 !important;
+}
+.form-inline .control {
+  width: 100%;
+}
+.form-inline .label {
+  width: 20%;
+  padding-top: 6px;
+}
+.form-inline .label ~ .control {
+  width: 60%;
+}
+.form-inline .no-label .control {
+  margin-left: 20%;
+  width: 60%;
+}
+fieldset.field [class^='fields-group-'] .field .control {
+  width: auto;
+  margin: 0 0 0 20px;
+}
+.form-inline .field-service {
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+  float: left;
+  width: 20%;
+  padding: 7px 0 0 15px;
+  color: #999;
+  font-size: 12px;
+  letter-spacing: 0.05em;
+}
+.form-inline .field-service[value-scope]:before {
+  content: attr(value-scope) !important;
+  white-space: nowrap;
+  display: block;
+  margin-bottom: 5px;
+}
+.form-inline .field-service .checkbox {
+  margin: 0;
+  vertical-align: middle;
+}
+.control > input {
+  width: 100%;
+}
+.control > input[type="button"] {
+  width: auto;
+}
+.control > input.hasDatepicker {
+  width: 130px;
+}
+.control > input[type="radio"],
+.control > input[type="checkbox"],
+.control > input[type="file"] {
+  width: auto;
+}
+.control > table {
+  width: 100%;
+}
+.multi-input {
+  margin: 0 0 20px;
+}
+.multi-input > input {
+  width: 100%;
+}
+.control .input-file {
+  margin-top: 4px;
+}
+/* TODO: remove styles for images when images will be replaced by font icons */
+.control .hasDatepicker + img {
+  margin: -3px 0 0 5px;
+  vertical-align: middle;
+}
+.nobr {
+  white-space: nowrap;
+}
+/*
+    Form Validation
+-------------------------------------- */
+label.mage-error {
+  display: block;
+  color: red;
+  text-align: left;
+  clear: both;
+  margin: 3px 0 0 0;
+}
+textarea.mage-error,
+select.mage-error,
+input.mage-error {
+  border-color: #fa7973 !important;
+  box-shadow: 0 0 8px rgba(250, 121, 115, 0.6) !important;
+}
+input.mage-error ~ .addafter {
+  border-color: #fa7973 !important;
+  box-shadow: 0 0 8px rgba(250, 121, 115, 0.6) !important;
+}
+/*
+    Forms for Store Scope
+-------------------------------------- */
+.form-inline .field-store_id .label + .control,
+.form-inline .field-store_ids .label + .control,
+.form-inline .field-website_ids .label + .control,
+.form-inline .field-website_id .label + .control,
+.form-inline .field-select_stores .label + .control,
+.form-inline .field-stores .label + .control {
+  width: auto;
+}
+/*
+    Forms styles
+-------------------------------------- */
+.page-content-inner {
+  position: relative;
+  background: #f5f2ed;
+  border: 1px solid #b7b2a6;
+  border-radius: 5px;
+  padding: 20px;
+}
+.fieldset-wrapper,
+.fieldset {
+  background: #fff;
+  border: 1px solid #eae6e0;
+  border-radius: 5px;
+  margin: 0 0 8px;
+  padding: 5px 18px 18px;
+  position: relative;
+}
+.fieldset-wrapper > .fieldset-wrapper-title,
+.fieldset > .legend {
+  position: static;
+  float: left;
+  width: 100%;
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+  padding: 0;
+  border-bottom: 1px solid #ededed;
+  margin: 0 0 18px;
+}
+.fieldset-wrapper > .fieldset-wrapper-title {
+  float: none;
+}
+.fieldset-wrapper > .fieldset-wrapper-title .title,
+.fieldset > .legend span {
+  color: #676056;
+  font-size: 20px;
+  font-weight: 400;
+  padding: 7px 0 10px;
+  display: inline-block;
+}
+/* Collapsable fieldset-wrapper */
+.collapsable-wrapper {
+  padding-bottom: 2px;
+}
+.collapsable-wrapper.opened {
+  padding-bottom: 18px;
+}
+.collapsable-wrapper > .fieldset-wrapper-title {
+  border-bottom: none;
+  margin-bottom: 0;
+}
+.collapsable-wrapper.opened > .fieldset-wrapper-title {
+  border-bottom: 1px solid #ededed;
+  margin-bottom: 18px;
+}
+.collapsable-wrapper .fieldset-wrapper-title > .title {
+  position: relative;
+  padding-left: 22px;
+  cursor: pointer;
+  float: left;
+}
+.collapsable-wrapper .fieldset-wrapper-title > .title:before {
+  position: absolute;
+  left: 0;
+  top: 7px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02a';
+  /* arrow right icon */
+
+  color: #b2b0ad;
+}
+.collapsable-wrapper.opened > .fieldset-wrapper-title > .title:before {
+  content: '\e02c';
+  /* arrow down icon */
+
+}
+.collapsable-wrapper .fieldset-wrapper-title > .title:hover:before {
+  color: #7e7e7e;
+}
+/* Fieldset styles in another fieldset */
+.fieldset .fieldset-wrapper,
+.fieldset-wrapper .fieldset-wrapper {
+  border-color: #cccbca;
+  padding: 0;
+}
+.fieldset .fieldset-wrapper .fieldset-wrapper-title,
+.fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title {
+  background: #f4f2ef;
+  background: url();
+  background: -moz-linear-gradient(top, #f4f2ef 0%, #eeebe6 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f4f2ef), color-stop(100%, #eeebe6));
+  background: -webkit-linear-gradient(top, #f4f2ef 0%, #eeebe6 100%);
+  background: -o-linear-gradient(top, #f4f2ef 0%, #eeebe6 100%);
+  background: -ms-linear-gradient(top, #f4f2ef 0%, #eeebe6 100%);
+  background: linear-gradient(to bottom, #f4f2ef 0%, #eeebe6 100%);
+  padding: 0 18px;
+  border-radius: 5px;
+}
+.fieldset .fieldset-wrapper.opened .fieldset-wrapper-title,
+.fieldset-wrapper .fieldset-wrapper.opened .fieldset-wrapper-title {
+  border-radius: 5px 5px 0 0;
+  border-bottom: 1px solid #cccbca;
+  -webkit-touch-callout: none;
+  -webkit-user-select: none;
+  -khtml-user-select: none;
+  -moz-user-select: none;
+  -ms-user-select: none;
+  min-height: 39px;
+}
+.fieldset .fieldset-wrapper .fieldset-wrapper-title .actions,
+.fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title .actions {
+  padding: 10px 2px 0 0;
+}
+.fieldset .fieldset-wrapper .fieldset-wrapper-title .title,
+.fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title .title {
+  padding-top: 9px;
+  padding-bottom: 8px;
+  color: #555;
+  font: normal 16px/1.333 Arial, Verdana, sans-serif;
+}
+.fieldset .fieldset-wrapper .fieldset-wrapper-title .title:before,
+.fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title .title:before {
+  top: 9px;
+}
+.fieldset-wrapper-content .fieldset > .title {
+  margin-top: 0;
+  padding-left: 22px;
+}
+.fieldset-wrapper .draggable-handle,
+.fieldset .draggable-handle {
+  width: 8px;
+  height: 14px;
+  line-height: 14px;
+  background: url(Magento_Backend::images/draggable-handle-vertical.gif) no-repeat 0 0;
+  cursor: ns-resize;
+  color: #b2b0ad;
+}
+.fieldset-wrapper-title > .draggable-handle {
+  position: absolute;
+  left: 10px;
+  top: 12px;
+}
+.fieldset .fieldset-wrapper .fieldset-wrapper-content,
+.fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-content {
+  padding: 0 10px;
+}
+/* Sortable fieldsets */
+.ui-sortable .entry-edit .fieldset-wrapper-title,
+#product_options_container_top .fieldset-wrapper-title {
+  padding-left: 30px;
+}
+.fieldset-wrapper-title > .actions,
+.fieldset .legend > .actions {
+  float: right;
+  padding-top: 8px;
+}
+.fieldset > .legend + br {
+  display: block;
+  height: 0;
+  overflow: hidden;
+  clear: left;
+}
+.fieldset-wrapper .fieldset,
+.fieldset .fieldset {
+  background: transparent;
+  padding: 9px 0;
+  border: none;
+  border-radius: 0;
+  margin: 0 0 29px;
+}
+.fieldset .comment {
+  margin: 0 0 29px 10px;
+}
+.fieldset .field {
+  margin: 0 0 29px;
+}
+.with-note .note,
+.field .note {
+  color: #676056;
+  font-size: 12px;
+  font-weight: 400;
+}
+.fieldset .field .options-list {
+  list-style: none;
+  margin: 0;
+  padding: 0;
+}
+.fieldset .field .options-list input[type="checkbox"],
+.fieldset .field .options-list input[type="radio"] {
+  margin-right: 5px;
+}
+[class^="fields-group-"] .field {
+  margin-bottom: 0;
+}
+.fieldset-wrapper .fieldset:last-child,
+.fieldset .fieldset:last-child,
+.fieldset .field:last-child {
+  margin-bottom: 0;
+}
+.fieldset .label {
+  color: #676056;
+  font-size: 13px;
+  font-weight: 600;
+}
+.fieldset .control .label {
+  color: #676056;
+  font-size: 14px;
+  font-weight: 400;
+}
+.field.required > .label:after {
+  color: #e22626;
+  font-size: 13px;
+  font-weight: 400;
+}
+.with-addon .textarea {
+  margin: 0 0 6px;
+}
+.fieldset .control .textarea,
+.fieldset .control .addon .textarea {
+  border-radius: 4px;
+  width: 100%;
+}
+.fieldset > .field > input[type="checkbox"] {
+  margin-top: 12px;
+}
+.fieldset-alt {
+  position: relative;
+  display: table-row;
+  border: 0;
+  padding: 0;
+  margin-bottom: 20px;
+  width: 100%;
+}
+.fieldset-alt > .field {
+  display: table-cell;
+  vertical-align: top;
+  padding-right: 4%;
+}
+.fieldset-alt > .field.no-display {
+  display: none;
+}
+.fieldset-alt .field > .label {
+  display: block;
+  width: 100%;
+  clear: both;
+  text-align: left;
+  margin: 0 0 10px;
+}
+.fieldset-alt .label + .control {
+  width: 100%;
+}
+.fieldset-alt .field-option-title {
+  width: 50%;
+}
+.fieldset .tooltip .help {
+  margin: 7px 0 0 15px;
+}
+.fieldset-alt .field-option-store-view {
+  width: 20%;
+}
+.fieldset-alt .field-option-input-type {
+  width: 20%;
+}
+.fieldset-alt .field-option-input-type select {
+  width: 100%;
+}
+.fieldset-alt .field-option-req {
+  width: 105px;
+  white-space: nowrap;
+}
+.fieldset-alt .field-option-req .control {
+  position: relative;
+  top: 32px;
+}
+.fieldset-alt .field-option-position,
+.fieldset-alt .field-option-position .control {
+  width: 60px;
+}
+/* "Use default" checkbox */
+.use-default-control {
+  display: none;
+}
+.use-default-label {
+  cursor: pointer;
+  text-decoration: underline;
+  font-size: 11px;
+  color: #a29c94;
+}
+.use-default-label:hover {
+  color: #7e7e7e;
+}
+/*
+    Custom Multiselect
+-------------------------------------- */
+.multiselect-alt {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+  border: 1px solid #ccc;
+  border-radius: 5px;
+  color: #333;
+}
+.multiselect-alt .item {
+  position: relative;
+  border-top: 1px solid #fff;
+  cursor: pointer;
+}
+.multiselect-alt .item:first-child {
+  border-top: 0;
+}
+.multiselect-alt .item.selected {
+  background: #d7ebf5;
+}
+.multiselect-alt .item.selected:hover {
+  background: #afdef2;
+}
+.multiselect-alt label {
+  display: block;
+  cursor: pointer;
+  padding: 6px 25px 5px;
+}
+.multiselect-alt .item.selected label:before {
+  position: absolute;
+  left: 8px;
+  top: 1px;
+  bottom: 0;
+  width: 10px;
+  line-height: 28px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e01e';
+  /* checked icon */
+
+  text-align: center;
+  color: #7ba4b1;
+  font-size: 9px;
+  text-shadow: 0 -1px 1px #60727b;
+}
+.multiselect-alt input[type="checkbox"] {
+  width: 0;
+  height: 0;
+  opacity: 0;
+  margin: 0;
+  padding: 0;
+}
+/*
+    Form item with table
+-------------------------------------- */
+.with-table .label {
+  float: none;
+  text-align: left;
+  width: 100%;
+}
+.with-table .control {
+  clear: left;
+  float: none;
+  width: 100%;
+}
+/*
+    Form currency label
+-------------------------------------- */
+.addon input {
+  border-width: 1px 0 1px 1px;
+}
+.addon input:focus ~ .addafter {
+  border-color: #75b9f0;
+  box-shadow: 0 0 8px rgba(82, 168, 236, 0.6);
+}
+.addon input ~ .addafter strong {
+  display: inline-block;
+  background: #fff;
+  line-height: 24px;
+  margin: 0 3px 0 -2px;
+  padding-left: 4px;
+  padding-right: 4px;
+  position: relative;
+  font-size: 12px;
+  top: 0;
+}
+.addon input:focus ~ .addafter strong {
+  margin-top: 0;
+}
+.addon .addafter {
+  background: none;
+  color: #a6a6a6;
+  border-width: 1px 1px 1px 0;
+  border-radius: 4px 4px 0 0;
+  padding: 0;
+  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.075) inset;
+}
+.field .control input[type='text'][disabled],
+.field .control input[type='text'][disabled] ~ .addafter,
+.field .control select[disabled],
+.field .control select[disabled] ~ .addafter {
+  background-color: #fff;
+  border-color: #eee;
+  box-shadow: none;
+  color: #999;
+}
+.field .control input[type='text'][disabled] ~ .addafter strong,
+.field .control select[disabled] ~ .addafter strong {
+  background-color: #fff;
+}
+.field.type-price .addon,
+.field-price .addon,
+.field-special_price .addon,
+.field-msrp .addon {
+  direction: rtl;
+}
+.field.type-price .addon > *,
+.field-price .addon > *,
+.field-special_price .addon > *,
+.field-msrp .addon > * {
+  direction: ltr;
+}
+.field.type-price .addon .addafter,
+.field-price .addon .addafter,
+.field-special_price .addon .addafter,
+.field-msrp .addon .addafter {
+  border-width: 1px 0 1px 1px;
+  border-radius: 4px 0 0 4px;
+}
+.field.type-price .addon input:first-child,
+.field-price .addon input:first-child,
+.field-special_price .addon input:first-child,
+.field-msrp .addon input:first-child {
+  border-radius: 0 4px 4px 0;
+}
+.field.type-price input,
+.field-price input,
+.field-special_price input,
+.field-msrp input {
+  border-width: 1px 1px 1px 0;
+  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.075) inset;
+}
+.field.type-price input:focus,
+.field-price input:focus,
+.field-special_price input:focus,
+.field-msrp input:focus {
+  box-shadow: 0 0 8px rgba(82, 168, 236, 0.6);
+}
+.field.type-price input:focus ~ label.addafter,
+.field-price input:focus ~ label.addafter,
+.field-special_price input:focus ~ label.addafter,
+.field-msrp input:focus ~ label.addafter {
+  box-shadow: 0 0 8px rgba(82, 168, 236, 0.6);
+}
+.field.type-price input ~ label.addafter strong,
+.field-price input ~ label.addafter strong,
+.field-special_price input ~ label.addafter strong,
+.field-msrp input ~ label.addafter strong {
+  margin-left: 2px;
+  margin-right: -2px;
+}
+/*
+    Calendar
+-------------------------------------- */
+.ui-datepicker {
+  z-index: 998 !important;
+}
+.ui-datepicker .ui-datepicker-calendar td {
+  padding: 0;
+}
+.ui-datepicker .ui-datepicker-calendar th {
+  background: #efefef;
+  border: 1px solid #cfcfcf;
+  padding: 4px;
+  color: #676056;
+  font-weight: bold;
+}
+.ui-datepicker-calendar tbody tr td,
+.ui-datepicker-calendar tbody tr:nth-child(2n+1) td {
+  background: #fff;
+}
+.ui-datepicker .ui-datepicker-prev span,
+.ui-datepicker .ui-datepicker-next span {
+  margin-top: -1px;
+}
+/*
+    Details element
+-------------------------------------- */
+summary {
+  cursor: pointer;
+  display: inline-block;
+}
+.no-details details > * {
+  display: none;
+}
+.no-details details > summary:before {
+  float: left;
+  width: 20px;
+  content: 'â–º ';
+}
+.no-details details.open > summary:before {
+  content: 'â–¼ ';
+}
+.no-details details summary {
+  display: block;
+}
+/*
+    Blockquotes
+-------------------------------------- */
+blockquote {
+  border-left: 2px solid #ccc;
+  padding-left: 5px;
+}
+blockquote small:before {
+  content: '\2014 \00A0';
+}
+/*
+    Addresses
+-------------------------------------- */
+address {
+  font-style: normal;
+}
+/*
+    Tables
+-------------------------------------- */
+table > caption {
+  margin-bottom: 5px;
+}
+table tfoot,
+table th {
+  background: #e6e6e6;
+}
+table tfoot,
+table thead {
+  background: #666158;
+  color: #cac3b4;
+}
+table thead.active {
+  /*background:#F37B21;*/
+
+}
+table th {
+  text-align: left;
+  background: transparent;
+  font-weight: normal;
+}
+table th,
+table td {
+  border: 1px solid #C0BBAF;
+  padding: 6px 10px 7px;
+}
+table tbody tr td {
+  background: #F5F2ED;
+  color: #676056;
+  padding-top: 12px;
+}
+table tbody tr:not(:last-child) td {
+  border-top: 1px solid transparent;
+  border-bottom: 1px solid transparent;
+}
+table .dropdown-menu li {
+  padding: 7px 15px;
+  line-height: 14px;
+  cursor: pointer;
+}
+table tbody tr td:first-child input[type="checkbox"] {
+  margin: 0;
+}
+table tbody tr:nth-child(odd) td,
+table tbody tr:nth-child(odd) th {
+  background-color: #E6E3DE;
+}
+table tbody tr.selected td,
+table tbody tr.selected th {
+  border: 1px solid #C0BBAF;
+}
+table tbody tr.selected td,
+table tbody tr.selected th,
+table tbody tr:hover td,
+table tbody tr:hover th,
+table tbody tr:nth-child(odd):hover td,
+table tbody tr:nth-child(odd):hover th {
+  background-color: #fff;
+}
+/*
+    X-tree styles
+-------------------------------------- */
+.x-tree-node .leaf .x-tree-node-icon {
+  background-image: url(../images/fam_leaf.png);
+}
+.x-tree-node .system-leaf .x-tree-node-icon {
+  background-image: url(../images/fam_application_form_delete.png);
+}
+.x-tree-node-ct {
+  overflow: hidden;
+}
+/*
+    Styles for "js" tooltip with positionings
+-------------------------------------- */
+.tipsy {
+  padding: 11px;
+}
+.tipsy-inner {
+  padding: 12px 15px;
+  max-width: 185px;
+  background: #faf8f6;
+  border: 1px solid #dcd8ce;
+  box-shadow: 0 2px 5px rgba(49, 48, 43, 0.4);
+}
+.tipsy-inner .error {
+  width: 158px;
+}
+.tipsy-inner .error h5 {
+  color: #be0a0a;
+  font-size: 16px;
+  font-weight: 500;
+  margin: 0 0 6px 0;
+}
+.tipsy-inner .error p {
+  color: #676056;
+  line-height: 1.5;
+  margin: 0;
+}
+.tipsy-e .tipsy-arrow {
+  top: 50%;
+  left: 1px;
+  margin-top: -10px;
+  border-top: 10px solid transparent;
+  border-right: 10px solid #dcd8ce;
+  border-bottom: 10px solid transparent;
+  border-left: none;
+}
+.tipsy-w .tipsy-arrow {
+  top: 50%;
+  right: 0;
+  margin-top: -10px;
+  border-top: 10px solid transparent;
+  border-right: none;
+  border-bottom: 10px solid transparent;
+  border-left: 10px solid #dcd8ce;
+}
+.tipsy-n .tipsy-arrow,
+.tipsy-ne .tipsy-arrow,
+.tipsy-nw .tipsy-arrow {
+  bottom: 1px;
+  border-top: 10px solid #dcd8ce;
+  border-right: 10px solid transparent;
+  border-bottom: none;
+  border-left: 10px solid transparent;
+}
+.tipsy-ne .tipsy-arrow {
+  left: 16px;
+}
+.tipsy-nw .tipsy-arrow {
+  right: 16px;
+}
+.tipsy-s .tipsy-arrow,
+.tipsy-se .tipsy-arrow,
+.tipsy-sw .tipsy-arrow {
+  top: 1px;
+  border-left: 10px solid transparent;
+  border-right: 10px solid transparent;
+  border-bottom: 10px solid #dcd8ce;
+  border-top: none;
+}
+.tipsy-se .tipsy-arrow {
+  left: 16px;
+}
+.tipsy-sw .tipsy-arrow {
+  right: 16px;
+}
+.tipsy-arrow:after,
+.tipsy-arrow:before {
+  position: absolute;
+  width: 0;
+  height: 0;
+  content: '';
+}
+.tipsy-e .tipsy-arrow:after {
+  top: -5px;
+  left: 2px;
+  margin-top: -4px;
+  border-top: 9px solid transparent;
+  border-right: 9px solid #faf8f6;
+  border-bottom: 9px solid transparent;
+}
+.tipsy-e .tipsy-arrow:before {
+  top: -8px;
+  margin-top: 0;
+  border-top: 10px solid transparent;
+  border-right: 10px solid rgba(49, 48, 43, 0.1);
+  border-bottom: 10px solid transparent;
+}
+.tipsy-w .tipsy-arrow:after {
+  top: -5px;
+  left: -12px;
+  margin-top: -4px;
+  border-top: 9px solid transparent;
+  border-right: none;
+  border-bottom: 9px solid transparent;
+  border-left: 9px solid #faf8f6;
+}
+.tipsy-w .tipsy-arrow:before {
+  top: -8px;
+  left: -10px;
+  margin-top: 0;
+  border-top: 10px solid transparent;
+  border-right: none;
+  border-bottom: 10px solid transparent;
+  border-left: 10px solid rgba(49, 48, 43, 0.1);
+}
+.tipsy-n .tipsy-arrow:after,
+.tipsy-ne .tipsy-arrow:after,
+.tipsy-nw .tipsy-arrow:after {
+  margin-top: -4px;
+  left: -9px;
+  top: -7px;
+  border-top: 9px solid #faf8f6;
+  border-right: 9px solid transparent;
+  border-left: 9px solid transparent;
+}
+.tipsy-n .tipsy-arrow:before,
+.tipsy-ne .tipsy-arrow:before,
+.tipsy-nw .tipsy-arrow:before {
+  left: -10px;
+  top: -8px;
+  margin-top: 0;
+  border-top: 10px solid rgba(49, 48, 43, 0.1);
+  border-right: 10px solid transparent;
+  border-left: 10px solid transparent;
+}
+.tipsy-s .tipsy-arrow:after,
+.tipsy-sw .tipsy-arrow:after,
+.tipsy-se .tipsy-arrow:after {
+  left: -9px;
+  top: 6px;
+  margin-top: -4px;
+  border-top: none;
+  border-right: 9px solid transparent;
+  border-bottom: 9px solid #faf8f6;
+  border-left: 9px solid transparent;
+}
+.tipsy-inner dl {
+  margin: 0;
+}
+.tipsy-inner dt {
+  margin: 0 0 4px;
+  font-size: 16px;
+  font-weight: 400;
+  color: #f47b20;
+}
+.tipsy-inner dd {
+  margin: 0;
+  color: #676056;
+  font-size: 12px;
+  line-height: 18px;
+  font-family: Arial, Helvetica, sans-serif;
+}
+/*
+    Popups
+-------------------------------------- */
+.fade .popup {
+  padding: 0;
+  border: 5px solid #969288;
+  border-radius: 8px;
+}
+.wrapper-popup {
+  padding: 0 10px;
+}
+.fade .popup .popup-inner {
+  padding: 20px;
+  border-radius: 3px;
+}
+.fade .popup .popup-title {
+  margin: 0 0 10px;
+}
+.popup-loading {
+  position: fixed;
+  z-index: 1003;
+  width: 200px;
+  background: rgba(255, 255, 255, 0.8);
+  left: 50%;
+  top: 40%;
+  margin-left: -100px;
+  color: #d85909;
+  border-color: #d85909;
+  font-size: 14px;
+  font-weight: bold;
+  text-align: center;
+  padding: 100px 0 10px;
+}
+.popup-loading:after {
+  position: absolute;
+  left: 50%;
+  top: 40%;
+  background-image: url(../mui/images/ajax-loader-big.gif);
+  width: 64px;
+  height: 64px;
+  margin: -32px 0 0 -32px;
+  content: '';
+  z-index: 2;
+}
+/* Loading mask */
+.loading-old,
+.loading-mask {
+  background: rgba(255, 255, 255, 0.4);
+  z-index: 999;
+}
+.loading-old,
+.loading-mask {
+  position: fixed;
+  left: 0;
+  top: 0;
+  right: 0;
+  bottom: 0;
+}
+.loading-old .loader,
+.loading-mask .loader {
+  position: absolute;
+  margin: auto;
+  left: 0;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  width: 160px;
+  height: 160px;
+  color: #5e5b56;
+  font-size: 14px;
+  font-weight: bold;
+  text-align: center;
+  background: #e5e2dd url(../mui/images/ajax-loader-big.gif) no-repeat 50% 30%;
+  border-radius: 5px;
+  opacity: .95;
+}
+.loading-mask img {
+  display: none;
+}
+.loading-old p,
+.loading-mask p {
+  margin-top: 118px;
+}
+/* Backup popup */
+/* TODO: remove after backups page js refactoring */
+.backup-dialog {
+  margin-top: inherit !important;
+}
+/*
+    Global Navigation
+-------------------------------------- */
+.navigation {
+  position: relative;
+  border-bottom: 1px solid #aaa69c;
+  background: #726c62;
+  background: url();
+  background: -moz-linear-gradient(top, #726c62 0%, #656057 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #726c62), color-stop(100%, #656057));
+  background: -webkit-linear-gradient(top, #726c62 0%, #656057 100%);
+  background: -o-linear-gradient(top, #726c62 0%, #656057 100%);
+  background: -ms-linear-gradient(top, #726c62 0%, #656057 100%);
+  background: linear-gradient(to bottom, #726c62 0%, #656057 100%);
+  padding: 0 20px;
+}
+.navigation:before {
+  position: absolute;
+  left: 0;
+  top: 0;
+  right: 0;
+  height: 5px;
+  box-shadow: 0 2px 4px #46433d inset;
+  content: '';
+  z-index: 991;
+}
+.navigation:after {
+  position: absolute;
+  left: 0;
+  bottom: 0;
+  right: 0;
+  height: 1px;
+  background: #4e483f;
+  content: '';
+  z-index: 1;
+}
+.navigation .level-0.reverse > .submenu {
+  right: 1px;
+}
+.navigation > ul {
+  position: relative;
+  min-width: 960px;
+  max-width: 1300px;
+  margin: 0 auto;
+  text-align: right;
+  z-index: 900;
+}
+.navigation .level-0 > .submenu {
+  display: none;
+  position: absolute;
+  top: 100%;
+  padding: 19px 10px;
+}
+.navigation .level-0 > .submenu a {
+  display: block;
+  color: #007dbd;
+  font-size: 13px;
+  font-weight: 400;
+  line-height: 1.385;
+  padding: 5px 20px 4px;
+  text-decoration: none;
+  -webkit-transition: color 0.15s ease-out;
+  -moz-transition: color 0.15s ease-out;
+}
+.navigation .level-0 > .submenu a:focus,
+.navigation .level-0 > .submenu a:hover {
+  text-decoration: underline;
+}
+.navigation .level-0 > .submenu li {
+  margin-bottom: 1px;
+}
+.navigation .level-0 > .submenu a[href="#"] {
+  cursor: default;
+  display: block;
+  color: #676056;
+  font-size: 14px;
+  font-weight: 600;
+  line-height: 1;
+  margin: 7px 0 6px;
+  padding: 0 20px;
+}
+.navigation .level-0 > .submenu a[href="#"]:focus,
+.navigation .level-0 > .submenu a[href="#"]:hover {
+  text-decoration: none;
+}
+.navigation .level-0 {
+  display: inline-block;
+  float: left;
+  text-align: left;
+  -webkit-transition: display 0.15s ease-out;
+  -moz-transition: display 0.15s ease-out;
+}
+.navigation .level-0 > a {
+  background: none;
+  position: relative;
+  display: inline-block;
+  padding: 37px 21px 11px;
+  color: #f2ebde;
+  font-size: 13px;
+  font-weight: 400;
+  text-shadow: 0 1px 3px #222;
+  text-transform: uppercase;
+  text-decoration: none;
+  -webkit-transition: background 0.15s ease-out;
+  -moz-transition: background 0.15s ease-out;
+}
+.navigation .level-0.active > a {
+  background: #625d54;
+  background: url();
+  background: -moz-linear-gradient(top, #625d54 1%, #565249 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(1%, #625d54), color-stop(100%, #565249));
+  background: -webkit-linear-gradient(top, #625d54 1%, #565249 100%);
+  background: -o-linear-gradient(top, #625d54 1%, #565249 100%);
+  background: -ms-linear-gradient(top, #625d54 1%, #565249 100%);
+  background: linear-gradient(to bottom, #625d54 1%, #565249 100%);
+}
+.navigation .level-0.hover.recent > a {
+  background: #fff;
+  color: #676056;
+  font-size: 13px;
+  font-weight: 400;
+  text-shadow: 0 1px 3px #c1bfbb;
+}
+.navigation .level-0 > a:focus {
+  outline: none;
+}
+.navigation .level-0 > .submenu {
+  opacity: 0;
+  visibility: hidden;
+}
+.navigation .level-0.recent.hover > .submenu {
+  opacity: 1;
+  visibility: visible;
+}
+.no-js .navigation .level-0:hover > .submenu,
+.no-js .navigation .level-0.hover > .submenu,
+.no-js .navigation .level-0 > a:focus + .submenu {
+  display: block;
+}
+.navigation .level-0 > a:before {
+  position: absolute;
+  left: 0;
+  right: 0;
+  top: 12px;
+  text-align: center;
+  height: 20px;
+  content: '';
+  font-family: 'admin-icons';
+  font-size: 18px;
+  speak: none;
+  font-weight: normal;
+  line-height: 1;
+  -webkit-font-smoothing: antialiased;
+  text-shadow: none;
+}
+.navigation .level-0.item-dashboard > a:before,
+.navigation .level-0.item-hub > a:before {
+  content: '\e007';
+  font-size: 17px;
+}
+.navigation .level-0.item-sales > a:before,
+.navigation .level-0.item-sales-and-orders > a:before {
+  content: '\e008';
+}
+.navigation .level-0.item-catalog > a:before {
+  content: '\e00b';
+}
+.navigation .level-0.item-customer > a:before,
+.navigation .level-0.item-customers > a:before {
+  content: '\e009';
+  font-size: 24px;
+  top: 10px;
+}
+.navigation .level-0.item-promo > a:before,
+.navigation .level-0.item-marketing > a:before {
+  content: '\e00a';
+  font-size: 17px;
+  top: 13px;
+}
+.navigation .level-0.item-cms > a:before,
+.navigation .level-0.item-content > a:before {
+  content: '\e006';
+  font-size: 16px;
+}
+.navigation .level-0.item-report > a:before,
+.navigation .level-0.item-reports > a:before {
+  content: '\e00c';
+  font-size: 16px;
+  top: 13px;
+}
+.navigation .level-0.item-newsletter > a:before {
+  font-family: 'MUI-Icons';
+  content: '\e03c';
+  font-size: 22px;
+  top: 9px;
+}
+.navigation .level-0 > .submenu {
+  background: #fff;
+  box-shadow: 0 3px 3px rgba(49, 48, 43, 0.5);
+  border-radius: 0 0 5px 5px;
+}
+.no-boxshadow .navigation .level-0 > .submenu {
+  border: 1px solid #cbc1b4;
+  border-width: 0 1px 1px;
+  margin-left: -1px;
+}
+.navigation .level-0 > .submenu li {
+  max-width: 200px;
+}
+.navigation .level-0 > .submenu > ul {
+  white-space: nowrap;
+}
+.navigation .level-0 > .submenu .column {
+  display: inline-block;
+  vertical-align: top;
+}
+.navigation .level-0 .submenu .level-1 {
+  white-space: normal;
+}
+.navigation .level-0.parent .submenu .level-1.parent {
+  margin: 17px 0;
+}
+.navigation .level-0.parent .level-1.parent:first-child {
+  margin-top: 0;
+}
+.navigation .level-2 .submenu {
+  margin-left: 7px;
+}
+.navigation .level-0 > .submenu .level-2 > a[href="#"] {
+  font-size: 13px;
+  margin-top: 10px;
+  margin-left: 7px;
+}
+.navigation .level-2 > .submenu a {
+  font-size: 12px;
+  line-height: 1.231;
+}
+.navigation .level-0 > .submenu .level-3 > a[href="#"],
+.navigation .level-3 .submenu {
+  margin-left: 15px;
+}
+/*
+    Admin and Store Settings
+-------------------------------------- */
+.navigation .level-0.item-system,
+.navigation .level-0.item-stores {
+  float: none;
+  margin: 21px 0 0;
+}
+.navigation .level-0.item-system > .submenu,
+.navigation .level-0.item-stores > .submenu {
+  left: auto;
+  right: 1px;
+}
+.navigation .level-0.item-system.hover:after,
+.navigation .level-0.item-stores.hover:after {
+  color: #c2b59c;
+}
+.navigation .level-0.item-system > a,
+.navigation .level-0.item-stores > a {
+  position: relative;
+  padding: 0;
+}
+.navigation .level-0.item-system:hover > a,
+.navigation .level-0.item-system.hover > a,
+.navigation .level-0.item-stores:hover > a,
+.navigation .level-0.item-stores.hover > a {
+  background: transparent;
+}
+.no-js .navigation .level-0.item-system:hover > a:before,
+.navigation .level-0.item-system:hover > a:before,
+.navigation .level-0.item-system.hover > a:before,
+.no-js .navigation .level-0.item-stores:hover > a:before,
+.navigation .level-0.item-stores:hover > a:before,
+.navigation .level-0.item-stores.hover > a:before {
+  display: none;
+  position: absolute;
+  top: 1.4em;
+  left: auto;
+  right: -19px;
+  height: 20px;
+  width: 20px;
+  content: '';
+  border: 10px solid #fff;
+  border-width: 0 0 10px 10px;
+  border-radius: 0 0 0 20px;
+  z-index: 2;
+}
+.navigation .level-0.item-system > a:after,
+.navigation .level-0.item-stores > a:after {
+  display: none;
+  position: absolute;
+  top: 2em;
+  left: -20px;
+  margin-top: -1px;
+  width: 20px;
+  height: 20px;
+  content: '';
+  border: 10px solid #fff;
+  border-width: 0 10px 10px 0;
+  border-radius: 0 0 20px;
+  z-index: 1;
+}
+.no-js .navigation .level-0.item-system:hover > a:after,
+.navigation .level-0.item-system.hover > a:after,
+.no-js .navigation .level-0.item-system:hover > a:before,
+.navigation .level-0.item-system.hover > a:before,
+.no-js .navigation .level-0.item-stores:hover > a:after,
+.navigation .level-0.item-stores.hover > a:after,
+.no-js .navigation .level-0.item-stores:hover > a:before,
+.navigation .level-0.item-stores.hover > a:before {
+  display: block;
+}
+.no-js .navigation .level-0.last:hover > a:before,
+.navigation .level-0.last.hover > a:before {
+  display: none;
+}
+.navigation .level-0.item-system > a span,
+.navigation .level-0.item-stores > a span {
+  display: block;
+  position: relative;
+  padding: 4px 20px 5px 10px;
+  border: 1px solid #4c483f;
+  border-left: 0;
+  font: 12px/1.333 "Helvetica", Arial, serif;
+  text-transform: none;
+  text-shadow: none;
+  background: #58534a;
+  color: #f2ebde;
+  height: 1.333em;
+}
+.navigation .level-0.item-system:hover > a span,
+.navigation .level-0.item-stores:hover > a span {
+  background: #31302B;
+}
+.navigation .level-0.item-system:hover > a span:after,
+.navigation .level-0.item-stores:hover > a span:after {
+  color: #58534a;
+}
+.no-js .navigation .level-0.item-system:hover > a span,
+.navigation .level-0.item-system.hover > a span,
+.no-js .navigation .level-0.item-stores:hover > a span,
+.navigation .level-0.item-stores.hover > a span {
+  background: #fff;
+  color: #676056;
+  text-shadow: none;
+  border-bottom: 0;
+  border-right: 0;
+  padding-right: 21px;
+  padding-bottom: 2em;
+  margin-bottom: -2em;
+}
+.no-js .navigation .level-0.last:hover > a span,
+.navigation .level-0.last.hover > a span {
+  background: #fff;
+  color: #676056;
+  text-shadow: none;
+  border-bottom: 0;
+  border-right: 0;
+  padding-right: 21px;
+  padding-bottom: 2em;
+  margin-bottom: -2em;
+}
+.no-js .navigation .level-0.last:hover > a span,
+.navigation .level-0.last.hover > a span {
+  border-right: 1px solid;
+  padding-right: 20px;
+}
+.navigation .level-0.item-system > a span:after,
+.navigation .level-0.item-stores > a span:after {
+  position: absolute;
+  top: 7px;
+  right: 7px;
+  width: 10px;
+  height: 10px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: "\e02c";
+  font-size: 8px;
+  text-align: center;
+  color: #31302b;
+  z-index: 2;
+}
+.navigation .level-0.item-stores > a span:before {
+  position: absolute;
+  left: -22px;
+  top: -1px;
+  bottom: -1px;
+  height: 1.333em;
+  padding: 0 0 9px;
+  width: 21px;
+  border: 1px solid #4c483f;
+  border-right: 0;
+  border-radius: 5px 0 0 5px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  font-size: 12px;
+  line-height: 2;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e07e';
+  text-align: center;
+  color: #31302b;
+}
+.navigation .level-0.last > a,
+.navigation .level-0.last > a span {
+  border-radius: 0 5px 5px 0;
+}
+.no-js .navigation .level-0.last:hover > a span,
+.navigation .level-0.last.hover > a span,
+.navigation .level-0.last > a:focus span {
+  border-radius: 0;
+}
+/*
+    Login page
+-------------------------------------- */
+.page-login {
+  height: 100%;
+}
+.page-login .wrapper {
+  min-height: 100%;
+  padding: 0;
+}
+.page-login .wrapper-inner {
+  overflow: auto;
+  padding-bottom: 140px;
+}
+.page-login .footer {
+  clear: both;
+  height: 140px;
+  margin-top: -140px;
+  position: relative;
+}
+.page-login .footer-content {
+  max-width: none;
+  min-width: 0;
+}
+.page-login .footer-copyright {
+  text-align: right;
+}
+.page-login .form-login {
+  width: 280px;
+  margin: 160px auto 60px;
+  padding: 30px 25px;
+  border: 1px solid #e3ded5;
+  border-radius: 5px;
+  background: #f7f2ec;
+}
+.page-login .fieldset {
+  background: transparent;
+  border: 0;
+  border-radius: 0;
+  margin: 0;
+  padding: 0;
+}
+.page-login .fieldset > .legend {
+  border-bottom: 0;
+  margin-bottom: 15px;
+}
+.page-login .fieldset > .legend span {
+  font-size: 32px;
+  line-height: 32px;
+  padding: 0;
+  color: #8a847c;
+  display: inline;
+}
+.page-login .fieldset .field {
+  margin: 0 0 13px;
+}
+.page-login .form-inline .label {
+  width: auto;
+  padding: 0;
+  margin-bottom: 13px;
+}
+.page-login .field-username label,
+.page-login .field-password label,
+.page-login .field-confirmation label {
+  display: none;
+}
+.page-login .form-inline .label + .control {
+  width: auto;
+  float: none;
+}
+.page-login .header {
+  margin-bottom: 30px;
+  background: transparent;
+  padding: 0;
+  z-index: auto;
+  position: static;
+}
+.page-login .header .logo {
+  display: block;
+  width: 262px;
+  height: 64px;
+  text-indent: -999em;
+  background: url(Magento_Backend::images/logo-magento.png) no-repeat;
+}
+.page-login .form-actions {
+  padding: 0;
+  margin: 0;
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+}
+.page-login .actions,
+.page-login .links {
+  display: inline-block;
+  vertical-align: middle;
+}
+.page-login input[type=text],
+.page-login input[type=password] {
+  border-color: #cac3b4;
+  font-size: 18px;
+  padding: 12px 12px 14px;
+  height: auto;
+}
+.page-login :-ms-input-placeholder {
+  color: #bebab1 !important;
+}
+.page-login ::-webkit-input-placeholder {
+  color: #bebab1 !important;
+}
+.page-login :-moz-placeholder {
+  color: #bebab1 !important;
+}
+.page-login .action-login,
+.page-login .action-retrieve {
+  font-size: 22px;
+  padding: 14px 22px 16px;
+}
+.page-login .action-retrieve,
+.page-login .action-reset {
+  font-size: 18px;
+  padding: 10px 17px 10px;
+}
+.page-login .action-forgotpassword,
+.page-login .action-back {
+  font-size: 12px;
+  color: #1c8bb8;
+  text-decoration: underline;
+  position: absolute;
+  left: 0;
+  bottom: -70px;
+}
+.page-login .action-forgotpassword:hover,
+.page-login .action-back:hover {
+  text-decoration: none;
+}
+/*
+    Page title
+-------------------------------------- */
+.page-title {
+  position: relative;
+  margin: 20px 0;
+}
+.page-content > .page-title {
+  max-width: 1300px;
+  min-width: 960px;
+  margin-left: auto;
+  margin-right: auto;
+}
+.page-title-inner > .title {
+  color: #676056;
+  font-size: 28px;
+  font-weight: 400;
+  display: inline-block;
+  margin: 0;
+  width: 100%;
+  word-wrap: break-word;
+}
+.page-title-inner .title > h3 {
+  margin: 0;
+}
+.page-title-inner .actions {
+  float: right;
+}
+.page-title-inner .actions form {
+  display: inline-block;
+}
+/*
+    Messages (Global)
+-------------------------------------- */
+.message {
+  margin: 0;
+  padding: 10px 26px 10px 32px;
+  background: #f9f5ec;
+  border: 0;
+  -moz-border-radius: 0;
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  color: #676056;
+  text-shadow: none;
+  border-bottom: 1px solid #c7c2b6;
+}
+.wrapper > .message {
+  padding: 0 20px;
+}
+.page-content > #messages {
+  max-width: 1300px;
+  min-width: 960px;
+  margin: 0 auto;
+}
+.message:before,
+.message-system .message-inner:before {
+  position: absolute;
+  left: 8px;
+  top: 50%;
+  margin-top: -8px;
+  background: none;
+  text-shadow: none;
+  width: auto;
+  height: auto;
+  border: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 16px;
+  content: '\e006';
+  /* notification icon */
+
+  color: #6e685e;
+}
+.messages-inbox {
+  float: right;
+}
+.messages-inbox .critical {
+  color: red;
+}
+/* System Messages */
+.message-system {
+  padding: 0;
+}
+.message-system:before {
+  display: none;
+}
+.message-system .message-inner {
+  position: relative;
+  min-width: 960px;
+  max-width: 1300px;
+  margin: 0 auto;
+}
+.message-system .message-inner:before {
+  margin-top: -10px;
+}
+.message-system .message-content {
+  padding: 10px 26px 10px 32px;
+}
+/*
+    No-javaScript-Enabled message
+-------------------------------------- */
+.message-noscript {
+  background: #ff9;
+  padding: 0;
+  border: 0;
+  box-shadow: 0 1px 2px #46433d;
+  z-index: 994;
+}
+.message-noscript .message-content {
+  margin: 0 auto;
+  max-width: 1300px;
+  min-width: 960px;
+  padding: 3px 0;
+  position: relative;
+  text-align: center;
+}
+.message-noscript:before {
+  content: '';
+}
+.message-noscript .message-content:before {
+  position: relative;
+  background: none;
+  text-shadow: none;
+  width: auto;
+  height: auto;
+  vertical-align: middle;
+  border: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 32px;
+  content: '\e006';
+  /* notification icon */
+
+  color: #6e685e;
+}
+.message-demo-mode {
+  background: #d75f07;
+  border: 0;
+  color: #fff;
+  text-align: center;
+  padding: 5px 0;
+  box-shadow: 0 1px 2px #46433d;
+  z-index: 993;
+}
+.message-demo-mode:before {
+  content: '';
+}
+.message-demo-mode .message-content {
+  margin: 0 auto;
+  max-width: 1300px;
+  min-width: 960px;
+  position: relative;
+  text-align: center;
+}
+.message-demo-mode .message-content:before {
+  position: relative;
+  background: none;
+  text-shadow: none;
+  width: auto;
+  height: auto;
+  vertical-align: middle;
+  border: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 16px;
+  content: '\e006';
+  /* notification icon */
+
+}
+/*
+    Information message
+-------------------------------------- */
+.message-info {
+  background: #fffbf0;
+  border: 1px solid #d87e34;
+  margin-bottom: 20px;
+}
+.message-info:before {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e046';
+  /* icon-info  */
+
+  color: #d87e34;
+}
+/*
+    Error message
+-------------------------------------- */
+.message-error {
+  color: #963535;
+  background: #f3dcd8;
+  border: 1px solid #963535;
+  margin-bottom: 20px;
+}
+.message-error:before {
+  content: '\e069';
+  color: #963535;
+}
+/*
+    Store Switcher
+-------------------------------------- */
+.store-switcher-alt {
+  position: relative;
+  display: inline-block;
+}
+.store-switcher-alt .dropdown-menu {
+  white-space: nowrap;
+  margin-top: 2px;
+}
+.store-switcher-alt.active .dropdown-menu {
+  display: block;
+}
+.store-switcher-alt .dropdown-menu ul {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+}
+.store-switcher-alt strong {
+  display: block;
+  font-size: 14px;
+  font-weight: 500;
+  line-height: 1.333;
+  color: #a6a098;
+  padding: 5px 10px;
+}
+.store-switcher-alt .store-selected {
+  font-size: 12px;
+  font-weight: 400;
+  line-height: 1.333;
+  color: #676056;
+  cursor: pointer;
+}
+.store-switcher-alt .store-selected:after {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02c';
+  /* arrow down icon */
+
+  color: #b3b0ad;
+  margin: 0 0 0 3px;
+  vertical-align: text-top;
+}
+.store-switcher-alt .store-switcher-website,
+.store-switcher-alt .store-switcher-store {
+  padding: 0;
+}
+.store-switcher-alt .store-switcher-website:hover,
+.store-switcher-alt .store-switcher-store:hover {
+  background: none;
+}
+.store-switcher-website {
+  margin: 5px 0 0;
+}
+.store-switcher-website > strong {
+  padding-left: 13px;
+}
+.store-switcher-store {
+  margin: 1px 0 0;
+}
+.store-switcher-store > strong {
+  padding-left: 20px;
+}
+.store-switcher-alt .store-switcher-store > ul {
+  margin-top: 1px;
+}
+.store-switcher-alt .store-switcher-store-view {
+  padding: 0;
+}
+.store-switcher-store-view:first-child {
+  border-top: 1px solid #e5e5e5;
+}
+.store-switcher-store-view > a {
+  display: block;
+  padding: 5px 15px 5px 24px;
+  color: #333;
+  font-size: 13px;
+  text-decoration: none;
+}
+.store-switcher-alt .store-switcher-all,
+.store-switcher-alt .manage-stores {
+  padding: 0;
+}
+.store-switcher-alt .store-switcher-all > a,
+.store-switcher-alt .manage-stores > a {
+  display: block;
+  padding: 8px 15px;
+  color: #676056;
+  text-decoration: none;
+  font-size: 12px;
+}
+/*
+    Page Structure
+-------------------------------------- */
+.wrapper {
+  padding: 0 0 60px;
+  min-width: 1000px;
+}
+.page-content {
+  margin: 0 auto;
+  padding: 0 20px;
+}
+.page-title.complex .title {
+  float: left;
+  width: 70%;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+}
+.page-title.complex .store-switcher-alt {
+  float: right;
+  margin: 12px 0 0;
+}
+.side-col {
+  position: relative;
+  width: 20%;
+}
+.main-col {
+  position: relative;
+  width: 80%;
+  padding: 0 20px 20px;
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  -ms-box-sizing: border-box;
+  box-sizing: border-box;
+}
+.col-left {
+  float: left;
+}
+.col-right {
+  float: right;
+}
+.col-1-layout .main-col {
+  width: auto;
+}
+.col-2-left-layout .main-col,
+.col-2-right-layout .side-col {
+  float: right;
+}
+.col-2-right-layout .main-col,
+.col-2-left-layout .side-col {
+  float: left;
+}
+.col-2-left-layout,
+.col-1-layout {
+  position: relative;
+  background: #f5f2ed;
+  border: 1px solid #d5d0ca;
+  border-radius: 5px;
+  min-width: 960px;
+  max-width: 1300px;
+  margin: 0 auto;
+}
+.col-1-layout {
+  padding: 20px;
+  min-width: 920px;
+  max-width: 1260px;
+}
+.col-2-left-layout:before {
+  position: absolute;
+  display: block;
+  left: 20%;
+  top: 0;
+  bottom: 0;
+  width: 6px;
+  margin-left: -7px;
+  content: '';
+  background: -moz-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.06) 100%);
+  /* FF3.6+ */
+
+  background: -webkit-gradient(linear, left top, right top, color-stop(0%, rgba(0, 0, 0, 0)), color-stop(100%, rgba(0, 0, 0, 0.06)));
+  /* Chrome,Safari4+ */
+
+  background: -webkit-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.06) 100%);
+  /* Chrome10+,Safari5.1+ */
+
+  background: -o-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.06) 100%);
+  /* Opera 11.10+ */
+
+  background: -ms-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.06) 100%);
+  /* IE10+ */
+
+  background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.06) 100%);
+  /* W3C */
+
+  z-index: 2;
+}
+/* Sidebar and main column vertical separator */
+.main-col:after,
+.side-col:after {
+  position: absolute;
+  top: 0;
+  bottom: 0;
+  width: 1px;
+  background: #ded9d3;
+  content: '';
+}
+.col-2-left-layout .side-col:after {
+  right: 0;
+}
+.col-2-right-layout .side-col:after {
+  left: 0;
+}
+.col-2-right-layout .main-col:after {
+  right: -1px;
+}
+.col-2-left-layout .main-col:after {
+  left: -1px;
+}
+.col-2-left-layout .main-col,
+.col-2-right-layout .main-col {
+  min-width: 730px;
+}
+/* Sidebar title and store view switcher*/
+/* TODO: temporary styles */
+.side-col h3 {
+  padding: 0 17px;
+  margin-top: 16px;
+}
+.field-store-switcher {
+  padding: 0 0 20px;
+  margin: 0;
+}
+.side-col .ui-tabs h3 {
+  margin-bottom: 5px;
+  color: #524c44;
+  text-shadow: 0 1px 0 #fff;
+}
+.side-col > .store-switcher {
+  padding-top: 6px;
+}
+.field-store-switcher,
+.field-store-switcher > .label + .control {
+  display: inline-block;
+}
+.field-store-switcher > .tooltip + div > a {
+  color: #007dbd;
+  font-size: 12px;
+  font-weight: 400;
+}
+.field-store-switcher > .tooltip + div > a:focus,
+.field-store-switcher > .tooltip + div > a:hover {
+  text-decoration: underline;
+}
+.field-store-switcher > .label {
+  margin: 0;
+}
+.side-col > .field-store-switcher {
+  padding: 19px 18px 0;
+}
+.side-col > .field-store-switcher > .label {
+  margin: 0 0 6px;
+  display: block;
+}
+.dashboard-container .field-store-switcher {
+  padding: 20px 0;
+}
+.toolbar .field-store-switcher {
+  padding: 0;
+  margin-right: 20px;
+}
+/*
+    Universal Sidebar Tabs
+-------------------------------------- */
+.side-col .ui-tabs .ui-accordion-header {
+  position: relative;
+  margin: 10px 0 0;
+  padding: 5px 20px;
+  cursor: pointer;
+  color: #524c44;
+  text-shadow: 0 1px 0 #fff;
+}
+.side-col .ui-tabs .ui-accordion-header:focus {
+  outline: none;
+}
+.side-col .ui-accordion-header:before {
+  position: absolute;
+  left: 4px;
+  top: 7px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02a';
+  /* arrow right icon */
+
+  font-size: 14px;
+  color: #ada79e;
+}
+.side-col .ui-accordion-header:hover:before {
+  color: #777;
+}
+.side-col .ui-accordion-header-active:before {
+  content: '\e02c';
+  /* arrow down icon */
+
+}
+.side-col .tabs {
+  margin: 0 0 30px;
+  padding: 0;
+  list-style: none;
+  font-weight: 500;
+}
+.side-col > .ui-tabs > .tabs:first-child > li:first-child > a {
+  border-top-left-radius: 5px;
+}
+.side-col .tabs > li {
+  border-bottom: 1px solid #e5e1db;
+}
+.side-col .tabs > li:first-child {
+  border-top: 1px solid #e5e1db;
+}
+.side-col .tabs > li a {
+  position: relative;
+  display: block;
+  padding: 8px 18px;
+  text-decoration: none;
+  color: #676056;
+  -webkit-transition: background 0.3s ease-in-out;
+  -moz-transition: background 0.3s ease-in-out;
+  transition: background 0.3s ease-in-out;
+}
+.side-col .tabs > li a:active,
+.side-col .tabs > li a:focus {
+  outline: none;
+}
+.side-col .tabs > li a:hover {
+  background: #fff;
+}
+.side-col .tabs > .ui-state-active a {
+  border-left: 3px solid #d87e34;
+  padding-left: 15px;
+  background: #dedcd8;
+  box-shadow: 0 1px 2px #ccc inset;
+}
+.side-col .tabs > .ui-state-active a:after,
+.side-col .tabs > .ui-state-active a:before {
+  position: absolute;
+  top: 50%;
+  right: 0;
+  width: 14px;
+  margin-top: -14px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02b';
+  /* left turned triangle icon */
+
+  font-size: 22px;
+  color: #f5f2ed;
+  overflow: hidden;
+  z-index: 4;
+}
+.side-col .tabs > .ui-state-active a:before {
+  color: #bdbbb7;
+  margin-top: -13px;
+  z-index: 3;
+}
+.side-col .tabs span.error,
+.side-col .tabs span.loader {
+  display: none;
+  position: absolute;
+  right: 12px;
+  top: 7px;
+  width: 16px;
+  height: 16px;
+  font-size: 16px;
+}
+.side-col .tab-item-link.changed {
+  font-style: italic;
+}
+.side-col .tab-item-link.error span.error,
+.side-col .ui-tabs-loading span.loader {
+  display: block;
+}
+.side-col .tab-item-link.error span.error:after {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e006';
+  /* warning icon */
+
+  color: #d87e34;
+}
+.side-col .ui-tabs-loading span.loader:after {
+  background: url(../mui/images/ajax-loader-small.gif) no-repeat 50% 50%;
+  display: block;
+  content: '';
+  width: 16px;
+  height: 16px;
+}
+/* TODO: styles for navigation on System > Configuration page */
+/*
+    Horizontal Tabs
+-------------------------------------- */
+.tabs-horiz {
+  list-style: none;
+  margin: 0;
+  padding: 3px 0 0;
+}
+.tabs-horiz > li {
+  float: left;
+  border: 1px solid #e9e4db;
+  border-bottom-width: 0;
+  margin: 0 -1px 0 0;
+}
+.tabs-horiz > li a {
+  position: relative;
+  display: block;
+  padding: 7px 18px 9px;
+  text-decoration: none;
+  font-size: 12px;
+  line-height: 1.666;
+  color: #676056;
+}
+.tabs-horiz > .ui-state-active a {
+  background: #fff;
+  border-top: 3px solid #f3771e;
+  margin-top: -3px;
+  box-shadow: 1px 0 3px #e9e4db;
+}
+/*
+    System -> Configuration page navigation in sidebar
+-------------------------------------- */
+.config-nav,
+.config-nav .items {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+}
+.config-nav-block:last-child {
+  margin-bottom: 30px;
+}
+.config-nav .item {
+  border-top: 1px solid #E5E1DB;
+}
+.config-nav .item:first-child {
+  border-top: 0;
+}
+.config-nav .title {
+  margin-bottom: 0;
+  text-transform: uppercase;
+  color: #444;
+  border: solid #CCC;
+  border-width: 1px 0;
+  opacity: .8;
+  padding: 7px 17px;
+  background: #E6E3DE;
+}
+.config-nav .item-nav {
+  display: block;
+  padding: 8px 18px;
+  text-decoration: none;
+  color: #676056;
+  -webkit-transition: background 0.3s ease-in-out;
+  -moz-transition: background 0.3s ease-in-out;
+  transition: background 0.3s ease-in-out;
+}
+.config-nav .item-nav:hover {
+  background: #fff;
+}
+.config-nav .item-nav.active {
+  position: relative;
+  border-left: 3px solid #d87e34;
+  padding-left: 15px;
+  background: #dedcd8;
+  box-shadow: 0 1px 2px #ccc inset;
+}
+.config-nav .item-nav.active:after {
+  position: absolute;
+  top: 50%;
+  right: 0;
+  width: 14px;
+  margin-top: -14px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02b';
+  /* left turned triangle icon */
+
+  font-size: 22px;
+  text-shadow: -1px 1px 0 #bdbbb7;
+  color: #f5f2ed;
+  overflow: hidden;
+  z-index: 3;
+}
+/*
+    Footer
+-------------------------------------- */
+.footer {
+  position: absolute;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  color: #989288;
+  font-size: 11px;
+}
+.footer-content {
+  margin: 0 auto;
+  max-width: 1300px;
+  min-width: 960px;
+  padding: 20px;
+}
+/*
+    Switcher
+-------------------------------------- */
+.switcher {
+  -webkit-touch-callout: none;
+  -webkit-user-select: none;
+  -khtml-user-select: none;
+  -moz-user-select: none;
+  -ms-user-select: none;
+  user-select: none;
+  cursor: pointer;
+  display: inline-block;
+  overflow: hidden;
+}
+.switcher input[type="checkbox"] {
+  position: absolute;
+  left: -999em;
+}
+.switcher-label {
+  color: #676056;
+  font-size: 13px;
+  font-weight: 600;
+  text-transform: uppercase;
+}
+.switcher-label:before {
+  content: attr(data-text-off);
+}
+.switcher-label:after {
+  display: inline-block;
+  margin-left: 10px;
+  vertical-align: bottom;
+  width: 34px;
+  height: 17px;
+  background: url(../images/switcher.png) no-repeat;
+  content: '';
+}
+.switcher input[type="checkbox"]:focus + .switcher-label:after {
+  border-color: #75b9f0;
+}
+.switcher input[type="checkbox"]:checked + .switcher-label:after {
+  background-position: -34px 0;
+}
+.switcher input[type="checkbox"]:checked + .switcher-label:before {
+  content: attr(data-text-on);
+}
+/*
+    Content actions panel (with buttons, switchers...)
+-------------------------------------- */
+.page-actions {
+  padding: 0 0 20px;
+  text-align: right;
+}
+.page-actions .buttons-group {
+  vertical-align: top;
+  text-align: left;
+}
+.page-actions > .switcher {
+  display: inline-block;
+  vertical-align: top;
+  margin: 6px 10px 0 0;
+}
+.main-col .page-actions {
+  padding: 20px 0;
+}
+.page-actions .store-switcher {
+  float: left;
+}
+.catalog-product-index .page-actions {
+  padding-top: 0;
+}
+/* TODO: refactor trees */
+.x-tree ul {
+  margin: 0;
+  padding: 0;
+}
+.page-actions.fixed {
+  padding: 0 21px;
+  position: fixed;
+  top: 0;
+  left: 0;
+  right: 0;
+  z-index: 998;
+}
+.page-actions.fixed .page-actions-inner {
+  background: -moz-linear-gradient(top, #f5f2ed 0%, #f5f2ed 56%, rgba(245, 242, 237, 0) 100%);
+  /* FF3.6+ */
+
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f5f2ed), color-stop(56%, #f5f2ed), color-stop(100%, rgba(245, 242, 237, 0)));
+  /* Chrome,Safari4+ */
+
+  background: -webkit-linear-gradient(top, #f5f2ed 0%, #f5f2ed 56%, rgba(245, 242, 237, 0) 100%);
+  /* Chrome10+,Safari5.1+ */
+
+  background: -o-linear-gradient(top, #f5f2ed 0%, #f5f2ed 56%, rgba(245, 242, 237, 0) 100%);
+  /* Opera 11.10+ */
+
+  background: -ms-linear-gradient(top, #f5f2ed 0%, #f5f2ed 56%, rgba(245, 242, 237, 0) 100%);
+  /* IE10+ */
+
+  background: linear-gradient(to bottom, #f5f2ed 0%, #f5f2ed 56%, rgba(245, 242, 237, 0) 100%);
+  /* W3C */
+
+  padding: 11px 20px 11px;
+  min-height: 36px;
+  margin: 0 auto;
+  min-width: 916px;
+  max-width: 1259px;
+}
+.lt-ie10 .page-actions.fixed .page-actions-inner {
+  background: #f5f2ed;
+}
+.page-actions.fixed .page-actions-inner:before {
+  content: attr(data-title);
+  float: left;
+  font-size: 20px;
+  max-width: 50%;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+}
+/*
+    Table Grid
+-------------------------------------- */
+/* Grid - General */
+.grid-container {
+  margin-bottom: 10px;
+}
+.grid {
+  border-bottom: 0;
+  color: #676056;
+  font-size: 13px;
+  font-weight: 400;
+  padding-bottom: .5em;
+}
+.grid table {
+  border-collapse: collapse;
+  border: none;
+  width: 100%;
+}
+.grid table.border {
+  border: 1px solid #c0bbaf;
+}
+.grid tbody {
+  background: #e6e3de;
+}
+.grid tr.even,
+.grid tr.even tr {
+  background: #f5f2ed;
+}
+.grid tr.on-mouse {
+  cursor: pointer;
+}
+.grid tr.on-mouse td,
+.grid table tbody tr.on-mouse:hover td,
+.grid table tbody tr.on-mouse:hover th,
+.grid table tbody tr.on-mouse:nth-child(odd):hover td,
+.grid table tbody tr.on-mouse:nth-child(odd):hover th {
+  background-color: #fff;
+}
+/* Rows mouse-over */
+.grid tr.invalid {
+  background-color: #f5d6c7;
+}
+.grid th,
+.grid td {
+  padding: 2px 4px 2px 4px;
+  vertical-align: top;
+}
+.grid th {
+  border: none;
+}
+.grid td.editable input.input-text {
+  width: 50px;
+  margin-left: 4px;
+}
+.grid td input.input-text {
+  width: 86%;
+}
+.grid td input.input-inactive {
+  background: #eee;
+}
+.grid table td {
+  border: solid #c0bbaf;
+  border-width: 0 1px 1px;
+  padding: 5px;
+}
+.grid table.border td {
+  background: #fff;
+}
+.grid table td.product {
+  text-align: right;
+}
+.grid table td.empty-text {
+  border: solid #c0bbaf;
+  border-width: 0 1px;
+  color: #676056;
+  font-size: 16px;
+  font-weight: 400;
+  text-align: center;
+  padding: 15px;
+}
+.grid table tr:last-child td.empty-text {
+  border-width: 0 1px 1px;
+}
+.grid table td.empty-text:hover {
+  background: #e6e3de;
+}
+.grid table td .action-select {
+  width: 100%;
+}
+.grid tbody.odd tr {
+  background: #fff;
+}
+.grid tbody.even tr {
+  background: #f6f6f6;
+}
+.grid tbody.odd tr td,
+.grid tbody.even tr td {
+  border-bottom: 0;
+}
+.grid tbody.odd tr.border td,
+.grid tbody.even tr.border td {
+  border-bottom: 1px solid #dadfe0;
+}
+/*
+    Grid - Pager and Buttons row
+-------------------------------------- */
+.grid-actions {
+  border: 1px solid #c0bbaf;
+  border-bottom: 0;
+  background: #f6f3ec;
+  background: url();
+  background: -moz-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f6f3ec), color-stop(100%, #edeae1));
+  background: -webkit-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -o-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -ms-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: linear-gradient(to bottom, #f6f3ec 0%, #edeae1 100%);
+  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f6f3ec', endColorstr='#edeae1', GradientType=0);
+  padding: 7px 8px 8px;
+  position: relative;
+}
+[id$='Grid'] .separator {
+  padding: 0 4px;
+  color: #b9b9b9;
+}
+.grid-actions select {
+  margin: 0 5px;
+}
+.grid-actions .export,
+.grid-actions .filter-actions {
+  float: right;
+  margin-left: 30px;
+}
+.grid-actions .filter-actions button {
+  float: left;
+  margin-left: 4px;
+}
+.grid-actions .pager {
+  color: #676056;
+  font-size: 13px;
+  font-weight: 400;
+}
+.grid-actions .pager select {
+  width: 5em;
+  margin: 0 4px;
+}
+.grid-actions .pager input.page {
+  width: 2em;
+}
+.pager .action-next,
+.pager .action-previous {
+  display: inline-block;
+  position: relative;
+  text-indent: 100%;
+  overflow: hidden;
+  height: 16px;
+  width: 16px;
+  vertical-align: middle;
+  text-decoration: none;
+}
+.pager .action-next:after,
+.pager .action-previous:after {
+  font-family: 'MUI-Icons';
+  content: "\e02a";
+  font-size: 16px;
+  color: #333;
+  position: absolute;
+  top: 0;
+  left: 0;
+  line-height: 1;
+  text-indent: 0;
+}
+.pager .action-previous:after {
+  content: "\e02b";
+}
+.pager span.action-next:after,
+.pager span.action-previous:after {
+  color: #7f7f7f;
+}
+.grid-actions .date {
+  float: left;
+  margin: 0 15px 0 0;
+  position: relative;
+}
+.grid-actions .date input {
+  margin: 0 5px;
+  width: 80px;
+}
+.grid-actions .required:after {
+  content: '*';
+  color: #f00;
+}
+[class^=" reports-report-"] .grid-actions .required:after {
+  content: '';
+}
+[class^=" reports-report-"] .grid-actions .required .label span:after {
+  content: '*';
+  color: #f00;
+}
+.grid-actions img {
+  vertical-align: middle;
+  height: 22px;
+  width: 22px;
+}
+.grid-actions .pager img {
+  width: auto;
+  height: auto;
+}
+.grid-actions .validation-advice {
+  background: #f3dcd8;
+  border: 1px solid #963535;
+  border-radius: 3px;
+  color: #963535;
+  margin: 5px 0 0;
+  padding: 3px 7px;
+  position: absolute;
+  white-space: nowrap;
+  z-index: 5;
+}
+.grid-actions .validation-advice:before {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e029';
+  /* user icon */
+
+  position: absolute;
+  top: -12px;
+  left: 50%;
+  margin-left: -3px;
+}
+.grid-actions .link-feed {
+  white-space: nowrap;
+}
+.grid-actions input[type="text"].validation-failed {
+  border-color: #fa7973;
+  box-shadow: 0 0 8px rgba(250, 121, 115, 0.6);
+}
+/*
+    Grid - Headings
+-------------------------------------- */
+.grid tr.headings th {
+  color: #ffffff;
+  font-size: 13px;
+  font-weight: 700;
+  border-right: 1px solid #837f79;
+  padding: 0;
+  vertical-align: bottom;
+}
+.grid tr th:first-child {
+  border-left: 1px solid #837f79;
+}
+.grid tr.headings th > span {
+  display: block;
+  border-bottom: 2px solid transparent;
+  padding: 5px 5px 2px;
+  white-space: nowrap;
+}
+.grid tr.headings th:hover > span {
+  border-color: #504841;
+}
+.grid tr.headings th.no-link:hover > span,
+.grid tr.headings th.col-select:hover > span {
+  border-color: transparent;
+}
+.grid tr.headings th a label {
+  display: block;
+  padding-right: 20px;
+}
+.grid tr.headings th a {
+  display: block;
+  color: #ffffff;
+  font-size: 13px;
+  font-weight: 700;
+  position: relative;
+  text-decoration: none;
+}
+.grid tr.headings th a:after {
+  display: none;
+  height: 8px;
+  width: 15px;
+  position: absolute;
+  bottom: 4px;
+  right: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  font-size: 20px;
+  line-height: 8px;
+  -webkit-font-smoothing: antialiased;
+  content: '\e038';
+  /* arrow down icon */
+
+  color: #8c8172;
+}
+.grid tr.headings th a:hover:after {
+  display: block;
+}
+.grid tr.headings th a.sort-arrow-desc:after {
+  color: #c7b299;
+  display: block;
+}
+.grid tr.headings th a.sort-arrow-asc:after {
+  color: #c7b299;
+  content: '\e035';
+  /* arrow up icon */
+
+  display: block;
+}
+.grid tr.headings th a.sort-arrow-desc:hover:after,
+.grid tr.headings th a.sort-arrow-asc:hover:after {
+  color: #fff;
+}
+/* Grid - Filter */
+.grid .filter {
+  cursor: default;
+}
+.grid .filter th {
+  padding: 5px;
+  border-right: 1px solid #837F79;
+  vertical-align: top;
+  white-space: normal;
+}
+.grid .filter input.input-text {
+  background: #5e5a52;
+  border-radius: 2px;
+  border: none;
+  color: #bcb795;
+  padding: 0 5px;
+  height: 20px;
+  width: 99%;
+}
+.grid .filter input.input-text::-webkit-input-placeholder {
+  color: #858376 !important;
+  text-transform: lowercase;
+}
+.grid .filter input.input-text:-moz-placeholder {
+  color: #858376 !important;
+  text-transform: lowercase;
+}
+.grid .filter input.input-text::-moz-placeholder {
+  color: #858376 !important;
+  text-transform: lowercase;
+}
+:-ms-input-placeholder {
+  color: #858376 !important;
+  text-transform: lowercase;
+}
+.grid .filter select {
+  background: #5e5a52;
+  border-radius: 2px;
+  border: none;
+  color: #bcb795;
+  margin: 0;
+  padding: 0;
+  height: 20px;
+  width: 99%;
+}
+.grid td select {
+  font-family: Arial, Helvetica, sans-serif;
+  font-size: 13px;
+  padding: 4px 4px 5px;
+  text-align: left;
+}
+.grid .action-select {
+  background: #fff;
+  border: 1px solid #ccc;
+  margin: 0;
+}
+.grid .filter .range .range-line {
+  margin-bottom: 3px;
+}
+.grid .filter .range div.date {
+  min-width: 121px;
+}
+.grid .filter .range .date input {
+  margin-top: 0;
+  vertical-align: middle;
+  width: 80%;
+}
+.grid .filter .range select {
+  margin: 0;
+  color: #676056;
+  font-size: 11px;
+  font-weight: 400;
+  color: #bcb795;
+}
+.grid .filter .date {
+  position: relative;
+}
+.grid .filter .date img {
+  width: 15px;
+  height: 15px;
+  cursor: pointer;
+  vertical-align: middle;
+  margin-left: 5px;
+  position: relative;
+  z-index: 2;
+  opacity: 0;
+}
+.grid .filter .date:before {
+  position: absolute;
+  left: 80%;
+  top: 1px;
+  margin-left: 5px;
+  text-shadow: none;
+  width: 16px;
+  height: 16px;
+  line-height: 16px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 16px;
+  content: '\e06a';
+  /* icon calendar  */
+
+  color: #cac3b4;
+  z-index: 1;
+}
+.grid .head-massaction select {
+  width: 50px;
+}
+/* Grid - Mass Action */
+.massaction {
+  color: #cac3b4;
+  padding: 7px 8px;
+  background: #666158;
+  box-shadow: 0 1px 2px 0 #504d46 inset, 0 -1px 2px 0 #504d46 inset;
+  overflow: hidden;
+}
+.massaction ul {
+  list-style: none;
+  margin: 0;
+  padding: 6px 0 0;
+}
+.massaction li {
+  display: inline-block;
+}
+.massaction li:before {
+  color: #837F79;
+  content: '|';
+  display: inline-block;
+  margin: 0 5px;
+}
+.massaction li:first-child:before {
+  display: none;
+}
+.massaction .entry-edit {
+  float: right;
+  display: inline-block;
+}
+.massaction .entry-edit fieldset {
+  margin: 0;
+  padding: 0;
+  background: none;
+  border: none;
+}
+.massaction .entry-edit fieldset select {
+  border-radius: 2px;
+  margin: 0;
+}
+.massaction .entry-edit fieldset select.validation-failed {
+  border: 1px dashed #eb340a;
+  background: #faebe7;
+}
+.massaction .entry-edit .field-row {
+  display: inline-block;
+  vertical-align: middle;
+}
+.massaction .entry-edit .outer-span .entry-edit {
+  float: none;
+}
+.massaction .entry-edit .field-row label {
+  color: #cac3b4;
+  line-height: 26px;
+  margin: 0 5px 0 20px;
+  padding: 0;
+  vertical-align: middle;
+  width: auto;
+  float: none;
+}
+.massaction .entry-edit .validation-advice {
+  display: none !important;
+}
+.massaction a {
+  color: #e7e2d7;
+  text-decoration: none;
+}
+.massaction a:hover {
+  color: #fff;
+}
+/* Grid Footer */
+.grid table tfoot tr {
+  background: #656156;
+}
+.grid table tfoot tr th,
+.grid table tfoot tr td {
+  border-right: 1px solid #837f79;
+  line-height: 1.7em;
+  padding: 3px 10px;
+}
+.grid table tfoot tr th:first-child,
+.grid table tfoot tr td:first-child {
+  border-left: 1px solid #837f79;
+}
+.grid table.border tfoot tr td {
+  background: #656156;
+}
+.grid .col-price,
+.grid .col-number {
+  text-align: right;
+}
+/* Dynamic Grid */
+/* Used in pages like Catalog -> Attributes */
+.dynamic-grid th {
+  padding: 2px;
+  width: 100px;
+}
+.dynamic-grid td {
+  padding: 2px;
+}
+.dynamic-grid td input {
+  width: 94px;
+}
+tr.dynamic-grid td,
+tr.dynamic-grid th {
+  padding: 2px 10px 2px 0;
+  width: auto;
+}
+tr.dynamic-grid input.input-text {
+  width: 154px;
+}
+.available {
+  color: #080;
+  font-weight: bold;
+}
+.not-available {
+  color: #800;
+}
+.categories-side-col {
+  padding: 0 3%;
+}
+/*
+    TODO: change ids to 'table.data' after refactoring of all templates for grids
+    Manage Products Grid
+-------------------------------------- */
+#cross_sell_product_grid table.data,
+#up_sell_product_grid table.data,
+#related_product_grid table.data,
+#productGrid_table,
+#setGrid_table,
+#attributeGrid_table,
+.custom-options .data-table,
+.ui-dialog .data {
+  word-wrap: break-word;
+  table-layout: fixed;
+}
+#cross_sell_product_grid table.data th,
+#up_sell_product_grid table.data th,
+#related_product_grid table.data th,
+#productGrid_table th,
+#setGrid_table th,
+#attributeGrid_table th,
+.custom-options .data-table th,
+.ui-dialog .data th {
+  word-wrap: normal;
+  overflow: hidden;
+  vertical-align: top;
+}
+#cross_sell_product_grid table.data th > span,
+#up_sell_product_grid table.data th > span,
+#related_product_grid table.data th > span,
+#productGrid_table th > span,
+#customerGrid_table th > span,
+#setGrid_table th > span,
+#attributeGrid_table th > span,
+.custom-options .data-table th > span,
+.ui-dialog .data th > span {
+  white-space: normal;
+}
+table .col-draggable .draggable-handle {
+  position: relative;
+  top: 0;
+  float: left;
+}
+.grid table .col-id {
+  text-align: left;
+}
+/*
+    Data table
+-------------------------------------- */
+.data-table {
+  border-collapse: separate;
+  /* do not remove this! without this rule in FF when table has only 1 row bottom and side borders disappear*/
+
+  width: 100%;
+}
+.data-table thead,
+.data-table tfoot,
+.data-table th,
+.accordion .config .data-table thead th,
+.accordion .config .data-table tfoot td {
+  background: #fff;
+  color: #676056;
+  font-size: 13px;
+  font-weight: 600;
+}
+.data-table th {
+  border-color: #c9c2b8;
+  border-width: 0 0 1px;
+  padding: 7px;
+}
+.data-table td,
+.data-table tbody tr td,
+.accordion .config .data-table td {
+  background: #fff;
+  padding: 5px 7px;
+  color: #676056;
+  font-size: 14px;
+  font-weight: 400;
+  vertical-align: middle;
+  border: solid #eae8e4;
+  border-width: 0 0 1px;
+}
+.data-table tbody tr.selected td,
+.data-table tbody tr.selected th,
+.data-table tbody tr:hover td,
+.data-table tbody tr:hover th {
+  background: #fff;
+}
+.data-table tbody tr:nth-child(odd) td,
+.data-table tbody tr:nth-child(odd):hover td,
+.accordion .config .data-table tbody tr:nth-child(odd) td {
+  background: #fbfaf6;
+}
+.data-table tbody tr.odd td {
+  background: #fbfaf6;
+}
+.data-table tfoot tr:last-child td,
+.data-table tfoot tr:last-child th,
+.accordion .config .data-table tfoot tr:last-child td {
+  border: 0;
+}
+.data-table input[type="text"] {
+  width: 98%;
+  padding-left: 1%;
+  padding-right: 1%;
+}
+.data-table select {
+  margin: 0;
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+  border-radius: 4px;
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.data-table th.required-entry:after,
+.data-table td.required-entry:after {
+  content: '*';
+  color: red;
+}
+.data-table .col-actions .actions-split {
+  margin-top: 4px;
+}
+.data-table .col-actions .actions-split [class^='action-'] {
+  background: none;
+  border: 1px solid #c8c3b5;
+  padding: 3px 5px;
+  color: #bbb3a6;
+  font-size: 12px;
+}
+.data-table .col-actions .actions-split [class^='action-']:first-child {
+  border-right: 0;
+}
+.data-table .col-actions .actions-split .dropdown-menu {
+  margin-top: -1px;
+}
+.data-table .col-actions .actions-split .dropdown-menu a {
+  display: block;
+  color: #333;
+  text-decoration: none;
+}
+.data-table .col-actions .actions-split.active .action-toggle {
+  position: relative;
+  border-bottom-right-radius: 0;
+  box-shadow: none;
+  background: #fff;
+}
+.data-table .col-actions .actions-split.active .action-toggle:after {
+  position: absolute;
+  top: 100%;
+  left: 0;
+  right: 0;
+  height: 2px;
+  margin-top: -1px;
+  background: #fff;
+  content: '';
+  z-index: 2;
+}
+.data-table .col-actions .actions-split.active .dropdown-menu {
+  border-top-right-radius: 0;
+}
+/*
+    Data table - alternative view
+-------------------------------------- */
+.customer-information .data-table,
+.order-information .data-table,
+.order-account-information .data-table,
+.adminhtml-rma-new .data-table {
+  width: 100%;
+}
+.customer-information .data-table tbody tr th,
+.order-information .data-table tbody tr th,
+.order-account-information .data-table tbody tr th,
+.adminhtml-rma-new .data-table tbody tr th,
+.adminhtml-logging-details .log-details .data-table th,
+[class^=" sales-transactions-"] .data-table tbody tr th,
+[class^=" sales-"] .order-payment-method .data-table tbody tr th,
+[class^=" sales-billing-agreement-"] .log-details .data-table tbody tr th {
+  font-weight: bold;
+}
+.customer-information .data-table tbody tr td,
+.customer-information .data-table tbody tr th,
+.order-information .data-table tbody tr td,
+.order-information .data-table tbody tr th,
+.order-account-information .data-table tbody tr td,
+.order-account-information .data-table tbody tr th,
+.adminhtml-logging-details .log-details .data-table td,
+.adminhtml-logging-details .log-details .data-table th,
+[class^=" adminhtml-rma-"] .data-table tbody tr td,
+[class^=" adminhtml-rma-"] .data-table tbody tr th,
+[class^=" sales-transactions-"] .data-table tbody tr th,
+[class^=" sales-transactions-"] .data-table tbody tr td,
+[class^=" sales-"] .order-payment-method .data-table tbody tr th,
+[class^=" sales-"] .order-payment-method .data-table tbody tr td,
+[class^=" sales-billing-agreement-"] .log-details .data-table tbody tr th,
+[class^=" sales-billing-agreement-"] .log-details .data-table tbody tr td {
+  background-color: #fff;
+  border: 0;
+  padding: 9px 10px 10px;
+  color: #666;
+  vertical-align: top;
+}
+.customer-information .data-table tbody tr:nth-child(2n+1) td,
+.customer-information .data-table tbody tr:nth-child(2n+1) th,
+.order-information .data-table tbody tr:nth-child(2n+1) td,
+.order-information .data-table tbody tr:nth-child(2n+1) th,
+.order-account-information .data-table tbody tr:nth-child(2n+1) td,
+.order-account-information .data-table tbody tr:nth-child(2n+1) th,
+.adminhtml-logging-details .log-details .data-table tr:nth-child(odd) td,
+.adminhtml-logging-details .log-details .data-table tr:nth-child(odd) th,
+[class^=" adminhtml-rma-"] .data-table tbody tr:nth-child(2n+1) td,
+[class^=" adminhtml-rma-"] .data-table tbody tr:nth-child(2n+1) th,
+[class^=" sales-transactions-"] .data-table tbody tr:nth-child(2n+1) th,
+[class^=" sales-transactions-"] .data-table tbody tr:nth-child(2n+1) td,
+[class^=" sales-"] .order-payment-method .data-table tbody tr:nth-child(2n+1) th,
+[class^=" sales-"] .order-payment-method .data-table tbody tr:nth-child(2n+1) td,
+[class^=" sales-billing-agreement-"] .log-details .data-table tbody tr:nth-child(2n+1) th,
+[class^=" sales-billing-agreement-"] .log-details .data-table tbody tr:nth-child(2n+1) td {
+  background-color: #fbfaf6;
+}
+/*
+    Content alignments in tables
+-------------------------------------- */
+/* left */
+.col-website,
+.col-name,
+.col-sku,
+.col-color,
+.col-size,
+.col-product,
+.col-comment,
+.col-actions,
+.col-status {
+  text-align: left;
+}
+/* center */
+.col-include,
+.col-display,
+.col-image,
+.col-no-records,
+.col-select,
+.col-default,
+.col-uqty {
+  text-align: center;
+}
+/* right */
+.col-qty,
+.col-weight,
+.col-price,
+.col-price > input,
+.col-id,
+.col-total,
+.col-average {
+  text-align: right;
+}
+/*
+    Attribute Information
+-------------------------------------- */
+.data-table .col-default {
+  white-space: nowrap;
+  text-align: center;
+  vertical-align: middle;
+}
+.data-table .col-delete {
+  text-align: center;
+  width: 32px;
+}
+.data-table .col-file {
+  white-space: nowrap;
+}
+.data-table .col-file input {
+  margin: 0 5px;
+  width: 40%;
+}
+.data-table .col-file input:first-child {
+  margin-left: 0;
+}
+/*
+    Website store views tree
+-------------------------------------- */
+.store-tree .website-name {
+  font-size: 14px;
+  font-weight: bold;
+}
+.store-tree .webiste-groups {
+  margin: 5px 0 20px 18px;
+}
+.store-tree .webiste-groups dt {
+  font-weight: bold;
+}
+.store-tree .webiste-groups dd {
+  margin: 5px 0 15px 15px;
+}
+.store-tree .webiste-groups dd > ul {
+  list-style: none;
+  margin: 0;
+  padding: 0;
+}
+.store-tree .webiste-groups dd > ul > li {
+  margin: 0 0 5px;
+}
+/*
+    Customer Reviews
+-------------------------------------- */
+.field-detailed_rating .control-value {
+  padding: 0;
+}
+.field-detailed_rating .nested {
+  padding: 0;
+}
+.field-detailed_rating .field-rating {
+  margin: 15px 0 0 0;
+}
+.field-detailed_rating .field-rating:first-child {
+  margin-top: 0;
+}
+.field-detailed_rating .field-rating .label {
+  width: 75px;
+}
+.field-detailed_rating .field-rating .control {
+  unicode-bidi: bidi-override;
+  direction: rtl;
+  width: 125px;
+}
+.field-detailed_rating input[type="radio"] {
+  display: none;
+}
+.field-detailed_rating .field-rating .control label {
+  color: #ccc;
+  cursor: pointer;
+  font-size: 18px;
+  float: right;
+  overflow: hidden;
+  white-space: nowrap;
+  width: 18px;
+  -webkit-transition: color 150ms linear;
+  -moz-transition: color 150ms linear;
+  -o-transition: color 150ms linear;
+  -ms-transition: color 150ms linear;
+  transition: color 150ms linear;
+}
+/*
+    Tree Store Scope
+-------------------------------------- */
+.tree-store-scope .buttons-set {
+  margin-bottom: 9px;
+}
+.tree-store-scope .buttons-set button {
+  margin-right: 4px;
+}
+.tree-store-scope .field {
+  margin: 0 0 5px;
+}
+.tree-store-scope [class^="field field-website_"] .label,
+.tree-store-scope [class^="field field-group_"] .label,
+.tree-store-scope [class^="field field-w_"] .label,
+.tree-store-scope [class^="field field-sg_"] .label {
+  text-align: left;
+  font-size: 18px;
+  padding-right: 0;
+  width: auto;
+}
+.tree-store-scope [class^="field field-group_"] .label,
+.tree-store-scope [class^="field field-sg_"] .label {
+  padding-left: 20px;
+}
+.tree-store-scope .field input[type="checkbox"] {
+  margin-right: 3px;
+  position: relative;
+  top: 2px;
+}
+.tree-store-scope .field .addafter {
+  display: inline-block;
+  padding-top: 6px;
+}
+.tree-store-scope .tooltip .help {
+  margin-top: 11px;
+}
+/*
+    Product Massaction page
+    TODO: css code below should be removed after element.html refactoring
+-------------------------------------- */
+.attributes-edit-form .attribute-change-checkbox {
+  white-space: nowrap;
+  display: block;
+}
+.attributes-edit-form .attribute-change-checkbox > label > input {
+  width: auto;
+}
+.attributes-edit-form .field:last-child,
+.attributes-edit-form .field-name,
+.attributes-edit-form .field.type-price,
+.attributes-edit-form .field-price,
+.attributes-edit-form .field-special_price,
+.attributes-edit-form .field-meta_title,
+.attributes-edit-form .field-visibility,
+.attributes-edit-form .field-custom_design,
+.attributes-edit-form .field-page_layout,
+.attributes-edit-form .field-options_container,
+.attributes-edit-form .field-country_of_manufacture,
+.attributes-edit-form .field-msrp_display_actual_price_type,
+.attributes-edit-form .field-tax_class_id,
+.attributes-edit-form .field-is_returnable,
+.attributes-edit-form .field-msrp,
+.attributes-edit-form .field-gift_wrapping_price {
+  margin-bottom: 50px;
+}
+.attributes-edit-form .field .control {
+  position: relative;
+}
+.attributes-edit-form .field-name .attribute-change-checkbox,
+.attributes-edit-form .field-meta_title .attribute-change-checkbox,
+.attributes-edit-form .field-gift_wrapping_price .attribute-change-checkbox,
+.attributes-edit-form .field .control select + .addafter {
+  position: absolute;
+  left: 0;
+  top: 35px;
+}
+.attributes-edit-form .field.type-price .attribute-change-checkbox,
+.attributes-edit-form .field-price .attribute-change-checkbox,
+.attributes-edit-form .field-special_price .attribute-change-checkbox,
+.attributes-edit-form .field-msrp .attribute-change-checkbox {
+  position: absolute;
+  top: 35px;
+}
+.attributes-edit-form .field-special_from_date > .control .input-text,
+.attributes-edit-form .field-special_to_date > .control .input-text,
+.attributes-edit-form .field-news_from_date > .control .input-text,
+.attributes-edit-form .field-news_to_date > .control .input-text,
+.attributes-edit-form .field-custom_design_from > .control .input-text,
+.attributes-edit-form .field-custom_design_to > .control .input-text {
+  border-width: 1px;
+  border-radius: 4px;
+  width: 130px;
+}
+.attributes-edit-form .field-special_from_date .attribute-change-checkbox,
+.attributes-edit-form .field-special_to_date .attribute-change-checkbox,
+.attributes-edit-form .field-news_from_date .attribute-change-checkbox,
+.attributes-edit-form .field-news_to_date .attribute-change-checkbox,
+.attributes-edit-form .field-custom_design_from .attribute-change-checkbox,
+.attributes-edit-form .field-custom_design_to .attribute-change-checkbox {
+  margin-top: 5px;
+}
+.attributes-edit-form .field-weight .fields-group-2 .control {
+  width: 160px;
+}
+.attributes-edit-form .field-weight .fields-group-2 .control > input {
+  width: 130px;
+  float: left;
+}
+.attributes-edit-form .field-weight .fields-group-2 .control > input + .addafter {
+  position: absolute;
+  top: 35px;
+}
+.attributes-edit-form .field-weight .fields-group-2 .control .addafter strong {
+  line-height: 26px;
+}
+.attributes-edit-form .field .control select {
+  border-radius: 4px;
+}
+.attributes-edit-form .field-gift_message_available .addon > .select,
+.attributes-edit-form .field-gift_wrapping_available .addon > .select {
+  margin-bottom: 25px;
+}
+.attributes-edit-form .field-gift_message_available .addon > input[type="checkbox"],
+.attributes-edit-form .field-gift_wrapping_available .addon > input[type="checkbox"] {
+  width: auto;
+  margin-right: 5px;
+}
+/*
+    Widgets
+-------------------------------------- */
+.widget-layout-updates .fieldset-wrapper,
+.widget-layout-updates .data-table {
+  margin: 0 0 18px;
+}
+.widget-layout-updates .fieldset-wrapper-title label {
+  padding: 10px 0 0;
+}
+.widget-layout-updates .fieldset-wrapper-title select {
+  margin: 3px 10px 5px;
+}
+.widget-layout-updates .fieldset-wrapper-title span,
+.widget-layout-updates .fieldset-wrapper-title select {
+  vertical-align: middle;
+}
+.widget-layout-updates .data-table {
+  table-layout: fixed;
+}
+.widget-layout-updates .data-table,
+.widget-layout-updates .data-table tr:nth-child(odd) td,
+.widget-layout-updates .data-table tr:nth-child(odd):hover td {
+  background: none;
+  border: none;
+}
+.widget-layout-updates .data-table th,
+.widget-layout-updates .data-table tbody td {
+  border: none;
+  padding: 5px 10px;
+  vertical-align: top;
+}
+.widget-layout-updates .data-table select {
+  margin: 0;
+  max-width: 99%;
+  overflow: hidden;
+}
+.widget-layout-updates .chooser_container {
+  padding: 0 10px;
+  margin-bottom: 18px;
+}
+.widget-layout-updates .chooser_container p {
+  margin: 0 0 18px;
+}
+.widget-layout-updates .chooser_container p img,
+.widget-layout-updates .chooser_container p input {
+  vertical-align: middle;
+}
+/*
+    Preview window
+-------------------------------------- */
+.preview-window {
+  background: #fff;
+}
+.preview-window .toolbar {
+  background: #f5f2ed;
+  padding: 20px;
+}
+.preview-window .toolbar .switcher {
+  margin: 0;
+}
+.preview-window .toolbar .switcher span {
+  background: none;
+  width: auto;
+}
+/*
+    Global 'No Products found' block
+-------------------------------------- */
+.no-products-message {
+  background: #fbfaf6;
+  padding: 12px;
+  text-align: center;
+  font-size: 12px;
+  color: #666;
+  margin-bottom: 13px;
+}
+/*
+    WYSIWYG
+-------------------------------------- */
+.action-wysiwyg {
+  margin: 10px 0;
+}
+#catalog-wysiwyg-editor .buttons-set {
+  margin-bottom: 9px;
+}
+#catalog-wysiwyg-editor .buttons-set button {
+  margin-right: 4px;
+}
+/*
+    System Messages
+-------------------------------------- */
+.message-system {
+  min-width: 960px;
+  max-width: 1300px;
+  margin: 0 auto;
+  overflow: hidden;
+}
+.message-system-inner {
+  background: #f7f3eb;
+  border: 1px solid #c0bbaf;
+  border-top: 0;
+  border-radius: 0 0 5px 5px;
+  float: right;
+  overflow: hidden;
+}
+.message-system-unread .message-system-inner {
+  float: none;
+}
+.message-system-list {
+  margin: 0;
+  padding: 0;
+  list-style: none;
+  float: left;
+}
+.message-system .message-system-list {
+  width: 75%;
+}
+.message-system-list li {
+  padding: 5px 13px 7px 36px;
+  position: relative;
+}
+.message-system-short {
+  padding: 5px 13px 7px;
+  float: right;
+}
+.message-system-short span {
+  display: inline-block;
+  margin-left: 7px;
+  border-left: 1px #d1ccc3 solid;
+}
+.message-system-short span:first-child {
+  border: 0;
+  margin-left: 0;
+}
+.message-system-short a {
+  padding-left: 27px;
+  position: relative;
+  height: 16px;
+}
+.message-system .message-system-short a:before,
+.message-system-list li:before {
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  height: 16px;
+  width: 16px;
+  font-size: 16px;
+  line-height: 16px;
+  text-align: center;
+  position: absolute;
+  left: 7px;
+  top: 2px;
+}
+.message-system-list li:before {
+  top: 5px;
+  left: 13px;
+}
+.message-system .message-system-short .warning a:before,
+.message-system-list li.warning:before {
+  content: "\e006";
+  color: #f2a825;
+}
+.message-system .message-system-short .error a:before,
+.message-system-list li.error:before {
+  content: "\e086";
+  font-family: 'MUI-Icons';
+  color: #c00815;
+}
+.ui-dialog .message-system-list {
+  margin-bottom: 25px;
+}
+/*
+    Add Attribute Popup
+-------------------------------------- */
+#create_new_attribute {
+  overflow: hidden;
+}
+#create_new_attribute > .loading-mask {
+  left: -25px;
+  top: -50px;
+}
+.attribute-popup {
+  background: none;
+}
+.attribute-popup #edit_form > .fieldset > .legend {
+  display: none;
+}
+.attribute-popup .wrapper-popup {
+  padding: 0;
+  height: 511px;
+  overflow-x: hidden;
+  overflow-y: auto;
+}
+.attribute-popup .fieldset,
+.attribute-popup .fieldset-wrapper {
+  border: none;
+  border-radius: 0;
+  padding: 4px 0 20px;
+  margin: 0 23px 20px;
+}
+.attribute-popup .fieldset-wrapper {
+  border-top: none;
+}
+.attribute-popup .fieldset-wrapper .fieldset-wrapper-title {
+  border-bottom: none;
+}
+.attribute-popup .fieldset-wrapper .fieldset-wrapper-content > .fieldset {
+  margin-left: 0;
+  margin-right: 0;
+}
+.attribute-popup .fieldset > .field > input[type="checkbox"] {
+  margin-top: 7px;
+}
+.attribute-popup .fieldset .label {
+  width: 35%;
+}
+.attribute-popup .collapsable-wrapper,
+#manage-titles-wrapper .fieldset-wrapper-title {
+  margin-bottom: 0;
+  padding-bottom: 0;
+}
+.attribute-popup .collapsable-wrapper .fieldset-wrapper-title > .title:before {
+  color: #797269;
+  font-size: 14px;
+  top: 9px;
+}
+.attribute-popup form .entry-edit:first-child .fieldset {
+  border-bottom: 1px solid #dfdcd7;
+}
+.attribute-popup .fieldset .legend {
+  border: none;
+}
+.attribute-popup .page-actions {
+  position: fixed;
+  top: auto !important;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  background: #fff;
+  padding: 27px 50px 25px 23px;
+  border-top: 1px solid #dfdcd7;
+}
+.attribute-popup .page-actions [class^='action-'] {
+  margin-left: 18px;
+}
+.attribute-popup #base_fieldset {
+  padding-top: 20px;
+}
+.attribute-popup #base_fieldset > .legend {
+  display: none;
+}
+.attribute-popup .page-actions #reset,
+.attribute-popup .page-actions #reset:hover,
+.attribute-popup .page-actions #reset:active,
+.attribute-popup .page-actions #reset:focus {
+  float: right;
+  vertical-align: middle;
+  margin: 5px 0 0 18px;
+}
+.attribute-popup .page-actions-placeholder {
+  display: none;
+}
+.attribute-popup .page-actions.fixed .page-actions-inner {
+  background: #fff;
+  padding: 0;
+  min-width: 100%;
+  max-width: 100%;
+  min-height: 100%;
+  margin: 0;
+}
+.attribute-popup .footer {
+  display: none;
+}
+#manage-options-panel > .data-table {
+  clear: both;
+}
+.CustomGridView .col-1-layout,
+.sales-order-index .col-1-layout,
+.adminhtml-rma-index .col-1-layout,
+.adminhtml-catalog-event-index .col-1-layout,
+.adminhtml-urlrewrite-index .col-1-layout,
+.catalog-search-index .col-1-layout,
+.catalog-product-review-index .col-1-layout,
+.catalog-rule-promo-catalog-index .col-1-layout,
+.sales-rule-promo-quote-index .col-1-layout,
+.adminhtml-reminder-index .col-1-layout,
+.newsletter-template-index .col-1-layout,
+.adminhtml-system-email-template-index .col-1-layout,
+.adminhtml-sitemap-index .col-1-layout,
+.adminhtml-googleshopping-types-index .col-1-layout,
+.customer-index-index .col-1-layout,
+.adminhtml-cms-page-index .col-1-layout,
+.cms-block-index .col-1-layout,
+.adminhtml-banner-index .col-1-layout,
+.adminhtml-widget-instance-index .col-1-layout,
+.cms-page-index .col-1-layout,
+.adminhtml-webapi-user-index .col-1-layout,
+.adminhtml-webapi-role-index .col-1-layout,
+.adminhtml-system-variable-index .col-1-layout,
+.adminhtml-user-index .col-1-layout,
+.adminhtml-user-role-index .col-1-layout,
+.adminhtml-integration-index .col-1-layout,
+.adminhtml-system-design-theme-index .col-1-layout,
+.adminhtml-system-design-index .col-1-layout,
+.adminhtml-customer-attribute-index .col-1-layout,
+.adminhtml-customer-address-attribute-index .col-1-layout,
+.rating-index-index .col-1-layout,
+.tax-rule-index .col-1-layout,
+.tax-rate-index .col-1-layout,
+.adminhtml-rma-item-attribute-index .col-1-layout,
+.adminhtml-reward-rate-index .col-1-layout,
+.customer-group-index .col-1-layout,
+.checkout-agreement-index .col-1-layout,
+.catalog-product-attribute-index .col-1-layout,
+.catalog-product-set-index .col-1-layout,
+.catalog-product-index .col-1-layout,
+.sales-invoice-index .col-1-layout,
+.sales-shipment-index .col-1-layout,
+.sales-creditmemo-index .col-1-layout,
+.sales-billing-agreement-index .col-1-layout,
+.sales-transactions-index .col-1-layout,
+.sales-recurring-profile-index .col-1-layout,
+.adminhtml-googleshopping-items-index .col-1-layout,
+.customer-online-index .col-1-layout,
+.newsletter-queue-index .col-1-layout,
+.newsletter-subscriber-index .col-1-layout,
+.adminhtml-report-shopcart-product .col-1-layout,
+.adminhtml-report-shopcart-abandoned .adminhtml-report-product-downloads .col-1-layout,
+.adminhtml-report-product-sold .col-1-layout,
+.adminhtml-report-product-lowstock .col-1-layout,
+.adminhtml-report-customer-accounts .col-1-layout,
+.adminhtml-report-customer-totals .col-1-layout,
+.adminhtml-report-customer-orders .col-1-layout,
+.adminhtml-report-customer-wishlist-wishlist .col-1-layout,
+.adminhtml-report-review-customer .col-1-layout,
+.adminhtml-report-review-product .col-1-layout,
+.adminhtml-report-search .col-1-layout,
+.adminhtml-report-statistics-index .col-1-layout,
+.newsletter-problem-index .col-1-layout,
+.adminhtml-system-store-index .col-1-layout,
+.sales-order-status-index .col-1-layout,
+.adminhtml-system-currency-index .col-1-layout,
+.adminhtml-system-currencysymbol-index .col-1-layout,
+.adminhtml-scheduled-operation-index .col-1-layout,
+.adminhtml-cache-index .col-1-layout,
+.adminhtml-system-backup-index .col-1-layout,
+.adminhtml-locks-index .col-1-layout,
+.adminhtml-notification-index .col-1-layout,
+.adminhtml-logging-archive .col-1-layout,
+.adminhtml-logging-index .col-1-layout,
+.adminhtml-process-list .col-1-layout,
+.catalog-product-index .col-1-layout {
+  padding: 0;
+  background: transparent;
+  border: 0;
+  border-radius: 0;
+  max-width: 1300px;
+  min-width: 960px;
+}
+.CustomGridAction .grid-actions,
+.sales-order-index .grid-actions,
+.adminhtml-rma-index .grid-actions,
+.adminhtml-catalog-event-index .grid-actions,
+.adminhtml-urlrewrite-index .grid-actions,
+.catalog-search-index .grid-actions,
+.catalog-product-review-index .grid-actions,
+.catalog-rule-promo-catalog-index .grid-actions,
+.sales-rule-promo-quote-index .grid-actions,
+.adminhtml-reminder-index .grid-actions,
+.newsletter-template-index .grid-actions,
+.adminhtml-system-email-template-index .grid-actions,
+.adminhtml-sitemap-index .grid-actions,
+.adminhtml-googleshopping-types-index .grid-actions,
+.customer-index-index .grid-actions,
+.adminhtml-cms-page-index .grid-actions,
+.cms-block-index .grid-actions,
+.adminhtml-banner-index .grid-actions,
+.adminhtml-widget-instance-index .grid-actions,
+.cms-page-index .grid-actions,
+.adminhtml-webapi-user-index .grid-actions,
+.adminhtml-webapi-role-index .grid-actions,
+.adminhtml-system-variable-index .grid-actions,
+.adminhtml-user-index .grid-actions,
+.adminhtml-user-role-index .grid-actions,
+.adminhtml-integration-index .grid-actions,
+.adminhtml-system-design-theme-index .grid-actions,
+.adminhtml-system-design-index .grid-actions,
+.adminhtml-customer-attribute-index .grid-actions,
+.adminhtml-customer-address-attribute-index .grid-actions,
+.rating-index-index .grid-actions,
+.tax-rule-index .grid-actions,
+.tax-rate-index .grid-actions,
+.adminhtml-rma-item-attribute-index .grid-actions,
+.adminhtml-reward-rate-index .grid-actions,
+.customer-group-index .grid-actions,
+.checkout-agreement-index .grid-actions,
+.catalog-product-attribute-index .grid-actions,
+.catalog-product-set-index .grid-actions,
+.catalog-product-index .grid-actions {
+  border-radius: 5px 5px 0 0;
+  margin-top: 20px;
+  padding: 9px 16px 9px 65px;
+}
+.CustomGridAction .page-actions.fixed,
+.sales-order-index .page-actions.fixed,
+.adminhtml-rma-index .page-actions.fixed,
+.adminhtml-catalog-event-index .page-actions.fixed,
+.adminhtml-urlrewrite-index .page-actions.fixed,
+.catalog-search-index .page-actions.fixed,
+.catalog-product-review-index .page-actions.fixed,
+.catalog-rule-promo-catalog-index .page-actions.fixed,
+.sales-rule-promo-quote-index .page-actions.fixed,
+.adminhtml-reminder-index .page-actions.fixed,
+.newsletter-template-index .page-actions.fixed,
+.adminhtml-system-email-template-index .page-actions.fixed,
+.adminhtml-sitemap-index .page-actions.fixed,
+.adminhtml-googleshopping-types-index .page-actions.fixed,
+.customer-index-index .page-actions.fixed,
+.adminhtml-cms-page-index .page-actions.fixed,
+.cms-block-index .page-actions.fixed,
+.adminhtml-banner-index .page-actions.fixed,
+.adminhtml-widget-instance-index .page-actions.fixed,
+.cms-page-index .page-actions.fixed,
+.adminhtml-webapi-user-index .page-actions.fixed,
+.adminhtml-webapi-role-index .page-actions.fixed,
+.adminhtml-system-variable-index .page-actions.fixed,
+.adminhtml-user-index .page-actions.fixed,
+.adminhtml-user-role-index .page-actions.fixed,
+.adminhtml-integration-index .page-actions.fixed,
+.adminhtml-system-design-theme-index .page-actions.fixed,
+.adminhtml-system-design-index .page-actions.fixed,
+.adminhtml-customer-attribute-index .page-actions.fixed,
+.adminhtml-customer-address-attribute-index .page-actions.fixed,
+.rating-index-index .page-actions.fixed,
+.tax-rule-index .page-actions.fixed,
+.tax-rate-index .page-actions.fixed,
+.adminhtml-rma-item-attribute-index .page-actions.fixed,
+.adminhtml-reward-rate-index .page-actions.fixed,
+.customer-group-index .page-actions.fixed,
+.checkout-agreement-index .page-actions.fixed,
+.catalog-product-attribute-index .page-actions.fixed,
+.catalog-product-set-index .page-actions.fixed,
+.catalog-product-index .page-actions.fixed {
+  left: 0;
+  margin: 0;
+  padding: 0 21px;
+  position: fixed;
+}
+.CustomGridAction .page-actions,
+.sales-order-index .page-actions,
+.adminhtml-rma-index .page-actions,
+.adminhtml-catalog-event-index .page-actions,
+.adminhtml-urlrewrite-index .page-actions,
+.catalog-search-index .page-actions,
+.catalog-product-review-index .page-actions,
+.catalog-rule-promo-catalog-index .page-actions,
+.sales-rule-promo-quote-index .page-actions,
+.adminhtml-reminder-index .page-actions,
+.newsletter-template-index .page-actions,
+.adminhtml-system-email-template-index .page-actions,
+.adminhtml-sitemap-index .page-actions,
+.adminhtml-googleshopping-types-index .page-actions,
+.customer-index-index .page-actions,
+.adminhtml-cms-page-index .page-actions,
+.cms-block-index .page-actions,
+.adminhtml-banner-index .page-actions,
+.adminhtml-widget-instance-index .page-actions,
+.cms-page-index .page-actions,
+.adminhtml-webapi-user-index .page-actions,
+.adminhtml-webapi-role-index .page-actions,
+.adminhtml-system-variable-index .page-actions,
+.adminhtml-user-index .page-actions,
+.adminhtml-user-role-index .page-actions,
+.adminhtml-integration-index .page-actions,
+.adminhtml-system-design-theme-index .page-actions,
+.adminhtml-system-design-index .page-actions,
+.adminhtml-customer-attribute-index .page-actions,
+.adminhtml-customer-address-attribute-index .page-actions,
+.rating-index-index .page-actions,
+.tax-rule-index .page-actions,
+.tax-rate-index .page-actions,
+.adminhtml-rma-item-attribute-index .page-actions,
+.adminhtml-reward-rate-index .page-actions,
+.customer-group-index .page-actions,
+.checkout-agreement-index .page-actions,
+.catalog-product-attribute-index .page-actions,
+.catalog-product-set-index .page-actions,
+.catalog-product-index .page-actions {
+  position: absolute;
+  z-index: 2;
+  margin-top: 10px;
+  margin-left: 15px;
+  padding: 0;
+}
+.adminhtml-googleshopping-items-index .grid-title,
+.adminhtml-system-backup-index .page-actions,
+.adminhtml-scheduled-operation-index .page-actions,
+.adminhtml-system-currency-index .page-actions,
+.adminhtml-system-currencysymbol-index .page-actions,
+.adminhtml-cache-index .page-actions,
+.adminhtml-system-store-index .page-actions,
+.sales-order-status-index .page-actions {
+  border: 1px solid #c0bbaf;
+  border-bottom: 0;
+  background: #f6f3ec;
+  background: url();
+  background: -moz-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f6f3ec), color-stop(100%, #edeae1));
+  background: -webkit-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -o-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -ms-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: linear-gradient(to bottom, #f6f3ec 0%, #edeae1 100%);
+  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f6f3ec', endColorstr='#edeae1', GradientType=0);
+  padding: 7px 8px 8px;
+  position: relative;
+  float: none;
+}
+.adminhtml-googleshopping-items-index .grid {
+  padding-bottom: 25px;
+}
+.adminhtml-googleshopping-items-index .grid-title .title {
+  font-size: 18px;
+}
+.adminhtml-googleshopping-items-index .page-actions {
+  float: right;
+}
+.adminhtml-system-backup-index .page-actions.fixed,
+.adminhtml-scheduled-operation-index .page-actions.fixed,
+.adminhtml-system-currency-index .page-actions.fixed,
+.adminhtml-system-currencysymbol-index .page-actions.fixed,
+.adminhtml-cache-index .page-actions.fixed,
+.adminhtml-system-store-index .page-actions.fixed,
+.sales-order-status-index .page-actions.fixed {
+  background-image: none;
+  padding: 0 21px;
+  position: fixed;
+}
+.catalog-product-index .grid-actions {
+  padding-left: 90px;
+}
+.catalog-rule-promo-catalog-index .grid-actions {
+  padding-left: 210px;
+}
+.catalog-rule-promo-catalog-index .page-actions .apply {
+  float: right;
+  margin: 0 0 0 10px;
+}
+.catalog-product-index .field-store-switcher {
+  padding: 0;
+}
+.sidebar-actions {
+  padding: 14px 0;
+}
+.sidebar-actions button {
+  margin: 0 0 5px;
+}
+.sales-order-create-index .grid table .action-configure {
+  float: right;
+}
+.adminhtml-system-currency-index .import-service {
+  float: left;
+}
+.adminhtml-system-currency-index .page-actions.fixed .import-service {
+  display: inline-block;
+  float: none;
+}
+.fpt-item-container select {
+  width: 100%;
+}
+.fpt-item-container select:first-child {
+  margin-bottom: 8px;
+}
+.clearfix:before,
+.clearfix:after,
+[class$="-layout"]:after,
+.footer-content:before,
+.footer-content:after,
+.page-title-inner:before,
+.page-title-inner:after,
+.tabs-horiz:before,
+.tabs-horiz:after,
+.navigation > ul:before,
+.navigation > ul:after,
+.actions-split:before,
+.actions-split:after,
+.page-create-order:before,
+.page-create-order:after,
+.order-addresses:before,
+.order-addresses:after,
+.order-methods:before,
+.order-methods:after,
+.order-summary:before,
+.order-summary:after,
+.order-methods:before,
+.order-methods:after,
+.grid-actions:before,
+.grid-actions:after,
+.fieldset-wrapper-title:before,
+.fieldset-wrapper-title:after {
+  content: "";
+  display: table;
+}
+.clearfix:after,
+[class$="-layout"]:after,
+.footer-content:after,
+.page-title-inner:after,
+.tabs-horiz:after,
+.navigation > ul:after,
+.actions-split:after,
+.page-create-order:after,
+.order-addresses:after,
+.order-methods:after,
+.order-summary:after,
+.order-methods:after,
+.grid-actions:after,
+.fieldset-wrapper-title:after {
+  clear: both;
+}
diff --git a/app/design/adminhtml/magento_backend/css/header.css b/app/design/adminhtml/magento_backend/css/header.css
new file mode 100644
index 0000000000000000000000000000000000000000..7ea154188d004d2ee803c5958ce263aa34492802
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/css/header.css
@@ -0,0 +1,710 @@
+/**
+ * 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.
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
+/*
+    Header
+-------------------------------------- */
+.header {
+  position: relative;
+  background: #f5f2ea;
+  background: url();
+  background: -moz-linear-gradient(top, #f5f2ea 0%, #f1ede3 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f5f2ea), color-stop(100%, #f1ede3));
+  background: -webkit-linear-gradient(top, #f5f2ea 0%, #f1ede3 100%);
+  background: -o-linear-gradient(top, #f5f2ea 0%, #f1ede3 100%);
+  background: -ms-linear-gradient(top, #f5f2ea 0%, #f1ede3 100%);
+  background: linear-gradient(to bottom, #f5f2ea 0%, #f1ede3 100%);
+  z-index: 992;
+  padding: 0 20px;
+}
+.header-inner {
+  min-width: 960px;
+  max-width: 1300px;
+  margin: 0 auto;
+  padding: 7px 0;
+}
+.header .logo {
+  display: block;
+  width: 109px;
+  height: 27px;
+  text-indent: -999em;
+  background: url(Magento_Backend::images/logo-magento-small.png) no-repeat;
+  margin: 0;
+}
+.header-panel {
+  float: right;
+  font-size: 12px;
+}
+/*
+    Header Dropdown
+-------------------------------------- */
+.header-panel .dropdown-menu {
+  display: none;
+  width: 195px;
+  margin: 8px -87px 0 0;
+  border: 0;
+  -moz-border-radius: 5px;
+  -webkit-border-radius: 5px;
+  border-radius: 5px;
+  -moz-box-shadow: 0 2px 7px 2px rgba(0, 0, 0, 0.2);
+  -webkit-box-shadow: 0 2px 7px 2px rgba(0, 0, 0, 0.2);
+  box-shadow: 0 2px 7px 2px rgba(0, 0, 0, 0.2);
+}
+.header-panel .dropdown-menu > li {
+  position: relative;
+  padding: 20px 30px 13px 18px;
+  background: #f7f3eb;
+  border-bottom: 1px solid #f7e4d0;
+  white-space: normal;
+}
+.header-panel .dropdown-menu > li:hover {
+  background: #fff;
+}
+.header-panel .dropdown-menu > li:first-child:hover:before,
+.header-panel .dropdown-menu > li.first:hover:before {
+  color: #fff;
+}
+.header-panel .dropdown-menu > li a {
+  display: block;
+  text-decoration: none;
+  color: #8c867e;
+  margin: 0 0 10px;
+}
+.header-panel .dropdown-menu > li a:hover {
+  text-decoration: underline;
+}
+.header-panel .dropdown-menu > li:first-child,
+.header-panel .dropdown-menu > li.first {
+  -moz-border-radius: 5px 5px 0 0;
+  -webkit-border-radius: 5px 5px 0 0;
+  border-radius: 5px 5px 0 0;
+}
+.header-panel .dropdown-menu > li:last-child,
+.header-panel .dropdown-menu > li.last {
+  border-bottom: 0;
+  -moz-border-radius: 0 0 5px 5px;
+  -webkit-border-radius: 0 0 5px 5px;
+  border-radius: 0 0 5px 5px;
+}
+/*
+    Account
+-------------------------------------- */
+.header-panel .account {
+  position: relative;
+  float: left;
+  margin: 0 0 0 30px;
+  padding: 6px 0 0;
+}
+.header-panel .account > a {
+  color: #656057;
+  position: relative;
+  display: inline-block;
+  min-width: 20px;
+  text-decoration: none;
+  padding: 0 10px 0 0;
+}
+.header-panel .account > a:before {
+  position: absolute;
+  top: 2px;
+  right: 0;
+  bottom: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  font-size: 9px;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02c';
+  /*  icon point down */
+
+}
+.header-panel .account img {
+  position: relative;
+  border-radius: 3px;
+  z-index: 1;
+}
+.no-js .header-panel .account:hover > a {
+  padding-bottom: 5px;
+  margin-bottom: -5px;
+}
+.header-panel .account.active .dropdown-menu,
+.no-js .header-panel .account:hover .dropdown-menu,
+.no-js .header-panel .account > a:focus + .dropdown-menu {
+  display: block;
+}
+/*
+    Link to store front
+-------------------------------------- */
+.header-panel .store-front {
+  color: #676056;
+  text-decoration: none;
+  position: relative;
+  padding: 6px 0 0 20px;
+  float: left;
+  margin: 0 0 0 30px;
+}
+.header-panel .store-front:before {
+  font-family: 'admin-icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e005';
+  /* icon store info */
+
+  font-size: 17px;
+  position: absolute;
+  left: 0;
+  top: 4px;
+}
+/*
+    Messages
+-------------------------------------- */
+.header-panel .notifications {
+  position: relative;
+  float: left;
+  margin: 0 6px 0 21px;
+  padding: 9px 0 0;
+}
+.header-panel .notifications-icon {
+  position: relative;
+  display: inline-block;
+  height: 12px;
+  width: 17px;
+  text-decoration: none;
+  text-align: center;
+  background: #cac2b5;
+  box-shadow: 0 1px 0 #fff;
+  border-radius: 2px;
+}
+.header-panel .notifications-icon:hover,
+.header-panel .notifications-icon:active {
+  background: #b0a798;
+}
+.header-panel .notifications-icon:before {
+  position: absolute;
+  left: 0;
+  right: 0;
+  bottom: -7px;
+  margin-top: -5px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02c';
+  /* user icon */
+
+  font-size: 8px;
+  color: #cac2b5;
+  text-shadow: 0 1px 0 #fff;
+}
+.header-panel .notifications-icon:hover:before,
+.header-panel .notifications-icon:active:before {
+  color: #b0a798;
+}
+.header-panel .notifications .value {
+  color: #ffffff;
+  font-size: 12px;
+  font-weight: 600;
+  line-height: 11px;
+  padding: 1px 3px;
+  min-width: 10px;
+  background: #f58220;
+  border: 1px solid #bd5100;
+  border-radius: 4px;
+  box-shadow: 0 1px 0 #31302b;
+  left: 6px;
+  top: -5px;
+  position: absolute;
+}
+.header-panel .notifications.active .dropdown-menu {
+  display: block;
+  margin-top: 12px;
+  border: 2px solid #676056;
+  width: 288px;
+  margin: 8px -52px 0 0;
+}
+.header-panel .dropdown-menu > li {
+  background: #fff;
+  border-bottom: 0;
+  position: relative;
+  padding: 13px 26px 14px 16px;
+  white-space: normal;
+}
+.header-panel .dropdown-menu > li:after {
+  border-bottom: 1px solid #f7e4d0;
+  display: block;
+  position: absolute;
+  bottom: 0;
+  left: 2px;
+  content: '';
+  width: 284px;
+}
+.header-panel .dropdown-menu > li:last-child:after,
+.header-panel .dropdown-menu > li.last:after {
+  display: none;
+}
+.header-panel .notifications > .dropdown-menu .notification-description {
+  max-height: 43px;
+  overflow: hidden;
+  display: block;
+  color: #676056;
+  font-size: 11px;
+  font-weight: 400;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry {
+  display: none;
+}
+.header-panel .notifications .dropdown-menu:before,
+.header-panel .notifications .dropdown-menu:after {
+  position: absolute;
+  width: 10px;
+  height: 10px;
+  right: 55px;
+  top: -10px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  font-weight: normal;
+  font-size: 13px;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  content: '\e029';
+  /* user icon */
+
+  color: #fff;
+  z-index: 2;
+}
+.header-panel .notifications .dropdown-menu:after {
+  color: #676056;
+  font-size: 17px;
+  height: 12px;
+  right: 57px;
+  top: -14px;
+  z-index: 1;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:first-child {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:first-child + .notification-entry {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:first-child + .notification-entry + .notification-entry {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:first-child + .notification-entry + .notification-entry + .notification-entry {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:first-child + .notification-entry + .notification-entry + .notification-entry + .notification-entry {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry:nth-child(-n+5) {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .notification-entry .notification-dialog-content {
+  display: none;
+}
+/*
+    Notification entry dialog
+-------------------------------------- */
+.notification-entry-dialog .notification-dialog-content,
+.notification-entry-dialog .ui-dialog-buttonpane {
+  background: #fefaf6;
+}
+.notification-entry-dialog .ui-dialog-titlebar {
+  background: #f9f1e8;
+}
+.notification-entry-dialog .ui-dialog-title {
+  font-size: 22px;
+  padding-left: 24px;
+}
+.notification-entry-dialog-critical .ui-dialog-titlebar {
+  background: #fee4d0;
+}
+.notification-entry-dialog-critical .ui-dialog-title {
+  padding-left: 54px;
+}
+.notification-entry-dialog-critical .ui-dialog-title:before {
+  content: "\e086";
+  font-family: 'MUI-Icons';
+  color: #c00815;
+  font-style: normal;
+  font-weight: normal;
+  font-size: 26px;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  left: 21px;
+  position: absolute;
+  top: 16px;
+}
+.notification-entry-dialog .ui-dialog-titlebar-close:before {
+  font-size: 15px;
+}
+.notification-entry-dialog .notification-dialog-content {
+  padding-top: 19px;
+  padding-bottom: 16px;
+}
+.notification-entry-dialog .notification-dialog-content strong {
+  display: block;
+  color: #f58220;
+  font-size: 18px;
+  font-weight: 500;
+}
+.notification-entry-dialog .notification-dialog-content .notification-description {
+  display: block;
+  font-family: Helvetica, Arial, sans-serif;
+  font-size: 14px;
+  line-height: 1.42;
+  padding: 3px 0 7px;
+}
+.notification-entry-dialog .notification-dialog-content time {
+  color: #8c867e;
+  font-size: 13px;
+  font-family: Helvetica, Arial, sans-serif;
+  position: absolute;
+  right: 17px;
+  bottom: 27px;
+  text-align: right;
+}
+.notification-entry-dialog .notification-dialog-content .actions {
+  margin-bottom: 22px;
+}
+.notification-entry-dialog .notification-dialog-content .actions a {
+  color: #676056;
+  position: relative;
+  margin-right: 20px;
+}
+.notification-entry-dialog .notification-dialog-content .actions a:after {
+  content: "\e084";
+  font-family: 'MUI-Icons';
+  color: #6a5f54;
+  font-size: 12px;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  position: absolute;
+  right: -17px;
+  top: -2px;
+}
+.notification-entry-dialog .ui-dialog-buttonset {
+  text-align: left;
+}
+.notification-entry-dialog .ui-dialog-buttonpane {
+  margin: 0;
+  padding: 0 24px 22px;
+}
+.notification-entry-dialog .ui-dialog-buttonset button[class^="action-"] {
+  background-image: none;
+  margin: 0 16px 0 0;
+  vertical-align: middle;
+  text-shadow: none;
+  box-shadow: none;
+  border: 0;
+}
+.notification-entry-dialog .ui-dialog-buttonset .action-acknowledge {
+  background-color: #f47b20;
+  border: 0;
+  padding: 5px 15px;
+}
+.notification-entry-dialog .ui-dialog-buttonset .action-acknowledge:hover {
+  background-color: #e47821;
+}
+.notification-entry-dialog .ui-dialog-buttonset .action-cancel {
+  background-color: #dbd6ce;
+  border: 0;
+  padding: 5px 15px;
+}
+.notification-entry-dialog .ui-dialog-buttonset .action-cancel:hover {
+  background-color: #d3cdc4;
+}
+.header-panel .account > .dropdown-menu a,
+.header-panel .search .autocomplete-results .title {
+  display: block;
+  color: #f58220;
+  font-size: 14px;
+  font-weight: 500;
+  margin-bottom: 5px;
+}
+.header-panel .notifications > .dropdown-menu li > strong {
+  display: block;
+  color: #026294;
+  font-size: 12px;
+  font-weight: 600;
+  max-height: 32px;
+  overflow: hidden;
+  line-height: 1.4;
+  margin-bottom: 4px;
+}
+.header-panel .notifications > .dropdown-menu li > strong:focus,
+.header-panel .notifications > .dropdown-menu li > strong:hover {
+  text-decoration: underline;
+}
+.header-panel .notifications > .dropdown-menu li.notification-critical strong {
+  padding-left: 30px;
+  position: relative;
+}
+.header-panel .notifications > .dropdown-menu li.notification-critical > strong:before {
+  display: block;
+  content: "\e086";
+  font-family: 'MUI-Icons';
+  color: #c00815;
+  font-size: 19px;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  position: absolute;
+  left: 0;
+  top: 5px;
+}
+.header-panel .notifications > .dropdown-menu > li:hover {
+  background: #f7f3eb;
+  cursor: pointer;
+  margin-top: -1px;
+  padding-top: 14px;
+  z-index: 2;
+}
+.header-panel .notifications > .dropdown-menu > li:first-child:hover,
+.header-panel .notifications > .dropdown-menu > li.first:hover,
+.header-panel .notifications > .dropdown-menu > li:last-child:hover,
+.header-panel .notifications > .dropdown-menu > li.last:hover {
+  margin-top: 0;
+  padding-top: 13px;
+}
+.header-panel .dropdown-menu > li:hover:after {
+  display: none;
+}
+.header-panel .notifications > .dropdown-menu > li:hover .action-close {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu > .new,
+.header-panel .notifications > .dropdown-menu > .new:hover {
+  background: #f47b20;
+  color: #fff;
+}
+.header-panel .notifications > .dropdown-menu > li.new:first-child:before,
+.header-panel .notifications > .dropdown-menu > li.new.first:before,
+.header-panel .notifications > .dropdown-menu > li.new:first-child:hover:before,
+.header-panel .notifications > .dropdown-menu > li.new.first:hover:before {
+  color: #f47b20;
+}
+.header-panel .notifications > .dropdown-menu > .new strong,
+.header-panel .notifications > .dropdown-menu > .new div,
+.header-panel .notifications > .dropdown-menu > .new a,
+.header-panel .notifications > .dropdown-menu > .new time,
+.header-panel .notifications > .dropdown-menu .new .action-close:hover,
+.header-panel .notifications > .dropdown-menu .new .action-close:focus {
+  color: #fff;
+}
+.header-panel .notifications > .dropdown-menu time {
+  color: #676056;
+  font-size: 11px;
+  font-weight: 400;
+  display: block;
+  margin-top: 7px;
+}
+.header-panel .notifications > .dropdown-menu a:focus ~ .action-close,
+.header-panel .notifications > .dropdown-menu .action-close:focus {
+  display: block;
+}
+.header-panel .notifications > .dropdown-menu .action-close {
+  position: absolute;
+  display: none;
+  top: 8px;
+  right: 4px;
+  width: 20px;
+  height: 20px;
+  text-indent: -999em;
+  overflow: hidden;
+  color: #cac2b5;
+}
+.header-panel .notifications > .dropdown-menu .action-close:hover {
+  color: #b0a789;
+}
+.header-panel .notifications > .dropdown-menu .action-close:before {
+  display: block;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  font-weight: normal;
+  font-size: 19px;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  content: '\e07f';
+  /* trashbin icon */
+
+  text-indent: 0;
+}
+.header .header-panel .notifications .dropdown-menu > li.last {
+  padding: 0;
+}
+.header .header-panel .notifications .action-more {
+  display: block;
+  background: #676056;
+  border: 0;
+  color: #f7f3eb;
+  font-size: 13px;
+  font-weight: bold;
+  height: 23px;
+  width: 100%;
+  line-height: 23px;
+  text-shadow: none;
+  text-align: center;
+  margin: 0;
+}
+.header .header-panel .notifications .action-more:hover {
+  text-decoration: none;
+}
+/*
+    Help
+-------------------------------------- */
+.header-panel .help {
+  float: left;
+  margin: 0 0 0 30px;
+  padding: 6px 0 0;
+}
+/*
+    Search
+-------------------------------------- */
+.search {
+  position: relative;
+  float: left;
+  margin: -4px 0 -5px 50px;
+}
+.search form {
+  position: relative;
+}
+.search input {
+  position: relative;
+  display: none;
+  width: 50px;
+  height: 36px;
+  line-height: 2;
+  margin: 0;
+  padding: 4px 25px 4px 4px;
+  background: #fff;
+}
+.header .search .ajax-loading:before {
+  display: block;
+  content: '';
+  position: absolute;
+  top: 10px;
+  left: -20px;
+  margin: 0;
+  width: 16px;
+  height: 16px;
+  line-height: 16px;
+  background-image: url(../mui/images/ajax-loader-small.gif);
+}
+.header .search .mage-suggest {
+  border: none;
+}
+.header .search .mage-suggest::after {
+  content: '';
+}
+.search .dropdown-menu {
+  display: block;
+  right: auto;
+  margin-right: 0;
+  width: 100%;
+}
+.autocomplete-results {
+  left: 0 !important;
+  right: 0;
+}
+.autocomplete-results .title {
+  display: block;
+}
+.autocomplete-results .type {
+  margin: 0 0 10px;
+}
+.header.active .search {
+  margin-left: 30px;
+}
+.header.active .search input {
+  display: inline-block;
+}
+.no-js .search input {
+  display: inline-block;
+  width: 350px;
+}
+.search button[type="submit"],
+.search button[type="submit"]:hover,
+.search button[type="submit"]:active,
+.search button[type="submit"]:focus {
+  position: absolute;
+  top: 2px;
+  right: 0;
+  width: 32px;
+  height: 32px;
+  background: none;
+  border: none;
+  overflow: hidden;
+  text-indent: -999em;
+  color: #676056;
+  text-shadow: 0 1px 0 #fff;
+  box-shadow: none;
+  filter: none;
+}
+.search button[type="submit"]:hover,
+.header.active .search button[type="submit"],
+.header.active .search button[type="submit"]:hover,
+.header.active .search button[type="submit"]:active,
+.header.active .search button[type="submit"]:focus {
+  color: #201f1c;
+}
+.eq-ie9 .search button[type="submit"] {
+  top: 4px;
+}
+.search button[type="submit"]:before {
+  position: absolute;
+  display: block;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e01f';
+  /* user icon */
+
+  text-indent: 0;
+  font-size: 18px;
+  line-height: 1.7;
+  text-align: center;
+}
+/*
+    Clearfix
+-------------------------------------- */
+.header-panel:before,
+.header-panel:after,
+.header-inner:before,
+.header-inner:after,
+.clearfix:before,
+.clearfix:after {
+  content: "";
+  display: table;
+}
+.header-panel:after,
+.header-inner:after,
+.clearfix:after {
+  clear: both;
+}
diff --git a/app/design/adminhtml/magento_backend/css/pages.css b/app/design/adminhtml/magento_backend/css/pages.css
new file mode 100644
index 0000000000000000000000000000000000000000..ba9d1a2a10c5e6af0ece6aaefbd766dd0afd956f
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/css/pages.css
@@ -0,0 +1,3053 @@
+/**
+ * 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.
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
+/*
+    Product Creation
+-------------------------------------- */
+/* Action "Back" as cross  */
+[class^=" catalog-product-"] .page-actions .action-back,
+[class^=" catalog-product-"] .page-actions .action-back:hover,
+[class^=" catalog-product-"] .page-actions .action-back:active,
+[class^=" newsletter-"] .page-actions .action-back,
+[class^=" newsletter-"] .page-actions .action-back:hover,
+[class^=" newsletter-"] .page-actions .action-back:active {
+  overflow: hidden;
+  padding: 5px 6px 3px;
+  margin-left: 12px;
+  color: #7a7976;
+}
+.sales-order-create-index .page-actions-inner .cancel,
+.sales-order-create-index .page-actions-inner .cancel:hover,
+.sales-order-create-index .page-actions-inner .cancel:active {
+  filter: none;
+  border: 0;
+}
+[class^=" catalog-product-"] .page-actions .action-back:hover,
+[class^=" newsletter-"] .page-actions .action-back:hover,
+.sales-order-create-index .page-actions-inner .cancel:hover {
+  color: #000;
+}
+[class^=" catalog-product-"] .page-actions .action-back.mage-error,
+[class^=" newsletter-"] .page-actions .action-back.mage-error {
+  color: #b57c72;
+}
+[class^=" catalog-product-"] .page-actions .action-back:before,
+[class^=" newsletter-"] .page-actions .action-back:before,
+.sales-order-create-index .page-actions-inner .cancel:before {
+  display: inline-block;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e07d';
+  /* close icon */
+
+  font-size: 16px;
+}
+[class^=" catalog-product-"] .page-actions .action-back span,
+[class^=" newsletter-"] .page-actions .action-back span,
+.sales-order-create-index .page-actions-inner .cancel span {
+  display: inline-block;
+  overflow: hidden;
+  text-indent: -999em;
+}
+.page-actions .switcher {
+  display: inline-block;
+  vertical-align: top;
+  margin: 6px 17px 6px 6px;
+}
+.field-weight .control .field:first-child {
+  width: 36%;
+  margin-right: 15px;
+}
+#allow_open_amount {
+  margin-top: 8px;
+}
+.catalog-product-new .user-defined.type-select select,
+.catalog-product-edit .user-defined.type-select select {
+  width: 100%;
+}
+#tab_content_downloadableInfo .data-table td {
+  vertical-align: top;
+}
+#tab_content_downloadableInfo .data-table td .row {
+  margin-bottom: 10px;
+}
+/*
+    Customer
+---------------------------------------*/
+.customer-index-edit .grid tr.headings th > span {
+  white-space: normal;
+}
+#customer_info_tabs_account_content #_accountsendemail {
+  margin-top: 8px;
+}
+.customer-information:before,
+.customer-information:after {
+  content: "";
+  display: table;
+}
+.customer-information:after {
+  clear: both;
+}
+.customer-information .data-table,
+.customer-information address {
+  width: 48.5%;
+}
+.customer-information .data-table {
+  float: left;
+  width: 48.5%;
+}
+.customer-information address {
+  padding-top: 4px;
+  line-height: 2.2;
+  float: right;
+}
+.address-list {
+  list-style: none;
+  width: 278px;
+  margin: 0 0 10px;
+  padding: 0;
+  float: left;
+}
+.address-list li {
+  border: 1px solid #d9d2ca;
+  background: #f7f2ec;
+  padding: 10px 10px 15px;
+  cursor: pointer;
+  margin-bottom: -1px;
+}
+.address-list li.ui-state-active {
+  background: #fff;
+  position: relative;
+  box-shadow: 0 1px 1px 0 #d9d2ca;
+  margin-left: -2px;
+  padding-left: 12px;
+}
+.address-list li.ui-state-active:before,
+.address-list li.ui-state-active:after {
+  position: absolute;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  font-weight: normal;
+  font-size: 18px;
+  color: #fff;
+  content: "\e02a";
+  speak: none;
+  line-height: 11px;
+  width: 10px;
+  right: -9px;
+  text-indent: -6px;
+  top: 50%;
+  margin-top: -5px;
+  z-index: 2;
+}
+.address-list li.ui-state-active:before {
+  color: #d9d2ca;
+  right: -11px;
+  z-index: 1;
+}
+.address-list li.address-list-actions:before,
+.address-list li.address-list-actions:after {
+  display: none;
+}
+.address-list li.address-list-actions {
+  padding: 20px 0 0 0;
+  border: 0;
+  background: none;
+  box-shadow: none;
+  cursor: default;
+}
+.address-list li.address-list-actions:first-child {
+  padding: 0;
+}
+.address-list .label {
+  float: none;
+  width: auto;
+  padding: 0 0 0 10px;
+}
+.address-list input[type="checkbox"] {
+  float: left;
+}
+.address-list address:first-line {
+  /*  its not work  if First Name and Last Name in two lines */
+
+  font-weight: bold;
+}
+.address-list address {
+  margin: 0 20px 15px 0;
+  line-height: 1.5;
+}
+.address-list-item-actions {
+  float: right;
+}
+.address-list .action-edit {
+  display: none;
+}
+.address-list .field {
+  margin-bottom: 15px;
+}
+.ui-tabs-nav .address-list-item a {
+  text-decoration: none;
+  color: #676056;
+}
+.address-item-edit {
+  margin-left: 277px;
+}
+.address-item-edit-content {
+  border: 1px solid #dad1c8;
+  background: #fff;
+  box-shadow: 0 2px 1px 0 rgba(217, 210, 202, 0.5);
+  padding-left: 10px;
+}
+.address-item-edit-content .fieldset:last-child {
+  margin-bottom: 29px;
+}
+.address-item-edit .legend {
+  border-bottom: 0;
+  margin: 0 0 18px;
+  padding-left: 20%;
+}
+.address-item-edit .legend span {
+  padding-left: 0;
+}
+.address-item-edit-actions {
+  padding: 0 0 18px 20%;
+}
+/*
+    Configuration -> Design
+-------------------------------------- */
+#row_design_theme_ua_regexp .design_theme_ua_regexp {
+  float: left;
+  width: 100%;
+}
+#row_design_theme_ua_regexp .tooltip {
+  margin-top: 8px;
+}
+#row_design_theme_ua_regexp .note {
+  clear: both;
+}
+/*
+    Configuration -> Payment Methods
+-------------------------------------- */
+.adminhtml-system-config-edit .payflow-settings-notice .important-label {
+  color: #e22626;
+  font-size: 14px;
+  font-weight: 700;
+}
+.adminhtml-system-config-edit .payflow-settings-notice ul.options-list strong {
+  color: #676056;
+  font-size: 14px;
+  font-weight: 700;
+}
+/*
+    CMS -> Banners
+-------------------------------------- */
+/* Banner Properties */
+#banner_properties_customer_segment_ids {
+  min-width: 20%;
+}
+/* Content */
+.field-store_default_content .buttons-set {
+  margin-bottom: 9px;
+}
+.field-store_default_content .buttons-set button {
+  margin-right: 4px;
+}
+.field-store_0_content_use input[type="checkbox"] {
+  margin-right: 3px;
+  position: relative;
+  top: 2px;
+}
+/*
+    CMS -> Manage Hierarchy
+-------------------------------------- */
+.cms-hierarchy .cms-scope {
+  float: right;
+  margin-right: 25px;
+  position: relative;
+  top: 2px;
+}
+.cms-hierarchy #tree-container {
+  margin-top: 25px;
+  overflow: auto;
+  padding-bottom: 10px;
+}
+.cms-hierarchy .buttons-set {
+  margin-bottom: 10px;
+}
+.cms-hierarchy .cms-hierarchy-tree {
+  width: 48.93617020799999%;
+  float: left;
+  margin: 10px 0 8px 0;
+}
+.cms-hierarchy .cms-hierarchy-node {
+  width: 48.93617020799999%;
+  float: left;
+  margin: 10px 0 8px 2.127659574%;
+}
+.cms-hierarchy #cms_page_grid_container {
+  clear: both;
+}
+.cms-hierarchy .store-switcher {
+  position: relative;
+  top: 10px;
+}
+.cms-hierarchy .store-switcher label {
+  margin-right: 8px;
+}
+.cms-hierarchy-node #node_properties_fieldset #node_preview {
+  position: relative;
+  top: 6px;
+}
+.cms-hierarchy-node .form-inline .label {
+  width: 30%;
+}
+/*
+    CMS -> Widgets
+-------------------------------------- */
+#widget_instace_tabs_properties_section_content .widget-option-label {
+  margin-top: 6px;
+}
+/*
+    CMS -> Static Blocks
+-------------------------------------- */
+#buttonsblock_content.buttons-set {
+  margin-bottom: 9px;
+}
+#buttonsblock_content.buttons-set button {
+  margin-right: 4px;
+}
+/*
+    CMS -> Manage Content
+-------------------------------------- */
+/* Content */
+.cms-manage-content-actions .buttons-set {
+  margin-bottom: 9px;
+}
+.cms-manage-content-actions .buttons-set button {
+  margin-right: 4px;
+}
+.cms-manage-content-actions textarea {
+  width: 100%;
+}
+/*
+    System -> Action Log -> Report
+-------------------------------------- */
+.adminhtml-logging-details .log-details-grid table th {
+  border: 1px solid #c9c2b8;
+  border-width: 0 0 1px;
+  padding: 6px 10px 7px;
+  background: #fff;
+  color: #676056;
+  font-size: 13px;
+  font-weight: 600;
+}
+.adminhtml-logging-details .log-details-grid table th span {
+  border: 0;
+  padding: 0;
+}
+.adminhtml-logging-details .log-details-grid table td {
+  border: none;
+  padding: 6px 10px 7px;
+  background: #fff;
+}
+.adminhtml-logging-details .log-details-grid table tr:last-child td {
+  border: 1px solid #eae8e4;
+  border-width: 0 0 1px;
+}
+.adminhtml-logging-details .log-details-grid table tr.on-mouse {
+  cursor: inherit;
+}
+.adminhtml-logging-details .log-details-grid table tr:nth-child(odd) td,
+.adminhtml-logging-details .log-details-grid table tr.on-mouse:nth-child(odd):hover td {
+  background: #fbfaf6;
+}
+/*
+    System -> Export
+-------------------------------------- */
+#export_filter_grid .grid td .input-text-range-date {
+  vertical-align: middle;
+}
+#export_filter_grid .grid td .ui-datepicker-trigger {
+  vertical-align: middle;
+  margin-left: 5px;
+}
+#export_filter_grid .grid select {
+  margin-bottom: 0;
+  width: 86%;
+}
+#export_filter_grid .grid table td:first-child,
+#export_filter_grid .grid tr th:first-child {
+  border-left: 0;
+}
+#export_filter_grid .data thead {
+  border-left: 1px solid #837F79;
+}
+#export_filter_grid .data tbody {
+  border-left: 1px solid #c0bbaf;
+}
+/*
+    System -> Roles
+-------------------------------------- */
+#gws_container ul {
+  padding: 0;
+  margin: 0;
+  list-style: none;
+}
+#gws_container ul ul {
+  margin: .8em 0 .8em 1.4em;
+}
+#gws_container input[type="checkbox"] {
+  margin-right: 3px;
+  position: relative;
+  top: -1px;
+}
+/*
+    Reports
+-------------------------------------- */
+.reports-title .page-actions {
+  float: right;
+}
+.reports-title .store-switcher {
+  padding: 14px 0 18px;
+}
+.reports-content select {
+  width: 160px;
+}
+.reports-content input.hasDatepicker {
+  width: 133px;
+}
+/* TODO: refactor when validation design is ready */
+.reports-content .required .control {
+  position: relative;
+}
+.reports-content input.hasDatepicker + label.mage-error {
+  left: 0;
+  position: absolute;
+  top: 30px;
+}
+.reports-title:before,
+.reports-title:after {
+  content: "";
+  display: table;
+}
+.reports-title:after {
+  clear: both;
+}
+/*
+    Reports - Customer Reviews
+-------------------------------------- */
+.reports-report-review-customer .col-qty,
+.reports-report-review-customer .col-actions {
+  width: 85px;
+}
+/*
+    Reports - Product Reviews
+-------------------------------------- */
+.reports-report-review-product .col-id {
+  width: 35px;
+}
+.reports-report-review-product .col-qty,
+.reports-report-review-product .col-rating,
+.reports-report-review-product .col-avg-rating,
+.reports-report-review-product .col-actions {
+  text-align: right;
+  width: 85px;
+}
+.reports-report-review-product .col-date {
+  width: 140px;
+}
+.reports-report-review-product .col-rating {
+  width: 104px;
+}
+/*
+    Reports - New Accounts
+-------------------------------------- */
+.reports-report-customer-accounts .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+/*
+    Reports - Refresh Statistics
+-------------------------------------- */
+.reports-report-statistics-index .col-period {
+  white-space: nowrap;
+  width: 140px;
+}
+.reports-report-statistics-index .col-select {
+  width: 25px;
+}
+/*
+    Reports - Products Ordered
+-------------------------------------- */
+.reports-report-product-sold .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-product-sold .col-qty {
+  width: 110px;
+}
+/*
+    Reports - Customers by Orders Total
+-------------------------------------- */
+.reports-report-customer-totals .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-customer-totals .col-qty {
+  width: 65px;
+}
+.reports-report-customer-totals .col-rating {
+  width: 100px;
+}
+/*
+    Reports - Tag by popular
+-------------------------------------- */
+.reports-report-tag-popular .col-qty,
+.reports-report-tag-popular .col-actions {
+  width: 80px;
+}
+/*
+    Reports - Tag by customer
+-------------------------------------- */
+.reports-report-tag-customer .col-id {
+  width: 35px;
+}
+.reports-report-tag-customer .col-qty,
+.reports-report-tag-customer .col-actions {
+  width: 80px;
+}
+/*
+    Reports - Tag by product
+-------------------------------------- */
+.reports-report-tag-product .col-id {
+  width: 35px;
+}
+.reports-report-tag-product .col-actions {
+  width: 70px;
+}
+.reports-report-tag-product .col-unique-numbers,
+.reports-report-tag-product .col-total-numbers {
+  text-align: right;
+  width: 95px;
+}
+/*
+    Reports - Customers by Number of Orders
+-------------------------------------- */
+.reports-report-customer-orders .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-customer-orders .col-qty,
+.reports-report-customer-orders .col-average,
+.reports-report-customer-orders .col-total {
+  width: 105px;
+}
+/*
+   Reports - Customers by Orders Total
+-------------------------------------- */
+.reports-report-customer-totals .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-customer-totals .col-qty,
+.reports-report-customer-totals .col-average,
+.reports-report-customer-totals .col-total {
+  width: 105px;
+}
+/*
+    Reports - Customer's wishlists
+-------------------------------------- */
+.adminhtml-report-customer-wishlist-wishlist .col-period {
+  width: 70px;
+}
+.adminhtml-report-customer-wishlist-wishlist .col-whishlist-qty,
+.adminhtml-report-customer-wishlist-wishlist .col-available-qty,
+.adminhtml-report-customer-wishlist-wishlist .col-qty-diff {
+  text-align: right;
+  width: 100px;
+}
+.adminhtml-report-customer-wishlist-wishlist .grid .range {
+  text-align: left;
+}
+/*
+    Reports - Most Viewed
+-------------------------------------- */
+.reports-report-product-viewed .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-product-viewed .col-qty,
+.reports-report-product-viewed .col-price {
+  white-space: nowrap;
+  width: 80px;
+}
+/*
+    Reports - Search Terms
+-------------------------------------- */
+.reports-index-search .col-id {
+  width: 35px;
+}
+.reports-index-search th.col-results,
+.reports-index-search th.col-hits {
+  text-align: left;
+  width: 117px;
+}
+.reports-index-search td.col-results,
+.reports-index-search td.col-hits {
+  text-align: right;
+  width: 117px;
+}
+.reports-index-search .col-results .range-line:first-child,
+.reports-index-search .col-hits .range-line:first-child {
+  float: left;
+  margin-right: 3px;
+}
+/*
+    Reports - Bestsellers
+-------------------------------------- */
+.reports-report-sales-bestsellers .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-bestsellers .col-qty,
+.reports-report-sales-bestsellers .col-price {
+  width: 80px;
+}
+/*
+    Reports - Downloads
+-------------------------------------- */
+.reports-report-product-downloads .col-qty,
+.reports-report-product-downloads .col-price {
+  width: 80px;
+}
+/*
+    Reports - Abandoned Carts
+-------------------------------------- */
+.reports-report-shopcart-abandoned .col-ip,
+.reports-report-shopcart-abandoned .col-subtotal,
+.reports-report-shopcart-abandoned .col-number,
+.reports-report-shopcart-abandoned .col-coupon {
+  text-align: right;
+}
+.reports-report-shopcart-abandoned .col-ip {
+  width: 105px;
+}
+.reports-report-shopcart-abandoned .col-subtotal {
+  width: 65px;
+}
+/*
+    Reports - Products in Carts
+-------------------------------------- */
+.reports-report-shopcart-product .col-id {
+  width: 35px;
+}
+.reports-report-shopcart-product .col-carts,
+.reports-report-shopcart-product .col-qty,
+.reports-report-shopcart-product .col-price {
+  text-align: right;
+  width: 80px;
+}
+/*
+    Reports - Refunds
+-------------------------------------- */
+.reports-report-sales-refunded .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-refunded .col-ref-total,
+.reports-report-sales-refunded .col-ref-online,
+.reports-report-sales-refunded .col-ref-offline {
+  text-align: right;
+  width: 23%;
+}
+/*
+    Reports - Shipping
+-------------------------------------- */
+.reports-report-sales-shipping .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-shipping .col-qty,
+.reports-report-sales-shipping .col-total-sales-shipping,
+.reports-report-sales-shipping .col-total-shipping {
+  text-align: right;
+  width: 115px;
+}
+/*
+    Reports - Invoiced
+-------------------------------------- */
+.reports-report-sales-invoiced .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-invoiced .col-qty,
+.reports-report-sales-invoiced .col-invoiced,
+.reports-report-sales-invoiced .col-total-invoiced,
+.reports-report-sales-invoiced .col-total-invoiced-paid,
+.reports-report-sales-invoiced .col-total-invoiced-not-paid {
+  text-align: right;
+  width: 19%;
+}
+/*
+    Reports - Tax
+-------------------------------------- */
+.reports-report-sales-tax .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-tax .col-rate,
+.reports-report-sales-tax .col-qty,
+.reports-report-sales-tax .col-tax-amount {
+  text-align: right;
+  width: 105px;
+}
+/*
+    Reports - Orders
+-------------------------------------- */
+.reports-report-sales-sales .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-sales .col-orders,
+.reports-report-sales-sales .col-sales-items,
+.reports-report-sales-sales .col-sales-total,
+.reports-report-sales-sales .col-invoiced,
+.reports-report-sales-sales .col-refunded,
+.reports-report-sales-sales .col-sales-tax,
+.reports-report-sales-sales .col-sales-shipping,
+.reports-report-sales-sales .col-sales-discount,
+.reports-report-sales-sales .col-canceled {
+  text-align: right;
+  width: 10.5%;
+}
+/*
+    Reports - Coupons
+-------------------------------------- */
+/* TODO: re-check styles for coupons table after coupons functionality will have been repaired */
+.reports-report-sales-coupons .col-period {
+  white-space: nowrap;
+  width: 70px;
+}
+.reports-report-sales-coupons .col-sales,
+.reports-report-sales-coupons .col-users,
+.reports-report-sales-coupons .col-sales-discount,
+.reports-report-sales-coupons .col-total-amount,
+.reports-report-sales-coupons .col-subtotal,
+.reports-report-sales-coupons .col-discount,
+.reports-report-sales-coupons .col-total {
+  text-align: right;
+}
+/*
+    Reports - Low Stock
+-------------------------------------- */
+.reports-report-product-lowstock .col-qty {
+  width: 10%;
+}
+.reports-report-product-lowstock .range-line {
+  display: inline-block;
+}
+.reports-report-product-lowstock .col-product {
+  width: 65%;
+}
+.reports-report-product-lowstock .col-sku {
+  width: 25%;
+}
+/*
+    Reports - PayPal Settlement Reports
+-------------------------------------- */
+.adminhtml-paypal-reports-index .grid tr.headings th > span {
+  white-space: normal;
+}
+.adminhtml-paypal-reports-index .col-transaction_event_code {
+  max-width: 150px;
+}
+.adminhtml-paypal-reports-index .col-amount,
+.adminhtml-paypal-reports-index .col-fee-amount {
+  text-align: right;
+}
+/*
+    Newsletter
+-------------------------------------- */
+[class^=" newsletter-"] .page-actions .action-back {
+  float: right;
+}
+/*
+    Newsletter Templates
+-------------------------------------- */
+.newsletter-template-index .col-id {
+  width: 35px;
+}
+.newsletter-template-index .col-actions {
+  width: 80px;
+}
+.newsletter-template-index .col-type {
+  width: 100px;
+}
+.newsletter-template-index .col-added,
+.newsletter-template-index .col-updated {
+  width: 140px;
+}
+[class^=' newsletter-'] .buttons-set {
+  margin: 0 0 15px;
+}
+[class^=" newsletter-"] .buttons-set button {
+  margin-right: 4px;
+}
+/*
+    Newsletter - Queue
+-------------------------------------- */
+.newsletter-queue-index .col-id {
+  width: 35px;
+}
+.newsletter-queue-index .col-finish,
+.newsletter-queue-index .col-start {
+  width: 130px;
+}
+.newsletter-queue-index .col-status,
+.newsletter-queue-index .col-processed,
+.newsletter-queue-index .col-recipients {
+  white-space: nowrap;
+  width: 85px;
+}
+.newsletter-queue-index td.col-processed,
+.newsletter-queue-index td.col-recipients {
+  text-align: right;
+}
+.newsletter-queue-index .col-actions {
+  width: 80px;
+}
+/*
+    Newsletter - Subscribers
+-------------------------------------- */
+.newsletter-subscriber-index .col-id {
+  width: 35px;
+}
+.newsletter-subscriber-index .col-type {
+  width: 75px;
+}
+.newsletter-subscriber-index .col-status {
+  white-space: nowrap;
+  width: 85px;
+}
+/*
+    Newsletter - Problems
+-------------------------------------- */
+.newsletter-problem-index .col-select {
+  width: 25px;
+}
+.newsletter-problem-index .col-id {
+  width: 35px;
+}
+.newsletter-problem-index .col-start {
+  width: 130px;
+}
+.newsletter-problem-index .col-error-code {
+  width: 150px;
+}
+.table-fieldset-alt,
+.type-options {
+  margin-bottom: 20px;
+}
+.table-fieldset-alt thead th,
+.table-fieldset-alt tbody tr td {
+  border-width: 0;
+}
+.table-fieldset-alt tbody tr:nth-child(odd) td,
+.table-fieldset-alt tbody tr:nth-child(odd):hover td {
+  background: #fff;
+}
+/*
+    System - Tax
+--------------------------------------*/
+.tax-rate-popup .ui-dialog-content.ui-widget-content {
+  padding: 10px 10px 0;
+}
+.tax-rate-popup .fieldset {
+  margin: 0;
+}
+.tax-rate-popup .field {
+  margin-bottom: 20px;
+}
+.tax-rate-popup .field .label {
+  margin: 5px 0 0 0;
+  width: 26%;
+  padding: 0 20px 0 0;
+  float: left;
+  text-align: right;
+  box-sizing: content-box;
+  -webkit-box-sizing: content-box;
+  -moz-box-sizing: content-box;
+  -ms-box-sizing: content-box;
+}
+.tax-rate-popup .field .control {
+  width: 58%;
+  margin: 0;
+  float: left;
+}
+.tax-rate-popup .field .control select,
+.tax-rate-popup .field .control .input-text {
+  width: 100%;
+}
+.tax-rate-popup .field-rate .control .input-text {
+  width: 50%;
+}
+.tax-rate-popup .field-rate label.mage-error {
+  display: block;
+}
+.tax-rate-popup .tax-rate-titles-note-td {
+  margin-left: 26%;
+  padding-left: 20px;
+}
+.field-tax_rate,
+.field-tax_customer_class,
+.field-tax_product_class {
+  position: relative;
+}
+.mselect-hidden + .mage-error {
+  position: absolute;
+  top: 100%;
+}
+/*
+    Tags
+-------------------------------------- */
+.tag-title {
+  overflow: hidden;
+}
+.tag-title .page-actions {
+  float: right;
+}
+/*
+    Attribute Mapping
+-------------------------------------- */
+.field-attributes_box .control-value {
+  width: 100%;
+}
+.adminhtml-googleshopping-types-new #attribute_set {
+  padding: 0;
+}
+.adminhtml-googleshopping-types-new #gcontent_attributes_container {
+  margin-top: -6px;
+}
+/*
+    Dashboard
+-------------------------------------- */
+.adminhtml-dashboard-index .col-2-left-layout,
+.adminhtml-dashboard-index .col-1-layout {
+  min-width: 0;
+}
+.adminhtml-dashboard-index .side-col {
+  width: 38%;
+  padding: 1%;
+}
+.adminhtml-dashboard-index .side-col .entry-edit {
+  padding: 10px 15px 10px 10px;
+  margin-bottom: 5px;
+}
+.adminhtml-dashboard-index .side-col .entry-edit .entry-edit-head {
+  margin-bottom: 20px;
+}
+.adminhtml-dashboard-index .side-col .entry-edit .entry-edit-head h4 {
+  margin: 0;
+}
+.adminhtml-dashboard-index .side-col .entry-edit fieldset {
+  padding: 0;
+  border: 0;
+}
+.adminhtml-dashboard-index .side-col .entry-edit fieldset .grid {
+  padding-bottom: 0;
+}
+.adminhtml-dashboard-index .col-2-left-layout .main-col {
+  min-width: 0;
+  width: 60%;
+  padding: 16px 30px 30px;
+}
+.adminhtml-dashboard-index .col-2-left-layout .main-col .store-switcher-alt {
+  margin-bottom: 15px;
+}
+.adminhtml-dashboard-index .col-2-left-layout .main-col .store-switcher-alt > strong {
+  padding-left: 0;
+}
+.dashboard-container {
+  border-radius: 0;
+}
+.dashboard-container.col-2-left-layout:before {
+  left: 40%;
+}
+.dashboard-inner .tabs-horiz > li a {
+  padding-left: 14px;
+  padding-right: 14px;
+}
+.dashboard-container #diagram_tab_content {
+  background: #fff;
+  border: 1px solid #eae6e0;
+  border-radius: 5px;
+  border-top-left-radius: 0;
+  margin: 0 0 20px;
+  padding: 18px;
+  position: relative;
+}
+.dashboard-container .dashboard-diagram .store-switcher + div {
+  /* loader under a diagram */
+
+  background: url(../mui/images/ajax-loader-small.gif) no-repeat 50% 50%;
+  min-height: 75px;
+  text-align: center;
+}
+.dashboard-container .dashboard-diagram .store-switcher + div img {
+  max-width: 100%;
+}
+.dashboard-container .dashboard-diagram .store-switcher + div.dashboard-diagram-nodata {
+  /* when there is no data to display the diagram */
+
+  background-image: none;
+  min-height: 15px;
+}
+.dashboard-container #grid_tab_content {
+  background: #ffffff url(../mui/images/ajax-loader-small.gif) no-repeat 50% 50%;
+  border: 1px solid #eae6e0;
+  border-radius: 5px;
+  border-top-left-radius: 0;
+  min-height: 50px;
+}
+.dashboard-container #grid_tab_content .grid {
+  padding: 0;
+}
+.dashboard-container .store-switcher {
+  margin: 20px 0 10px;
+}
+.dashboard-container .dashboard-diagram .store-switcher {
+  margin-top: 0;
+}
+.dashboard-diagram-nodata {
+  border: 1px solid #ccc;
+  padding: 20px 0;
+  text-align: center;
+}
+.action-switch-to-analytics:link,
+.action-switch-to-analytics:visited,
+.action-switch-to-hub:link,
+.action-switch-to-hub:visited {
+  font-weight: 400;
+  font-size: 16px;
+  color: #19a3d1;
+  position: relative;
+  padding: 0 0 0 20px;
+  margin: 11px 0 0 20px;
+  background: none;
+  box-shadow: none;
+}
+.action-switch-to-hub:before,
+.action-switch-to-analytics:before {
+  position: absolute;
+  width: 17px;
+  height: 12px;
+  background: url(../images/icons-dashboard-switcher.png) 0 0 no-repeat;
+  left: 0;
+  top: 4px;
+  content: '';
+}
+.action-switch-to-hub:before {
+  top: 2px;
+}
+.action-switch-to-analytics:before {
+  background-position: 0 -13px;
+}
+/*
+    Sales
+-------------------------------------- */
+#order-totals strong {
+  color: #676056;
+  font-size: 14px;
+  font-weight: 700;
+}
+#order-shipping-method-summary a {
+  color: #007dbd;
+  font-size: 14px;
+  font-weight: 400;
+}
+#order-shipping-method-summary a:focus,
+#order-shipping-method-summary a:hover {
+  text-decoration: underline;
+}
+.customer-current-activity {
+  float: left;
+  width: 22%;
+}
+.customer-current-activity-inner {
+  background: #fff;
+  border: 1px solid #eae6e0;
+  padding: 18px;
+  border-radius: 5px;
+}
+.order-details-existing-customer {
+  padding-left: 1%;
+  position: relative;
+  width: 77%;
+  float: right;
+}
+.order-billing-address,
+.order-billing-method,
+[class^=" sales-order-"] .order-history,
+[class^=" sales-order-"] .order-comments-history,
+[class^=" sales-order-"] .order-information,
+[class^=" sales-order-"] .order-billing-address,
+[class^=" sales-order-"] .order-payment-method,
+[class^=" adminhtml-rma-"] .order-comments-history,
+[class^=" adminhtml-rma-"] .order-shipping-address,
+[class^=" adminhtml-rma-"] .rma-request-details {
+  float: left;
+  width: 49.5%;
+}
+.order-shipping-address,
+.order-shipping-method,
+[class^=" sales-order-"] .order-totals,
+[class^=" sales-order-"] .order-account-information,
+[class^=" sales-order-"] .order-shipping-address,
+[class^=" sales-order-"] .order-payment-method-virtual,
+[class^=" sales-order-"] .order-shipping-method,
+[class^=" adminhtml-rma-"] .rma-confirmation,
+[class^=" adminhtml-rma-"] .order-shipping-method,
+[class^=" adminhtml-rma-"] .order-return-address {
+  float: right;
+  width: 49%;
+}
+#order-data .order-account-information {
+  float: none;
+  width: auto;
+}
+[class^=" sales-"] .order-information .fieldset-wrapper > .fieldset-wrapper-title .title {
+  width: 100%;
+}
+#order-data .actions .action-add,
+#order-data .actions .action-delete,
+#order-customer-selector .actions .action-add {
+  margin: 0 0 0 20px;
+}
+#order-data .order-methods ul {
+  list-style: none;
+  margin: 0;
+  padding: 0;
+}
+#order-data .order-methods dl,
+#order-data .order-methods dt,
+#order-data .order-methods dd,
+#order-data .payment-methods dl,
+#order-data .payment-methods dt,
+#order-data .payment-methods dd {
+  margin: 0;
+  padding: 0;
+}
+#order-data .order-methods dd + dt,
+#order-data .payment-methods dd + dt {
+  margin-top: 17px;
+}
+#order-data .order-methods dt,
+#order-data .payment-methods dt {
+  margin: 0 0 8px;
+}
+.order-coupons .box-left,
+.order-gift-options .box-left {
+  float: left;
+  width: 49%;
+}
+.order-coupons .box-right,
+.order-gift-options .box-right {
+  float: right;
+  width: 49%;
+}
+.order-gift-options .box-left:last-child,
+.order-gift-options .fieldset-wrapper-title + .box-right {
+  float: none;
+  width: auto;
+}
+.order-gift-options fieldset {
+  border-radius: 5px;
+}
+.order-gift-options .gift-wrapping-form select {
+  margin-left: 10px;
+}
+.order-gift-options .giftmessage-entire-order textarea {
+  height: 6em;
+  width: 100%;
+}
+.order-gift-options .giftmessage-whole-order-container textarea {
+  height: 6em;
+  width: 100%;
+}
+.order-gift-options .giftmessage-whole-order-container .actions {
+  margin-left: 20%;
+}
+.ui-dialog.gift-options-popup .ui-dialog-content {
+  padding: 25px;
+}
+.ui-dialog.gift-options-popup .ui-dialog-content h4 {
+  margin: 0 0 17px;
+}
+.gift-options-tooltip {
+  background: #fff;
+  border-radius: 5px;
+  padding: 10px;
+  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
+}
+#order-data .box-left fieldset,
+#order-data .box-right fieldset {
+  border-radius: 5px;
+}
+#order-data .order-items td[colspan="8"] {
+  border: 1px solid #c0bbaf;
+}
+.order-search-items thead th:nth-child(1) {
+  width: 60px;
+}
+.order-search-items thead th:nth-child(3) {
+  width: 80px;
+}
+.order-search-items thead th:nth-child(4) {
+  width: 100px;
+}
+.order-search-items thead th:nth-child(5) {
+  width: 55px;
+}
+.order-search-items thead th:nth-child(6) {
+  width: 1px;
+}
+.adminhtml-rma-new .order-totals,
+.order-comments-history .order-comments-history,
+[class^=" adminhtml-rma-"] .rma-comments-history {
+  float: none;
+  width: 100%;
+}
+[class^=" sales-order-"] .order-billing-address .actions,
+[class^=" sales-order-"] .order-shipping-address .actions {
+  margin: 17px 0;
+}
+[class^=" sales-order-"] .order-billing-address .control + label,
+[class^=" sales-order-"] .order-shipping-address .control + label {
+  margin: 17px 0 0;
+}
+.sales-order-create-index .page-actions-inner .cancel,
+.sales-order-create-index .page-actions-inner .cancel:hover,
+.sales-order-create-index .page-actions-inner .cancel:active {
+  float: right;
+  margin: 0 0 0 12px;
+  padding: 3px 0 3px 6px;
+}
+.sales-order-create-index #order-message ul.messages > li,
+.sales-order-edit-index #order-message ul.messages > li {
+  margin: 0 0 60px;
+}
+.sales-order-create-index thead .col-entity_id,
+.sales-order-create-index .col-entity_id,
+.sales-order-create-index .col-qty,
+.checkout-index-index .col-qty {
+  width: 50px;
+}
+.sales-order-create-index .col-in_products,
+.checkout-index-index .col-in_products {
+  text-align: center;
+}
+.sales-order-create-index .col-sku,
+.sales-order-create-index .col-remove,
+.checkout-index-index .col-remove {
+  width: 120px;
+}
+.sales-order-create-index .col-price {
+  width: 70px;
+}
+.sales-order-create-index .order-search-items .col-name,
+.checkout-index-index #source_products_table .col-name {
+  width: 50%;
+}
+.sales-order-create-index .order-items.fieldset-wrapper .fieldset-wrapper-title,
+.sales-order-create-index .order-search-items.fieldset-wrapper .fieldset-wrapper-title,
+.sales-order-create-index .order-additional-area.fieldset-wrapper .fieldset-wrapper-title,
+.sales-order-create-index .order-errors .fieldset-wrapper-title,
+.checkout-index-index .checkout-errors .fieldset-wrapper-title {
+  border-bottom: 0;
+  margin: 0;
+}
+.sales-order-create-index #order-data .fieldset-wrapper-title .actions .action-add {
+  margin-left: 0;
+  margin-right: 20px;
+}
+.sales-order-create-index .order-items.fieldset-wrapper .title,
+.sales-order-create-index .order-additional-area.fieldset-wrapper .title,
+.sales-order-create-index .order-search-items.fieldset-wrapper .title,
+.sales-order-create-index .order-errors .title,
+.checkout-index-index .checkout-errors .title {
+  border-bottom: 1px solid #ededed;
+  float: none;
+  margin: 0 0 18px;
+  width: 100%;
+}
+.sales-order-create-index .order-items.fieldset-wrapper .actions,
+.sales-order-create-index .order-search-items.fieldset-wrapper .actions,
+.sales-order-create-index #order-errors .actions,
+.checkout-index-index .checkout-errors .fieldset-wrapper-title .actions {
+  float: none;
+  border: 1px solid #c0bbaf;
+  border-bottom: 0;
+  background: #f6f3ec;
+  background: url();
+  background: -moz-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f6f3ec), color-stop(100%, #edeae1));
+  background: -webkit-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -o-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: -ms-linear-gradient(top, #f6f3ec 0%, #edeae1 100%);
+  background: linear-gradient(to bottom, #f6f3ec 0%, #edeae1 100%);
+  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f6f3ec', endColorstr='#edeae1', GradientType=0);
+  margin: 0;
+  padding: 0 8px;
+  position: relative;
+}
+.sales-order-create-index #order-data .fieldset-wrapper .actions .action-add,
+.checkout-index-index .checkout-errors .fieldset-wrapper-title .actions .action-add {
+  margin: 7px 8px 8px 0;
+}
+.sales-order-create-index .order-additional-area.fieldset-wrapper .actions {
+  float: none;
+  margin: 0 0 8px;
+  padding: 0;
+}
+.sales-order-create-index #order-data .fieldset-wrapper .actions .action-delete,
+.checkout-index-index .checkout-errors .fieldset-wrapper-title .actions .action-delete {
+  margin: 13px 0 0;
+}
+.sales-order-create-index .ui-dialog .downloadable.information .link .label {
+  margin-left: 0;
+}
+.sales-order-create-index .ui-dialog .downloadable.information .link .nested {
+  margin-left: 8px;
+}
+.sales-order-create-index .ui-dialog .fieldset.bundle .nested {
+  padding-left: 6px;
+}
+.sales-order-create-index .ui-dialog .fieldset.bundle .nested .field {
+  margin: 0 0 5px;
+}
+.sales-order-create-index .ui-dialog .fieldset.bundle .nested .label {
+  font-size: 13px;
+  margin: 0;
+}
+.sales-order-create-index .ui-dialog .fieldset.bundle .nested .qty .control {
+  display: inline-block;
+  margin: 0 0 0 10px;
+  width: 60px;
+}
+.sales-order-create-index .order-billing-method .payment-methods .fieldset {
+  padding: 0;
+  margin: 0;
+}
+.sales-order-create-index .order-billing-method .payment-methods .fieldset .field {
+  margin: 0 0 12px 0;
+}
+.tax.summary-total .summary-collapse {
+  cursor: pointer;
+  display: inline-block;
+}
+.tax.summary-total .summary-collapse:before {
+  content: "\e02d";
+  color: #816063;
+  background: #f2ebde;
+  display: inline-block;
+  text-indent: 0;
+  font-size: 16px;
+  width: 16px;
+  height: 16px;
+  line-height: 16px;
+  overflow: hidden;
+  font-family: 'MUI-Icons';
+  border: 1px solid #ada89e;
+  font-style: normal;
+  vertical-align: top;
+  margin-right: 7px;
+  font-weight: normal;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+  border-radius: 2px;
+}
+.tax.summary-total .summary-collapse:hover:before {
+  background: #cac3b4;
+}
+.tax.summary-total.show-details .summary-collapse:before {
+  content: "\e03a";
+}
+tr.row-totals:nth-child(even) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(even) td,
+tr.row-totals:nth-child(even) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(even) ~ tr.row-totals:nth-child(even) td,
+tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(odd) ~ tr.row-totals:nth-child(even) td {
+  background: #fbfaf6;
+}
+tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(odd) ~ tr.row-totals:nth-child(odd) td,
+tr.row-totals:nth-child(even) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(even) ~ tr.row-totals:nth-child(odd) td,
+tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-details):nth-child(odd) td {
+  background: #fff;
+}
+/* ----------------------------------- */
+#order-data .page-actions {
+  padding-top: 0;
+}
+#order-data .store-switcher {
+  margin: -46px 0 0;
+  position: relative;
+  width: 50%;
+}
+.create-order-sidebar-container > div + div {
+  border-top: 1px solid #ededed;
+  margin-top: 35px;
+}
+.create-order-sidebar-container > div .head h5 {
+  color: #676056;
+  font-size: 14px;
+  font-weight: 400;
+  margin: 17px 0 7px;
+}
+.customer-current-activity-inner > h4 {
+  color: #676056;
+  font-size: 20px;
+  font-weight: 400;
+  border-bottom: 1px solid #ededed;
+  margin-top: 0;
+  padding: 0 0 16px;
+}
+.customer-current-activity-inner .data-table th {
+  color: #676056;
+  font-size: 13px;
+  font-weight: 400;
+}
+.customer-current-activity-inner .data-table td {
+  color: #676056;
+  font-size: 12px;
+  font-weight: 400;
+}
+.customer-current-activity .action-refresh {
+  float: right;
+}
+.customer-current-activity .action-refresh,
+.customer-current-activity .data-table .icon {
+  display: inline-block;
+  text-indent: 100%;
+  overflow: hidden;
+  height: 16px;
+  width: 16px;
+  white-space: nowrap;
+}
+.customer-current-activity .action-refresh:before,
+.customer-current-activity .data-table .icon:before {
+  content: "\e010";
+  color: #c3c2be;
+  display: block;
+  text-indent: 0;
+  font-size: 16px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  font-weight: normal;
+  speak: none;
+  -webkit-font-smoothing: antialiased;
+}
+.customer-current-activity .data-table .icon-remove:before {
+  content: "\e07f";
+}
+.customer-current-activity .data-table .icon-add:before {
+  content: "\e071";
+}
+.customer-current-activity .auto-scroll {
+  color: #676056;
+  font-size: 13px;
+  font-weight: 400;
+  overflow: auto;
+  max-height: 150px;
+}
+.customer-current-activity .auto-scroll + button {
+  margin: 22px 0 0;
+}
+.customer-current-activity .actions {
+  border-top: none;
+  margin: 20px 0 0;
+  padding: 0;
+}
+.overlay {
+  background: rgba(255, 255, 255, 0.5);
+  border-radius: 5px;
+  position: absolute;
+  top: 0;
+  bottom: 0;
+  left: 0;
+  right: 0;
+}
+.overlay span {
+  color: #111;
+  font-weight: bold;
+  position: absolute;
+  top: 56px;
+  left: 0;
+  margin: 0 8px;
+  padding: 10px;
+  background: #ffffff;
+}
+/*
+    Order view
+-------------------------------------- */
+[class^=" sales-order-"] .fieldset-wrapper-title .actions {
+  float: right;
+  font-size: 12px;
+  margin: 8px 20px 0 0;
+}
+[class^=" sales-order-"] .fieldset-wrapper-title .actions a:link,
+[class^=" sales-order-"] .fieldset-wrapper-title .actions a:visited,
+[class^=" sales-order-"] .fieldset-wrapper-title .actions a:hover,
+[class^=" sales-order-"] .fieldset-wrapper-title .actions a:active {
+  color: #a29c94;
+}
+.order-comments-history fieldset {
+  border: 0;
+  margin: 0;
+  padding: 0;
+}
+.order-comments-history textarea,
+.rma-history-form textarea {
+  height: 6em;
+  margin: 5px 0 10px;
+  resize: vertical;
+  width: 100%;
+}
+.order-comments-history input[type="checkbox"] {
+  margin-right: 5px;
+}
+.order-history-comments-options {
+  float: left;
+}
+.order-comments-history .actions {
+  float: right;
+}
+[class^=" sales-order-"] .fieldset-wrapper address {
+  overflow: auto;
+}
+/*
+    Orders comments
+-------------------------------------- */
+.note-list {
+  list-style: none;
+  padding: 0;
+}
+.note-list li {
+  border-top: 1px solid #ededed;
+  padding: 9px 0;
+}
+.note-list li:first-child {
+  border: 0;
+  padding-top: 13px;
+}
+.note-list div {
+  font-size: 12px;
+}
+.note-list .note-list-date,
+.note-list .note-list-status,
+.note-list .note-list-customer span {
+  font-weight: bold;
+}
+.note-list .note-list-time,
+.note-list .note-list-status {
+  border-right: 1px solid #676056;
+  padding: 0 5px 0 0;
+  margin: 0 5px 0 0;
+}
+.note-list .note-list-customer {
+  white-space: nowrap;
+}
+.note-list .note-list-comment {
+  margin: 5px 0 0;
+}
+.note-list .note-list-customer-notapplicable {
+  color: #d87e34;
+}
+.note-list .note-list-customer-notified {
+  color: #185b00;
+}
+.note-list .note-list-customer-not-notified {
+  color: #963535;
+}
+.checkout-agreement-index .col-id,
+[class^=" sales-billing-"] .col-id,
+[class^=" sales-transactions-"] .col-id {
+  width: 35px;
+}
+[class^=" sales-order-shipment-"] .col-ship,
+[class^=" sales-"] .col-return-to-stock,
+.adminhtml-rma-new .col-select {
+  text-align: center;
+  width: 35px;
+}
+[class^=" sales-order-"] .col-price-original,
+[class^=" sales-order-"] .col-tax-amount,
+[class^=" sales-order-"] .col-tax-percent,
+[class^=" sales-order-"] .col-discont,
+[class^=" sales-order-"] .col-total,
+[class^=" sales-order-"] .col-discount,
+[class^=" sales-order-"] .col-tax,
+[class^=" sales-"] .col-refunded,
+[class^=" adminhtml-rma-"] .col-order,
+[class^=" adminhtml-rma-"] .col-required,
+[class^=" adminhtml-rma-"] .col-system,
+[class^=" adminhtml-rma-"] .col-visible-on-front,
+.checkout-agreement-index .col-status,
+.adminhtml-rma-item-attribute-edit .col-position {
+  text-align: right;
+  white-space: nowrap;
+  width: 50px;
+}
+[class^=" sales-order-"] .col-subtotal,
+[class^=" sales-order-"] .col-price,
+[class^=" adminhtml-rma-"] .col-price {
+  text-align: right;
+  width: 50px;
+}
+.sales-order-invoice-view .col-subtotal,
+.sales-order-invoice-view .col-price {
+  width: 10%;
+}
+[class^=" sales-"] .col-actions,
+[class^=" adminhtml-rma-"] .col-actions,
+[class^=" adminhtml-rma-"] .col-default {
+  width: 50px;
+}
+[class^=" sales-"] .col-select,
+[class^=" adminhtml-rma-"] .col-select {
+  width: 60px;
+}
+[class^=" sales-"] .col-qty,
+[class^=" sales-order-"] .col-qty-invoice,
+[class^=" sales-order-"] .col-ordered-qty,
+[class^=" adminhtml-rma-"] .col-qty,
+[class^=" adminhtml-rma-"] .col-condition {
+  width: 70px;
+}
+[class^=" sales-"] .col-refund,
+[class^=" sales-transactions-"] .col-closed,
+.sales-order-view .col-closed {
+  text-align: center;
+  width: 70px;
+}
+[class^=" sales-"] .col-order-number,
+[class^=" sales-"] .col-invoice-number,
+[class^=" sales-"] .col-memo-number,
+[class^=" sales-"] .col-shipment-number,
+[class^=" sales-"] .col-rma-number,
+[class^=" sales-"] .col-status,
+[class^=" adminhtml-rma-"] .col-order-number,
+[class^=" adminhtml-rma-"] .col-rma-number,
+[class^=" sales-transactions-"] .col-order-id,
+.sales-order-view .col-refunded {
+  white-space: normal;
+  width: 75px;
+}
+[class^=" sales-"] .col-gtbase,
+[class^=" sales-"] .col-gtpurchased {
+  text-align: right;
+  white-space: normal;
+  width: 75px;
+}
+[class^=" sales-"] .col-order-number,
+[class^=" sales-"] .col-rma-number,
+[class^=" adminhtml-rma-"] .col-order-number,
+[class^=" adminhtml-rma-"] .col-rma-number {
+  text-align: left;
+}
+[class^=" adminhtml-rma-"] .col-status,
+[class^=" adminhtml-rma-"] .col-reason,
+[class^=" adminhtml-rma-"] .col-resolution,
+[class^=" sales-transactions-"] .col-transaction-type,
+.sales-order-view .col-memo {
+  width: 100px;
+}
+[class^=" sales-"] tr.headings .col-parent-transaction-id > span,
+[class^=" sales-"] tr.headings .col-method > span,
+[class^=" sales-"] tr.headings .col-transaction-id > span,
+[class^=" sales-"] tr.headings .col-transaction-type > span,
+[class^=" sales-"] tr.headings .col-gtbase > span,
+[class^=" sales-"] tr.headings .col-gtpurchased > span,
+[class^=" sales-order-"] tr.headings .col-discont > span {
+  white-space: normal;
+}
+[class^=" sales-"] .col-period,
+[class^=" adminhtml-rma-"] .col-period {
+  width: 150px;
+}
+[class^=" sales-order-shipment-"] .col-carrier {
+  width: 190px;
+}
+.checkout-agreement-index .col-store-view {
+  white-space: nowrap;
+  width: 200px;
+}
+[class^=" sales-transactions-"] .log-details .data-table tbody tr th,
+[class^=" sales-transactions-"] .col-key {
+  width: 22%;
+}
+.sales-order-index .col-1-layout table.data {
+  table-layout: fixed;
+  word-wrap: break-word;
+}
+[class^=" sales-"] .col-from-store {
+  width: 15%;
+}
+[class^=" sales-"] .col-2-left-layout .hor-scroll {
+  margin-bottom: -4px;
+  overflow: auto;
+  padding-bottom: 4px;
+  width: 100%;
+}
+[class^=" sales-order-"] .order-totals .actions,
+[class^=" adminhtml-rma-"] .col-qty,
+[class^=" adminhtml-rma-"] .col-qty_ordered,
+.sales-order-view .col-refunded {
+  text-align: right;
+}
+[class^=" sales-order-"] .col-price .label,
+[class^=" sales-order-"] .col-subtotal .label {
+  display: inline-block;
+  min-width: 60px;
+  white-space: nowrap;
+}
+[class^=" sales-order-"] .col-price .price-excl-tax .price,
+[class^=" sales-order-"] .col-price .price-incl-tax .price,
+[class^=" sales-order-"] .col-subtotal .price-excl-tax .price,
+[class^=" sales-order-"] .col-subtotal .price-incl-tax .price {
+  font-weight: bold;
+}
+[class^=" sales-order-"] .grid .col-qty table,
+[class^=" sales-order-"] .grid .col-qty tbody,
+[class^=" sales-order-"] .grid .col-qty tr,
+[class^=" sales-order-"] .grid .col-qty td,
+[class^=" sales-order-"] .grid .col-ordered-qty table,
+[class^=" sales-order-"] .grid .col-ordered-qty tbody,
+[class^=" sales-order-"] .grid .col-ordered-qty tr,
+[class^=" sales-order-"] .grid .col-ordered-qty td {
+  background: none;
+  border: 0;
+}
+[class^=" sales-order-"] .col-ordered-qty td {
+  padding: 0 5px 3px;
+}
+[class^=" sales-order-"] .grid .product-title {
+  font-weight: bold;
+}
+[class^=" sales-order-"] .item-options {
+  margin: 5px 0 5px 10px;
+}
+[class^=" sales-order-"] .item-options dt {
+  font-weight: bold;
+}
+[class^=" sales-order-"] .item-options dd {
+  margin: 0 0 0 10px;
+}
+.adminhtml-rma-item-attribute-edit .col-position input {
+  text-align: center;
+}
+.order-subtotal .label {
+  text-align: right;
+}
+.items-to-invoice {
+  border: 1px solid #c0bbaf;
+  margin-top: 13px;
+  width: 100%;
+}
+.items-to-invoice td,
+table.items-to-invoice tbody tr:hover td {
+  background-color: #e6e3de;
+  border: 0;
+  text-align: center;
+}
+[class^=" sales-order-creditmemo-"] .no-items {
+  padding-top: 13px;
+  text-align: center;
+}
+.items-to-invoice .grand-total {
+  color: #19a3d1;
+  font-weight: bold;
+}
+.sales-order-shipment-new .order-totals .fieldset-wrapper {
+  padding-top: 18px;
+}
+.sales-order-shipment-new .actions {
+  float: right;
+}
+.creditmemo-totals .data-table input[type="text"] {
+  text-align: right;
+  width: 60px;
+}
+[class^=" sales-order-"] .order-subtotal .label {
+  width: 80%;
+}
+.adminhtml-rma-new .rma-confirmation .actions {
+  margin-top: 10px;
+  text-align: right;
+}
+[class^=" adminhtml-rma-"] .rma-items th.col-qty span,
+.adminhtml-rma-edit .rma-items th.col-qty span {
+  text-align: left;
+  white-space: normal;
+}
+.adminhtml-rma-edit .data-table .col-carrier,
+[class^=" sales-billing-agreement-"] .log-details .data-table th {
+  width: 20%;
+}
+.adminhtml-rma-edit .data-table .col-title {
+  width: 35%;
+}
+.adminhtml-rma-edit .data-table .col-number {
+  width: 25%;
+}
+[class^=" sales-order-"] .order-shipping-address .price,
+.order-shipping-address .shipping-description-title {
+  font-weight: bold;
+}
+[class^=" adminhtml-rma-"] .col-actions a {
+  cursor: pointer;
+  white-space: nowrap;
+}
+[class^=" adminhtml-rma-"] .col-reason input[type="text"] {
+  margin: 5px 0 0;
+  width: 100%;
+}
+[class^=" adminhtml-rma-"] .col-actions .separator {
+  margin: 0 3px;
+}
+[class^=" sales-"] .order-payment-method .data-table {
+  margin-top: 15px;
+}
+[class^=" sales-"] .order-payment-currency {
+  margin-top: 15px;
+}
+[class^=" sales-"] .grid tbody td {
+  vertical-align: top;
+}
+[class^=" sales-"] .grid tbody.even tr td {
+  background: #e6e3de;
+}
+[class^=" sales-"] .grid tbody.odd tr td {
+  border-bottom: 0;
+  background: #f5f2ed;
+}
+[class^=" sales-"] .grid .data {
+  border-bottom: 1px solid #c0bbaf;
+}
+[class^=" sales-"] .grid td .option-label {
+  font-weight: bold;
+}
+[class^=" sales-"] .grid td .option-value {
+  margin: 0 0 0 10px;
+}
+.col-product .product_to_add {
+  float: right;
+}
+[class^=" adminhtml-extension-custom-"] #authors_fieldset .data-table td {
+  vertical-align: top;
+}
+/*
+    Packaging for Shipping Popup
+-------------------------------------- */
+#popup-window-mask,
+.popup-window-mask {
+  background: rgba(0, 0, 0, 0.5);
+  position: absolute;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  height: 100%;
+  z-index: 999;
+}
+.packaging-window,
+.packed-window {
+  background: #fff;
+  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
+  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
+  left: 50%;
+  margin: -200px 0 0 -471px;
+  position: fixed;
+  top: 50%;
+  width: 1000px;
+  z-index: 1000;
+}
+.packaging-window .entry-edit-head {
+  padding: 3px 5px;
+}
+.packaging-window .messages {
+  padding: 10px 26px 10px 32px;
+  border: 0;
+  -moz-border-radius: 0;
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  color: #963535;
+  text-shadow: none;
+  position: relative;
+  background: #f3dcd8;
+  border: 1px solid #963535;
+  margin-top: -1px;
+}
+.packaging-window .messages:before {
+  position: absolute;
+  left: 8px;
+  top: 50%;
+  margin-top: -11px;
+  background: none;
+  text-shadow: none;
+  width: auto;
+  height: auto;
+  border: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 16px;
+  content: '\e069';
+  color: #963535;
+}
+.packaging-window .validation-failed {
+  background: #fef0ed;
+  border: 1px dashed #d6340e;
+}
+.packaging-window .packaging-content {
+  overflow: auto;
+  overflow-x: hidden;
+  height: auto !important;
+  max-height: 400px;
+}
+.packaging-window .package-options {
+  width: 100%;
+  border-top: 1px solid #ccc;
+  padding: 10px 0 0;
+  margin: 3px 0 0;
+}
+.packaging-window .package-options td {
+  vertical-align: middle;
+}
+.packaging-window .package-options .input-text {
+  width: 50px;
+}
+.packaging-window .package_prapare {
+  margin-bottom: 15px;
+}
+.packaging-window .package-options .customs-value {
+  width: 80px;
+}
+.packaging-window .package-options .options-weight {
+  width: 75px;
+}
+.packaging-window .package-options .options-units-weight {
+  width: 45px;
+}
+.packaging-window .package-options .options-units-dimensions {
+  width: 45px;
+}
+.packaging-window .package-options .options-content-type {
+  width: 120px;
+}
+.packaging-window .package-options input[type=text].disabled,
+.packaging-window .package-options select.disabled {
+  background: #eee;
+}
+.packaging-window .package-options-contents {
+  border-top: 0;
+}
+.packaging-window .package-add-products {
+  margin: 20px 0 0;
+}
+.packaging-window .package-add-products .grid {
+  padding: 0;
+}
+.packaging-window .package-add-products .grid button {
+  vertical-align: middle;
+}
+.packaging-window .package-number {
+  font-weight: bold;
+}
+.packaging-window .package-number span {
+  margin-left: 5px;
+}
+.packed-window .entry-edit-head {
+  padding: 3px 5px;
+}
+.packed-window .packed-content {
+  padding: 10px 10px 0;
+  overflow: auto;
+  max-height: 400px;
+}
+.packed-window .package {
+  border-top: 1px solid #ededed;
+  margin-bottom: 30px;
+  padding: 10px;
+}
+.packed-window .package:first-child {
+  border-top: 0;
+}
+.package-info {
+  background: #e6e3de;
+  border: 1px solid #c0bbaf;
+}
+.package-info th {
+  font-weight: bold;
+}
+.packed-window .package-info table tbody tr td,
+.packed-window .package-info table tbody tr th,
+.package-info table tbody tr:nth-child(2n+1) td,
+.package-info table tbody tr:nth-child(2n+1) th {
+  background: none;
+  border: 0;
+  padding: 5px 5px 2px;
+}
+.packed-window .package .grid {
+  padding: 0;
+}
+.packed-window .package-options {
+  width: 60%;
+}
+.packed-window .package-options td,
+.packed-window .package-options th {
+  padding: 1px 0;
+}
+.grid .popup-window {
+  text-align: left;
+}
+.grid tr.on-mouse td .popup-window .data-table tbody tr:nth-child(2n+1) td,
+.grid table tbody tr.on-mouse:nth-child(odd):hover td .popup-window .data-table tbody tr:nth-child(2n+1) td,
+.grid table tbody tr.on-mouse:nth-child(odd):hover td .popup-window .data-table tbody tr:nth-child(2n+1):hover td,
+.grid table tbody tr.on-mouse:nth-child(2n+1):hover td .popup-window .data-table tbody tr:nth-child(2n+1) td,
+.grid table tbody tr.on-mouse:nth-child(2n+1):hover td .popup-window .data-table tbody tr:nth-child(2n+1):hover td,
+.grid table tbody tr.on-mouse:hover td .popup-window .data-table tbody tr:nth-child(2n+1),
+.grid table tbody tr.on-mouse:hover th .popup-window .data-table tbody tr:nth-child(2n+1) {
+  background-color: #fbfaf6;
+}
+.grid .popup-window {
+  text-align: left;
+}
+.popup-window-buttons-set {
+  text-align: right;
+  padding: 25px;
+}
+.popup-window-title {
+  background: #f3efea;
+  padding: 19px 20px;
+}
+.popup-window-title .title {
+  color: #676056;
+  display: block;
+  font-size: 20px;
+  line-height: 1;
+}
+.popup-window-title .actions {
+  float: right;
+}
+.popup-window-content {
+  padding: 25px 25px 0;
+}
+.popup-window-content > ul {
+  list-style: none;
+  padding: 0;
+}
+.packaging-window .col-weight {
+  text-align: left;
+  width: 60px;
+}
+.packaging-window .col-qty {
+  text-align: left;
+  width: 80px;
+}
+.packed-window .col-qty,
+.packed-window .col-weight,
+.packed-window .col-qty_ordered {
+  text-align: right;
+  width: 70px;
+}
+.packaging-window .col-select,
+.packaging-window .col-measure {
+  text-align: center;
+  width: 35px;
+}
+.popup-fieldset-title .title {
+  color: #666;
+  display: inline-block;
+  font-size: 18px;
+  font-weight: normal;
+  padding: 7px 0 10px;
+}
+.popup-fieldset-title .actions {
+  float: right;
+}
+.packaging-window select {
+  margin-bottom: 0;
+}
+.packaging-window .col-width,
+.packaging-window .col-height,
+.packaging-window .col-length,
+.packaging-window .data-table .col-total-weight input[type="text"] {
+  width: 60px;
+}
+.packaging-window .col-total-weight {
+  white-space: nowrap;
+  width: 100px;
+}
+.packaging-window .col-signature {
+  width: 160px;
+}
+.packaging-window .data-table .col-actions,
+.packaging-window .col-total-weight {
+  white-space: nowrap;
+}
+.packaging-window .data-table .action-delete {
+  margin: 5px 0 0 5px;
+}
+.packaging-window .grid tr th {
+  border-bottom: 1px solid #c9c2b8;
+}
+.packaging-window .grid tr th:first-child,
+.packaging-window .grid td:first-child,
+.packaging-window .grid td:last-child {
+  border-left: 0;
+  border-right: 0;
+}
+.packaging-window .data-table .col-qty-edit {
+  white-space: nowrap;
+  width: 50px;
+}
+.packaging-window .data-table .col-qty-edit input[type="text"] {
+  width: 50px;
+}
+.sp-methods > dt {
+  font-weight: bold;
+}
+.sp-methods > dd {
+  margin: 5px 0 5px 15px;
+}
+.sp-methods > dd > ul {
+  list-style: none;
+  padding: 0;
+}
+[class^=" sales-order-"] .order-billing-address .packaging-window .actions,
+[class^=" sales-order-"] .order-shipping-address .packaging-window .actions {
+  margin: 0;
+}
+/*
+    Popup Configuration Popup
+-------------------------------------- */
+#product_composite_configure_messages {
+  margin-left: 0 !important;
+  padding: 10px 15px;
+}
+.rma-popup,
+.cms-popup {
+  background: #fff;
+  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
+  cursor: default;
+  position: fixed;
+  left: 50%;
+  top: 50%;
+  z-index: 1000;
+}
+.rma-popup {
+  width: 540px;
+  margin: 0 0 0 -271px;
+}
+.rma-popup .entry-edit .fieldset {
+  border: none;
+}
+.rma-popup .validation-advice,
+.rma-popup label.mage-error {
+  margin-left: 0;
+}
+.rma-popup .content {
+  background: #fff;
+  border-bottom: 1px solid #ccc;
+  max-height: 400px;
+  overflow: auto;
+}
+.rma-popup .content .grid {
+  padding: 0;
+}
+.rma-popup .content .grid table {
+  border-bottom: 1px solid #cbd3d4;
+}
+.rma-popup .product-options {
+  border-bottom: 1px solid #e7e7e7;
+  margin: 0 0 15px;
+  padding: 0 0 12px;
+}
+.rma-popup .product-options .required {
+  color: #333 !important;
+  font-weight: normal !important;
+}
+.rma-popup .product-options .required em {
+  color: #d40707;
+}
+.rma-popup .last-fieldset .product-options {
+  border: 0 none;
+  margin-bottom: 0;
+  padding-bottom: 0;
+}
+.rma-popup .buttons-set {
+  text-align: right;
+  margin: 0;
+  overflow: hidden;
+  padding: 7px 10px 8px;
+}
+.rma-popup .buttons-set {
+  width: 518px;
+}
+.cms-popup .buttons-set {
+  width: 289px;
+}
+.rma-popup .buttons-set button {
+  margin: 0 0 0 5px;
+}
+.grid .rma-popup .form-list tr,
+.grid tr.even .rma-popup .form-list tr,
+.grid tr.on-mouse .rma-popup .form-list tr {
+  background: #fff !important;
+}
+/*
+    URL rewrite
+-------------------------------------- */
+.adminhtml-urlrewrite-edit .field-url-rewrite-option-select .label {
+  width: auto;
+}
+/*
+    Shopping Cart Price Rule
+-------------------------------------- */
+.fieldset .field-coupon_code,
+.fieldset .field-rule_use_auto_generation {
+  margin-bottom: 0;
+}
+.field-rule_use_auto_generation .label {
+  margin-left: 5px;
+}
+.field-rule_use_auto_generation .nested {
+  margin-bottom: 29px;
+}
+/*
+    Product Image Placeholders
+-------------------------------------- */
+#catalog_placeholder .input-file,
+#catalog_placeholder .delete-image > input {
+  margin-right: 5px;
+}
+/* Permanent Redirect for old URL */
+.control > [name="product[url_key_create_redirect]"],
+.control > [name="general[url_key_create_redirect]"] {
+  float: left;
+  margin: 8px 5px 0 0;
+}
+.control > [name="product[url_key_create_redirect]"] + .label,
+.control > [name="general[url_key_create_redirect]"] + .label {
+  width: auto;
+}
+/*
+    New Product Attribute Set
+-------------------------------------- */
+.field-skeleton_set .select {
+  width: 100%;
+}
+/*
+    Cache Management
+-------------------------------------- */
+.additional-cache-management .label {
+  margin-top: 5px;
+}
+/*
+    Currency Symbols
+-------------------------------------- */
+.adminhtml-system-currencysymbol-index th.col-symbol .required:after {
+  content: '*';
+  margin-left: 3px;
+}
+.adminhtml-system-currencysymbol-index td.col-currency .label {
+  margin-top: 5px;
+}
+/*
+    Categories
+-------------------------------------- */
+.category-content .form-inline.permissions-custom-options .messages li {
+  margin-top: 0;
+}
+.category-content .form-inline.permissions-custom-options .data-table {
+  margin-bottom: 25px;
+}
+/*
+    Marketing - Email Reminders
+-------------------------------------- */
+.lt-1280 .adminhtml-reminder-edit #customerGrid .grid .filter .range div.date {
+  min-width: 0;
+}
+/*
+    Customers - Manage Shopping Cart
+-------------------------------------- */
+.checkout-index-index .products-search {
+  margin-top: 35px;
+}
+.checkout-index-index .products-search > .actions {
+  text-align: right;
+  margin: 10px 0;
+}
+.checkout-index-index .shopping-cart-items > .actions {
+  margin-bottom: 15px;
+}
+.checkout-index-index .shopping-cart-items .box-left,
+.checkout-index-index .shopping-cart-items .box.right {
+  width: 49%;
+}
+.checkout-index-index .shopping-cart-items .box-left fieldset,
+.checkout-index-index .shopping-cart-items .box.right fieldset {
+  border-radius: 5px;
+}
+.checkout-index-index .shopping-cart-items .box-left {
+  float: left;
+}
+.checkout-index-index .shopping-cart-items .box.right {
+  float: right;
+}
+.checkout-index-index .grid table .action-configure {
+  float: right;
+}
+/*
+    Clearfix
+-------------------------------------- */
+.shopping-cart-items:before,
+.shopping-cart-items:after,
+.image-panel:before,
+.image-panel:after,
+.images:before,
+.images:after,
+.tax-rate-popup .field:before,
+.tax-rate-popup .field:after,
+.clearfix:before,
+.clearfix:after,
+#tab_content_downloadableInfo .data-table td .row:before,
+#tab_content_downloadableInfo .data-table td .row:after {
+  content: "";
+  display: table;
+}
+.shopping-cart-items:after,
+.image-panel:after,
+.images:after,
+.tax-rate-popup .field:after,
+.clearfix:after,
+#tab_content_downloadableInfo .data-table td .row:after {
+  clear: both;
+}
+.debug {
+  border: 1px solid red !important;
+}
+.messages ul,
+ul.messages {
+  list-style: none;
+  margin: 0;
+  padding: 0;
+}
+ul.messages > li {
+  margin: 20px 0;
+}
+ul.messages li li {
+  padding: 10px 26px 10px 35px;
+  border-radius: 5px;
+  color: #676056;
+  text-shadow: none;
+  position: relative;
+  background: #fffbf0;
+  border: 1px solid #d87e34;
+  margin-top: -1px;
+}
+ul.messages li li:first-child {
+  margin-top: 0;
+}
+ul.messages li li:before {
+  position: absolute;
+  left: 11px;
+  top: 50%;
+  margin-top: -11px;
+  background: none;
+  text-shadow: none;
+  width: auto;
+  height: auto;
+  border: 0;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  font-size: 16px;
+  content: '\e046';
+  /* icon-info  */
+
+  color: #d87e34;
+}
+ul.messages li.error-msg li {
+  color: #963535;
+  border-color: #963535;
+  background: #f3dcd8;
+}
+ul.messages li.error-msg li:before {
+  content: '\e069';
+  color: #963535;
+}
+ul.messages li.success-msg li {
+  border-color: #ceceb6;
+  background: #e4eecb;
+  color: #185b00;
+}
+ul.messages li.success-msg li:before {
+  content: '\e067';
+  color: #185b00;
+}
+/*
+    Accordion
+------------------------*/
+.accordion {
+  margin: 0 0 8px;
+  padding: 0;
+}
+.accordion > dt,
+.accordion > dd.open,
+.accordion .collapseable,
+.section-config.active > .collapseable + input + fieldset,
+.accordion .collapseable.open + input + fieldset {
+  background: #fff;
+  border: 1px solid #eae6e0;
+  border-radius: 5px;
+  margin: 0 0 8px;
+  padding: 5px 18px 2px;
+  position: relative;
+}
+.accordion > dt + dd {
+  display: none;
+}
+.accordion > dt.open,
+.section-config.active > .collapseable,
+.accordion .collapseable.open {
+  margin: 0;
+  border-bottom: 0;
+  border-radius: 5px 5px 0 0;
+}
+.section-config.active > .collapseable + input + fieldset,
+.accordion > dt + dd.open,
+.accordion .collapseable.open + input + fieldset {
+  padding: 25px 18px 18px;
+  display: block;
+  border-top: 0;
+  border-radius: 0 0 5px 5px;
+}
+.section-config > .collapseable > a,
+.accordion > dt a,
+.accordion .collapseable > a {
+  color: #676056;
+  font-size: 20px;
+  font-weight: 400;
+  display: block;
+  padding: 7px 0 10px 22px;
+  text-decoration: none;
+  position: relative;
+  cursor: pointer;
+}
+.section-config > .collapseable > a i,
+.accordion > dt a i,
+.accordion .collapseable > a i {
+  color: #676056;
+  font-size: 20px;
+  font-style: italic;
+  font-weight: 400;
+}
+.section-config.active > .collapseable > a,
+.accordion .collapseable.open a,
+.accordion dt.open a {
+  border-bottom: 1px solid #ededed;
+}
+.section-config > .collapseable > a:before,
+.accordion > dt a:before,
+.accordion .collapseable > a:before {
+  position: absolute;
+  left: 0;
+  top: 7px;
+  font-family: 'MUI-Icons';
+  font-style: normal;
+  speak: none;
+  font-weight: normal;
+  -webkit-font-smoothing: antialiased;
+  content: '\e02a';
+  /* arrow right icon */
+
+  color: #b2b0ad;
+}
+.section-config.active > .collapseable > a:before,
+.accordion > dt.open a:before,
+.accordion .collapseable.open a:before {
+  content: '\e02c';
+  /* arrow down icon */
+
+}
+.section-config > .collapseable > a:hover:before,
+.accordion > dt a:hover:before,
+.accordion .collapseable > a:hover:before {
+  color: #7e7e7e;
+}
+/* PayPal connected */
+.section-config.complex .section-config.with-button {
+  padding: 20px 15px;
+  margin: 0 -30px 0 -15px;
+  border-bottom: 1px solid #eae6e0;
+}
+.section-config.complex tr:last-child .section-config.with-button {
+  border-bottom: 0;
+}
+.section-config.complex .section-config.with-button > .entry-edit-head {
+  padding: 0;
+  padding-left: 25px;
+  border: 0;
+}
+.section-config.complex .section-config.with-button.enabled > .entry-edit-head:before {
+  content: "\e01e";
+  color: #fff;
+  background: #65940a;
+  font-family: "MUI-Icons";
+  font-weight: normal;
+  padding: 3px;
+  font-size: 10px;
+  width: 10px;
+  height: 10px;
+  line-height: 10px;
+  overflow: hidden;
+  border-radius: 8px;
+  display: block;
+  float: left;
+  margin-left: -25px;
+  margin-top: 0;
+}
+.section-config.complex .section-config.with-button > .config {
+  margin: 10px -10px;
+  border: 1px solid #d1d0ce;
+  border-radius: 5px;
+  padding: 5px 0;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr > td {
+  padding: 0;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr > td > .section-config > .entry-edit-head {
+  border: 0;
+  border-radius: 0;
+  margin-bottom: 0;
+  padding: 5px 10px 2px;
+  border-bottom: 1px solid #d1d0ce;
+  background: transparent;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr:last-child > td > .section-config > .entry-edit-head {
+  border: 0;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr > td > .section-config > .entry-edit-head a {
+  border-bottom: 0;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr > td > .section-config > .config {
+  border: 0;
+  border-bottom: 1px solid #d1d0ce;
+  border-radius: 0;
+  margin: 0;
+  padding-bottom: 50px;
+}
+.section-config.complex .section-config.with-button > .config > table > tbody > tr:last-child > td > .section-config > .config {
+  border-bottom: 0;
+}
+.section-config .config h4 {
+  padding-left: 25%;
+  font-size: 18px;
+}
+.section-config .config td.label label.enabled:before {
+  content: "\e01e";
+  color: #fff;
+  background: #65940a;
+  font-family: "MUI-Icons";
+  font-weight: normal;
+  padding: 3px;
+  font-size: 10px;
+  width: 10px;
+  height: 10px;
+  line-height: 10px;
+  overflow: hidden;
+  border-radius: 8px;
+  display: block;
+  float: left;
+  margin-right: 5px;
+}
+.section-config.complex .section-config.with-button > .config:before {
+  content: '';
+  height: 9px;
+  width: 20px;
+  overflow: hidden;
+  display: block;
+  position: absolute;
+  bottom: 100%;
+  left: 50%;
+  zoom: 1;
+  z-index: 2;
+  margin-left: -10px;
+  background: url(../images/subconfig-bg.png) no-repeat 0 0;
+}
+.section-config.config-advanced {
+  padding: 30px 0 0;
+}
+.section-config.config-advanced > .entry-edit-head {
+  border: 0;
+  padding: 0;
+  padding-left: 25%;
+}
+.section-config.config-advanced > .entry-edit-head a {
+  border: 0 !important;
+}
+.section-config.config-advanced > .config {
+  padding-left: 0!important;
+  padding-right: 0!important;
+  border: 0!important;
+  border-radius: 0!important;
+}
+.section-config.config-advanced > .entry-edit-head a {
+  margin-left: -22px;
+}
+.section-config.with-button .config-heading strong {
+  display: block;
+  color: #676056;
+  font-size: 14px;
+  font-weight: 700;
+  margin-bottom: 5px;
+}
+.section-config.with-button .config-heading .button-container {
+  margin: 15px 0 0;
+}
+.section-config.with-button .button-container {
+  line-height: 28px;
+}
+.section-config.with-button .button-container a {
+  margin-left: 20px;
+}
+.section-config.with-button .action-configure span {
+  display: block;
+  position: relative;
+  text-align: center;
+}
+.section-config.with-button .action-configure .state-opened {
+  visibility: hidden;
+  height: 0;
+  overflow: hidden;
+}
+.section-config.with-button .action-configure.open .state-opened {
+  visibility: visible;
+  height: auto;
+  overflow: auto;
+}
+.section-config.with-button .action-configure.open .state-closed {
+  visibility: hidden;
+  height: 0;
+  overflow: hidden;
+}
+.accordion > dt + dd {
+  display: none;
+}
+.accordion > dt + .open:empty {
+  background: #ffffff url(../mui/images/ajax-loader-big.gif) no-repeat center;
+  height: 100px;
+}
+/* TODO: arrange configuration tables */
+.accordion .collapseable.disabled {
+  background: #f1f1f1;
+}
+.accordion .collapseable.disabled > a {
+  cursor: not-allowed;
+}
+.accordion .collapseable.disabled > a:before {
+  content: '';
+}
+.accordion .config {
+  border: 0;
+}
+.accordion .config .comment a {
+  color: #007dbd;
+  font-size: 14px;
+  font-weight: 400;
+}
+.accordion .config .comment a:focus,
+.accordion .config .comment a:hover {
+  text-decoration: underline;
+}
+.accordion .config legend {
+  display: none;
+}
+.accordion .config table {
+  width: 100%;
+}
+.accordion .config .label {
+  float: none;
+  width: 25%;
+  text-align: right;
+  color: #676056;
+  font-size: 13px;
+  font-weight: 600;
+}
+.accordion .config .value .label {
+  padding: 6px 5px 0 15px;
+  vertical-align: top;
+  width: auto;
+}
+.accordion .config .value .label:first-child {
+  padding-left: 0;
+}
+.accordion .config .label label {
+  padding-top: 6px;
+}
+.accordion .config td {
+  background: none;
+  border: 0;
+  padding: 8px 15px 0 0;
+  vertical-align: top;
+}
+.accordion .paypal-selection-simplified {
+  padding-left: 30px;
+}
+.accordion .paypal-selection input[type="checkbox"] {
+  margin: -4px 7px 0 0;
+}
+.accordion .config input[type="text"],
+.accordion .config input[type="password"],
+.accordion .config select,
+.accordion .config textarea {
+  width: 100%;
+  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  -moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
+}
+.accordion .config input.input-file {
+  margin-top: 4px;
+}
+.accordion .config select.select-date {
+  width: 20%;
+}
+.accordion .config .value {
+  width: 50%;
+  padding-right: 40px;
+}
+.accordion .config .value.with-tooltip {
+  padding-top: 5px;
+}
+.accordion .config .value.with-tooltip .tooltip {
+  position: relative;
+  top: 0;
+  left: 0;
+  right: 0;
+  bottom: 0;
+  margin: 0;
+  float: right;
+  margin-right: -20px;
+  margin-top: 6px;
+}
+.accordion .config .value.with-tooltip .tooltip-content {
+  padding: 18px;
+  margin: 0 -17px 10px 0;
+  right: 0;
+  bottom: 100%;
+  width: 239px;
+  max-width: 239px;
+  font-size: 13px;
+  line-height: 1.4;
+  background: #31302b;
+  background: rgba(49, 48, 43, 0.8);
+  border-radius: 5px;
+}
+.accordion .config .value.with-tooltip .tooltip-content:before {
+  content: '';
+  position: absolute;
+  width: 0;
+  height: 0;
+  top: auto;
+  bottom: -5px;
+  left: auto;
+  right: 20px;
+  border-left: 5px solid transparent;
+  border-right: 5px solid transparent;
+  border-top: 5px solid #31302b;
+  border-bottom: 0;
+  opacity: .8;
+}
+.accordion .config .value.with-tooltip .help {
+  position: relative;
+  width: auto;
+  margin: 0;
+}
+.accordion .config .scope-label {
+  color: #999;
+  font-size: 12px;
+  letter-spacing: 0.05em;
+  padding: 15px 15px 0 0;
+}
+.accordion .config .note {
+  color: #676056;
+  font-size: 12px;
+  font-weight: 400;
+  padding-left: 15px;
+  margin: 5px 0;
+}
+.accordion .config .note a {
+  color: #007dbd;
+  font-size: 12px;
+  font-weight: 400;
+}
+.accordion .config .note a:focus,
+.accordion .config .note a:hover {
+  text-decoration: underline;
+}
+.accordion .config .note:before {
+  position: absolute;
+  margin: 4px 0 0 -14px;
+  content: '';
+  display: inline-block;
+  vertical-align: top;
+  font-size: 0;
+  line-height: 0;
+  width: 0;
+  border-bottom: 5px solid #666;
+  border-left: 5px solid transparent;
+  border-right: 5px solid transparent;
+}
+.accordion .config .system-tooltip-box {
+  position: absolute;
+}
+.accordion .paypal-selection {
+  margin: 10px;
+  width: 98%;
+}
+.accordion .paypal-selection th {
+  padding: 6px 10px 7px;
+}
+.accordion .paypal-selection {
+  border-bottom: 2px solid #c0bbaf;
+}
+.accordion .paypal-payment-notice {
+  margin: 10px;
+}
+.accordion .custom-options {
+  border: 1px solid #999;
+  padding: 0 10px;
+  margin: 0 0 20px;
+}
+/* TODO: arrange range inputs width in tables */
+.grid td input.input-text-range {
+  width: 35%;
+}
+.grid td input.input-text-range-date {
+  width: 31%;
+}
+/* TODO: styles for required TH fields */
+th.required:after {
+  color: red;
+  content: "*";
+  margin-left: 5px;
+}
+/* TODO: set color for messages in Cache Storage Management */
+.grid-severity-critical,
+.grid-severity-major,
+.grid-severity-notice,
+.grid-severity-minor {
+  display: block;
+  border: 1px solid #c76f35;
+  background: #fffbf0;
+  text-align: center;
+}
+.grid-severity-critical {
+  border-color: #6e1313;
+  background: #f7bfbf;
+  color: #6e1313;
+}
+.grid-severity-major {
+  border-color: #963535;
+  background: #f3dcd8;
+  color: #963535;
+}
+.grid-severity-notice {
+  border-color: #185b00;
+  background: #e6ecc0;
+  color: #185b00;
+}
+/*
+    Sales
+-------------------------------------- */
+.order-items .entry-edit-head .form-buttons {
+  float: right;
+}
+.order-items .entry-edit-head .icon-head {
+  display: inline;
+}
+.order-items .entry-edit-head {
+  margin-bottom: 20px;
+}
+.order-items .entry-edit-head:before,
+.order-items .entry-edit-head:after {
+  content: "";
+  display: table;
+}
+.order-items .entry-edit-head:after {
+  clear: both;
+}
+/*
+    Import-export tax rates
+-------------------------------------- */
+.import-export-tax-rates input[type=file] {
+  margin-right: 10px;
+}
+.import-tax-rates,
+.export-tax-rates {
+  float: left;
+  width: 48.9362%;
+}
+.export-tax-rates {
+  margin-left: 2.12766%;
+}
+.import-export-tax-rates:before,
+.import-export-tax-rates:after {
+  content: "";
+  display: table;
+}
+.import-export-tax-rates:after {
+  clear: both;
+}
+/*
+    Product
+-------------------------------------- */
+.tier {
+  margin: 20px 0 0;
+}
+/*
+    Edit attribute set
+-------------------------------------- */
+.attribute-set-col {
+  display: block;
+  float: left;
+  width: 100%;
+  margin-left: 2.127659574%;
+  -webkit-box-sizing: border-box;
+  -moz-box-sizing: border-box;
+  -ms-box-sizing: border-box;
+  box-sizing: border-box;
+  width: 31.9149%;
+}
+.attribute-set-col:first-child {
+  margin-left: 0;
+}
+.attribute-set-tree {
+  margin-top: 5px;
+  overflow: auto;
+  height: 400px;
+  width: 100%;
+}
+.attribute-set:before,
+.attribute-set:after {
+  content: "";
+  display: table;
+}
+.attribute-set:after {
+  clear: both;
+}
+/*
+    Manage Categories
+-------------------------------------- */
+.catalog-category-edit .category-edit-title {
+  float: left;
+}
+/*
+    Catalog Price Rule
+-------------------------------------- */
+.rule-tree-wrapper {
+  line-height: 28px;
+}
+.rule-tree ul {
+  list-style: none;
+  padding-left: 16px;
+  border-left: dotted 1px #888;
+}
+.rule-tree li {
+  margin: 0 0 10px;
+}
+.rule-tree .x-tree ul {
+  padding-left: 0 !important;
+  border-left: none !important;
+}
+.rule-param .label {
+  color: #000;
+  float: none;
+  text-align: left;
+  padding: 0;
+  vertical-align: baseline;
+  width: auto;
+}
+.rule-param .label-disabled {
+  color: #eee;
+  cursor: default;
+  text-decoration: none;
+}
+.rule-chooser,
+.rule-param .element,
+.rule-param-edit .label {
+  display: none;
+}
+.rule-param input,
+.rule-param select {
+  width: auto !important;
+  margin: 0;
+  min-width: 170px;
+}
+.rule-param-edit .element {
+  display: inline;
+}
+.rule-param-edit .element .addafter {
+  padding-left: 5px;
+}
+[class^="rule-param-"] img,
+.rule-chooser-trigger img {
+  vertical-align: middle;
+}
+.rule-chooser {
+  border: solid 1px #CCC;
+  margin: 20px;
+  padding: 15px 10px 5px;
+}
+.rule-param-wait {
+  background: url(../mui/images/ajax-loader-small.gif) no-repeat left center;
+  padding-left: 20px;
+}
+/*
+
+    URL Rewrite
+-------------------------------------- */
+.field-url-rewrite-option-select {
+  padding-top: 13px;
+}
+/* jstree */
+.jstree-default .disabled > a {
+  color: #a29c94;
+}
+/*  File brouser */
diff --git a/app/design/adminhtml/magento_backend/css/styles-ie8.css b/app/design/adminhtml/magento_backend/css/styles-ie8.css
new file mode 100644
index 0000000000000000000000000000000000000000..12df12f742abe93b23129e6f4e05299cddc0cfef
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/css/styles-ie8.css
@@ -0,0 +1,300 @@
+/**
+ * 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.
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
+.eq-ie8 .customer-current-activity .action-refresh,
+.eq-ie8 .pager .action-next,
+.eq-ie8 .pager .action-previous,
+.eq-ie8 .pager .action-next:hover,
+.eq-ie8 .pager .action-previous:hover,
+.eq-ie8 .pager .action-next.disabled:focus,
+.eq-ie8 .pager .action-previous.disabled:focus,
+.eq-ie8 .pager .action-next.disabled:active,
+.eq-ie8 .pager .action-previous.disabled:active,
+.eq-ie8 .data-table .action-.delete,
+.eq-ie8 .data-table .action-.delete:hover,
+.eq-ie8 .data-table .action-.delete:active,
+.eq-ie8 .data-table .action-.delete.active,
+.eq-ie8 .data-table .action-delete,
+.eq-ie8 .data-table .action-delete:hover,
+.eq-ie8 .data-table .action-delete:active,
+.eq-ie8 .data-table .action-delete.active,
+.eq-ie8 .data-table .action-locked,
+.eq-ie8 .data-table .action-locked:hover,
+.eq-ie8 .data-table .action-locked:active,
+.eq-ie8 .data-table .action-locked.active,
+.eq-ie8 #product-variations-matrix .action-choose,
+.eq-ie8 #product-variations-matrix .action-choose:hover,
+.eq-ie8 #product-variations-matrix .action-choose:active,
+.eq-ie8 #product-variations-matrix .action-choose.active,
+.eq-ie8 .image-panel .action-close,
+.eq-ie8 .eq-ie8 .image-panel .action-close:hover,
+.eq-ie8 .image-panel .action-close:active,
+.eq-ie8 .image-panel .action-close.active,
+.eq-ie8 .image-panel-controls .action-remove,
+.eq-ie8 .image-panel-controls .action-remove:hover,
+.eq-ie8 .image-panel-controls .action-remove:active,
+.eq-ie8 .image-panel-controls .action-remove.active,
+.eq-ie8 .suggest-expandable .action-show-all,
+.eq-ie8 .suggest-expandable .action-show-all:hover,
+.eq-ie8 .suggest-expandable .action-show-all:active,
+.eq-ie8 .suggest-expandable .action-show-all.active,
+.eq-ie8 .vde-tools-header .action-close,
+.eq-ie8 .vde-tools-header .action-close:hover,
+.eq-ie8 .vde-tools-header .action-close:active,
+.eq-ie8 .vde-tools-header .action-close.active,
+.eq-ie8 .image .action-delete,
+.eq-ie8 .image .action-delete:hover,
+.eq-ie8 .image .action-delete:active,
+.eq-ie8 .image .action-delete.active,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete:hover,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete:active,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete.active,
+.eq-ie8 .address-list-item-actions .action-delete,
+.eq-ie8 .address-list-item-actions .action-delete:hover,
+.eq-ie8 .address-list-item-actions .action-delete:active,
+.eq-ie8 .address-list-item-actions .action-delete.active,
+.eq-ie8 .notification .action-close,
+.eq-ie8 .notification .action-close:hover,
+.eq-ie8 .notification .action-close:active,
+.eq-ie8 .notification .action-close.active,
+.eq-ie8 .page-login .action-forgotpassword,
+.eq-ie8 .page-login .action-forgotpassword:hover,
+.eq-ie8 .page-login .action-forgotpassword:active,
+.eq-ie8 .page-login .action-forgotpassword.active,
+.eq-ie8 .page-login .action-back,
+.eq-ie8 .page-login .action-back:hover,
+.eq-ie8 .page-login .action-back:active,
+.eq-ie8 .page-login .action-back.active {
+  border: none;
+  border-radius: 0;
+  background: none;
+  margin: 0;
+  padding: 0;
+  box-shadow: none;
+  text-shadow: none;
+  filter: none;
+}
+.eq-ie8 .actions-image-uploader .action-upload {
+  filter: none;
+}
+.eq-ie8 select[disabled="disabled"][multiple="multiple"] option[selected="selected"] {
+  background-color: #ddd;
+}
+.eq-ie8 .fieldset {
+  border-width: 0 0 1px;
+}
+.eq-ie8 .fieldset .fieldset-wrapper .fieldset-wrapper-title,
+.eq-ie8 .fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title {
+  background: #f4f2ef;
+}
+.eq-ie8 .fieldset-alt,
+.eq-ie8 .fieldset-alt > .fieldset {
+  display: block;
+  width: 100%;
+}
+.eq-ie8 .fieldset-alt > .field {
+  display: inline-block;
+}
+.eq-ie8 .field.type-price .addon .addafter,
+.eq-ie8 .field-price .addon .addafter,
+.eq-ie8 .field-special_price .addon .addafter,
+.eq-ie8 .field-msrp .addon .addafter {
+  border-width: 1px 1px 1px 0;
+}
+.eq-ie8 .field-apply_to .multiselect {
+  height: 120px;
+}
+.eq-ie8 .popup-loading {
+  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
+}
+.eq-ie8 .loading-old,
+.eq-ie8 .loading-mask {
+  background: #fff;
+  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
+}
+.eq-ie8 .navigation {
+  background: #726c62;
+}
+.eq-ie8 .navigation:before {
+  border-top: 1px solid #46433d;
+}
+.eq-ie8 .navigation .level-0.active > a {
+  background: #625d54;
+}
+.eq-ie8 .navigation .level-0.active > a,
+.eq-ie8 .navigation .level-0:hover > a,
+.eq-ie8 .navigation .level-0.hover > a {
+  border-top: 1px solid #46433d;
+  padding-top: 36px;
+}
+.eq-ie8 .navigation .level-0 > .submenu .column {
+  float: left;
+}
+.eq-ie8 .navigation .level-0.item-system > a,
+.eq-ie8 .navigation .level-0.item-system:hover > a,
+.eq-ie8 .navigation .level-0.item-system.hover > a,
+.eq-ie8 .navigation .level-0.item-stores > a,
+.eq-ie8 .navigation .level-0.item-stores:hover > a,
+.eq-ie8 .navigation .level-0.item-stores.hover > a {
+  border-top: 0;
+  padding-top: 0;
+}
+.eq-ie8 .navigation .level-0.item-system > a:before,
+.eq-ie8 .navigation .level-0.item-system > a:after,
+.eq-ie8 .navigation .level-0.item-stores > a:before,
+.eq-ie8 .navigation .level-0.item-stores > a:after {
+  display: none;
+}
+.eq-ie8 .page-login .field-username label,
+.eq-ie8 .page-login .field-password label,
+.eq-ie8 .page-login .field-confirmation label {
+  display: block;
+}
+.eq-ie8 .message-noscript,
+.eq-ie8 .message-demo-mode {
+  border-bottom: 1px solid #46433d;
+}
+.eq-ie8 .store-switcher-alt .store-selected:after {
+  vertical-align: middle;
+}
+.eq-ie8 .store-switcher-website {
+  border-bottom: 0;
+}
+.eq-ie8 .store-switcher-store-view {
+  border-bottom: 0;
+  border-top: 1px solid #e5e5e5;
+}
+.eq-ie8 .switcher-label:after {
+  content: 'off';
+  overflow: hidden;
+  white-space: nowrap;
+  text-indent: 100%;
+}
+.eq-ie8 .switcher.checked .switcher-label:after {
+  background-position: -34px 0;
+  content: 'on';
+}
+.eq-ie8 .switcher.checked .switcher-label:before {
+  content: attr(data-text-on);
+}
+.eq-ie8 .grid table td.empty-text {
+  border-width: 0 1px 1px;
+}
+.eq-ie8 .grid table tr td.empty-text {
+  border-width: 0 1px 1px;
+}
+.eq-ie8 .grid .filter .date img {
+  filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0);
+}
+.eq-ie8 .massaction .entry-edit .field-row:first-child {
+  margin-right: 1px;
+}
+.eq-ie8 .massaction .entry-edit .field-row {
+  display: inline;
+}
+.eq-ie8 .data-table td,
+.eq-ie8 .data-table tbody tr td {
+  border-width: 0 0 1px;
+}
+.eq-ie8 .data-table td > .field {
+  margin-bottom: 0;
+}
+.eq-ie8 .data-table tfoot tr td {
+  border: none;
+}
+.eq-ie8 .customer-information .data-table tbody tr td,
+.eq-ie8 .customer-information .data-table tbody tr th,
+.eq-ie8 .order-information .data-table tbody tr td,
+.eq-ie8 .order-information .data-table tbody tr th,
+.eq-ie8 .order-account-information .data-table tbody tr td,
+.eq-ie8 .order-account-information .data-table tbody tr th,
+.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr td,
+.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr th,
+.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr th,
+.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr td,
+.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr th,
+.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr td,
+.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr th,
+.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr td {
+  border-bottom: 1px solid #ededed;
+}
+.eq-ie8 .widget-layout-updates .data-table {
+  table-layout: auto;
+}
+.eq-ie8 .massaction {
+  border-bottom: 2px solid #504d46;
+}
+.eq-ie8 .header {
+  background: #f5f2ea;
+}
+.eq-ie8 .header-panel .dropdown-menu {
+  border: 1px solid #c3bcaf;
+}
+.eq-ie8 .header-panel .notifications-icon:before {
+  bottom: -6px;
+}
+.eq-ie8 .header-panel .notifications > .dropdown-menu > li:hover {
+  margin-top: 0;
+  padding-top: 13px;
+}
+.eq-ie8 .header-panel .dropdown-menu > li:hover:after {
+  display: block;
+}
+.eq-ie8 .header-panel .notifications > .dropdown-menu .action-close {
+  filter: none;
+}
+.eq-ie8 .header .header-panel .notifications .action-more {
+  filter: none;
+}
+.eq-ie8 .header .header-panel .notifications .action-more {
+  margin-bottom: -1px;
+}
+.eq-ie8 .autocomplete-results {
+  margin-top: -10px;
+}
+.eq-ie8 .search button[type="submit"]:before {
+  line-height: 1.3;
+}
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back,
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:hover,
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:active,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:hover,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:active {
+  filter: none;
+  border: 0;
+}
+.eq-ie8 .sales-order-index .col-1-layout table.data {
+  table-layout: auto;
+  word-wrap: normal;
+}
+.eq-ie8 .accordion .config legend {
+  position: absolute;
+  left: -999em;
+  display: block;
+  width: 0;
+  height: 0;
+  padding: 0;
+  margin: 0;
+  overflow: hidden;
+}
diff --git a/app/design/adminhtml/magento_backend/css/styles.css b/app/design/adminhtml/magento_backend/css/styles.css
index 6c1cab91a97a8840f159beacd2de6253a3e027c2..3387b22a778b4450be0ff515708463636a5ffb44 100644
--- a/app/design/adminhtml/magento_backend/css/styles.css
+++ b/app/design/adminhtml/magento_backend/css/styles.css
@@ -9273,7 +9273,7 @@ tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-d
   padding: 0;
 }
 .overlay {
-  background: rgba(0, 0, 0, 0.3);
+  background: rgba(255, 255, 255, 0.5);
   border-radius: 5px;
   position: absolute;
   top: 0;
@@ -9285,10 +9285,11 @@ tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-d
   color: #111;
   font-weight: bold;
   position: absolute;
-  top: 50%;
-  left: 50%;
-  margin: -25px 0 0 -100px;
-  width: 200px;
+  top: 56px;
+  left: 0;
+  margin: 0 8px;
+  padding: 10px;
+  background: #ffffff;
 }
 /*
     Order view
@@ -10583,17 +10584,17 @@ ul.messages li.success-msg li:before {
   margin-top: 6px;
 }
 .accordion .config .value.with-tooltip .tooltip-content {
-  padding: 15px;
+  padding: 18px;
+  margin: 0 -17px 10px 0;
   right: 0;
-  margin-left: 0;
-  margin-right: -19px;
-  margin-bottom: 10px;
-  left: auto;
-  top: auto;
   bottom: 100%;
-  width: 400px;
-  max-width: 400px;
-  line-height: 1.333;
+  width: 239px;
+  max-width: 239px;
+  font-size: 13px;
+  line-height: 1.4;
+  background: #31302b;
+  background: rgba(49, 48, 43, 0.8);
+  border-radius: 5px;
 }
 .accordion .config .value.with-tooltip .tooltip-content:before {
   content: '';
@@ -10606,7 +10607,7 @@ ul.messages li.success-msg li:before {
   right: 20px;
   border-left: 5px solid transparent;
   border-right: 5px solid transparent;
-  border-top: 5px solid #000;
+  border-top: 5px solid #31302b;
   border-bottom: 0;
   opacity: .8;
 }
diff --git a/app/design/adminhtml/magento_backend/less/lib/buttons.less b/app/design/adminhtml/magento_backend/less/lib/buttons.less
index d6d4958cca97c42715b01df61ae1a1eca126b989..d8ddfec8ae45505ea14562c20f806f4903839fef 100644
--- a/app/design/adminhtml/magento_backend/less/lib/buttons.less
+++ b/app/design/adminhtml/magento_backend/less/lib/buttons.less
@@ -43,6 +43,7 @@
     &:hover,
     &:focus,
     &:active {
+        text-decoration: none;
         background: @defaultButton4;
         color: @defaultButton3;
     }
diff --git a/app/design/adminhtml/magento_backend/less/styles/admin.less b/app/design/adminhtml/magento_backend/less/styles/admin.less
index 8a9e235e1fd42cca576af275accaf0e5344ed0e0..faa49622af006fc6cd5e4732a13d73c2c249f2d6 100644
--- a/app/design/adminhtml/magento_backend/less/styles/admin.less
+++ b/app/design/adminhtml/magento_backend/less/styles/admin.less
@@ -1,5 +1,5 @@
-// /**
-//  * Magento
+/**
+  * Magento
  *
  * NOTICE OF LICENSE
  *
@@ -16,10 +16,14 @@
  * 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.
-//  *
-//  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
-//  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
-//  */
+  *
+  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+  */
+
+@import "vars.less";
+@import "base.less";
+@import "../lib/buttons.less";
 
 .dont-use-this-class-big-size {
     font-size: 18px;
@@ -133,81 +137,6 @@
     margin: 0 15px;
 }
 
-.eq-ie8 .customer-current-activity .action-refresh,
-.eq-ie8 .pager .action-next,
-.eq-ie8 .pager .action-previous,
-.eq-ie8 .pager .action-next:hover,
-.eq-ie8 .pager .action-previous:hover,
-.eq-ie8 .pager .action-next.disabled:focus,
-.eq-ie8 .pager .action-previous.disabled:focus,
-.eq-ie8 .pager .action-next.disabled:active,
-.eq-ie8 .pager .action-previous.disabled:active,
-.eq-ie8 .data-table .action-.delete,
-.eq-ie8 .data-table .action-.delete:hover,
-.eq-ie8 .data-table .action-.delete:active,
-.eq-ie8 .data-table .action-.delete.active,
-.eq-ie8 .data-table .action-delete,
-.eq-ie8 .data-table .action-delete:hover,
-.eq-ie8 .data-table .action-delete:active,
-.eq-ie8 .data-table .action-delete.active,
-.eq-ie8 .data-table .action-locked,
-.eq-ie8 .data-table .action-locked:hover,
-.eq-ie8 .data-table .action-locked:active,
-.eq-ie8 .data-table .action-locked.active,
-.eq-ie8 #product-variations-matrix .action-choose,
-.eq-ie8 #product-variations-matrix .action-choose:hover,
-.eq-ie8 #product-variations-matrix .action-choose:active,
-.eq-ie8 #product-variations-matrix .action-choose.active,
-.eq-ie8 .image-panel .action-close,
-.eq-ie8 .eq-ie8 .image-panel .action-close:hover,
-.eq-ie8 .image-panel .action-close:active,
-.eq-ie8 .image-panel .action-close.active,
-.eq-ie8 .image-panel-controls .action-remove,
-.eq-ie8 .image-panel-controls .action-remove:hover,
-.eq-ie8 .image-panel-controls .action-remove:active,
-.eq-ie8 .image-panel-controls .action-remove.active,
-.eq-ie8 .suggest-expandable .action-show-all,
-.eq-ie8 .suggest-expandable .action-show-all:hover,
-.eq-ie8 .suggest-expandable .action-show-all:active,
-.eq-ie8 .suggest-expandable .action-show-all.active,
-.eq-ie8 .vde-tools-header .action-close,
-.eq-ie8 .vde-tools-header .action-close:hover,
-.eq-ie8 .vde-tools-header .action-close:active,
-.eq-ie8 .vde-tools-header .action-close.active,
-.eq-ie8 .image .action-delete,
-.eq-ie8 .image .action-delete:hover,
-.eq-ie8 .image .action-delete:active,
-.eq-ie8 .image .action-delete.active,
-.eq-ie8 .fieldset-wrapper-title .actions .action-delete,
-.eq-ie8 .fieldset-wrapper-title .actions .action-delete:hover,
-.eq-ie8 .fieldset-wrapper-title .actions .action-delete:active,
-.eq-ie8 .fieldset-wrapper-title .actions .action-delete.active,
-.eq-ie8 .address-list-item-actions .action-delete,
-.eq-ie8 .address-list-item-actions .action-delete:hover,
-.eq-ie8 .address-list-item-actions .action-delete:active,
-.eq-ie8 .address-list-item-actions .action-delete.active,
-.eq-ie8 .notification .action-close,
-.eq-ie8 .notification .action-close:hover,
-.eq-ie8 .notification .action-close:active,
-.eq-ie8 .notification .action-close.active,
-.eq-ie8 .page-login .action-forgotpassword,
-.eq-ie8 .page-login .action-forgotpassword:hover,
-.eq-ie8 .page-login .action-forgotpassword:active,
-.eq-ie8 .page-login .action-forgotpassword.active,
-.eq-ie8 .page-login .action-back,
-.eq-ie8 .page-login .action-back:hover,
-.eq-ie8 .page-login .action-back:active,
-.eq-ie8 .page-login .action-back.active {
-    border: none;
-    border-radius: 0;
-    background: none;
-    margin: 0;
-    padding: 0;
-    box-shadow: none;
-    text-shadow: none;
-    filter: none;
-}
-
 .data-table .action-.delete[disabled],
 .data-table .action-delete[disabled],
 .data-table .action-locked[disabled],
@@ -779,10 +708,6 @@
     height: 31px;
 }
 
-.eq-ie8 .actions-image-uploader .action-upload {
-    filter: none;
-}
-
 .actions-image-uploader .action-toggle,
 .actions-image-uploader .action-toggle:hover,
 .actions-image-uploader .action-toggle:active,
@@ -1033,10 +958,6 @@ select[disabled].multiselect > option[selected] {
     background: #6d6d6d;
 }
 
-.eq-ie8 select[disabled="disabled"][multiple="multiple"] option[selected="selected"] {
-    background-color: #ddd;
-}
-
 textarea:-moz-placeholder,
 input:-moz-placeholder {
     color: #999 !important;
@@ -1208,10 +1129,6 @@ input.mage-error ~ .addafter {
     position: relative;
 }
 
-.eq-ie8 .fieldset {
-    border-width: 0 0 1px;
-}
-
 .fieldset-wrapper > .fieldset-wrapper-title,
 .fieldset > .legend {
     position: static;
@@ -1304,11 +1221,6 @@ input.mage-error ~ .addafter {
     border-radius: 5px;
 }
 
-.eq-ie8 .fieldset .fieldset-wrapper .fieldset-wrapper-title,
-.eq-ie8 .fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title {
-    background: #f4f2ef;
-}
-
 .fieldset .fieldset-wrapper.opened .fieldset-wrapper-title,
 .fieldset-wrapper .fieldset-wrapper.opened .fieldset-wrapper-title {
     border-radius: 5px 5px 0 0;
@@ -1396,16 +1308,6 @@ input.mage-error ~ .addafter {
     margin: 0 0 29px;
 }
 
-.eq-ie8 .fieldset-alt,
-.eq-ie8 .fieldset-alt > .fieldset {
-    display: block;
-    width: 100%;
-}
-
-.eq-ie8 .fieldset-alt > .field {
-    display: inline-block;
-}
-
 .fieldset .comment {
     margin: 0 0 29px 10px;
 }
@@ -1712,13 +1614,6 @@ input.mage-error ~ .addafter {
     border-radius: 0 4px 4px 0;
 }
 
-.eq-ie8 .field.type-price .addon .addafter,
-.eq-ie8 .field-price .addon .addafter,
-.eq-ie8 .field-special_price .addon .addafter,
-.eq-ie8 .field-msrp .addon .addafter {
-    border-width: 1px 1px 1px 0;
-}
-
 .field.type-price input,
 .field-price input,
 .field-special_price input,
@@ -1749,10 +1644,6 @@ input.mage-error ~ .addafter {
     margin-right: -2px;
 }
 
-.eq-ie8 .field-apply_to .multiselect {
-    height: 120px;
-}
-
 /*
     Calendar
 -------------------------------------- */
@@ -2153,10 +2044,6 @@ table tbody tr:nth-child(odd):hover th {
     z-index: 2;
 }
 
-.eq-ie8 .popup-loading {
-    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
-}
-
 /* Loading mask */
 .loading-old,
 .loading-mask {
@@ -2201,18 +2088,6 @@ table tbody tr:nth-child(odd):hover th {
     margin-top: 118px;
 }
 
-.eq-ie8 .loading-old,
-.eq-ie8 .loading-mask {
-    background: #fff;
-    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
-}
-
-/* Backup popup */
-/* TODO: remove after backups page js refactoring */
-.backup-dialog {
-    margin-top: inherit !important;
-}
-
 /* Backup popup */
 /* TODO: remove after backups page js refactoring */
 .backup-dialog {
@@ -2237,14 +2112,6 @@ table tbody tr:nth-child(odd):hover th {
     padding: 0 20px;
 }
 
-.navigation:hover .level-0 > a {
-    /*background: red !important;*/
-}
-
-.eq-ie8 .navigation {
-    background: #726c62;
-}
-
 .navigation:before {
     position: absolute;
     left: 0;
@@ -2256,10 +2123,6 @@ table tbody tr:nth-child(odd):hover th {
     z-index: 991;
 }
 
-.eq-ie8 .navigation:before {
-    border-top: 1px solid #46433d;
-}
-
 .navigation:after {
     position: absolute;
     left: 0;
@@ -2351,12 +2214,7 @@ table tbody tr:nth-child(odd):hover th {
     background: linear-gradient(to bottom, #625d54 1%, #565249 100%);
 }
 
-.eq-ie8 .navigation .level-0.active > a {
-    background: #625d54;
-}
-
-/*.navigation .level-0:hover > a,
-.eq-ie8 .navigation .level-0:hover > a,*/
+//.navigation .level-0:hover > a,
 .navigation .level-0.hover.recent > a {
     background: #fff;
     .style15I();
@@ -2383,13 +2241,6 @@ table tbody tr:nth-child(odd):hover th {
     display: block;
 }
 
-.eq-ie8 .navigation .level-0.active > a,
-.eq-ie8 .navigation .level-0:hover > a,
-.eq-ie8 .navigation .level-0.hover > a {
-    border-top: 1px solid #46433d;
-    padding-top: 36px;
-}
-
 .navigation .level-0 > a:before {
     position: absolute;
     left: 0;
@@ -2481,10 +2332,6 @@ table tbody tr:nth-child(odd):hover th {
     vertical-align: top;
 }
 
-.eq-ie8 .navigation .level-0 > .submenu .column {
-    float: left;
-}
-
 .navigation .level-0 .submenu .level-1 {
     white-space: normal;
 }
@@ -2543,16 +2390,6 @@ table tbody tr:nth-child(odd):hover th {
     padding: 0;
 }
 
-.eq-ie8 .navigation .level-0.item-system > a,
-.eq-ie8 .navigation .level-0.item-system:hover > a,
-.eq-ie8 .navigation .level-0.item-system.hover > a,
-.eq-ie8 .navigation .level-0.item-stores > a,
-.eq-ie8 .navigation .level-0.item-stores:hover > a,
-.eq-ie8 .navigation .level-0.item-stores.hover > a {
-    border-top: 0;
-    padding-top: 0;
-}
-
 .navigation .level-0.item-system:hover > a,
 .navigation .level-0.item-system.hover > a,
 .navigation .level-0.item-stores:hover > a,
@@ -2608,11 +2445,7 @@ table tbody tr:nth-child(odd):hover th {
 }
 
 .no-js .navigation .level-0.last:hover > a:before,
-.navigation .level-0.last.hover > a:before,
-.eq-ie8 .navigation .level-0.item-system > a:before,
-.eq-ie8 .navigation .level-0.item-system > a:after,
-.eq-ie8 .navigation .level-0.item-stores > a:before,
-.eq-ie8 .navigation .level-0.item-stores > a:after {
+.navigation .level-0.last.hover > a:before {
     display: none;
 }
 
@@ -2805,12 +2638,6 @@ table tbody tr:nth-child(odd):hover th {
     display: none;
 }
 
-.eq-ie8 .page-login .field-username label,
-.eq-ie8 .page-login .field-password label,
-.eq-ie8 .page-login .field-confirmation label {
-    display: block;
-}
-
 .page-login .form-inline .label + .control {
     width: auto;
     float: none;
@@ -2832,55 +2659,56 @@ table tbody tr:nth-child(odd):hover th {
     background: url(Magento_Backend::images/logo-magento.png) no-repeat;
 }
 
-/*
-.page-login .logo {
-    display: block;
-    width: 100px;
-    height: 65px;
-    margin: 0;
-    text-indent: -999em;
-    position: relative;
-    z-index: 1;
-}
-
-.page-login .logo:before,
-.page-login .logo:after {
-    font-family: 'admin-icons';
-    font-size: 65px;
-    content: '\e00d';
-    position: absolute;
-    bottom: 0;
-    left: 0;
-    text-indent: 0;
-    line-height: 1;
-    font-weight: normal;
-}
-
-.page-login .logo:before {
-    content: '\e00d';
-    color: #f37b20;
-}
-
-.page-login .logo:after {
-    content: '\e00e';
-    color: #fab57f;
-}
-
-.page-login .logo span:before {
-    font-family: 'admin-icons';
-    content: '\e00f';
-    display: block;
-    position: absolute;
-    top: 0;
-    bottom: 0;
-    left: 70px;
-    font-size: 154px;
-    margin-top: -42px;
-    text-indent: 0;
-    line-height: 1;
-    font-weight: normal;
-    color: #000;
-}*/
+///*
+//.page-login .logo {
+//    display: block;
+//    width: 100px;
+//    height: 65px;
+//    margin: 0;
+//    text-indent: -999em;
+//    position: relative;
+//    z-index: 1;
+//}
+//
+//.page-login .logo:before,
+//.page-login .logo:after {
+//    font-family: 'admin-icons';
+//    font-size: 65px;
+//    content: '\e00d';
+//    position: absolute;
+//    bottom: 0;
+//    left: 0;
+//    text-indent: 0;
+//    line-height: 1;
+//    font-weight: normal;
+//}
+//
+//.page-login .logo:before {
+//    content: '\e00d';
+//    color: #f37b20;
+//}
+//
+//.page-login .logo:after {
+//    content: '\e00e';
+//    color: #fab57f;
+//}
+//
+//.page-login .logo span:before {
+//    font-family: 'admin-icons';
+//    content: '\e00f';
+//    display: block;
+//    position: absolute;
+//    top: 0;
+//    bottom: 0;
+//    left: 70px;
+//    font-size: 154px;
+//    margin-top: -42px;
+//    text-indent: 0;
+//    line-height: 1;
+//    font-weight: normal;
+//    color: #000;
+//}
+//*/
 
 .page-login .form-actions {
     padding: 0;
@@ -3068,10 +2896,6 @@ table tbody tr:nth-child(odd):hover th {
     z-index: 994;
 }
 
-.eq-ie8 .message-noscript {
-    border-bottom: 1px solid #46433d;
-}
-
 .message-noscript .message-content {
     margin: 0 auto;
     max-width: 1300px;
@@ -3113,10 +2937,6 @@ table tbody tr:nth-child(odd):hover th {
     z-index: 993;
 }
 
-.eq-ie8 .message-demo-mode {
-    border-bottom: 1px solid #46433d;
-}
-
 .message-demo-mode:before {
     content: '';
 }
@@ -3232,14 +3052,9 @@ table tbody tr:nth-child(odd):hover th {
     vertical-align: text-top;
 }
 
-.eq-ie8 .store-switcher-alt .store-selected:after {
-    vertical-align: middle;
-}
-
 .store-switcher-alt .store-switcher-website,
 .store-switcher-alt .store-switcher-store {
     padding: 0;
-
 }
 
 .store-switcher-alt .store-switcher-website:hover,
@@ -3275,15 +3090,6 @@ table tbody tr:nth-child(odd):hover th {
     border-top: 1px solid #e5e5e5;
 }
 
-.eq-ie8 .store-switcher-website {
-    border-bottom: 0;
-}
-
-.eq-ie8 .store-switcher-store-view {
-    border-bottom: 0;
-    border-top: 1px solid #e5e5e5;
-}
-
 .store-switcher-store-view > a {
     display: block;
     padding: 5px 15px 5px 24px;
@@ -3492,7 +3298,7 @@ table tbody tr:nth-child(odd):hover th {
 /*
     Universal Sidebar Tabs
 -------------------------------------- */
-/* TODO: for "Product" page only while refactoring */
+// TODO: for "Product" page only while refactoring */
 
 .side-col .ui-tabs .ui-accordion-header {
     position: relative;
@@ -3821,22 +3627,6 @@ table tbody tr:nth-child(odd):hover th {
     content: attr(data-text-on);
 }
 
-.eq-ie8 .switcher-label:after {
-    content: 'off';
-    overflow: hidden;
-    white-space: nowrap;
-    text-indent: 100%;
-}
-
-.eq-ie8 .switcher.checked .switcher-label:after {
-    background-position: -34px 0;
-    content: 'on';
-}
-
-.eq-ie8 .switcher.checked .switcher-label:before {
-    content: attr(data-text-on);
-}
-
 /*
     Content actions panel (with buttons, switchers...)
 -------------------------------------- */
@@ -4004,19 +3794,10 @@ table tbody tr:nth-child(odd):hover th {
     text-align: center;
     padding: 15px;
 }
-
-.eq-ie8 .grid table td.empty-text {
-    border-width: 0 1px 1px;
-}
-
 .grid table tr:last-child td.empty-text {
     border-width: 0 1px 1px;
 }
 
-.eq-ie8 .grid table tr td.empty-text {
-    border-width: 0 1px 1px;
-}
-
 .grid table td.empty-text:hover {
     background: #e6e3de;
 }
@@ -4381,10 +4162,6 @@ table tbody tr:nth-child(odd):hover th {
     opacity: 0;
 }
 
-.eq-ie8 .grid .filter .date img {
-    filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0);
-}
-
 .grid .filter .date:before {
     position: absolute;
     left: 80%;
@@ -4418,10 +4195,6 @@ table tbody tr:nth-child(odd):hover th {
     overflow: hidden;
 }
 
-.eq-ie8 .massaction {
-    border-bottom: 2px solid #504d46;
-}
-
 .massaction ul {
     list-style: none;
     margin: 0;
@@ -4470,14 +4243,6 @@ table tbody tr:nth-child(odd):hover th {
     vertical-align: middle;
 }
 
-.eq-ie8 .massaction .entry-edit .field-row:first-child {
-    margin-right: 1px;
-}
-
-.eq-ie8 .massaction .entry-edit .field-row {
-    display: inline;
-}
-
 .massaction .entry-edit .outer-span .entry-edit {
     float: none;
 }
@@ -4610,48 +4375,48 @@ tr.dynamic-grid input.input-text {
     white-space: normal;
 }
 
-/* will be deleted after checking entire back-end
-table .col-draggable {
-    width: 1%;
-}
-
-table .col-default,
-table .col-select,
-table .col-qty,
-table .col-actions,
-table .col-action,
-table .col-id,
-table .col-uqty.qty-box {
-    width: 5%;
-}
-
-table .col-visibility,
-table .col-status,
-table .col-websites,
-table .col-position {
-    width: 7%;
-}
-
-table .col-type,
-table .col-price,
-table .col-attr-name {
-    width: 8%;
-}
-
-table .col-name,
-table .col-sku {
-    width: 15%;
-}
-
-table .col-attribute_code,
-table .col-frontend_label {
-    width: 25%;
-}
-
-.ui-dialog .selection-search table .col-select {
-    width: 25%;
-}
-*/
+///* will be deleted after checking entire back-end
+//table .col-draggable {
+//    width: 1%;
+//}
+//
+//table .col-default,
+//table .col-select,
+//table .col-qty,
+//table .col-actions,
+//table .col-action,
+//table .col-id,
+//table .col-uqty.qty-box {
+//    width: 5%;
+//}
+//
+//table .col-visibility,
+//table .col-status,
+//table .col-websites,
+//table .col-position {
+//    width: 7%;
+//}
+//
+//table .col-type,
+//table .col-price,
+//table .col-attr-name {
+//    width: 8%;
+//}
+//
+//table .col-name,
+//table .col-sku {
+//    width: 15%;
+//}
+//
+//table .col-attribute_code,
+//table .col-frontend_label {
+//    width: 25%;
+//}
+//
+//.ui-dialog .selection-search table .col-select {
+//    width: 25%;
+//}
+//*/
 
 table .col-draggable .draggable-handle {
     position: relative;
@@ -4697,15 +4462,6 @@ table .col-draggable .draggable-handle {
     border-width: 0 0 1px;
 }
 
-.eq-ie8 .data-table td,
-.eq-ie8 .data-table tbody tr td {
-    border-width: 0 0 1px;
-}
-
-.eq-ie8 .data-table td > .field {
-    margin-bottom: 0;
-}
-
 .data-table tbody tr.selected td,
 .data-table tbody tr.selected th,
 .data-table tbody tr:hover td,
@@ -4729,10 +4485,6 @@ table .col-draggable .draggable-handle {
     border: 0;
 }
 
-.eq-ie8 .data-table tfoot tr td {
-    border: none;
-}
-
 .data-table input[type="text"] {
     width: 98%;
     padding-left: 1%;
@@ -4866,23 +4618,6 @@ table .col-draggable .draggable-handle {
     background-color: #fbfaf6;
 }
 
-.eq-ie8 .customer-information .data-table tbody tr td,
-.eq-ie8 .customer-information .data-table tbody tr th,
-.eq-ie8 .order-information .data-table tbody tr td,
-.eq-ie8 .order-information .data-table tbody tr th,
-.eq-ie8 .order-account-information .data-table tbody tr td,
-.eq-ie8 .order-account-information .data-table tbody tr th,
-.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr td,
-.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr th,
-.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr th,
-.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr td,
-.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr th,
-.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr td,
-.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr th,
-.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr td {
-    border-bottom: 1px solid #ededed;
-}
-
 /*
     Content alignments in tables
 -------------------------------------- */
@@ -5203,10 +4938,6 @@ table .col-draggable .draggable-handle {
     table-layout: fixed;
 }
 
-.eq-ie8 .widget-layout-updates .data-table {
-    table-layout: auto;
-}
-
 .widget-layout-updates .data-table,
 .widget-layout-updates .data-table tr:nth-child(odd) td,
 .widget-layout-updates .data-table tr:nth-child(odd):hover td {
diff --git a/app/design/adminhtml/magento_backend/less/styles/base.less b/app/design/adminhtml/magento_backend/less/styles/base.less
index 8d3b401d83d648a39407ad5ecb53943f3fa62dce..a46576eb670fc0133506261cc95cfca684af186a 100644
--- a/app/design/adminhtml/magento_backend/less/styles/base.less
+++ b/app/design/adminhtml/magento_backend/less/styles/base.less
@@ -21,253 +21,6 @@
 // * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
 // */
 
-.actionLink() {
-    display: inline;
-    color: @linkColor;
-    text-decoration: none;
-    &:visited,
-    &:active {
-        color: @linkColor;
-    }
-    &:focus,
-    &:hover {
-        color: @linkColor;
-        text-decoration: underline;
-    }
-}
-
-.actionLinkI() {
-    display: inline;
-    color: @linkColor2;
-    text-decoration: underline;
-    &:visited,
-    &:active {
-        color: @linkColor2;
-    }
-    &:focus,
-    &:hover {
-        color: @linkColor2;
-        text-decoration: underline;
-    }
-}
-
-.style1() { // absent in design
-}
-
-.style2 {
-    color: @primary1;
-    font-size: 13px;
-    font-weight: @baseFontWeightSemibold;
-}
-
-.style3() {
-    color: @primary5;
-    font-size: 14px;
-    font-weight: @baseFontWeight;
-
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
-.style4() { // absent in design
-}
-
-.style5() { // absent in design
-}
-
-.style6() {
-    color: @primary5;
-    font-size: 13px;
-    font-weight: @baseFontWeight;
-
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
-.style7() {
-    color: @primary1;
-    font-size: 16px;
-    font-weight: @baseFontWeight;
-}
-
-.style8() {
-    color: @primary6;
-    font-size: 13px;
-    font-weight: @baseFontWeight;
-}
-
-.style9() {
-    color: @primary1;
-    font-size: 14px;
-    font-weight: @baseFontWeight;
-}
-
-.style10() {
-    color: @primary1;
-    font-size: 20px;
-    font-weight: @baseFontWeight;
-}
-
-.style11() { // absent in design
-}
-
-.style12() { // absent in design
-}
-
-.style13() { // absent in design
-}
-
-.style14() {
-    color: @primary1;
-    font-size: 11px;
-    font-weight: @baseFontWeight;
-}
-
-.style15() {
-    color: @primary7;
-    font-size: 13px;
-    font-weight: @baseFontWeight;
-}
-
-.style15I() {
-    color: @primary1;
-    font-size: 13px;
-    font-weight: @baseFontWeight;
-}
-
-.style16() {
-    color: @primary4;
-    font-size: 12px;
-    font-weight: @baseFontWeightSemibold;
-}
-
-.style17() { // absent in design
-}
-
-.style18() {
-    color: @primary1;
-    font-size: 13px;
-    font-weight: @baseFontWeight;
-}
-
-.style19() {
-    color: @primary1;
-    font-size: 12px;
-    font-weight: @baseFontWeight;
-}
-
-.style20() { // absent in design
-    color: @primary2;
-    font-size: 12px;
-    font-weight: @baseFontWeightSemibold;
-}
-
-.style21() { // absent in design
-    color: @primary1;
-    font-size: 11px;
-    font-weight: @baseFontWeight;
-}
-
-.style22() {
-    color: @primary5;
-    font-size: 12px;
-    font-weight: @baseFontWeight;
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
-.style23() {
-    color: @primary1;
-    font-size: 28px;
-    font-weight: @baseFontWeight;
-}
-
-.style24() { // absent in design
-    color: @primary1;
-    font-size: 12px;
-    font-weight: @baseFontWeight;
-}
-
-.style25() { // absent in design
-    color: @primary8;
-    font-size: 14px;
-    font-weight: @baseFontWeight;
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
-.style26() { // absent in design
-    color: @primary4;
-    font-size: 30px;
-    font-weight: @baseFontWeightBold;
-}
-
-.style27() { // absent in design
-    color: @primary9;
-    font-size: 20px;
-    font-weight: @baseFontWeightBold;
-}
-
-.style28() {
-    color: @primary1;
-    font-size: 14px;
-    font-weight: @baseFontWeightBold;
-}
-
-.style29() {
-    color: @primary4;
-    font-size: 13px;
-    font-weight: @baseFontWeightBold;
-}
-
-.style30() {
-    color: @primary1;
-    font-size: 14px;
-    font-weight: @baseFontWeightSemibold;
-}
-
-.style31() {
-    color: @primary1;
-    font-size: 20px;
-    font-style: italic;
-    font-weight: @baseFontWeight;
-}
-
-.style32() {
-    color: @primary6;
-    font-size: 14px;
-    font-weight: @baseFontWeightBold;
-}
-
-.style33() {
-    color: @primary3;
-    font-size: 12px;
-    font-weight: @baseFontWeightSemibold;
-
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
-.style34() { // no such html yet
-    color: @primary2;
-    font-size: 12px;
-    font-weight: @baseFontWeight;
-    &:focus,
-    &:hover {
-        text-decoration: underline;
-    }
-}
-
 // Fonts
 
 @font-face {
@@ -289,28 +42,28 @@
 /* @import url(http://fonts.googleapis.com/css?family=Open+Sans:400italic,400,600,700 <http://fonts.googleapis.com/css?family=Open+Sans:400italic%2c400%2c600%2c700>); */
 
 @font-face {
-  font-family: 'Open Sans';
-  font-style: normal;
-  font-weight: 400;
-  src: local('Open Sans'), local('OpenSans'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/cJZKeOuBrn4kERxqtaUH3T8E0i7KZn-EPnyo3HZu7kw.woff) format('woff');
+    font-family: 'Open Sans';
+    font-style: normal;
+    font-weight: 400;
+    src: local('Open Sans'), local('OpenSans'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/cJZKeOuBrn4kERxqtaUH3T8E0i7KZn-EPnyo3HZu7kw.woff) format('woff');
 }
 @font-face {
-  font-family: 'Open Sans';
-  font-style: normal;
-  font-weight: 600;
-  src: local('Open Sans Semibold'), local('OpenSans-Semibold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/MTP_ySUJH_bn48VBG8sNSnhCUOGz7vYGh680lGh-uXM.woff) format('woff');
+    font-family: 'Open Sans';
+    font-style: normal;
+    font-weight: 600;
+    src: local('Open Sans Semibold'), local('OpenSans-Semibold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/MTP_ySUJH_bn48VBG8sNSnhCUOGz7vYGh680lGh-uXM.woff) format('woff');
 }
 @font-face {
-  font-family: 'Open Sans';
-  font-style: normal;
-  font-weight: 700;
-  src: local('Open Sans Bold'), local('OpenSans-Bold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/k3k702ZOKiLJc3WVjuplzHhCUOGz7vYGh680lGh-uXM.woff) format('woff');
+    font-family: 'Open Sans';
+    font-style: normal;
+    font-weight: 700;
+    src: local('Open Sans Bold'), local('OpenSans-Bold'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/k3k702ZOKiLJc3WVjuplzHhCUOGz7vYGh680lGh-uXM.woff) format('woff');
 }
 @font-face {
-  font-family: 'Open Sans';
-  font-style: italic;
-  font-weight: 400;
-  src: local('Open Sans Italic'), local('OpenSans-Italic'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/xjAJXh38I15wypJXxuGMBobN6UDyHWBl620a-IRfuBk.woff) format('woff');
+    font-family: 'Open Sans';
+    font-style: italic;
+    font-weight: 400;
+    src: local('Open Sans Italic'), local('OpenSans-Italic'), url(//themes.googleusercontent.com/static/fonts/opensans/v6/xjAJXh38I15wypJXxuGMBobN6UDyHWBl620a-IRfuBk.woff) format('woff');
 }
 
 // Base
@@ -364,4 +117,4 @@ h6 {
 
 a {
     .actionLink();
-}
\ No newline at end of file
+}
diff --git a/app/design/adminhtml/magento_backend/less/styles/debug.less b/app/design/adminhtml/magento_backend/less/styles/debug.less
index 276e70485ad7550ddd2213d364fdd5c937afaf6e..5ed22427aee0823613461a3c9218d56a00c1758e 100644
--- a/app/design/adminhtml/magento_backend/less/styles/debug.less
+++ b/app/design/adminhtml/magento_backend/less/styles/debug.less
@@ -21,28 +21,28 @@
 //  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
 //  */
 
-/*
-    This file was created to debug old classes in order to indicate where we must replase it with new ones
-    The types of messages are generated in file: \app\code\core\Mage\Core\Block\Messages.php like $html .= '<' . $this->_messagesSecondLevelTagName . ' class="' . $type . '-msg">';
--------------------------------------- */
-
-/*
-    All messages to identify and refactor:
-
-label.mage-error,
-.notice,
-.messages ul,
-.messages li,
-.messages ul li,
-.error-msg,
-.success-msg,
-.notice-msg,
-.warning-msg
-
-Done:
-.notification-global
-.notification-global-notice
--------------------------------------- */
+///*
+//    This file was created to debug old classes in order to indicate where we must replase it with new ones
+//    The types of messages are generated in file: \app\code\core\Mage\Core\Block\Messages.php like $html .= '<' . $this->_messagesSecondLevelTagName . ' class="' . $type . '-msg">';
+//-------------------------------------- */
+
+///*
+//    All messages to identify and refactor:
+//
+//label.mage-error,
+//.notice,
+//.messages ul,
+//.messages li,
+//.messages ul li,
+//.error-msg,
+//.success-msg,
+//.notice-msg,
+//.warning-msg
+//
+//Done:
+//.notification-global
+//.notification-global-notice
+//-------------------------------------- */
 .debug {
     border: 1px solid red !important;
 }
@@ -413,17 +413,6 @@ ul.messages li.success-msg li:before {
     display: none;
 }
 
-.eq-ie8 .accordion .config legend {
-    position: absolute;
-    left: -999em;
-    display: block;
-    width: 0;
-    height: 0;
-    padding: 0;
-    margin: 0;
-    overflow: hidden;
-}
-
 .accordion .config table {
     width: 100%;
 }
@@ -502,17 +491,17 @@ ul.messages li.success-msg li:before {
     margin-top:6px;
 }
 .accordion .config .value.with-tooltip .tooltip-content {
-    padding:15px;
-    right:0;
-    margin-left:0;
-    margin-right:-19px;
-    margin-bottom:10px;
-    left:auto;
-    top:auto;
-    bottom:100%;
-    width: 400px;
-    max-width: 400px;
-    line-height: 1.333;
+    padding: 18px;
+    margin: 0 -17px 10px 0;
+    right: 0;
+    bottom: 100%;
+    width: 239px;
+    max-width: 239px;
+    font-size: 13px;
+    line-height: 1.4;
+    background: #31302b;
+    background: rgba(49, 48, 43, .8);
+    border-radius: 5px;
 }
 .accordion .config .value.with-tooltip .tooltip-content:before {
     content: '';
@@ -525,7 +514,7 @@ ul.messages li.success-msg li:before {
     right: 20px;
     border-left: 5px solid transparent;
     border-right: 5px solid transparent;
-    border-top: 5px solid #000;
+    border-top: 5px solid #31302b;
     border-bottom:0;
     opacity: .8;
 }
diff --git a/app/design/adminhtml/magento_backend/less/styles/header.less b/app/design/adminhtml/magento_backend/less/styles/header.less
index 57b2ac82e0345bf2f888a1556c6e88a20a9b4e7e..b9352175bff1f1480e49c60857b81aba18ecbf22 100644
--- a/app/design/adminhtml/magento_backend/less/styles/header.less
+++ b/app/design/adminhtml/magento_backend/less/styles/header.less
@@ -1,5 +1,5 @@
-// /**
-//  * Magento
+/**
+ * Magento
  *
  * NOTICE OF LICENSE
  *
@@ -16,11 +16,12 @@
  * 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.
-//  *
-//  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
-//  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
-//  */
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
 
+@import "vars.less";
 /*
     Header
 -------------------------------------- */
@@ -38,10 +39,6 @@
     padding: 0 20px;
 }
 
-.eq-ie8 .header {
-    background: #f5f2ea;
-}
-
 .header-inner {
     min-width: 960px;
     max-width: 1300px;
@@ -57,55 +54,56 @@
     background: url(Magento_Backend::images/logo-magento-small.png) no-repeat;
     margin: 0;
 }
-/*
-.header .logo {
-    display: inline-block;
-    width: 100px;
-    height: 27px;
-    margin: 0;
-    text-indent: -999em;
-    position: relative;
-    z-index: 1;
-}
-
-.header .logo:before,
-.header .logo:after {
-    font-family: 'admin-icons';
-    font-size: 26px;
-    content: '\e00d';
-    position: absolute;
-    bottom: 0;
-    left: 0;
-    text-indent: 0;
-    line-height: 1;
-    font-weight: normal;
-}
-
-.header .logo:before {
-    content: '\e00d';
-    color: #f37b20;
-}
-
-.header .logo:after {
-    content: '\e00e';
-    color: #fab57f;
-}
-
-.header .logo span:before {
-    font-family: 'admin-icons';
-    content: '\e00f';
-    display: block;
-    position: absolute;
-    top: 0;
-    bottom: 0;
-    left: 28px;
-    font-size: 65px;
-    margin-top: -17px;
-    text-indent: 0;
-    line-height: 1;
-    font-weight: normal;
-    color: #000;
-}*/
+// /*
+//.header .logo {
+//    display: inline-block;
+//    width: 100px;
+//    height: 27px;
+//    margin: 0;
+//    text-indent: -999em;
+//    position: relative;
+//    z-index: 1;
+//}
+//
+//.header .logo:before,
+//.header .logo:after {
+//    font-family: 'admin-icons';
+//    font-size: 26px;
+//    content: '\e00d';
+//    position: absolute;
+//    bottom: 0;
+//    left: 0;
+//    text-indent: 0;
+//    line-height: 1;
+//    font-weight: normal;
+//}
+//
+//.header .logo:before {
+//    content: '\e00d';
+//    color: #f37b20;
+//}
+//
+//.header .logo:after {
+//    content: '\e00e';
+//    color: #fab57f;
+//}
+//
+//.header .logo span:before {
+//    font-family: 'admin-icons';
+//    content: '\e00f';
+//    display: block;
+//    position: absolute;
+//    top: 0;
+//    bottom: 0;
+//    left: 28px;
+//    font-size: 65px;
+//    margin-top: -17px;
+//    text-indent: 0;
+//    line-height: 1;
+//    font-weight: normal;
+//    color: #000;
+//}
+// */
 
 .header-panel {
     float: right;
@@ -128,10 +126,6 @@
     box-shadow: 0 2px 7px 2px rgba(0, 0, 0, 0.2);
 }
 
-.eq-ie8 .header-panel .dropdown-menu {
-    border: 1px solid #c3bcaf;
-}
-
 .header-panel .dropdown-menu > li {
     position: relative;
     padding: 20px 30px 13px 18px;
@@ -299,10 +293,6 @@
     color: #b0a798;
 }
 
-.eq-ie8 .header-panel .notifications-icon:before {
-    bottom: -6px;
-}
-
 .header-panel .notifications .value {
     .style16();
     line-height: 11px;
@@ -577,7 +567,7 @@
     padding-top: 14px;
     z-index: 2;
 }
-.eq-ie8 .header-panel .notifications > .dropdown-menu > li:hover,
+
 .header-panel .notifications > .dropdown-menu > li:first-child:hover,
 .header-panel .notifications > .dropdown-menu > li.first:hover,
 .header-panel .notifications > .dropdown-menu > li:last-child:hover,
@@ -590,10 +580,6 @@
     display: none;
 }
 
-.eq-ie8 .header-panel .dropdown-menu > li:hover:after {
-    display: block;
-}
-
 .header-panel .notifications > .dropdown-menu > li:hover .action-close {
     display: block;
 }
@@ -659,9 +645,6 @@
     text-indent: 0;
 }
 
-.eq-ie8 .header-panel .notifications > .dropdown-menu .action-close {
-    filter: none;
-}
 
 .header .header-panel .notifications .dropdown-menu > li.last {
     padding: 0;
@@ -682,18 +665,10 @@
     margin: 0;
 }
 
-.eq-ie8 .header .header-panel .notifications .action-more {
-    filter: none;
-}
-
 .header .header-panel .notifications .action-more:hover {
     text-decoration: none;
 }
 
-.eq-ie8 .header .header-panel .notifications .action-more {
-    margin-bottom: -1px;
-}
-
 /*
     Help
 -------------------------------------- */
@@ -756,14 +731,10 @@
 }
 
 .autocomplete-results {
-    left: 0 !important; /* TODO: Because of script bug in IE9 */
+    left: 0 !important; // TODO: Because of script bug in IE9
     right: 0;
 }
 
-.eq-ie8 .autocomplete-results {
-    margin-top: -10px;
-}
-
 .autocomplete-results .title {
     display: block;
 }
@@ -835,10 +806,6 @@
     text-align: center;
 }
 
-.eq-ie8 .search button[type="submit"]:before {
-    line-height: 1.3;
-}
-
 /*
     Clearfix
 -------------------------------------- */
diff --git a/app/design/adminhtml/magento_backend/less/styles/pages.less b/app/design/adminhtml/magento_backend/less/styles/pages.less
index 55d29b75e6d47a993b9c8042a67781f167c4b620..06197eccfadf5f0ba4efe63a7522fea78bd74291 100644
--- a/app/design/adminhtml/magento_backend/less/styles/pages.less
+++ b/app/design/adminhtml/magento_backend/less/styles/pages.less
@@ -1,5 +1,5 @@
-// /**
-//  * Magento
+/**
+ * Magento
  *
  * NOTICE OF LICENSE
  *
@@ -16,10 +16,12 @@
  * 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.
-//  *
-//  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
-//  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
-//  */
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
+
+@import "vars.less";
 
 /*
     Product Creation
@@ -38,12 +40,6 @@
     color: #7a7976;
 }
 
-.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back,
-.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:hover,
-.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:active,
-.eq-ie8 [class^=" newsletter-"] .page-actions .action-back,
-.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:hover,
-.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:active,
 .sales-order-create-index .page-actions-inner .cancel,
 .sales-order-create-index .page-actions-inner .cancel:hover,
 .sales-order-create-index .page-actions-inner .cancel:active {
@@ -103,9 +99,20 @@
     width: 100%;
 }
 
+#tab_content_downloadableInfo .data-table td {
+    vertical-align: top;
+    .row {
+        margin-bottom: 10px;
+    }
+}
+
 /*
     Customer
 ---------------------------------------*/
+.customer-index-edit .grid tr.headings th > span {
+    white-space: normal;
+}
+
 #customer_info_tabs_account_content #_accountsendemail {
     margin-top: 8px;
 }
@@ -464,6 +471,7 @@
 
 #export_filter_grid .grid select {
     margin-bottom: 0;
+    width: 86%;
 }
 
 #export_filter_grid .grid table td:first-child,
@@ -1619,6 +1627,17 @@
             }
         }
     }
+    .order-billing-method {
+        .payment-methods {
+            .fieldset {
+                padding: 0;
+                margin: 0;
+                .field {
+                    margin: 0 0 12px 0;
+                }
+            }
+        }
+    }
 }
 
 .tax.summary-total .summary-collapse {
@@ -1756,23 +1775,24 @@ tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-d
 }
 
 .overlay {
-    background: rgba(0, 0, 0, .3);
+    background: rgba(255, 255, 255, .5);
     border-radius: 5px;
     position: absolute;
     top: 0;
     bottom: 0;
     left: 0;
     right: 0;
-}
 
-.overlay span {
-    color: #111;
-    font-weight: bold;
-    position: absolute;
-    top: 50%;
-    left: 50%;
-    margin: -25px 0 0 -100px;
-    width: 200px;
+    span {
+        color: #111;
+        font-weight: bold;
+        position: absolute;
+        top: 56px;
+        left: 0;
+        margin: 0 8px;
+        padding: 10px;
+        background: #ffffff;
+    }
 }
 
 /*
@@ -2017,11 +2037,6 @@ tr.row-totals:nth-child(odd) + tr.summary-details ~ tr.summary-total:not(.show-d
     word-wrap: break-word;
 }
 
-.eq-ie8 .sales-order-index .col-1-layout table.data {
-    table-layout: auto;
-    word-wrap: normal;
-}
-
 [class^=" sales-"] .col-from-store {
     width: 15%;
 }
@@ -2797,7 +2812,9 @@ table.items-to-invoice tbody tr:hover td {
 .tax-rate-popup .field:before,
 .tax-rate-popup .field:after,
 .clearfix:before,
-.clearfix:after {
+.clearfix:after,
+#tab_content_downloadableInfo .data-table td .row:before,
+#tab_content_downloadableInfo .data-table td .row:after {
     content: "";
     display: table;
 }
@@ -2806,6 +2823,9 @@ table.items-to-invoice tbody tr:hover td {
 .image-panel:after,
 .images:after,
 .tax-rate-popup .field:after,
-.clearfix:after {
+.clearfix:after,
+#tab_content_downloadableInfo .data-table td .row:after {
     clear: both;
 }
+
+@import "debug.less";
diff --git a/app/design/adminhtml/magento_backend/less/styles/styles-ie8.less b/app/design/adminhtml/magento_backend/less/styles/styles-ie8.less
new file mode 100644
index 0000000000000000000000000000000000000000..dd8d4c7f517ffb6d1646d30fe3e55f7d4ca1474c
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/less/styles/styles-ie8.less
@@ -0,0 +1,372 @@
+/**
+ * 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.
+ *
+ * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ */
+
+// Reset 'button view' for actions
+.eq-ie8 .customer-current-activity .action-refresh,
+.eq-ie8 .pager .action-next,
+.eq-ie8 .pager .action-previous,
+.eq-ie8 .pager .action-next:hover,
+.eq-ie8 .pager .action-previous:hover,
+.eq-ie8 .pager .action-next.disabled:focus,
+.eq-ie8 .pager .action-previous.disabled:focus,
+.eq-ie8 .pager .action-next.disabled:active,
+.eq-ie8 .pager .action-previous.disabled:active,
+.eq-ie8 .data-table .action-.delete,
+.eq-ie8 .data-table .action-.delete:hover,
+.eq-ie8 .data-table .action-.delete:active,
+.eq-ie8 .data-table .action-.delete.active,
+.eq-ie8 .data-table .action-delete,
+.eq-ie8 .data-table .action-delete:hover,
+.eq-ie8 .data-table .action-delete:active,
+.eq-ie8 .data-table .action-delete.active,
+.eq-ie8 .data-table .action-locked,
+.eq-ie8 .data-table .action-locked:hover,
+.eq-ie8 .data-table .action-locked:active,
+.eq-ie8 .data-table .action-locked.active,
+.eq-ie8 #product-variations-matrix .action-choose,
+.eq-ie8 #product-variations-matrix .action-choose:hover,
+.eq-ie8 #product-variations-matrix .action-choose:active,
+.eq-ie8 #product-variations-matrix .action-choose.active,
+.eq-ie8 .image-panel .action-close,
+.eq-ie8 .eq-ie8 .image-panel .action-close:hover,
+.eq-ie8 .image-panel .action-close:active,
+.eq-ie8 .image-panel .action-close.active,
+.eq-ie8 .image-panel-controls .action-remove,
+.eq-ie8 .image-panel-controls .action-remove:hover,
+.eq-ie8 .image-panel-controls .action-remove:active,
+.eq-ie8 .image-panel-controls .action-remove.active,
+.eq-ie8 .suggest-expandable .action-show-all,
+.eq-ie8 .suggest-expandable .action-show-all:hover,
+.eq-ie8 .suggest-expandable .action-show-all:active,
+.eq-ie8 .suggest-expandable .action-show-all.active,
+.eq-ie8 .vde-tools-header .action-close,
+.eq-ie8 .vde-tools-header .action-close:hover,
+.eq-ie8 .vde-tools-header .action-close:active,
+.eq-ie8 .vde-tools-header .action-close.active,
+.eq-ie8 .image .action-delete,
+.eq-ie8 .image .action-delete:hover,
+.eq-ie8 .image .action-delete:active,
+.eq-ie8 .image .action-delete.active,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete:hover,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete:active,
+.eq-ie8 .fieldset-wrapper-title .actions .action-delete.active,
+.eq-ie8 .address-list-item-actions .action-delete,
+.eq-ie8 .address-list-item-actions .action-delete:hover,
+.eq-ie8 .address-list-item-actions .action-delete:active,
+.eq-ie8 .address-list-item-actions .action-delete.active,
+.eq-ie8 .notification .action-close,
+.eq-ie8 .notification .action-close:hover,
+.eq-ie8 .notification .action-close:active,
+.eq-ie8 .notification .action-close.active,
+.eq-ie8 .page-login .action-forgotpassword,
+.eq-ie8 .page-login .action-forgotpassword:hover,
+.eq-ie8 .page-login .action-forgotpassword:active,
+.eq-ie8 .page-login .action-forgotpassword.active,
+.eq-ie8 .page-login .action-back,
+.eq-ie8 .page-login .action-back:hover,
+.eq-ie8 .page-login .action-back:active,
+.eq-ie8 .page-login .action-back.active {
+    border: none;
+    border-radius: 0;
+    background: none;
+    margin: 0;
+    padding: 0;
+    box-shadow: none;
+    text-shadow: none;
+    filter: none;
+}
+
+// Variations Image Uploader
+
+.eq-ie8 .actions-image-uploader .action-upload {
+    filter: none;
+}
+
+// Forms
+
+.eq-ie8 select[disabled="disabled"][multiple="multiple"] option[selected="selected"] {
+    background-color: #ddd;
+}
+
+.eq-ie8 .fieldset {
+    border-width: 0 0 1px;
+}
+
+.eq-ie8 .fieldset .fieldset-wrapper .fieldset-wrapper-title,
+.eq-ie8 .fieldset-wrapper .fieldset-wrapper .fieldset-wrapper-title {
+    background: #f4f2ef;
+}
+
+.eq-ie8 .fieldset-alt,
+.eq-ie8 .fieldset-alt > .fieldset {
+    display: block;
+    width: 100%;
+}
+
+.eq-ie8 .fieldset-alt > .field {
+    display: inline-block;
+}
+
+.eq-ie8 .field.type-price .addon .addafter,
+.eq-ie8 .field-price .addon .addafter,
+.eq-ie8 .field-special_price .addon .addafter,
+.eq-ie8 .field-msrp .addon .addafter {
+    border-width: 1px 1px 1px 0;
+}
+
+.eq-ie8 .field-apply_to .multiselect {
+    height: 120px;
+}
+
+// Popups
+
+.eq-ie8 .popup-loading {
+    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
+}
+
+.eq-ie8 .loading-old,
+.eq-ie8 .loading-mask {
+    background: #fff;
+    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
+}
+
+// Global Navigation
+.eq-ie8 .navigation {
+    background: #726c62;
+}
+
+.eq-ie8 .navigation:before {
+    border-top: 1px solid #46433d;
+}
+
+.eq-ie8 .navigation .level-0.active > a {
+    background: #625d54;
+}
+
+.eq-ie8 .navigation .level-0.active > a,
+.eq-ie8 .navigation .level-0:hover > a,
+.eq-ie8 .navigation .level-0.hover > a {
+    border-top: 1px solid #46433d;
+    padding-top: 36px;
+}
+
+.eq-ie8 .navigation .level-0 > .submenu .column {
+    float: left;
+}
+
+.eq-ie8 .navigation .level-0.item-system > a,
+.eq-ie8 .navigation .level-0.item-system:hover > a,
+.eq-ie8 .navigation .level-0.item-system.hover > a,
+.eq-ie8 .navigation .level-0.item-stores > a,
+.eq-ie8 .navigation .level-0.item-stores:hover > a,
+.eq-ie8 .navigation .level-0.item-stores.hover > a {
+    border-top: 0;
+    padding-top: 0;
+}
+
+.eq-ie8 .navigation .level-0.item-system > a:before,
+.eq-ie8 .navigation .level-0.item-system > a:after,
+.eq-ie8 .navigation .level-0.item-stores > a:before,
+.eq-ie8 .navigation .level-0.item-stores > a:after {
+    display: none;
+}
+
+.eq-ie8 .page-login .field-username label,
+.eq-ie8 .page-login .field-password label,
+.eq-ie8 .page-login .field-confirmation label {
+    display: block;
+}
+
+.eq-ie8 .message-noscript,
+.eq-ie8 .message-demo-mode {
+    border-bottom: 1px solid #46433d;
+}
+
+// Switcher
+.eq-ie8 .store-switcher-alt .store-selected:after {
+    vertical-align: middle;
+}
+
+.eq-ie8 .store-switcher-website {
+    border-bottom: 0;
+}
+
+.eq-ie8 .store-switcher-store-view {
+    border-bottom: 0;
+    border-top: 1px solid #e5e5e5;
+}
+
+.eq-ie8 .switcher-label:after {
+    content: 'off';
+    overflow: hidden;
+    white-space: nowrap;
+    text-indent: 100%;
+}
+
+.eq-ie8 .switcher.checked .switcher-label:after {
+    background-position: -34px 0;
+    content: 'on';
+}
+
+.eq-ie8 .switcher.checked .switcher-label:before {
+    content: attr(data-text-on);
+}
+
+// Table Grid
+
+.eq-ie8 .grid table td.empty-text {
+    border-width: 0 1px 1px;
+}
+
+.eq-ie8 .grid table tr td.empty-text {
+    border-width: 0 1px 1px;
+}
+
+.eq-ie8 .grid .filter .date img {
+    filter: progid:DXImageTransform.Microsoft.Alpha(opacity=0);
+}
+
+.eq-ie8 .massaction .entry-edit .field-row:first-child {
+    margin-right: 1px;
+}
+
+.eq-ie8 .massaction .entry-edit .field-row {
+    display: inline;
+}
+
+// Data table
+
+.eq-ie8 .data-table td,
+.eq-ie8 .data-table tbody tr td {
+    border-width: 0 0 1px;
+}
+
+.eq-ie8 .data-table td > .field {
+    margin-bottom: 0;
+}
+
+.eq-ie8 .data-table tfoot tr td {
+    border: none;
+}
+
+// Data table - alternative view
+
+.eq-ie8 .customer-information .data-table tbody tr td,
+.eq-ie8 .customer-information .data-table tbody tr th,
+.eq-ie8 .order-information .data-table tbody tr td,
+.eq-ie8 .order-information .data-table tbody tr th,
+.eq-ie8 .order-account-information .data-table tbody tr td,
+.eq-ie8 .order-account-information .data-table tbody tr th,
+.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr td,
+.eq-ie8 [class^=" adminhtml-rma-"] .data-table tbody tr th,
+.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr th,
+.eq-ie8 [class^=" sales-transactions-"] .data-table tbody tr td,
+.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr th,
+.eq-ie8 [class^=" sales-"] .order-payment-method .data-table tbody tr td,
+.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr th,
+.eq-ie8 [class^=" sales-billing-agreement-"] .log-details .data-table tbody tr td {
+    border-bottom: 1px solid #ededed;
+}
+
+// Widgets
+.eq-ie8 .widget-layout-updates .data-table {
+    table-layout: auto;
+}
+
+// Grid - Mass Action
+
+.eq-ie8 .massaction {
+    border-bottom: 2px solid #504d46;
+}
+
+// Header
+.eq-ie8 .header {
+    background: #f5f2ea;
+}
+
+.eq-ie8 .header-panel .dropdown-menu {
+    border: 1px solid #c3bcaf;
+}
+
+.eq-ie8 .header-panel .notifications-icon:before {
+    bottom: -6px;
+}
+
+.eq-ie8 .header-panel .notifications > .dropdown-menu > li:hover {
+    margin-top: 0;
+    padding-top: 13px;
+}
+
+.eq-ie8 .header-panel .dropdown-menu > li:hover:after {
+    display: block;
+}
+
+.eq-ie8 .header-panel .notifications > .dropdown-menu .action-close {
+    filter: none;
+}
+
+.eq-ie8 .header .header-panel .notifications .action-more {
+    filter: none;
+}
+
+.eq-ie8 .header .header-panel .notifications .action-more {
+    margin-bottom: -1px;
+}
+
+.eq-ie8 .autocomplete-results {
+    margin-top: -10px;
+}
+
+.eq-ie8 .search button[type="submit"]:before {
+    line-height: 1.3;
+}
+
+// Product Creation
+
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back,
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:hover,
+.eq-ie8 [class^=" catalog-product-"] .page-actions .action-back:active,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:hover,
+.eq-ie8 [class^=" newsletter-"] .page-actions .action-back:active {
+    filter: none;
+    border: 0;
+}
+
+.eq-ie8 .sales-order-index .col-1-layout table.data {
+    table-layout: auto;
+    word-wrap: normal;
+}
+
+// Accordion
+.eq-ie8 .accordion .config legend {
+    position: absolute;
+    left: -999em;
+    display: block;
+    width: 0;
+    height: 0;
+    padding: 0;
+    margin: 0;
+    overflow: hidden;
+}
diff --git a/app/design/adminhtml/magento_backend/less/styles/vars.less b/app/design/adminhtml/magento_backend/less/styles/vars.less
new file mode 100644
index 0000000000000000000000000000000000000000..d1e4701b182816a5e85b02d33a491086a19a5eda
--- /dev/null
+++ b/app/design/adminhtml/magento_backend/less/styles/vars.less
@@ -0,0 +1,337 @@
+// /**
+//  * 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.
+//  *
+//  * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+//  * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+//  */
+
+@import "../clearless/all.less";
+
+@baseDir: ~"..";
+
+// Primary colors
+@primary1: #676056;
+@primary2: #ed4f2e;
+@primary3: #026294;
+@primary4: #fff;
+@primary5: #007dbd;
+@primary6: #e22626;
+@primary7: #f2ebde;
+@primary8: #31302b;
+@primary9: #ef672f;
+
+// Buttons
+// Default Buttons
+@defaultButton1: #f2ebde;
+@defaultButton2: #ada89e;
+@defaultButton3: #676056;
+@defaultButton4: #cac3b4;
+@defaultButton5: #989287;
+
+// Primary Buttons
+@primaryButton1: #007dbd;
+@primaryButton2: #0574ad;
+@primaryButton3: #026294;
+@primaryButton4: #004c74;
+
+// Links
+@linkColor: @primary3;
+@linkColor2: @primary4;
+
+// Base font
+@baseFont: 'Open Sans', sans-serif;
+@baseFontSize: 14px;
+@baseFontWeight: 400;
+@baseFontWeightSemibold: 600;
+@baseFontWeightBold: 700;
+@baseLineHeight: 1.33;
+@baseColor: @primary1;
+
+// Headings
+// H1
+@h1color: @primary1;
+@h1font: 400 28px/1.2 @baseFont;
+
+// H2
+@h2color: @primary1;
+@h2font: 400 20px/1.2 @baseFont;
+
+// H3
+@h3color: @primary1;
+@h3font: 600 16px/1.2 @baseFont;
+
+// H4
+@h4color: @primary1;
+@h4font: 600 14px/1.2 @baseFont;
+
+// H5
+@h5color: @primary1;
+@h5font: 600 13px/1.2 @baseFont;
+
+// H6
+@h6color: @primary1;
+@h6font: 600 12px/1.2 @baseFont;
+
+
+.actionLink() {
+    display: inline;
+    color: @linkColor;
+    text-decoration: none;
+    &:visited,
+    &:active {
+        color: @linkColor;
+    }
+    &:focus,
+    &:hover {
+        color: @linkColor;
+        text-decoration: underline;
+    }
+}
+
+.actionLinkI() {
+    display: inline;
+    color: @linkColor2;
+    text-decoration: underline;
+    &:visited,
+    &:active {
+        color: @linkColor2;
+    }
+    &:focus,
+    &:hover {
+        color: @linkColor2;
+        text-decoration: underline;
+    }
+}
+
+.style1() { // absent in design
+}
+
+.style2() {
+    color: @primary1;
+    font-size: 13px;
+    font-weight: @baseFontWeightSemibold;
+}
+
+.style3() {
+    color: @primary5;
+    font-size: 14px;
+    font-weight: @baseFontWeight;
+
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
+
+.style4() { // absent in design
+}
+
+.style5() { // absent in design
+}
+
+.style6() {
+    color: @primary5;
+    font-size: 13px;
+    font-weight: @baseFontWeight;
+
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
+
+.style7() {
+    color: @primary1;
+    font-size: 16px;
+    font-weight: @baseFontWeight;
+}
+
+.style8() {
+    color: @primary6;
+    font-size: 13px;
+    font-weight: @baseFontWeight;
+}
+
+.style9() {
+    color: @primary1;
+    font-size: 14px;
+    font-weight: @baseFontWeight;
+}
+
+.style10() {
+    color: @primary1;
+    font-size: 20px;
+    font-weight: @baseFontWeight;
+}
+
+.style11() { // absent in design
+}
+
+.style12() { // absent in design
+}
+
+.style13() { // absent in design
+}
+
+.style14() {
+    color: @primary1;
+    font-size: 11px;
+    font-weight: @baseFontWeight;
+}
+
+.style15() {
+    color: @primary7;
+    font-size: 13px;
+    font-weight: @baseFontWeight;
+}
+
+.style15I() {
+    color: @primary1;
+    font-size: 13px;
+    font-weight: @baseFontWeight;
+}
+
+.style16() {
+    color: @primary4;
+    font-size: 12px;
+    font-weight: @baseFontWeightSemibold;
+}
+
+.style17() { // absent in design
+}
+
+.style18() {
+    color: @primary1;
+    font-size: 13px;
+    font-weight: @baseFontWeight;
+}
+
+.style19() {
+    color: @primary1;
+    font-size: 12px;
+    font-weight: @baseFontWeight;
+}
+
+.style20() { // absent in design
+    color: @primary2;
+    font-size: 12px;
+    font-weight: @baseFontWeightSemibold;
+}
+
+.style21() { // absent in design
+    color: @primary1;
+    font-size: 11px;
+    font-weight: @baseFontWeight;
+}
+
+.style22() {
+    color: @primary5;
+    font-size: 12px;
+    font-weight: @baseFontWeight;
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
+
+.style23() {
+    color: @primary1;
+    font-size: 28px;
+    font-weight: @baseFontWeight;
+}
+
+.style24() { // absent in design
+    color: @primary1;
+    font-size: 12px;
+    font-weight: @baseFontWeight;
+}
+
+.style25() { // absent in design
+    color: @primary8;
+    font-size: 14px;
+    font-weight: @baseFontWeight;
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
+
+.style26() { // absent in design
+    color: @primary4;
+    font-size: 30px;
+    font-weight: @baseFontWeightBold;
+}
+
+.style27() { // absent in design
+    color: @primary9;
+    font-size: 20px;
+    font-weight: @baseFontWeightBold;
+}
+
+.style28() {
+    color: @primary1;
+    font-size: 14px;
+    font-weight: @baseFontWeightBold;
+}
+
+.style29() {
+    color: @primary4;
+    font-size: 13px;
+    font-weight: @baseFontWeightBold;
+}
+
+.style30() {
+    color: @primary1;
+    font-size: 14px;
+    font-weight: @baseFontWeightSemibold;
+}
+
+.style31() {
+    color: @primary1;
+    font-size: 20px;
+    font-style: italic;
+    font-weight: @baseFontWeight;
+}
+
+.style32() {
+    color: @primary6;
+    font-size: 14px;
+    font-weight: @baseFontWeightBold;
+}
+
+.style33() {
+    color: @primary3;
+    font-size: 12px;
+    font-weight: @baseFontWeightSemibold;
+
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
+
+.style34() { // no such html yet
+    color: @primary2;
+    font-size: 12px;
+    font-weight: @baseFontWeight;
+    &:focus,
+    &:hover {
+        text-decoration: underline;
+    }
+}
diff --git a/app/design/frontend/magento_plushe/Magento_Theme/layout/default_head_blocks.xml b/app/design/frontend/magento_plushe/Magento_Theme/layout/default_head_blocks.xml
index baaa059b8b8da53a3efa2bdb036c2e232ab2d681..87820ad284cbda2284d910fdbdbd3419753da917 100644
--- a/app/design/frontend/magento_plushe/Magento_Theme/layout/default_head_blocks.xml
+++ b/app/design/frontend/magento_plushe/Magento_Theme/layout/default_head_blocks.xml
@@ -32,7 +32,7 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-matchmedia-js">
             <arguments>
-                <argument name="file" xsi:type="string">js/matchMedia.js</argument>
+                <argument name="file" xsi:type="string">matchMedia.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-responsive-js">
@@ -42,7 +42,7 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-head-js">
             <arguments>
-                <argument name="file" xsi:type="string">js/head.js</argument>
+                <argument name="file" xsi:type="string">headjs/head.min.js</argument>
             </arguments>
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-jquery-dropdowns-js">
@@ -67,7 +67,7 @@
         </block>
         <block class="Magento\Theme\Block\Html\Head\Script" name="js-selectivizr-js">
             <arguments>
-                <argument name="file" xsi:type="string">js/selectivizr.js</argument>
+                <argument name="file" xsi:type="string">selectivizr.js</argument>
                 <argument name="properties" xsi:type="array">
                     <item name="ie_condition" xsi:type="string">lt IE 9</item>
                 </argument>
diff --git a/app/design/frontend/magento_plushe/css/styles.css b/app/design/frontend/magento_plushe/css/styles.css
index 16a5de8bdb00535ec7c94c69abc888fdaa2719fc..6b5a8b9d13789502d35843114778818e6a02ce07 100644
--- a/app/design/frontend/magento_plushe/css/styles.css
+++ b/app/design/frontend/magento_plushe/css/styles.css
@@ -5278,6 +5278,19 @@ body {
   padding: 0;
   margin: 0 0 30px;
 }
+.block.progress.onepage dd.complete .cards.items dd {
+  margin-left: 0;
+}
+.block.progress.onepage dd.complete .cards.items dd .card.item {
+  font-size: 12px;
+  margin: 5px 0 10px;
+}
+.block.progress.onepage dd.complete .cards.items dd .card.item dt {
+  font-weight: bold;
+}
+.block.progress.onepage dd.complete .cards.items dd .card.item dd {
+  margin-bottom: 5px;
+}
 .block.progress.onepage address {
   font-style: normal;
 }
diff --git a/app/design/frontend/magento_plushe/js/extra-options.js b/app/design/frontend/magento_plushe/js/extra-options.js
index a7457b18dc75d67de33a81f95db1d0222f3719ab..5e32b5cc2e12b392d87abec6c1787ff3e682fba0 100644
--- a/app/design/frontend/magento_plushe/js/extra-options.js
+++ b/app/design/frontend/magento_plushe/js/extra-options.js
@@ -17,8 +17,6 @@
  * versions in the future. If you wish to customize Magento for your
  * needs please refer to http://www.magentocommerce.com for more information.
  *
- * @category    gift options
- * @package     mage
  * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
  * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
  */
diff --git a/app/design/frontend/magento_plushe/js/head.js b/app/design/frontend/magento_plushe/js/head.js
deleted file mode 100644
index 67de77740949bcedf9cfcad1034ce8a90a2f5cd6..0000000000000000000000000000000000000000
--- a/app/design/frontend/magento_plushe/js/head.js
+++ /dev/null
@@ -1,356 +0,0 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
-
-(function (a, w) {
-    function f(a) {
-        p[p.length] = a
-    }
-
-    function m(a) {
-        q.className = q.className.replace(RegExp("\\b" + a + "\\b"), "")
-    }
-
-    function k(a, d) {
-        for (var b = 0, c = a.length; b < c; b++)d.call(a, a[b], b)
-    }
-
-    function s() {
-        q.className = q.className.replace(/ (w-|eq-|gt-|gte-|lt-|lte-|portrait|no-portrait|landscape|no-landscape)\d+/g, "");
-        var b = a.innerWidth || q.clientWidth, d = a.outerWidth || a.screen.width;
-        h.screen.innerWidth = b;
-        h.screen.outerWidth = d;
-        f("w-" + b);
-        k(c.screens, function (a) {
-            b > a ? (c.screensCss.gt && f("gt-" + a), c.screensCss.gte && f("gte-" +
-                a)) : b < a ? (c.screensCss.lt && f("lt-" + a), c.screensCss.lte && f("lte-" + a)) : b === a && (c.screensCss.lte && f("lte-" + a), c.screensCss.eq && f("e-q" + a), c.screensCss.gte && f("gte-" + a))
-        });
-        var d = a.innerHeight || q.clientHeight, g = a.outerHeight || a.screen.height;
-        h.screen.innerHeight = d;
-        h.screen.outerHeight = g;
-        h.feature("portrait", d > b);
-        h.feature("landscape", d < b)
-    }
-
-    function r() {
-        a.clearTimeout(u);
-        u = a.setTimeout(s, 100)
-    }
-
-    var n = a.document, g = a.navigator, t = a.location, q = n.documentElement, p = [], c = {screens:[240, 320, 480, 640, 768, 800, 1024, 1280,
-        1440, 1680, 1920], screensCss:{gt:!0, gte:!1, lt:!0, lte:!1, eq:!1}, browsers:[
-        {ie:{min:6, max:10}}
-    ], browserCss:{gt:!0, gte:!1, lt:!0, lte:!1, eq:!0}, section:"-section", page:"-page", head:"head"};
-    if (a.head_conf)for (var b in a.head_conf)a.head_conf[b] !== w && (c[b] = a.head_conf[b]);
-    var h = a[c.head] = function () {
-        h.ready.apply(null, arguments)
-    };
-    h.feature = function (a, b, c) {
-        if (!a)return q.className += " " + p.join(" "), p = [], h;
-        "[object Function]" === Object.prototype.toString.call(b) && (b = b.call());
-        f((b ? "" : "no-") + a);
-        h[a] = !!b;
-        c || (m("no-" +
-            a), m(a), h.feature());
-        return h
-    };
-    h.feature("js", !0);
-    b = g.userAgent.toLowerCase();
-    g = /mobile|midp/.test(b);
-    h.feature("mobile", g, !0);
-    h.feature("desktop", !g, !0);
-    b = /(chrome|firefox)[ \/]([\w.]+)/.exec(b) || /(iphone|ipad|ipod)(?:.*version)?[ \/]([\w.]+)/.exec(b) || /(android)(?:.*version)?[ \/]([\w.]+)/.exec(b) || /(webkit|opera)(?:.*version)?[ \/]([\w.]+)/.exec(b) || /(msie) ([\w.]+)/.exec(b) || [];
-    g = b[1];
-    b = parseFloat(b[2]);
-    switch (g) {
-        case "msie":
-            g = "ie";
-            b = n.documentMode || b;
-            break;
-        case "firefox":
-            g = "ff";
-            break;
-        case "ipod":
-        case "ipad":
-        case "iphone":
-            g =
-                "ios";
-            break;
-        case "webkit":
-            g = "safari"
-    }
-    h.browser = {name:g, version:b};
-    h.browser[g] = !0;
-    for (var v = 0, x = c.browsers.length; v < x; v++)for (var i in c.browsers[v])if (g === i) {
-        f(i);
-        for (var A = c.browsers[v][i].max, l = c.browsers[v][i].min; l <= A; l++)b > l ? (c.browserCss.gt && f("gt-" + i + l), c.browserCss.gte && f("gte-" + i + l)) : b < l ? (c.browserCss.lt && f("lt-" + i + l), c.browserCss.lte && f("lte-" + i + l)) : b === l && (c.browserCss.lte && f("lte-" + i + l), c.browserCss.eq && f("eq-" + i + l), c.browserCss.gte && f("gte-" + i + l))
-    } else f("no-" + i);
-    "ie" === g && 9 > b && k("abbr article aside audio canvas details figcaption figure footer header hgroup mark meter nav output progress section summary time video".split(" "),
-        function (a) {
-            n.createElement(a)
-        });
-    k(t.pathname.split("/"), function (a, b) {
-        if (2 < this.length && this[b + 1] !== w)b && f(this.slice(1, b + 1).join("-").toLowerCase() + c.section); else {
-            var g = a || "index", h = g.indexOf(".");
-            0 < h && (g = g.substring(0, h));
-            q.id = g.toLowerCase() + c.page;
-            b || f("root" + c.section)
-        }
-    });
-    h.screen = {height:a.screen.height, width:a.screen.width};
-    s();
-    var u = 0;
-    a.addEventListener ? a.addEventListener("resize", r, !1) : a.attachEvent("onresize", r)
-})(window);
-(function (a, w) {
-    function f(a) {
-        var f = a.charAt(0).toUpperCase() + a.substr(1), a = (a + " " + r.join(f + " ") + f).split(" "), c;
-        a:{
-            for (c in a)if (k[a[c]] !== w) {
-                c = !0;
-                break a
-            }
-            c = !1
-        }
-        return!!c
-    }
-
-    var m = a.document.createElement("i"), k = m.style, s = " -o- -moz- -ms- -webkit- -khtml- ".split(" "), r = ["Webkit", "Moz", "O", "ms", "Khtml"], n = a[a.head_conf && a.head_conf.head || "head"], g = {gradient:function () {
-        k.cssText = ("background-image:" + s.join("gradient(linear,left top,right bottom,from(#9f9),to(#fff));background-image:") + s.join("linear-gradient(left top,#eee,#fff);background-image:")).slice(0,
-            -17);
-        return!!k.backgroundImage
-    }, rgba:function () {
-        k.cssText = "background-color:rgba(0,0,0,0.5)";
-        return!!k.backgroundColor
-    }, opacity:function () {
-        return"" === m.style.opacity
-    }, textshadow:function () {
-        return"" === k.textShadow
-    }, multiplebgs:function () {
-        k.cssText = "background:url(//:),url(//:),red url(//:)";
-        return/(url\s*\(.*?){3}/.test(k.background)
-    }, boxshadow:function () {
-        return f("boxShadow")
-    }, borderimage:function () {
-        return f("borderImage")
-    }, borderradius:function () {
-        return f("borderRadius")
-    }, cssreflections:function () {
-        return f("boxReflect")
-    },
-        csstransforms:function () {
-            return f("transform")
-        }, csstransitions:function () {
-            return f("transition")
-        }, touch:function () {
-            return"ontouchstart"in a
-        }, retina:function () {
-            return 1 < a.devicePixelRatio
-        }, fontface:function () {
-            var a = n.browser.version;
-            switch (n.browser.name) {
-                case "ie":
-                    return 9 <= a;
-                case "chrome":
-                    return 13 <= a;
-                case "ff":
-                    return 6 <= a;
-                case "ios":
-                    return 5 <= a;
-                case "android":
-                    return!1;
-                case "webkit":
-                    return 5.1 <= a;
-                case "opera":
-                    return 10 <= a;
-                default:
-                    return!1
-            }
-        }}, t;
-    for (t in g)g[t] && n.feature(t, g[t].call(), !0);
-    n.feature()
-})(window);
-(function (a, w) {
-    function f() {
-    }
-
-    function m(j, a) {
-        if (j) {
-            "object" === typeof j && (j = [].slice.call(j));
-            for (var b = 0, c = j.length; b < c; b++)a.call(j, j[b], b)
-        }
-    }
-
-    function k(a, b) {
-        var e = Object.prototype.toString.call(b).slice(8, -1);
-        return b !== w && null !== b && e === a
-    }
-
-    function s(a) {
-        return k("Function", a)
-    }
-
-    function r(a) {
-        a = a || f;
-        a._done || (a(), a._done = 1)
-    }
-
-    function n(a) {
-        var b = {};
-        if ("object" === typeof a)for (var e in a)a[e] && (b = {name:e, url:a[e]}); else b = a.split("/"), b = b[b.length - 1], e = b.indexOf("?"), b = {name:-1 !== e ? b.substring(0, e) : b, url:a};
-        return(a = i[b.name]) && a.url === b.url ? a : i[b.name] = b
-    }
-
-    function g(a) {
-        var a = a || i, b;
-        for (b in a)if (a.hasOwnProperty(b) && a[b].state !== y)return!1;
-        return!0
-    }
-
-    function t(a, b) {
-        b = b || f;
-        a.state === y ? b() : a.state === D ? d.ready(a.name, b) : a.state === C ? a.onpreload.push(function () {
-            t(a, b)
-        }) : (a.state = D, q(a, function () {
-            a.state = y;
-            b();
-            m(x[a.name], function (a) {
-                r(a)
-            });
-            u && g() && m(x.ALL, function (a) {
-                r(a)
-            })
-        }))
-    }
-
-    function q(j, c) {
-        var c = c || f, e;
-        /\.css[^\.]*$/.test(j.url) ? (e = b.createElement("link"), e.type = "text/" + (j.type || "css"), e.rel = "stylesheet",
-            e.href = j.url) : (e = b.createElement("script"), e.type = "text/" + (j.type || "javascript"), e.src = j.url);
-        e.onload = e.onreadystatechange = function (j) {
-            j = j || a.event;
-            if ("load" === j.type || /loaded|complete/.test(e.readyState) && (!b.documentMode || 9 > b.documentMode))e.onload = e.onreadystatechange = e.onerror = null, c()
-        };
-        e.onerror = function () {
-            e.onload = e.onreadystatechange = e.onerror = null;
-            c()
-        };
-        e.async = !1;
-        e.defer = !1;
-        var d = b.head || b.getElementsByTagName("head")[0];
-        d.insertBefore(e, d.lastChild)
-    }
-
-    function p() {
-        b.body ? u || (u = !0, m(h, function (a) {
-            r(a)
-        })) :
-            (a.clearTimeout(d.readyTimeout), d.readyTimeout = a.setTimeout(p, 50))
-    }
-
-    function c() {
-        b.addEventListener ? (b.removeEventListener("DOMContentLoaded", c, !1), p()) : "complete" === b.readyState && (b.detachEvent("onreadystatechange", c), p())
-    }
-
-    var b = a.document, h = [], v = [], x = {}, i = {}, A = "async"in b.createElement("script") || "MozAppearance"in b.documentElement.style || a.opera, l, u, B = a.head_conf && a.head_conf.head || "head", d = a[B] = a[B] || function () {
-        d.ready.apply(null, arguments)
-    }, C = 1, D = 3, y = 4;
-    d.load = A ? function () {
-        var a = arguments, b = a[a.length -
-            1], e = {};
-        s(b) || (b = null);
-        m(a, function (c, d) {
-            c !== b && (c = n(c), e[c.name] = c, t(c, b && d === a.length - 2 ? function () {
-                g(e) && r(b)
-            } : null))
-        });
-        return d
-    } : function () {
-        var a = arguments, b = [].slice.call(a, 1), c = b[0];
-        if (!l)return v.push(function () {
-            d.load.apply(null, a)
-        }), d;
-        c ? (m(b, function (a) {
-            if (!s(a)) {
-                var b = n(a);
-                b.state === w && (b.state = C, b.onpreload = [], q({url:b.url, type:"cache"}, function () {
-                    b.state = 2;
-                    m(b.onpreload, function (a) {
-                        a.call()
-                    })
-                }))
-            }
-        }), t(n(a[0]), s(c) ? c : function () {
-            d.load.apply(null, b)
-        })) : t(n(a[0]));
-        return d
-    };
-    d.js = d.load;
-    d.test =
-        function (a, b, c, g) {
-            a = "object" === typeof a ? a : {test:a, success:b ? k("Array", b) ? b : [b] : !1, failure:c ? k("Array", c) ? c : [c] : !1, callback:g || f};
-            (b = !!a.test) && a.success ? (a.success.push(a.callback), d.load.apply(null, a.success)) : !b && a.failure ? (a.failure.push(a.callback), d.load.apply(null, a.failure)) : g();
-            return d
-        };
-    d.ready = function (a, c) {
-        if (a === b)return u ? r(c) : h.push(c), d;
-        s(a) && (c = a, a = "ALL");
-        if ("string" !== typeof a || !s(c))return d;
-        var e = i[a];
-        if (e && e.state === y || "ALL" === a && g() && u)return r(c), d;
-        (e = x[a]) ? e.push(c) : x[a] = [c];
-        return d
-    };
-    d.ready(b, function () {
-        g() && m(x.ALL, function (a) {
-            r(a)
-        });
-        d.feature && d.feature("domloaded", !0)
-    });
-    if ("complete" === b.readyState)p(); else if (b.addEventListener)b.addEventListener("DOMContentLoaded", c, !1), a.addEventListener("load", p, !1); else {
-        b.attachEvent("onreadystatechange", c);
-        a.attachEvent("onload", p);
-        var z = !1;
-        try {
-            z = null == a.frameElement && b.documentElement
-        } catch (F) {
-        }
-        z && z.doScroll && function E() {
-            if (!u) {
-                try {
-                    z.doScroll("left")
-                } catch (b) {
-                    a.clearTimeout(d.readyTimeout);
-                    d.readyTimeout = a.setTimeout(E, 50);
-                    return
-                }
-                p()
-            }
-        }()
-    }
-    setTimeout(function () {
-        l = !0;
-        m(v, function (a) {
-            a()
-        })
-    }, 300)
-})(window);
diff --git a/app/design/frontend/magento_plushe/js/sticky.js b/app/design/frontend/magento_plushe/js/sticky.js
index 2ebd90c1f143d731ea6d406277ee00b07bb0692a..64000be11e584f87765e09849300b8041f778630 100644
--- a/app/design/frontend/magento_plushe/js/sticky.js
+++ b/app/design/frontend/magento_plushe/js/sticky.js
@@ -17,8 +17,6 @@
  * versions in the future. If you wish to customize Magento for your
  * needs please refer to http://www.magentocommerce.com for more information.
  *
- * @category    EE
- * @package     EE_refrence
  * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
  * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
  */
@@ -58,4 +56,4 @@
             }
         }
     });
-})(jQuery, window);
\ No newline at end of file
+})(jQuery, window);
diff --git a/app/design/frontend/magento_plushe/less/styles.less b/app/design/frontend/magento_plushe/less/styles.less
index 2a5ddb95c480b8934360b55ee68a736ae7280362..ce54fa847d4053d718b55d66a2d76a4f116152dc 100644
--- a/app/design/frontend/magento_plushe/less/styles.less
+++ b/app/design/frontend/magento_plushe/less/styles.less
@@ -854,6 +854,21 @@ body {
     dd.complete {
         padding: 0;
         margin: 0 0 30px;
+        .cards.items {
+            dd {
+                margin-left: 0;
+                .card.item {
+                    font-size: 12px;
+                    margin: 5px 0 10px;
+                    dt {
+                        font-weight: bold;
+                    }
+                    dd {
+                        margin-bottom: 5px;
+                    }
+                }
+            }
+        }
     }
     address {
         font-style: normal;
diff --git a/dev/tests/integration/framework/Magento/TestFramework/Helper/Memory.php b/dev/tests/integration/framework/Magento/TestFramework/Helper/Memory.php
index 95b314cf9219fd8c4c0cabd99aa18b70b23066b8..942e7431c1fd5e1bd2645a0d6640472677b660ea 100644
--- a/dev/tests/integration/framework/Magento/TestFramework/Helper/Memory.php
+++ b/dev/tests/integration/framework/Magento/TestFramework/Helper/Memory.php
@@ -85,7 +85,11 @@ class Memory
     protected function _getUnixProcessMemoryUsage($pid)
     {
         // RSS - resident set size, the non-swapped physical memory
-        $output = $this->_shell->execute('ps --pid %s --format rss --no-headers', array($pid));
+        $command = 'ps --pid %s --format rss --no-headers';
+        if ($this->isMacOS()) {
+            $command = 'ps -p %s -o rss=';
+        }
+        $output = $this->_shell->execute($command, array($pid));
         $result = $output . 'k'; // kilobytes
         return self::convertToBytes($result);
     }
@@ -165,4 +169,15 @@ class Memory
         }
         return preg_replace('/\D+/', '', $number);
     }
+
+    /**
+     * Whether the operating system belongs to the Mac family
+     *
+     * @link http://php.net/manual/en/function.php-uname.php
+     * @return boolean
+     */
+    public static function isMacOs()
+    {
+        return (strtoupper(PHP_OS) === 'DARWIN');
+    }
 }
diff --git a/dev/tests/integration/framework/bootstrap.php b/dev/tests/integration/framework/bootstrap.php
index 6b6976c618e72689325e49559139e377b6515e67..0663d27b189505dc8224c80d05e63d297938dd5d 100644
--- a/dev/tests/integration/framework/bootstrap.php
+++ b/dev/tests/integration/framework/bootstrap.php
@@ -71,7 +71,7 @@ $bootstrap->runBootstrap();
 
 \Magento\TestFramework\Helper\Bootstrap::setInstance(new \Magento\TestFramework\Helper\Bootstrap($bootstrap));
 
-Magento\TestFramework\Utility\Files::init(new Magento\TestFramework\Utility\Files($magentoBaseDir));
+Magento\TestFramework\Utility\Files::setInstance(new Magento\TestFramework\Utility\Files($magentoBaseDir));
 
 /* Unset declared global variables to release the PHPUnit from maintaining their values between tests */
 unset($bootstrap);
diff --git a/dev/tests/integration/testsuite/Magento/Backend/Utility/Controller.php b/dev/tests/integration/testsuite/Magento/Backend/Utility/Controller.php
index 9d912e5d93835908b87aa905fd326873627f3ce2..250e1309b59f420d7915ee91dc7fce784679d046 100644
--- a/dev/tests/integration/testsuite/Magento/Backend/Utility/Controller.php
+++ b/dev/tests/integration/testsuite/Magento/Backend/Utility/Controller.php
@@ -52,9 +52,20 @@ class Controller extends \Magento\TestFramework\TestCase\AbstractController
 
         $this->_auth = $this->_objectManager->get('Magento\Backend\Model\Auth');
         $this->_session = $this->_auth->getAuthStorage();
-        $this->_auth->login(
-            \Magento\TestFramework\Bootstrap::ADMIN_NAME,
-            \Magento\TestFramework\Bootstrap::ADMIN_PASSWORD
+        $credentials = $this->_getAdminCredentials();
+        $this->_auth->login($credentials['user'], $credentials['password']);
+    }
+
+    /**
+     * Get credentials to login admin user
+     *
+     * @return array
+     */
+    protected function _getAdminCredentials()
+    {
+        return array(
+            'user' => \Magento\TestFramework\Bootstrap::ADMIN_NAME,
+            'password' => \Magento\TestFramework\Bootstrap::ADMIN_PASSWORD,
         );
     }
 
diff --git a/dev/tests/integration/testsuite/Magento/Catalog/Helper/CategoryTest.php b/dev/tests/integration/testsuite/Magento/Catalog/Helper/CategoryTest.php
index a6d49296ea43b61866e7cd4013e84a3e4c2c2e97..c95aabab12897a2f3c84508201b2fdadf432b532 100644
--- a/dev/tests/integration/testsuite/Magento/Catalog/Helper/CategoryTest.php
+++ b/dev/tests/integration/testsuite/Magento/Catalog/Helper/CategoryTest.php
@@ -59,7 +59,10 @@ class CategoryTest extends \PHPUnit_Framework_TestCase
         $categories = $this->_helper->getStoreCategories();
         $this->assertInstanceOf('Magento\Data\Tree\Node\Collection', $categories);
         $index = 0;
-        $expectedPaths = array(array(3, '1/2/3'), array(6, '1/2/6'), array(7, '1/2/7'));
+        $expectedPaths = array(
+            array(3, '1/2/3'), array(6, '1/2/6'), array(7, '1/2/7'),
+            array(9, '1/2/9'), array(10, '1/2/10'), array(11, '1/2/11'),
+        );
         foreach ($categories as $category) {
             $this->assertInstanceOf('Magento\Data\Tree\Node', $category);
             $this->assertEquals($expectedPaths[$index][0], $category->getId());
diff --git a/dev/tests/integration/testsuite/Magento/Catalog/Model/CategoryTreeTest.php b/dev/tests/integration/testsuite/Magento/Catalog/Model/CategoryTreeTest.php
index 0c118a9614d2769a0b25d2d22ebc6b7e481400c5..85152f1979b36e4aa685191f455b476d15395158 100644
--- a/dev/tests/integration/testsuite/Magento/Catalog/Model/CategoryTreeTest.php
+++ b/dev/tests/integration/testsuite/Magento/Catalog/Model/CategoryTreeTest.php
@@ -47,6 +47,44 @@ class CategoryTreeTest extends \PHPUnit_Framework_TestCase
             ->create('Magento\Catalog\Model\Category');
     }
 
+    /**
+     * Load category
+     *
+     * @param $categoryId
+     * @return Category
+     */
+    protected function loadCategory($categoryId)
+    {
+        $this->_model->setData(array());
+        $this->_model->load($categoryId);
+        return $this->_model;
+    }
+
+    public function testMovePosition()
+    {
+        //move category 9 to new parent 6 with afterCategoryId = null
+        $category = $this->loadCategory(9);
+        $category->move(6, null);
+        $category = $this->loadCategory(9);
+        $this->assertEquals(1, $category->getPosition(), 'Position must be 1, if $afterCategoryId was null|false|0');
+        $category = $this->loadCategory(10);
+        $this->assertEquals(5, $category->getPosition(), 'Category 10 position must decrease after Category 9 moved');
+        $category = $this->loadCategory(11);
+        $this->assertEquals(6, $category->getPosition(), 'Category 11 position must decrease after Category 9 moved');
+        $category = $this->loadCategory(6);
+        $this->assertEquals(2, $category->getPosition(), 'Category 6 position must be the same');
+
+        //move category 11 to new parent 6 with afterCategoryId = 9
+        $category = $this->loadCategory(11);
+        $category->move(6, 9);
+        $category = $this->loadCategory(11);
+        $this->assertEquals(2, $category->getPosition(), 'Category 11 position must be after category 9');
+        $category = $this->loadCategory(10);
+        $this->assertEquals(5, $category->getPosition(), 'Category 10 position must be the same');
+        $category = $this->loadCategory(9);
+        $this->assertEquals(1, $category->getPosition(), 'Category 9 position must be 1');
+    }
+
     public function testMove()
     {
         $this->_model->load(7);
diff --git a/dev/tests/integration/testsuite/Magento/Catalog/Model/ProductTest.php b/dev/tests/integration/testsuite/Magento/Catalog/Model/ProductTest.php
index f3434c54f41906a0399e86eb50c9dfe8d9cdf5bc..30eb9cb1418db7593d0bc406103fbfefddf043be 100644
--- a/dev/tests/integration/testsuite/Magento/Catalog/Model/ProductTest.php
+++ b/dev/tests/integration/testsuite/Magento/Catalog/Model/ProductTest.php
@@ -153,6 +153,7 @@ class ProductTest extends \PHPUnit_Framework_TestCase
             $this->assertNotEquals($duplicate->getId(), $this->_model->getId());
             $this->assertNotEquals($duplicate->getSku(), $this->_model->getSku());
             $this->assertEquals(\Magento\Catalog\Model\Product\Status::STATUS_DISABLED, $duplicate->getStatus());
+            $this->assertEquals(\Magento\Core\Model\Store::DEFAULT_STORE_ID, $duplicate->getStoreId());
             $this->_undo($duplicate);
         } catch (\Exception $e) {
             $this->_undo($duplicate);
diff --git a/dev/tests/integration/testsuite/Magento/Catalog/_files/categories.php b/dev/tests/integration/testsuite/Magento/Catalog/_files/categories.php
index e3dc77a153add844e9c826f065bd79a94a7ac38c..a3cd9e68c132103453e8c61a8d1e986f0c2f6faa 100644
--- a/dev/tests/integration/testsuite/Magento/Catalog/_files/categories.php
+++ b/dev/tests/integration/testsuite/Magento/Catalog/_files/categories.php
@@ -35,7 +35,7 @@ $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(3)
     ->setName('Category 1')
-    ->setParentId(2) /**/
+    ->setParentId(2)
     ->setPath('1/2/3')
     ->setLevel(2)
     ->setAvailableSortBy('name')
@@ -48,7 +48,7 @@ $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(4)
     ->setName('Category 1.1')
-    ->setParentId(3) /**/
+    ->setParentId(3)
     ->setPath('1/2/3/4')
     ->setLevel(3)
     ->setAvailableSortBy('name')
@@ -62,13 +62,13 @@ $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(5)
     ->setName('Category 1.1.1')
-    ->setParentId(4) /**/
+    ->setParentId(4)
     ->setPath('1/2/3/4/5')
     ->setLevel(4)
     ->setAvailableSortBy('name')
     ->setDefaultSortBy('name')
     ->setIsActive(true)
-    ->setPosition(2)
+    ->setPosition(1)
     ->setCustomUseParentSettings(0)
     ->setCustomDesign('magento_blank')
     ->save();
@@ -77,7 +77,7 @@ $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(6)
     ->setName('Category 2')
-    ->setParentId(2) /**/
+    ->setParentId(2)
     ->setPath('1/2/6')
     ->setLevel(2)
     ->setAvailableSortBy('name')
@@ -90,7 +90,7 @@ $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(7)
     ->setName('Movable')
-    ->setParentId(2) /**/
+    ->setParentId(2)
     ->setPath('1/2/7')
     ->setLevel(2)
     ->setAvailableSortBy('name')
@@ -99,11 +99,50 @@ $category->setId(7)
     ->setPosition(3)
     ->save();
 
+$category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\Catalog\Model\Category');
+$category->setId(9)
+    ->setName('Movable Position 1')
+    ->setParentId(2)
+    ->setPath('1/2/9')
+    ->setLevel(2)
+    ->setAvailableSortBy('name')
+    ->setDefaultSortBy('name')
+    ->setIsActive(true)
+    ->setPosition(5)
+    ->save();
+
+$category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\Catalog\Model\Category');
+$category->setId(10)
+    ->setName('Movable Position 2')
+    ->setParentId(2)
+    ->setPath('1/2/10')
+    ->setLevel(2)
+    ->setAvailableSortBy('name')
+    ->setDefaultSortBy('name')
+    ->setIsActive(true)
+    ->setPosition(6)
+    ->save();
+
+$category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\Catalog\Model\Category');
+$category->setId(11)
+    ->setName('Movable Position 3')
+    ->setParentId(2)
+    ->setPath('1/2/11')
+    ->setLevel(2)
+    ->setAvailableSortBy('name')
+    ->setDefaultSortBy('name')
+    ->setIsActive(true)
+    ->setPosition(7)
+    ->save();
+
 $category = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Category');
 $category->setId(8)
     ->setName('Inactive')
-    ->setParentId(2) /**/
+    ->setParentId(2)
     ->setPath('1/2/8')
     ->setAvailableSortBy('name')
     ->setDefaultSortBy('name')
@@ -111,7 +150,6 @@ $category->setId(8)
     ->setPosition(4)
     ->save();
 
-
 /** @var $product \Magento\Catalog\Model\Product */
 $product = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Catalog\Model\Product');
diff --git a/dev/tests/integration/testsuite/Magento/Checkout/Controller/OnepageTest.php b/dev/tests/integration/testsuite/Magento/Checkout/Controller/OnepageTest.php
index 78a80fa74e936fb1d2cf344a438f8e9f6094321b..ebe1a517a718a23d22142e2d4e5db74b9a7963b6 100644
--- a/dev/tests/integration/testsuite/Magento/Checkout/Controller/OnepageTest.php
+++ b/dev/tests/integration/testsuite/Magento/Checkout/Controller/OnepageTest.php
@@ -52,6 +52,7 @@ class OnepageTest extends \Magento\TestFramework\TestCase\AbstractController
         $this->assertContains('<li id="opc-payment"', $html);
         $this->assertSelectCount('[id="checkout-payment-method-load"]', 1, $html);
         $this->assertSelectCount('form[id="co-billing-form"][action=""]', 1, $html);
+        $this->assertSelectCount('form[id="co-payment-form"] input[name="form_key"]', 1, $html);
     }
 
     /**
@@ -92,6 +93,24 @@ class OnepageTest extends \Magento\TestFramework\TestCase\AbstractController
         $this->assertContains('Place Order', $this->getResponse()->getBody());
         $this->assertContains('checkout-review', $this->getResponse()->getBody());
     }
+
+    public function testSaveOrderActionWithoutFormKey()
+    {
+        $this->dispatch('checkout/onepage/saveOrder');
+        $this->assertRedirect($this->stringContains('checkout/onepage'));
+    }
+
+    public function testSaveOrderActionWithFormKey()
+    {
+        $formKey = $this->_objectManager->get('\Magento\Data\Form\FormKey');
+        $this->getRequest()->setParam('form_key', $formKey->getFormKey());
+        $this->dispatch('checkout/onepage/saveOrder');
+        $html = $this->getResponse()->getBody();
+        $this->assertEquals(
+            '{"success":false,"error":true,"error_messages":"Please specify a shipping method."}',
+            $html
+        );
+    }
 }
 
 
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/CustomerTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/CustomerTest.php
index 29c5e2bfdba616a4421560d73fce96f5e620e838..db32c7fcd5daa6cff16921cdf1e728cc10d96422 100644
--- a/dev/tests/integration/testsuite/Magento/Customer/Service/CustomerTest.php
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/CustomerTest.php
@@ -65,7 +65,8 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             $this->_createdCustomer->getAddressesCollection()->delete();
             $this->_createdCustomer->delete();
         }
-        \Magento\TestFramework\Helper\Bootstrap::getObjectManager()->get('Magento\Core\Model\StoreManagerInterface')
+        \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+            ->get('Magento\Core\Model\StoreManagerInterface')
             ->setCurrentStore($previousStoreId);
 
         $this->_model = null;
@@ -324,9 +325,9 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             ->load(1);
 
         $updatedCustomer = $this->_model->update($expected->getId(), $customerData);
+
         $this->assertInstanceOf('Magento\Customer\Model\Customer', $updatedCustomer);
         $this->assertFalse($updatedCustomer->isObjectNew());
-
         $actualData = $this->_customerFactory->create()
             ->load($expected->getId())->getData();
         $expectedData = array_merge($updatedCustomer->toArray(array_keys($actualData)), $customerData);
@@ -365,6 +366,24 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
         );
     }
 
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testUpdateFirstname()
+    {
+        $customer = $this->_customerFactory->create()->load(1);
+        // This call to getAttributes will cause our test to fail if the
+        // customer fixture was using attribute set 0 instead of 1
+        $customer->getAttributes();
+
+        $updatedCustomer = $this->_model->update(1, ['firstname' => 'new_name']);
+
+        $customer = $this->_customerFactory->create()->load(1);
+
+        $this->assertEquals('new_name', $customer->getFirstname());
+        $this->assertEquals('new_name', $updatedCustomer->getFirstname());
+    }
+
     /**
      * @param array $customerData
      * @param string $exceptionName
@@ -386,15 +405,24 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
     public function updateExceptionsDataProvider()
     {
         return array(
-            'Invalid password' => array(array(
-                'password' => '111'
-            ), 'Magento\Eav\Model\Entity\Attribute\Exception'),
-            'Invalid name' => array(array(
-                'firstname' => null
-            ), 'Magento\Validator\ValidatorException'),
-            'Invalid email' => array(array(
-                'email' => '3434@23434'
-            ), 'Magento\Validator\ValidatorException')
+            'Invalid password' => array(
+                array(
+                    'password' => '111'
+                ),
+                'Magento\Eav\Model\Entity\Attribute\Exception'
+            ),
+            'Invalid name' => array(
+                array(
+                    'firstname' => null
+                ),
+                'Magento\Validator\ValidatorException'
+            ),
+            'Invalid email' => array(
+                array(
+                    'email' => '3434@23434'
+                ),
+                'Magento\Validator\ValidatorException'
+            )
         );
     }
 
@@ -416,9 +444,10 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
         $oldPasswordHash = $this->_customerFactory->create()
             ->load(1)
             ->getPasswordHash();
-        $updatedCustomer = $this->_model->update(1, array(
-            'autogenerate_password' => true,
-        ));
+        $updatedCustomer = $this->_model->update(
+            1,
+            array('autogenerate_password' => true,)
+        );
         $this->assertNotEquals($oldPasswordHash, $updatedCustomer->getPasswordHash());
     }
 
@@ -435,8 +464,11 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             ->load(1);
         $this->assertCount(2, $customer->getAddresses(), 'Not all customer addresses were created.');
         $updatedCustomer = $this->_model->update(1, array(), $addressesData);
-        $this->assertCount(count($addressesData), $updatedCustomer->getAddresses(),
-            'Customer address was not deleted.');
+        $this->assertCount(
+            count($addressesData),
+            $updatedCustomer->getAddresses(),
+            'Customer address was not deleted.'
+        );
 
         /** @var \Magento\Customer\Model\Customer $actualCustomer */
         $actualCustomer = $this->_customerFactory->create()
@@ -515,15 +547,17 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             ->load(1);
         $customerData = array('firstname' => 'Updated name');
         $customer->addData($customerData);
-        $addressData = array(array(
-            'firstname' => 'John',
-            'lastname' => 'Smith',
-            'street' => 'Green str, 67',
-            'country_id' => 'AL',
-            'city' => 'CityM',
-            'postcode' => '75477',
-            'telephone' => '3468676',
-        ));
+        $addressData = array(
+            array(
+                'firstname' => 'John',
+                'lastname' => 'Smith',
+                'street' => 'Green str, 67',
+                'country_id' => 'AL',
+                'city' => 'CityM',
+                'postcode' => '75477',
+                'telephone' => '3468676',
+            )
+        );
 
         $callbackCount = 0;
         $callback = function ($actualCustomer, $actualData, $actualAddresses) use ($customer, $customerData,
@@ -533,8 +567,10 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             // Remove updated_at as in afterSave updated_at may be changed
             $expectedCustomerData = $customer->getData();
             unset($expectedCustomerData['updated_at']);
-            \PHPUnit_Framework_Assert::assertEquals($expectedCustomerData,
-                $actualCustomer->toArray(array_keys($expectedCustomerData)));
+            \PHPUnit_Framework_Assert::assertEquals(
+                $expectedCustomerData,
+                $actualCustomer->toArray(array_keys($expectedCustomerData))
+            );
             \PHPUnit_Framework_Assert::assertEquals($customerData, $actualData);
             \PHPUnit_Framework_Assert::assertEquals($addressData, $actualAddresses);
         };
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..1589d285eebc70a788aa94ff66a1aeeb65243448
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php
@@ -0,0 +1,434 @@
+<?php
+
+namespace Magento\Customer\Service\V1;
+use Magento\Customer\Service\V1;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+/**
+ * Integration test for service layer \Magento\Customer\Service\CustomerV1
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ */
+class CustomerAccountServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /** @var CustomerAccountServiceInterface */
+    private $_service;
+
+    /** @var CustomerServiceInterface needed to setup tests */
+    private $_customerService;
+
+    /** @var \Magento\ObjectManager */
+    private $_objectManager;
+
+    /** @var \Magento\Customer\Service\V1\Dto\Address[] */
+    private $_expectedAddresses;
+
+    /** @var \Magento\Customer\Service\V1\Dto\AddressBuilder */
+    private $_addressBuilder;
+
+    /** @var \Magento\Customer\Service\V1\Dto\CustomerBuilder */
+    private $_customerBuilder;
+
+    protected function setUp()
+    {
+        $this->_objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+        $this->_service = $this->_objectManager->create('Magento\Customer\Service\V1\CustomerAccountServiceInterface');
+        $this->_customerService = $this->_objectManager->create('Magento\Customer\Service\V1\CustomerServiceInterface');
+
+        $this->_addressBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\AddressBuilder');
+        $this->_customerBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\CustomerBuilder');
+
+        $this->_addressBuilder->setId(1)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(true)
+            ->setDefaultShipping(true)
+            ->setPostcode('75477')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Green str, 67'])
+            ->setTelephone('3468676')
+            ->setCity('CityM')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address = $this->_addressBuilder->create();
+
+        /* XXX: would it be better to have a clear method for this? */
+        $this->_addressBuilder->setId(2)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(false)
+            ->setDefaultShipping(false)
+            ->setPostcode('47676')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Black str, 48'])
+            ->setCity('CityX')
+            ->setTelephone('3234676')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address2 = $this->_addressBuilder->create();
+
+        $this->_expectedAddresses = [$address, $address2];
+    }
+
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testLogin()
+    {
+        // Customer e-mail and password are pulled from the fixture customer.php
+        $customer = $this->_service->authenticate('customer@example.com', 'password', true);
+
+        $this->assertSame('customer@example.com', $customer->getEmail());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage Invalid login or password
+     */
+    public function testLoginWrongPassword()
+    {
+        // Customer e-mail and password are pulled from the fixture customer.php
+        $this->_service->authenticate('customer@example.com', 'wrongPassword', true);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage Invalid login or password
+     */
+    public function testLoginWrongUsername()
+    {
+        // Customer e-mail and password are pulled from the fixture customer.php
+        $this->_service->authenticate('non_existing_user', 'password', true);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/inactive_customer.php
+     * @magentoAppArea frontend
+     */
+    public function testActivateAccount()
+    {
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\Customer');
+        $customerModel->load(1);
+        // Assert in just one test that the fixture is working
+        $this->assertNotNull($customerModel->getConfirmation(), 'New customer needs to be confirmed');
+
+        $this->_service->activateAccount($customerModel->getId(), $customerModel->getConfirmation());
+
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\Customer');
+        $customerModel->load(1);
+        $this->assertNull($customerModel->getConfirmation(), 'Customer should be considered confirmed now');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/inactive_customer.php
+     *
+     * @expectedException \Magento\Core\Exception
+     * @expectedExceptionMessage Wrong confirmation key
+     */
+    public function testActivateAccountWrongKey()
+    {
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\Customer');
+        $customerModel->load(1);
+        $key = $customerModel->getConfirmation();
+
+        $this->_service->activateAccount($customerModel->getId(), $key . $key);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/inactive_customer.php
+     *
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage No customer with customerId 12341 exists.
+     */
+    public function testActivateAccountWrongAccount()
+    {
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\Customer');
+        $customerModel->load(1);
+        $key = $customerModel->getConfirmation();
+
+        $this->_service->activateAccount('1234' . $customerModel->getId(), $key);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/inactive_customer.php
+     * @magentoAppArea frontend
+     *
+     * @expectedException  \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage Customer account is already active
+     */
+    public function testActivateAccountAlreadyActive()
+    {
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\Customer');
+        $customerModel->load(1);
+        $key = $customerModel->getConfirmation();
+        $this->_service->activateAccount($customerModel->getId(), $key);
+
+        $this->_service->activateAccount($customerModel->getId(), $key);
+    }
+
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testValidateResetPasswordLinkToken()
+    {
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => 'token',
+            'rp_token_created_at' => date('Y-m-d')
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->validateResetPasswordLinkToken(1, 'token');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     */
+    public function testValidateResetPasswordLinkTokenExpired()
+    {
+        $this->_service->validateResetPasswordLinkToken(1, 'some_token');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_RESET_TOKEN
+     */
+    public function testValidateResetPasswordLinkTokenInvalid()
+    {
+        $this->_service->validateResetPasswordLinkToken(0, null);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_CUSTOMER_ID
+     * @expectedExceptionMessage No customer with customerId 4200 exists
+     */
+    public function testValidateResetPasswordLinkTokenWrongUser()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+
+
+        $this->_service->validateResetPasswordLinkToken(4200, $resetToken);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_RESET_TOKEN
+     * @expectedExceptionMessage Invalid password reset token
+     */
+    public function testValidateResetPasswordLinkTokenNull()
+    {
+        $this->_service->validateResetPasswordLinkToken(null, null);
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSendPasswordResetLink()
+    {
+        $email = 'customer@example.com';
+
+        $this->_service->sendPasswordResetLink($email, 1);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_EMAIL_NOT_FOUND
+     * @expectedExceptionMessage No customer found for the provided email and website ID
+     */
+    public function testSendPasswordResetLinkBadEmailOrWebsite()
+    {
+        $email = 'foo@example.com';
+
+        $this->_service->sendPasswordResetLink($email, 0);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testResetPassword()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => $resetToken,
+            'rp_token_created_at' => date('Y-m-d')
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->resetPassword(1, $password, $resetToken);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testResetPasswordTokenExpired()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => $resetToken,
+            'rp_token_created_at' => '1970-01-01'
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->resetPassword(1, $password, $resetToken);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testResetPasswordTokenInvalid()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $invalidToken = $resetToken . 'invalid';
+        $password = 'password_secret';
+
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => $resetToken,
+            'rp_token_created_at' => date('Y-m-d')
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->resetPassword(1, $password, $invalidToken);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_CUSTOMER_ID
+     * @expectedExceptionMessage No customer with customerId 4200 exists
+     */
+    public function testResetPasswordTokenWrongUser()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => $resetToken,
+            'rp_token_created_at' => date('Y-m-d')
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->resetPassword(4200, $password, $resetToken);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_RESET_TOKEN
+     * @expectedExceptionMessage Invalid password reset token
+     */
+    public function testResetPasswordTokenInvalidUserId()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_customerBuilder->populateWithArray(array_merge($this->_customerService->getCustomer(1)->__toArray(), [
+            'rp_token' => $resetToken,
+            'rp_token_created_at' => date('Y-m-d')
+        ]));
+        $this->_customerService->saveCustomer($this->_customerBuilder->create());
+
+        $this->_service->resetPassword(0, $password, $resetToken);
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoAppIsolation enabled
+     * @magentoDataFixture Magento/Customer/_files/inactive_customer.php
+     */
+    public function testSendConfirmation()
+    {
+        $this->_service->sendConfirmation('customer@needAconfirmation.com');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_EMAIL_NOT_FOUND
+     */
+    public function testSendConfirmationNoEmail()
+    {
+        $this->_service->sendConfirmation('wrongemail@example.com');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_CONFIRMATION_NOT_NEEDED
+     */
+    public function testSendConfirmationNotNeeded()
+    {
+        $this->_service->sendConfirmation('customer@example.com');
+    }
+
+
+
+}
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..91fbe7dd24af90d1f0741d365336083627d94eb3
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php
@@ -0,0 +1,568 @@
+<?php
+
+namespace Magento\Customer\Service\V1;
+use Magento\Customer\Service\V1;
+use Magento\Customer\Service\Entity\V1\Exception;
+
+/**
+ * Integration test for service layer \Magento\Customer\Service\V1\CustomerAddressService
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ */
+class CustomerAddressServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /** @var CustomerAddressServiceInterface */
+    private $_service;
+
+    /** @var \Magento\ObjectManager */
+    private $_objectManager;
+
+    /** @var \Magento\Customer\Service\V1\Dto\Address[] */
+    private $_expectedAddresses;
+
+    /** @var \Magento\Customer\Service\V1\Dto\AddressBuilder */
+    private $_addressBuilder;
+
+    /** @var \Magento\Customer\Service\V1\Dto\CustomerBuilder */
+    private $_customerBuilder;
+
+    protected function setUp()
+    {
+        $this->_objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+        $this->_service = $this->_objectManager->create('Magento\Customer\Service\V1\CustomerAddressServiceInterface');
+
+        $this->_addressBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\AddressBuilder');
+        $this->_customerBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\CustomerBuilder');
+
+        $this->_addressBuilder->setId(1)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(true)
+            ->setDefaultShipping(true)
+            ->setPostcode('75477')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Green str, 67'])
+            ->setTelephone('3468676')
+            ->setCity('CityM')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address = $this->_addressBuilder->create();
+
+        /* XXX: would it be better to have a clear method for this? */
+        $this->_addressBuilder->setId(2)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(false)
+            ->setDefaultShipping(false)
+            ->setPostcode('47676')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Black str, 48'])
+            ->setCity('CityX')
+            ->setTelephone('3234676')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address2 = $this->_addressBuilder->create();
+
+        $this->_expectedAddresses = [$address, $address2];
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveAddressChanges()
+    {
+        $customerId = 1;
+        $address = $this->_service->getAddressById($customerId, 2);
+        $proposedAddressBuilder = $this->_addressBuilder->populate($address);
+        $proposedAddressBuilder->setTelephone('555' . $address->getTelephone());
+        $proposedAddress = $proposedAddressBuilder->create();
+
+        $this->_service->saveAddresses($customerId, [$proposedAddress]);
+
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals(2, count($addresses));
+        $this->assertNotEquals($this->_expectedAddresses[1], $addresses[1]);
+        $this->_assertAddressAndRegionArrayEquals($proposedAddress->__toArray(), $addresses[1]->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveAddressesIdSetButNotAlreadyExisting()
+    {
+        $proposedAddressBuilder = $this->_createSecondAddressBuilder()
+            ->setFirstname('Jane')
+            ->setId(4200);
+        $proposedAddress = $proposedAddressBuilder->create();
+
+        $customerId = 1;
+        $this->_service->saveAddresses($customerId, [$proposedAddress]);
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals($this->_expectedAddresses[0], $addresses[0]);
+        $this->assertEquals($this->_expectedAddresses[1], $addresses[1]);
+
+        $expectedThirdAddressBuilder = $this->_addressBuilder->populate($proposedAddress);
+        // set id
+        $expectedThirdAddressBuilder->setId($addresses[2]->getId());
+        $expectedThirdAddress = $expectedThirdAddressBuilder->create();
+        $this->_assertAddressAndRegionArrayEquals($expectedThirdAddress->__toArray(), $addresses[2]->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testGetAddresses()
+    {
+        $customerId = 1;
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals(2, count($this->_expectedAddresses) );
+        $this->assertEquals(2, count($addresses) );
+        $this->_assertAddressAndRegionArrayEquals(
+            $this->_expectedAddresses[0]->__toArray(),
+            $addresses[0]->__toArray()
+        );
+        $this->_assertAddressAndRegionArrayEquals(
+            $this->_expectedAddresses[1]->__toArray(),
+            $addresses[1]->__toArray()
+        );
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testGetDefaultBillingAddress()
+    {
+        $customerId = 1;
+        $address = $this->_service->getDefaultBillingAddress($customerId);
+        $this->assertEquals($this->_expectedAddresses[0], $address);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testGetAddressById()
+    {
+        $customerId = 1;
+        $addressId = 2;
+        $addresses = $this->_service->getAddressById($customerId, $addressId);
+        $this->assertEquals($this->_expectedAddresses[1], $addresses);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_ADDRESS_NOT_FOUND
+     */
+    public function testGetAddressByIdBadAddrId()
+    {
+        // Should throw the address not found excetion
+        $this->_service->getAddressById(1, 12345);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveNewAddress()
+    {
+        $proposedAddressBuilder = $this->_createSecondAddressBuilder();
+        $proposedAddress = $proposedAddressBuilder->create();
+        $customerId = 1;
+
+        $this->_service->saveAddresses($customerId, [$proposedAddress]);
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals($this->_expectedAddresses[0], $addresses[0]);
+        $expectedNewAddressBuilder = $this->_addressBuilder->populate($this->_expectedAddresses[1]);
+        $expectedNewAddressBuilder
+            ->setId($addresses[1]->getId());
+        $expectedNewAddress = $expectedNewAddressBuilder->create();
+        $this->assertEquals($expectedNewAddress->__toArray(), $addresses[1]->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveNewAddressWithAttributes()
+    {
+        $this->_addressBuilder->populateWithArray(array_merge($this->_expectedAddresses[1]->__toArray(), [
+            'firstname' => 'Jane',
+            'id' => 4200,
+            'weird' => 'something_strange_with_hair'
+        ]))->setId(null);
+        $proposedAddress = $this->_addressBuilder->create();
+
+        $customerId = 1;
+        $this->_service->saveAddresses($customerId, [$proposedAddress]);
+
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertNotEquals($proposedAddress->getAttributes(), $addresses[1]->getAttributes());
+        $this->assertArrayHasKey('weird', $proposedAddress->getAttributes());
+        $this->assertArrayNotHasKey('weird', $addresses[1]->getAttributes());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveNewInvalidAddresses()
+    {
+        $firstAddressBuilder = $this->_addressBuilder->populateWithArray(
+            array_merge($this->_expectedAddresses[0]->__toArray(), [
+                'firstname' => null
+            ])
+        )->setId(null);
+        $firstAddress = $firstAddressBuilder->create();
+        $secondAddressBuilder = $this->_addressBuilder->populateWithArray(
+            array_merge($this->_expectedAddresses[0]->__toArray(), [
+                'lastname' => null
+            ])
+        )->setId(null);
+        $secondAddress = $secondAddressBuilder->create();
+        $customerId = 1;
+        try {
+            $this->_service->saveAddresses($customerId, [$firstAddress, $secondAddress]);
+        } catch (\Magento\Customer\Service\Entity\V1\AggregateException $ae) {
+            $failures = $ae->getExceptions();
+            $firstAddressError = $failures[0];
+            $this->assertInstanceOf('\Magento\Customer\Service\Entity\V1\Exception', $firstAddressError);
+            $this->assertInstanceOf('\Magento\Validator\ValidatorException', $firstAddressError->getPrevious());
+            $this->assertSame('Please enter the first name.', $firstAddressError->getPrevious()->getMessage());
+
+            $secondAddressError = $failures[1];
+            $this->assertInstanceOf('\Magento\Customer\Service\Entity\V1\Exception', $secondAddressError);
+            $this->assertInstanceOf('\Magento\Validator\ValidatorException', $secondAddressError->getPrevious());
+            $this->assertSame('Please enter the last name.', $secondAddressError->getPrevious()->getMessage());
+            return;
+        }
+        $this->fail('Expected AggregateException not caught.');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveNewAddressDefaults()
+    {
+        $addressShippingBuilder = $this->_createFirstAddressBuilder();
+        $addressShippingBuilder->setDefaultShipping(true)->setDefaultBilling(false);
+        $addressShipping = $addressShippingBuilder->create();
+
+        $addressBillingBuilder = $this->_createSecondAddressBuilder();
+        $addressBillingBuilder->setDefaultBilling(true)->setDefaultShipping(false);
+        $addressBilling = $addressBillingBuilder->create();
+        $customerId = 1;
+        $this->_service->saveAddresses($customerId, [$addressShipping, $addressBilling]);
+
+        $shipping = $this->_service->getDefaultShippingAddress($customerId);
+        /* XXX: cannot reuse addressShippingBuilder; actually all of this code
+           is re-using the same addressBuilder which is wrong */
+        $addressShipping = $this->_addressBuilder->populate($addressShipping)->setId($shipping->getId())->create();
+        $this->_assertAddressAndRegionArrayEquals($addressShipping->__toArray(), $shipping->__toArray());
+
+        $billing = $this->_service->getDefaultBillingAddress($customerId);
+        $addressBilling = $this->_addressBuilder->populate($addressBilling)->setId($billing->getId())->create();
+        $this->_assertAddressAndRegionArrayEquals($addressBilling->__toArray(), $billing->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveSeveralNewAddressesSameDefaults()
+    {
+        $addressTwoBuilder = $this->_createSecondAddressBuilder();
+        $addressTwo = $addressTwoBuilder->create();
+        $addressThreeBuilder = $this->_addressBuilder->populate($addressTwo);
+        $addressThreeBuilder->setDefaultBilling(true);
+        $addressThree = $addressThreeBuilder->create();
+
+        $addressFourBuilder = $this->_addressBuilder->populate($addressTwo);
+        $addressFourBuilder->setDefaultBilling(false)->setDefaultShipping(true);
+        $addressFour = $addressFourBuilder->create();
+
+        $addressDefaultBuilder = $this->_addressBuilder->populate($addressTwo);
+        $addressDefaultBuilder->setDefaultBilling(true)->setDefaultShipping(true)
+            ->setFirstname('Dirty Garry');
+        $addressDefault = $addressDefaultBuilder->create();
+
+        $customerId = 1;
+        $this->_service->saveAddresses(
+            $customerId,
+            [$addressTwo, $addressThree, $addressFour, $addressDefault]
+        );
+
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals(5, count($addresses));
+
+        // retrieve defaults
+        $addresses = [
+            $this->_service->getDefaultBillingAddress($customerId),
+            $this->_service->getDefaultShippingAddress($customerId),
+        ];
+        // Same address is returned twice
+        $this->assertEquals($addresses[0], $addresses[1]);
+        $this->assertEquals($addressDefault->getFirstname(), $addresses[1]->getFirstname());
+
+        //clone object
+        $expectedDefaultBuilder = $this->_addressBuilder->populate($addressDefault);
+        // It is the same address retrieved as the one which get saved
+        $expectedDefaultBuilder->setId($addresses[1]->getId());
+        $expectedDefault = $expectedDefaultBuilder->create();
+        $this->_assertAddressAndRegionArrayEquals($expectedDefault->__toArray(), $addresses[1]->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveSeveralNewAddressesDifferentDefaults()
+    {
+        $addressTwoBuilder = $this->_createSecondAddressBuilder();
+        $addressTwo = $addressTwoBuilder->create();
+
+        $addressThreeBuilder = $this->_addressBuilder->populate($addressTwo);
+        $addressThreeBuilder->setDefaultBilling(true);
+        $addressThree = $addressThreeBuilder->create();
+
+        $defaultShippingBuilder = $this->_addressBuilder->populate($addressTwo);
+        $defaultShippingBuilder->setFirstname('Shippy')
+            ->setLastname('McShippington')
+            ->setDefaultBilling(false)
+            ->setDefaultShipping(true);
+        $defaultShipping = $defaultShippingBuilder->create();
+
+        $defaultBillingBuilder = $this->_addressBuilder->populate($addressTwo);
+        $defaultBillingBuilder
+            ->setFirstname('Billy')
+            ->setLastname('McBillington')
+            ->setDefaultBilling(true)
+            ->setDefaultShipping(false);
+        $defaultBilling = $defaultBillingBuilder->create();
+
+        $customerId = 1;
+
+        $this->_service->saveAddresses($customerId, [$addressTwo, $addressThree, $defaultShipping, $defaultBilling]);
+        $addresses = $this->_service->getAddresses($customerId);
+
+        $this->assertEquals(5, count($addresses));
+
+        $addresses = [
+            $this->_service->getDefaultBillingAddress($customerId),
+            $this->_service->getDefaultShippingAddress($customerId),
+        ];
+        $this->assertNotEquals($addresses[0], $addresses[1]);
+        $this->assertTrue($addresses[0]->isDefaultBilling());
+        $this->assertTrue($addresses[1]->isDefaultShipping());
+
+        $expectedDfltShipBuilder = $this->_addressBuilder->populate($defaultShipping);
+        $expectedDfltShipBuilder->setId($addresses[1]->getId());
+        $expectedDfltShip = $expectedDfltShipBuilder->create();
+
+        $expectedDfltBillBuilder = $this->_addressBuilder->populate($defaultBilling);
+        $expectedDfltBillBuilder->setId($addresses[0]->getId());
+        $expectedDfltBill = $expectedDfltBillBuilder->create();
+
+        $this->_assertAddressAndRegionArrayEquals($expectedDfltShip->__toArray(), $addresses[1]->__toArray());
+        $this->_assertAddressAndRegionArrayEquals($expectedDfltBill->__toArray(), $addresses[0]->__toArray());
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @magentoAppIsolation enabled
+     */
+    public function testSaveAddressesNoAddresses()
+    {
+        $addressIds = $this->_service->saveAddresses(1, []);
+        $this->assertEmpty($addressIds);
+        $customerId = 1;
+        $addresses = $this->_service->getAddresses($customerId);
+        $this->assertEquals($this->_expectedAddresses, $addresses);
+    }
+
+    /**
+     * @expectedException Exception
+     * @expectedExceptionMessage No customer with customerId 4200 exists
+     */
+    public function testSaveAddressesCustomerIdNotExist()
+    {
+        $proposedAddress = $this->_createSecondAddressBuilder()->create();
+        $this->_service->saveAddresses(4200, [$proposedAddress]);
+    }
+
+    /**
+     * @expectedException Exception
+     * @expectedExceptionMessage No customer with customerId this_is_not_a_valid_id exists
+     */
+    public function testSaveAddressesCustomerIdInvalid()
+    {
+        $proposedAddress = $this->_createSecondAddressBuilder()->create();
+        $this->_service->saveAddresses('this_is_not_a_valid_id', [$proposedAddress]);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_address.php
+     */
+    public function testDeleteAddressFromCustomer()
+    {
+        $customerId = 1;
+        $addressId = 1;
+        // See that customer already has an address with expected addressId
+        $addressDto = $this->_service->getAddressById($customerId, $addressId);
+        $this->assertEquals($addressDto->getId(), $addressId);
+
+        // Delete the address from the customer
+        $this->_service->deleteAddressFromCustomer($customerId, $addressId);
+
+        // See that address is deleted
+        try {
+            $addressDto = $this->_service->getAddressById($customerId, $addressId);
+            $this->fail('Did not catch expected exception');
+        } catch (Exception $e) {
+            $this->assertEquals($e->getCode(), Exception::CODE_ADDRESS_NOT_FOUND);
+        }
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_ADDRESS_NOT_FOUND
+     */
+    public function testDeleteAddressFromCustomerBadAddrId()
+    {
+        // Should throw the address not found exception
+        $this->_service->deleteAddressFromCustomer(1, 12345);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     *
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_ADDRESS_ID
+     */
+    public function testDeleteAddressFromCustomerAddrIdNotSet()
+    {
+        // Should throw the address not found exception
+        $this->_service->deleteAddressFromCustomer(1, 0);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoDataFixture Magento/Customer/_files/customer_two_addresses.php
+     * @expectedException Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_CUSTOMER_ID_MISMATCH
+     */
+    public function testDeleteAddressFromCustomerBadCustMismatch()
+    {
+        // Should throw the address not found excetion
+        $this->_service->deleteAddressFromCustomer(2, 1);
+    }
+
+    /**
+     * Helper function that returns an Address DTO that matches the data from customer_address fixture
+     *
+     * @return \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private function _createFirstAddressBuilder()
+    {
+        $addressBuilder = $this->_addressBuilder->populate($this->_expectedAddresses[0]);
+        $addressBuilder->setId(null);
+        return $addressBuilder;
+    }
+
+    /**
+     * Helper function that returns an Address DTO that matches the data from customer_two_address fixture
+     *
+     * @return \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private function _createSecondAddressBuilder()
+    {
+        return $this->_addressBuilder->populate($this->_expectedAddresses[1])
+            ->setId(null);
+    }
+
+    /**
+     * Checks that the arrays are equal, but accounts for the 'region' being an object
+     *
+     * @param array $expectedArray
+     * @param array $actualArray
+     */
+    protected function _assertAddressAndRegionArrayEquals($expectedArray, $actualArray)
+    {
+        if (array_key_exists('region', $expectedArray)) {
+            /** @var \Magento\Customer\Service\V1\Dto\Region $expectedRegion */
+            $expectedRegion = $expectedArray['region'];
+            unset($expectedArray['region']);
+        }
+        if (array_key_exists('region', $actualArray)) {
+            /** @var \Magento\Customer\Service\V1\Dto\Region $actualRegion */
+            $actualRegion = $actualArray['region'];
+            unset($actualArray['region']);
+        }
+
+        $this->assertEquals($expectedArray, $actualArray);
+
+        // Either both set or both unset
+        $this->assertTrue(!(isset($expectedRegion) xor isset($actualRegion)));
+        if (isset($expectedRegion) && isset($actualRegion)) {
+            $this->assertInstanceOf('Magento\Customer\Service\V1\Dto\Region', $expectedRegion);
+            $this->assertInstanceOf('Magento\Customer\Service\V1\Dto\Region', $actualRegion);
+            $this->assertEquals($expectedRegion->__toArray(), $actualRegion->__toArray());
+        }
+    }
+}
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerGroupServiceTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerGroupServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..4e0a4412629f9ed69fa0cc0d166f93acffc32184
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerGroupServiceTest.php
@@ -0,0 +1,181 @@
+<?php
+/**
+ * Integration test for service layer \Magento\Customer\Service\Customer
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1;
+
+class CustomerGroupServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * @var \Magento\ObjectManager
+     */
+    protected $_objectManager = null;
+
+    /**
+     * @var \Magento\Customer\Service\V1\CustomerGroupServiceInterface
+     */
+    protected $_groupService = null;
+
+    protected function setUp()
+    {
+
+        $this->_objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+        $this->_groupService = $this->_objectManager->get('Magento\Customer\Service\V1\CustomerGroupServiceInterface');
+    }
+
+    protected function tearDown()
+    {
+        $this->_objectManager = null;
+        $this->_groupService = null;
+    }
+
+    /**
+     * Cleaning up the extra groups that might have been created as part of the testing.
+     */
+    public static function tearDownAfterClass()
+    {
+        /** @var \Magento\Customer\Service\V1\CustomerGroupServiceInterface $customerGroupService */
+        $customerGroupService = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()->get(
+            'Magento\Customer\Service\V1\CustomerGroupServiceInterface'
+        );
+        foreach ($customerGroupService->getGroups() as $group) {
+            if ($group->getId() > 3) {
+                $customerGroupService->deleteGroup($group->getId());
+            }
+        }
+    }
+
+    /**
+     */
+    public function testGetGroups()
+    {
+        $groups = $this->_groupService->getGroups();
+        $this->assertEquals(4, count($groups));
+        $this->assertEquals(
+            [0, "NOT LOGGED IN", 3],
+            [$groups[0]->getId(), $groups[0]->getCode(), $groups[0]->getTaxClassId()]
+        );
+        $this->assertEquals(
+            [1, "General", 3],
+            [$groups[1]->getId(), $groups[1]->getCode(), $groups[1]->getTaxClassId()]
+        );
+        $this->assertEquals(
+            [2, "Wholesale", 3],
+            [$groups[2]->getId(), $groups[2]->getCode(), $groups[2]->getTaxClassId()]
+        );
+        $this->assertEquals(
+            [3, "Retailer", 3],
+            [$groups[3]->getId(), $groups[3]->getCode(), $groups[3]->getTaxClassId()]
+        );
+    }
+
+    /**
+     */
+    public function testGetGroupsFiltered()
+    {
+        $groups = $this->_groupService->getGroups(FALSE);
+        $this->assertEquals(3, count($groups));
+        $this->assertEquals(
+            [1, "General", 3],
+            [$groups[0]->getId(), $groups[0]->getCode(), $groups[0]->getTaxClassId()]
+        );
+        $this->assertEquals(
+            [2, "Wholesale", 3],
+            [$groups[1]->getId(), $groups[1]->getCode(), $groups[1]->getTaxClassId()]
+        );
+        $this->assertEquals(
+            [3, "Retailer", 3],
+            [$groups[2]->getId(), $groups[2]->getCode(), $groups[2]->getTaxClassId()]
+        );
+    }
+
+    /**
+     * @param array $group
+     * @dataProvider getGroups
+     */
+    public function testGetGroup($testGroup)
+    {
+        $group = $this->_groupService->getGroup($testGroup["id"]);
+        $this->assertEquals($testGroup["id"], $group->getId());
+        $this->assertEquals($testGroup["code"], $group->getCode());
+        $this->assertEquals($testGroup["taxClass"], $group->getTaxClassId());
+    }
+
+    public function testCreateGroup()
+    {
+        $group = new V1\Dto\CustomerGroup([
+          'id' => null,
+          'code' => "Test Group",
+          'tax_class_id' => 4
+        ]);
+        $groupId = $this->_groupService->saveGroup($group);
+        $this->assertNotNull($groupId);
+
+        $newGroup = $this->_groupService->getGroup($groupId);
+        $this->assertEquals($groupId, $newGroup->getId());
+        $this->assertEquals($group->getCode(), $newGroup->getCode());
+        $this->assertEquals($group->getTaxClassId(), $newGroup->getTaxClassId());
+    }
+
+    public function testUpdateGroup()
+    {
+        $group = new V1\Dto\CustomerGroup([
+          'id' => null,
+          'code' => "New Group",
+          'tax_class_id' => 4
+        ]);
+        $groupId = $this->_groupService->saveGroup($group);
+        $this->assertNotNull($groupId);
+
+        $newGroup = $this->_groupService->getGroup($groupId);
+        $this->assertEquals($groupId, $newGroup->getId());
+        $this->assertEquals($group->getCode(), $newGroup->getCode());
+        $this->assertEquals($group->getTaxClassId(), $newGroup->getTaxClassId());
+
+        $updates = new V1\Dto\CustomerGroup([
+          'id' => $groupId,
+          'code' => "Updated Group",
+          'tax_class_id' => 2
+        ]);
+        $newId = $this->_groupService->saveGroup($updates);
+        $this->assertEquals($newId, $groupId);
+        $updatedGroup = $this->_groupService->getGroup($groupId);
+        $this->assertEquals($updates->getCode(), $updatedGroup->getCode());
+        $this->assertEquals($updates->getTaxClassId(), $updatedGroup->getTaxClassId());
+    }
+
+    /**
+     * @return array
+     */
+    public function getGroups()
+    {
+        return [ [["id" => 0, "code" => "NOT LOGGED IN", "taxClass" => 3]],
+                 [["id" => 1, "code" => "General", "taxClass" => 3]],
+                 [["id" => 2, "code" => "Wholesale", "taxClass" => 3]],
+                 [["id" => 3, "code" => "Retailer", "taxClass" => 3]],
+                ];
+    }
+}
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..a42fda2b25bf0dfafe4b4b1095205ec2e595b4be
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php
@@ -0,0 +1,113 @@
+<?php
+/**
+ * Integration test for service layer \Magento\Customer\Service\Eav\AttributeMetadataV1
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+class CustomerMetadataServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /** @var \Magento\Customer\Service\V1\CustomerServiceInterface */
+    private $_customerService;
+
+    /** @var \Magento\Customer\Service\V1\CustomerMetadataServiceInterface */
+    private $_service;
+
+    protected function setUp()
+    {
+        $objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+        $this->_customerService = $objectManager->create('Magento\Customer\Service\V1\CustomerServiceInterface');
+        $this->_service = $objectManager->create('Magento\Customer\Service\V1\CustomerMetadataServiceInterface');
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testGetCustomerAttributeMetadata()
+    {
+        // Expect these attributes to exist but do not check the value
+        $expectAttrsWOutVals = array('updated_at', 'created_at', 'password_hash');
+
+        // Expect these attributes to exist and check the value - values come from _files/customer.php
+        $expectAttrsWithVals = array(
+            'entity_id'                 => '1',
+            'entity_type_id'            => '1',
+            'attribute_set_id'          => '1',
+            'website_id'                => '1',
+            'store_id'                  => '1',
+            'group_id'                  => '1',
+            'disable_auto_group_change' => '0',
+            'firstname'                 => 'Firstname',
+            'lastname'                  => 'Lastname',
+            'email'                     => 'customer@example.com',
+            'default_billing'           => '1',
+            'default_shipping'          => '1',
+        );
+
+        $customer = $this->_customerService->getCustomer(1);
+        $this->assertNotNull($customer);
+
+        $attributes = $customer->getAttributes();
+        $this->assertNotEmpty($attributes);
+
+        foreach ($attributes as $attributeCode => $attributeValue) {
+            $this->assertNotNull($attributeCode);
+            $this->assertNotNull($attributeValue);
+            $attributeMetadata = $this->_service->getCustomerAttributeMetadata($attributeCode);
+            $attrMetadataCode = $attributeMetadata->getAttributeCode();
+            $this->assertSame($attributeCode, $attrMetadataCode);
+            if (($key = array_search($attrMetadataCode, $expectAttrsWOutVals)) !== false) {
+                unset($expectAttrsWOutVals[$key]);
+            } else {
+                $this->assertArrayHasKey($attrMetadataCode, $expectAttrsWithVals);
+                $this->assertSame(
+                    $expectAttrsWithVals[$attrMetadataCode],
+                    $attributeValue,
+                    "Failed for $attrMetadataCode"
+                );
+                unset($expectAttrsWithVals[$attrMetadataCode]);
+            }
+        }
+        $this->assertEmpty($expectAttrsWOutVals);
+        $this->assertEmpty($expectAttrsWithVals);
+    }
+
+    public function testAttributeMetadataCached()
+    {
+        $firstCallMetadata = $this->_service->getAddressAttributeMetadata('firstname');
+        $secondCallMetadata = $this->_service->getAddressAttributeMetadata('firstname');
+
+        $this->assertSame($firstCallMetadata, $secondCallMetadata);
+
+    }
+
+    public function testGetAddressAttributeMetadata()
+    {
+        $vatValidMetadata = $this->_service->getAddressAttributeMetadata('vat_is_valid');
+
+        $this->assertNotNull($vatValidMetadata);
+        $this->assertEquals('vat_is_valid', $vatValidMetadata->getAttributeCode());
+        $this->assertEquals('text', $vatValidMetadata->getFrontendInput());
+        $this->assertEquals('VAT number validity', $vatValidMetadata->getStoreLabel());
+    }
+}
diff --git a/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..5395bf9aacffc51fb4dd91a467a06769187be376
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php
@@ -0,0 +1,596 @@
+<?php
+
+namespace Magento\Customer\Service\V1;
+use Magento\Customer\Service\Entity\V1\Exception;
+use Magento\Customer\Service\V1;
+
+/**
+ * Integration test for service layer \Magento\Customer\Service\CustomerV1
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ */
+class CustomerServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /** @var CustomerServiceInterface */
+    private $_service;
+
+    /** @var CustomerAccountServiceInterface Needed for password checking */
+    private $_accountService;
+
+    /** @var \Magento\ObjectManager */
+    private $_objectManager;
+
+    /** @var \Magento\Customer\Service\V1\Dto\Address[] */
+    private $_expectedAddresses;
+
+    /** @var \Magento\Customer\Service\V1\Dto\AddressBuilder */
+    private $_addressBuilder;
+
+    /** @var \Magento\Customer\Service\V1\Dto\CustomerBuilder */
+    private $_customerBuilder;
+
+    protected function setUp()
+    {
+        $this->_objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+        $this->_service = $this->_objectManager->create('Magento\Customer\Service\V1\CustomerServiceInterface');
+        $this->_accountService = $this->_objectManager
+            ->create('Magento\Customer\Service\V1\CustomerAccountServiceInterface');
+
+        $this->_addressBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\AddressBuilder');
+        $this->_customerBuilder = $this->_objectManager->create('Magento\Customer\Service\V1\Dto\CustomerBuilder');
+
+        $this->_addressBuilder->setId(1)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(true)
+            ->setDefaultShipping(true)
+            ->setPostcode('75477')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Green str, 67'])
+            ->setTelephone('3468676')
+            ->setCity('CityM')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address = $this->_addressBuilder->create();
+
+        /* XXX: would it be better to have a clear method for this? */
+        $this->_addressBuilder->setId(2)
+            ->setCountryId('US')
+            ->setCustomerId(1)
+            ->setDefaultBilling(false)
+            ->setDefaultShipping(false)
+            ->setPostcode('47676')
+            ->setRegion(new V1\Dto\Region([
+                'region_code' => 'AL',
+                'region' => 'Alabama',
+                'region_id' => 1
+            ]))
+            ->setStreet(['Black str, 48'])
+            ->setCity('CityX')
+            ->setTelephone('3234676')
+            ->setFirstname('John')
+            ->setLastname('Smith');
+        $address2 = $this->_addressBuilder->create();
+
+        $this->_expectedAddresses = [$address, $address2];
+    }
+
+    /**
+     * @param mixed $custId
+     * @dataProvider invalidCustomerIdsDataProvider
+     * @expectedException Exception
+     * @expectedExceptionMessage customerId
+     */
+    public function testInvalidCustomerIds($custId)
+    {
+        $this->_service->getCustomer($custId);
+    }
+
+    public function invalidCustomerIdsDataProvider()
+    {
+        return array(
+            array('ab'),
+            array(' '),
+            array(-1),
+            array(0),
+            array(' 1234'),
+            array('-1'),
+            array('0'),
+        );
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testGetCustomerCached()
+    {
+        $firstCall = $this->_service->getCustomer(1);
+        $secondCall = $this->_service->getCustomer(1);
+
+        $this->assertSame($firstCall, $secondCall);
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     * @magentoAppIsolation enabled
+     */
+    public function testGetCustomer()
+    {
+        // _files/customer.php sets the customer id to 1
+        $customer = $this->_service->getCustomer(1);
+
+        // All these expected values come from _files/customer.php fixture
+        $this->assertEquals(1, $customer->getCustomerId());
+        $this->assertEquals('customer@example.com', $customer->getEmail());
+        $this->assertEquals('Firstname', $customer->getFirstname());
+        $this->assertEquals('Lastname', $customer->getLastname());
+    }
+
+    /**
+     * @expectedException Exception
+     * @expectedExceptionMessage No customer with customerId 1 exists.
+     */
+    public function testGetCustomerNotExist()
+    {
+        // No fixture, so customer with id 1 shouldn't exist, exception should be thrown
+        $this->_service->getCustomer(1);
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveCustomer()
+    {
+        $existingCustId = 1;
+
+        $email = 'savecustomer@example.com';
+        $firstName = 'Firstsave';
+        $lastname = 'Lastsave';
+
+        $customerBefore = $this->_service->getCustomer($existingCustId);
+
+        $customerData = array_merge($customerBefore->__toArray(), array(
+            'id' => 1,
+            'email' => $email,
+            'firstname' => $firstName,
+            'lastname' => $lastname,
+            'created_in' => 'Admin',
+            'password' => 'notsaved'
+        ));
+        $this->_customerBuilder->populateWithArray($customerData);
+        $modifiedCustomer = $this->_customerBuilder->create();
+
+        $returnedCustomerId = $this->_service->saveCustomer($modifiedCustomer, 'aPassword');
+        $this->assertEquals($existingCustId, $returnedCustomerId);
+        $customerAfter = $this->_service->getCustomer($existingCustId);
+        $this->assertEquals($email, $customerAfter->getEmail());
+        $this->assertEquals($firstName, $customerAfter->getFirstname());
+        $this->assertEquals($lastname, $customerAfter->getLastname());
+        $this->assertEquals('Admin', $customerAfter->getAttribute('created_in'));
+        $this->_accountService->authenticate(
+            $customerAfter->getEmail(),
+            'aPassword',
+            true
+        );
+        $attributesBefore = $customerBefore->getAttributes();
+        $attributesAfter = $customerAfter->getAttributes();
+        // ignore 'updated_at'
+        unset($attributesBefore['updated_at']);
+        unset($attributesAfter['updated_at']);
+        $inBeforeOnly = array_diff_assoc($attributesBefore, $attributesAfter);
+        $inAfterOnly = array_diff_assoc($attributesAfter, $attributesBefore);
+        $expectedInBefore = array(
+            'firstname',
+            'lastname',
+            'email',
+            'password_hash',
+        );
+        $this->assertEquals($expectedInBefore, array_keys($inBeforeOnly));
+        $this->assertContains('created_in', array_keys($inAfterOnly));
+        $this->assertContains('firstname', array_keys($inAfterOnly));
+        $this->assertContains('lastname', array_keys($inAfterOnly));
+        $this->assertContains('email', array_keys($inAfterOnly));
+        $this->assertContains('password_hash', array_keys($inAfterOnly));
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveCustomerWithoutChangingPassword()
+    {
+        $existingCustId = 1;
+
+        $email = 'savecustomer@example.com';
+        $firstName = 'Firstsave';
+        $lastName = 'Lastsave';
+
+        $customerBefore = $this->_service->getCustomer($existingCustId);
+        $customerData = array_merge($customerBefore->__toArray(),
+            [
+                'id' => 1,
+                'email' => $email,
+                'firstname' => $firstName,
+                'lastname' => $lastName,
+                'created_in' => 'Admin'
+            ]
+        );
+        $this->_customerBuilder->populateWithArray($customerData);
+        $modifiedCustomer = $this->_customerBuilder->create();
+
+        $returnedCustomerId = $this->_service->saveCustomer($modifiedCustomer);
+        $this->assertEquals($existingCustId, $returnedCustomerId);
+        $customerAfter = $this->_service->getCustomer($existingCustId);
+        $this->assertEquals($email, $customerAfter->getEmail());
+        $this->assertEquals($firstName, $customerAfter->getFirstname());
+        $this->assertEquals($lastName, $customerAfter->getLastname());
+        $this->assertEquals('Admin', $customerAfter->getAttribute('created_in'));
+        $this->_accountService->authenticate(
+            $customerAfter->getEmail(),
+            'password',
+            true
+        );
+        $attributesBefore = $customerBefore->getAttributes();
+        $attributesAfter = $customerAfter->getAttributes();
+        // ignore 'updated_at'
+        unset($attributesBefore['updated_at']);
+        unset($attributesAfter['updated_at']);
+        $inBeforeOnly = array_diff_assoc($attributesBefore, $attributesAfter);
+        $inAfterOnly = array_diff_assoc($attributesAfter, $attributesBefore);
+        $expectedInBefore = array(
+            'firstname',
+            'lastname',
+            'email',
+        );
+        sort($expectedInBefore);
+        $actualInBeforeOnly = array_keys($inBeforeOnly);
+        sort($actualInBeforeOnly);
+        $this->assertEquals($expectedInBefore, $actualInBeforeOnly);
+        $expectedInAfter = array(
+            'firstname',
+            'lastname',
+            'email',
+            'created_in',
+        );
+        sort($expectedInAfter);
+        $actualInAfterOnly = array_keys($inAfterOnly);
+        sort($actualInAfterOnly);
+        $this->assertEquals($expectedInAfter, $actualInAfterOnly);
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveCustomerPasswordCannotSetThroughAttributeSetting()
+    {
+        $existingCustId = 1;
+
+        $email = 'savecustomer@example.com';
+        $firstName = 'Firstsave';
+        $lastName = 'Lastsave';
+
+        $customerBefore = $this->_service->getCustomer($existingCustId);
+        $customerData = array_merge($customerBefore->__toArray(),
+            [
+                'id' => 1,
+                'email' => $email,
+                'firstname' => $firstName,
+                'lastname' => $lastName,
+                'created_in' => 'Admin',
+                'password' => 'aPassword'
+            ]
+        );
+        $this->_customerBuilder->populateWithArray($customerData);
+        $modifiedCustomer = $this->_customerBuilder->create();
+
+        $returnedCustomerId = $this->_service->saveCustomer($modifiedCustomer);
+        $this->assertEquals($existingCustId, $returnedCustomerId);
+        $customerAfter = $this->_service->getCustomer($existingCustId);
+        $this->assertEquals($email, $customerAfter->getEmail());
+        $this->assertEquals($firstName, $customerAfter->getFirstname());
+        $this->assertEquals($lastName, $customerAfter->getLastname());
+        $this->assertEquals('Admin', $customerAfter->getAttribute('created_in'));
+        $this->_accountService->authenticate(
+            $customerAfter->getEmail(),
+            'password',
+            true
+        );
+        $attributesBefore = $customerBefore->getAttributes();
+        $attributesAfter = $customerAfter->getAttributes();
+        // ignore 'updated_at'
+        unset($attributesBefore['updated_at']);
+        unset($attributesAfter['updated_at']);
+        $inBeforeOnly = array_diff_assoc($attributesBefore, $attributesAfter);
+        $inAfterOnly = array_diff_assoc($attributesAfter, $attributesBefore);
+        $expectedInBefore = array(
+            'firstname',
+            'lastname',
+            'email',
+        );
+        sort($expectedInBefore);
+        $actualInBeforeOnly = array_keys($inBeforeOnly);
+        sort($actualInBeforeOnly);
+        $this->assertEquals($expectedInBefore, $actualInBeforeOnly);
+        $expectedInAfter = array(
+            'firstname',
+            'lastname',
+            'email',
+            'created_in',
+        );
+        sort($expectedInAfter);
+        $actualInAfterOnly = array_keys($inAfterOnly);
+        sort($actualInAfterOnly);
+        $this->assertEquals($expectedInAfter, $actualInAfterOnly);
+    }
+
+    /**
+     * @magentoDbIsolation enabled
+     * @expectedException \Magento\Validator\ValidatorException
+     * @expectedExceptionMessage Please correct this email address
+     */
+    public function testSaveCustomerException()
+    {
+        $customerData = [
+            'id' => 1,
+            'password' => 'aPassword'
+        ];
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        try {
+            $this->_service->saveCustomer($customerEntity);
+        } catch (Exception $e) {
+            $this->assertEquals('There were one or more errors validating the customer object.', $e->getMessage());
+            $this->assertEquals(Exception::CODE_VALIDATION_FAILED, $e->getCode());
+            throw $e->getPrevious();
+        }
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveNonexistingCustomer()
+    {
+        $existingCustId = 1;
+        $existingCustomer = $this->_service->getCustomer($existingCustId);
+
+        $newCustId = 2;
+        $email = 'savecustomer@example.com';
+        $firstName = 'Firstsave';
+        $lastName = 'Lastsave';
+        $customerData = array_merge($existingCustomer->__toArray(),
+            [
+                'id' => $newCustId,
+                'email' => $email,
+                'firstname' => $firstName,
+                'lastname' => $lastName,
+                'created_in' => 'Admin'
+            ]
+        );
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $customerId = $this->_service->saveCustomer($customerEntity, 'aPassword');
+        $this->assertEquals($newCustId, $customerId);
+        $customerAfter = $this->_service->getCustomer($customerId);
+        $this->assertEquals($email, $customerAfter->getEmail());
+        $this->assertEquals($firstName, $customerAfter->getFirstname());
+        $this->assertEquals($lastName, $customerAfter->getLastname());
+        $this->assertEquals('Admin', $customerAfter->getAttribute('created_in'));
+        $this->_accountService->authenticate(
+            $customerAfter->getEmail(),
+            'aPassword',
+            true
+        );
+        $attributesBefore = $existingCustomer->getAttributes();
+        $attributesAfter = $customerAfter->getAttributes();
+        // ignore 'updated_at'
+        unset($attributesBefore['updated_at']);
+        unset($attributesAfter['updated_at']);
+        unset($attributesAfter['reward_update_notification']);
+        unset($attributesAfter['reward_warning_notification']);
+        $inBeforeOnly = array_diff_assoc($attributesBefore, $attributesAfter);
+        $inAfterOnly = array_diff_assoc($attributesAfter, $attributesBefore);
+        $expectedInBefore = array(
+            'firstname',
+            'lastname',
+            'email',
+            'entity_id',
+            'password_hash',
+        );
+        sort($expectedInBefore);
+        $actualInBeforeOnly = array_keys($inBeforeOnly);
+        sort($actualInBeforeOnly);
+        $this->assertEquals($expectedInBefore, $actualInBeforeOnly);
+        $expectedInAfter = array(
+            'firstname',
+            'lastname',
+            'email',
+            'entity_id',
+            'created_in',
+            'password_hash',
+        );
+        sort($expectedInAfter);
+        $actualInAfterOnly = array_keys($inAfterOnly);
+        sort($actualInAfterOnly);
+        $this->assertEquals($expectedInAfter, $actualInAfterOnly);
+    }
+
+    /**
+     * @magentoDbIsolation enabled
+     */
+    public function testSaveCustomerInServiceVsInModel()
+    {
+        $email = 'email@example.com';
+        $email2 = 'email2@example.com';
+        $firstname = 'Tester';
+        $lastname = 'McTest';
+        $groupId = 1;
+        $password = 'aPassword';
+
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $customerModel = $this->_objectManager->create('Magento\Customer\Model\CustomerFactory')
+            ->create();
+        $customerModel->setEmail($email)
+            ->setFirstname($firstname)
+            ->setLastname($lastname)
+            ->setGroupId($groupId)
+            ->setPassword($password);
+        $customerModel->save();
+        /** @var \Magento\Customer\Model\Customer $customerModel */
+        $savedModel = $this->_objectManager->create('Magento\Customer\Model\CustomerFactory')
+            ->create()
+            ->load($customerModel->getId());
+        $dataInModel = $savedModel->getData();
+
+        $this->_customerBuilder->setEmail($email2)
+            ->setFirstname($firstname)
+            ->setLastname($lastname)
+            ->setGroupId($groupId);
+        $newCustomerEntity = $this->_customerBuilder->create();
+        $customerId = $this->_service->saveCustomer($newCustomerEntity, $password);
+        $this->assertNotNull($customerId);
+        $savedCustomer = $this->_service->getCustomer($customerId);
+        $dataInService = $savedCustomer->getAttributes();
+        foreach ($dataInModel as $key => $value) {
+            if (!in_array(
+                $key,
+                array('created_at', 'updated_at', 'email', 'is_active', 'entity_id', 'password_hash',
+                     'attribute_set_id')
+            )) {
+                if (is_null($value)) {
+                    $this->assertArrayNotHasKey($key, $dataInService);
+                } else {
+                    $this->assertEquals($value, $dataInService[$key], 'Failed asserting value for '. $key);
+                }
+            }
+        }
+        $this->assertArrayNotHasKey('is_active', $dataInService);
+        $this->assertNotNull($dataInService['created_at']);
+        $this->assertNotNull($dataInService['updated_at']);
+        $this->assertNotNull($dataInService['entity_id']);
+        $this->assertNotNull($dataInService['password_hash']);
+        $this->assertEquals($email2, $dataInService['email']);
+    }
+
+    /**
+     * @magentoDbIsolation enabled
+     */
+    public function testSaveNewCustomer()
+    {
+        $email = 'email@example.com';
+        $storeId = 1;
+        $firstname = 'Tester';
+        $lastname = 'McTest';
+        $groupId = 1;
+
+        $this->_customerBuilder->setStoreId($storeId)
+            ->setEmail($email)
+            ->setFirstname($firstname)
+            ->setLastname($lastname)
+            ->setGroupId($groupId);
+        $newCustomerEntity = $this->_customerBuilder->create();
+        $customerId = $this->_service->saveCustomer($newCustomerEntity, 'aPassword');
+        $this->assertNotNull($customerId);
+        $savedCustomer = $this->_service->getCustomer($customerId);
+        $this->assertEquals($email, $savedCustomer->getEmail());
+        $this->assertEquals($storeId, $savedCustomer->getStoreId());
+        $this->assertEquals($firstname, $savedCustomer->getFirstname());
+        $this->assertEquals($lastname, $savedCustomer->getLastname());
+        $this->assertEquals($groupId, $savedCustomer->getGroupId());
+        $this->assertTrue(!$savedCustomer->getSuffix());
+    }
+
+    /**
+     * @magentoAppArea frontend
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveNewCustomerFromClone()
+    {
+        $email = 'savecustomer@example.com';
+        $firstName = 'Firstsave';
+        $lastname = 'Lastsave';
+
+        $existingCustId = 1;
+        $existingCustomer = $this->_service->getCustomer($existingCustId);
+        $customerData = array_merge($existingCustomer->__toArray(),
+            [
+                'email' => $email,
+                'firstname' => $firstName,
+                'lastname' => $lastname,
+                'created_in' => 'Admin'
+            ]
+        );
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $customerId = $this->_service->saveCustomer($customerEntity, 'aPassword');
+        $this->assertNotEmpty($customerId);
+        $customer = $this->_service->getCustomer($customerId);
+        $this->assertEquals($email, $customer->getEmail());
+        $this->assertEquals($firstName, $customer->getFirstname());
+        $this->assertEquals($lastname, $customer->getLastname());
+        $this->assertEquals('Admin', $customer->getAttribute('created_in'));
+        $this->_accountService->authenticate(
+            $customer->getEmail(),
+            'aPassword',
+            true
+        );
+    }
+
+    /**
+     * @magentoDataFixture Magento/Customer/_files/customer.php
+     */
+    public function testSaveCustomerRpToken()
+    {
+        $this->_customerBuilder->populateWithArray(array_merge($this->_service->getCustomer(1)->__toArray(), [
+            'rp_token' => 'token',
+            'rp_token_created_at' => '2013-11-05'
+        ]));
+        $customer = $this->_customerBuilder->create();
+        $this->_service->saveCustomer($customer);
+
+        // Empty current reset password token i.e. invalidate it
+        $this->_customerBuilder->populateWithArray(array_merge($this->_service->getCustomer(1)->__toArray(), [
+            'rp_token' => null,
+            'rp_token_created_at' => null
+        ]));
+        $this->_customerBuilder->setConfirmation(null);
+        $customer = $this->_customerBuilder->create();
+
+        $this->_service->saveCustomer($customer, 'password');
+
+        $customer = $this->_service->getCustomer(1);
+        $this->assertEquals('Firstname', $customer->getFirstname());
+        $this->assertNull($customer->getAttribute('rp_token'));
+    }
+}
diff --git a/dev/tests/integration/testsuite/Magento/Customer/_files/customer.php b/dev/tests/integration/testsuite/Magento/Customer/_files/customer.php
index f640fe7342733a8ee264195aa8b77cfeeb168e25..3f29b8530339b22410dfc7cde2fa339a84d2ca57 100644
--- a/dev/tests/integration/testsuite/Magento/Customer/_files/customer.php
+++ b/dev/tests/integration/testsuite/Magento/Customer/_files/customer.php
@@ -28,9 +28,9 @@ $customer = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
     ->create('Magento\Customer\Model\Customer');
 $customer
     ->setWebsiteId(1)
-    ->setEntityId(1)
+    ->setId(1)
     ->setEntityTypeId(1)
-    ->setAttributeSetId(0)
+    ->setAttributeSetId(1)
     ->setEmail('customer@example.com')
     ->setPassword('password')
     ->setGroupId(1)
diff --git a/dev/tests/integration/testsuite/Magento/Customer/_files/customer_address.php b/dev/tests/integration/testsuite/Magento/Customer/_files/customer_address.php
index 451fa32fb5708a02cddd55b8f60c3e2f5c269dab..5b8aac69eed224d42fd5a53c3fe877546cb2a040 100644
--- a/dev/tests/integration/testsuite/Magento/Customer/_files/customer_address.php
+++ b/dev/tests/integration/testsuite/Magento/Customer/_files/customer_address.php
@@ -31,13 +31,15 @@ $customerAddress->isObjectNew(true);
 $customerAddress->setCustomerId(1)
     ->setData(array(
         'entity_id' => 1,
+        'attribute_set_id' => 2,
         'telephone' => 3468676,
         'postcode' => 75477,
-        'country_id' => 'AL',
+        'country_id' => 'US',
         'city' => 'CityM',
         'street' => 'Green str, 67',
         'lastname' => 'Smith',
         'firstname' => 'John',
-        'parent_id' => 1
+        'parent_id' => 1,
+        'region_id' => 1
     ));
 $customerAddress->save();
diff --git a/dev/tests/integration/testsuite/Magento/Customer/_files/customer_two_addresses.php b/dev/tests/integration/testsuite/Magento/Customer/_files/customer_two_addresses.php
index de427f9497dc51f08b1311a3b77e6e9ee4a772c3..5ac194c7aec2905a2817f7c8ca62ce046ec3384b 100644
--- a/dev/tests/integration/testsuite/Magento/Customer/_files/customer_two_addresses.php
+++ b/dev/tests/integration/testsuite/Magento/Customer/_files/customer_two_addresses.php
@@ -33,13 +33,15 @@ $customerAddress->isObjectNew(true);
 $customerAddress->setCustomerId(1)
     ->setData(array(
         'entity_id' => 2,
+        'attribute_set_id' => 2,
         'telephone' => 3234676,
         'postcode' => 47676,
-        'country_id' => 'AL',
+        'country_id' => 'US',
         'city' => 'CityX',
         'street' => 'Black str, 48',
         'lastname' => 'Smith',
         'firstname' => 'John',
-        'parent_id' => 1
+        'parent_id' => 1,
+        'region_id' => 1
     ));
 $customerAddress->save();
diff --git a/dev/tests/integration/testsuite/Magento/Customer/_files/inactive_customer.php b/dev/tests/integration/testsuite/Magento/Customer/_files/inactive_customer.php
new file mode 100644
index 0000000000000000000000000000000000000000..ebddc5f3b74907a51cc05fa8d30193d1762cfc3d
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/Customer/_files/inactive_customer.php
@@ -0,0 +1,44 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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    Magento
+ * @package     Magento_Customer
+ * @subpackage  integration_tests
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+$customer = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\Customer\Model\Customer');
+$customer
+    ->setWebsiteId(1)
+    ->setId(1)
+    ->setConfirmation($customer->getRandomConfirmationKey())
+    ->setEntityTypeId(1)
+    ->setAttributeSetId(0)
+    ->setEmail('customer@needAconfirmation.com')
+    ->setPassword('password')
+    ->setGroupId(1)
+    ->setStoreId(1)
+    ->setFirstname('Firstname')
+    ->setLastname('Lastname')
+    ->setDefaultBilling(1)
+    ->setDefaultShipping(1);
+$customer->isObjectNew(true);
+$customer->save();
diff --git a/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/ObserverTest.php b/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/ObserverTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..e2b940346ae30f63b015e8f6651d0dd206593af8
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/ObserverTest.php
@@ -0,0 +1,51 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\GoogleShopping\Model;
+
+class ObserverTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * @magentoDataFixture Magento/GoogleShopping/Model/_files/flag_expired.php
+     */
+    public function testCheckSynchronizationOperationsWithExpiredFlag()
+    {
+        $objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+
+        /** @var \Magento\AdminNotification\Model\Inbox $inbox */
+        $inbox = $objectManager->create('Magento\AdminNotification\Model\Inbox');
+        $notice = $inbox->loadLatestNotice();
+        $this->assertNotContains('Google Shopping', (string)$notice->getTitle());
+
+        /** @var \Magento\GoogleShopping\Model\Observer $observer */
+        $observer = $objectManager->get('Magento\GoogleShopping\Model\Observer');
+        $dummyEventData = $this->getMock('\Magento\Event\Observer', array(), array(), '', false);
+        $result = $observer->checkSynchronizationOperations($dummyEventData);
+
+        $this->assertSame($observer, $result);
+
+        $notice = $inbox->loadLatestNotice();
+        $this->assertContains('Google Shopping', (string)$notice->getTitle());
+    }
+}
diff --git a/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/_files/flag_expired.php b/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/_files/flag_expired.php
new file mode 100644
index 0000000000000000000000000000000000000000..971394ce5241b3fec21b750fa2b9aa83560da063
--- /dev/null
+++ b/dev/tests/integration/testsuite/Magento/GoogleShopping/Model/_files/flag_expired.php
@@ -0,0 +1,38 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+/**
+ * Expired flag for the google shopping synchronization
+ */
+$objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+
+ /** @var $flag \Magento\GoogleShopping\Model\Flag */
+$flag = $objectManager->create('Magento\GoogleShopping\Model\Flag');
+$flag->lock();
+
+/** @var $flagResource \Magento\Core\Model\Resource\Flag */
+$flagResource = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\Core\Model\Resource\Flag');
+$flag->setLastUpdate(date('Y-m-d H:i:s', time() - \Magento\GoogleShopping\Model\Flag::FLAG_TTL - 1));
+$flagResource->save($flag);
diff --git a/dev/tests/integration/testsuite/Magento/User/Model/UserTest.php b/dev/tests/integration/testsuite/Magento/User/Model/UserTest.php
index 4a5b37614b1428fd71bbaecb0d81d7b7bb78bf8a..2b36d5f27cf157c9ae8b545834af90b10bf9afd7 100644
--- a/dev/tests/integration/testsuite/Magento/User/Model/UserTest.php
+++ b/dev/tests/integration/testsuite/Magento/User/Model/UserTest.php
@@ -70,6 +70,19 @@ class UserTest extends \PHPUnit_Framework_TestCase
         $crud->testCrud();
     }
 
+    /**
+     * @magentoDataFixture Magento/User/_files/dummy_user.php
+     */
+    public function testCreatedOnUpdate()
+    {
+        $this->_model->loadByUsername('user_created_date');
+        $this->assertEquals('2010-01-06 00:00:00', $this->_model->getCreated());
+        //reload to update lognum record
+        $this->_model->getResource()->recordLogin($this->_model);
+        $this->_model->reload();
+        $this->assertEquals('2010-01-06 00:00:00', $this->_model->getCreated());
+    }
+
     /**
      * Ensure that an exception is not thrown, if the user does not exist
      */
diff --git a/dev/tests/integration/testsuite/Magento/User/_files/dummy_user.php b/dev/tests/integration/testsuite/Magento/User/_files/dummy_user.php
index 37a4a1f9140213c7f20ae71d7ea864eeafb8fc1e..5be6390a35eba12bb520e70acdc427f0787dfe2a 100644
--- a/dev/tests/integration/testsuite/Magento/User/_files/dummy_user.php
+++ b/dev/tests/integration/testsuite/Magento/User/_files/dummy_user.php
@@ -38,3 +38,20 @@ $user->setFirstname('Dummy')
     ->setUsername('dummy_username')
     ->setPassword('dummy_password1')
     ->save();
+
+
+\Magento\TestFramework\Helper\Bootstrap::getObjectManager()->get('Magento\Core\Model\App')
+    ->loadArea(\Magento\Backend\App\Area\FrontNameResolver::AREA_CODE);
+$user = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\User\Model\User');
+$user->setFirstname('CreateDate')
+    ->setLastname('User 2')
+    ->setEmail('dummy2@dummy.com')
+    ->setUsername('user_created_date')
+    ->setPassword('dummy_password2')
+    ->save();
+$user = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()
+    ->create('Magento\User\Model\User');
+$user->loadByUsername('user_created_date');
+$user->setCreated('2010-01-06 00:00:00');
+$user->save();
\ No newline at end of file
diff --git a/dev/tests/js/jsTestDriverOrder.php b/dev/tests/js/jsTestDriverOrder.php
index e55724a1c6f3ee2dbad2375be5190877862ce65a..7fe3e7f813902dfa98532a645f5c611c8c6b1be9 100644
--- a/dev/tests/js/jsTestDriverOrder.php
+++ b/dev/tests/js/jsTestDriverOrder.php
@@ -32,7 +32,7 @@ return array(
     '/pub/lib/jquery/jquery.js',
     '/pub/lib/jquery/jquery-ui.js',
     '/pub/lib/jquery/jquery.cookie.js',
-    '/pub/lib/head.load.min.js',
+    '/pub/lib/headjs/head.load.min.js',
     '/pub/lib/mage/mage.js',
     '/pub/lib/mage/decorate.js',
     '/pub/lib/jquery/jquery.validate.js',
diff --git a/dev/tests/static/framework/Magento/TestFramework/Utility/Files.php b/dev/tests/static/framework/Magento/TestFramework/Utility/Files.php
index 49d9b988868eb162186aa603123fe9e1a8da4aec..ec14f402d8db33904934beda634e93fb09b2ad12 100644
--- a/dev/tests/static/framework/Magento/TestFramework/Utility/Files.php
+++ b/dev/tests/static/framework/Magento/TestFramework/Utility/Files.php
@@ -47,17 +47,25 @@ class Files
     protected $_path = '';
 
     /**
-     * Setter/Getter for an instance of self
+     * Setter for an instance of self
+     *
+     * Also can unset the current instance, if no arguments are specified
+     *
+     * @param Files|null $instance
+     */
+    public static function setInstance(Files $instance = null)
+    {
+        self::$_instance = $instance;
+    }
+
+    /**
+     * Getter for an instance of self
      *
-     * @param \Magento\TestFramework\Utility\Files $instance
      * @return \Magento\TestFramework\Utility\Files
      * @throws \Exception when there is no instance set
      */
-    public static function init(\Magento\TestFramework\Utility\Files $instance = null)
+    public static function init()
     {
-        if ($instance) {
-            self::$_instance = $instance;
-        }
         if (!self::$_instance) {
             throw new \Exception('Instance is not set yet.');
         }
@@ -633,8 +641,9 @@ class Files
             /**
              * Use realpath() instead of file_exists() to avoid incorrect work on Windows because of case insensitivity
              * of file names
+             * Note that realpath() automatically changes directory separator to the OS-native
              */
-            if (realpath($fullPath) == $fullPath) {
+            if (realpath($fullPath) == str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $fullPath)) {
                 $fileContent = file_get_contents($fullPath);
                 if (strpos($fileContent, 'namespace ' . $namespace) !== false &&
                     (strpos($fileContent, 'class ' . $className) !== false ||
@@ -715,4 +724,39 @@ class Files
 
         return self::$_cache[$key];
     }
+
+    /**
+     * Read all text files by specified glob pattern and combine them into an array of valid files/directories
+     *
+     * The Magento root path is prepended to all (non-empty) entries
+     *
+     * @param string $globPattern
+     * @return array
+     * @throws \Exception if any of the patterns don't return any result
+     */
+    public static function readLists($globPattern)
+    {
+        $patterns = array();
+        foreach (glob($globPattern) as $list) {
+            $patterns = array_merge($patterns, file($list, FILE_IGNORE_NEW_LINES));
+        }
+
+        // Expand glob patterns
+        $result = array();
+        foreach ($patterns as $pattern) {
+            if (0 === strpos($pattern, '#')) {
+                continue;
+            }
+            /**
+             * Note that glob() for directories will be returned as is,
+             * but passing directory is supported by the tools (phpcpd, phpmd, phpcs)
+             */
+            $files = glob(self::init()->getPathToSource() . '/' . $pattern, GLOB_BRACE);
+            if (empty($files)) {
+                throw new \Exception("The glob() pattern '{$pattern}' didn't return any result.");
+            }
+            $result = array_merge($result, $files);
+        }
+        return $result;
+    }
 }
diff --git a/dev/tests/static/framework/bootstrap.php b/dev/tests/static/framework/bootstrap.php
index 336db8defe5e60219ef18ede6ee281b93c8f220e..17c46092271893331a1bc1634d0c2a75908f1365 100644
--- a/dev/tests/static/framework/bootstrap.php
+++ b/dev/tests/static/framework/bootstrap.php
@@ -32,7 +32,7 @@ require BP . '/app/autoload.php';
     dirname(__DIR__) . '/testsuite',
     BP . '/lib',
 ));
-\Magento\TestFramework\Utility\Files::init(new \Magento\TestFramework\Utility\Files(BP));
+\Magento\TestFramework\Utility\Files::setInstance(new \Magento\TestFramework\Utility\Files(BP));
 
 function tool_autoloader($className)
 {
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/FilesTest.php b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/FilesTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..a55af184b5cefb0b02e331e85fb95c3c3cc89cc2
--- /dev/null
+++ b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/FilesTest.php
@@ -0,0 +1,83 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\TestFramework\Utility;
+
+class FilesTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * @var string
+     */
+    private static $baseDir;
+
+    public static function setUpBeforeClass()
+    {
+        self::$baseDir = __DIR__ . '/_files/foo';
+        Files::setInstance(new Files(self::$baseDir));
+    }
+
+    public static function tearDownAfterClass()
+    {
+        Files::setInstance();
+    }
+
+    public function testReadLists()
+    {
+        $result = Files::init()->readLists(__DIR__ . '/_files/*good.txt');
+
+        // the braces
+        $this->assertContains(self::$baseDir . '/one.txt', $result);
+        $this->assertContains(self::$baseDir . '/two.txt', $result);
+
+        // directory is returned as-is, without expanding contents recursively
+        $this->assertContains(self::$baseDir . '/bar', $result);
+
+        // the * wildcard
+        $this->assertContains(self::$baseDir . '/baz/one.txt', $result);
+        $this->assertContains(self::$baseDir . '/baz/two.txt', $result);
+    }
+
+    public function testReadListsWrongPattern()
+    {
+        $this->assertSame(array(), Files::init()->readLists(__DIR__ . '/_files/no_good.txt'));
+    }
+
+    /**
+     * @expectedException \Exception
+     * @expectedExceptionMessage The glob() pattern 'bar/unknown' didn't return any result.
+     */
+    public function testReadListsCorruptedDir()
+    {
+        Files::init()->readLists(__DIR__ . '/_files/list_corrupted_dir.txt');
+    }
+
+    /**
+     * @expectedException \Exception
+     * @expectedExceptionMessage The glob() pattern 'unknown.txt' didn't return any result.
+     */
+    public function testReadListsCorruptedFile()
+    {
+        Files::init()->readLists(__DIR__ . '/_files/list_corrupted_file.txt');
+    }
+}
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/one.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/one.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/recursive/one.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/recursive/one.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/recursive/two.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/recursive/two.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/two.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/bar/two.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/baz/one.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/baz/one.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/baz/two.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/baz/two.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/one.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/one.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/two.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/foo/two.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_dir.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_dir.txt
new file mode 100644
index 0000000000000000000000000000000000000000..547500b58830b01accba1ca756bacf0ec6acecd9
--- /dev/null
+++ b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_dir.txt
@@ -0,0 +1,2 @@
+one.txt
+bar/unknown
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_file.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_file.txt
new file mode 100644
index 0000000000000000000000000000000000000000..290ae97cdbc16c8de15adb307cb18933a01644df
--- /dev/null
+++ b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_corrupted_file.txt
@@ -0,0 +1,3 @@
+one.txt
+two.txt
+unknown.txt
diff --git a/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_good.txt b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_good.txt
new file mode 100644
index 0000000000000000000000000000000000000000..f7681982e34d1b23cf9d7758176d22d3676c4d40
--- /dev/null
+++ b/dev/tests/static/framework/tests/unit/testsuite/Magento/TestFramework/Utility/_files/list_good.txt
@@ -0,0 +1,4 @@
+# comments are ignored
+{one,two}.txt
+bar
+baz/*.txt
diff --git a/dev/tests/static/testsuite/Magento/Test/Js/LiveCodeTest.php b/dev/tests/static/testsuite/Magento/Test/Js/LiveCodeTest.php
index af0e3a74d3d4397a3df75faac31417d54cafc550..030df32fe46f03499fe879e9bb8950fc54a53ec6 100644
--- a/dev/tests/static/testsuite/Magento/Test/Js/LiveCodeTest.php
+++ b/dev/tests/static/testsuite/Magento/Test/Js/LiveCodeTest.php
@@ -24,11 +24,17 @@
  * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
  */
 
+namespace Magento\Test\Js;
+
 /**
- * JSHint static code analysis tests for javascript files
+ * Duplicating the same namespace in the "use" below is a workaround to comply with
+ * \Magento\Test\Integrity\ClassesTest::testClassReferences()
  */
-namespace Magento\Test\Js;
+use Magento\TestFramework\Utility\Files, Magento\TestFramework\Utility\AggregateInvoker;
 
+/**
+ * JSHint static code analysis tests for javascript files
+ */
 class LiveCodeTest extends \PHPUnit_Framework_TestCase
 {
     /**
@@ -72,14 +78,14 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
      */
     public static function setUpBeforeClass()
     {
-        $reportDir = \Magento\TestFramework\Utility\Files::init()->getPathToSource() . '/dev/tests/static/report';
+        $reportDir = Files::init()->getPathToSource() . '/dev/tests/static/report';
         if (!is_dir($reportDir)) {
             mkdir($reportDir, 0777);
         }
         self::$_reportFile = $reportDir . '/js_report.txt';
         @unlink(self::$_reportFile);
-        $whiteList = self::_readLists(__DIR__ . '/_files/whitelist/*.txt');
-        $blackList = self::_readLists(__DIR__ . '/_files/blacklist/*.txt');
+        $whiteList = Files::readLists(__DIR__ . '/_files/whitelist/*.txt');
+        $blackList = Files::readLists(__DIR__ . '/_files/blacklist/*.txt');
         foreach ($blackList as $listFiles) {
             self::$_blackListJsFiles = array_merge(self::$_blackListJsFiles, self::_scanJsFile($listFiles));
         }
@@ -95,7 +101,7 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
 
     public function testCodeJsHint()
     {
-        $invoker = new \Magento\TestFramework\Utility\AggregateInvoker($this);
+        $invoker = new AggregateInvoker($this);
         $invoker(
             /**
              * @param string $filename
@@ -128,25 +134,4 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
         };
         return array_map($map, self::$_whiteListJsFiles);
     }
-
-    /**
-     * Read all text files by specified glob pattern and combine them into an array of valid files/directories
-     *
-     * The Magento root path is prepended to all (non-empty) entries
-     *
-     * @param string $globPattern
-     * @return array
-     */
-    protected static function _readLists($globPattern)
-    {
-        $result = array();
-        foreach (glob($globPattern) as $list) {
-            $result = array_merge($result, file($list));
-        }
-        $map = function ($value) {
-            return trim($value) ?
-                \Magento\TestFramework\Utility\Files::init()->getPathToSource() . '/' . trim($value) : '';
-        };
-        return array_filter(array_map($map, $result), 'file_exists');
-    }
 }
diff --git a/dev/tests/static/testsuite/Magento/Test/Js/_files/blacklist/core.txt b/dev/tests/static/testsuite/Magento/Test/Js/_files/blacklist/core.txt
index 9ac33494f34e4ec91b5d08ef639eb8df3e012ee6..0b919ec4ec732569496d5bcf66342b1a951b29de 100644
--- a/dev/tests/static/testsuite/Magento/Test/Js/_files/blacklist/core.txt
+++ b/dev/tests/static/testsuite/Magento/Test/Js/_files/blacklist/core.txt
@@ -1,20 +1,20 @@
-pub/lib/head.load.min.js
-pub/lib/mage/adminhtml
-pub/lib/mage/backend/editablemultiselect.js
-pub/lib/mage/captcha.js
-pub/lib/mage/directpost.js
-pub/lib/mage/jquery-no-conflict.js
-app/code/Magento/Theme/view/frontend/menu.js
-app/code/Magento/Checkout/view/frontend/multishipping/payment.js
-app/code/Magento/Checkout/view/frontend/onepage/accordion.js
-app/code/Magento/Checkout/view/frontend/opcheckout.js
+app/code/Magento/Backend/view/adminhtml/variables.js
 app/code/Magento/Captcha/view/frontend/onepage.js
 app/code/Magento/Catalog/view/adminhtml/catalog/category/edit.js
-app/code/Magento/Catalog/view/adminhtml/catalog/product/composite/configure.js
 app/code/Magento/Catalog/view/adminhtml/catalog/product.js
-app/code/Magento/Adminhtml/view/adminhtml/rules.js
+app/code/Magento/Catalog/view/adminhtml/catalog/product/composite/configure.js
+app/code/Magento/Checkout/view/frontend/js/accordion.js
+app/code/Magento/Checkout/view/frontend/js/opcheckout.js
+app/code/Magento/Checkout/view/frontend/js/payment.js
+app/code/Magento/Rule/view/adminhtml/rules.js
 app/code/Magento/Sales/view/adminhtml/order/create/giftmessage.js
 app/code/Magento/Sales/view/adminhtml/order/create/scripts.js
 app/code/Magento/Sales/view/adminhtml/order/giftoptions_tooltip.js
 app/code/Magento/Sales/view/adminhtml/order/shipment/packaging.js
-app/code/Magento/Adminhtml/view/adminhtml/variables.js
+app/code/Magento/Theme/view/frontend/menu.js
+pub/lib/mage/adminhtml
+pub/lib/mage/backend/editablemultiselect.js
+pub/lib/mage/captcha.js
+pub/lib/mage/directpost.js
+pub/lib/mage/flex.js
+pub/lib/mage/jquery-no-conflict.js
diff --git a/dev/tests/static/testsuite/Magento/Test/Js/_files/whitelist/core.txt b/dev/tests/static/testsuite/Magento/Test/Js/_files/whitelist/core.txt
index 54c56692c82c8416a15da9b65f59f79b1ffcd994..c7a5d925e00bf631001e419c07b3bd8600bd49ee 100644
--- a/dev/tests/static/testsuite/Magento/Test/Js/_files/whitelist/core.txt
+++ b/dev/tests/static/testsuite/Magento/Test/Js/_files/whitelist/core.txt
@@ -1,21 +1,20 @@
-pub/lib/mage
-app/code/Magento/Install
+app/code/Magento/Authorizenet
+app/code/Magento/Bundle
+app/code/Magento/Captcha
 app/code/Magento/Catalog
-app/code/Magento/Newsletter
-app/code/Magento/Theme
-app/code/Magento/PageCache
 app/code/Magento/CatalogSearch
 app/code/Magento/Checkout
-app/code/Magento/Captcha
 app/code/Magento/Customer
 app/code/Magento/Downloadable
-app/code/Magento/Persistent
-app/code/Magento/Wishlist
-app/code/Magento/Bundle
-app/code/Magento/Adminhtml
+app/code/Magento/GiftMessage
+app/code/Magento/Install
+app/code/Magento/Newsletter
+app/code/Magento/PageCache
+app/code/Magento/Paygate
 app/code/Magento/Payment
 app/code/Magento/Paypal
-app/code/Magento/GiftMessage
+app/code/Magento/Persistent
 app/code/Magento/Sales
-app/code/Magento/Authorizenet
-app/code/Magento/Paygate
+app/code/Magento/Theme
+app/code/Magento/Wishlist
+pub/lib/mage
diff --git a/dev/tests/static/testsuite/Magento/Test/Php/LiveCodeTest.php b/dev/tests/static/testsuite/Magento/Test/Php/LiveCodeTest.php
index 95c82d9f89c1aac2ab036b63d9abf63f8314ff2e..e72132c4f240e86cba057cc80b6f4995c96d4f5c 100644
--- a/dev/tests/static/testsuite/Magento/Test/Php/LiveCodeTest.php
+++ b/dev/tests/static/testsuite/Magento/Test/Php/LiveCodeTest.php
@@ -24,11 +24,12 @@
  * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
  */
 
+namespace Magento\Test\Php;
+use Magento\TestFramework\Utility;
+
 /**
  * Set of tests for static code analysis, e.g. code style, code complexity, copy paste detecting, etc.
  */
-namespace Magento\Test\Php;
-
 class LiveCodeTest extends \PHPUnit_Framework_TestCase
 {
     /**
@@ -48,7 +49,7 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
 
     public static function setUpBeforeClass()
     {
-        self::$_reportDir = \Magento\TestFramework\Utility\Files::init()->getPathToSource()
+        self::$_reportDir = Utility\Files::init()->getPathToSource()
             . '/dev/tests/static/report';
         if (!is_dir(self::$_reportDir)) {
             mkdir(self::$_reportDir, 0777);
@@ -61,8 +62,8 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
         if ($type != '' && !preg_match('/\/$/', $type)) {
             $type = $type . '/';
         }
-        self::$_whiteList = self::_readLists(__DIR__ . '/_files/' . $type . 'whitelist/*.txt');
-        self::$_blackList = self::_readLists(__DIR__ . '/_files/' . $type . 'blacklist/*.txt');
+        self::$_whiteList = Utility\Files::readLists(__DIR__ . '/_files/' . $type . 'whitelist/*.txt');
+        self::$_blackList = Utility\Files::readLists(__DIR__ . '/_files/' . $type . 'blacklist/*.txt');
     }
 
     /**
@@ -158,39 +159,4 @@ class LiveCodeTest extends \PHPUnit_Framework_TestCase
             "PHP Copy/Paste Detector has found error(s): See detailed report in $reportFile"
         );
     }
-
-    /**
-     * Read all text files by specified glob pattern and combine them into an array of valid files/directories
-     *
-     * The Magento root path is prepended to all (non-empty) entries
-     *
-     * @param string $globPattern
-     * @return array
-     * @throws \Exception if any of the patterns don't return any result
-     */
-    protected static function _readLists($globPattern)
-    {
-        $patterns = array();
-        foreach (glob($globPattern) as $list) {
-            $patterns = array_merge($patterns, file($list, FILE_IGNORE_NEW_LINES));
-        }
-
-        // Expand glob patterns
-        $result = array();
-        foreach ($patterns as $pattern) {
-            if (0 === strpos($pattern, '#')) {
-                continue;
-            }
-            /**
-             * Note that glob() for directories will be returned as is,
-             * but passing directory is supported by the tools (phpcpd, phpmd, phpcs)
-             */
-            $files = glob(\Magento\TestFramework\Utility\Files::init()->getPathToSource() . '/' . $pattern, GLOB_BRACE);
-            if (empty($files)) {
-                throw new \Exception("The glob() pattern '{$pattern}' didn't return any result.");
-            }
-            $result = array_merge($result, $files);
-        }
-        return $result;
-    }
 }
diff --git a/dev/tests/static/testsuite/Magento/Test/Php/_files/phpcpd/blacklist/common.txt b/dev/tests/static/testsuite/Magento/Test/Php/_files/phpcpd/blacklist/common.txt
index 630aa0f424b20bb2c9b36adeddf457b066d9e79f..c0726a3247d5fc48f27d086667365198300136d0 100644
--- a/dev/tests/static/testsuite/Magento/Test/Php/_files/phpcpd/blacklist/common.txt
+++ b/dev/tests/static/testsuite/Magento/Test/Php/_files/phpcpd/blacklist/common.txt
@@ -50,6 +50,7 @@ Magento/Cron/Model/Config/Backend/Product
 Magento/Customer/Block/Account/Dashboard
 Magento/Customer/Block/Adminhtml/Edit/Tab
 Magento/Customer/Model/Config/Backend/Show
+Magento/Customer/Model/Metadata
 Magento/DesignEditor/Block/Adminhtml/Editor/Tools/Code
 Magento/DesignEditor/Block/Adminhtml/Theme/Selector/Tab
 Magento/DesignEditor/Model/Url
diff --git a/dev/tests/unit/testsuite/Magento/Authorizenet/Model/Directpost/ObserverTest.php b/dev/tests/unit/testsuite/Magento/Authorizenet/Model/Directpost/ObserverTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..75c3ec36c007c0176b545eaf9ddf765f20cac404
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Authorizenet/Model/Directpost/ObserverTest.php
@@ -0,0 +1,110 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Authorizenet\Model\Directpost;
+
+class ObserverTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * @var Observer
+     */
+    protected $model;
+
+    /**
+     * @var \Magento\Core\Model\Registry|\PHPUnit_Framework_MockObject_MockObject
+     */
+    protected $coreRegistry;
+
+    /**
+     * @var \Magento\Core\Helper\Data|\PHPUnit_Framework_MockObject_MockObject
+     */
+    protected $coreData;
+
+    protected function setUp()
+    {
+        $helper = new \Magento\TestFramework\Helper\ObjectManager($this);
+        $store = $this->getMock('Magento\Core\Model\Store', [], [], '', false);
+        $this->coreRegistry = $this->getMock('Magento\Core\Model\Registry', []);
+        $storeManager = $this->getMockForAbstractClass('Magento\Core\Model\StoreManagerInterface');
+        $storeManager->expects($this->any())->method('getStore')->will($this->returnValue($store));
+        $payment = $this->getMock('Magento\Authorizenet\Model\Directpost', null, [], '', false);
+        $this->coreData = $this->getMock('Magento\Core\Helper\Data', [], [], '', false);
+        $this->model = $helper->getObject('Magento\Authorizenet\Model\Directpost\Observer', [
+            'coreRegistry' => $this->coreRegistry,
+            'storeManager' => $storeManager,
+            'payment' => $payment,
+            'coreData' => $this->coreData
+        ]);
+    }
+
+    public function testAddAdditionalFieldsToResponseFrontend()
+    {
+        $directpostRequest = $this->getMock('Magento\Authorizenet\Model\Directpost\Request', []);
+        $order = $this->getMock('Magento\Sales\Model\Order', [], [], '', false);
+
+        $methodInstance = $this->getMock('Magento\Authorizenet\Model\Directpost', [], [], '', false);
+        $methodInstance->expects($this->once())
+            ->method('generateRequestFromOrder')
+            ->with($this->identicalTo($order))
+            ->will($this->returnValue($directpostRequest));
+
+        $payment = $this->getMock('Magento\Sales\Model\Order\Payment', [
+            'getMethodInstance',
+            '__wakeup'
+        ], [], '', false);
+        $payment->expects($this->once())->method('getMethodInstance')->will($this->returnValue($methodInstance));
+        $payment->setMethod('authorizenet_directpost');
+
+        $order->expects($this->once())->method('getId')->will($this->returnValue(1));
+        $order->expects($this->atLeastOnce())->method('getPayment')->will($this->returnValue($payment));
+
+
+        $this->coreRegistry->expects($this->once())
+            ->method('registry')
+            ->with('directpost_order')
+            ->will($this->returnValue($order));
+
+        $request = new \Magento\Object();
+        $response = $this->getMock('Magento\App\Response\Http', [], [], '', false);
+        $controller = $this->getMock('Magento\Checkout\Controller\Action', [
+            'getRequest',
+            'getResponse'
+        ], [], '', false);
+        $controller->expects($this->once())->method('getRequest')->will($this->returnValue($request));
+        $controller->expects($this->once())->method('getResponse')->will($this->returnValue($response));
+        $observer = new \Magento\Event\Observer(['event' => new \Magento\Object(['controller_action' => $controller])]);
+
+        $this->coreData->expects($this->once())
+            ->method('jsonEncode')
+            ->with(self::logicalNot(self::isEmpty()))
+            ->will($this->returnValue('encoded response'));
+        $response->expects($this->once())
+            ->method('clearHeader')
+            ->with('Location');
+        $response->expects($this->once())
+            ->method('setBody')
+            ->with('encoded response');
+        $this->model->addAdditionalFieldsToResponseFrontend($observer);
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Backend/Block/Widget/Grid/Column/Renderer/CurrencyTest.php b/dev/tests/unit/testsuite/Magento/Backend/Block/Widget/Grid/Column/Renderer/CurrencyTest.php
index f200d7e4f51bf1b0c65edddac499c1628b1537ea..1a5d32cdc07a9b86d9335812cb49261be4bf6a1c 100644
--- a/dev/tests/unit/testsuite/Magento/Backend/Block/Widget/Grid/Column/Renderer/CurrencyTest.php
+++ b/dev/tests/unit/testsuite/Magento/Backend/Block/Widget/Grid/Column/Renderer/CurrencyTest.php
@@ -59,6 +59,11 @@ class CurrencyTest extends \PHPUnit_Framework_TestCase
      */
     protected $_requestMock;
 
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject
+     */
+    protected $_currencyMock;
+
     /**
      * @var \Magento\Object
      */
@@ -80,6 +85,21 @@ class CurrencyTest extends \PHPUnit_Framework_TestCase
             ->method('getIndex')
             ->will($this->returnValue('columnIndex'));
 
+        $this->_currencyMock = $this->getMock('Magento\Directory\Model\Currency', array(), array(), '', false);
+        $this->_currencyMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $currencyFactoryMock = $this->getMock(
+            'Magento\Directory\Model\CurrencyFactory',
+            array('create'),
+            array(),
+            '',
+            false
+        );
+        $currencyFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_currencyMock));
+
         $this->_row = new \Magento\Object(array('columnIndex' => '10'));
 
         $helper = new \Magento\TestFramework\Helper\ObjectManager($this);
@@ -87,7 +107,8 @@ class CurrencyTest extends \PHPUnit_Framework_TestCase
             'storeManager' => $this->_storeManagerMock,
             'locale' => $this->_localeMock,
             'currencyLocator' => $this->_curLocatorMock,
-            'request' => $this->_requestMock
+            'request' => $this->_requestMock,
+            'currencyFactory' => $currencyFactoryMock
             )
         );
 
@@ -111,17 +132,9 @@ class CurrencyTest extends \PHPUnit_Framework_TestCase
      */
     public function testRenderWithDefaultCurrency()
     {
-        $currencyMock = $this->getMock('Magento\Directory\Model\Currency', array(), array(), '', false);
-        $currencyMock->expects($this->once())->method('getRate')->with('defaultCurrency')
+        $this->_currencyMock->expects($this->once())->method('getRate')->with('defaultCurrency')
             ->will($this->returnValue(1.5));
 
-        $storeMock = $this->getMock('Magento\Core\Model\Store', array(), array(), '', false);
-        $storeMock->expects($this->once())->method('getBaseCurrency')->will($this->returnValue($currencyMock));
-
-        $this->_storeManagerMock->expects($this->once())
-            ->method('getStore')
-            ->will($this->returnValue($storeMock));
-
         $this->_curLocatorMock->expects($this->any())
             ->method('getDefaultCurrency')
             ->with($this->_requestMock)
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Model/ConverterTest.php b/dev/tests/unit/testsuite/Magento/Customer/Model/ConverterTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..542059b9ce3f31ca851d6b3431ff36098e9aeeb6
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Model/ConverterTest.php
@@ -0,0 +1,154 @@
+<?php
+/**
+ * Unit test for converter \Magento\Customer\Model\Converter
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Model;
+
+class ConverterTest extends \PHPUnit_Framework_TestCase
+{
+    public function testCreateCustomerFromModel()
+    {
+        $customerModelMock =
+            $this->getMockBuilder('Magento\Customer\Model\Customer')
+                ->disableOriginalConstructor()
+                ->setMethods(
+                    array(
+                        'getId',
+                        'getFirstname',
+                        'getLastname',
+                        'getEmail',
+                        'getAttributes',
+                        'getData',
+                        '__wakeup',
+                    )
+                )
+                ->getMock();
+
+        $attributeModelMock =
+            $this->getMockBuilder('\Magento\Customer\Model\Attribute')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $attributeModelMock
+            ->expects($this->at(0))
+            ->method('getAttributeCode')
+            ->will($this->returnValue('attribute_code'));
+
+        $attributeModelMock
+            ->expects($this->at(1))
+            ->method('getAttributeCode')
+            ->will($this->returnValue('attribute_code2'));
+
+        $attributeModelMock
+            ->expects($this->at(2))
+            ->method('getAttributeCode')
+            ->will($this->returnValue('attribute_code3'));
+
+        $this->_mockReturnValue(
+            $customerModelMock,
+            array(
+                'getId' => 1,
+                'getFirstname' => 'Tess',
+                'getLastname' => 'Tester',
+                'getEmail' => 'ttester@example.com',
+                'getAttributes' => [$attributeModelMock, $attributeModelMock, $attributeModelMock],
+            )
+        );
+
+        $map = [
+            ['attribute_code', null, 'attributeValue'],
+            ['attribute_code2', null, 'attributeValue2'],
+            ['attribute_code3', null, null],
+        ];
+        $customerModelMock
+            ->expects($this->any())
+            ->method('getData')
+            ->will($this->returnValueMap($map));
+
+        $customerBuilder = new \Magento\Customer\Service\V1\Dto\CustomerBuilder();
+        $customerFactory = $this->getMockBuilder('Magento\Customer\Model\CustomerFactory')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $converter = new Converter($customerBuilder, $customerFactory);
+        $customerDto = $converter->createCustomerFromModel($customerModelMock);
+
+        $customerBuilder = new \Magento\Customer\Service\V1\Dto\CustomerBuilder();
+        $customerData = [
+            'firstname' => 'Tess',
+            'email' => 'ttester@example.com',
+            'lastname' => 'Tester',
+            'id' => 1,
+            'attribute_code' => 'attributeValue',
+            'attribute_code2' => 'attributeValue2'
+        ];
+        // There will be no attribute_code3: it has a value of null, so the converter will drop it
+        $customerBuilder->populateWithArray($customerData);
+        $expectedCustomerDto = $customerBuilder->create();
+
+        $this->assertEquals($expectedCustomerDto, $customerDto);
+    }
+
+    /**
+     * @dataProvider createCustomerFromModelBadParamDataProvider
+     * @expectedException \InvalidArgumentException
+     * @expectedExceptionMessage customer model is invalid
+     */
+    public function testCreateCustomerFromModelBadParam($param)
+    {
+        $customerBuilder = $this->getMockBuilder('Magento\Customer\Service\V1\Dto\CustomerBuilder')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $customerFactory = $this->getMockBuilder('Magento\Customer\Model\CustomerFactory')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $converter = new Converter($customerBuilder, $customerFactory);
+        $converter->createCustomerFromModel($param);
+    }
+
+    public function createCustomerFromModelBadParamDataProvider()
+    {
+        return [
+            [null],
+            ['a string'],
+            [5],
+            [new \Magento\Object()],
+        ];
+    }
+
+    /**
+     * @param \PHPUnit_Framework_MockObject_MockObject $mock
+     * @param array $valueMap
+     */
+    private function _mockReturnValue($mock, $valueMap)
+    {
+        foreach ($valueMap as $method => $value) {
+            $mock->expects($this->any())
+                ->method($method)
+                ->will($this->returnValue($value));
+        }
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/CustomerTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/CustomerTest.php
index 6410d0b3e205e7ca752bab2ff981373330088849..065658c71339e57b0147327c95ec52d870549e80 100644
--- a/dev/tests/unit/testsuite/Magento/Customer/Service/CustomerTest.php
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/CustomerTest.php
@@ -79,6 +79,7 @@ class CustomerTest extends \PHPUnit_Framework_TestCase
             )
             ->disableOriginalConstructor()
             ->getMock();
+
         $this->_customerFactory->expects($this->any())
             ->method('create')
             ->will($this->returnValue($this->_customer));
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..87f0cd6fefca1af04b779d768a2d1154591e59d6
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAccountServiceTest.php
@@ -0,0 +1,1030 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+/**
+ * \Magento\Customer\Service\V1\CustomerAccountService
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ * @SuppressWarnings(PHPMD.ExcessiveMethodLength)
+ * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
+ */
+class CustomerAccountServiceTest extends \PHPUnit_Framework_TestCase
+{
+
+    const STREET = 'Parmer';
+    const CITY = 'Albuquerque';
+    const POSTCODE = '90014';
+    const TELEPHONE = '7143556767';
+    const REGION = 'Alabama';
+    const REGION_ID = 1;
+    const COUNTRY_ID = 'US';
+
+    /** Sample values for testing */
+    const ID = 1;
+    const FIRSTNAME = 'Jane';
+    const LASTNAME = 'Doe';
+    const NAME = 'J';
+    const EMAIL = 'janedoe@example.com';
+    const EMAIL_CONFIRMATION_KEY = 'blj487lkjs4confirmation_key';
+    const PASSWORD = 'password';
+    const ATTRIBUTE_CODE = 'random_attr_code';
+    const ATTRIBUTE_VALUE = 'random_attr_value';
+    const WEBSITE_ID = 1;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\CustomerFactory
+     */
+    private $_customerFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\AddressFactory
+     */
+    private $_addressFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Customer
+     */
+    private $_customerModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Attribute
+     */
+    private $_attributeModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\CustomerMetadataServiceInterface
+     */
+    private $_eavMetadataServiceMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Event\ManagerInterface
+     */
+    private $_eventManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\StoreManagerInterface
+     */
+    private $_storeManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Math\Random
+     */
+    private $_mathRandomMock;
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\Store
+     */
+    private $_storeMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private $_addressBuilder;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\CustomerBuilder
+     */
+    private $_customerBuilder;
+
+    private $_validator;
+
+    private $_customerServiceMock;
+
+    private $_customerAddressServiceMock;
+
+    public function setUp()
+    {
+        $this->_customerFactoryMock = $this->getMockBuilder('Magento\Customer\Model\CustomerFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_customerModelMock = $this->getMockBuilder('Magento\Customer\Model\Customer')
+            ->disableOriginalConstructor()
+            ->setMethods(
+                array(
+                    'getId',
+                    'getFirstname',
+                    'getLastname',
+                    'getName',
+                    'getEmail',
+                    'getAttributes',
+                    'getConfirmation',
+                    'setConfirmation',
+                    'save',
+                    'load',
+                    '__wakeup',
+                    'authenticate',
+                    'getData',
+                    'getDefaultBilling',
+                    'getDefaultShipping',
+                    'getDefaultShippingAddress',
+                    'getDefaultBillingAddress',
+                    'getStoreId',
+                    'getAddressById',
+                    'getAddresses',
+                    'getAddressItemById',
+                    'getParentId',
+                    'isConfirmationRequired',
+                    'addAddress',
+                    'loadByEmail',
+                    'sendNewAccountEmail',
+                    'setFirstname',
+                    'setLastname',
+                    'setEmail',
+                    'setPassword',
+                    'setData',
+                    'setWebsiteId',
+                    'getAttributeSetId',
+                    'setAttributeSetId',
+                    'validate',
+                    'getRpToken',
+                    'setRpToken',
+                    'setRpTokenCreatedAt',
+                    'isResetPasswordLinkTokenExpired',
+                    'changeResetPasswordLinkToken',
+                    'sendPasswordResetConfirmationEmail',
+                )
+            )
+            ->getMock();
+
+        $this->_addressFactoryMock = $this->getMockBuilder('Magento\Customer\Model\AddressFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_eavMetadataServiceMock =
+            $this->getMockBuilder('Magento\Customer\Service\Eav\AttributeMetadataServiceV1Interface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_eventManagerMock =
+            $this->getMockBuilder('\Magento\Event\ManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_attributeModelMock =
+            $this->getMockBuilder('\Magento\Customer\Model\Attribute')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_attributeModelMock
+            ->expects($this->any())
+            ->method('getAttributeCode')
+            ->will($this->returnValue(self::ATTRIBUTE_CODE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('getData')
+            ->with($this->equalTo(self::ATTRIBUTE_CODE))
+            ->will($this->returnValue(self::ATTRIBUTE_VALUE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('validate')
+            ->will($this->returnValue(TRUE));
+
+        $this->_setupStoreMock();
+
+        $this->_mathRandomMock = $this->getMockBuilder('\Magento\Math\Random')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_validator = $this->getMockBuilder('\Magento\Customer\Model\Metadata\Validator')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_addressBuilder = new Dto\AddressBuilder(
+            new Dto\RegionBuilder());
+
+        $this->_customerBuilder = new Dto\CustomerBuilder();
+
+        $customerBuilder = new Dto\CustomerBuilder();
+
+        $this->_converter = new \Magento\Customer\Model\Converter($customerBuilder, $this->_customerFactoryMock);
+
+        $this->_customerServiceMock = $this->getMockBuilder('\Magento\Customer\Service\V1\CustomerService')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_customerAddressServiceMock =
+            $this->getMockBuilder('\Magento\Customer\Service\V1\CustomerAddressService')
+            ->disableOriginalConstructor()
+            ->getMock();
+    }
+
+
+    public function testActivateAccount()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'getConfirmation' => self::EMAIL_CONFIRMATION_KEY,
+                'getAttributes' => array(),
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions
+        $this->_customerModelMock->expects($this->once())
+            ->method('save');
+        $this->_customerModelMock->expects($this->once())
+            ->method('setConfirmation')
+            ->with($this->isNull());
+
+        $customerService = $this->_createService();
+
+        $customer = $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+
+        $this->assertEquals(self::ID, $customer->getCustomerId());
+    }
+
+    /**
+     * @expectedException  \Magento\Customer\Service\Entity\V1\Exception
+     */
+    public function testActivateAccountAlreadyActive()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'getConfirmation' => null,
+                'getAttributes' => array()
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions
+        $this->_customerModelMock->expects($this->never())
+            ->method('save');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setConfirmation');
+
+        $customerService = $this->_createService();
+
+        $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage No customer with customerId 1 exists.
+     */
+    public function testActivateAccountDoesntExist()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions
+        $this->_customerModelMock->expects($this->never())
+            ->method('save');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setConfirmation');
+
+        $customerService = $this->_createService();
+
+        $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage DB was down
+     */
+    public function testActivateAccountLoadError()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->throwException(new \Exception('DB was down')));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions
+        $this->_customerModelMock->expects($this->never())
+            ->method('save');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setConfirmation');
+
+        $customerService = $this->_createService();
+
+        $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+    }
+
+    /**
+     * @expectedException \Magento\Core\Exception
+     * @expectedExceptionMessage Wrong confirmation key
+     */
+    public function testActivateAccountBadKey()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'getConfirmation' => self::EMAIL_CONFIRMATION_KEY . 'BAD',
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions
+        $this->_customerModelMock->expects($this->never())
+            ->method('save');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setConfirmation');
+
+        $customerService = $this->_createService();
+
+        $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+    }
+
+    /**
+     * @expectedException \Magento\Core\Exception
+     * @expectedExceptionMessage Failed to confirm customer account
+     */
+    public function testActivateAccountSaveFailed()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'getConfirmation' => self::EMAIL_CONFIRMATION_KEY,
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        // Assertions/Mocking
+        $this->_customerModelMock->expects($this->once())
+            ->method('save')
+            ->will($this->throwException(new \Exception('DB is down')));
+        $this->_customerModelMock->expects($this->once())
+            ->method('setConfirmation');
+
+        $customerService = $this->_createService();
+
+        $customerService->activateAccount(self::ID, self::EMAIL_CONFIRMATION_KEY);
+    }
+
+    public function testLoginAccount()
+    {
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'authenticate' => true,
+                'load' => $this->_customerModelMock,
+                'getAttributes' => array()
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customer = $customerService->authenticate(self::EMAIL, self::PASSWORD, self::WEBSITE_ID);
+
+        $this->assertEquals(self::ID, $customer->getCustomerId());
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage exception message
+     */
+    public function testLoginAccountWithException()
+    {
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+            )
+        );
+
+        $this->_customerModelMock->expects($this->any())
+            ->method('authenticate')
+            ->will($this->throwException(new \Magento\Core\Exception('exception message') ));
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->authenticate(self::EMAIL, self::PASSWORD, self::WEBSITE_ID);
+    }
+
+    public function testValidateResetPasswordLinkToken()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->validateResetPasswordLinkToken(self::ID, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testValidateResetPasswordLinkTokenExpired()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => true,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->validateResetPasswordLinkToken(self::ID, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testValidateResetPasswordLinkTokenInvalid()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $invalidToken = $resetToken . 'extra_stuff';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->validateResetPasswordLinkToken(self::ID, $invalidToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_CUSTOMER_ID
+     * @expectedExceptionMessage No customer with customerId 1 exists
+     */
+    public function testValidateResetPasswordLinkTokenWrongUser()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->validateResetPasswordLinkToken(1, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_RESET_TOKEN
+     * @expectedExceptionMessage Invalid password reset token
+     */
+    public function testValidateResetPasswordLinkTokenNull()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerService->validateResetPasswordLinkToken(null, null);
+    }
+
+    public function testSendPasswordResetLink()
+    {
+        $email = 'foo@example.com';
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'setWebsiteId' => $this->_customerModelMock,
+                'loadByEmail' => $this->_customerModelMock,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->once())
+            ->method('sendPasswordResetConfirmationEmail');
+
+        $customerService = $this->_createService();
+
+        $customerService->sendPasswordResetLink($email, self::WEBSITE_ID);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_EMAIL_NOT_FOUND
+     * @expectedExceptionMessage No customer found for the provided email and website ID
+     */
+    public function testSendPasswordResetLinkBadEmailOrWebsite()
+    {
+        $email = 'foo@example.com';
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+                'setWebsiteId' => $this->_customerModelMock,
+                'loadByEmail' => $this->_customerModelMock,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->never())
+            ->method('sendPasswordResetConfirmationEmail');
+
+        $customerService = $this->_createService();
+
+        $customerService->sendPasswordResetLink($email, 0);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_UNKNOWN
+     * @expectedExceptionMessage Invalid transactional email code: 0
+     */
+    public function testSendPasswordResetLinkSendException()
+    {
+        $email = 'foo@example.com';
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'setWebsiteId' => $this->_customerModelMock,
+                'loadByEmail' => $this->_customerModelMock,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->once())
+            ->method('sendPasswordResetConfirmationEmail')
+            ->will($this->throwException(new \Magento\Core\Exception(__('Invalid transactional email code: %1', 0))));
+
+        $customerService = $this->_createService();
+
+        $customerService->sendPasswordResetLink($email, self::WEBSITE_ID);
+    }
+
+    public function testResetPassword()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->once())
+            ->method('setRpToken')
+            ->with(null)
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->once())
+            ->method('setRpTokenCreatedAt')
+            ->with(null)
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->once())
+            ->method('setPassword')
+            ->with($password)
+            ->will($this->returnSelf());
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(self::ID, $password, $resetToken);
+    }
+
+    public function testResetPasswordShortPassword()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = '';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->once())
+            ->method('setRpToken')
+            ->with(null)
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->once())
+            ->method('setRpTokenCreatedAt')
+            ->with(null)
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->once())
+            ->method('setPassword')
+            ->with($password)
+            ->will($this->returnSelf());
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(self::ID, $password, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testResetPasswordTokenExpired()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => true,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpToken');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpTokenCreatedAt');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setPassword');
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(self::ID, $password, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_RESET_TOKEN_EXPIRED
+     * @expectedExceptionMessage Your password reset link has expired.
+     */
+    public function testResetPasswordTokenInvalid()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $invalidToken = $resetToken . 'invalid';
+        $password = 'password_secret';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpToken');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpTokenCreatedAt');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setPassword');
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(self::ID, $password, $invalidToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_CUSTOMER_ID
+     * @expectedExceptionMessage No customer with customerId 4200 exists
+     */
+    public function testResetPasswordTokenWrongUser()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpToken');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpTokenCreatedAt');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setPassword');
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(4200, $password, $resetToken);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_RESET_TOKEN
+     * @expectedExceptionMessage Invalid password reset token
+     */
+    public function testResetPasswordTokenInvalidUserId()
+    {
+        $resetToken = 'lsdj579slkj5987slkj595lkj';
+        $password = 'password_secret';
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => 0,
+                'load' => $this->_customerModelMock,
+                'getRpToken' => $resetToken,
+                'isResetPasswordLinkTokenExpired' => false,
+            )
+        );
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpToken');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setRpTokenCreatedAt');
+        $this->_customerModelMock->expects($this->never())
+            ->method('setPassword');
+
+        $customerService = $this->_createService();
+
+        $customerService->resetPassword(0, $password, $resetToken);
+    }
+
+
+    public function testSendConfirmation()
+    {
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(55));
+        $this->_customerModelMock->expects($this->once())
+            ->method('setWebsiteId')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('isConfirmationRequired')
+            ->will($this->returnValue(true));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getConfirmation')
+            ->will($this->returnValue('123abc'));
+
+        $customerService = $this->_createService();
+        $customerService->sendConfirmation('email');
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_EMAIL_NOT_FOUND
+     */
+    public function testSendConfirmationNoEmail()
+    {
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->once())
+            ->method('getId')
+            ->will($this->returnValue(0));
+        $this->_customerModelMock->expects($this->once())
+            ->method('setWebsiteId')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+        $customerService->sendConfirmation('email');
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_CONFIRMATION_NOT_NEEDED
+     */
+    public function testSendConfirmationNotNeeded()
+    {
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->once())
+            ->method('getId')
+            ->will($this->returnValue(55));
+        $this->_customerModelMock->expects($this->once())
+            ->method('setWebsiteId')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+        $customerService->sendConfirmation('email');
+    }
+
+
+    private function _setupStoreMock()
+    {
+        $this->_storeManagerMock =
+            $this->getMockBuilder('\Magento\Core\Model\StoreManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_storeMock = $this->getMockBuilder('\Magento\Core\Model\Store')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_storeManagerMock
+            ->expects($this->any())
+            ->method('getStore')
+            ->will($this->returnValue($this->_storeMock));
+    }
+
+
+    /**
+     * @param \PHPUnit_Framework_MockObject_MockObject $mock
+     * @param array $valueMap
+     */
+    private function _mockReturnValue($mock, $valueMap)
+    {
+        foreach ($valueMap as $method => $value) {
+            $mock->expects($this->any())
+                ->method($method)
+                ->will($this->returnValue($value));
+        }
+    }
+
+    /**
+     * @return CustomerAccountService
+     */
+    private function _createService()
+    {
+        $customerService = new CustomerAccountService(
+            $this->_customerFactoryMock,
+            $this->_eventManagerMock,
+            $this->_storeManagerMock,
+            $this->_mathRandomMock,
+            $this->_converter,
+            $this->_validator,
+            new Dto\Response\CreateCustomerAccountResponseBuilder(),
+            $this->_customerServiceMock,
+            $this->_customerAddressServiceMock
+        );
+        return $customerService;
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..4f49ff8ff4a63a36a3955e9004117324ad66e296
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerAddressServiceTest.php
@@ -0,0 +1,880 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+/**
+ * \Magento\Customer\Service\V1\CustomerAddressService
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ * @SuppressWarnings(PHPMD.ExcessiveMethodLength)
+ * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
+ */
+class CustomerAddressServiceTest extends \PHPUnit_Framework_TestCase
+{
+
+    const STREET = 'Parmer';
+    const CITY = 'Albuquerque';
+    const POSTCODE = '90014';
+    const TELEPHONE = '7143556767';
+    const REGION = 'Alabama';
+    const REGION_ID = 1;
+    const COUNTRY_ID = 'US';
+
+    /** Sample values for testing */
+    const ID = 1;
+    const FIRSTNAME = 'Jane';
+    const LASTNAME = 'Doe';
+    const NAME = 'J';
+    const EMAIL = 'janedoe@example.com';
+    const EMAIL_CONFIRMATION_KEY = 'blj487lkjs4confirmation_key';
+    const PASSWORD = 'password';
+    const ATTRIBUTE_CODE = 'random_attr_code';
+    const ATTRIBUTE_VALUE = 'random_attr_value';
+    const WEBSITE_ID = 1;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\CustomerFactory
+     */
+    private $_customerFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\AddressFactory
+     */
+    private $_addressFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Customer
+     */
+    private $_customerModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Attribute
+     */
+    private $_attributeModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\CustomerMetadataServiceInterface
+     */
+    private $_eavMetadataServiceMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Event\ManagerInterface
+     */
+    private $_eventManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\StoreManagerInterface
+     */
+    private $_storeManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Math\Random
+     */
+    private $_mathRandomMock;
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\Store
+     */
+    private $_storeMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private $_addressBuilder;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\CustomerBuilder
+     */
+    private $_customerBuilder;
+
+    private $_validator;
+
+    public function setUp()
+    {
+        $this->_customerFactoryMock = $this->getMockBuilder('Magento\Customer\Model\CustomerFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_customerModelMock = $this->getMockBuilder('Magento\Customer\Model\Customer')
+            ->disableOriginalConstructor()
+            ->setMethods(
+                array(
+                    'getId',
+                    'getFirstname',
+                    'getLastname',
+                    'getName',
+                    'getEmail',
+                    'getAttributes',
+                    'getConfirmation',
+                    'setConfirmation',
+                    'save',
+                    'load',
+                    '__wakeup',
+                    'authenticate',
+                    'getData',
+                    'getDefaultBilling',
+                    'getDefaultShipping',
+                    'getDefaultShippingAddress',
+                    'getDefaultBillingAddress',
+                    'getStoreId',
+                    'getAddressById',
+                    'getAddresses',
+                    'getAddressItemById',
+                    'getParentId',
+                    'isConfirmationRequired',
+                    'addAddress',
+                    'loadByEmail',
+                    'sendNewAccountEmail',
+                    'setFirstname',
+                    'setLastname',
+                    'setEmail',
+                    'setPassword',
+                    'setData',
+                    'setWebsiteId',
+                    'getAttributeSetId',
+                    'setAttributeSetId',
+                    'validate',
+                    'getRpToken',
+                    'setRpToken',
+                    'setRpTokenCreatedAt',
+                    'isResetPasswordLinkTokenExpired',
+                    'changeResetPasswordLinkToken',
+                    'sendPasswordResetConfirmationEmail',
+                )
+            )
+            ->getMock();
+
+        $this->_addressFactoryMock = $this->getMockBuilder('Magento\Customer\Model\AddressFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_eavMetadataServiceMock =
+            $this->getMockBuilder('Magento\Customer\Service\Eav\AttributeMetadataServiceV1Interface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_eventManagerMock =
+            $this->getMockBuilder('\Magento\Event\ManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_attributeModelMock =
+            $this->getMockBuilder('\Magento\Customer\Model\Attribute')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_attributeModelMock
+            ->expects($this->any())
+            ->method('getAttributeCode')
+            ->will($this->returnValue(self::ATTRIBUTE_CODE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('getData')
+            ->with($this->equalTo(self::ATTRIBUTE_CODE))
+            ->will($this->returnValue(self::ATTRIBUTE_VALUE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('validate')
+            ->will($this->returnValue(TRUE));
+
+        $this->_setupStoreMock();
+
+        $this->_mathRandomMock = $this->getMockBuilder('\Magento\Math\Random')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_validator = $this->getMockBuilder('\Magento\Customer\Model\Metadata\Validator')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_addressBuilder = new Dto\AddressBuilder(
+            new Dto\RegionBuilder());
+
+        $this->_customerBuilder = new Dto\CustomerBuilder();
+
+        $customerBuilder = new Dto\CustomerBuilder();
+
+        $this->_converter = new \Magento\Customer\Model\Converter($customerBuilder, $this->_customerFactoryMock);
+    }
+
+    public function testGetAddressesDefaultBilling()
+    {
+        $addressMock = $this->_createAddress(1, 'John');
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultBillingAddress')
+            ->will($this->returnValue($addressMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultBilling')
+            ->will($this->returnValue(1));
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerId = 1;
+        $address = $customerService->getDefaultBillingAddress($customerId);
+
+        $expected = [
+            'id' => 1,
+            'default_billing' => true,
+            'default_shipping' => false,
+            'customer_id' => self::ID,
+            'region' => new Dto\Region([
+                    'region_id' => self::REGION_ID,
+                    'region_code' => '',
+                    'region' => self::REGION
+                ]),
+            'country_id' => self::COUNTRY_ID,
+            'street' => [self::STREET],
+            'telephone' => self::TELEPHONE,
+            'postcode' => self::POSTCODE,
+            'city' => self::CITY,
+            'firstname' => 'John',
+            'lastname' => 'Doe',
+        ];
+
+        $this->assertEquals($expected, $address->__toArray());
+    }
+
+    public function testGetAddressesDefaultShipping()
+    {
+        $addressMock = $this->_createAddress(1, 'John');
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultShippingAddress')
+            ->will($this->returnValue($addressMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultShipping')
+            ->will($this->returnValue(1));
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerId = 1;
+        $address = $customerService->getDefaultShippingAddress($customerId);
+
+        $expected = [
+            'id' => 1,
+            'default_shipping' => true,
+            'default_billing' => false,
+            'customer_id' => self::ID,
+            'region' => new Dto\Region([
+                    'region_id' => self::REGION_ID,
+                    'region_code' => '',
+                    'region' => self::REGION
+                ]),
+            'country_id' => self::COUNTRY_ID,
+            'street' => [self::STREET],
+            'telephone' => self::TELEPHONE,
+            'postcode' => self::POSTCODE,
+            'city' => self::CITY,
+            'firstname' => 'John',
+            'lastname' => 'Doe',
+        ];
+
+        $this->assertEquals($expected, $address->__toArray());
+    }
+
+    public function testGetAddressesById()
+    {
+        $addressMock = $this->_createAddress(1, 'John');
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddressById')
+            ->will($this->returnValue($addressMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultShipping')
+            ->will($this->returnValue(1));
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $customerId = 1;
+        $addressId = 1;
+        $address = $customerService->getAddressById($customerId, $addressId);
+
+        $expected = [
+            'id' => 1,
+            'default_shipping' => true,
+            'default_billing' => false,
+            'customer_id' => self::ID,
+            'region' => new Dto\Region([
+                    'region_id' => self::REGION_ID,
+                    'region_code' => '',
+                    'region' => self::REGION
+                ]),
+            'country_id' => self::COUNTRY_ID,
+            'street' => [self::STREET],
+            'telephone' => self::TELEPHONE,
+            'postcode' => self::POSTCODE,
+            'city' => self::CITY,
+            'firstname' => 'John',
+            'lastname' => 'Doe',
+        ];
+
+        $this->assertEquals($expected, $address->__toArray());
+    }
+
+    public function testGetAddresses()
+    {
+        $addressMock = $this->_createAddress(1, 'John');
+        $addressMock2 = $this->_createAddress(2, 'Genry');
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddresses')
+            ->will($this->returnValue([$addressMock, $addressMock2]));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultShipping')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getDefaultBilling')
+            ->will($this->returnValue(2));
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $addresses = $customerService->getAddresses(1);
+
+        $expected = [
+            [
+                'id' => 1,
+                'default_shipping' => true,
+                'default_billing' => false,
+                'customer_id' => self::ID,
+                'region' => new Dto\Region([
+                        'region_id' => self::REGION_ID,
+                        'region_code' => '',
+                        'region' => self::REGION
+                    ]),
+                'country_id' => self::COUNTRY_ID,
+                'street' => [self::STREET],
+                'telephone' => self::TELEPHONE,
+                'postcode' => self::POSTCODE,
+                'city' => self::CITY,
+                'firstname' => 'John',
+                'lastname' => 'Doe',
+            ], [
+                'id' => 2,
+                'default_billing' => true,
+                'default_shipping' => false,
+                'customer_id' => self::ID,
+                'region' => new Dto\Region([
+                        'region_id' => self::REGION_ID,
+                        'region_code' => '',
+                        'region' => self::REGION
+                    ]),
+                'country_id' => self::COUNTRY_ID,
+                'street' => [self::STREET],
+                'telephone' => self::TELEPHONE,
+                'postcode' => self::POSTCODE,
+                'city' => self::CITY,
+                'firstname' => 'Genry',
+                'lastname' => 'Doe',
+            ]
+        ];
+
+        $this->assertEquals($expected[0], $addresses[0]->__toArray());
+        $this->assertEquals($expected[1], $addresses[1]->__toArray());
+    }
+
+    public function testSaveAddresses()
+    {
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddresses')
+            ->will($this->returnValue([]));
+
+        // Setup address mock
+        $mockAddress = $this->_createAddress(1, 'John');
+        $mockAddress->expects($this->once())
+            ->method('save');
+        $mockAddress->expects($this->any())
+            ->method('setData');
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+        $customerService = $this->_createService();
+
+        $this->_addressBuilder->setFirstname('John')
+            ->setLastname(self::LASTNAME)
+            ->setRegion(new Dto\Region([
+                'region_id' => self::REGION_ID,
+                'region_code' => '',
+                'region' => self::REGION
+            ]))
+            ->setStreet([self::STREET])
+            ->setTelephone(self::TELEPHONE)
+            ->setCity(self::CITY)
+            ->setCountryId(self::COUNTRY_ID)
+            ->setPostcode(self::POSTCODE);
+        $ids = $customerService->saveAddresses(1, [$this->_addressBuilder->create()]);
+        $this->assertEquals([1], $ids);
+    }
+
+    public function testSaveAddressesChanges()
+    {
+        // Setup address mock
+        $mockAddress = $this->_createAddress(1, 'John');
+
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddressItemById')
+            ->with(1)
+            ->will($this->returnValue($mockAddress));
+
+        // Assert
+        $mockAddress->expects($this->once())
+            ->method('save');
+        $mockAddress->expects($this->any())
+            ->method('setData');
+
+        $customerService = $this->_createService();
+        $this->_addressBuilder->setId(1)
+            ->setFirstname('Jane')
+            ->setLastname(self::LASTNAME)
+            ->setRegion(new Dto\Region([
+                'region_id' => self::REGION_ID,
+                'region_code' => '',
+                'region' => self::REGION
+            ]))
+            ->setStreet([self::STREET])
+            ->setTelephone(self::TELEPHONE)
+            ->setCity(self::CITY)
+            ->setCountryId(self::COUNTRY_ID)
+            ->setPostcode(self::POSTCODE);
+        $ids = $customerService->saveAddresses(1, [$this->_addressBuilder->create()]);
+        $this->assertEquals([1], $ids);
+    }
+
+    public function testSaveAddressesNoAddresses()
+    {
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $customerService = $this->_createService();
+
+        $ids = $customerService->saveAddresses(1, []);
+        $this->assertEmpty($ids);
+    }
+
+    public function testSaveAddressesIdSetButNotAlreadyExisting()
+    {
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddresses')
+            ->will($this->returnValue([]));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddressItemById')
+            ->with(1)
+            ->will($this->returnValue(null));
+
+        // Setup address mock
+        $mockAddress = $this->_createAddress(1, 'John');
+        $mockAddress->expects($this->once())
+            ->method('save');
+        $mockAddress->expects($this->any())
+            ->method('setData');
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+        $customerService = $this->_createService();
+
+        $this->_addressBuilder->setId(1)
+            ->setFirstname('John')
+            ->setLastname(self::LASTNAME)
+            ->setRegion(new Dto\Region([
+                'region_id' => self::REGION_ID,
+                'region_code' => '',
+                'region' => self::REGION
+            ]))
+            ->setStreet([self::STREET])
+            ->setTelephone(self::TELEPHONE)
+            ->setCity(self::CITY)
+            ->setCountryId(self::COUNTRY_ID)
+            ->setPostcode(self::POSTCODE);
+        $ids = $customerService->saveAddresses(1, [$this->_addressBuilder->create()]);
+        $this->assertEquals([1], $ids);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage No customer with customerId 4200 exists
+     */
+    public function testSaveAddressesCustomerIdNotExist()
+    {
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(0));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddresses')
+            ->will($this->returnValue([]));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddressItemById')
+            ->with(1)
+            ->will($this->returnValue(null));
+        $customerService = $this->_createService();
+        $this->_addressBuilder->setFirstname('John')
+            ->setLastname(self::LASTNAME)
+            ->setRegion(new Dto\Region([
+                'region_id' => self::REGION_ID,
+                'region_code' => '',
+                'region' => self::REGION
+            ]))
+            ->setStreet([self::STREET])
+            ->setTelephone(self::TELEPHONE)
+            ->setCity(self::CITY)
+            ->setCountryId(self::COUNTRY_ID)
+            ->setPostcode(self::POSTCODE);
+
+        $failures = $customerService->saveAddresses(4200, [$this->_addressBuilder->create()]);
+        $this->assertEmpty($failures);
+    }
+
+    public function testDeleteAddressFromCustomer()
+    {
+        // Setup address mock
+        $mockAddress = $this->_createAddress(1, 'John');
+        $mockAddress->expects($this->any())
+            ->method('getCustomerId')
+            ->will($this->returnValue(self::ID));
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+
+        // verify delete is called on the mock address model
+        $mockAddress->expects($this->once())
+            ->method('delete');
+
+        $customerService = $this->_createService();
+        $customerService->deleteAddressFromCustomer(1, 1);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_CUSTOMER_ID_MISMATCH
+     */
+    public function testDeleteAddressFromCustomerMismatch()
+    {
+        // Setup address mock
+        $mockAddress = $this->_createAddress(1, 'John', 55);
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+
+        // verify delete is called on the mock address model
+        $mockAddress->expects($this->never())
+            ->method('delete');
+
+        $customerService = $this->_createService();
+        $customerService->deleteAddressFromCustomer(1, 1);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_ADDRESS_NOT_FOUND
+     */
+    public function testDeleteAddressFromCustomerBadAddrId()
+    {
+        // Setup address mock
+        $mockAddress = $this->_createAddress(0, '');
+        $mockAddress->expects($this->any())
+            ->method('getCustomerId')
+            ->will($this->returnValue(self::ID));
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+
+        // verify delete is called on the mock address model
+        $mockAddress->expects($this->never())
+            ->method('delete');
+
+        $customerService = $this->_createService();
+        $customerService->deleteAddressFromCustomer(1, 2);
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionCode \Magento\Customer\Service\Entity\V1\Exception::CODE_INVALID_ADDRESS_ID
+     */
+    public function testDeleteAddressFromCustomerInvalidAddrId()
+    {
+        $customerService = $this->_createService();
+        $customerService->deleteAddressFromCustomer(1, 0);
+    }
+
+
+    public function testSaveAddressesWithValidatorException()
+    {
+        // Setup Customer mock
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $this->_customerModelMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue(1));
+        $this->_customerModelMock->expects($this->any())
+            ->method('getAddresses')
+            ->will($this->returnValue([]));
+
+        // Setup address mock
+        $mockAddress = $this->getMockBuilder('Magento\Customer\Model\Address')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $mockAddress->expects($this->any())
+            ->method('validate')
+            ->will($this->returnValue(['some error']));
+        $this->_addressFactoryMock->expects($this->once())
+            ->method('create')
+            ->will($this->returnValue($mockAddress));
+        $customerService = $this->_createService();
+
+        $this->_addressBuilder->setFirstname('John')
+            ->setLastname(self::LASTNAME)
+            ->setRegion(new Dto\Region([
+                'region_id' => self::REGION_ID,
+                'region_code' => '',
+                'region' => self::REGION
+            ]))
+            ->setStreet([self::STREET])
+            ->setTelephone(self::TELEPHONE)
+            ->setCity(self::CITY)
+            ->setCountryId(self::COUNTRY_ID)
+            ->setPostcode(self::POSTCODE);
+        try {
+            $customerService->saveAddresses(1, [$this->_addressBuilder->create()]);
+        } catch (\Magento\Customer\Service\Entity\V1\AggregateException $ae) {
+            $addressException = $ae->getExceptions()[0];
+            $this->assertInstanceOf('\Magento\Customer\Service\Entity\V1\Exception', $addressException);
+            $this->assertInstanceOf('\Magento\Validator\ValidatorException', $addressException->getPrevious());
+            $this->assertSame('some error', $addressException->getPrevious()->getMessage());
+            return;
+        }
+        $this->fail("Expected AggregateException not caught.");
+    }
+
+
+    private function _setupStoreMock()
+    {
+        $this->_storeManagerMock =
+            $this->getMockBuilder('\Magento\Core\Model\StoreManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_storeMock = $this->getMockBuilder('\Magento\Core\Model\Store')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_storeManagerMock
+            ->expects($this->any())
+            ->method('getStore')
+            ->will($this->returnValue($this->_storeMock));
+    }
+
+    /**
+     * @return CustomerAddressService
+     */
+    private function _createService()
+    {
+        $customerService = new CustomerAddressService(
+            $this->_addressFactoryMock,
+            $this->_converter,
+            new Dto\RegionBuilder(),
+            $this->_addressBuilder
+        );
+        return $customerService;
+    }
+
+
+    /**
+     * Helper that returns a mock \Magento\Customer\Model\Address object.
+     *
+     * @param $addrId
+     * @param $firstName
+     * @param $customerId
+     * @return \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Address
+     */
+    private function _createAddress($addrId, $firstName, $customerId = self::ID)
+    {
+        $attributes = [
+            $this->_createAttribute('firstname'),
+            $this->_createAttribute('lastname'),
+            $this->_createAttribute('street'),
+            $this->_createAttribute('city'),
+            $this->_createAttribute('postcode'),
+            $this->_createAttribute('telephone'),
+            $this->_createAttribute('region_id'),
+            $this->_createAttribute('region'),
+            $this->_createAttribute('country_id'),
+        ];
+
+        $addressMock = $this->getMockBuilder('Magento\Customer\Model\Address')
+            ->disableOriginalConstructor()
+            ->setMethods(
+                [
+                    'getId', 'hasDataChanges', 'getRegion', 'getRegionId',
+                    'addData', 'setData', 'setCustomerId', 'setPostIndex',
+                    'setFirstname', 'load', 'save', '__sleep', '__wakeup',
+                    'getDefaultAttributeCodes', 'getAttributes', 'getData',
+                    'getCustomerId', 'getParentId', 'delete', 'validate'
+                ]
+            )
+            ->getMock();
+        $addressMock->expects($this->any())
+            ->method('getId')
+            ->will($this->returnValue($addrId));
+        $addressMock->expects($this->any())
+            ->method('getRegion')
+            ->will($this->returnValue(self::REGION));
+        $addressMock->expects($this->any())
+            ->method('getRegionId')
+            ->will($this->returnValue(self::REGION_ID));
+        $addressMock->expects($this->any())
+            ->method('getCustomerId')
+            ->will($this->returnValue($customerId));
+        $addressMock->expects($this->any())
+            ->method('validate')
+            ->will($this->returnValue(true));
+
+        $map = [
+            ['firstname', null, $firstName],
+            ['lastname', null, self::LASTNAME],
+            ['street', null, self::STREET],
+            ['city', null, self::CITY],
+            ['postcode', null, self::POSTCODE],
+            ['telephone', null, self::TELEPHONE],
+            ['region', null, self::REGION],
+            ['country_id', null, self::COUNTRY_ID],
+        ];
+
+        $addressMock->expects($this->any())
+            ->method('getData')
+            ->will($this->returnValueMap($map));
+
+        $addressMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnSelf());
+        $addressMock->expects($this->any())
+            ->method('getDefaultAttributeCodes')
+            ->will($this->returnValue(['entity_id', 'attribute_set_id']));
+        $addressMock->expects($this->any())
+            ->method('getAttributes')
+            ->will($this->returnValue($attributes));
+        return $addressMock;
+    }
+
+    private function _createAttribute($attributeCode)
+    {
+        $attribute = $this->getMockBuilder('\Magento\Customer\Model\Attribute')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $attribute->expects($this->any())
+            ->method('getAttributeCode')
+            ->will($this->returnValue($attributeCode));
+        return $attribute;
+    }
+
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..ebbb52560e3a11f28cc2de57253dfe94802b7cd3
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerMetadataServiceTest.php
@@ -0,0 +1,234 @@
+<?php
+/**
+ * \Magento\Customer\Service\Eav\CustomerMetadataService
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1;
+
+use Magento\Customer\Service\V1\CustomerMetadataService;
+use Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata;
+use Magento\Customer\Service\V1\Dto\Eav\Option;
+
+class CustomerMetadataServiceTest extends \PHPUnit_Framework_TestCase
+{
+    /** Sample values for testing */
+    const ATTRIBUTE_CODE = 1;
+    const FRONTEND_INPUT = 'frontend input';
+    const INPUT_FILTER = 'input filter';
+    const STORE_LABEL = 'store label';
+    const VALIDATE_RULES = 'validate rules';
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Eav\Model\Config
+     */
+    private $_eavConfigMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Eav\Model\Entity\Attribute\AbstractAttribute
+     */
+    private $_attributeEntityMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Eav\Model\Entity\Attribute\Source\AbstractSource
+     */
+    private $_sourceMock;
+
+    public function setUp()
+    {
+        $this->_eavConfigMock = $this->getMockBuilder('\Magento\Eav\Model\Config')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_attributeEntityMock =
+            $this->getMockBuilder('\Magento\Eav\Model\Entity\Attribute\AbstractAttribute')
+                ->setMethods(
+                    array(
+                        'getAttributeCode',
+                        'getFrontendInput',
+                        'getInputFilter',
+                        'getStoreLabel',
+                        'getValidateRules',
+                        'getSource',
+                        '__wakeup',
+                    )
+                )
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_sourceMock =
+            $this->getMockBuilder('\Magento\Eav\Model\Entity\Attribute\Source\AbstractSource')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_mockReturnValue(
+            $this->_attributeEntityMock,
+            array(
+                'getAttributeCode' => self::ATTRIBUTE_CODE,
+                'getFrontendInput' => self::FRONTEND_INPUT,
+                'getInputFilter' => self::INPUT_FILTER,
+                'getStoreLabel' => self::STORE_LABEL,
+                'getValidateRules' => self::VALIDATE_RULES,
+            )
+        );
+    }
+
+    public function testGetAttributeMetadata()
+    {
+        $this->_eavConfigMock->expects($this->any())
+            ->method('getAttribute')
+            ->will($this->returnValue($this->_attributeEntityMock));
+
+        $this->_attributeEntityMock->expects($this->any())
+            ->method('getSource')
+            ->will($this->returnValue($this->_sourceMock));
+
+        $allOptions = array(
+            array(
+                'label' => 'label1',
+                'value' => 'value1',
+            ),
+            array(
+                'label' => 'label2',
+                'value' => 'value2',
+            ),
+        );
+        $this->_sourceMock->expects($this->any())
+            ->method('getAllOptions')
+            ->will($this->returnValue($allOptions));
+
+        $attributeColMock = $this->getMockBuilder('\\Magento\\Customer\\Model\\Resource\\Form\\Attribute\\Collection')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $storeManagerMock = $this->getMockBuilder('\\Magento\\Core\\Model\\StoreManager')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $optionBuilder = new \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder();
+
+        $attributeMetadataBuilder = new \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder();
+
+        $service = new CustomerMetadataService($this->_eavConfigMock, $attributeColMock, $storeManagerMock,
+            $optionBuilder, $attributeMetadataBuilder);
+
+        $attributeMetadata = $service->getAttributeMetadata('entityCode', 'attributeId');
+        $this->assertEquals(self::ATTRIBUTE_CODE, $attributeMetadata->getAttributeCode());
+        $this->assertEquals(self::FRONTEND_INPUT, $attributeMetadata->getFrontendInput());
+        $this->assertEquals(self::INPUT_FILTER, $attributeMetadata->getInputFilter());
+        $this->assertEquals(self::STORE_LABEL, $attributeMetadata->getStoreLabel());
+        $this->assertEquals(self::VALIDATE_RULES, $attributeMetadata->getValidationRules());
+
+        $options = $attributeMetadata->getOptions();
+        $this->assertNotEquals(array(), $options);
+        $this->assertEquals('label1', $options['label1']->getLabel());
+        $this->assertEquals('value1', $options['label1']->getValue());
+        $this->assertEquals('label2', $options['label2']->getLabel());
+        $this->assertEquals('value2', $options['label2']->getValue());
+    }
+
+    public function testGetAttributeMetadataWithoutOptions()
+    {
+        $this->_eavConfigMock->expects($this->any())
+            ->method('getAttribute')
+            ->will($this->returnValue($this->_attributeEntityMock));
+
+        $this->_attributeEntityMock->expects($this->any())
+            ->method('getSource')
+            ->will($this->returnValue($this->_sourceMock));
+
+        $this->_sourceMock->expects($this->any())
+            ->method('getAllOptions')
+            ->will($this->returnValue(array()));
+
+        $attributeColMock = $this->getMockBuilder('\\Magento\\Customer\\Model\\Resource\\Form\\Attribute\\Collection')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $storeManagerMock = $this->getMockBuilder('\\Magento\\Core\\Model\\StoreManager')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $attributeMetadataBuilder = new \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder();
+
+        $optionBuilder = new \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder();
+
+        $service = new CustomerMetadataService($this->_eavConfigMock, $attributeColMock, $storeManagerMock,
+            $optionBuilder, $attributeMetadataBuilder);
+
+        $attributeMetadata = $service->getAttributeMetadata('entityCode', 'attributeId');
+        $this->assertEquals(self::ATTRIBUTE_CODE, $attributeMetadata->getAttributeCode());
+        $this->assertEquals(self::FRONTEND_INPUT, $attributeMetadata->getFrontendInput());
+        $this->assertEquals(self::INPUT_FILTER, $attributeMetadata->getInputFilter());
+        $this->assertEquals(self::STORE_LABEL, $attributeMetadata->getStoreLabel());
+        $this->assertEquals(self::VALIDATE_RULES, $attributeMetadata->getValidationRules());
+
+        $options = $attributeMetadata->getOptions();
+        $this->assertEquals(0, count($options));
+    }
+
+    public function testGetAttributeMetadataWithoutSource()
+    {
+        $this->_eavConfigMock->expects($this->any())
+            ->method('getAttribute')
+            ->will($this->returnValue($this->_attributeEntityMock));
+
+        $this->_attributeEntityMock->expects($this->any())
+            ->method('getSource')
+            ->will($this->throwException(new \Exception('exception message')));
+
+        $attributeColMock = $this->getMockBuilder('\\Magento\\Customer\\Model\\Resource\\Form\\Attribute\\Collection')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $storeManagerMock = $this->getMockBuilder('\\Magento\\Core\\Model\\StoreManager')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $optionBuilder = new \Magento\Customer\Service\V1\Dto\Eav\OptionBuilder();
+
+        $attributeMetadataBuilder = new \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadataBuilder();
+
+        $service = new CustomerMetadataService($this->_eavConfigMock, $attributeColMock, $storeManagerMock,
+            $optionBuilder, $attributeMetadataBuilder);
+
+        $attributeMetadata = $service->getAttributeMetadata('entityCode', 'attributeId');
+        $this->assertEquals(self::ATTRIBUTE_CODE, $attributeMetadata->getAttributeCode());
+        $this->assertEquals(self::FRONTEND_INPUT, $attributeMetadata->getFrontendInput());
+        $this->assertEquals(self::INPUT_FILTER, $attributeMetadata->getInputFilter());
+        $this->assertEquals(self::STORE_LABEL, $attributeMetadata->getStoreLabel());
+        $this->assertEquals(self::VALIDATE_RULES, $attributeMetadata->getValidationRules());
+
+        $options = $attributeMetadata->getOptions();
+        $this->assertEquals(0, count($options));
+    }
+
+    /**
+     * @param \PHPUnit_Framework_MockObject_MockObject $mock
+     * @param array $valueMap
+     */
+    private function _mockReturnValue($mock, $valueMap)
+    {
+        foreach ($valueMap as $method => $value) {
+            $mock->expects($this->any())
+                ->method($method)
+                ->will($this->returnValue($value));
+        }
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..6a8d7cb856fa5dc103d959f78ec8817f82c6ef39
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/CustomerServiceTest.php
@@ -0,0 +1,471 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1;
+
+/**
+ * \Magento\Customer\Service\V1\CustomerService
+ *
+ * @SuppressWarnings(PHPMD.TooManyMethods)
+ * @SuppressWarnings(PHPMD.ExcessivePublicCount)
+ * @SuppressWarnings(PHPMD.ExcessiveMethodLength)
+ * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
+ */
+class CustomerServiceTest extends \PHPUnit_Framework_TestCase
+{
+    const STREET = 'Parmer';
+    const CITY = 'Albuquerque';
+    const POSTCODE = '90014';
+    const TELEPHONE = '7143556767';
+    const REGION = 'Alabama';
+    const REGION_ID = 1;
+    const COUNTRY_ID = 'US';
+
+    /** Sample values for testing */
+    const ID = 1;
+    const FIRSTNAME = 'Jane';
+    const LASTNAME = 'Doe';
+    const NAME = 'J';
+    const EMAIL = 'janedoe@example.com';
+    const EMAIL_CONFIRMATION_KEY = 'blj487lkjs4confirmation_key';
+    const PASSWORD = 'password';
+    const ATTRIBUTE_CODE = 'random_attr_code';
+    const ATTRIBUTE_VALUE = 'random_attr_value';
+    const WEBSITE_ID = 1;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\CustomerFactory
+     */
+    private $_customerFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\AddressFactory
+     */
+    private $_addressFactoryMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Customer
+     */
+    private $_customerModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Model\Attribute
+     */
+    private $_attributeModelMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\CustomerMetadataServiceInterface
+     */
+    private $_eavMetadataServiceMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Event\ManagerInterface
+     */
+    private $_eventManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\StoreManagerInterface
+     */
+    private $_storeManagerMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Math\Random
+     */
+    private $_mathRandomMock;
+
+    /**
+     * @var \Magento\Customer\Model\Converter
+     */
+    private $_converter;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Core\Model\Store
+     */
+    private $_storeMock;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    private $_addressBuilder;
+
+    /**
+     * @var \PHPUnit_Framework_MockObject_MockObject | \Magento\Customer\Service\V1\Dto\CustomerBuilder
+     */
+    private $_customerBuilder;
+
+    private $_validator;
+
+    public function setUp()
+    {
+        $this->_customerFactoryMock = $this->getMockBuilder('Magento\Customer\Model\CustomerFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_customerModelMock = $this->getMockBuilder('Magento\Customer\Model\Customer')
+            ->disableOriginalConstructor()
+            ->setMethods(
+                array(
+                    'getId',
+                    'getFirstname',
+                    'getLastname',
+                    'getName',
+                    'getEmail',
+                    'getAttributes',
+                    'getConfirmation',
+                    'setConfirmation',
+                    'save',
+                    'load',
+                    '__wakeup',
+                    'authenticate',
+                    'getData',
+                    'getDefaultBilling',
+                    'getDefaultShipping',
+                    'getDefaultShippingAddress',
+                    'getDefaultBillingAddress',
+                    'getStoreId',
+                    'getAddressById',
+                    'getAddresses',
+                    'getAddressItemById',
+                    'getParentId',
+                    'isConfirmationRequired',
+                    'addAddress',
+                    'loadByEmail',
+                    'sendNewAccountEmail',
+                    'setFirstname',
+                    'setLastname',
+                    'setEmail',
+                    'setPassword',
+                    'setData',
+                    'setWebsiteId',
+                    'getAttributeSetId',
+                    'setAttributeSetId',
+                    'validate',
+                    'getRpToken',
+                    'setRpToken',
+                    'setRpTokenCreatedAt',
+                    'isResetPasswordLinkTokenExpired',
+                    'changeResetPasswordLinkToken',
+                    'sendPasswordResetConfirmationEmail',
+                )
+            )
+            ->getMock();
+
+        $this->_addressFactoryMock = $this->getMockBuilder('Magento\Customer\Model\AddressFactory')
+            ->disableOriginalConstructor()
+            ->setMethods(array('create'))
+            ->getMock();
+
+        $this->_eavMetadataServiceMock =
+            $this->getMockBuilder('Magento\Customer\Service\Eav\AttributeMetadataServiceV1Interface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_eventManagerMock =
+            $this->getMockBuilder('\Magento\Event\ManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_attributeModelMock =
+            $this->getMockBuilder('\Magento\Customer\Model\Attribute')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_attributeModelMock
+            ->expects($this->any())
+            ->method('getAttributeCode')
+            ->will($this->returnValue(self::ATTRIBUTE_CODE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('getData')
+            ->with($this->equalTo(self::ATTRIBUTE_CODE))
+            ->will($this->returnValue(self::ATTRIBUTE_VALUE));
+
+        $this->_customerModelMock
+            ->expects($this->any())
+            ->method('validate')
+            ->will($this->returnValue(TRUE));
+
+        $this->_setupStoreMock();
+
+        $this->_mathRandomMock = $this->getMockBuilder('\Magento\Math\Random')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_validator = $this->getMockBuilder('\Magento\Customer\Model\Metadata\Validator')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_addressBuilder = new Dto\AddressBuilder(
+            new Dto\RegionBuilder());
+
+        $this->_customerBuilder = new Dto\CustomerBuilder();
+
+        $customerBuilder = new Dto\CustomerBuilder();
+
+        $this->_converter = new \Magento\Customer\Model\Converter($customerBuilder, $this->_customerFactoryMock);
+    }
+
+    public function testGetCustomer()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                 'getId' => self::ID,
+                 'getFirstname' => self::FIRSTNAME,
+                 'getLastname' => self::LASTNAME,
+                 'getName' => self::NAME,
+                 'getEmail' => self::EMAIL,
+                 'getAttributes' => array($this->_attributeModelMock),
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $customerService = $this->_createService();
+
+        $actualCustomer = $customerService->getCustomer(self::ID);
+        $this->assertEquals(self::ID, $actualCustomer->getCustomerId(), 'customer id does not match');
+        $this->assertEquals(self::FIRSTNAME, $actualCustomer->getFirstName());
+        $this->assertEquals(self::LASTNAME, $actualCustomer->getLastName());
+        $this->assertEquals(self::EMAIL, $actualCustomer->getEmail());
+        $this->assertEquals(4, count($actualCustomer->getAttributes()));
+        $attribute = $actualCustomer->getAttribute(self::ATTRIBUTE_CODE);
+        $this->assertEquals(self::ATTRIBUTE_VALUE, $attribute);
+    }
+
+    public function testGetCustomerCached()
+    {
+        $this->_customerModelMock->expects($this->any())
+            ->method('load')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'getFirstname' => self::FIRSTNAME,
+                'getLastname' => self::LASTNAME,
+                'getName' => self::NAME,
+                'getEmail' => self::EMAIL,
+                'getAttributes' => array($this->_attributeModelMock),
+            )
+        );
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+        $service = $this->_createService();
+
+        $firstCall = $service->getCustomer(self::ID);
+        $secondCall = $service->getCustomer(1);
+
+        $this->assertSame($firstCall, $secondCall);
+    }
+
+    public function testSaveCustomer()
+    {
+        $customerData = [
+            'customer_id' => self::ID,
+            'email' => self::EMAIL,
+            'firstname' => self::FIRSTNAME,
+            'lastname' => self::LASTNAME,
+            'create_in' => 'Admin',
+            'password' => 'password'
+        ];
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+                'load' => $this->_customerModelMock,
+            )
+        );
+
+        // verify
+        $this->_customerModelMock->expects($this->atLeastOnce())
+            ->method('setData');
+
+        $customerService = $this->_createService();
+
+        $this->assertEquals(self::ID, $customerService->saveCustomer($customerEntity));
+    }
+
+    public function testSaveNonexistingCustomer()
+    {
+        $customerData = [
+            'customer_id' => self::ID,
+            'email' => self::EMAIL,
+            'firstname' => self::FIRSTNAME,
+            'lastname' => self::LASTNAME,
+            'create_in' => 'Admin',
+            'password' => 'password'
+        ];
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $this->_customerFactoryMock->expects($this->atLeastOnce())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => '2',
+            )
+        );
+
+        // verify
+        $this->_customerModelMock->expects($this->atLeastOnce())
+            ->method('setData');
+
+        $customerService = $this->_createService();
+
+        $this->assertEquals(2, $customerService->saveCustomer($customerEntity));
+    }
+
+    public function testSaveNewCustomer()
+    {
+        $customerData = [
+            'email' => self::EMAIL,
+            'firstname' => self::FIRSTNAME,
+            'lastname' => self::LASTNAME,
+            'create_in' => 'Admin',
+            'password' => 'password'
+        ];
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+            )
+        );
+
+        // verify
+        $this->_customerModelMock->expects($this->atLeastOnce())
+            ->method('setData');
+
+        $customerService = $this->_createService();
+
+        $this->assertEquals(self::ID, $customerService->saveCustomer($customerEntity));
+    }
+
+    /**
+     * @expectedException \Magento\Customer\Service\Entity\V1\Exception
+     * @expectedExceptionMessage exception message
+     */
+    public function testSaveCustomerWithException()
+    {
+        $customerData = [
+            'email' => self::EMAIL,
+            'firstname' => self::FIRSTNAME,
+            'lastname' => self::LASTNAME,
+            'create_in' => 'Admin',
+            'password' => 'password'
+        ];
+        $this->_customerBuilder->populateWithArray($customerData);
+        $customerEntity = $this->_customerBuilder->create();
+
+        $this->_customerFactoryMock->expects($this->any())
+            ->method('create')
+            ->will($this->returnValue($this->_customerModelMock));
+
+        $this->_mockReturnValue(
+            $this->_customerModelMock,
+            array(
+                'getId' => self::ID,
+            )
+        );
+
+        $this->_customerModelMock->expects($this->once())
+            ->method('save')
+            ->will($this->throwException(new \Exception('exception message')));
+
+        // verify
+        $customerService = $this->_createService();
+
+        $customerService->saveCustomer($customerEntity);
+    }
+
+    /**
+     * @param \PHPUnit_Framework_MockObject_MockObject $mock
+     * @param array $valueMap
+     */
+    private function _mockReturnValue($mock, $valueMap)
+    {
+        foreach ($valueMap as $method => $value) {
+            $mock->expects($this->any())
+                ->method($method)
+                ->will($this->returnValue($value));
+        }
+    }
+
+    /**
+     * @return CustomerService
+     */
+    private function _createService()
+    {
+        $customerService = new CustomerService(
+            $this->_converter
+        );
+        return $customerService;
+    }
+
+    private function _setupStoreMock()
+    {
+        $this->_storeManagerMock =
+            $this->getMockBuilder('\Magento\Core\Model\StoreManagerInterface')
+                ->disableOriginalConstructor()
+                ->getMock();
+
+        $this->_storeMock = $this->getMockBuilder('\Magento\Core\Model\Store')
+            ->disableOriginalConstructor()
+            ->getMock();
+
+        $this->_storeManagerMock
+            ->expects($this->any())
+            ->method('getStore')
+            ->will($this->returnValue($this->_storeMock));
+    }
+
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/AddressTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/AddressTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..1f58ade0380aa89fcdf35509af1787b7daec28ef
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/AddressTest.php
@@ -0,0 +1,218 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Address;
+use Magento\Customer\Service\V1\Dto\AddressBuilder;
+
+class AddressTest extends \PHPUnit_Framework_TestCase
+{
+    /** Sample values for testing */
+    const ID = 14;
+    const IS_SHIPPING = true;
+    const IS_BILLING = false;
+    const COMPANY = 'Company Name';
+    const FAX = '(555) 555-5555';
+    const MIDDLENAME = 'Mid';
+    const PREFIX = 'Mr.';
+    const SUFFIX = 'Esq.';
+    const VAT_ID = 'S45';
+    const FIRSTNAME = 'Jane';
+    const LASTNAME = 'Doe';
+    const STREET_LINE_0 = '7700 W Parmer Ln';
+    const CITY = 'Austin';
+    const COUNTRY_CODE = 'US';
+    const POSTCODE = '78620';
+    const TELEPHONE = '5125125125';
+    const REGION = 'Texas';
+
+    protected $_expectedValues = [
+        'id' => 14,
+        'default_shipping' => true,
+        'default_billing' => false,
+        'company' => 'Company Name',
+        'fax' => '(555) 555-5555',
+        'middlename' => 'Mid',
+        'prefix' => 'Mr.',
+        'suffix' => 'Esq.',
+        'vat_id' => 'S45',
+        'firstname' => 'Jane',
+        'lastname' => 'Doe',
+        'street' => ['7700 W Parmer Ln'],
+        'city' => 'Austin',
+        'country_id' => 'US',
+        'postcode' => '78620',
+        'telephone' => '5125125125',
+        'region_id' => 0,
+        'region' => 'Texas',
+    ];
+
+    /**
+     * @var \Magento\Customer\Service\V1\Dto\AddressBuilder
+     */
+    protected $_addressBuilder;
+
+    protected function setUp()
+    {
+        $this->_addressBuilder = new \Magento\Customer\Service\V1\Dto\AddressBuilder(
+            new \Magento\Customer\Service\V1\Dto\RegionBuilder()
+        );
+    }
+
+    public function testMinimalAddress()
+    {
+        $this->_fillMinimumRequiredFields($this->_addressBuilder);
+        $this->_assertMinimumRequiredFields($this->_addressBuilder->create());
+    }
+
+    public function testCopyAndModify()
+    {
+        /** @var \Magento\Customer\Service\V1\Dto\Address $origAddress */
+        $origAddress = $this->getMockBuilder('\Magento\Customer\Service\V1\Dto\Address')
+            ->disableOriginalConstructor()
+            ->getMock();
+        $this->_mockReturnValue($origAddress, array(
+            'getFirstname' => $this->_expectedValues['firstname'],
+            'getLastname' => $this->_expectedValues['lastname'],
+            'getStreet' => $this->_expectedValues['street'],
+            'getCity' => $this->_expectedValues['city'],
+            'getCountryId' => $this->_expectedValues['country_id'],
+            'getRegion' => new \Magento\Customer\Service\V1\Dto\Region(['region' => 'Texas', 'region_code' => '']),
+            'getPostcode' => $this->_expectedValues['postcode'],
+            'getTelephone' => $this->_expectedValues['telephone'],
+        ));
+
+        $this->_assertMinimumRequiredFields($origAddress);
+    }
+
+    public function testFullAddress()
+    {
+        $this->_fillAllFields($this->_addressBuilder);
+        $address = $this->_addressBuilder->create();
+
+        $this->_assertMinimumRequiredFields($address);
+        $this->assertEquals($this->_expectedValues['id'], $address->getId());
+        $this->assertEquals($this->_expectedValues['default_shipping'], $address->isDefaultShipping());
+        $this->assertEquals($this->_expectedValues['default_billing'], $address->isDefaultBilling());
+        $this->assertEquals($this->_expectedValues['company'], $address->getCompany());
+        $this->assertEquals($this->_expectedValues['fax'], $address->getFax());
+        $this->assertEquals($this->_expectedValues['middlename'], $address->getMiddlename());
+        $this->assertEquals($this->_expectedValues['prefix'], $address->getPrefix());
+        $this->assertEquals($this->_expectedValues['suffix'], $address->getSuffix());
+        $this->assertEquals($this->_expectedValues['vat_id'], $address->getVatId());
+    }
+
+    public function testSetStreet()
+    {
+        $this->_fillMinimumRequiredFields($this->_addressBuilder);
+        $tmpAddress = $this->_addressBuilder->create();
+        $street = $tmpAddress->getStreet();
+        $street[] = 'Line_1';
+        $this->_addressBuilder->populate($tmpAddress);
+        $this->_addressBuilder->setStreet($street);
+
+        $address = $this->_addressBuilder->create();
+        $this->_assertMinimumRequiredFields($address);
+        $this->assertEquals('Line_1', $address->getStreet()[1]);
+    }
+
+    public function testGetAttributes()
+    {
+        $this->_fillAllFields($this->_addressBuilder);
+        $expected = $this->_expectedValues;
+        unset($expected['id']);
+        unset($expected['default_billing']);
+        unset($expected['default_shipping']);
+        $this->assertEquals($expected, $this->_addressBuilder->create()->getAttributes());
+    }
+
+    /**
+     * @param \PHPUnit_Framework_MockObject_MockObject $mock
+     * @param array $valueMap
+     */
+    private function _mockReturnValue($mock, $valueMap)
+    {
+        foreach ($valueMap as $method => $value) {
+            $mock->expects($this->any())
+                ->method($method)
+                ->will($this->returnValue($value));
+        }
+    }
+
+    /**
+     * @param AddressBuilder $address
+     */
+    private function _fillMinimumRequiredFields($addressBuilder)
+    {
+        $addressBuilder->setFirstname($this->_expectedValues['firstname']);
+        $addressBuilder->setLastname($this->_expectedValues['lastname']);
+        $addressBuilder->setStreet($this->_expectedValues['street']);
+        $addressBuilder->setCity($this->_expectedValues['city']);
+        $addressBuilder->setCountryId($this->_expectedValues['country_id']);
+        $addressBuilder->setRegion(
+            new \Magento\Customer\Service\V1\Dto\Region(['region' => $this->_expectedValues['region'],
+                'region_code' => ''])
+        );
+        $addressBuilder->setPostcode($this->_expectedValues['postcode']);
+        $addressBuilder->setTelephone($this->_expectedValues['telephone']);
+    }
+
+    /**
+     * @param Address $address
+     */
+    private function _fillAllFields($addressBuilder)
+    {
+        $this->_fillMinimumRequiredFields($addressBuilder);
+
+        $addressBuilder->setId($this->_expectedValues['id']);
+        $addressBuilder->setSuffix($this->_expectedValues['suffix']);
+        $addressBuilder->setMiddlename($this->_expectedValues['middlename']);
+        $addressBuilder->setPrefix($this->_expectedValues['prefix']);
+        $addressBuilder->setVatId($this->_expectedValues['vat_id']);
+        $addressBuilder->setDefaultShipping($this->_expectedValues['default_shipping']);
+        $addressBuilder->setDefaultBilling($this->_expectedValues['default_billing']);
+        $addressBuilder->setCompany($this->_expectedValues['company']);
+        $addressBuilder->setFax($this->_expectedValues['fax']);
+    }
+
+    /**
+     * @param Address $address
+     */
+    private function _assertMinimumRequiredFields($address)
+    {
+        $this->assertEquals($this->_expectedValues['firstname'], $address->getFirstname());
+        $this->assertEquals($this->_expectedValues['lastname'], $address->getLastname());
+        $this->assertEquals($this->_expectedValues['street'][0], $address->getStreet()[0]);
+        $this->assertEquals($this->_expectedValues['city'], $address->getCity());
+        $this->assertEquals($this->_expectedValues['country_id'], $address->getCountryId());
+        $this->assertEquals(
+            new \Magento\Customer\Service\V1\Dto\Region(['region' => $this->_expectedValues['region'],
+                'region_code' => '']),
+            $address->getRegion()
+        );
+        $this->assertEquals($this->_expectedValues['postcode'], $address->getPostcode());
+        $this->assertEquals($this->_expectedValues['telephone'], $address->getTelephone());
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/CustomerTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/CustomerTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..138774bf6fcab0c245ef156a348029a524741d60
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/CustomerTest.php
@@ -0,0 +1,156 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1\Dto;
+
+/**
+ * Customer
+ *
+ * @package Magento\Customer\Service\Entity\V1
+ */
+class CustomerTest extends \PHPUnit_Framework_TestCase
+{
+    const CONFIRMATION = 'a4fg7h893e39d';
+    const CREATED_AT = '2013-11-05';
+    const STORE_NAME = 'Store Name';
+    const DOB = '1970-01-01';
+    const GENDER = 'Male';
+    const GROUP_ID = 1;
+    const MIDDLENAME = 'A';
+    const PREFIX = 'Mr.';
+    const STORE_ID = 1;
+    const SUFFIX = 'Esq.';
+    const TAXVAT = '12';
+    const WEBSITE_ID = 1;
+
+    /** Sample values for testing */
+    const ID = 1;
+    const FIRSTNAME = 'Jane';
+    const LASTNAME = 'Doe';
+    const NAME = 'J';
+    const EMAIL = 'janedoe@example.com';
+    const ATTRIBUTE_CODE = 'attribute_code';
+    const ATTRIBUTE_VALUE = 'attribute_value';
+
+    public function testSetters()
+    {
+        $customerData = $this->_createCustomerData();
+        $customerBuilder = new \Magento\Customer\Service\V1\Dto\CustomerBuilder();
+        $customerBuilder->populateWithArray($customerData);
+
+        /** @var Customer $customer */
+        $customer = $customerBuilder->create();
+
+        $this->assertEquals(self::ID, $customer->getCustomerId());
+        $this->assertEquals(self::FIRSTNAME, $customer->getFirstname());
+        $this->assertEquals(self::LASTNAME, $customer->getLastname());
+        $this->assertEquals(self::EMAIL, $customer->getEmail());
+        $this->assertEquals(self::CONFIRMATION, $customer->getConfirmation());
+        $this->assertEquals(self::CREATED_AT, $customer->getCreatedAt());
+        $this->assertEquals(self::STORE_NAME, $customer->getCreatedIn());
+        $this->assertEquals(self::DOB, $customer->getDob());
+        $this->assertEquals(self::GENDER, $customer->getGender());
+        $this->assertEquals(self::GROUP_ID, $customer->getGroupId());
+        $this->assertEquals(self::MIDDLENAME, $customer->getMiddlename());
+        $this->assertEquals(self::PREFIX, $customer->getPrefix());
+        $this->assertEquals(self::STORE_ID, $customer->getStoreId());
+        $this->assertEquals(self::SUFFIX, $customer->getSuffix());
+        $this->assertEquals(self::TAXVAT, $customer->getTaxvat());
+        $this->assertEquals(self::WEBSITE_ID, $customer->getWebsiteId());
+        $attribute = $customer->getAttribute(self::ATTRIBUTE_CODE);
+        $this->assertEquals(self::ATTRIBUTE_VALUE, $attribute);
+    }
+
+    public function testGetAttributeNotExist()
+    {
+        $customerData = $this->_createCustomerData();
+        $customerBuilder = new \Magento\Customer\Service\V1\Dto\CustomerBuilder();
+        $customerBuilder->populateWithArray($customerData);
+        /** @var Customer $customer */
+        $customer = $customerBuilder->create();
+
+        $this->assertNull($customer->getAttribute('A non existing attribute code'));
+    }
+
+    public function testGetAttributes()
+    {
+        $customerData = $this->_createCustomerData();
+        /** @var CustomerBuilder $customerBuilder */
+        $customerBuilder = new \Magento\Customer\Service\V1\Dto\CustomerBuilder();
+        $customerBuilder->populateWithArray($customerData);
+        /** @var Customer $customer */
+        $customer = $customerBuilder->create();
+
+        $actualAttributes = $customer->getAttributes();
+        $this->assertEquals(
+            [
+                'confirmation' => self::CONFIRMATION,
+                'created_at' => self::CREATED_AT,
+                'created_in' => self::STORE_NAME,
+                'dob' => self::DOB,
+                'email' => self::EMAIL,
+                'firstname' => self::FIRSTNAME,
+                'gender' => self::GENDER,
+                'group_id' => self::GROUP_ID,
+                'lastname' => self::LASTNAME,
+                'middlename' => self::MIDDLENAME,
+                'prefix' => self::PREFIX,
+                'store_id' => self::STORE_ID,
+                'suffix' => self::SUFFIX,
+                'taxvat' => self::TAXVAT,
+                'website_id' => self::WEBSITE_ID,
+                self::ATTRIBUTE_CODE => self::ATTRIBUTE_VALUE,
+            ],
+            $actualAttributes
+        );
+    }
+
+    /**
+     * Create customer using setters.
+     *
+     * @return CustomerBuilder
+     */
+    private function _createCustomerData()
+    {
+        return [
+            self::ATTRIBUTE_CODE => self::ATTRIBUTE_VALUE,
+            'id' => self::ID,
+            'firstname' => self::FIRSTNAME,
+            'lastname' => self::LASTNAME,
+            'email' => self::EMAIL,
+            'confirmation' => self::CONFIRMATION,
+            'created_at' => self::CREATED_AT,
+            'created_in' => self::STORE_NAME,
+            'dob' => self::DOB,
+            'gender' => self::GENDER,
+            'group_id' => self::GROUP_ID,
+            'middlename' => self::MIDDLENAME,
+            'prefix' => self::PREFIX,
+            'store_id' => self::STORE_ID,
+            'suffix' => self::SUFFIX,
+            'taxvat' => self::TAXVAT,
+            'website_id' => self::WEBSITE_ID
+        ];
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..4ae711b6411471726ace54858a548664a8e389a7
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeMetadataTest.php
@@ -0,0 +1,58 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+class AttributeMetadataTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * Constants for testing
+     */
+    const ATTRIBUTE_CODE = 'ATTRIBUTE_CODE';
+    const FRONT_END_INPUT = 'FRONT_END_INPUT';
+    const INPUT_FILTER = 'INPUT_FILTER';
+    const STORE_LABEL = 'STORE_LABEL';
+    const VALIDATION_RULES = 'VALIDATION_RULES';
+
+    public function testConstructorAndGetters()
+    {
+        $options = array('OPTION_ONE', 'OPTION_TWO');
+
+        $attributeMetadata = new \Magento\Customer\Service\V1\Dto\Eav\AttributeMetadata([
+            'attribute_code' => self::ATTRIBUTE_CODE,
+            'front_end_input' => self::FRONT_END_INPUT,
+            'input_filter' => self::INPUT_FILTER,
+            'store_label' => self::STORE_LABEL,
+            'validation_rules' => self::VALIDATION_RULES,
+            'options' => $options
+        ]);
+
+        $this->assertSame(self::ATTRIBUTE_CODE, $attributeMetadata->getAttributeCode());
+        $this->assertSame(self::FRONT_END_INPUT, $attributeMetadata->getFrontendInput());
+        $this->assertSame(self::INPUT_FILTER, $attributeMetadata->getInputFilter());
+        $this->assertSame(self::STORE_LABEL, $attributeMetadata->getStoreLabel());
+        $this->assertSame(self::VALIDATION_RULES, $attributeMetadata->getValidationRules());
+        $this->assertSame($options, $attributeMetadata->getOptions());
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..808a9b563e16dac0a4a670b3f55cccbcf58b1bd9
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/AttributeTest.php
@@ -0,0 +1,43 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+class AttributeTest extends \PHPUnit_Framework_TestCase
+{
+    const ATTRIBUTE_CODE = 'ATTRIBUTE_CODE';
+
+    const VALUE = 'VALUE';
+
+    public function testConstructorAndGetters()
+    {
+        $attribute = new \Magento\Customer\Service\V1\Dto\Eav\Attribute([
+            'attribute_code' => self::ATTRIBUTE_CODE,
+            'value' => self::VALUE
+        ]);
+
+        $this->assertSame(self::ATTRIBUTE_CODE, $attribute->getAttributeCode());
+        $this->assertSame(self::VALUE, $attribute->getValue());
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/OptionTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/OptionTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..4b63e285dd70ddddf70de5471cbc02143a87bb29
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/Eav/OptionTest.php
@@ -0,0 +1,43 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Customer\Service\V1\Dto\Eav;
+
+class OptionTest extends \PHPUnit_Framework_TestCase
+{
+    const LABEL = 'LABEL';
+
+    const VALUE = 'VALUE';
+
+    public function testConstructorAndGetters()
+    {
+        $option = new \Magento\Customer\Service\V1\Dto\Eav\Option([
+            'label' => self::LABEL,
+            'value' => self::VALUE
+        ]);
+
+        $this->assertSame(self::LABEL, $option->getLabel());
+        $this->assertSame(self::VALUE, $option->getValue());
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/RegionTest.php b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/RegionTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..bb323654fdd3c059e4adc0395db656a55fec42dd
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Customer/Service/V1/Dto/RegionTest.php
@@ -0,0 +1,44 @@
+<?php
+/**
+ * Test \Magento\Customer\Service\Entity\V1\Region
+ *
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Customer\Service\V1\Dto;
+
+use Magento\Customer\Service\V1\Dto\Region;
+
+class RegionTest extends \PHPUnit_Framework_TestCase
+{
+    public function testRegion()
+    {
+        $region = new Region([
+            'region' => 'Alabama',
+            'region_code' => 'AL',
+            'region_id' => 1
+        ]);
+
+        $this->assertEquals(1, $region->getRegionId());
+        $this->assertEquals('AL', $region->getRegionCode());
+        $this->assertEquals('Alabama', $region->getRegion());
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Directory/Model/Currency/DefaultLocatorTest.php b/dev/tests/unit/testsuite/Magento/Directory/Model/Currency/DefaultLocatorTest.php
index 1f032999678e9a2726ce7322a8125d344ab4e3b1..e647fae51ccb933c6f956905203b91b1fe2891ee 100644
--- a/dev/tests/unit/testsuite/Magento/Directory/Model/Currency/DefaultLocatorTest.php
+++ b/dev/tests/unit/testsuite/Magento/Directory/Model/Currency/DefaultLocatorTest.php
@@ -55,9 +55,8 @@ class DefaultLocatorTest extends \PHPUnit_Framework_TestCase
 
     public function testGetDefaultCurrencyReturnDefaultStoreDefaultCurrencyIfNoStoreIsSpecified()
     {
-        $storeMock = $this->getMock('Magento\Core\Model\Store', array(), array(), '', false);
-        $storeMock->expects($this->once())->method('getBaseCurrencyCode')->will($this->returnValue('storeCurrency'));
-        $this->_appMock->expects($this->once())->method('getStore')->will($this->returnValue($storeMock));
+        $this->_appMock->expects($this->once())->method('getBaseCurrencyCode')
+            ->will($this->returnValue('storeCurrency'));
         $this->assertEquals('storeCurrency', $this->_model->getDefaultCurrency($this->_requestMock));
     }
 
diff --git a/dev/tests/unit/testsuite/Magento/Image/Adapter/Gd2Test.php b/dev/tests/unit/testsuite/Magento/Image/Adapter/Gd2Test.php
new file mode 100644
index 0000000000000000000000000000000000000000..51f061dd3ff1b12a48ee915ee87ec2f1ecec9ea8
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Image/Adapter/Gd2Test.php
@@ -0,0 +1,172 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Image\Adapter;
+
+use \Magento\TestFramework\Helper\ObjectManager;
+
+/**
+ * Mocking crucial for this adapter global functions
+ */
+
+/**
+ * @param $paramName
+ * @throws \InvalidArgumentException
+ * @return string
+ */
+function ini_get($paramName)
+{
+    if ('memory_limit' == $paramName) {
+        return Gd2Test::$memoryLimit;
+    }
+
+    throw new \InvalidArgumentException('Unexpected parameter ' . $paramName);
+}
+
+/**
+ * @param $file
+ * @return mixed
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+function getimagesize($file)
+{
+    return Gd2Test::$imageData;
+}
+
+/**
+ * @param $real
+ * @return int
+ *
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+function memory_get_usage($real)
+{
+    return 1000000;
+}
+
+/**
+ * @param $callable
+ * @param $param
+ * @return bool
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+function call_user_func($callable, $param)
+{
+    return false;
+}
+
+/**
+ * \Magento\Image\Adapter\Gd2 class test
+ */
+class Gd2Test extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * Value to mock ini_get('memory_limit')
+     *
+     * @var string
+     */
+    public static $memoryLimit;
+
+    /**
+     * @var array simulation of getimagesize()
+     */
+    public static $imageData = array();
+
+    /**
+     * Adapter for testing
+     * @var \Magento\Image\Adapter\Gd2
+     */
+    protected $adapter;
+
+    /**
+     * @var \Magento\TestFramework\Helper\ObjectManager
+     */
+    protected $objectManager;
+
+    /**
+     * Setup testing object
+     */
+    public function setUp()
+    {
+        $this->objectManager = new ObjectManager($this);
+        $this->adapter = $this->objectManager->getObject('\Magento\Image\Adapter\Gd2');
+    }
+
+    /**
+     * Test parent class
+     */
+    public function testParentClass()
+    {
+        $this->assertInstanceOf('\Magento\Image\Adapter\AbstractAdapter', $this->adapter);
+    }
+
+    /**
+     * Test open() method
+     *
+     * @param $fileData array
+     * @param $exception string|bool|null
+     * @param $limit string
+     * @dataProvider filesProvider
+     */
+    public function testOpen($fileData, $exception, $limit)
+    {
+        self::$memoryLimit = $limit;
+        self::$imageData = $fileData;
+
+        if (!empty($exception)) {
+            $this->setExpectedException($exception);
+        }
+
+        $this->adapter->open('file');
+    }
+
+    public function filesProvider()
+    {
+        $smallFile = array(
+            0 => 480,
+            1 => 320,
+            2 => 2,
+            3 => 'width="480" height="320"',
+            'bits' => 8,
+            'channels' => 3,
+            'mime' => 'image/jpeg',
+        );
+
+        $bigFile = array(
+            0 => 3579,
+            1 => 2398,
+            2 => 2,
+            3 => 'width="3579" height="2398"',
+            'bits' => 8,
+            'channels' => 3,
+            'mime' => 'image/jpeg',
+        );
+
+        return array(
+            'positive_M' => array($smallFile, false, '2M'),
+            'positive_KB' => array($smallFile, false, '2048KB'),
+            'negative_bytes' => array($bigFile, 'OverflowException', '2048000')
+        );
+    }
+}
diff --git a/dev/tests/unit/testsuite/Magento/Paypal/Block/Express/ReviewTest.php b/dev/tests/unit/testsuite/Magento/Paypal/Block/Express/ReviewTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..8297f11cba7c4d89de2470fdbaf41cc269ea53ae
--- /dev/null
+++ b/dev/tests/unit/testsuite/Magento/Paypal/Block/Express/ReviewTest.php
@@ -0,0 +1,75 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+
+namespace Magento\Paypal\Block\Express;
+
+class ReviewTest extends \PHPUnit_Framework_TestCase
+{
+    /**
+     * @var \Magento\App\Request\Http|\PHPUnit_Framework_MockObject_MockObject
+     */
+    protected $request;
+
+    /**
+     * @var \Magento\View\Url|\PHPUnit_Framework_MockObject_MockObject
+     */
+    protected $viewUrl;
+
+    /**
+     * @var Review
+     */
+    protected $model;
+
+    protected function setUp()
+    {
+        $helper = new \Magento\TestFramework\Helper\ObjectManager($this);
+        $this->request = $this->getMock('Magento\App\Request\Http', [], [], '', false);
+        $this->viewUrl = $this->getMock('Magento\View\Url', [], [], '', false);
+        $this->model = $helper->getObject(
+            'Magento\Paypal\Block\Express\Review',
+            ['request' => $this->request, 'viewUrl' => $this->viewUrl]
+        );
+    }
+
+    /**
+     * @param bool $isSecure
+     * @dataProvider getViewFileUrlDataProvider
+     */
+    public function testGetViewFileUrl($isSecure)
+    {
+        $this->request->expects($this->once())->method('isSecure')->will($this->returnValue($isSecure));
+        $this->viewUrl->expects($this->once())
+            ->method('getViewFileUrl')
+            ->with('some file', $this->callback(function ($value) use ($isSecure) {
+                return isset($value['_secure']) && $value['_secure'] === $isSecure;
+            }))
+            ->will($this->returnValue('result url'));
+        $this->assertEquals('result url', $this->model->getViewFileUrl('some file'));
+    }
+
+    public function getViewFileUrlDataProvider()
+    {
+        return [[true], [false]];
+    }
+}
diff --git a/lib/3Dsecure/CentinelClient.php b/lib/3Dsecure/CentinelClient.php
index d37c0d70d427f14b920b7f1bd679a9aeb76ce861..c2f19380cbe2e4c34e2fe89ec120d068e97b351a 100644
--- a/lib/3Dsecure/CentinelClient.php
+++ b/lib/3Dsecure/CentinelClient.php
@@ -92,7 +92,7 @@
 				curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
 				curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,  2);
 				curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
-				curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
+				curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
 				curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
 
 				// Execute the request.
diff --git a/lib/Magento/App/Response/Http/FileFactory.php b/lib/Magento/App/Response/Http/FileFactory.php
index d7f720a7c24306755cb39525d3436cd721589ece..f48a1538713ccaeb9de06e4c8aaa50c76ec64fac 100644
--- a/lib/Magento/App/Response/Http/FileFactory.php
+++ b/lib/Magento/App/Response/Http/FileFactory.php
@@ -55,6 +55,7 @@ class FileFactory
      * @param string $fileName
      * @param string|array $content set to null to avoid starting output, $contentLength should be set explicitly in
      *                              that case
+     * @param string $baseDir
      * @param string $contentType
      * @param int $contentLength explicit content length, if strlen($content) isn't applicable
      * @throws \Exception
@@ -65,9 +66,14 @@ class FileFactory
      * @SuppressWarnings(PHPMD.NPathComplexity)
      * @SuppressWarnings(PHPMD.ExitExpression)
      */
-    public function create($fileName, $content, $contentType = 'application/octet-stream', $contentLength = null)
-    {
-        $dir = $this->_filesystem->getDirectoryWrite(\Magento\Filesystem::VAR_DIR);
+    public function create(
+        $fileName,
+        $content,
+        $baseDir = \Magento\Filesystem::ROOT,
+        $contentType = 'application/octet-stream',
+        $contentLength = null
+    ) {
+        $dir = $this->_filesystem->getDirectoryWrite($baseDir);
         $isFile = false;
         $file = null;
         if (is_array($content)) {
diff --git a/lib/Magento/Convert/Object.php b/lib/Magento/Convert/Object.php
index 5133fb7790668713fc117a11a90dd707ee4cbe30..488407282a75503ec5fbef13a0b8d91a672387e3 100644
--- a/lib/Magento/Convert/Object.php
+++ b/lib/Magento/Convert/Object.php
@@ -97,4 +97,74 @@ class Object
         return $result;
     }
 
+    /**
+     * Converts the list of objects into an array of the form: [ [ 'label' => <id>, 'value' => <value> ], ... ].
+     *
+     *
+     * The <id> and <value> values are taken from the objects in the list using the $idField and $valueField
+     * parameters, which can be either the name of the field to use, or a closure.
+     *
+     * @param array $items
+     * @param string|callable $idField
+     * @param string|callable $valueField
+     *
+     * @return array
+     */
+    public function toOptionArray(array $items, $idField, $valueField)
+    {
+        $options = [];
+        foreach ($items as $item) {
+            $options[] = ['value' => $this->_invokeGetter($item, $idField),
+                          'label' => $this->_invokeGetter($item, $valueField)];
+        }
+        return $options;
+    }
+
+    /**
+     * Converts the list of objects into an array of the form: [ <id> => <value>, ... ].
+     *
+     *
+     * The <id> and <value> values are taken from the objects in the list using the $idField and $valueField parameters,
+     * which can be either the name of the field to use, or a closure.
+     *
+     * @param array $items
+     * @param string|callable $idField
+     * @param string|callable $valueField
+     *
+     * @return array
+     */
+    public function toOptionHash(array $items, $idField, $valueField)
+    {
+        $options = [];
+        foreach ($items as $item) {
+            $options[$this->_invokeGetter($item, $idField)] = $this->_invokeGetter($item, $valueField);
+        }
+        return $options;
+    }
+
+    /**
+     * Returns the value of the property represented by $field on the $item object.
+     *
+     *
+     * When $field is a closure, the $item parameter is passed to the $field method, otherwise the $field is assumed
+     * to be a property name, and the associated get method is invoked on the $item instead.
+     *
+     * @param mixed $item
+     * @param string|callable $field
+     *
+     * @return mixed
+     */
+    protected function _invokeGetter($item, $field)
+    {
+        if (is_callable($field)) {
+            // if $field is a closure, use that on the item
+            return $field($item);
+        } else {
+            // otherwise, turn it into a call to the item's getter method
+            $methodName = 'get' . str_replace(' ', '', ucwords(str_replace('_', ' ', $field)));
+            return $item->$methodName();
+        }
+    }
+
+
 }
diff --git a/lib/Magento/HTTP/Adapter/Curl.php b/lib/Magento/HTTP/Adapter/Curl.php
index 01b622342b554e3cd0612db6b87bf075e2e93b88..d59754edd440831200334ce5abfc9f81dcc9ee44 100644
--- a/lib/Magento/HTTP/Adapter/Curl.php
+++ b/lib/Magento/HTTP/Adapter/Curl.php
@@ -85,10 +85,10 @@ class Curl implements \Zend_Http_Client_Adapter_Interface
             curl_setopt($this->_getResource(), $option, $value);
         }
 
-        $verifyPeer = isset($this->_config['verifypeer']) ? $this->_config['verifypeer'] : 0;
+        $verifyPeer = isset($this->_config['verifypeer']) ? $this->_config['verifypeer'] : true;
         curl_setopt($this->_getResource(), CURLOPT_SSL_VERIFYPEER, $verifyPeer);
 
-        $verifyHost = isset($this->_config['verifyhost']) ? $this->_config['verifyhost'] : 0;
+        $verifyHost = isset($this->_config['verifyhost']) ? $this->_config['verifyhost'] : 2;
         curl_setopt($this->_getResource(), CURLOPT_SSL_VERIFYHOST, $verifyHost);
 
         foreach ($this->_config as $param => $curlOption) {
diff --git a/lib/Magento/Image/Adapter/Gd2.php b/lib/Magento/Image/Adapter/Gd2.php
index a02472f3dc6f1f2de50f58ce7b7a26bff017ab4e..91d72e8b0c7b1d36843da28c4dd38e960d0122ad 100644
--- a/lib/Magento/Image/Adapter/Gd2.php
+++ b/lib/Magento/Image/Adapter/Gd2.php
@@ -60,15 +60,77 @@ class Gd2 extends \Magento\Image\Adapter\AbstractAdapter
      * Open image for processing
      *
      * @param string $filename
+     * @throws \OverflowException
      */
     public function open($filename)
     {
         $this->_fileName = $filename;
         $this->getMimeType();
         $this->_getFileAttributes();
+        if ($this->_isMemoryLimitReached()) {
+            throw new \OverflowException('Memory limit has been reached.');
+        }
         $this->_imageHandler = call_user_func($this->_getCallback('create'), $this->_fileName);
     }
 
+    /**
+     * Checks whether memory limit is reached.
+     *
+     * @return bool
+     */
+    protected function _isMemoryLimitReached()
+    {
+        $limit = $this->_convertToByte(ini_get('memory_limit'));
+        $requiredMemory = $this->_getImageNeedMemorySize($this->_fileName);
+        return (memory_get_usage(true) + $requiredMemory) > $limit;
+    }
+
+    /**
+     * Get image needed memory size
+     *
+     * @param string $file
+     * @return float|int
+     */
+    protected function _getImageNeedMemorySize($file)
+    {
+        $imageInfo = getimagesize($file);
+        if (!isset($imageInfo[0]) || !isset($imageInfo[1])) {
+            return 0;
+        }
+        if (!isset($imageInfo['channels'])) {
+            // if there is no info about this parameter lets set it for maximum
+            $imageInfo['channels'] = 4;
+        }
+        if (!isset($imageInfo['bits'])) {
+            // if there is no info about this parameter lets set it for maximum
+            $imageInfo['bits'] = 8;
+        }
+
+        return round(
+            ($imageInfo[0] * $imageInfo[1] * $imageInfo['bits'] * $imageInfo['channels'] / 8 + Pow(2, 16)) * 1.65
+        );
+    }
+
+    /**
+     * Converts memory value (e.g. 64M, 129KB) to bytes.
+     * Case insensitive value might be used.
+     *
+     * @param string $memoryValue
+     * @return int
+     */
+    protected function _convertToByte($memoryValue)
+    {
+        if (stripos($memoryValue, 'G') !== false) {
+            return (int)$memoryValue * pow(1024, 3);
+        } elseif (stripos($memoryValue, 'M') !== false) {
+            return (int)$memoryValue * 1024 * 1024;
+        } elseif (stripos($memoryValue, 'KB') !== false) {
+            return (int)$memoryValue * 1024;
+        }
+
+        return (int)$memoryValue;
+    }
+
     /**
      * Save image to specific path.
      * If some folders of path does not exist they will be created
@@ -96,9 +158,12 @@ class Gd2 extends \Magento\Image\Adapter\AbstractAdapter
                 imagecopy(
                     $newImage,
                     $this->_imageHandler,
-                    0, 0,
-                    0, 0,
-                    $this->_imageSrcWidth, $this->_imageSrcHeight
+                    0,
+                    0,
+                    0,
+                    0,
+                    $this->_imageSrcWidth,
+                    $this->_imageSrcHeight
                 );
                 $this->_imageHandler = $newImage;
             }
diff --git a/lib/Magento/Oauth/Helper/Request.php b/lib/Magento/Oauth/Helper/Request.php
index 46414b13e98a7d9a797da88ae5f7eb8411c1cfed..86bb41f6749a7713a4ccd27c11c03f9ee80816bd 100644
--- a/lib/Magento/Oauth/Helper/Request.php
+++ b/lib/Magento/Oauth/Helper/Request.php
@@ -280,4 +280,4 @@ class Request
         $response->setHttpResponseCode($responseCode);
         return array('oauth_problem' => $errorMsg);
     }
-}
\ No newline at end of file
+}
diff --git a/lib/Magento/Object/Copy.php b/lib/Magento/Object/Copy.php
index cdda521e19354ae4964190bcf53aaff02f4dd439..bd37410260e6b8740116dfc44fbe73c281916fb9 100644
--- a/lib/Magento/Object/Copy.php
+++ b/lib/Magento/Object/Copy.php
@@ -104,6 +104,42 @@ class Copy
         return $target;
     }
 
+    /**
+     * Get data from object|array to object|array containing fields
+     * from fieldset matching an aspect.
+     *
+     * @param string $fieldset
+     * @param string $aspect a field name
+     * @param array|\Magento\Object $source
+     * @param string $root
+     * @return array $data
+     */
+    public function getDataFromFieldset($fieldset, $aspect, $source, $root='global')
+    {
+        if (!(is_array($source) || $source instanceof \Magento\Object)) {
+            return null;
+        }
+        $fields = $this->_fieldsetConfig->getFieldset($fieldset, $root);
+        if (is_null($fields)) {
+            return null;
+        }
+
+        $data = array();
+        foreach ($fields as $code => $node) {
+            if (empty($node[$aspect])) {
+                continue;
+            }
+
+            $value = $this->_getFieldsetFieldValue($source, $code);
+
+            $targetCode = (string)$node[$aspect];
+            $targetCode = $targetCode == '*' ? $code : $targetCode;
+            $data[$targetCode] = $value;
+        }
+
+        return $data;
+    }
+
     /**
      * Check if source and target are valid input for converting using fieldset
      *
diff --git a/lib/Magento/Service/Entity/AbstractDto.php b/lib/Magento/Service/Entity/AbstractDto.php
new file mode 100644
index 0000000000000000000000000000000000000000..27e19a2fba85a44bfb5a92f2dcaffce146d23d32
--- /dev/null
+++ b/lib/Magento/Service/Entity/AbstractDto.php
@@ -0,0 +1,63 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Service\Entity;
+
+abstract class AbstractDto
+{
+    /**
+     * @var array
+     */
+    protected $_data;
+
+    /**
+     * Initialize internal storage
+     *
+     * @param array $data
+     */
+    public function __construct(array $data)
+    {
+        $this->_data = $data;
+    }
+
+    /**
+     * Retrieves a value from the data array if set, or null otherwise.
+     *
+     * @param string $key
+     * @return mixed|null
+     */
+    protected function _get($key)
+    {
+        return isset($this->_data[$key]) ? $this->_data[$key]: null;
+    }
+
+    /**
+     * Return DTO data in array format.
+     *
+     * @return \ArrayAccess
+     */
+    public function __toArray()
+    {
+        return $this->_data;
+    }
+}
diff --git a/lib/Magento/Service/Entity/AbstractDtoBuilder.php b/lib/Magento/Service/Entity/AbstractDtoBuilder.php
new file mode 100644
index 0000000000000000000000000000000000000000..4116091276708a999da66616817c8075ca178300
--- /dev/null
+++ b/lib/Magento/Service/Entity/AbstractDtoBuilder.php
@@ -0,0 +1,111 @@
+<?php
+/**
+ * Magento
+ *
+ * NOTICE OF LICENSE
+ *
+ * This source file is subject to the Open Software License (OSL 3.0)
+ * that is bundled with this package in the file LICENSE.txt.
+ * It is also available through the world-wide-web at this URL:
+ * http://opensource.org/licenses/osl-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.
+ *
+ * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
+ * @license     http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
+ */
+namespace Magento\Service\Entity;
+
+abstract class AbstractDtoBuilder
+{
+    /**
+     * @var array
+     */
+    protected $_data;
+
+    /**
+     * Initialize internal storage
+     */
+    public function __construct()
+    {
+        $this->_data = array();
+    }
+
+    /**
+     * Populates the fields with an existing entity.
+     *
+     * @param \Magento\Service\Entity\AbstractDto $prototype the prototype to base on
+     * @return $this
+     */
+    public function populate(\Magento\Service\Entity\AbstractDto $prototype)
+    {
+        $this->_data = array();
+        foreach (get_class_methods(get_class($prototype)) as $method) {
+            if (substr($method, 0, 3) === 'get') {
+                $originalDataName = lcfirst(substr($method, 3));
+                $dataName = strtolower(preg_replace('/([a-z])([A-Z])/', '$1_$2', $originalDataName));
+
+                if ($dataName === 'attribute' || $dataName === 'attributes') {
+                    continue;
+                } else {
+                    $value = $prototype->$method();
+                    if ($value !== null) {
+                        $this->_data[$dataName] = $prototype->$method();
+                    }
+                }
+            } elseif (substr($method, 0, 2) == 'is') {
+                $originalDataName = lcfirst(substr($method, 2));
+                $dataName = strtolower(preg_replace('/([a-z])([A-Z])/', '$1_$2', $originalDataName));
+
+                $this->_data[$dataName] = $prototype->$method();
+            }
+        }
+
+        return $this;
+    }
+
+    /**
+     * Populates the fields with data from the array.
+     *
+     * @param array $data
+     */
+    public function populateWithArray(array $data)
+    {
+        $this->_data = $data;
+
+        return $this;
+    }
+
+    /**
+     * Builds the entity.
+     *
+     * @return AbstractDto
+     */
+    public function create()
+    {
+        $dtoType = substr(get_class($this), 0, -7);
+        $retObj = new $dtoType($this->_data);
+        $this->_data = array();
+        return $retObj;
+    }
+
+    /**
+     * @param string $key
+     * @param mixed $value
+     *
+     * @return AbstractDto
+     */
+    protected function _set($key, $value)
+    {
+        $this->_data[$key] = $value;
+        return $this;
+    }
+
+}
diff --git a/lib/Magento/View/Element/AbstractBlock.php b/lib/Magento/View/Element/AbstractBlock.php
index ded193b6b700a939b145401a981ea2420790ea5c..e9c7d5c78081c3c48ed6c10d95722af8edc9a3ec 100644
--- a/lib/Magento/View/Element/AbstractBlock.php
+++ b/lib/Magento/View/Element/AbstractBlock.php
@@ -687,6 +687,7 @@ abstract class AbstractBlock extends \Magento\Object implements BlockInterface
     public function getViewFileUrl($file = null, array $params = array())
     {
         try {
+            $params = array_merge(['_secure' => $this->getRequest()->isSecure()], $params);
             return $this->_viewUrl->getViewFileUrl($file, $params);
         } catch (\Magento\Exception $e) {
 
diff --git a/lib/Magento/View/Element/Text/ListText.php b/lib/Magento/View/Element/Text/ListText.php
index ec156b6e88e40e441dfd3c32d0dc6fdeb08874a2..7b768abd51210669d125e4b2bd56989a9c530d30 100644
--- a/lib/Magento/View/Element/Text/ListText.php
+++ b/lib/Magento/View/Element/Text/ListText.php
@@ -42,7 +42,7 @@ class ListText extends \Magento\View\Element\Text
 
         $layout = $this->getLayout();
         foreach ($this->getChildNames() as $child) {
-            $this->addText($layout->renderElement($child));
+            $this->addText($layout->renderElement($child, false));
         }
 
         return parent::_toHtml();
diff --git a/pub/lib/dnd.js b/pub/lib/dnd.js
new file mode 100644
index 0000000000000000000000000000000000000000..1e1c5386cb0c8cc8d8c3bccf43d3caad95dc0401
--- /dev/null
+++ b/pub/lib/dnd.js
@@ -0,0 +1,664 @@
+// webkitdragdrop.js v1.0, Mon May 15 2010
+//
+// Copyright (c) 2010 Tommaso Buvoli (http://www.tommasobuvoli.com)
+// No Extra Libraries are required, simply download this file, add it to your pages!
+//
+// To See this library in action, grab an ipad and head over to http://www.gotproject.com
+// webkitdragdrop is freely distributable under the terms of an MIT-style license.
+
+
+//Description
+// Because this library was designed to run without requiring any other libraries, several basic helper functions were implemented
+// 6 helper functions in this webkit_tools class have been taked directly from Prototype 1.6.1 (http://prototypejs.org/) (c) 2005-2009 Sam Stephenson
+
+var webkit_tools =
+{
+    //$ function - simply a more robust getElementById
+
+    $:function(e)
+    {
+        if(typeof(e) == 'string')
+        {
+            return document.getElementById(e);
+        }
+        return e;
+    },
+
+    //extend function - copies the values of b into a (Shallow copy)
+
+    extend:function(a,b)
+    {
+        for (var key in b)
+        {
+            a[key] = b[key];
+        }
+        return a;
+    },
+
+    //empty function - used as defaut for events
+
+    empty:function()
+    {
+
+    },
+
+    //remove null values from an array
+
+    compact:function(a)
+    {
+        var b = []
+        var l = a.length;
+        for(var i = 0; i < l; i ++)
+        {
+            if(a[i] !== null)
+            {
+                b.push(a[i]);
+            }
+        }
+        return b;
+    },
+
+    //DESCRIPTION
+    //    This function was taken from the internet (http://robertnyman.com/2006/04/24/get-the-rendered-style-of-an-element/) and returns
+    //    the computed style of an element independently from the browser
+    //INPUT
+    //    oELM (DOM ELEMENT) element whose style should be extracted
+    //    strCssRule element
+
+    getCalculatedStyle:function(oElm, strCssRule)
+    {
+        var strValue = "";
+        if(document.defaultView && document.defaultView.getComputedStyle){
+            strValue = document.defaultView.getComputedStyle(oElm, "").getPropertyValue(strCssRule);
+        }
+        else if(oElm.currentStyle){
+            strCssRule = strCssRule.replace(/\-(\w)/g, function (strMatch, p1){
+                return p1.toUpperCase();
+            });
+            strValue = oElm.currentStyle[strCssRule];
+        }
+        return strValue;
+    },
+
+    //bindAsEventListener function - used to bind events
+
+    bindAsEventListener:function(f,object)
+    {
+        var __method = f;
+        return function(event) {
+            __method.call(object, event || window.event);
+        };
+    },
+
+    //cumulative offset - courtesy of Prototype (http://www.prototypejs.org)
+
+    cumulativeOffset:function(element)
+    {
+        var valueT = 0, valueL = 0;
+        do {
+          valueT += element.offsetTop  || 0;
+          valueL += element.offsetLeft || 0;
+          if (element.offsetParent == document.body)
+            if (element.style.position == 'absolute') break;
+
+          element = element.offsetParent;
+        } while (element);
+
+        return {left : valueL, top : valueT};
+      },
+
+      //getDimensions - courtesy of Prototype (http://www.prototypejs.org)
+
+    getDimensions: function(element)
+    {
+        var display = element.style.display;
+        if (display != 'none' && display != null) // Safari bug
+          return {width: element.offsetWidth, height: element.offsetHeight};
+
+        var els = element.style;
+        var originalVisibility = els.visibility;
+        var originalPosition = els.position;
+        var originalDisplay = els.display;
+        els.visibility = 'hidden';
+        if (originalPosition != 'fixed') // Switching fixed to absolute causes issues in Safari
+          els.position = 'absolute';
+        els.display = 'block';
+        var originalWidth = element.clientWidth;
+        var originalHeight = element.clientHeight;
+        els.display = originalDisplay;
+        els.position = originalPosition;
+        els.visibility = originalVisibility;
+        return {width: originalWidth, height: originalHeight};
+    },
+
+    //hasClassName - courtesy of Prototype (http://www.prototypejs.org)
+
+    hasClassName: function(element, className)
+    {
+        var elementClassName = element.className;
+        return (elementClassName.length > 0 && (elementClassName == className ||
+        new RegExp("(^|\\s)" + className + "(\\s|$)").test(elementClassName)));
+      },
+
+    //addClassName - courtesy of Prototype (http://www.prototypejs.org)
+
+    addClassName: function(element, className)
+    {
+        if (!this.hasClassName(element, className))
+            element.className += (element.className ? ' ' : '') + className;
+        return element;
+    },
+
+    //removeClassName - courtesy of Prototype (http://www.prototypejs.org)
+
+    removeClassName: function(element, className)
+    {
+        element.className = this.strip(element.className.replace(new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' '));
+        return element;
+    },
+
+    //strip - courtesy of Prototype (http://www.prototypejs.org)
+
+    strip:function(s)
+    {
+        return s.replace(/^\s+/, '').replace(/\s+$/, '');
+    }
+
+}
+
+//Description
+// Droppable fire events when a draggable is dropped on them
+
+var webkit_droppables = function()
+{
+    this.initialize = function()
+    {
+        this.droppables = [];
+        this.droppableRegions = [];
+    }
+
+    this.add = function(root, instance_props)
+    {
+        root = webkit_tools.$(root);
+        var default_props = {accept : [], hoverClass : null, onDrop : webkit_tools.empty, onOver : webkit_tools.empty, onOut : webkit_tools.empty};
+        default_props = webkit_tools.extend(default_props, instance_props || {});
+        this.droppables.push({r : root, p : default_props});
+    }
+
+    this.remove = function(root)
+    {
+        root = webkit_tools.$(root);
+        var d = this.droppables;
+        var i = d.length;
+        while(i--)
+        {
+            if(d[i].r == root)
+            {
+                d[i] = null;
+                this.droppables = webkit_tools.compact(d);
+                return true;
+            }
+        }
+        return false;
+    }
+
+    //calculate position and size of all droppables
+
+    this.prepare = function()
+    {
+        var d = this.droppables;
+        var i = d.length;
+        var dR = [];
+        var r = null;
+
+        while(i--)
+        {
+            r = d[i].r;
+            if(r.style.display != 'none')
+            {
+                dR.push({i : i, size : webkit_tools.getDimensions(r), offset : webkit_tools.cumulativeOffset(r)})
+            }
+        }
+
+        this.droppableRegions = dR;
+    }
+
+    this.finalize = function(x,y,r,e)
+    {
+        var indices = this.isOver(x,y);
+        var index = this.maxZIndex(indices);
+        var over = this.process(index,r);
+        if(over)
+        {
+            this.drop(index, r,e);
+        }
+        this.process(-1,r);
+        return over;
+    }
+
+    this.check = function(x,y,r,e)
+    {
+        var indices = this.isOver(x,y);
+        var index = this.maxZIndex(indices);
+        return this.process(index,r, e);
+    }
+
+    this.isOver = function(x, y)
+    {
+        var dR = this.droppableRegions;
+        var i = dR.length;
+        var active = [];
+        var r = 0;
+        var maxX = 0;
+        var minX = 0;
+        var maxY = 0;
+        var minY = 0;
+
+        while(i--)
+        {
+            r = dR[i];
+
+            minY = r.offset.top;
+            maxY = minY + r.size.height;
+
+            if((y > minY) && (y < maxY))
+            {
+                minX = r.offset.left;
+                maxX = minX + r.size.width;
+
+                if((x > minX) && (x < maxX))
+                {
+                    active.push(r.i);
+                }
+            }
+        }
+
+        return active;
+    }
+
+    this.maxZIndex = function(indices)
+    {
+        var d = this.droppables;
+        var l = indices.length;
+        var index = -1;
+
+        var maxZ = -100000000;
+        var curZ = 0;
+
+        while(l--)
+        {
+            curZ = parseInt(d[indices[l]].r.style.zIndex || 0);
+            if(curZ > maxZ)
+            {
+                maxZ = curZ;
+                index = indices[l];
+            }
+        }
+
+        return index;
+    }
+
+    this.process = function(index, draggableRoot, e)
+    {
+        //only perform update if a change has occurred
+        if(this.lastIndex != index)
+        {
+            //remove previous
+            if(this.lastIndex != null)
+            {
+                var d = this.droppables[this.lastIndex]
+                var p = d.p;
+                var r = d.r;
+
+                if(p.hoverClass)
+                {
+                    webkit_tools.removeClassName(r,p.hoverClass);
+                }
+                p.onOut(draggableRoot, e);
+                this.lastIndex = null;
+                this.lastOutput = false;
+            }
+
+            //add new
+            if(index != -1)
+            {
+                var d = this.droppables[index]
+                var p = d.p;
+                var r = d.r;
+
+                if(this.hasClassNames(draggableRoot, p.accept))
+                {
+                    if(p.hoverClass)
+                    {
+                        webkit_tools.addClassName(r,p.hoverClass);
+                    }
+                    p.onOver(draggableRoot, e);
+                    this.lastIndex = index;
+                    this.lastOutput = true;
+                }
+            }
+        }
+        return this.lastOutput;
+    }
+
+    this.drop = function(index, r, e)
+    {
+        if(index != -1)
+        {
+            this.droppables[index].p.onDrop(r,e);
+        }
+    }
+
+    this.hasClassNames = function(r, names)
+    {
+        var l = names.length;
+        if(l == 0){return true}
+        while(l--)
+        {
+            if(webkit_tools.hasClassName(r,names[l]))
+            {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    this.initialize();
+}
+
+webkit_drop = new webkit_droppables();
+
+//Description
+//webkit draggable - allows users to drag elements with their hands
+
+var webkit_draggable = function(r, ip)
+{
+    this.ready = false;
+    this.timeout = undefined;
+    this.initialize = function(root, instance_props)
+    {
+        this.root = webkit_tools.$(root);
+        var default_props = {scroll : false, revert : false, handle : this.root, zIndex : 1000, onStart : webkit_tools.empty, onEnd : webkit_tools.empty};
+
+        this.p = webkit_tools.extend(default_props, instance_props || {});
+        default_props.handle = webkit_tools.$(default_props.handle);
+        this.prepare();
+        this.bindEvents();
+    }
+
+    this.prepare = function()
+    {
+        var rs = this.root.style;
+
+        //set position
+        if(webkit_tools.getCalculatedStyle(this.root,'position') != 'absolute')
+        {
+            rs.position = 'relative';
+        }
+
+        //set top, right, bottom, left
+        rs.top = rs.top || '0px';
+        rs.left = rs.left || '0px';
+        rs.right = "";
+        rs.bottom = "";
+
+        //set zindex;
+        rs.zIndex = rs.zIndex || '0';
+    }
+
+    this.bindEvents = function()
+    {
+        var handle = this.p.handle;
+
+        this.ts = webkit_tools.bindAsEventListener(this.touchStart, this);
+        this.tm = webkit_tools.bindAsEventListener(this.touchMove, this);
+        this.te = webkit_tools.bindAsEventListener(this.touchEnd, this);
+
+        handle.addEventListener("touchstart", this.ts, false);
+        handle.addEventListener("touchmove", this.tm, false);
+        handle.addEventListener("touchend", this.te, false);
+    }
+
+    this.destroy = function()
+    {
+        var handle = this.p.handle;
+
+        handle.removeEventListener("touchstart", this.ts);
+        handle.removeEventListener("touchmove", this.tm);
+        handle.removeEventListener("touchend", this.te);
+    }
+
+    this.set = function(key, value)
+    {
+        this.p[key] = value;
+    }
+
+    this.touchStart = function(event)
+    {
+        this.timeout = setTimeout(function () {
+            //prepare needed variables
+            var p = this.p;
+            var r = this.root;
+            var rs = r.style;
+            var t = event.targetTouches[0];
+
+            //get position of touch
+            touchX = t.pageX;
+            touchY = t.pageY;
+
+            //set base values for position of root
+            rs.top = this.root.style.top || '0px';
+            rs.left = this.root.style.left || '0px';
+            rs.bottom = null;
+            rs.right = null;
+
+            var rootP = webkit_tools.cumulativeOffset(r);
+            var cp = this.getPosition();
+
+            //save event properties
+            p.rx = cp.x;
+            p.ry = cp.y;
+            p.tx = touchX;
+            p.ty = touchY;
+            p.z = parseInt(this.root.style.zIndex);
+
+            //boost zIndex
+            rs.zIndex = p.zIndex;
+            webkit_drop.prepare();
+            p.onStart(r, event);
+            
+            this.ready = true;
+            
+        }.bind(this), 500);
+    }
+
+    this.touchMove = function(event)
+    {
+        if ( this.ready ) {
+            event.preventDefault();
+            event.stopPropagation();
+
+            //prepare needed variables
+            var p = this.p;
+            var r = this.root;
+            var rs = r.style;
+            var t = event.targetTouches[0];
+            if(t == null){return}
+
+            var curX = t.pageX;
+            var curY = t.pageY;
+
+            var delX = curX - p.tx;
+            var delY = curY - p.ty;
+
+            rs.webkitTransform = 'translate3d(' + (p.rx + delX) + 'px,' + (p.ry + delY) + 'px, 1px)';
+
+            //scroll window
+            if(p.scroll)
+            {
+                s = this.getScroll(curX, curY);
+                if((s[0] != 0) || (s[1] != 0))
+                {
+                    window.scrollTo(window.scrollX + s[0], window.scrollY + s[1]);
+                }
+            }
+
+            //check droppables
+            webkit_drop.check(curX, curY, r, event);
+
+            //save position for touchEnd
+            this.lastCurX = curX;
+            this.lastCurY = curY;
+        }
+    }
+
+    this.touchEnd = function(event)
+    {
+        clearTimeout(this.timeout);
+        if ( this.ready ) {
+            event.preventSwipe = true;
+            var r = this.root;
+            var p = this.p;
+            var dropped = webkit_drop.finalize(this.lastCurX, this.lastCurY, r, event);
+
+            if(((p.revert) && (!dropped)) || (p.revert === 'always'))
+            {
+                //revert root
+                var rs = r.style;
+                rs.webkitTransform = 'translate3d(' + p.rx + 'px,' + p.ry + 'px, 1px)';
+                //rs.top = (p.ry + 'px');
+                //rs.left = (p.rx + 'px');
+            }
+
+            r.style.zIndex = this.p.z;
+            this.p.onEnd(r, event);
+            this.ready = false;
+        }
+    }
+
+    this.getPosition = function()
+    {
+        var rs = this.root.style;
+        return {x : parseInt(rs.left || 0), y : parseInt(rs.top  || 0)}
+    }
+
+    this.getScroll = function(pX, pY)
+    {
+        //read window variables
+        var sX = window.scrollX;
+        var sY = window.scrollY;
+
+        var wX = window.innerWidth;
+        var wY = window.innerHeight;
+
+        //set contants
+        var scroll_amount = 10; //how many pixels to scroll
+        var scroll_sensitivity = 100; //how many pixels from border to start scrolling from.
+
+        var delX = 0;
+        var delY = 0;
+
+        //process vertical y scroll
+        if(pY - sY < scroll_sensitivity)
+        {
+            delY = -scroll_amount;
+        }
+        else
+        if((sY + wY) - pY < scroll_sensitivity)
+        {
+            delY = scroll_amount;
+        }
+
+        //process horizontal x scroll
+        if(pX - sX < scroll_sensitivity)
+        {
+            delX = -scroll_amount;
+        }
+        else
+        if((sX + wX) - pX < scroll_sensitivity)
+        {
+            delX = scroll_amount;
+        }
+
+        return [delX, delY]
+    }
+
+    //contructor
+    this.initialize(r, ip);
+}
+
+//Description
+//webkit_click class. manages click events for draggables
+
+var webkit_click = function(r, ip)
+{
+    this.initialize = function(root, instance_props)
+    {
+        var default_props = {onClick : webkit_tools.empty};
+
+        this.root = webkit_tools.$(root);
+        this.p = webkit_tools.extend(default_props, instance_props || {});
+        this.bindEvents();
+    }
+
+    this.bindEvents = function()
+    {
+        var root = this.root;
+
+        //bind events to local scope
+        this.ts = webkit_tools.bindAsEventListener(this.touchStart,this);
+        this.tm = webkit_tools.bindAsEventListener(this.touchMove,this);
+        this.te = webkit_tools.bindAsEventListener(this.touchEnd,this);
+
+        //add Listeners
+        root.addEventListener("touchstart", this.ts, false);
+        root.addEventListener("touchmove", this.tm, false);
+        root.addEventListener("touchend", this.te, false);
+
+        this.bound = true;
+    }
+
+    this.touchStart = function()
+    {
+        this.moved = false;
+        if(this.bound == false)
+        {
+            this.root.addEventListener("touchmove", this.tm, false);
+            this.bound = true;
+        }
+    }
+
+    this.touchMove = function()
+    {
+        this.moved = true;
+        this.root.removeEventListener("touchmove", this.tm);
+        this.bound = false;
+    }
+
+    this.touchEnd = function()
+    {e.preventSwipe = true;
+        if(this.moved == false)
+        {
+            this.p.onClick();
+        }
+    }
+
+    this.setEvent = function(f)
+    {
+        if(typeof(f) == 'function')
+        {
+            this.p.onClick = f;
+        }
+    }
+
+    this.unbind = function()
+    {
+        var root = this.root;
+        root.removeEventListener("touchstart", this.ts);
+        root.removeEventListener("touchmove", this.tm);
+        root.removeEventListener("touchend", this.te);
+    }
+
+    //call constructor
+    this.initialize(r, ip);
+}
\ No newline at end of file
diff --git a/pub/lib/head.load.min.js b/pub/lib/headjs/head.load.min.js
similarity index 92%
rename from pub/lib/head.load.min.js
rename to pub/lib/headjs/head.load.min.js
index 05e489381844ab02656ac16fb5d48398cf226217..e384332d8f3db84068b405fb2dde545b43e54e1a 100644
--- a/pub/lib/head.load.min.js
+++ b/pub/lib/headjs/head.load.min.js
@@ -1 +1,9 @@
-(function(e,t){"use strict";function y(e){if(e._done)return;e(),e._done=1}function b(e){var t=e.split("/"),n=t[t.length-1],r=n.indexOf("?");return r!=-1?n.substring(0,r):n}function w(e){var t;if(typeof e=="object")for(var n in e)e[n]&&(t={name:n,url:e[n]});else t={name:b(e),url:e};var r=l[t.name];return r&&r.url===t.url?r:(l[t.name]=t,t)}function E(e,t){if(!e)return;typeof e=="object"&&(e=[].slice.call(e));for(var n=0;n<e.length;n++)t.call(e,e[n],n)}function S(e){return Object.prototype.toString.call(e)=="[object Function]"}function x(e){e=e||l;var t;for(var n in e){if(e.hasOwnProperty(n)&&e[n].state!=g)return!1;t=!0}return t}function T(e){e.state=d,E(e.onpreload,function(e){e.call()})}function N(e,n){e.state===t&&(e.state=v,e.onpreload=[],k({src:e.url,type:"cache"},function(){T(e)}))}function C(e,t){if(e.state==g)return t&&t();if(e.state==m)return p.ready(e.name,t);if(e.state==v)return e.onpreload.push(function(){C(e,t)});e.state=m,k(e.url,function(){e.state=g,t&&t(),E(f[e.name],function(e){y(e)}),x()&&o&&E(f.ALL,function(e){y(e)})})}function k(e,t){var r=n.createElement("script");r.type="text/"+(e.type||"javascript"),r.src=e.src||e,r.async=!1,r.onreadystatechange=r.onload=function(){var e=r.readyState;!t.done&&(!e||/loaded|complete/.test(e))&&(t.done=!0,t())},(n.body||i).appendChild(r)}function L(){o||(o=!0,E(u,function(e){y(e)}))}var n=e.document,r=e.navigator,i=n.documentElement,s,o,u=[],a=[],f={},l={},c=n.createElement("script").async===!0||"MozAppearance"in n.documentElement.style||e.opera,h=e.head_conf&&e.head_conf.head||"head",p=e[h]=e[h]||function(){p.ready.apply(null,arguments)},d=1,v=2,m=3,g=4;c?p.js=function(){var e=arguments,t=e[e.length-1],n={};return S(t)||(t=null),E(e,function(r,i){r!=t&&(r=w(r),n[r.name]=r,C(r,t&&i==e.length-2?function(){x(n)&&y(t)}:null))}),p}:p.js=function(){var e=arguments,t=[].slice.call(e,1),n=t[0];return s?(n?(E(t,function(e){S(e)||N(w(e))}),C(w(e[0]),S(n)?n:function(){p.js.apply(null,t)})):C(w(e[0])),p):(a.push(function(){p.js.apply(null,e)}),p)},p.ready=function(e,t){if(e==n)return o?y(t):u.push(t),p;S(e)&&(t=e,e="ALL");if(typeof e!="string"||!S(t))return p;var r=l[e];if(r&&r.state==g||e=="ALL"&&x()&&o)return y(t),p;var i=f[e];return i?i.push(t):i=f[e]=[t],p},p.ready(n,function(){x()&&E(f.ALL,function(e){y(e)}),p.feature&&p.feature("domloaded",!0)});if(e.addEventListener)n.addEventListener("DOMContentLoaded",L,!1),e.addEventListener("load",L,!1);else if(e.attachEvent){n.attachEvent("onreadystatechange",function(){n.readyState==="complete"&&L()});var A=1;try{A=e.frameElement}catch(O){}!A&&i.doScroll&&function(){try{i.doScroll("left"),L()}catch(e){setTimeout(arguments.callee,1);return}}(),e.attachEvent("onload",L)}!n.readyState&&n.addEventListener&&(n.readyState="loading",n.addEventListener("DOMContentLoaded",handler=function(){n.removeEventListener("DOMContentLoaded",handler,!1),n.readyState="complete"},!1)),setTimeout(function(){s=!0,E(a,function(e){e()})},300)})(window);
\ No newline at end of file
+/*!
+ * HeadJS     The only script in your <HEAD>
+ * Author     Tero Piirainen  (tipiirai)
+ * Maintainer Robert Hoffmann (itechnology)
+ * License    MIT / http://bit.ly/mit-license
+ *
+ * http://headjs.com
+ */
+(function(e,t){"use strict";function y(e){if(e._done)return;e(),e._done=1}function b(e){var t=e.split("/"),n=t[t.length-1],r=n.indexOf("?");return r!=-1?n.substring(0,r):n}function w(e){var t;if(typeof e=="object")for(var n in e)e[n]&&(t={name:n,url:e[n]});else t={name:b(e),url:e};var r=l[t.name];return r&&r.url===t.url?r:(l[t.name]=t,t)}function E(e,t){if(!e)return;typeof e=="object"&&(e=[].slice.call(e));for(var n=0;n<e.length;n++)t.call(e,e[n],n)}function S(e){return Object.prototype.toString.call(e)=="[object Function]"}function x(e){e=e||l;var t;for(var n in e){if(e.hasOwnProperty(n)&&e[n].state!=g)return!1;t=!0}return t}function T(e){e.state=d,E(e.onpreload,function(e){e.call()})}function N(e,n){e.state===t&&(e.state=v,e.onpreload=[],k({src:e.url,type:"cache"},function(){T(e)}))}function C(e,t){if(e.state==g)return t&&t();if(e.state==m)return p.ready(e.name,t);if(e.state==v)return e.onpreload.push(function(){C(e,t)});e.state=m,k(e.url,function(){e.state=g,t&&t(),E(f[e.name],function(e){y(e)}),x()&&o&&E(f.ALL,function(e){y(e)})})}function k(e,t){var r=n.createElement("script");r.type="text/"+(e.type||"javascript"),r.src=e.src||e,r.async=!1,r.onreadystatechange=r.onload=function(){var e=r.readyState;!t.done&&(!e||/loaded|complete/.test(e))&&(t.done=!0,t())},(n.body||i).appendChild(r)}function L(){o||(o=!0,E(u,function(e){y(e)}))}var n=e.document,r=e.navigator,i=n.documentElement,s,o,u=[],a=[],f={},l={},c=n.createElement("script").async===!0||"MozAppearance"in n.documentElement.style||e.opera,h=e.head_conf&&e.head_conf.head||"head",p=e[h]=e[h]||function(){p.ready.apply(null,arguments)},d=1,v=2,m=3,g=4;c?p.js=function(){var e=arguments,t=e[e.length-1],n={};return S(t)||(t=null),E(e,function(r,i){r!=t&&(r=w(r),n[r.name]=r,C(r,t&&i==e.length-2?function(){x(n)&&y(t)}:null))}),p}:p.js=function(){var e=arguments,t=[].slice.call(e,1),n=t[0];return s?(n?(E(t,function(e){S(e)||N(w(e))}),C(w(e[0]),S(n)?n:function(){p.js.apply(null,t)})):C(w(e[0])),p):(a.push(function(){p.js.apply(null,e)}),p)},p.ready=function(e,t){if(e==n)return o?y(t):u.push(t),p;S(e)&&(t=e,e="ALL");if(typeof e!="string"||!S(t))return p;var r=l[e];if(r&&r.state==g||e=="ALL"&&x()&&o)return y(t),p;var i=f[e];return i?i.push(t):i=f[e]=[t],p},p.ready(n,function(){x()&&E(f.ALL,function(e){y(e)}),p.feature&&p.feature("domloaded",!0)});if(e.addEventListener)n.addEventListener("DOMContentLoaded",L,!1),e.addEventListener("load",L,!1);else if(e.attachEvent){n.attachEvent("onreadystatechange",function(){n.readyState==="complete"&&L()});var A=1;try{A=e.frameElement}catch(O){}!A&&i.doScroll&&function(){try{i.doScroll("left"),L()}catch(e){setTimeout(arguments.callee,1);return}}(),e.attachEvent("onload",L)}!n.readyState&&n.addEventListener&&(n.readyState="loading",n.addEventListener("DOMContentLoaded",handler=function(){n.removeEventListener("DOMContentLoaded",handler,!1),n.readyState="complete"},!1)),setTimeout(function(){s=!0,E(a,function(e){e()})},300)})(window);
diff --git a/app/design/adminhtml/magento_backend/js/head.js b/pub/lib/headjs/head.min.js
similarity index 93%
rename from app/design/adminhtml/magento_backend/js/head.js
rename to pub/lib/headjs/head.min.js
index 67de77740949bcedf9cfcad1034ce8a90a2f5cd6..cb58a5cfb384faf5880c1f53ddb20b6fa37f6938 100644
--- a/app/design/adminhtml/magento_backend/js/head.js
+++ b/pub/lib/headjs/head.min.js
@@ -1,26 +1,11 @@
-/**
- * Magento
+/*!
+ * HeadJS     The only script in your <HEAD>
+ * Author     Tero Piirainen  (tipiirai)
+ * Maintainer Robert Hoffmann (itechnology)
+ * License    MIT / http://bit.ly/mit-license
  *
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
+ * http://headjs.com
  */
-
 (function (a, w) {
     function f(a) {
         p[p.length] = a
diff --git a/app/design/adminhtml/magento_backend/js/jquery.details.js b/pub/lib/jquery/jquery.details.js
similarity index 77%
rename from app/design/adminhtml/magento_backend/js/jquery.details.js
rename to pub/lib/jquery/jquery.details.js
index 1e2ddd923b73a857b3cb3f32fa83951ec79fffdc..30ce703386614f6d1494317cf0a5b5a1bf283fcc 100644
--- a/app/design/adminhtml/magento_backend/js/jquery.details.js
+++ b/pub/lib/jquery/jquery.details.js
@@ -1,51 +1,4 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
-
 /*! http://mths.be/details v0.0.6 by @mathias | includes http://mths.be/noselect v1.0.3 */
-Modernizr.addTest('details', function() {
-    var doc = document,
-        el = doc.createElement('details'),
-        fake,
-        root,
-        diff;
-    if (!('open' in el)) { // return early if possible; thanks @aFarkas!
-        return false;
-    }
-    root = doc.body || (function() {
-        var de = doc.documentElement;
-        fake = true;
-        return de.insertBefore(doc.createElement('body'), de.firstElementChild || de.firstChild);
-    }());
-    el.innerHTML = '<summary>a</summary>b';
-    el.style.display = 'block';
-    root.appendChild(el);
-    diff = el.offsetHeight;
-    el.open = true;
-    diff = diff != el.offsetHeight;
-    root.removeChild(el);
-    fake && root.parentNode.removeChild(root);
-    return diff;
-});
 ;(function(document, $) {
     var proto = $.fn,
         details,
@@ -167,4 +120,4 @@ Modernizr.addTest('details', function() {
 
     }
 
-}(document, jQuery));
\ No newline at end of file
+}(document, jQuery));
diff --git a/app/design/adminhtml/magento_backend/js/jquery.details.min.js b/pub/lib/jquery/jquery.details.min.js
similarity index 67%
rename from app/design/adminhtml/magento_backend/js/jquery.details.min.js
rename to pub/lib/jquery/jquery.details.min.js
index 2cb5037be2471aea12406ce00d119c4ea7bd840c..04317a021fbba47e8cdb0d0f555da84a50ac587e 100644
--- a/app/design/adminhtml/magento_backend/js/jquery.details.min.js
+++ b/pub/lib/jquery/jquery.details.min.js
@@ -1,25 +1,2 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
-
 /*! http://mths.be/details v0.0.6 by @mathias | includes http://mths.be/noselect v1.0.3 */
-;(function(a,$){var e=$.fn,d,c=Object.prototype.toString.call(window.opera)=='[object Opera]',f=(function(k){var i=k.createElement('details'),h,g,j;if(!('open' in i)){return false}g=k.body||(function(){var l=k.documentElement;h=true;return l.insertBefore(k.createElement('body'),l.firstElementChild||l.firstChild)}());i.innerHTML='<summary>a</summary>b';i.style.display='block';g.appendChild(i);j=i.offsetHeight;i.open=true;j=j!=i.offsetHeight;g.removeChild(i);if(h){g.parentNode.removeChild(g)}return j}(a)),b=function(h,k,j,g){var i=typeof h.attr('open')=='string',l=i&&g||!i&&!g;if(l){h.removeClass('open').prop('open',false).triggerHandler('close.details');k.attr('aria-expanded',false);j.hide()}else{h.addClass('open').prop('open',true).triggerHandler('open.details');k.attr('aria-expanded',true);j.show()}};e.noSelect=function(){var g='none';return this.bind('selectstart dragstart mousedown',function(){return false}).css({MozUserSelect:g,msUserSelect:g,webkitUserSelect:g,userSelect:g})};if(f){d=e.details=function(){return this.each(function(){var h=$(this),g=$('summary',h).first();g.attr({role:'button','aria-expanded':h.prop('open')}).on('click',function(){var i=h.prop('open');g.attr('aria-expanded',!i);h.triggerHandler((i?'close':'open')+'.details')})})};d.support=f}else{d=e.details=function(){return this.each(function(){var g=$(this),i=$('summary',g).first(),h=g.children(':not(summary)'),j=g.contents(':not(summary)');if(!i.length){i=$('<summary>').text('Details').prependTo(g)}if(h.length!=j.length){j.filter(function(){return this.nodeType==3&&/[^ \t\n\f\r]/.test(this.data)}).wrap('<span>');h=g.children(':not(summary)')}b(g,i,h);i.attr('role','button').noSelect().prop('tabIndex',0).on('click',function(){i.focus();b(g,i,h,true)}).keyup(function(k){if(32==k.keyCode||(13==k.keyCode&&!c)){k.preventDefault();i.click()}})})};d.support=f}}(document,jQuery));
\ No newline at end of file
+;(function(a,$){var e=$.fn,d,c=Object.prototype.toString.call(window.opera)=='[object Opera]',f=(function(k){var i=k.createElement('details'),h,g,j;if(!('open' in i)){return false}g=k.body||(function(){var l=k.documentElement;h=true;return l.insertBefore(k.createElement('body'),l.firstElementChild||l.firstChild)}());i.innerHTML='<summary>a</summary>b';i.style.display='block';g.appendChild(i);j=i.offsetHeight;i.open=true;j=j!=i.offsetHeight;g.removeChild(i);if(h){g.parentNode.removeChild(g)}return j}(a)),b=function(h,k,j,g){var i=typeof h.attr('open')=='string',l=i&&g||!i&&!g;if(l){h.removeClass('open').prop('open',false).triggerHandler('close.details');k.attr('aria-expanded',false);j.hide()}else{h.addClass('open').prop('open',true).triggerHandler('open.details');k.attr('aria-expanded',true);j.show()}};e.noSelect=function(){var g='none';return this.bind('selectstart dragstart mousedown',function(){return false}).css({MozUserSelect:g,msUserSelect:g,webkitUserSelect:g,userSelect:g})};if(f){d=e.details=function(){return this.each(function(){var h=$(this),g=$('summary',h).first();g.attr({role:'button','aria-expanded':h.prop('open')}).on('click',function(){var i=h.prop('open');g.attr('aria-expanded',!i);h.triggerHandler((i?'close':'open')+'.details')})})};d.support=f}else{d=e.details=function(){return this.each(function(){var g=$(this),i=$('summary',g).first(),h=g.children(':not(summary)'),j=g.contents(':not(summary)');if(!i.length){i=$('<summary>').text('Details').prependTo(g)}if(h.length!=j.length){j.filter(function(){return this.nodeType==3&&/[^ \t\n\f\r]/.test(this.data)}).wrap('<span>');h=g.children(':not(summary)')}b(g,i,h);i.attr('role','button').noSelect().prop('tabIndex',0).on('click',function(){i.focus();b(g,i,h,true)}).keyup(function(k){if(32==k.keyCode||(13==k.keyCode&&!c)){k.preventDefault();i.click()}})})};d.support=f}}(document,jQuery));
diff --git a/app/design/adminhtml/magento_backend/js/jquery.mousewheel.js b/pub/lib/jquery/jquery.mousewheel.js
similarity index 72%
rename from app/design/adminhtml/magento_backend/js/jquery.mousewheel.js
rename to pub/lib/jquery/jquery.mousewheel.js
index 5c3bfb61a70b16dee4c5ddfd96b5e880f8f10360..38b60951b201bedf3e1005ed49cbd1c0834d5815 100644
--- a/app/design/adminhtml/magento_backend/js/jquery.mousewheel.js
+++ b/pub/lib/jquery/jquery.mousewheel.js
@@ -1,26 +1,3 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
-
 /*! Copyright (c) 2011 Brandon Aaron (http://brandonaaron.net)
  * Licensed under the MIT License (LICENSE.txt).
  *
diff --git a/pub/lib/lib/dropdown.js b/pub/lib/lib/dropdown.js
deleted file mode 100644
index 13fff757a3f61ef961f4d14d50059c344a8bfc63..0000000000000000000000000000000000000000
--- a/pub/lib/lib/dropdown.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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    Mage
- * @package     js
- * @copyright   Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
-dropdown = function() {
-    var ele = document.getElementById("nav").getElementsByTagName("LI");
-    for (var i=0; i<ele.length; i++) {
-        ele[i].onmouseover=function() {
-            this.className+=" over";
-        }
-        ele[i].onmouseout=function() {
-            this.className=this.className.replace(new RegExp(" over\\b"), "");
-        }
-    }
-}
-if (window.attachEvent) window.attachEvent("onload", dropdown);
diff --git a/pub/lib/lib/flex.js b/pub/lib/mage/flex.js
similarity index 100%
rename from pub/lib/lib/flex.js
rename to pub/lib/mage/flex.js
diff --git a/app/design/frontend/magento_plushe/js/matchMedia.js b/pub/lib/matchMedia.js
similarity index 81%
rename from app/design/frontend/magento_plushe/js/matchMedia.js
rename to pub/lib/matchMedia.js
index 764dabd6c9a22ca6de2849180e9989498a2d413e..e91c2b97803c4387695437c00d81b82a821d0b4e 100644
--- a/app/design/frontend/magento_plushe/js/matchMedia.js
+++ b/pub/lib/matchMedia.js
@@ -1,25 +1,3 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
 /*! matchMedia() polyfill - Test a CSS media type/query in JS. Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas. Dual MIT/BSD license */
 
 window.matchMedia = window.matchMedia || (function( doc, undefined ) {
diff --git a/pub/lib/modernizr/modernizr.2.0.6.js b/pub/lib/modernizr/modernizr.2.0.6.js
new file mode 100644
index 0000000000000000000000000000000000000000..db230439e74ee5105a504c8b87c2d0bfd796b0be
--- /dev/null
+++ b/pub/lib/modernizr/modernizr.2.0.6.js
@@ -0,0 +1,4 @@
+/* Modernizr 2.0.6 (Custom Build) | MIT & BSD
+ * Build: http://www.modernizr.com/download/#-csstransforms-csstransforms3d-cssclasses-prefixed-teststyles-testprop-testallprops-prefixes-domprefixes
+ */
+;window.Modernizr=function(a,b,c){function C(a,b){var c=a.charAt(0).toUpperCase()+a.substr(1),d=(a+" "+o.join(c+" ")+c).split(" ");return B(d,b)}function B(a,b){for(var d in a)if(k[a[d]]!==c)return b=="pfx"?a[d]:!0;return!1}function A(a,b){return!!~(""+a).indexOf(b)}function z(a,b){return typeof a===b}function y(a,b){return x(n.join(a+";")+(b||""))}function x(a){k.cssText=a}var d="2.0.6",e={},f=!0,g=b.documentElement,h=b.head||b.getElementsByTagName("head")[0],i="modernizr",j=b.createElement(i),k=j.style,l,m=Object.prototype.toString,n=" -webkit- -moz- -o- -ms- -khtml- ".split(" "),o="Webkit Moz O ms Khtml".split(" "),p={},q={},r={},s=[],t=function(a,c,d,e){var f,h,j,k=b.createElement("div");if(parseInt(d,10))while(d--)j=b.createElement("div"),j.id=e?e[d]:i+(d+1),k.appendChild(j);f=["&shy;","<style>",a,"</style>"].join(""),k.id=i,k.innerHTML+=f,g.appendChild(k),h=c(k,a),k.parentNode.removeChild(k);return!!h},u,v={}.hasOwnProperty,w;!z(v,c)&&!z(v.call,c)?w=function(a,b){return v.call(a,b)}:w=function(a,b){return b in a&&z(a.constructor.prototype[b],c)};var D=function(a,c){var d=a.join(""),f=c.length;t(d,function(a,c){var d=b.styleSheets[b.styleSheets.length-1],g=d.cssRules&&d.cssRules[0]?d.cssRules[0].cssText:d.cssText||"",h=a.childNodes,i={};while(f--)i[h[f].id]=h[f];e.csstransforms3d=i.csstransforms3d.offsetLeft===9},f,c)}([,["@media (",n.join("transform-3d),("),i,")","{#csstransforms3d{left:9px;position:absolute}}"].join("")],[,"csstransforms3d"]);p.csstransforms=function(){return!!B(["transformProperty","WebkitTransform","MozTransform","OTransform","msTransform"])},p.csstransforms3d=function(){var a=!!B(["perspectiveProperty","WebkitPerspective","MozPerspective","OPerspective","msPerspective"]);a&&"webkitPerspective"in g.style&&(a=e.csstransforms3d);return a};for(var E in p)w(p,E)&&(u=E.toLowerCase(),e[u]=p[E](),s.push((e[u]?"":"no-")+u));x(""),j=l=null,e._version=d,e._prefixes=n,e._domPrefixes=o,e.testProp=function(a){return B([a])},e.testAllProps=C,e.testStyles=t,e.prefixed=function(a){return C(a,"pfx")},g.className=g.className.replace(/\bno-js\b/,"")+(f?" js "+s.join(" "):"");return e}(this,this.document);
\ No newline at end of file
diff --git a/pub/lib/modernizr/modernizr.details.js b/pub/lib/modernizr/modernizr.details.js
new file mode 100644
index 0000000000000000000000000000000000000000..48f1c9cfe0b26de26cc947780c046ff319a37b6d
--- /dev/null
+++ b/pub/lib/modernizr/modernizr.details.js
@@ -0,0 +1,25 @@
+// By @mathias, based on http://mths.be/axh
+Modernizr.addTest('details', function() {
+    var doc = document,
+        el = doc.createElement('details'),
+        fake,
+        root,
+        diff;
+    if (!('open' in el)) { // return early if possible; thanks @aFarkas!
+        return false;
+    }
+    root = doc.body || (function() {
+        var de = doc.documentElement;
+        fake = true;
+        return de.insertBefore(doc.createElement('body'), de.firstElementChild || de.firstChild);
+    }());
+    el.innerHTML = '<summary>a</summary>b';
+    el.style.display = 'block';
+    root.appendChild(el);
+    diff = el.offsetHeight;
+    el.open = true;
+    diff = diff != el.offsetHeight;
+    root.removeChild(el);
+    fake && root.parentNode.removeChild(root);
+    return diff;
+});
diff --git a/pub/lib/lib/modernizr.js b/pub/lib/modernizr/modernizr.js
similarity index 100%
rename from pub/lib/lib/modernizr.js
rename to pub/lib/modernizr/modernizr.js
diff --git a/pub/lib/prototype/validation.js b/pub/lib/prototype/validation.js
index 5ad144557f07ded184528d85af40bee502a86a8c..798194949ad5a55b62ba77435c130f755363792d 100644
--- a/pub/lib/prototype/validation.js
+++ b/pub/lib/prototype/validation.js
@@ -856,7 +856,7 @@ Validation.addAllThese([
          $(prefix + '_cc_issue').advaiceContainer
            = $(prefix + '_start_month').advaiceContainer
            = $(prefix + '_start_year').advaiceContainer
-           = $(prefix + '_cc_type_ss_div').down('ul li.adv-container');
+           = $(prefix + '_cc_type_ss_div').down('.adv-container');
 
          var ccIssue   =  $(prefix + '_cc_issue').value;
          var ccSMonth  =  $(prefix + '_start_month').value;
diff --git a/app/design/frontend/magento_plushe/js/selectivizr.js b/pub/lib/selectivizr.js
similarity index 95%
rename from app/design/frontend/magento_plushe/js/selectivizr.js
rename to pub/lib/selectivizr.js
index db735c5080d8c0f33ef3ae89c4fddde3720e6268..f7bd64295b5b82b889c3729adc3159437f46d19e 100644
--- a/app/design/frontend/magento_plushe/js/selectivizr.js
+++ b/pub/lib/selectivizr.js
@@ -1,25 +1,3 @@
-/**
- * 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.
- *
- * @copyright  Copyright (c) 2014 X.commerce, Inc. (http://www.magentocommerce.com)
- * @license    http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
- */
 /*
 selectivizr v1.0.2 - (c) Keith Clark, freely distributable under the terms 
 of the MIT license.
@@ -564,4 +542,4 @@ References:
 			addEvent(win,"load", init);
 		}
 	};
-})(this);
\ No newline at end of file
+})(this);