[
  {
    "path": ".dockerignore",
    "content": "db/data\ntarget/classes\ntarget/generated-sources\ntarget/generated-test-sources\ntarget/maven-archiver\ntarget/maven-status\ntarget/surefire\ntarget/test-classes"
  },
  {
    "path": ".gitignore",
    "content": "HELP.md\n/target/\n!.mvn/wrapper/maven-wrapper.jar\n\n### STS ###\n.apt_generated\n.classpath\n.factorypath\n.project\n.settings\n.springBeans\n.sts4-cache\n\n### IntelliJ IDEA ###\n.idea\n*.iws\n*.iml\n*.ipr\n\n### NetBeans ###\n/nbproject/private/\n/nbbuild/\n/dist/\n/nbdist/\n/.nb-gradle/\n/build/\n\n### Database ###\ndb/*\n\n#mac-os\n*.DS_Store\n"
  },
  {
    "path": "Dockerfile",
    "content": "# our base build image\nFROM maven:3.6.0-jdk-8 as maven\n\n# copy the project files\nCOPY ./pom.xml ./pom.xml\n\n# build all dependencies\nRUN mvn dependency:go-offline -B\n\n# copy your other files\nCOPY ./src ./src\n\n# build for release\nRUN mvn package -DskipTests\n\n# our final base image\nFROM openjdk:8-jre-alpine\n\n# set deployment directory\nWORKDIR /my-project\n\n# copy over the built artifact from the maven image\nCOPY --from=maven target/springboot-starterkit-mysql-1.0.jar ./\n\n# set the startup command to run your binary\nCMD [\"java\", \"-jar\", \"./springboot-starterkit-mysql-1.0.jar\"]\n"
  },
  {
    "path": "LICENSE",
    "content": "MIT License\n\nCopyright (c) 2020 Arpit Khandelwal\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n"
  },
  {
    "path": "docker-compose.yml",
    "content": "version: '3.5'\nservices:\n  mysql:\n    image: mysql:latest\n    restart: always\n    container_name: \"mysql\"\n    volumes:\n      - \"./db:/var/lib/mysql\"\n    ports:\n      - 3306:3306\n    environment:\n      - MYSQL_ROOT_PASSWORD=root\n      - MYSQL_DATABASE=brs\n      - MYSQL_USER=brs-user\n      - MYSQL_PASSWORD=changeit\n  web:\n    build: .\n    links:\n      - mysql\n    container_name: BRS-Service\n    restart: on-failure\n    ports:\n      - \"8080:8080\"\n    environment:\n      - DB_PORT=3306\n      - DB_NAME=brs\n      - DB_HOST=mysql\n      - MYSQL_USER=brs-user\n      - MYSQL_USER_PASSWORD=changeit\n      - SPRING_PROFILES_ACTIVE=prod\n    depends_on:\n      - mysql"
  },
  {
    "path": "pom.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project xmlns=\"http://maven.apache.org/POM/4.0.0\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n\txsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd\">\n\t<modelVersion>4.0.0</modelVersion>\n\t<parent>\n\t\t<groupId>org.springframework.boot</groupId>\n\t\t<artifactId>spring-boot-starter-parent</artifactId>\n\t\t<version>2.3.3.RELEASE</version>\n\t\t<relativePath/>\n\t</parent>\n\t<groupId>com.starterkit.springboot</groupId>\n\t<artifactId>springboot-starterkit-mysql</artifactId>\n\t<version>1.0</version>\n\t<name>springboot-starterkit-mysql</name>\n\t<packaging>jar</packaging>\n\t<description>Demo project for Spring Boot with MySQL DB</description>\n\n\t<properties>\n\t\t<java.version>1.8</java.version>\n\t\t<downloadSources>true</downloadSources>\n\t\t<downloadJavadocs>true</downloadJavadocs>\n\t</properties>\n\n\t<repositories>\n\t\t<repository>\n\t\t\t<id>jcenter-snapshots</id>\n\t\t\t<name>jcenter</name>\n\t\t\t<url>https://jcenter.bintray.com/</url>\n\t\t</repository>\n\t</repositories>\n\n\t<dependencies>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-web</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-security</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-data-jpa</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-thymeleaf</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>nz.net.ultraq.thymeleaf</groupId>\n\t\t\t<artifactId>thymeleaf-layout-dialect</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-actuator</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.data</groupId>\n\t\t\t<artifactId>spring-data-rest-hal-browser</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>io.jsonwebtoken</groupId>\n\t\t\t<artifactId>jjwt</artifactId>\n\t\t\t<version>0.9.1</version>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-devtools</artifactId>\n\t\t\t<scope>runtime</scope>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>mysql</groupId>\n\t\t\t<artifactId>mysql-connector-java</artifactId>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.projectlombok</groupId>\n\t\t\t<artifactId>lombok</artifactId>\n\t\t\t<optional>true</optional>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.modelmapper</groupId>\n\t\t\t<artifactId>modelmapper</artifactId>\n\t\t\t<version>2.3.2</version>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>javax.persistence</groupId>\n\t\t\t<artifactId>persistence-api</artifactId>\n\t\t\t<version>1.0.2</version>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>io.springfox</groupId>\n\t\t\t<artifactId>springfox-boot-starter</artifactId>\n\t\t\t<version>3.0.0</version>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t<artifactId>spring-boot-starter-test</artifactId>\n\t\t\t<scope>test</scope>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>org.springframework.security</groupId>\n\t\t\t<artifactId>spring-security-test</artifactId>\n\t\t\t<scope>test</scope>\n\t\t</dependency>\n\t\t<dependency>\n\t\t\t<groupId>javax.validation</groupId>\n\t\t\t<artifactId>validation-api</artifactId>\n\t\t</dependency>\n\t</dependencies>\n\n\t<profiles>\n\t\t<profile>\n\t\t\t<id>UAT</id>\n\t\t\t<properties>\n\t\t\t\t<activatedProperties>UAT</activatedProperties>\n\t\t\t</properties>\n\t\t</profile>\n\t\t<profile>\n\t\t\t<id>PROD</id>\n\t\t\t<properties>\n\t\t\t\t<activatedProperties>PROD</activatedProperties>\n\t\t\t</properties>\n\t\t</profile>\n\t</profiles>\n\n\t<build>\n\t\t<plugins>\n\t\t\t<plugin>\n\t\t\t\t<groupId>org.springframework.boot</groupId>\n\t\t\t\t<artifactId>spring-boot-maven-plugin</artifactId>\n\t\t\t</plugin>\n\t\t</plugins>\n\t</build>\n\n</project>\n"
  },
  {
    "path": "readme.md",
    "content": "<h1 align=\"center\">\n  <br>\n  <a><img src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/spring-framework.png\" alt=\"spring boot\"></a>\n  <br>\n  Spring Boot Starter-kit\n  <br>\n</h1>\n\n<h4 align=\"center\">Production ready starter-kit for Spring Boot applications with MySQL database.</h4>\n\n<p align=\"center\">\n    <a alt=\"Java\">\n        <img src=\"https://img.shields.io/badge/Java-v1.8-orange.svg\" />\n    </a>\n    <a alt=\"Spring Boot\">\n        <img src=\"https://img.shields.io/badge/Spring%20Boot-v2.3.3-brightgreen.svg\" />\n    </a>\n    <a alt=\"Bootstrap\">\n        <img src=\"https://img.shields.io/badge/Bootstrap-v4.0.0-yellowgreen.svg\">\n    </a>\n    <a alt=\"Material\">\n        <img src=\"https://img.shields.io/badge/Material%20Design-UI-orange.svg\">  \n    </a>      \n    <a alt=\"Docker\">\n        <img src=\"https://img.shields.io/badge/Docker-v19-yellowgreen.svg\" />\n    </a>\n    <a alt=\"Dependencies\">\n        <img src=\"https://img.shields.io/badge/dependencies-up%20to%20date-brightgreen.svg\" />\n    </a>\n    <a alt=\"Contributions\">\n        <img src=\"https://img.shields.io/badge/contributions-welcome-orange.svg\" />\n    </a>\n    <a alt=\"License\">\n        <img src=\"https://img.shields.io/badge/license-MIT-blue.svg\" />\n    </a>\n</p>\n\n## Table of Contents ##\n1. [Philosophy](#Philosophy)\n2. [Medium Articles](#Medium-Articles)\n3. [Spring Boot](#Spring-Boot)\n4. [Application](#Application)\n5. [Database Schema](#Database-Schema)\n6. [Technology](#Technology)\n7. [Application Structure](#Application-Structure)\n8. [Run Locally](#Running-the-server-locally)\n9. [Run Insider Docker](#Running-the-server-in-Docker-Container)\n10. [API Documentation](#API-Documentation)\n11. [User Interface](#User-Interface)\n12. [Contributor](#Contributor)\n13. [License](#License)\n\n## Philosophy ##\nA lot of work has gone into Spring Boot to reduce complexity and dependencies, which largely alleviates our previous reservations. If you live in a Spring ecosystem and are moving to microservices, Spring Boot is now the obvious choice. Spring Boot allows easy set up of standalone Spring-based applications. It's ideal for pulling up new microservices and easy to deploy. It also makes data access less of a pain due to the hibernate mappings with much less boilerplate code. You can get started with minimum fuss due to it taking an opinionated view of the Spring platform and third-party libraries. Most Spring Boot applications need very little Spring configuration. \n\nThe greatest thing about Spring Boot is the ability to be up and running in very little time. You don’t have to install a web server like JBoss, Websphere, or even Tomcat for that matter. All you need to do is pull in the proper libraries, annotate, and fire away. If you are going to do a lot of Spring Boot projects, I would highly suggest using the IntelliJ IDEA IDE. It has some great features for making Boot projects really easy to manage. You can of course choose between Maven or Gradle to manage dependencies and builds. This starter kit is based on Maven as it is what I am familiar and slightly more comfortable with. \n\n## Medium Articles ##\nReaders can find more information about this starter-kit on my medium publication [The Resonant Web](https://medium.com/the-resonant-web). I have written a series of two articles on Spring Boot v2, here are the links:\n\n[Part-1](https://medium.com/the-resonant-web/spring-boot-2-0-starter-kit-part-1-23ddff0c7da2)  \n[Part-2](https://medium.com/the-resonant-web/spring-boot-2-0-project-structure-and-best-practices-part-2-7137bdcba7d3)\n\nThere is also a NoSQL version of this starter kit which is built with MongoDB as the database. The location of GitHub repository for the same is [here](https://github.com/khandelwal-arpit/springboot-starterkit).\n\n## Spring Boot ##\n_Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can just run. We take an opinionated view of the Spring platform and third-party libraries so you can get started with minimum fuss. Most Spring Boot applications need very little Spring configuration._\n\n**Spring Boot is opinionated** : This simply means that Spring Boot has its own configurations, application structures, dependencies, Servers and other environment configuration available inside its realm. Thus, to say Spring Boot has its own opinions about an application development environment. For example, most of the Java-based web applications use tomcat server. While working on Spring Boot you need not use any server, because Spring Boot already has an embedded tomcat container.\n\n**Spring Boot is stand-alone** : What it means is that you don’t need to use any other third-party library or server to run or develop a spring boot application, it already has all of it.\n\n**It is production-grade** : This implies that application developed using Spring Boot defaults is able to handle all complexities and requirements of a production environment.\n\n**Still very customizable** : It is not worth using a framework which has its own rigid opinions, which you can’t customize or change according to your own business requirements. Although Spring Boot is opinionated you can easily change or customize its defaults to suit your own needs. \n\n## Application ##\nThis starter kit focuses on how to use Spring Boot following all the best practices that are recommended by Spring Framework 5.0, ensure the code is loosely coupled and that all the layers in the application are completely independent of each other and talk using neutral objects. While writing this kit, I have done sufficient research around the code structure and usage of appropriate design patterns to make this as an excellent starting point to begin coding your own web application.\n\nThe kit would have been incomplete if it did not have a concrete use case to implement, here I have taken a case study of a _Bus Reservation System_ and tried to implement an Admin portal which can be operated over browsers and a series of REST APIs to interact with the system using mobile applications or frontend applications written for the browsers. The complete systems has two important actors :\n\n1. Admin user\n2. End user\n\nThe _Admin user_ can access this application on browser (laptop or mobile/tablet, doesn't really matter as this is built using bootstrap, material design and is completely responsive) and can perform the following actions :\n\n1. Signup\n2. Login\n3. Update their profile\n4. Create an agency\n5. Add buses to the agency\n6. Add trips consisting of predefined stops and buses\n \nThe _End user_ can use their mobile application (yet to be built, however the REST APIs are ready and could be used via Postman or Swagger) to perform the following actions :\n\n1. Signup\n2. Login (and get a JWT token) \n3. List all available stops\n4. Search a trip between any two stops\n5. Filter search results with a date option\n6. Book a ticket for a given trip schedule\n\nAdmin interface and REST APIs both have their independent authentication mechanisms, the web application uses the cookie based authentication (provided by default by Spring security) and the REST API uses the JWT authentication for access. This application assumes the availability of 'MySQL' installation on the localhost where the server will run or the use of docker-compose to boot up a mysql container and link the application with it within the realm of docker.\n\nAny changes that the admin users will do on the web portal will impact the search results of the end users, there will be certain use cases which you may find missing here, I hope you will appreciate that the overall idea was to present a way to create such an application completely inside the realm of Spring Boot and not to actually building a fully functional reservation system.\n\nThe admin user interface is completely written in material design using Bootstrap v4 and is responsive to suite a variety of devices. The template engine used to render the admin views is Thymeleaf since the library is extremely extensible and its natural templating capability ensures templates can be prototyped without a back-end – which makes development very fast when compared with other popular template engines such as JSP.\n\n## Database Schema ##\nThe current schema looks as follows:\n\n<img src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/db-schema.png\" alt=\"spring boot\"></a>\n\n- The authentication and authorization is governed by _User_ and _Role_ entities.\n- The _Agency_ entity keeps the details of agency along with who owns it.\n- The _Stop_ entity keeps the data about all the stops in the system.\n- The _Bus_ entity has the data of all the buses for various agencies along with their capacity and make years.\n- The _Trip_ and _TripSchedule_ entities keep the information about all the trips that agency owners create within the system. Information like source and destination stops, journey time, data of travel, tickets sold so far and the available seats is collected in them.\n- Last, the _Ticket_ entity keeps information about all the tickets issued in the application for various trips.\n  \n## Technology ##\nFollowing libraries were used during the development of this starter kit :\n\n- **Spring Boot** - Server side framework\n- **Docker** - Containerizing framework\n- **MySQL** - Database \n- **Swagger** - API documentation\n- **Thymeleaf** - Templating engine\n- **Material** - UI theming/design\n- **Bootstrap** - CSS framework\n- **JWT** - Authentication mechanism for REST APIs\n\n\n## Application Structure ##\nSpring Boot is an opinionated framework that makes our life very easy since we don't have to choose the versions of different dependencies based on the version of Spring framework, its all taken care of by Spring Boot. I have tried to follow the same ideology while creating the project structure, at first it might seem like overwhelming, but do believe me once you start writing your pieces the structure will help you immensely by saving your time and thinking about questions which are already answered. The structure look as follows :\n\n<img src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/project-structure.png\" alt=\"project structure\"></a>\n\n**_Models & DTOs_**\n\nThe various models of the application are organized under the **_model_** package, their DTOs(data transfer objects) are present under the **_dto_** package. There are different opinions about whether we should use DTOs or not, I belong to the set of minds who think we definitely should and not using DTOs makes your model layer very tightly coupled with the UI layer and that is something that no enterprise project should ever get into. DTOs let us transfer only the data that we need to share with the user interface and not the entire model object that we may have aggregated using several sub-objects and persisted in the database. The mapping of models to the DTOs can be handled using ModelMapper utility, however its only useful when your DTO is almost similar (literally) to the concerned models which is not always the case and hence I prefer using custom mapper classes. You can find some examples under the dto/mapper package.\n\n**_DAOs_**\n\nThe data access objects (DAOs) are present in the **_repository_** package. They are all extensions of the CrudRepository Interface helping the service layer to persist and retrieve the data from MySQL. The service layer is defined under the **_service_** package, considering the current case study it made sense to create two basic services - UserService and BusReservationService to satisfy the different business operations that the users are executing using the UI.\n\n**_Security_**\n\nThe security setting are present under the **_config_** package and the actual configurations are done under the class present in the **_security_** package. The application has different security concepts for the admin portal and the REST APIs, for the portal I have applied the default spring session mechanism that is based on the concept of sessionID and cookies. For the REST APIs I have used JWT token based authentication mechanism.\n\n**_Controllers_**\n\nLast, but the most important part is the controller layer. It binds everything together right from the moment a request is intercepted till the response is prepared and sent back. The controller layer is present in the **_controller_** package, the best practices suggest that we keep this layer versioned to support multiple versions of the application and the same practice is applied here. For now code is only present under v1 but over the time I expect to have different versions having different features. The Admin portal related controllers are present in the **_ui_** package and it's concerning form command objects are located under the **_command_** package. The REST API controllers are located under the **_api_** package and the corresponding request classes are located under the **_request_** package. \n\n**_Request and Form Commands_**\n\nAgain, there are different opinions amongst the fraternity regarding the usage of separate classes for mapping the incoming request vs using the DTOs, I am personally a fan of segregating the two as far as possible to promote loose coupling amongst the UI and controller layer. The request objects and the form commands do give us a way to apply an additional level of validations on the incoming requests before they get converted to the DTOs which transfer valid information to the service layer for persistence and data retrieval. We could use DTOs here and some developers prefer that approach as it reduces some additional classes, however I usually prefer to keep the validation logic separate from the transfer objects and hence am inclined to use the request/command objects ahead of them.\n\nThe static resources are grouped under the **_resources_** directory. All the UI objects and their styling aspects can be located here.\n\n## Response and Exception Handling ##\nI have tried to experiment a bit with the RuntimeExceptions and come up with a mini framework for handling the entire application's exceptions using a few classes and the properties file. If you carefully observe the **_exception_** package, it consists of two enums - EntityType and ExceptionType. The EntityType enum contains all the entity names that we are using in the system for persistence and those which can result in a run time exception. The ExceptionType enum consists of the different entity level exceptions such as the EntityNotFound and DuplicateEntity exceptions. \n\nThe BRSException class has two static classes _EntityNotFoundException_ and _DuplicateEntityException_ which are the two most widely thrown exceptions from the service layer. It also contains a set of overloaded methods _throwException_ which take the EntityType, ExceptionType and arguments to come up with a formatted message whose template is present under the **_custom.properties_** file. Using this class I was able to empower the entire services layer to throw entity exceptions in a uniform manner without cluttering the code base with all sorts of NOT_FOUND and DUPLICATE entity exceptions.\n\nFor example, while login if you try to use a email address which is not registered, an exception is raised and thrown using the following single line of code -\n\n``` java\nthrow exception(USER, ENTITY_NOT_FOUND, userDto.getEmail());\n```\n\nThis results in clubbing the names of these two enums USER(user) and ENTITY_NOT_FOUND(not.found) and coming up with a key _user.not.found_ which is present in the custom.properties files as follows :\n\n``` \nuser.not.found=Requested user with email - {0} does not exist.\n```\nBy simply replacing the {0} param with the email address included in the thrown exception you can get a well formatted message to be shown to the user or to be sent back as the response of the REST API call.\n\nAnother important part of this mini framework is the **_CustomizedResponseEntityExceptionHandler_** class. This class takes care of these RuntimeExceptions before sending a response to the API requests. Its a controller advice that checks if a service layer invocation resulted in a EntityNotFoundException or a DuplicateEntityException and sends an appropriate response to the caller.\n\nLast, the API response are all being sent in a uniform manner using the **_Response_** class present in the dto/response package. This class allows us to create uniform objects which result in a response as shown below (this one is a response for the \"api/v1/reservation/stops\" api) :\n\n```\n{\n    \"status\": \"OK\",\n    \"payload\": [\n        {\n            \"code\": \"STPA\",\n            \"name\": \"Stop A\",\n            \"detail\": \"Near hills\"\n        },\n        {\n            \"code\": \"STPB\",\n            \"name\": \"Stop B\",\n            \"detail\": \"Near river\"\n        }\n    ]\n}\n```\n\nAnd when there is an exception (for example searching for a trip between two stops which are not linked by any bus) the following responses are sent back (result of \"api/v1/reservation/tripsbystops\" GET request) :\n\n```\n{\n    \"status\": \"NOT_FOUND\",\n    \"errors\": \"No trips between source stop - 'STPD' and destination stop - 'STPC' are available at this time.\"\n}\n```\n\n```\n{\n    \"status\": \"NOT_FOUND\",\n    \"errors\": {\n        \"timestamp\": \"2019-03-13T07:47:10.990+0000\",\n        \"message\": \"Requested stop with code - STPF does not exist.\",\n        \"details\": \"Requested stop with code - STPF does not exist.\"\n    }\n}\n```\n\nAs you can observe, both type of responses, one with a HTTP-200 and another with HTTP-404 the response payload doesn't change its structure and the calling framework can blindly accept the response knowing that there is a status and a error or payload field in the JSON object.\n\n## UI Architecture ##\nThe user interface for the admin portal is designed using material design with the help of Bootstrap and responsive web app concept. The UI is server side rendered using Thymeleaf templates (preferred templating engine in Spring). The standard way of working with Thymeleaf is to use includes. This quite often leads to repetitive code, especially, when a website has many pages and each page has several reusable components (e.g. header, navigation, sidebar, and footer). It is repetitive as each content page has to include the same fragments at the same locations. This also has a negative effect when the page layout changes, e.g. when putting the sidebar from the left to the right side.\n\nThe decorator pattern used by the Thymeleaf Layout dialect solves these issues. In the context of template engines, the decorator pattern doesn't work with includes on content pages anymore, but it refers to a common template file. Each page basically only provides the main content and by describing which basic template to use the template engine can build the final page. The content is being decorated with the template file.This approach has advantages compared to the standard way of including fragments:\n\n- The page itself only has to provide the content\n- As a template file is being used to build the final page global changes can be applied easily\n- The code becomes shorter and cleaner\n- As each content page references which template file to use, it is easy to use different templates for different areas of the application (e.g. public area and admin area)\n\nThe layout for admin portal is arranged as follows :\n\n<p align=\"center\">\n<img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/ui-layout.png\">\n</p>\n\nThe individual areas in this layout serve the following purpose :\n\n- **Header**: this fragment is used for the static imports (CSS and JavaScript), the title and meta tags\n- **Navigation**: the navigation bar\n- **Content**: the content placeholder that will be replaced by the requested page\n- **Sidebar**: a sidebar for additional information\n- **Footer**: the footer area that provides the copyright info\n\nThese components can be located in the resources/templates directory at the root as well as under the sub-directories fragments and layout. The content area in this layout will host the following pages :\n\n- Dashboard\n- Agency\n- Bus\n- Trip\n- Profile\n\nAlso, an error page for any unhandled exception is designed with the name \"error.html\". The login and signup pages are designed separately from the portal accessible to a logged-in user.\n\n## Running the server locally ##\nTo be able to run this Spring Boot app you will need to first build it. To build and package a Spring Boot app into a single executable Jar file with a Maven, use the below command. You will need to run it from the project folder which contains the pom.xml file.\n\n```\nmaven package\n```\nor you can also use\n\n```\nmvn install\n```\n\nTo run the Spring Boot app from a command line in a Terminal window you can you the java -jar command. This is provided your Spring Boot app was packaged as an executable jar file.\n\n```\njava -jar target/springboot-starterkit-mysql-1.0.jar\n```\n\nYou can also use Maven plugin to run the app. Use the below example to run your Spring Boot app with Maven plugin :\n\n```\nmvn spring-boot:run\n```\n\nIf you do not have a mysql instance running and still just want to create the JAR, then please use the following command:\n\n```\nmvn install -DskipTests\n```\n\nThis will skip the test cases and won't check the availability of a mysql instance and allow you to create the JAR.\n\nYou can follow any/all the above commands, or simply use the run configuration provided by your favorite IDE and run/debug the app from there for development purposes. Once the server is setup you should be able to access the admin interface at the following URL :\n\nhttp://localhost:8080\n\nAnd the REST APIs can be accessed over the following base-path :\n\nhttp://localhost:8080/api/\n\nSome of the important api endpoints are as follows :\n\n- http://localhost:8080/api/v1/user/signup (HTTP:POST)\n- http://localhost:8080/api/auth (HTTP:POST)\n- http://localhost:8080/api/v1/reservation/stops (HTTP:GET)\n- http://localhost:8080/api/v1/reservation/tripsbystops (HTTP:GET)\n- http://localhost:8080/api/v1/reservation/tripschedules (HTTP:GET)\n- http://localhost:8080/api/v1/reservation/bookticket (HTTP:POST)\n\n## Running the server in Docker Container ##\n##### Docker #####\nCommand to build the container :\n\n```\ndocker build -t spring/starterkit .\n```\n\nCommand to run the container :\n\n```\ndocker run -p 8080:8080 spring/starterkit\n```\n\nPlease **note** when you build the container image and if mysql is running locally on your system, you will need to provide your system's IP address (or cloud hosted database's IP) in the application.properties file to be able to connect to the database from within the container.\n\n##### Docker Compose #####\nAnother alternative to run the application is to use the docker-compose.yml file and utility. To build the application using docker-compose simply execute the following command :\n```\ndocker-compose build\n```\n\nAnd to run the application, please execute the following command :\n```\ndocker-compose up\n```\n\n## API Documentation ##\nIts as important to document(as is the development) and make your APIs available in a readable manner for frontend teams or external consumers. The tool for API documentation used in this starter kit is Swagger3, you can open the same inside a browser at the following url -\n\nhttp://localhost:8080/swagger-ui/index.html\n\nIt will present you with a well structured UI which has two specs :\n\n1. User\n2. BRS\n\nYou can use the User spec to execute the login api for generating the Bearer token. The token then should be applied in the \"Authorize\" popup which will by default apply it to all secured apis (get and post both).\n\n<p align=\"center\">\n    <b>User Spec</b><br>\n    <br>\n    <img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/swagger-screens/swagger-1.png\">\n</p>\n\n<p align=\"center\">\n    <b>User Login</b><br>\n    <br>\n    <img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/swagger-screens/swagger-2.png\">\n</p>\n\n<p align=\"center\">\n    <b>Authorization</b><br>\n    <br>\n    <img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/swagger-screens/swagger-3.png\">\n</p>\n\n<p align=\"center\">\n    <b>BRS Spec</b><br>\n    <br>\n    <img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/swagger-screens/swagger-4.png\">\n</p>\n\n<p align=\"center\">\n    <b>BRS APIs</b><br>\n    <br>\n    <img width=\"600\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/swagger-screens/swagger-5.png\">\n</p>\n\nThe configuration of Swagger is being taken care of by class BrsConfiguration. I have defined two specs there with the help of \"swaggerBRSApi\" and \"swaggerUserApi\" methods. Since the login part is by default taken care of by Spring Security we don't get to expose its apis implicitly as the rest of the apis defined in the system and for the same reason I have defined a controller in the config package with the name \"FakeController\". Its purpose is to facilitate the generation of swagger documentation for login and logout apis, it will never come into existence during the application life cycle as the \"/api/auth\" api is being handled by the security filters defined in the code base. \n\n## User Interface ##\nHere are the various screens of the Admin portal that you should be able to use once the application is setup properly :\n\n\n<p align=\"center\">\n    <b>Login</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/login.png\">\n</p>\n\n<p align=\"center\">\n    <b>Signup</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/signup.png\">\n</p>\n\n<p align=\"center\">\n    <b>Dashboard</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/dashboard.png\">\n</p>\n\n<p align=\"center\">\n    <b>Agency</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/agency.png\">\n</p>\n\n<p align=\"center\">\n    <b>Buses</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/buses.png\">\n</p>\n\n<p align=\"center\">\n    <b>Trips</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/trips.png\">\n</p>\n\n<p align=\"center\">\n    <b>Profile</b><br>\n    <br>\n    <img width=\"800\" src=\"https://github.com/khandelwal-arpit/springboot-starterkit-mysql/blob/master/docs/images/app-screens/profile.png\">\n</p>\n\n## Contributors ##\n[Arpit Khandelwal](https://www.linkedin.com/in/arpitkhandelwal1984/)\n\n## License ##\nThis project is licensed under the terms of the MIT license."
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/BusReservationSystemApplication.java",
    "content": "package com.starterkit.springboot.brs;\n\nimport com.starterkit.springboot.brs.model.bus.*;\nimport com.starterkit.springboot.brs.model.user.Role;\nimport com.starterkit.springboot.brs.model.user.User;\nimport com.starterkit.springboot.brs.model.user.UserRoles;\nimport com.starterkit.springboot.brs.repository.bus.*;\nimport com.starterkit.springboot.brs.repository.user.RoleRepository;\nimport com.starterkit.springboot.brs.repository.user.UserRepository;\nimport com.starterkit.springboot.brs.util.DateUtils;\nimport org.springframework.boot.CommandLineRunner;\nimport org.springframework.boot.SpringApplication;\nimport org.springframework.boot.autoconfigure.SpringBootApplication;\nimport org.springframework.context.annotation.Bean;\n\nimport java.util.Arrays;\nimport java.util.HashSet;\nimport java.util.Set;\n\n@SpringBootApplication\npublic class BusReservationSystemApplication {\n\n    public static void main(String[] args) {\n        SpringApplication.run(BusReservationSystemApplication.class, args);\n    }\n\n    @Bean\n    CommandLineRunner init(RoleRepository roleRepository, UserRepository userRepository,\n                           StopRepository stopRepository, AgencyRepository agencyRepository,\n                           BusRepository busRepository, TripRepository tripRepository,\n                           TripScheduleRepository tripScheduleRepository) {\n        return args -> {\n            //Create Admin and Passenger Roles\n            Role adminRole = roleRepository.findByRole(UserRoles.ADMIN);\n            if (adminRole == null) {\n                adminRole = new Role();\n                adminRole.setRole(UserRoles.ADMIN);\n                roleRepository.save(adminRole);\n            }\n\n            Role userRole = roleRepository.findByRole(UserRoles.PASSENGER);\n            if (userRole == null) {\n                userRole = new Role();\n                userRole.setRole(UserRoles.PASSENGER);\n                roleRepository.save(userRole);\n            }\n\n            //Create an Admin user\n            User admin = userRepository.findByEmail(\"admin@gmail.com\");\n            if (admin == null) {\n                admin = new User()\n                        .setEmail(\"admin@gmail.com\")\n                        .setPassword(\"$2a$10$7PtcjEnWb/ZkgyXyxY1/Iei2dGgGQUbqIIll/dt.qJ8l8nQBWMbYO\") // \"123456\"\n                        .setFirstName(\"John\")\n                        .setLastName(\"Doe\")\n                        .setMobileNumber(\"9425094250\")\n                        .setRoles(Arrays.asList(adminRole));\n                userRepository.save(admin);\n            }\n\n            //Create a passenger user\n            User passenger = userRepository.findByEmail(\"passenger@gmail.com\");\n            if (passenger == null) {\n                passenger = new User()\n                        .setEmail(\"passenger@gmail.com\")\n                        .setPassword(\"$2a$10$7PtcjEnWb/ZkgyXyxY1/Iei2dGgGQUbqIIll/dt.qJ8l8nQBWMbYO\") // \"123456\"\n                        .setFirstName(\"Mira\")\n                        .setLastName(\"Jane\")\n                        .setMobileNumber(\"8000110008\")\n                        .setRoles(Arrays.asList(userRole));\n                userRepository.save(passenger);\n            }\n\n            //Create four stops\n            Stop stopA = stopRepository.findByCode(\"STPA\");\n            if (stopA == null) {\n                stopA = new Stop()\n                        .setName(\"Stop A\")\n                        .setDetail(\"Near hills\")\n                        .setCode(\"STPA\");\n                stopRepository.save(stopA);\n            }\n\n            Stop stopB = stopRepository.findByCode(\"STPB\");\n            if (stopB == null) {\n                stopB = new Stop()\n                        .setName(\"Stop B\")\n                        .setDetail(\"Near river\")\n                        .setCode(\"STPB\");\n                stopRepository.save(stopB);\n            }\n\n            Stop stopC = stopRepository.findByCode(\"STPC\");\n            if (stopC == null) {\n                stopC = new Stop()\n                        .setName(\"Stop C\")\n                        .setDetail(\"Near desert\")\n                        .setCode(\"STPC\");\n                stopRepository.save(stopC);\n            }\n\n            Stop stopD = stopRepository.findByCode(\"STPD\");\n            if (stopD == null) {\n                stopD = new Stop()\n                        .setName(\"Stop D\")\n                        .setDetail(\"Near lake\")\n                        .setCode(\"STPD\");\n                stopRepository.save(stopD);\n            }\n\n            //Create an Agency\n            Agency agencyA = agencyRepository.findByCode(\"AGENCY-A\");\n            if (agencyA == null) {\n                agencyA = new Agency()\n                        .setName(\"Green Mile Agency\")\n                        .setCode(\"AGENCY-A\")\n                        .setDetails(\"Reaching desitnations with ease\")\n                        .setOwner(admin);\n                agencyRepository.save(agencyA);\n            }\n\n            //Create a bus\n            Bus busA = busRepository.findByCode(\"AGENCY-A-1\");\n            if (busA == null) {\n                busA = new Bus()\n                        .setCode(\"AGENCY-A-1\")\n                        .setAgency(agencyA)\n                        .setCapacity(60);\n                busRepository.save(busA);\n            }\n\n            //Add busA to set of buses owned by Agency 'AGENCYA'\n            if (agencyA.getBuses() == null) {\n                Set<Bus> buses = new HashSet<>();\n                agencyA.setBuses(buses);\n                agencyA.getBuses().add(busA);\n                agencyRepository.save(agencyA);\n            }\n\n            //Create a Trip\n            Trip trip = tripRepository.findBySourceStopAndDestStopAndBus(stopA, stopB, busA);\n            if (trip == null) {\n                trip = new Trip()\n                        .setSourceStop(stopA)\n                        .setDestStop(stopB)\n                        .setBus(busA)\n                        .setAgency(agencyA)\n                        .setFare(100)\n                        .setJourneyTime(60);\n                tripRepository.save(trip);\n            }\n\n            //Create a trip schedule\n            TripSchedule tripSchedule = tripScheduleRepository.findByTripDetailAndTripDate(trip, DateUtils.todayStr());\n            if (tripSchedule == null) {\n                tripSchedule = new TripSchedule()\n                        .setTripDetail(trip)\n                        .setTripDate(DateUtils.todayStr())\n                        .setAvailableSeats(trip.getBus().getCapacity());\n                tripScheduleRepository.save(tripSchedule);\n            }\n        };\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/config/BrsConfiguration.java",
    "content": "package com.starterkit.springboot.brs.config;\n\nimport org.modelmapper.ModelMapper;\nimport org.modelmapper.convention.NamingConventions;\nimport org.springframework.context.annotation.Bean;\nimport org.springframework.context.annotation.Configuration;\nimport org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;\nimport springfox.documentation.builders.ApiInfoBuilder;\nimport springfox.documentation.builders.PathSelectors;\nimport springfox.documentation.builders.RequestHandlerSelectors;\nimport springfox.documentation.service.ApiInfo;\nimport springfox.documentation.service.ApiKey;\nimport springfox.documentation.service.Contact;\nimport springfox.documentation.spi.DocumentationType;\nimport springfox.documentation.spring.web.plugins.Docket;\nimport springfox.documentation.swagger2.annotations.EnableSwagger2;\n\nimport java.util.Arrays;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Configuration\npublic class BrsConfiguration {\n\n    @Bean\n    public BCryptPasswordEncoder bCryptPasswordEncoder() {\n        return new BCryptPasswordEncoder();\n    }\n\n    @Bean\n    public ModelMapper modelMapper() {\n        ModelMapper modelMapper = new ModelMapper();\n        modelMapper.getConfiguration()\n                .setFieldMatchingEnabled(true)\n                .setFieldAccessLevel(org.modelmapper.config.Configuration.AccessLevel.PRIVATE)\n                .setSourceNamingConvention(NamingConventions.JAVABEANS_MUTATOR);\n        return modelMapper;\n        //https://github.com/modelmapper/modelmapper/issues/212\n    }\n\n    /**\n     * Group BRS contains operations related to reservations and agency management\n     */\n    @Bean\n    public Docket swaggerBRSApi() {\n        return new Docket(DocumentationType.SWAGGER_2)\n                .groupName(\"BRS\")\n                .select()\n                .apis(RequestHandlerSelectors.basePackage(\"com.starterkit.springboot.brs.controller.v1.api\"))\n                .paths(PathSelectors.any())\n                .build()\n                .apiInfo(apiInfo())\n                .securitySchemes(Arrays.asList(apiKey()));\n    }\n\n    /**\n     * Group User contains operations related to user management such as login/logout\n     */\n    @Bean\n    public Docket swaggerUserApi() {\n        return new Docket(DocumentationType.SWAGGER_2)\n                .groupName(\"User\")\n                .select()\n                .apis(RequestHandlerSelectors.basePackage(\"com.starterkit.springboot.brs.config\"))\n                .paths(PathSelectors.any())\n                .build()\n                .apiInfo(apiInfo())\n                .securitySchemes(Arrays.asList(apiKey()));\n    }\n\n    private ApiInfo apiInfo() {\n        return new ApiInfoBuilder().title(\"Bus Reservation System - REST APIs\")\n                .description(\"Spring Boot starter kit application.\").termsOfServiceUrl(\"\")\n                .contact(new Contact(\"Arpit Khandelwal\", \"https://medium.com/the-resonant-web\", \"khandelwal.arpit@outlook.com\"))\n                .license(\"Apache License Version 2.0\")\n                .licenseUrl(\"https://www.apache.org/licenses/LICENSE-2.0\")\n                .version(\"0.0.1\")\n                .build();\n    }\n\n    private ApiKey apiKey() {\n        return new ApiKey(\"apiKey\", \"Authorization\", \"header\");\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/config/FakeController.java",
    "content": "package com.starterkit.springboot.brs.config;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport io.swagger.annotations.Api;\nimport io.swagger.annotations.ApiOperation;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestMapping;\nimport org.springframework.web.bind.annotation.RestController;\n\nimport javax.validation.Valid;\nimport javax.validation.constraints.NotNull;\n\n/**\n * This is a global controller written merely for showing the login and logout apis in the\n * swagger documentation allowing users to get the authorisation token from the same interface\n * and use it for executing the secured API operations.\n * <p>\n * Created by Arpit Khandelwal.\n */\n@RestController\n@RequestMapping(\"/api\")\n@Api(value = \"brs-application\", description = \"Operations pertaining to user login and logout in the BRS application\")\npublic class FakeController {\n    @ApiOperation(\"Login\")\n    @PostMapping(\"/auth\")\n    public void fakeLogin(@RequestBody @Valid LoginRequest loginRequest) {\n        throw new IllegalStateException(\"This method shouldn't be called. It's implemented by Spring Security filters.\");\n    }\n\n    @ApiOperation(\"Logout\")\n    @PostMapping(\"/logout\")\n    public void fakeLogout() {\n        throw new IllegalStateException(\"This method shouldn't be called. It's implemented by Spring Security filters.\");\n    }\n\n    @Getter\n    @Setter\n    @Accessors(chain = true)\n    @NoArgsConstructor\n    @JsonIgnoreProperties(ignoreUnknown = true)\n    private static class LoginRequest {\n        @NotNull(message = \"{constraints.NotEmpty.message}\")\n        private String email;\n        @NotNull(message = \"{constraints.NotEmpty.message}\")\n        private String password;\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/config/PageConfig.java",
    "content": "package com.starterkit.springboot.brs.config;\n\nimport org.springframework.context.annotation.Configuration;\nimport org.springframework.web.servlet.config.annotation.ViewControllerRegistry;\nimport org.springframework.web.servlet.config.annotation.WebMvcConfigurer;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Configuration\npublic class PageConfig implements WebMvcConfigurer {\n\n    @Override\n    public void addViewControllers(ViewControllerRegistry registry) {\n        registry.addViewController(\"/home\").setViewName(\"home\");\n        registry.addViewController(\"/\").setViewName(\"login\");\n        registry.addViewController(\"/dashboard\").setViewName(\"dashboard\");\n        registry.addViewController(\"/login\").setViewName(\"login\");\n        registry.addViewController(\"/signup\").setViewName(\"signup\");\n        registry.addViewController(\"/profile\").setViewName(\"profile\");\n        registry.addViewController(\"/agency\").setViewName(\"agency\");\n        registry.addViewController(\"/bus\").setViewName(\"bus\");\n        registry.addViewController(\"/trip\").setViewName(\"trip\");\n        registry.addViewController(\"/logout\").setViewName(\"logout\");\n    }\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/config/PropertiesConfig.java",
    "content": "package com.starterkit.springboot.brs.config;\n\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.context.annotation.PropertySource;\nimport org.springframework.core.env.Environment;\nimport org.springframework.stereotype.Component;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Component\n@PropertySource(\"classpath:custom.properties\")\npublic class PropertiesConfig {\n    @Autowired\n    private Environment env;\n\n    public String getConfigValue(String configKey) {\n        return env.getProperty(configKey);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/api/BusReservationController.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.api;\n\nimport com.starterkit.springboot.brs.controller.v1.request.BookTicketRequest;\nimport com.starterkit.springboot.brs.controller.v1.request.GetTripSchedulesRequest;\nimport com.starterkit.springboot.brs.dto.model.bus.TicketDto;\nimport com.starterkit.springboot.brs.dto.model.bus.TripDto;\nimport com.starterkit.springboot.brs.dto.model.bus.TripScheduleDto;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.dto.response.Response;\nimport com.starterkit.springboot.brs.service.BusReservationService;\nimport com.starterkit.springboot.brs.service.UserService;\nimport com.starterkit.springboot.brs.util.DateUtils;\nimport io.swagger.annotations.Api;\nimport io.swagger.annotations.ApiOperation;\nimport io.swagger.annotations.Authorization;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.core.context.SecurityContextHolder;\nimport org.springframework.web.bind.annotation.*;\n\nimport javax.validation.Valid;\nimport java.util.List;\nimport java.util.Optional;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@RestController\n@RequestMapping(\"/api/v1/reservation\")\n@Api(value = \"brs-application\", description = \"Operations pertaining to agency management and ticket issue in the BRS application\")\npublic class BusReservationController {\n    @Autowired\n    private BusReservationService busReservationService;\n\n    @Autowired\n    private UserService userService;\n\n    @GetMapping(\"/stops\")\n    @ApiOperation(value = \"\", authorizations = {@Authorization(value = \"apiKey\")})\n    public Response getAllStops() {\n        return Response\n                .ok()\n                .setPayload(busReservationService.getAllStops());\n    }\n\n    @GetMapping(\"/tripsbystops\")\n    @ApiOperation(value = \"\", authorizations = {@Authorization(value = \"apiKey\")})\n    public Response getTripsByStops(@RequestBody @Valid GetTripSchedulesRequest getTripSchedulesRequest) {\n        List<TripDto> tripDtos = busReservationService.getAvailableTripsBetweenStops(\n                getTripSchedulesRequest.getSourceStop(),\n                getTripSchedulesRequest.getDestinationStop());\n        if (!tripDtos.isEmpty()) {\n            return Response.ok().setPayload(tripDtos);\n        }\n        return Response.notFound()\n                .setErrors(String.format(\"No trips between source stop - '%s' and destination stop - '%s' are available at this time.\", getTripSchedulesRequest.getSourceStop(), getTripSchedulesRequest.getDestinationStop()));\n    }\n\n    @GetMapping(\"/tripschedules\")\n    @ApiOperation(value = \"\", authorizations = {@Authorization(value = \"apiKey\")})\n    public Response getTripSchedules(@RequestBody @Valid GetTripSchedulesRequest getTripSchedulesRequest) {\n        List<TripScheduleDto> tripScheduleDtos = busReservationService.getAvailableTripSchedules(\n                getTripSchedulesRequest.getSourceStop(),\n                getTripSchedulesRequest.getDestinationStop(),\n                DateUtils.formattedDate(getTripSchedulesRequest.getTripDate()));\n        if (!tripScheduleDtos.isEmpty()) {\n            return Response.ok().setPayload(tripScheduleDtos);\n        }\n        return Response.notFound()\n                .setErrors(String.format(\"No trips between source stop - '%s' and destination stop - '%s' on date - '%s' are available at this time.\", getTripSchedulesRequest.getSourceStop(), getTripSchedulesRequest.getDestinationStop(), DateUtils.formattedDate(getTripSchedulesRequest.getTripDate())));\n    }\n\n    @PostMapping(\"/bookticket\")\n    @ApiOperation(value = \"\", authorizations = {@Authorization(value = \"apiKey\")})\n    public Response bookTicket(@RequestBody @Valid BookTicketRequest bookTicketRequest) {\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        String email = (String) auth.getPrincipal();\n        Optional<UserDto> userDto = Optional.ofNullable(userService.findUserByEmail(email));\n        if (userDto.isPresent()) {\n            Optional<TripDto> tripDto = Optional\n                    .ofNullable(busReservationService.getTripById(bookTicketRequest.getTripID()));\n            if (tripDto.isPresent()) {\n                Optional<TripScheduleDto> tripScheduleDto = Optional\n                        .ofNullable(busReservationService.getTripSchedule(tripDto.get(), DateUtils.formattedDate(bookTicketRequest.getTripDate()), true));\n                if (tripScheduleDto.isPresent()) {\n                    Optional<TicketDto> ticketDto = Optional\n                            .ofNullable(busReservationService.bookTicket(tripScheduleDto.get(), userDto.get()));\n                    if (ticketDto.isPresent()) {\n                        return Response.ok().setPayload(ticketDto.get());\n                    }\n                }\n            }\n        }\n        return Response.badRequest().setErrors(\"Unable to process ticket booking.\");\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/api/UserController.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.api;\n\nimport com.starterkit.springboot.brs.controller.v1.request.UserSignupRequest;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.dto.response.Response;\nimport com.starterkit.springboot.brs.service.UserService;\nimport io.swagger.annotations.Api;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestMapping;\nimport org.springframework.web.bind.annotation.RestController;\n\nimport javax.validation.Valid;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@RestController\n@RequestMapping(\"/api/v1/user\")\n@Api(value = \"brs-application\", description = \"Operations pertaining to user management in the BRS application\")\npublic class UserController {\n    @Autowired\n    private UserService userService;\n\n    /**\n     * Handles the incoming POST API \"/v1/user/signup\"\n     *\n     * @param userSignupRequest\n     * @return\n     */\n    @PostMapping(\"/signup\")\n    public Response signup(@RequestBody @Valid UserSignupRequest userSignupRequest) {\n        return Response.ok().setPayload(registerUser(userSignupRequest, false));\n    }\n\n    /**\n     * Register a new user in the database\n     *\n     * @param userSignupRequest\n     * @return\n     */\n    private UserDto registerUser(UserSignupRequest userSignupRequest, boolean isAdmin) {\n        UserDto userDto = new UserDto()\n                .setEmail(userSignupRequest.getEmail())\n                .setPassword(userSignupRequest.getPassword())\n                .setFirstName(userSignupRequest.getFirstName())\n                .setLastName(userSignupRequest.getLastName())\n                .setMobileNumber(userSignupRequest.getMobileNumber())\n                .setAdmin(isAdmin);\n\n        return userService.signup(userDto);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/AdminSignupFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.Email;\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Size;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class AdminSignupFormCommand {\n    @NotBlank\n    @Email\n    private String email;\n\n    @NotBlank\n    @Size(min = 5)\n    private String password;\n\n    @NotBlank\n    private String firstName;\n\n    @NotBlank\n    private String lastName;\n\n    @NotBlank\n    @Size(min = 5, max = 100)\n    private String agencyName;\n\n    @NotBlank\n    @Size(max = 100)\n    private String agencyDetails;\n\n    @NotBlank\n    @Size(min = 5, max = 13)\n    private String mobileNumber;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/AgencyFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Size;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class AgencyFormCommand {\n    @NotBlank\n    @Size(min = 5, max = 100)\n    private String agencyName;\n\n    @NotBlank\n    @Size(max = 100)\n    private String agencyDetails;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/BusFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.Min;\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Size;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class BusFormCommand {\n    @NotBlank\n    @Size(min = 4, max = 8)\n    private String code;\n\n    @Min(value = 10, message = \"Cannot enroll a bus with capacity smaller than 10\")\n    private int capacity;\n\n    @NotBlank\n    private String make;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/PasswordFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Size;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class PasswordFormCommand {\n    @NotBlank\n    @Size(min = 5, max = 12)\n    private String password;\n\n    private String email;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/ProfileFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Size;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class ProfileFormCommand {\n    @NotBlank\n    @Size(min = 1, max = 40)\n    private String firstName;\n\n    @NotBlank\n    private String lastName;\n\n    @NotBlank\n    @Size(min = 5, max = 13)\n    private String mobileNumber;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/command/TripFormCommand.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.command;\n\nimport lombok.Data;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.NotBlank;\nimport javax.validation.constraints.Positive;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Data\n@Accessors(chain = true)\npublic class TripFormCommand {\n    @NotBlank\n    private String sourceStop;\n\n    @NotBlank\n    private String destinationStop;\n\n    @NotBlank\n    private String busCode;\n\n    @Positive\n    private int tripDuration;\n\n    @Positive\n    private int tripFare;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/request/BookTicketRequest.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.request;\n\nimport com.fasterxml.jackson.annotation.JsonFormat;\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.Temporal;\nimport javax.persistence.TemporalType;\nimport javax.validation.constraints.NotEmpty;\nimport javax.validation.constraints.NotNull;\nimport java.util.Date;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class BookTicketRequest {\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private Long tripID;\n\n    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = \"yyyy-MM-dd\")\n    @NotNull(message = \"{constraints.NotEmpty.message}\")\n    @Temporal(TemporalType.DATE)\n    private Date tripDate;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/request/GetTripSchedulesRequest.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.request;\n\nimport com.fasterxml.jackson.annotation.JsonFormat;\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.Temporal;\nimport javax.persistence.TemporalType;\nimport javax.validation.constraints.NotEmpty;\nimport java.util.Date;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class GetTripSchedulesRequest {\n\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String sourceStop;\n\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String destinationStop;\n\n    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = \"yyyy-MM-dd\")\n    @Temporal(TemporalType.DATE)\n    private Date tripDate;\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/request/UserSignupRequest.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.request;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.validation.constraints.NotEmpty;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class UserSignupRequest {\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String email;\n\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String password;\n\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String firstName;\n\n    @NotEmpty(message = \"{constraints.NotEmpty.message}\")\n    private String lastName;\n\n    private String mobileNumber;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/ui/AdminController.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.ui;\n\n\nimport com.starterkit.springboot.brs.controller.v1.command.AdminSignupFormCommand;\nimport com.starterkit.springboot.brs.dto.model.bus.AgencyDto;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.service.BusReservationService;\nimport com.starterkit.springboot.brs.service.UserService;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.security.core.context.SecurityContextHolder;\nimport org.springframework.stereotype.Controller;\nimport org.springframework.validation.BindingResult;\nimport org.springframework.web.bind.annotation.GetMapping;\nimport org.springframework.web.bind.annotation.ModelAttribute;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.servlet.ModelAndView;\n\nimport javax.validation.Valid;\n\n/**\n * Created by Arpit Khandelwal.\n */\n\n@Controller\npublic class AdminController {\n\n    @Autowired\n    BusReservationService busReservationService;\n    @Autowired\n    private UserService userService;\n\n    @GetMapping(value = {\"/\", \"/login\"})\n    public ModelAndView login() {\n        return new ModelAndView(\"login\");\n    }\n\n    @GetMapping(value = {\"/logout\"})\n    public String logout() {\n        SecurityContextHolder.getContext().setAuthentication(null);\n        return \"redirect:login\";\n    }\n\n    @GetMapping(value = \"/home\")\n    public String home() {\n        return \"redirect:dashboard\";\n    }\n\n    @GetMapping(value = \"/signup\")\n    public ModelAndView signup() {\n        ModelAndView modelAndView = new ModelAndView(\"signup\");\n        modelAndView.addObject(\"adminSignupFormData\", new AdminSignupFormCommand());\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/signup\")\n    public ModelAndView createNewAdmin(@Valid @ModelAttribute(\"adminSignupFormData\") AdminSignupFormCommand adminSignupFormCommand, BindingResult bindingResult) {\n        ModelAndView modelAndView = new ModelAndView(\"signup\");\n        if (bindingResult.hasErrors()) {\n            return modelAndView;\n        } else {\n            try {\n                UserDto newUser = registerAdmin(adminSignupFormCommand);\n            } catch (Exception exception) {\n                bindingResult.rejectValue(\"email\", \"error.adminSignupFormCommand\", exception.getMessage());\n                return modelAndView;\n            }\n        }\n        return new ModelAndView(\"login\");\n    }\n\n    /**\n     * Register a new user in the database\n     *\n     * @param adminSignupRequest\n     * @return\n     */\n    private UserDto registerAdmin(@Valid AdminSignupFormCommand adminSignupRequest) {\n        UserDto userDto = new UserDto()\n                .setEmail(adminSignupRequest.getEmail())\n                .setPassword(adminSignupRequest.getPassword())\n                .setFirstName(adminSignupRequest.getFirstName())\n                .setLastName(adminSignupRequest.getLastName())\n                .setMobileNumber(adminSignupRequest.getMobileNumber())\n                .setAdmin(true);\n        UserDto admin = userService.signup(userDto); //register the admin\n        AgencyDto agencyDto = new AgencyDto()\n                .setName(adminSignupRequest.getAgencyName())\n                .setDetails(adminSignupRequest.getAgencyDetails())\n                .setOwner(admin);\n        busReservationService.addAgency(agencyDto); //add the agency for this admin\n        return admin;\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/controller/v1/ui/DashboardController.java",
    "content": "package com.starterkit.springboot.brs.controller.v1.ui;\n\nimport com.starterkit.springboot.brs.controller.v1.command.*;\nimport com.starterkit.springboot.brs.dto.model.bus.AgencyDto;\nimport com.starterkit.springboot.brs.dto.model.bus.BusDto;\nimport com.starterkit.springboot.brs.dto.model.bus.StopDto;\nimport com.starterkit.springboot.brs.dto.model.bus.TripDto;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.service.BusReservationService;\nimport com.starterkit.springboot.brs.service.UserService;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.core.context.SecurityContextHolder;\nimport org.springframework.stereotype.Controller;\nimport org.springframework.validation.BindingResult;\nimport org.springframework.web.bind.annotation.GetMapping;\nimport org.springframework.web.bind.annotation.ModelAttribute;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.servlet.ModelAndView;\n\nimport javax.validation.Valid;\nimport java.util.List;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Controller\npublic class DashboardController {\n\n    @Autowired\n    private UserService userService;\n\n    @Autowired\n    private BusReservationService busReservationService;\n\n    @GetMapping(value = \"/dashboard\")\n    public ModelAndView dashboard() {\n        ModelAndView modelAndView = new ModelAndView(\"dashboard\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        modelAndView.addObject(\"currentUser\", userDto);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        return modelAndView;\n    }\n\n    @GetMapping(value = \"/agency\")\n    public ModelAndView agencyDetails() {\n        ModelAndView modelAndView = new ModelAndView(\"agency\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        AgencyFormCommand agencyFormCommand = new AgencyFormCommand()\n                .setAgencyName(agencyDto.getName())\n                .setAgencyDetails(agencyDto.getDetails());\n        modelAndView.addObject(\"agencyFormData\", agencyFormCommand);\n        modelAndView.addObject(\"agency\", agencyDto);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/agency\")\n    public ModelAndView updateAgency(@Valid @ModelAttribute(\"agencyFormData\") AgencyFormCommand agencyFormCommand, BindingResult bindingResult) {\n        ModelAndView modelAndView = new ModelAndView(\"agency\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        modelAndView.addObject(\"agency\", agencyDto);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        if (!bindingResult.hasErrors()) {\n            if (agencyDto != null) {\n                agencyDto.setName(agencyFormCommand.getAgencyName())\n                        .setDetails(agencyFormCommand.getAgencyDetails());\n                busReservationService.updateAgency(agencyDto, null);\n            }\n        }\n        return modelAndView;\n    }\n\n    @GetMapping(value = \"/bus\")\n    public ModelAndView busDetails() {\n        ModelAndView modelAndView = new ModelAndView(\"bus\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        modelAndView.addObject(\"agency\", agencyDto);\n        modelAndView.addObject(\"busFormData\", new BusFormCommand());\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/bus\")\n    public ModelAndView addNewBus(@Valid @ModelAttribute(\"busFormData\") BusFormCommand busFormCommand, BindingResult bindingResult) {\n        ModelAndView modelAndView = new ModelAndView(\"bus\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        modelAndView.addObject(\"agency\", agencyDto);\n        if (!bindingResult.hasErrors()) {\n            try {\n                BusDto busDto = new BusDto()\n                        .setCode(busFormCommand.getCode())\n                        .setCapacity(busFormCommand.getCapacity())\n                        .setMake(busFormCommand.getMake());\n                AgencyDto updatedAgencyDto = busReservationService.updateAgency(agencyDto, busDto);\n                modelAndView.addObject(\"agency\", updatedAgencyDto);\n                modelAndView.addObject(\"busFormData\", new BusFormCommand());\n            } catch (Exception ex) {\n                bindingResult.rejectValue(\"code\", \"error.busFormCommand\", ex.getMessage());\n            }\n        }\n        return modelAndView;\n    }\n\n    @GetMapping(value = \"/trip\")\n    public ModelAndView tripDetails() {\n        ModelAndView modelAndView = new ModelAndView(\"trip\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        Set<StopDto> stops = busReservationService.getAllStops();\n        List<TripDto> trips = busReservationService.getAgencyTrips(agencyDto.getCode());\n        modelAndView.addObject(\"agency\", agencyDto);\n        modelAndView.addObject(\"stops\", stops);\n        modelAndView.addObject(\"trips\", trips);\n        modelAndView.addObject(\"tripFormData\", new TripFormCommand());\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/trip\")\n    public ModelAndView addNewTrip(@Valid @ModelAttribute(\"tripFormData\") TripFormCommand tripFormCommand, BindingResult bindingResult) {\n        ModelAndView modelAndView = new ModelAndView(\"trip\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        AgencyDto agencyDto = busReservationService.getAgency(userDto);\n        Set<StopDto> stops = busReservationService.getAllStops();\n        List<TripDto> trips = busReservationService.getAgencyTrips(agencyDto.getCode());\n\n        modelAndView.addObject(\"stops\", stops);\n        modelAndView.addObject(\"agency\", agencyDto);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        modelAndView.addObject(\"trips\", trips);\n\n        if (!bindingResult.hasErrors()) {\n            try {\n                TripDto tripDto = new TripDto()\n                        .setSourceStopCode(tripFormCommand.getSourceStop())\n                        .setDestinationStopCode(tripFormCommand.getDestinationStop())\n                        .setBusCode(tripFormCommand.getBusCode())\n                        .setJourneyTime(tripFormCommand.getTripDuration())\n                        .setFare(tripFormCommand.getTripFare())\n                        .setAgencyCode(agencyDto.getCode());\n                busReservationService.addTrip(tripDto);\n\n                trips = busReservationService.getAgencyTrips(agencyDto.getCode());\n                modelAndView.addObject(\"trips\", trips);\n                modelAndView.addObject(\"tripFormData\", new TripFormCommand());\n            } catch (Exception ex) {\n                bindingResult.rejectValue(\"sourceStop\", \"error.tripFormData\", ex.getMessage());\n            }\n        }\n        return modelAndView;\n    }\n\n    @GetMapping(value = \"/profile\")\n    public ModelAndView getUserProfile() {\n        ModelAndView modelAndView = new ModelAndView(\"profile\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        ProfileFormCommand profileFormCommand = new ProfileFormCommand()\n                .setFirstName(userDto.getFirstName())\n                .setLastName(userDto.getLastName())\n                .setMobileNumber(userDto.getMobileNumber());\n        PasswordFormCommand passwordFormCommand = new PasswordFormCommand()\n                .setEmail(userDto.getEmail())\n                .setPassword(userDto.getPassword());\n        modelAndView.addObject(\"profileForm\", profileFormCommand);\n        modelAndView.addObject(\"passwordForm\", passwordFormCommand);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/profile\")\n    public ModelAndView updateProfile(@Valid @ModelAttribute(\"profileForm\") ProfileFormCommand profileFormCommand, BindingResult bindingResult) {\n        ModelAndView modelAndView = new ModelAndView(\"profile\");\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        PasswordFormCommand passwordFormCommand = new PasswordFormCommand()\n                .setEmail(userDto.getEmail())\n                .setPassword(userDto.getPassword());\n        modelAndView.addObject(\"passwordForm\", passwordFormCommand);\n        modelAndView.addObject(\"userName\", userDto.getFullName());\n        if (!bindingResult.hasErrors()) {\n            userDto.setFirstName(profileFormCommand.getFirstName())\n                    .setLastName(profileFormCommand.getLastName())\n                    .setMobileNumber(profileFormCommand.getMobileNumber());\n            userService.updateProfile(userDto);\n            modelAndView.addObject(\"userName\", userDto.getFullName());\n        }\n        return modelAndView;\n    }\n\n    @PostMapping(value = \"/password\")\n    public ModelAndView changePassword(@Valid @ModelAttribute(\"passwordForm\") PasswordFormCommand passwordFormCommand, BindingResult bindingResult) {\n        Authentication auth = SecurityContextHolder.getContext().getAuthentication();\n        UserDto userDto = userService.findUserByEmail(auth.getName());\n        if (bindingResult.hasErrors()) {\n            ModelAndView modelAndView = new ModelAndView(\"profile\");\n            ProfileFormCommand profileFormCommand = new ProfileFormCommand()\n                    .setFirstName(userDto.getFirstName())\n                    .setLastName(userDto.getLastName())\n                    .setMobileNumber(userDto.getMobileNumber());\n            modelAndView.addObject(\"profileForm\", profileFormCommand);\n            modelAndView.addObject(\"userName\", userDto.getFullName());\n            return modelAndView;\n        } else {\n            userService.changePassword(userDto, passwordFormCommand.getPassword());\n            return new ModelAndView(\"login\");\n        }\n    }\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/mapper/TicketMapper.java",
    "content": "package com.starterkit.springboot.brs.dto.mapper;\n\nimport com.starterkit.springboot.brs.dto.model.bus.TicketDto;\nimport com.starterkit.springboot.brs.model.bus.Ticket;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class TicketMapper {\n    public static TicketDto toTicketDto(Ticket ticket) {\n        return new TicketDto()\n                .setId(ticket.getId())\n                .setBusCode(ticket.getTripSchedule().getTripDetail().getBus().getCode())\n                .setSeatNumber(ticket.getSeatNumber())\n                .setSourceStop(ticket.getTripSchedule().getTripDetail().getSourceStop().getName())\n                .setDestinationStop(ticket.getTripSchedule().getTripDetail().getDestStop().getName())\n                .setCancellable(false)\n                .setJourneyDate(ticket.getJourneyDate())\n                .setPassengerName(ticket.getPassenger().getFullName())\n                .setPassengerMobileNumber(ticket.getPassenger().getMobileNumber());\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/mapper/TripMapper.java",
    "content": "package com.starterkit.springboot.brs.dto.mapper;\n\nimport com.starterkit.springboot.brs.dto.model.bus.TripDto;\nimport com.starterkit.springboot.brs.model.bus.Trip;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class TripMapper {\n    public static TripDto toTripDto(Trip trip) {\n        return new TripDto()\n                .setId(trip.getId())\n                .setAgencyCode(trip.getAgency().getCode())\n                .setSourceStopCode(trip.getSourceStop().getCode())\n                .setSourceStopName(trip.getSourceStop().getName())\n                .setDestinationStopCode(trip.getDestStop().getCode())\n                .setDestinationStopName(trip.getDestStop().getName())\n                .setBusCode(trip.getBus().getCode())\n                .setJourneyTime(trip.getJourneyTime())\n                .setFare(trip.getFare());\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/mapper/TripScheduleMapper.java",
    "content": "package com.starterkit.springboot.brs.dto.mapper;\n\nimport com.starterkit.springboot.brs.dto.model.bus.TripScheduleDto;\nimport com.starterkit.springboot.brs.model.bus.Trip;\nimport com.starterkit.springboot.brs.model.bus.TripSchedule;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class TripScheduleMapper {\n    public static TripScheduleDto toTripScheduleDto(TripSchedule tripSchedule) {\n        Trip tripDetails = tripSchedule.getTripDetail();\n        return new TripScheduleDto()\n                .setId(tripSchedule.getId())\n                .setTripId(tripDetails.getId())\n                .setBusCode(tripDetails.getBus().getCode())\n                .setAvailableSeats(tripSchedule.getAvailableSeats())\n                .setFare(tripDetails.getFare())\n                .setJourneyTime(tripDetails.getJourneyTime())\n                .setSourceStop(tripDetails.getSourceStop().getName())\n                .setDestinationStop(tripDetails.getDestStop().getName());\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/mapper/UserMapper.java",
    "content": "package com.starterkit.springboot.brs.dto.mapper;\n\nimport com.starterkit.springboot.brs.dto.model.user.RoleDto;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.model.user.User;\nimport org.modelmapper.ModelMapper;\nimport org.springframework.stereotype.Component;\n\nimport java.util.HashSet;\nimport java.util.stream.Collectors;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Component\npublic class UserMapper {\n\n    public static UserDto toUserDto(User user) {\n        return new UserDto()\n                .setEmail(user.getEmail())\n                .setFirstName(user.getFirstName())\n                .setLastName(user.getLastName())\n                .setMobileNumber(user.getMobileNumber())\n                .setRoles(new HashSet<RoleDto>(user\n                        .getRoles()\n                        .stream()\n                        .map(role -> new ModelMapper().map(role, RoleDto.class))\n                        .collect(Collectors.toSet())));\n    }\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/AgencyDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class AgencyDto {\n    private String code;\n\n    private UserDto owner;\n\n    private Set<BusDto> buses;\n\n    private String name;\n\n    private String details;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/BusDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class BusDto {\n\n    private String code;\n\n    private int capacity;\n\n    private String make;\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/StopDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class StopDto implements Comparable {\n\n    private String code;\n    private String name;\n    private String detail;\n\n    @Override\n    public int compareTo(Object o) {\n        return this.getName().compareTo(((StopDto) o).getName());\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/TicketDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class TicketDto {\n    private Long id;\n\n    private String busCode;\n\n    private int seatNumber;\n\n    private boolean cancellable;\n\n    private String journeyDate;\n\n    private String sourceStop;\n\n    private String destinationStop;\n\n    private String passengerName;\n\n    private String passengerMobileNumber;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/TripDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class TripDto {\n\n    private Long id;\n\n    private int fare;\n\n    private int journeyTime;\n\n    private String sourceStopCode;\n\n    private String sourceStopName;\n\n    private String destinationStopCode;\n\n    private String destinationStopName;\n\n    private String busCode;\n\n    private String agencyCode;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/bus/TripScheduleDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.bus;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class TripScheduleDto {\n\n    private Long id;\n\n    private Long tripId;\n\n    private String tripDate;\n\n    private int availableSeats;\n\n    private int fare;\n\n    private int journeyTime;\n\n    private String busCode;\n\n    private String sourceStop;\n\n    private String destinationStop;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/user/RoleDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.user;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class RoleDto {\n    private String role;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/model/user/UserDto.java",
    "content": "package com.starterkit.springboot.brs.dto.model.user;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.ToString;\nimport lombok.experimental.Accessors;\n\nimport java.util.Collection;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@ToString\n@JsonInclude(value = JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class UserDto {\n    private String email;\n    private String password;\n    private String firstName;\n    private String lastName;\n    private String mobileNumber;\n    private boolean isAdmin;\n    private Collection<RoleDto> roles;\n\n    public String getFullName() {\n        return firstName != null ? firstName.concat(\" \").concat(lastName) : \"\";\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/response/Response.java",
    "content": "package com.starterkit.springboot.brs.dto.response;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport com.starterkit.springboot.brs.util.DateUtils;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\n/**\n * @author Arpit Khandelwal\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@JsonInclude(JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class Response<T> {\n\n    private Status status;\n    private T payload;\n    private Object errors;\n    private Object metadata;\n\n    public static <T> Response<T> badRequest() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.BAD_REQUEST);\n        return response;\n    }\n\n    public static <T> Response<T> ok() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.OK);\n        return response;\n    }\n\n    public static <T> Response<T> unauthorized() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.UNAUTHORIZED);\n        return response;\n    }\n\n    public static <T> Response<T> validationException() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.VALIDATION_EXCEPTION);\n        return response;\n    }\n\n    public static <T> Response<T> wrongCredentials() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.WRONG_CREDENTIALS);\n        return response;\n    }\n\n    public static <T> Response<T> accessDenied() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.ACCESS_DENIED);\n        return response;\n    }\n\n    public static <T> Response<T> exception() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.EXCEPTION);\n        return response;\n    }\n\n    public static <T> Response<T> notFound() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.NOT_FOUND);\n        return response;\n    }\n\n    public static <T> Response<T> duplicateEntity() {\n        Response<T> response = new Response<>();\n        response.setStatus(Status.DUPLICATE_ENTITY);\n        return response;\n    }\n\n    public void addErrorMsgToResponse(String errorMsg, Exception ex) {\n        ResponseError error = new ResponseError()\n                .setDetails(errorMsg)\n                .setMessage(ex.getMessage())\n                .setTimestamp(DateUtils.today());\n        setErrors(error);\n    }\n\n    public enum Status {\n        OK, BAD_REQUEST, UNAUTHORIZED, VALIDATION_EXCEPTION, EXCEPTION, WRONG_CREDENTIALS, ACCESS_DENIED, NOT_FOUND, DUPLICATE_ENTITY\n    }\n\n    @Getter\n    @Accessors(chain = true)\n    @JsonInclude(JsonInclude.Include.NON_NULL)\n    @JsonIgnoreProperties(ignoreUnknown = true)\n    public static class PageMetadata {\n        private final int size;\n        private final long totalElements;\n        private final int totalPages;\n        private final int number;\n\n        public PageMetadata(int size, long totalElements, int totalPages, int number) {\n            this.size = size;\n            this.totalElements = totalElements;\n            this.totalPages = totalPages;\n            this.number = number;\n        }\n    }\n\n}\n\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/dto/response/ResponseError.java",
    "content": "package com.starterkit.springboot.brs.dto.response;\n\nimport com.fasterxml.jackson.annotation.JsonIgnoreProperties;\nimport com.fasterxml.jackson.annotation.JsonInclude;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport java.util.Date;\n\n/**\n * Created by Arpit Khandelwal\n */\n@Getter\n@Setter\n@Accessors(chain = true)\n@NoArgsConstructor\n@JsonInclude(JsonInclude.Include.NON_NULL)\n@JsonIgnoreProperties(ignoreUnknown = true)\npublic class ResponseError {\n    private Date timestamp;\n    private String message;\n    private String details;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/exception/BRSException.java",
    "content": "package com.starterkit.springboot.brs.exception;\n\nimport com.starterkit.springboot.brs.config.PropertiesConfig;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.stereotype.Component;\n\nimport java.text.MessageFormat;\nimport java.util.Optional;\n\n/**\n * A helper class to generate RuntimeExceptions with a little AI inbuilt.\n * <p>\n * Created by Arpit Khandelwal.\n */\n@Component\npublic class BRSException {\n\n    private static PropertiesConfig propertiesConfig;\n\n    @Autowired\n    public BRSException(PropertiesConfig propertiesConfig) {\n        BRSException.propertiesConfig = propertiesConfig;\n    }\n\n    /**\n     * Returns new RuntimeException based on template and args\n     *\n     * @param messageTemplate\n     * @param args\n     * @return\n     */\n    public static RuntimeException throwException(String messageTemplate, String... args) {\n        return new RuntimeException(format(messageTemplate, args));\n    }\n\n    /**\n     * Returns new RuntimeException based on EntityType, ExceptionType and args\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param args\n     * @return\n     */\n    public static RuntimeException throwException(EntityType entityType, ExceptionType exceptionType, String... args) {\n        String messageTemplate = getMessageTemplate(entityType, exceptionType);\n        return throwException(exceptionType, messageTemplate, args);\n    }\n\n    /**\n     * Returns new RuntimeException based on EntityType, ExceptionType and args\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param args\n     * @return\n     */\n    public static RuntimeException throwExceptionWithId(EntityType entityType, ExceptionType exceptionType, Integer id, String... args) {\n        String messageTemplate = getMessageTemplate(entityType, exceptionType).concat(\".\").concat(id.toString());\n        return throwException(exceptionType, messageTemplate, args);\n    }\n\n    /**\n     * Returns new RuntimeException based on EntityType, ExceptionType, messageTemplate and args\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param messageTemplate\n     * @param args\n     * @return\n     */\n    public static RuntimeException throwExceptionWithTemplate(EntityType entityType, ExceptionType exceptionType, String messageTemplate, String... args) {\n        return throwException(exceptionType, messageTemplate, args);\n    }\n\n    /**\n     * Returns new RuntimeException based on template and args\n     *\n     * @param messageTemplate\n     * @param args\n     * @return\n     */\n    private static RuntimeException throwException(ExceptionType exceptionType, String messageTemplate, String... args) {\n        if (ExceptionType.ENTITY_NOT_FOUND.equals(exceptionType)) {\n            return new EntityNotFoundException(format(messageTemplate, args));\n        } else if (ExceptionType.DUPLICATE_ENTITY.equals(exceptionType)) {\n            return new DuplicateEntityException(format(messageTemplate, args));\n        }\n        return new RuntimeException(format(messageTemplate, args));\n    }\n\n    private static String getMessageTemplate(EntityType entityType, ExceptionType exceptionType) {\n        return entityType.name().concat(\".\").concat(exceptionType.getValue()).toLowerCase();\n    }\n\n    private static String format(String template, String ... args) {\n        Optional<String> templateContent = Optional.ofNullable(propertiesConfig.getConfigValue(template));\n        if (templateContent.isPresent()) {\n            return MessageFormat.format(templateContent.get(), (Object[]) args);\n        }\n        return String.format(template, (Object[]) args);\n    }\n\n    public static class EntityNotFoundException extends RuntimeException {\n        public EntityNotFoundException(String message) {\n            super(message);\n        }\n    }\n\n    public static class DuplicateEntityException extends RuntimeException {\n        public DuplicateEntityException(String message) {\n            super(message);\n        }\n    }\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/exception/CustomizedResponseEntityExceptionHandler.java",
    "content": "package com.starterkit.springboot.brs.exception;\n\nimport com.starterkit.springboot.brs.dto.response.Response;\nimport org.springframework.http.HttpStatus;\nimport org.springframework.http.ResponseEntity;\nimport org.springframework.web.bind.annotation.ControllerAdvice;\nimport org.springframework.web.bind.annotation.ExceptionHandler;\nimport org.springframework.web.bind.annotation.RestController;\nimport org.springframework.web.context.request.WebRequest;\nimport org.springframework.web.servlet.mvc.method.annotation.ResponseEntityExceptionHandler;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@ControllerAdvice\n@RestController\npublic class CustomizedResponseEntityExceptionHandler extends ResponseEntityExceptionHandler {\n\n    @ExceptionHandler(BRSException.EntityNotFoundException.class)\n    public final ResponseEntity handleNotFountExceptions(Exception ex, WebRequest request) {\n        Response response = Response.notFound();\n        response.addErrorMsgToResponse(ex.getMessage(), ex);\n        return new ResponseEntity(response, HttpStatus.NOT_FOUND);\n    }\n\n    @ExceptionHandler(BRSException.DuplicateEntityException.class)\n    public final ResponseEntity handleNotFountExceptions1(Exception ex, WebRequest request) {\n        Response response = Response.duplicateEntity();\n        response.addErrorMsgToResponse(ex.getMessage(), ex);\n        return new ResponseEntity(response, HttpStatus.CONFLICT);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/exception/EntityType.java",
    "content": "package com.starterkit.springboot.brs.exception;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic enum EntityType {\n    USER,\n    ROLE,\n    AGENCY,\n    BUS,\n    STOP,\n    TICKET,\n    TRIP,\n    TRIPSCHEDULE\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/exception/ExceptionType.java",
    "content": "package com.starterkit.springboot.brs.exception;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic enum ExceptionType {\n    ENTITY_NOT_FOUND(\"not.found\"),\n    DUPLICATE_ENTITY(\"duplicate\"),\n    ENTITY_EXCEPTION(\"exception\");\n\n    String value;\n\n    ExceptionType(String value) {\n        this.value = value;\n    }\n\n    String getValue() {\n        return this.value;\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/Agency.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport com.starterkit.springboot.brs.model.user.User;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"agency\",\n        indexes = @Index(\n                name = \"idx_agency_code\",\n                columnList = \"code\",\n                unique = true\n        ))\npublic class Agency {\n    @Id\n    @Column(name = \"agency_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    private String code;\n\n    private String name;\n\n    private String details;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"owner_user_id\")\n    private User owner;\n\n    @OneToMany(mappedBy = \"agency\", cascade = CascadeType.ALL)\n    private Set<Bus> buses;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/Bus.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(\n        name = \"bus\",\n        indexes = @Index(\n                name = \"idx_bus_code\",\n                columnList = \"code\",\n                unique = true\n        )\n)\npublic class Bus {\n    @Id\n    @Column(name = \"bus_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    private String code;\n\n    private int capacity;\n\n    private String make;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"agency_id\")\n    private Agency agency;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/Stop.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(\n        name = \"stop\",\n        indexes = @Index(\n                name = \"idx_stop_code\",\n                columnList = \"code\",\n                unique = true\n        )\n)\npublic class Stop {\n    @Id\n    @Column(name = \"stop_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    private String code;\n\n    private String name;\n\n    private String detail;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/Ticket.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport com.starterkit.springboot.brs.model.user.User;\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"ticket\")\npublic class Ticket {\n    @Id\n    @Column(name = \"ticket_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    @Column(name = \"seat_number\")\n    private int seatNumber;\n\n    private Boolean cancellable;\n\n    @Column(name = \"journey_date\")\n    private String journeyDate;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"trip_schedule_id\")\n    private TripSchedule tripSchedule;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"user_id\")\n    private User passenger;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/Trip.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"trip\")\npublic class Trip {\n    @Id\n    @Column(name = \"trip_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    private int fare;\n\n    @Column(name = \"journey_time\")\n    private int journeyTime;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"source_stop_id\")\n    private Stop sourceStop;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"dest_stop_id\")\n    private Stop destStop;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"bus_id\")\n    private Bus bus;\n\n    @ManyToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"agency_id\")\n    private Agency agency;\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/bus/TripSchedule.java",
    "content": "package com.starterkit.springboot.brs.model.bus;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"trip_schedule\")\npublic class TripSchedule {\n    @Id\n    @Column(name = \"trip_schedule_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    @OneToOne(fetch = FetchType.LAZY)\n    @JoinColumn(name = \"trip_id\")\n    private Trip tripDetail;\n\n    @OneToMany(mappedBy = \"tripSchedule\", cascade = CascadeType.ALL)\n    private Set<Ticket> ticketsSold;\n\n    @Column(name = \"trip_date\")\n    private String tripDate;\n\n    @Column(name = \"available_seats\")\n    private int availableSeats;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/user/Role.java",
    "content": "package com.starterkit.springboot.brs.model.user;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\nimport java.util.Collection;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"role\")\npublic class Role {\n    @Id\n    @Column(name = \"role_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    @ManyToMany(mappedBy = \"roles\")\n    private Collection<User> users;\n\n    @Enumerated(EnumType.STRING)\n    private UserRoles role;\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/user/User.java",
    "content": "package com.starterkit.springboot.brs.model.user;\n\nimport lombok.Getter;\nimport lombok.NoArgsConstructor;\nimport lombok.Setter;\nimport lombok.experimental.Accessors;\n\nimport javax.persistence.*;\nimport java.util.Collection;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Getter\n@Setter\n@NoArgsConstructor\n@Accessors(chain = true)\n@Entity\n@Table(name = \"user\",\n        indexes = @Index(\n                name = \"idx_user_email\",\n                columnList = \"email\",\n                unique = true\n        ))\npublic class User {\n    @Id\n    @Column(name = \"user_id\")\n    @GeneratedValue(strategy = GenerationType.IDENTITY)\n    private Long id;\n\n    private String email;\n\n    private String password;\n\n    @Column(name = \"first_name\")\n    private String firstName;\n\n    @Column(name = \"last_name\")\n    private String lastName;\n\n    @Column(name = \"mobile_number\")\n    private String mobileNumber;\n\n    @ManyToMany(fetch = FetchType.LAZY)\n    @JoinTable(name = \"user_role\",\n            joinColumns = {@JoinColumn(name = \"user_id\")},\n            inverseJoinColumns = {@JoinColumn(name = \"role_id\")})\n    private Collection<Role> roles;\n\n    public String getFullName() {\n        return firstName != null ? firstName.concat(\" \").concat(lastName) : \"\";\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/model/user/UserRoles.java",
    "content": "package com.starterkit.springboot.brs.model.user;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic enum UserRoles {\n    ADMIN, PASSENGER\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/AgencyRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Agency;\nimport com.starterkit.springboot.brs.model.user.User;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface AgencyRepository extends CrudRepository<Agency, Long> {\n    Agency findByCode(String agencyCode);\n\n    Agency findByOwner(User owner);\n\n    Agency findByName(String name);\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/BusRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Agency;\nimport com.starterkit.springboot.brs.model.bus.Bus;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface BusRepository extends CrudRepository<Bus, Long> {\n    Bus findByCode(String busCode);\n\n    Bus findByCodeAndAgency(String busCode, Agency agency);\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/StopRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Stop;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface StopRepository extends CrudRepository<Stop, Long> {\n    Stop findByCode(String code);\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/TicketRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Ticket;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface TicketRepository extends CrudRepository<Ticket, Long> {\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/TripRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Agency;\nimport com.starterkit.springboot.brs.model.bus.Bus;\nimport com.starterkit.springboot.brs.model.bus.Stop;\nimport com.starterkit.springboot.brs.model.bus.Trip;\nimport org.springframework.data.repository.CrudRepository;\n\nimport java.util.List;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface TripRepository extends CrudRepository<Trip, Long> {\n    Trip findBySourceStopAndDestStopAndBus(Stop source, Stop destination, Bus bus);\n\n    List<Trip> findAllBySourceStopAndDestStop(Stop source, Stop destination);\n\n    List<Trip> findByAgency(Agency agency);\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/bus/TripScheduleRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.bus;\n\nimport com.starterkit.springboot.brs.model.bus.Trip;\nimport com.starterkit.springboot.brs.model.bus.TripSchedule;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface TripScheduleRepository extends CrudRepository<TripSchedule, Long> {\n    TripSchedule findByTripDetailAndTripDate(Trip tripDetail, String tripDate);\n}"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/user/RoleRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.user;\n\nimport com.starterkit.springboot.brs.model.user.Role;\nimport com.starterkit.springboot.brs.model.user.UserRoles;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface RoleRepository extends CrudRepository<Role, Long> {\n\n    Role findByRole(UserRoles role);\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/repository/user/UserRepository.java",
    "content": "package com.starterkit.springboot.brs.repository.user;\n\nimport com.starterkit.springboot.brs.model.user.User;\nimport org.springframework.data.repository.CrudRepository;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface UserRepository extends CrudRepository<User, Long> {\n\n    User findByEmail(String email);\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/CustomUserDetailsService.java",
    "content": "package com.starterkit.springboot.brs.security;\n\nimport com.starterkit.springboot.brs.dto.model.user.RoleDto;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.service.UserService;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.security.core.GrantedAuthority;\nimport org.springframework.security.core.authority.SimpleGrantedAuthority;\nimport org.springframework.security.core.userdetails.UserDetails;\nimport org.springframework.security.core.userdetails.UserDetailsService;\nimport org.springframework.security.core.userdetails.UsernameNotFoundException;\nimport org.springframework.stereotype.Service;\n\nimport java.util.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Service\npublic class CustomUserDetailsService implements UserDetailsService {\n\n    @Autowired\n    private UserService userService;\n\n    @Override\n    public UserDetails loadUserByUsername(String email) throws UsernameNotFoundException {\n        UserDto userDto = userService.findUserByEmail(email);\n        if (userDto != null) {\n            List<GrantedAuthority> authorities = getUserAuthority(userDto.getRoles());\n            return buildUserForAuthentication(userDto, authorities);\n        } else {\n            throw new UsernameNotFoundException(\"user with email \" + email + \" does not exist.\");\n        }\n    }\n\n    private List<GrantedAuthority> getUserAuthority(Collection<RoleDto> userRoles) {\n        Set<GrantedAuthority> roles = new HashSet<>();\n        userRoles.forEach((role) -> {\n            roles.add(new SimpleGrantedAuthority(role.getRole()));\n        });\n        return new ArrayList<GrantedAuthority>(roles);\n    }\n\n    private UserDetails buildUserForAuthentication(UserDto user, List<GrantedAuthority> authorities) {\n        return new org.springframework.security.core.userdetails.User(user.getEmail(), user.getPassword(), authorities);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/MultiHttpSecurityConfig.java",
    "content": "package com.starterkit.springboot.brs.security;\n\nimport com.starterkit.springboot.brs.security.api.ApiJWTAuthenticationFilter;\nimport com.starterkit.springboot.brs.security.api.ApiJWTAuthorizationFilter;\nimport com.starterkit.springboot.brs.security.form.CustomAuthenticationSuccessHandler;\nimport com.starterkit.springboot.brs.security.form.CustomLogoutSuccessHandler;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.context.annotation.Configuration;\nimport org.springframework.core.annotation.Order;\nimport org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;\nimport org.springframework.security.config.annotation.web.builders.HttpSecurity;\nimport org.springframework.security.config.annotation.web.builders.WebSecurity;\nimport org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;\nimport org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;\nimport org.springframework.security.config.http.SessionCreationPolicy;\nimport org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;\nimport org.springframework.security.web.util.matcher.AntPathRequestMatcher;\n\nimport javax.servlet.http.HttpServletResponse;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@EnableWebSecurity\npublic class MultiHttpSecurityConfig {\n\n    @Configuration\n    @Order(1)\n    public static class ApiWebSecurityConfigurationAdapter extends WebSecurityConfigurerAdapter {\n        @Autowired\n        private BCryptPasswordEncoder bCryptPasswordEncoder;\n\n        @Autowired\n        private CustomUserDetailsService userDetailsService;\n\n        @Override\n        protected void configure(AuthenticationManagerBuilder auth) throws Exception {\n            auth\n                    .userDetailsService(userDetailsService)\n                    .passwordEncoder(bCryptPasswordEncoder);\n        }\n\n        // @formatter:off\n        protected void configure(HttpSecurity http) throws Exception {\n            http\n                    .csrf()\n                    .disable()\n                    .antMatcher(\"/api/**\")\n                    .authorizeRequests()\n                    .antMatchers(\"/api/v1/user/signup\").permitAll()\n                    .anyRequest()\n                    .authenticated()\n                    .and()\n                    .exceptionHandling()\n                    .authenticationEntryPoint((req, rsp, e) -> rsp.sendError(HttpServletResponse.SC_UNAUTHORIZED))\n                    .and()\n                    .addFilter(new ApiJWTAuthenticationFilter(authenticationManager()))\n                    .addFilter(new ApiJWTAuthorizationFilter(authenticationManager()))\n                    .sessionManagement()\n                    .sessionCreationPolicy(SessionCreationPolicy.STATELESS);\n        }\n        // @formatter:on\n\n    }\n\n    @Order(2)\n    @Configuration\n    public static class FormLoginWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {\n        @Autowired\n        private BCryptPasswordEncoder bCryptPasswordEncoder;\n\n        @Autowired\n        private CustomAuthenticationSuccessHandler customAuthenticationSuccessHandler;\n\n        @Autowired\n        private CustomUserDetailsService userDetailsService;\n\n        @Override\n        protected void configure(AuthenticationManagerBuilder auth) throws Exception {\n            auth\n                    .userDetailsService(userDetailsService)\n                    .passwordEncoder(bCryptPasswordEncoder);\n        }\n\n        // @formatter:off\n        @Override\n        protected void configure(HttpSecurity http) throws Exception {\n            http\n                    .cors()\n                    .and()\n                    .csrf()\n                    .disable()\n                    .authorizeRequests()\n                    .antMatchers(\"/\").permitAll()\n                    .antMatchers(\"/login\").permitAll()\n                    .antMatchers(\"/signup\").permitAll()\n                    .antMatchers(\"/dashboard/**\").hasAuthority(\"ADMIN\")\n                    .anyRequest()\n                    .authenticated()\n                    .and()\n                    .formLogin()\n                    .loginPage(\"/login\")\n                    .permitAll()\n                    .failureUrl(\"/login?error=true\")\n                    .usernameParameter(\"email\")\n                    .passwordParameter(\"password\")\n                    .successHandler(customAuthenticationSuccessHandler)\n                    .and()\n                    .logout()\n                    .permitAll()\n                    .logoutRequestMatcher(new AntPathRequestMatcher(\"/logout\"))\n                    .logoutSuccessHandler(new CustomLogoutSuccessHandler())\n                    .deleteCookies(\"JSESSIONID\")\n                    .logoutSuccessUrl(\"/\")\n                    .and()\n                    .exceptionHandling();\n        }\n\n        @Override\n        public void configure(WebSecurity web) throws Exception {\n            web.ignoring().antMatchers(\n                    \"/resources/**\", \"/static/**\", \"/css/**\", \"/js/**\", \"/images/**\",\n                    \"/resources/static/**\", \"/css/**\", \"/js/**\", \"/img/**\", \"/fonts/**\",\n                    \"/images/**\", \"/scss/**\", \"/vendor/**\", \"/favicon.ico\", \"/auth/**\", \"/favicon.png\",\n                    \"/v2/api-docs\", \"/configuration/ui\", \"/configuration/security\",\n                    \"/webjars/**\", \"/swagger-resources/**\", \"/actuator\", \"/swagger-ui/**\",\n                    \"/actuator/**\", \"/swagger-ui/index.html\", \"/swagger-ui/\");\n        }\n        // @formatter:on\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/SecurityConstants.java",
    "content": "package com.starterkit.springboot.brs.security;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface SecurityConstants {\n    String SECRET = \"SecretKeyToGenJWTs\";\n    String TOKEN_PREFIX = \"Bearer \";\n    String HEADER_STRING = \"Authorization\";\n    String SIGN_UP_URL = \"/users/sign-up\";\n    long EXPIRATION_TIME = 864_000_000; // 10 days\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/api/ApiJWTAuthenticationFilter.java",
    "content": "package com.starterkit.springboot.brs.security.api;\n\nimport com.fasterxml.jackson.databind.ObjectMapper;\nimport com.starterkit.springboot.brs.model.user.User;\nimport io.jsonwebtoken.Claims;\nimport io.jsonwebtoken.Jwts;\nimport io.jsonwebtoken.SignatureAlgorithm;\nimport org.springframework.security.authentication.AuthenticationManager;\nimport org.springframework.security.authentication.UsernamePasswordAuthenticationToken;\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.core.AuthenticationException;\nimport org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;\nimport org.springframework.security.web.util.matcher.AntPathRequestMatcher;\n\nimport javax.servlet.FilterChain;\nimport javax.servlet.ServletException;\nimport javax.servlet.http.HttpServletRequest;\nimport javax.servlet.http.HttpServletResponse;\nimport java.io.IOException;\nimport java.util.ArrayList;\nimport java.util.Date;\nimport java.util.List;\n\nimport static com.starterkit.springboot.brs.security.SecurityConstants.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class ApiJWTAuthenticationFilter extends UsernamePasswordAuthenticationFilter {\n    private final AuthenticationManager authenticationManager;\n\n    public ApiJWTAuthenticationFilter(AuthenticationManager authenticationManager) {\n        this.authenticationManager = authenticationManager;\n        this.setRequiresAuthenticationRequestMatcher(new AntPathRequestMatcher(\"/api/auth\", \"POST\"));\n    }\n\n    @Override\n    public Authentication attemptAuthentication(HttpServletRequest req,\n                                                HttpServletResponse res) throws AuthenticationException {\n        try {\n            User user = new ObjectMapper().readValue(req.getInputStream(), User.class);\n            return authenticationManager.authenticate(\n                    new UsernamePasswordAuthenticationToken(\n                            user.getEmail(),\n                            user.getPassword(),\n                            new ArrayList<>())\n            );\n        } catch (IOException e) {\n            throw new RuntimeException(e);\n        }\n    }\n\n    @Override\n    protected void successfulAuthentication(HttpServletRequest req,\n                                            HttpServletResponse res,\n                                            FilterChain chain,\n                                            Authentication auth) throws IOException, ServletException {\n        if (auth.getPrincipal() != null) {\n            org.springframework.security.core.userdetails.User user = (org.springframework.security.core.userdetails.User) auth.getPrincipal();\n            String login = user.getUsername();\n            if (login != null && login.length() > 0) {\n                Claims claims = Jwts.claims().setSubject(login);\n                List<String> roles = new ArrayList<>();\n                user.getAuthorities().stream().forEach(authority -> roles.add(authority.getAuthority()));\n                claims.put(\"roles\", roles);\n                String token = Jwts.builder()\n                        .setClaims(claims)\n                        .setExpiration(new Date(System.currentTimeMillis() + EXPIRATION_TIME))\n                        .signWith(SignatureAlgorithm.HS512, SECRET)\n                        .compact();\n                res.addHeader(HEADER_STRING, TOKEN_PREFIX + token);\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/api/ApiJWTAuthorizationFilter.java",
    "content": "package com.starterkit.springboot.brs.security.api;\n\nimport io.jsonwebtoken.Claims;\nimport io.jsonwebtoken.Jwts;\nimport org.springframework.security.authentication.AuthenticationManager;\nimport org.springframework.security.authentication.UsernamePasswordAuthenticationToken;\nimport org.springframework.security.core.GrantedAuthority;\nimport org.springframework.security.core.authority.SimpleGrantedAuthority;\nimport org.springframework.security.core.context.SecurityContextHolder;\nimport org.springframework.security.web.authentication.www.BasicAuthenticationFilter;\n\nimport javax.servlet.FilterChain;\nimport javax.servlet.ServletException;\nimport javax.servlet.http.HttpServletRequest;\nimport javax.servlet.http.HttpServletResponse;\nimport java.io.IOException;\nimport java.util.ArrayList;\n\nimport static com.starterkit.springboot.brs.security.SecurityConstants.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class ApiJWTAuthorizationFilter extends BasicAuthenticationFilter {\n    public ApiJWTAuthorizationFilter(AuthenticationManager authManager) {\n        super(authManager);\n    }\n\n    @Override\n    protected void doFilterInternal(HttpServletRequest req,\n                                    HttpServletResponse res,\n                                    FilterChain chain) throws IOException, ServletException {\n        String header = req.getHeader(HEADER_STRING);\n        if (header == null || !header.startsWith(TOKEN_PREFIX)) {\n            chain.doFilter(req, res);\n            return;\n        }\n        UsernamePasswordAuthenticationToken authentication = getAuthentication(req);\n        SecurityContextHolder.getContext().setAuthentication(authentication);\n        chain.doFilter(req, res);\n    }\n\n    private UsernamePasswordAuthenticationToken getAuthentication(HttpServletRequest request) {\n        String token = request.getHeader(HEADER_STRING);\n        if (token != null) {\n            Claims claims = Jwts.parser()\n                    .setSigningKey(SECRET)\n                    .parseClaimsJws(token.replace(TOKEN_PREFIX, \"\"))\n                    .getBody();\n            // Extract the UserName\n            String user = claims.getSubject();\n            // Extract the Roles\n            ArrayList<String> roles = (ArrayList<String>) claims.get(\"roles\");\n            // Then convert Roles to GrantedAuthority Object for injecting\n            ArrayList<GrantedAuthority> list = new ArrayList<>();\n            if (roles != null) {\n                for (String a : roles) {\n                    GrantedAuthority g = new SimpleGrantedAuthority(a);\n                    list.add(g);\n                }\n            }\n            if (user != null) {\n                return new UsernamePasswordAuthenticationToken(user, null, list);\n            }\n            return null;\n        }\n        return null;\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/form/CustomAuthenticationSuccessHandler.java",
    "content": "package com.starterkit.springboot.brs.security.form;\n\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.core.GrantedAuthority;\nimport org.springframework.security.web.authentication.AuthenticationSuccessHandler;\nimport org.springframework.stereotype.Component;\n\nimport javax.servlet.ServletException;\nimport javax.servlet.http.HttpServletRequest;\nimport javax.servlet.http.HttpServletResponse;\nimport java.io.IOException;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Component\npublic class CustomAuthenticationSuccessHandler implements AuthenticationSuccessHandler {\n    @Override\n    public void onAuthenticationSuccess(HttpServletRequest request,\n                                        HttpServletResponse response, Authentication authentication)\n            throws IOException, ServletException {\n        response.setStatus(HttpServletResponse.SC_OK);\n        for (GrantedAuthority auth : authentication.getAuthorities()) {\n            if (\"ADMIN\".equals(auth.getAuthority())) {\n                response.sendRedirect(\"/dashboard\");\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/form/CustomLogoutSuccessHandler.java",
    "content": "package com.starterkit.springboot.brs.security.form;\n\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.web.authentication.logout.LogoutSuccessHandler;\nimport org.springframework.security.web.authentication.logout.SimpleUrlLogoutSuccessHandler;\n\nimport javax.servlet.ServletException;\nimport javax.servlet.http.HttpServletRequest;\nimport javax.servlet.http.HttpServletResponse;\nimport java.io.IOException;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class CustomLogoutSuccessHandler extends SimpleUrlLogoutSuccessHandler\n        implements LogoutSuccessHandler {\n    @Override\n    public void onLogoutSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) throws IOException, ServletException {\n        super.onLogoutSuccess(request, response, authentication);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/security/form/FormBasedJWTAuthenticationFilter.java",
    "content": "package com.starterkit.springboot.brs.security.form;\n\nimport com.starterkit.springboot.brs.model.user.User;\nimport io.jsonwebtoken.Claims;\nimport io.jsonwebtoken.Jwts;\nimport io.jsonwebtoken.SignatureAlgorithm;\nimport org.springframework.security.authentication.AuthenticationManager;\nimport org.springframework.security.authentication.UsernamePasswordAuthenticationToken;\nimport org.springframework.security.core.Authentication;\nimport org.springframework.security.core.AuthenticationException;\nimport org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;\n\nimport javax.servlet.FilterChain;\nimport javax.servlet.ServletException;\nimport javax.servlet.http.HttpServletRequest;\nimport javax.servlet.http.HttpServletResponse;\nimport java.io.IOException;\nimport java.util.ArrayList;\nimport java.util.Date;\nimport java.util.List;\n\nimport static com.starterkit.springboot.brs.security.SecurityConstants.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class FormBasedJWTAuthenticationFilter extends UsernamePasswordAuthenticationFilter {\n    private final AuthenticationManager authenticationManager;\n\n    public FormBasedJWTAuthenticationFilter(AuthenticationManager authenticationManager) {\n        this.authenticationManager = authenticationManager;\n    }\n\n    @Override\n    public Authentication attemptAuthentication(HttpServletRequest req,\n                                                HttpServletResponse res) throws AuthenticationException {\n        String email = req.getParameter(\"email\");\n        String password = req.getParameter(\"password\");\n        if (email != null && password != null) {\n            User user = new User().setEmail(email).setPassword(password);\n            return authenticationManager.authenticate(\n                    new UsernamePasswordAuthenticationToken(\n                            user.getEmail(),\n                            user.getPassword(),\n                            new ArrayList<>())\n            );\n        }\n\n        return null;\n    }\n\n    @Override\n    protected void successfulAuthentication(HttpServletRequest req,\n                                            HttpServletResponse res,\n                                            FilterChain chain,\n                                            Authentication auth) throws IOException, ServletException {\n        if (auth.getPrincipal() != null) {\n            // The Auth Mechanism stores the Username the Principal.\n            // The username is stored in the Subject field of the Token\n            org.springframework.security.core.userdetails.User user = (org.springframework.security.core.userdetails.User) auth.getPrincipal();\n            String login = user.getUsername();\n            if (login != null && login.length() > 0) {\n                Claims claims = Jwts.claims().setSubject(login);\n                List<String> roles = new ArrayList<>();\n                user\n                        .getAuthorities()\n                        .stream()\n                        .forEach(authority -> roles.add(authority.getAuthority()));\n\n                claims.put(\"roles\", roles);\n                String token = Jwts.builder()\n                        .setClaims(claims)\n                        .setExpiration(new Date(System.currentTimeMillis() + EXPIRATION_TIME))\n                        .signWith(SignatureAlgorithm.HS512, SECRET.getBytes())\n                        .compact();\n                res.addHeader(HEADER_STRING, TOKEN_PREFIX + token);\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/service/BusReservationService.java",
    "content": "package com.starterkit.springboot.brs.service;\n\nimport com.starterkit.springboot.brs.dto.model.bus.*;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\n\nimport java.util.List;\nimport java.util.Set;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface BusReservationService {\n\n    //Stop related methods\n    Set<StopDto> getAllStops();\n\n    StopDto getStopByCode(String stopCode);\n\n    //Agency related methods\n    AgencyDto getAgency(UserDto userDto);\n\n    AgencyDto addAgency(AgencyDto agencyDto);\n\n    AgencyDto updateAgency(AgencyDto agencyDto, BusDto busDto);\n\n    //Trip related methods\n    TripDto getTripById(Long tripID);\n\n    List<TripDto> addTrip(TripDto tripDto);\n\n    List<TripDto> getAgencyTrips(String agencyCode);\n\n    List<TripDto> getAvailableTripsBetweenStops(String sourceStopCode, String destinationStopCode);\n\n    //Trips Schedule related methods\n    List<TripScheduleDto> getAvailableTripSchedules(String sourceStopCode, String destinationStopCode, String tripDate);\n\n    TripScheduleDto getTripSchedule(TripDto tripDto, String tripDate, boolean createSchedForTrip);\n\n    //Ticket related method\n    TicketDto bookTicket(TripScheduleDto tripScheduleDto, UserDto passenger);\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/service/BusReservationServiceImpl.java",
    "content": "package com.starterkit.springboot.brs.service;\n\nimport com.starterkit.springboot.brs.dto.mapper.TicketMapper;\nimport com.starterkit.springboot.brs.dto.mapper.TripMapper;\nimport com.starterkit.springboot.brs.dto.mapper.TripScheduleMapper;\nimport com.starterkit.springboot.brs.dto.model.bus.*;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.exception.BRSException;\nimport com.starterkit.springboot.brs.exception.EntityType;\nimport com.starterkit.springboot.brs.exception.ExceptionType;\nimport com.starterkit.springboot.brs.model.bus.*;\nimport com.starterkit.springboot.brs.model.user.User;\nimport com.starterkit.springboot.brs.repository.bus.*;\nimport com.starterkit.springboot.brs.repository.user.UserRepository;\nimport com.starterkit.springboot.brs.util.RandomStringUtil;\nimport org.modelmapper.ModelMapper;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.stereotype.Component;\nimport org.springframework.transaction.annotation.Transactional;\n\nimport java.util.*;\nimport java.util.stream.Collectors;\nimport java.util.stream.StreamSupport;\n\nimport static com.starterkit.springboot.brs.exception.EntityType.*;\nimport static com.starterkit.springboot.brs.exception.ExceptionType.*;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Component\npublic class BusReservationServiceImpl implements BusReservationService {\n    @Autowired\n    private AgencyRepository agencyRepository;\n\n    @Autowired\n    private BusRepository busRepository;\n\n    @Autowired\n    private StopRepository stopRepository;\n\n    @Autowired\n    private TicketRepository ticketRepository;\n\n    @Autowired\n    private TripRepository tripRepository;\n\n    @Autowired\n    private TripScheduleRepository tripScheduleRepository;\n\n    @Autowired\n    private UserRepository userRepository;\n\n    @Autowired\n    private ModelMapper modelMapper;\n\n    /**\n     * Retruns all the available stops in the database.\n     *\n     * @return\n     */\n    @Override\n    public Set<StopDto> getAllStops() {\n        return StreamSupport\n                .stream(stopRepository.findAll().spliterator(), false)\n                .map(stop -> modelMapper.map(stop, StopDto.class))\n                .collect(Collectors.toCollection(TreeSet::new));\n    }\n\n    /**\n     * Returns the Stop details based on stop code.\n     *\n     * @param stopCode\n     * @return\n     */\n    @Override\n    public StopDto getStopByCode(String stopCode) {\n        Optional<Stop> stop = Optional.ofNullable(stopRepository.findByCode(stopCode));\n        if (stop.isPresent()) {\n            return modelMapper.map(stop.get(), StopDto.class);\n        }\n        throw exception(STOP, ENTITY_NOT_FOUND, stopCode);\n    }\n\n    /**\n     * Fetch AgencyDto from userDto\n     *\n     * @param userDto\n     * @return\n     */\n    @Override\n    public AgencyDto getAgency(UserDto userDto) {\n        User user = getUser(userDto.getEmail());\n        if (user != null) {\n            Optional<Agency> agency = Optional.ofNullable(agencyRepository.findByOwner(user));\n            if (agency.isPresent()) {\n                return modelMapper.map(agency.get(), AgencyDto.class);\n            }\n            throw exceptionWithId(AGENCY, ENTITY_NOT_FOUND, 2, user.getEmail());\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, userDto.getEmail());\n    }\n\n    /**\n     * Register a new agency from the Admin signup flow\n     *\n     * @param agencyDto\n     * @return\n     */\n    @Override\n    public AgencyDto addAgency(AgencyDto agencyDto) {\n        User admin = getUser(agencyDto.getOwner().getEmail());\n        if (admin != null) {\n            Optional<Agency> agency = Optional.ofNullable(agencyRepository.findByName(agencyDto.getName()));\n            if (!agency.isPresent()) {\n                Agency agencyModel = new Agency()\n                        .setName(agencyDto.getName())\n                        .setDetails(agencyDto.getDetails())\n                        .setCode(RandomStringUtil.getAlphaNumericString(8, agencyDto.getName()))\n                        .setOwner(admin);\n                agencyRepository.save(agencyModel);\n                return modelMapper.map(agencyModel, AgencyDto.class);\n            }\n            throw exception(AGENCY, DUPLICATE_ENTITY, agencyDto.getName());\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, agencyDto.getOwner().getEmail());\n    }\n\n    /**\n     * Updates the agency with given Bus information\n     *\n     * @param agencyDto\n     * @param busDto\n     * @return\n     */\n    @Transactional\n    public AgencyDto updateAgency(AgencyDto agencyDto, BusDto busDto) {\n        Agency agency = getAgency(agencyDto.getCode());\n        if (agency != null) {\n            if (busDto != null) {\n                Optional<Bus> bus = Optional.ofNullable(busRepository.findByCodeAndAgency(busDto.getCode(), agency));\n                if (!bus.isPresent()) {\n                    Bus busModel = new Bus()\n                            .setAgency(agency)\n                            .setCode(busDto.getCode())\n                            .setCapacity(busDto.getCapacity())\n                            .setMake(busDto.getMake());\n                    busRepository.save(busModel);\n                    if (agency.getBuses() == null) {\n                        agency.setBuses(new HashSet<>());\n                    }\n                    agency.getBuses().add(busModel);\n                    return modelMapper.map(agencyRepository.save(agency), AgencyDto.class);\n                }\n                throw exceptionWithId(BUS, DUPLICATE_ENTITY, 2, busDto.getCode(), agencyDto.getCode());\n            } else {\n                //update agency details case\n                agency.setName(agencyDto.getName())\n                        .setDetails(agencyDto.getDetails());\n                return modelMapper.map(agencyRepository.save(agency), AgencyDto.class);\n            }\n        }\n        throw exceptionWithId(AGENCY, ENTITY_NOT_FOUND, 2, agencyDto.getOwner().getEmail());\n    }\n\n    /**\n     * Returns trip details basd on trip_id\n     *\n     * @param tripID\n     * @return\n     */\n    @Override\n    public TripDto getTripById(Long tripID) {\n        Optional<Trip> trip = tripRepository.findById(tripID);\n        if (trip.isPresent()) {\n            return TripMapper.toTripDto(trip.get());\n        }\n        throw exception(TRIP, ENTITY_NOT_FOUND, tripID.toString());\n    }\n\n    /**\n     * Creates two new Trips with the given information in tripDto object\n     *\n     * @param tripDto\n     * @return\n     */\n    @Override\n    @Transactional\n    public List<TripDto> addTrip(TripDto tripDto) {\n        Stop sourceStop = getStop(tripDto.getSourceStopCode());\n        if (sourceStop != null) {\n            Stop destinationStop = getStop(tripDto.getDestinationStopCode());\n            if (destinationStop != null) {\n                if (!sourceStop.getCode().equalsIgnoreCase(destinationStop.getCode())) {\n                    Agency agency = getAgency(tripDto.getAgencyCode());\n                    if (agency != null) {\n                        Bus bus = getBus(tripDto.getBusCode());\n                        if (bus != null) {\n                            //Each new trip creation results in a to and a fro trip\n                            List<TripDto> trips = new ArrayList<>(2);\n                            Trip toTrip = new Trip()\n                                    .setSourceStop(sourceStop)\n                                    .setDestStop(destinationStop)\n                                    .setAgency(agency)\n                                    .setBus(bus)\n                                    .setJourneyTime(tripDto.getJourneyTime())\n                                    .setFare(tripDto.getFare());\n                            trips.add(TripMapper.toTripDto(tripRepository.save(toTrip)));\n\n                            Trip froTrip = new Trip()\n                                    .setSourceStop(destinationStop)\n                                    .setDestStop(sourceStop)\n                                    .setAgency(agency)\n                                    .setBus(bus)\n                                    .setJourneyTime(tripDto.getJourneyTime())\n                                    .setFare(tripDto.getFare());\n                            trips.add(TripMapper.toTripDto(tripRepository.save(froTrip)));\n                            return trips;\n                        }\n                        throw exception(BUS, ENTITY_NOT_FOUND, tripDto.getBusCode());\n                    }\n                    throw exception(AGENCY, ENTITY_NOT_FOUND, tripDto.getAgencyCode());\n                }\n                throw exception(TRIP, ENTITY_EXCEPTION, \"\");\n            }\n            throw exception(STOP, ENTITY_NOT_FOUND, tripDto.getDestinationStopCode());\n        }\n        throw exception(STOP, ENTITY_NOT_FOUND, tripDto.getSourceStopCode());\n    }\n\n    /**\n     * Fetch all the trips for a given agency\n     *\n     * @param agencyCode\n     * @return\n     */\n    @Override\n    public List<TripDto> getAgencyTrips(String agencyCode) {\n        Agency agency = getAgency(agencyCode);\n        if (agency != null) {\n            List<Trip> agencyTrips = tripRepository.findByAgency(agency);\n            if (!agencyTrips.isEmpty()) {\n                return agencyTrips\n                        .stream()\n                        .map(trip -> TripMapper.toTripDto(trip))\n                        .collect(Collectors.toList());\n            }\n            return Collections.emptyList();\n        }\n        throw exception(AGENCY, ENTITY_NOT_FOUND, agencyCode);\n    }\n\n    /**\n     * Returns a list of trips between given source and destination stops.\n     *\n     * @param sourceStopCode\n     * @param destinationStopCode\n     * @return\n     */\n    @Override\n    public List<TripDto> getAvailableTripsBetweenStops(String sourceStopCode, String destinationStopCode) {\n        List<Trip> availableTrips = findTripsBetweenStops(sourceStopCode, destinationStopCode);\n        if (!availableTrips.isEmpty()) {\n            return availableTrips\n                    .stream()\n                    .map(trip -> TripMapper.toTripDto(trip))\n                    .collect(Collectors.toList());\n        }\n        return Collections.emptyList();\n    }\n\n    /**\n     * Function to locate all the trips between src and dest stops and then\n     * filter the results as per the given date based on data present in\n     * trip schedule collection.\n     *\n     * @param sourceStopCode\n     * @param destinationStopCode\n     * @param tripDate\n     * @return list of tripschedules on given date\n     */\n    @Override\n    public List<TripScheduleDto> getAvailableTripSchedules(String sourceStopCode, String destinationStopCode, String tripDate) {\n        List<Trip> availableTrips = findTripsBetweenStops(sourceStopCode, destinationStopCode);\n        if (!availableTrips.isEmpty()) {\n            return availableTrips\n                    .stream()\n                    .map(trip -> getTripSchedule(TripMapper.toTripDto(trip), tripDate, true))\n                    .filter(tripScheduleDto -> tripScheduleDto != null)\n                    .collect(Collectors.toList());\n        }\n        return Collections.emptyList();\n    }\n\n    /**\n     * Returns TripScheduleDto based on trip details and trip date,\n     * optionally creates a schedule if its not found and if the createSchedForTrip\n     * parameter is set to true.\n     *\n     * @param tripDto\n     * @param tripDate\n     * @param createSchedForTrip\n     * @return\n     */\n    @Override\n    public TripScheduleDto getTripSchedule(TripDto tripDto, String tripDate, boolean createSchedForTrip) {\n        Optional<Trip> trip = tripRepository.findById(tripDto.getId());\n        if (trip.isPresent()) {\n            Optional<TripSchedule> tripSchedule = Optional.ofNullable(tripScheduleRepository.findByTripDetailAndTripDate(trip.get(), tripDate));\n            if (tripSchedule.isPresent()) {\n                return TripScheduleMapper.toTripScheduleDto(tripSchedule.get());\n            } else {\n                if (createSchedForTrip) { //create the schedule\n                    TripSchedule tripSchedule1 = new TripSchedule()\n                            .setTripDetail(trip.get())\n                            .setTripDate(tripDate)\n                            .setAvailableSeats(trip.get().getBus().getCapacity());\n                    return TripScheduleMapper.toTripScheduleDto(tripScheduleRepository.save(tripSchedule1));\n                } else {\n                    throw exceptionWithId(TRIP, ENTITY_NOT_FOUND, 2, tripDto.getId().toString(), tripDate);\n                }\n            }\n        }\n        throw exception(TRIP, ENTITY_NOT_FOUND, tripDto.getId().toString());\n    }\n\n    /**\n     * Method to book ticket for a given trip schedule\n     *\n     * @param tripScheduleDto\n     * @param userDto\n     * @return\n     */\n    @Override\n    @Transactional\n    public TicketDto bookTicket(TripScheduleDto tripScheduleDto, UserDto userDto) {\n        User user = getUser(userDto.getEmail());\n        if (user != null) {\n            Optional<TripSchedule> tripSchedule = tripScheduleRepository.findById(tripScheduleDto.getId());\n            if (tripSchedule.isPresent()) {\n                Ticket ticket = new Ticket()\n                        .setCancellable(false)\n                        .setJourneyDate(tripSchedule.get().getTripDate())\n                        .setPassenger(user)\n                        .setTripSchedule(tripSchedule.get())\n                        .setSeatNumber(tripSchedule.get().getTripDetail().getBus().getCapacity() - tripSchedule.get().getAvailableSeats());\n                ticketRepository.save(ticket);\n                tripSchedule.get().setAvailableSeats(tripSchedule.get().getAvailableSeats() - 1); //reduce availability by 1\n                tripScheduleRepository.save(tripSchedule.get());//update schedule\n                return TicketMapper.toTicketDto(ticket);\n            }\n            throw exceptionWithId(TRIP, ENTITY_NOT_FOUND, 2, tripScheduleDto.getTripId().toString(), tripScheduleDto.getTripDate());\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, userDto.getEmail());\n    }\n\n    /**\n     * Search for all Trips between src and dest stops\n     *\n     * @param sourceStopCode\n     * @param destinationStopCode\n     * @return\n     */\n    private List<Trip> findTripsBetweenStops(String sourceStopCode, String destinationStopCode) {\n        Optional<Stop> sourceStop = Optional\n                .ofNullable(stopRepository.findByCode(sourceStopCode));\n        if (sourceStop.isPresent()) {\n            Optional<Stop> destStop = Optional\n                    .ofNullable(stopRepository.findByCode(destinationStopCode));\n            if (destStop.isPresent()) {\n                List<Trip> availableTrips = tripRepository.findAllBySourceStopAndDestStop(sourceStop.get(), destStop.get());\n                if (!availableTrips.isEmpty()) {\n                    return availableTrips;\n                }\n                return Collections.emptyList();\n            }\n            throw exception(STOP, ENTITY_NOT_FOUND, destinationStopCode);\n        }\n        throw exception(STOP, ENTITY_NOT_FOUND, sourceStopCode);\n    }\n\n    /**\n     * Fetch user from UserDto\n     *\n     * @param email\n     * @return\n     */\n    private User getUser(String email) {\n        return userRepository.findByEmail(email);\n    }\n\n    /**\n     * Fetch Stop from stopCode\n     *\n     * @param stopCode\n     * @return\n     */\n    private Stop getStop(String stopCode) {\n        return stopRepository.findByCode(stopCode);\n    }\n\n    /**\n     * Fetch Bus from busCode, since it is unique we don't have issues of finding duplicate Buses\n     *\n     * @param busCode\n     * @return\n     */\n    private Bus getBus(String busCode) {\n        return busRepository.findByCode(busCode);\n    }\n\n    /**\n     * Fetch Agency from agencyCode\n     *\n     * @param agencyCode\n     * @return\n     */\n    private Agency getAgency(String agencyCode) {\n        return agencyRepository.findByCode(agencyCode);\n    }\n\n    /**\n     * Returns a new RuntimeException\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param args\n     * @return\n     */\n    private RuntimeException exception(EntityType entityType, ExceptionType exceptionType, String... args) {\n        return BRSException.throwException(entityType, exceptionType, args);\n    }\n\n    /**\n     * Returns a new RuntimeException\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param args\n     * @return\n     */\n    private RuntimeException exceptionWithId(EntityType entityType, ExceptionType exceptionType, Integer id, String... args) {\n        return BRSException.throwExceptionWithId(entityType, exceptionType, id, args);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/service/UserService.java",
    "content": "package com.starterkit.springboot.brs.service;\n\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic interface UserService {\n    /**\n     * Register a new user\n     *\n     * @param userDto\n     * @return\n     */\n    UserDto signup(UserDto userDto);\n\n    /**\n     * Search an existing user\n     *\n     * @param email\n     * @return\n     */\n    UserDto findUserByEmail(String email);\n\n    /**\n     * Update profile of the user\n     *\n     * @param userDto\n     * @return\n     */\n    UserDto updateProfile(UserDto userDto);\n\n    /**\n     * Update password\n     *\n     * @param newPassword\n     * @return\n     */\n    UserDto changePassword(UserDto userDto, String newPassword);\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/service/UserServiceImpl.java",
    "content": "package com.starterkit.springboot.brs.service;\n\nimport com.starterkit.springboot.brs.dto.mapper.UserMapper;\nimport com.starterkit.springboot.brs.dto.model.user.UserDto;\nimport com.starterkit.springboot.brs.exception.BRSException;\nimport com.starterkit.springboot.brs.exception.EntityType;\nimport com.starterkit.springboot.brs.exception.ExceptionType;\nimport com.starterkit.springboot.brs.model.user.Role;\nimport com.starterkit.springboot.brs.model.user.User;\nimport com.starterkit.springboot.brs.model.user.UserRoles;\nimport com.starterkit.springboot.brs.repository.user.RoleRepository;\nimport com.starterkit.springboot.brs.repository.user.UserRepository;\nimport org.modelmapper.ModelMapper;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;\nimport org.springframework.stereotype.Component;\nimport org.springframework.transaction.annotation.Transactional;\n\nimport java.util.Arrays;\nimport java.util.HashSet;\nimport java.util.Optional;\n\nimport static com.starterkit.springboot.brs.exception.EntityType.USER;\nimport static com.starterkit.springboot.brs.exception.ExceptionType.DUPLICATE_ENTITY;\nimport static com.starterkit.springboot.brs.exception.ExceptionType.ENTITY_NOT_FOUND;\n\n/**\n * Created by Arpit Khandelwal.\n */\n@Component\npublic class UserServiceImpl implements UserService {\n    @Autowired\n    private BCryptPasswordEncoder bCryptPasswordEncoder;\n\n    @Autowired\n    private RoleRepository roleRepository;\n\n    @Autowired\n    private UserRepository userRepository;\n\n    @Autowired\n    private BusReservationService busReservationService;\n\n    @Autowired\n    private ModelMapper modelMapper;\n\n    @Override\n    public UserDto signup(UserDto userDto) {\n        Role userRole;\n        User user = userRepository.findByEmail(userDto.getEmail());\n        if (user == null) {\n            if (userDto.isAdmin()) {\n                userRole = roleRepository.findByRole(UserRoles.ADMIN);\n            } else {\n                userRole = roleRepository.findByRole(UserRoles.PASSENGER);\n            }\n            user = new User()\n                    .setEmail(userDto.getEmail())\n                    .setPassword(bCryptPasswordEncoder.encode(userDto.getPassword()))\n                    .setRoles(new HashSet<>(Arrays.asList(userRole)))\n                    .setFirstName(userDto.getFirstName())\n                    .setLastName(userDto.getLastName())\n                    .setMobileNumber(userDto.getMobileNumber());\n            return UserMapper.toUserDto(userRepository.save(user));\n        }\n        throw exception(USER, DUPLICATE_ENTITY, userDto.getEmail());\n    }\n\n    /**\n     * Search an existing user\n     *\n     * @param email\n     * @return\n     */\n    @Transactional\n    public UserDto findUserByEmail(String email) {\n        Optional<User> user = Optional.ofNullable(userRepository.findByEmail(email));\n        if (user.isPresent()) {\n            return modelMapper.map(user.get(), UserDto.class);\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, email);\n    }\n\n    /**\n     * Update User Profile\n     *\n     * @param userDto\n     * @return\n     */\n    @Override\n    public UserDto updateProfile(UserDto userDto) {\n        Optional<User> user = Optional.ofNullable(userRepository.findByEmail(userDto.getEmail()));\n        if (user.isPresent()) {\n            User userModel = user.get();\n            userModel.setFirstName(userDto.getFirstName())\n                    .setLastName(userDto.getLastName())\n                    .setMobileNumber(userDto.getMobileNumber());\n            return UserMapper.toUserDto(userRepository.save(userModel));\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, userDto.getEmail());\n    }\n\n    /**\n     * Change Password\n     *\n     * @param userDto\n     * @param newPassword\n     * @return\n     */\n    @Override\n    public UserDto changePassword(UserDto userDto, String newPassword) {\n        Optional<User> user = Optional.ofNullable(userRepository.findByEmail(userDto.getEmail()));\n        if (user.isPresent()) {\n            User userModel = user.get();\n            userModel.setPassword(bCryptPasswordEncoder.encode(newPassword));\n            return UserMapper.toUserDto(userRepository.save(userModel));\n        }\n        throw exception(USER, ENTITY_NOT_FOUND, userDto.getEmail());\n    }\n\n    /**\n     * Returns a new RuntimeException\n     *\n     * @param entityType\n     * @param exceptionType\n     * @param args\n     * @return\n     */\n    private RuntimeException exception(EntityType entityType, ExceptionType exceptionType, String... args) {\n        return BRSException.throwException(entityType, exceptionType, args);\n    }\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/util/DateUtils.java",
    "content": "package com.starterkit.springboot.brs.util;\n\nimport java.text.SimpleDateFormat;\nimport java.util.Date;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class DateUtils {\n\n    private static final SimpleDateFormat sdf = new SimpleDateFormat(\"yyyy-MM-dd\");\n\n    /**\n     * Returns today's date as java.util.Date object\n     *\n     * @return today's date as java.util.Date object\n     */\n    public static Date today() {\n        return new Date();\n    }\n\n    /**\n     * Returns today's date as yyyy-MM-dd format\n     *\n     * @return today's date as yyyy-MM-dd format\n     */\n    public static String todayStr() {\n        return sdf.format(today());\n    }\n\n    /**\n     * Returns the formatted String date for the passed java.util.Date object\n     *\n     * @param date\n     * @return\n     */\n    public static String formattedDate(Date date) {\n        return date != null ? sdf.format(date) : todayStr();\n    }\n\n}\n"
  },
  {
    "path": "src/main/java/com/starterkit/springboot/brs/util/RandomStringUtil.java",
    "content": "package com.starterkit.springboot.brs.util;\n\n/**\n * Created by Arpit Khandelwal.\n */\npublic class RandomStringUtil {\n    // function to generate a random string of length n\n    public static String getAlphaNumericString(int n, String inputString) {\n\n        // chose a Character random from this String\n        String inputStringUcase = inputString.trim().toUpperCase().replaceAll(\" \", \"\").concat(\"123456789\");\n\n        // create StringBuffer size of inputString\n        StringBuilder sb = new StringBuilder(n);\n\n        for (int i = 0; i < n; i++) {\n\n            // generate a random number between\n            // 0 to inputString variable length\n            int index\n                    = (int) (inputStringUcase.length()\n                    * Math.random());\n\n            // add Character one by one in end of sb\n            sb.append(inputStringUcase\n                    .charAt(index));\n        }\n\n        return sb.toString();\n    }\n}\n\n"
  },
  {
    "path": "src/main/resources/application-prod.properties",
    "content": "#Default server port\nserver.port=8080"
  },
  {
    "path": "src/main/resources/application-uat.properties",
    "content": "#Default server port\nserver.port=8090"
  },
  {
    "path": "src/main/resources/application.properties",
    "content": "#Default server port\nserver.port=8080\n\n## MySQL\nspring.datasource.url=jdbc:mysql://${DB_HOST:localhost}:${DB_PORT:3306}/${DB_NAME:brs}?useSSL=false&allowPublicKeyRetrieval=true\nspring.datasource.username=${MYSQL_USER:root}\nspring.datasource.password=${MYSQL_USER_PASSWORD:root}\n\n# drop n create table, good for testing, comment this in production\nspring.jpa.hibernate.ddl-auto=update\nspring.jpa.show-sql=${SHOW_SQL:false}\n\n#Set active profile\nspring.profiles.active=@activatedProperties@\n\nlogging.level.web=${LOG_LEVEL:DEBUG}\nmanagement.endpoints.web.exposure.include=*\nserver.error.whitelabel.enabled=false"
  },
  {
    "path": "src/main/resources/banner.txt",
    "content": " +-+ +-+ +-+   +-+ +-+ +-+ +-+ +-+ +-+ +-+ +-+   +-+ +-+ +-+\n |T| |h| |e|   |R| |e| |s| |o| |n| |a| |n| |t|   |W| |e| |b|\n +-+ +-+ +-+   +-+ +-+ +-+ +-+ +-+ +-+ +-+ +-+   +-+ +-+ +-+"
  },
  {
    "path": "src/main/resources/custom.properties",
    "content": "#Exception Messages\nstop.not.found=Requested stop with code - {0} does not exist.\nstop.duplicate=Stop with code - {0} already exists.\nagency.not.found=Agency with code - {0} does not exist.\nagency.not.found.2=User with email - {0} does not own any agency yet.\nagency.duplicate=The Agency with code/Name - {0} already exists.\nuser.not.found=Requested user with email - {0} does not exist.\nuser.duplicate=User with email - {0} already exists.\nbus.duplicate=The Bus with code - {0} already exists.\nbus.duplicate.2=The Bus with code - {0} already exists under agency - {1}.\ntrip.not.found=Requested trip with id - {0} does not exist.\ntrip.duplicate=Trip with id - {0} already exists.\ntrip.exception=The source and destination stops cannot be the same, please select different stop codes.\ntripschedule.not.found=Requested schedule for Trip with ID - {0} does not exist.\ntripschedule.not.found.2=Requested schedule for Trip with ID - {0} and Journey Date - {1} does not exist."
  },
  {
    "path": "src/main/resources/static/auth/css/style.css",
    "content": "/* @extend display-flex; */\r\ndisplay-flex, .display-flex, .display-flex-center, .signup-content, .signin-content, .social-login, .socials {\r\n  display: flex;\r\n  display: -webkit-flex; }\r\n\r\n/* @extend list-type-ulli; */\r\nlist-type-ulli, .socials {\r\n  list-style-type: none;\r\n  margin: 0;\r\n  padding: 0; }\r\n\r\n/* poppins-300 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 300;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-300.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Light\"), local(\"Poppins-Light\"), url(\"../fonts/poppins/poppins-v5-latin-300.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-300.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-300.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-300.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-300.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-300italic - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: italic;\r\n  font-weight: 300;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-300italic.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Light Italic\"), local(\"Poppins-LightItalic\"), url(\"../fonts/poppins/poppins-v5-latin-300italic.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-300italic.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-300italic.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-300italic.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-300italic.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-regular - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 400;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-regular.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Regular\"), local(\"Poppins-Regular\"), url(\"../fonts/poppins/poppins-v5-latin-regular.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-regular.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-regular.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-regular.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-regular.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-italic - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: italic;\r\n  font-weight: 400;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-italic.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Italic\"), local(\"Poppins-Italic\"), url(\"../fonts/poppins/poppins-v5-latin-italic.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-italic.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-italic.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-italic.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-italic.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-500 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 500;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-500.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Medium\"), local(\"Poppins-Medium\"), url(\"../fonts/poppins/poppins-v5-latin-500.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-500.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-500.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-500.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-500.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-500italic - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: italic;\r\n  font-weight: 500;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-500italic.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Medium Italic\"), local(\"Poppins-MediumItalic\"), url(\"../fonts/poppins/poppins-v5-latin-500italic.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-500italic.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-500italic.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-500italic.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-500italic.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-600 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 600;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-600.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins SemiBold\"), local(\"Poppins-SemiBold\"), url(\"../fonts/poppins/poppins-v5-latin-600.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-600.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-600.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-600.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-600.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-700 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 700;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-700.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Bold\"), local(\"Poppins-Bold\"), url(\"../fonts/poppins/poppins-v5-latin-700.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-700.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-700.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-700.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-700.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-700italic - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: italic;\r\n  font-weight: 700;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-700italic.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Bold Italic\"), local(\"Poppins-BoldItalic\"), url(\"../fonts/poppins/poppins-v5-latin-700italic.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-700italic.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-700italic.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-700italic.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-700italic.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-800 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 800;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-800.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins ExtraBold\"), local(\"Poppins-ExtraBold\"), url(\"../fonts/poppins/poppins-v5-latin-800.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-800.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-800.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-800.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-800.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-800italic - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: italic;\r\n  font-weight: 800;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-800italic.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins ExtraBold Italic\"), local(\"Poppins-ExtraBoldItalic\"), url(\"../fonts/poppins/poppins-v5-latin-800italic.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-800italic.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-800italic.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-800italic.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-800italic.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\n/* poppins-900 - latin */\r\n@font-face {\r\n  font-family: 'Poppins';\r\n  font-style: normal;\r\n  font-weight: 900;\r\n  src: url(\"../fonts/poppins/poppins-v5-latin-900.eot\");\r\n  /* IE9 Compat Modes */\r\n  src: local(\"Poppins Black\"), local(\"Poppins-Black\"), url(\"../fonts/poppins/poppins-v5-latin-900.eot?#iefix\") format(\"embedded-opentype\"), url(\"../fonts/poppins/poppins-v5-latin-900.woff2\") format(\"woff2\"), url(\"../fonts/poppins/poppins-v5-latin-900.woff\") format(\"woff\"), url(\"../fonts/poppins/poppins-v5-latin-900.ttf\") format(\"truetype\"), url(\"../fonts/poppins/poppins-v5-latin-900.svg#Poppins\") format(\"svg\");\r\n  /* Legacy iOS */ }\r\na:focus, a:active {\r\n  text-decoration: none;\r\n  outline: none;\r\n  transition: all 300ms ease 0s;\r\n  -moz-transition: all 300ms ease 0s;\r\n  -webkit-transition: all 300ms ease 0s;\r\n  -o-transition: all 300ms ease 0s;\r\n  -ms-transition: all 300ms ease 0s; }\r\n\r\ninput, select, textarea {\r\n  outline: none;\r\n  appearance: unset !important;\r\n  -moz-appearance: unset !important;\r\n  -webkit-appearance: unset !important;\r\n  -o-appearance: unset !important;\r\n  -ms-appearance: unset !important; }\r\n\r\ninput::-webkit-outer-spin-button, input::-webkit-inner-spin-button {\r\n  appearance: none !important;\r\n  -moz-appearance: none !important;\r\n  -webkit-appearance: none !important;\r\n  -o-appearance: none !important;\r\n  -ms-appearance: none !important;\r\n  margin: 0; }\r\n\r\ninput:focus, select:focus, textarea:focus {\r\n  outline: none;\r\n  box-shadow: none !important;\r\n  -moz-box-shadow: none !important;\r\n  -webkit-box-shadow: none !important;\r\n  -o-box-shadow: none !important;\r\n  -ms-box-shadow: none !important; }\r\n\r\ninput[type=checkbox] {\r\n  appearance: checkbox !important;\r\n  -moz-appearance: checkbox !important;\r\n  -webkit-appearance: checkbox !important;\r\n  -o-appearance: checkbox !important;\r\n  -ms-appearance: checkbox !important; }\r\n\r\ninput[type=radio] {\r\n  appearance: radio !important;\r\n  -moz-appearance: radio !important;\r\n  -webkit-appearance: radio !important;\r\n  -o-appearance: radio !important;\r\n  -ms-appearance: radio !important; }\r\n\r\nimg {\r\n  max-width: 100%;\r\n  height: auto; }\r\n\r\nfigure {\r\n  margin: 0; }\r\n\r\np {\r\n  margin-bottom: 0px;\r\n  font-size: 15px;\r\n  color: #777; }\r\n\r\nh2 {\r\n  line-height: 1.66;\r\n  margin: 0;\r\n  padding: 0;\r\n  font-weight: bold;\r\n  color: #222;\r\n  font-family: Poppins;\r\n  font-size: 36px; }\r\n\r\n\r\n.main {\r\n  background: #f8f8f8; }\r\n\r\n.clear {\r\n  clear: both; }\r\n\r\nbody {\r\n  font-size: 13px;\r\n  line-height: 1.8;\r\n  color: #222;\r\n  background: #f8f8f8;\r\n  font-weight: 400;\r\n  font-family: Poppins; }\r\n\r\n.container {\r\n  width: 900px;\r\n  background: #fff;\r\n  margin: 0 auto;\r\n  box-shadow: 0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05);\r\n  -moz-box-shadow: 0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05);\r\n  -webkit-box-shadow: 0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05);\r\n  -o-box-shadow: 0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05);\r\n  -ms-box-shadow: 0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05);\r\n  border-radius: 20px;\r\n  -moz-border-radius: 20px;\r\n  -webkit-border-radius: 20px;\r\n  -o-border-radius: 20px;\r\n  -ms-border-radius: 20px; }\r\n\r\n.display-flex {\r\n  justify-content: space-between;\r\n  -moz-justify-content: space-between;\r\n  -webkit-justify-content: space-between;\r\n  -o-justify-content: space-between;\r\n  -ms-justify-content: space-between;\r\n  align-items: center;\r\n  -moz-align-items: center;\r\n  -webkit-align-items: center;\r\n  -o-align-items: center;\r\n  -ms-align-items: center; }\r\n\r\n.display-flex-center {\r\n  justify-content: center;\r\n  -moz-justify-content: center;\r\n  -webkit-justify-content: center;\r\n  -o-justify-content: center;\r\n  -ms-justify-content: center;\r\n  align-items: center;\r\n  -moz-align-items: center;\r\n  -webkit-align-items: center;\r\n  -o-align-items: center;\r\n  -ms-align-items: center; }\r\n\r\n.position-center {\r\n  position: absolute;\r\n  top: 50%;\r\n  left: 50%;\r\n  transform: translate(-50%, -50%);\r\n  -moz-transform: translate(-50%, -50%);\r\n  -webkit-transform: translate(-50%, -50%);\r\n  -o-transform: translate(-50%, -50%);\r\n  -ms-transform: translate(-50%, -50%); }\r\n\r\n.signup {\r\n  margin-bottom: 150px; }\r\n\r\n.signup-content {\r\n  padding: 75px 0; }\r\n\r\n.signup-form, .signup-image, .signin-form, .signin-image {\r\n  width: 50%;\r\n  overflow: hidden; }\r\n\r\n.signup-image {\r\n  margin: 0 55px; }\r\n\r\n.form-title {\r\n  margin-bottom: 33px; }\r\n\r\n.signup-image {\r\n  margin-top: 45px; }\r\n\r\n.text-danger {\r\n  color: #fc4b6c !important; }\r\n\r\nfigure {\r\n  margin-bottom: 50px;\r\n  text-align: center; }\r\n\r\n.form-submit {\r\n  display: inline-block;\r\n  background: #6dabe4;\r\n  color: #fff;\r\n  border-bottom: none;\r\n  width: auto;\r\n  padding: 15px 39px;\r\n  border-radius: 5px;\r\n  -moz-border-radius: 5px;\r\n  -webkit-border-radius: 5px;\r\n  -o-border-radius: 5px;\r\n  -ms-border-radius: 5px;\r\n  margin-top: 25px;\r\n  cursor: pointer; }\r\n  .form-submit:hover {\r\n    background: #4292dc; }\r\n\r\n#signin {\r\n  margin-top: 16px; }\r\n\r\n.signup-image-link {\r\n  font-size: 14px;\r\n  color: #222;\r\n  display: block;\r\n  text-align: center; }\r\n\r\n.term-service {\r\n  font-size: 13px;\r\n  color: #222; }\r\n\r\n.signup-form {\r\n  margin-left: 75px;\r\n  margin-right: 75px;\r\n  padding-left: 34px; }\r\n\r\n.register-form {\r\n  width: 100%; }\r\n\r\n.form-group {\r\n  position: relative;\r\n  margin-bottom: 25px;\r\n  overflow: hidden; }\r\n  .form-group:last-child {\r\n    margin-bottom: 0px; }\r\n\r\ninput {\r\n  width: 100%;\r\n  display: block;\r\n  border: none;\r\n  border-bottom: 1px solid #999;\r\n  padding: 6px 30px;\r\n  font-family: Poppins;\r\n  box-sizing: border-box; }\r\n  input::-webkit-input-placeholder {\r\n    color: #999; }\r\n  input::-moz-placeholder {\r\n    color: #999; }\r\n  input:-ms-input-placeholder {\r\n    color: #999; }\r\n  input:-moz-placeholder {\r\n    color: #999; }\r\n  input:focus {\r\n    border-bottom: 1px solid #222; }\r\n    input:focus::-webkit-input-placeholder {\r\n      color: #222; }\r\n    input:focus::-moz-placeholder {\r\n      color: #222; }\r\n    input:focus:-ms-input-placeholder {\r\n      color: #222; }\r\n    input:focus:-moz-placeholder {\r\n      color: #222; }\r\n\r\ninput[type=checkbox]:not(old) {\r\n  width: 2em;\r\n  margin: 0;\r\n  padding: 0;\r\n  font-size: 1em;\r\n  display: none; }\r\n\r\ninput[type=checkbox]:not(old) + label {\r\n  display: inline-block;\r\n  line-height: 1.5em;\r\n  margin-top: 6px; }\r\n\r\ninput[type=checkbox]:not(old) + label > span {\r\n  display: inline-block;\r\n  width: 13px;\r\n  height: 13px;\r\n  margin-right: 15px;\r\n  margin-bottom: 3px;\r\n  border: 1px solid #999;\r\n  border-radius: 2px;\r\n  -moz-border-radius: 2px;\r\n  -webkit-border-radius: 2px;\r\n  -o-border-radius: 2px;\r\n  -ms-border-radius: 2px;\r\n  background: white;\r\n  background-image: -moz-linear-gradient(white, white);\r\n  background-image: -ms-linear-gradient(white, white);\r\n  background-image: -o-linear-gradient(white, white);\r\n  background-image: -webkit-linear-gradient(white, white);\r\n  background-image: linear-gradient(white, white);\r\n  vertical-align: bottom; }\r\n\r\ninput[type=checkbox]:not(old):checked + label > span {\r\n  background-image: -moz-linear-gradient(white, white);\r\n  background-image: -ms-linear-gradient(white, white);\r\n  background-image: -o-linear-gradient(white, white);\r\n  background-image: -webkit-linear-gradient(white, white);\r\n  background-image: linear-gradient(white, white); }\r\n\r\ninput[type=checkbox]:not(old):checked + label > span:before {\r\n  content: '\\f26b';\r\n  display: block;\r\n  color: #222;\r\n  font-size: 11px;\r\n  line-height: 1.2;\r\n  text-align: center;\r\n  font-family: 'Material-Design-Iconic-Font';\r\n  font-weight: bold; }\r\n\r\n.agree-term {\r\n  display: inline-block;\r\n  width: auto; }\r\n\r\nlabel {\r\n  position: absolute;\r\n  left: 0;\r\n  top: 15px;\r\n  transform: translateY(-50%);\r\n  -moz-transform: translateY(-50%);\r\n  -webkit-transform: translateY(-50%);\r\n  -o-transform: translateY(-50%);\r\n  -ms-transform: translateY(-50%);\r\n  color: #222; }\r\n\r\n.label-has-error {\r\n  top: 22%; }\r\n\r\nlabel.error {\r\n  position: relative;\r\n  background: url(\"../images/unchecked.gif\") no-repeat;\r\n  background-position-y: 3px;\r\n  padding-left: 20px;\r\n  display: block;\r\n  margin-top: 20px; }\r\n\r\nlabel.valid {\r\n  display: block;\r\n  position: absolute;\r\n  right: 0;\r\n  left: auto;\r\n  margin-top: -6px;\r\n  width: 20px;\r\n  height: 20px;\r\n  background: transparent; }\r\n  label.valid:after {\r\n    font-family: 'Material-Design-Iconic-Font';\r\n    content: '\\f269';\r\n    width: 100%;\r\n    height: 100%;\r\n    position: absolute;\r\n    /* right: 0; */\r\n    font-size: 16px;\r\n    color: green; }\r\n\r\n.label-agree-term {\r\n  position: relative;\r\n  top: 0%;\r\n  transform: translateY(0);\r\n  -moz-transform: translateY(0);\r\n  -webkit-transform: translateY(0);\r\n  -o-transform: translateY(0);\r\n  -ms-transform: translateY(0); }\r\n\r\n.material-icons-name {\r\n  font-size: 18px; }\r\n\r\n.signin-content {\r\n  padding-top: 67px;\r\n  padding-bottom: 87px; }\r\n\r\n.social-login {\r\n  align-items: center;\r\n  -moz-align-items: center;\r\n  -webkit-align-items: center;\r\n  -o-align-items: center;\r\n  -ms-align-items: center;\r\n  margin-top: 80px; }\r\n\r\n.social-label {\r\n  display: inline-block;\r\n  margin-right: 15px; }\r\n\r\n.socials li {\r\n  padding: 5px; }\r\n  .socials li:last-child {\r\n    margin-right: 0px; }\r\n  .socials li a {\r\n    text-decoration: none; }\r\n    .socials li a i {\r\n      width: 30px;\r\n      height: 30px;\r\n      color: #fff;\r\n      font-size: 14px;\r\n      border-radius: 5px;\r\n      -moz-border-radius: 5px;\r\n      -webkit-border-radius: 5px;\r\n      -o-border-radius: 5px;\r\n      -ms-border-radius: 5px;\r\n      transform: translateZ(0);\r\n      -moz-transform: translateZ(0);\r\n      -webkit-transform: translateZ(0);\r\n      -o-transform: translateZ(0);\r\n      -ms-transform: translateZ(0);\r\n      -webkit-transition-duration: 0.3s;\r\n      transition-duration: 0.3s;\r\n      -webkit-transition-property: transform;\r\n      transition-property: transform;\r\n      -webkit-transition-timing-function: ease-out;\r\n      transition-timing-function: ease-out; }\r\n  .socials li:hover a i {\r\n    -webkit-transform: scale(1.3) translateZ(0);\r\n    transform: scale(1.3) translateZ(0); }\r\n\r\n.zmdi-facebook {\r\n  background: #3b5998; }\r\n\r\n.zmdi-twitter {\r\n  background: #1da0f2; }\r\n\r\n.zmdi-google {\r\n  background: #e72734; }\r\n\r\n.signin-form {\r\n  margin-right: 90px;\r\n  margin-left: 80px; }\r\n\r\n.signin-image {\r\n  margin-left: 110px;\r\n  margin-right: 20px;\r\n  margin-top: 10px; }\r\n\r\n@media screen and (max-width: 1200px) {\r\n  .container {\r\n    width: calc( 100% - 30px);\r\n    max-width: 100%; } }\r\n@media screen and (min-width: 1024px) {\r\n  .container {\r\n    max-width: 1200px; } }\r\n@media screen and (max-width: 768px) {\r\n  .signup-content, .signin-content {\r\n    flex-direction: column;\r\n    -moz-flex-direction: column;\r\n    -webkit-flex-direction: column;\r\n    -o-flex-direction: column;\r\n    -ms-flex-direction: column;\r\n    justify-content: center;\r\n    -moz-justify-content: center;\r\n    -webkit-justify-content: center;\r\n    -o-justify-content: center;\r\n    -ms-justify-content: center; }\r\n\r\n  .signup-form {\r\n    margin-left: 0px;\r\n    margin-right: 0px;\r\n    padding-left: 0px;\r\n    /* box-sizing: border-box; */\r\n    padding: 0 30px; }\r\n\r\n  .signin-image {\r\n    margin-left: 0px;\r\n    margin-right: 0px;\r\n    margin-top: 50px;\r\n    order: 2;\r\n    -moz-order: 2;\r\n    -webkit-order: 2;\r\n    -o-order: 2;\r\n    -ms-order: 2; }\r\n\r\n  .signup-form, .signup-image, .signin-form, .signin-image {\r\n    width: auto; }\r\n\r\n  .social-login {\r\n    justify-content: center;\r\n    -moz-justify-content: center;\r\n    -webkit-justify-content: center;\r\n    -o-justify-content: center;\r\n    -ms-justify-content: center; }\r\n\r\n  .form-button {\r\n    text-align: center; }\r\n\r\n  .signin-form {\r\n    order: 1;\r\n    -moz-order: 1;\r\n    -webkit-order: 1;\r\n    -o-order: 1;\r\n    -ms-order: 1;\r\n    margin-right: 0px;\r\n    margin-left: 0px;\r\n    padding: 0 30px; }\r\n\r\n  .form-title {\r\n    text-align: center; } }\r\n@media screen and (max-width: 400px) {\r\n  .social-login {\r\n    flex-direction: column;\r\n    -moz-flex-direction: column;\r\n    -webkit-flex-direction: column;\r\n    -o-flex-direction: column;\r\n    -ms-flex-direction: column; }\r\n\r\n  .social-label {\r\n    margin-right: 0px;\r\n    margin-bottom: 10px; } }\r\n\r\n/*# sourceMappingURL=style.css.map */\r\n"
  },
  {
    "path": "src/main/resources/static/auth/fonts/material-icon/css/material-design-iconic-font.css",
    "content": "/*!\r\n *  Material Design Iconic Font by Sergey Kupletsky (@zavoloklom) - http://zavoloklom.github.io/material-design-iconic-font/\r\n *  License - http://zavoloklom.github.io/material-design-iconic-font/license (Font: SIL OFL 1.1, CSS: MIT License)\r\n */\r\n@font-face {\r\n  font-family: 'Material-Design-Iconic-Font';\r\n  src: url('../fonts/Material-Design-Iconic-Font.woff2?v=2.2.0') format('woff2'), url('../fonts/Material-Design-Iconic-Font.woff?v=2.2.0') format('woff'), url('../fonts/Material-Design-Iconic-Font.ttf?v=2.2.0') format('truetype');\r\n  font-weight: normal;\r\n  font-style: normal;\r\n}\r\n.zmdi {\r\n  display: inline-block;\r\n  font: normal normal normal 14px/1 'Material-Design-Iconic-Font';\r\n  font-size: inherit;\r\n  text-rendering: auto;\r\n  -webkit-font-smoothing: antialiased;\r\n  -moz-osx-font-smoothing: grayscale;\r\n}\r\n.zmdi-hc-lg {\r\n  font-size: 1.33333333em;\r\n  line-height: 0.75em;\r\n  vertical-align: -15%;\r\n}\r\n.zmdi-hc-2x {\r\n  font-size: 2em;\r\n}\r\n.zmdi-hc-3x {\r\n  font-size: 3em;\r\n}\r\n.zmdi-hc-4x {\r\n  font-size: 4em;\r\n}\r\n.zmdi-hc-5x {\r\n  font-size: 5em;\r\n}\r\n.zmdi-hc-fw {\r\n  width: 1.28571429em;\r\n  text-align: center;\r\n}\r\n.zmdi-hc-ul {\r\n  padding-left: 0;\r\n  margin-left: 2.14285714em;\r\n  list-style-type: none;\r\n}\r\n.zmdi-hc-ul > li {\r\n  position: relative;\r\n}\r\n.zmdi-hc-li {\r\n  position: absolute;\r\n  left: -2.14285714em;\r\n  width: 2.14285714em;\r\n  top: 0.14285714em;\r\n  text-align: center;\r\n}\r\n.zmdi-hc-li.zmdi-hc-lg {\r\n  left: -1.85714286em;\r\n}\r\n.zmdi-hc-border {\r\n  padding: .1em .25em;\r\n  border: solid 0.1em #9e9e9e;\r\n  border-radius: 2px;\r\n}\r\n.zmdi-hc-border-circle {\r\n  padding: .1em .25em;\r\n  border: solid 0.1em #9e9e9e;\r\n  border-radius: 50%;\r\n}\r\n.zmdi.pull-left {\r\n  float: left;\r\n  margin-right: .15em;\r\n}\r\n.zmdi.pull-right {\r\n  float: right;\r\n  margin-left: .15em;\r\n}\r\n.zmdi-hc-spin {\r\n  -webkit-animation: zmdi-spin 1.5s infinite linear;\r\n          animation: zmdi-spin 1.5s infinite linear;\r\n}\r\n.zmdi-hc-spin-reverse {\r\n  -webkit-animation: zmdi-spin-reverse 1.5s infinite linear;\r\n          animation: zmdi-spin-reverse 1.5s infinite linear;\r\n}\r\n@-webkit-keyframes zmdi-spin {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(359deg);\r\n            transform: rotate(359deg);\r\n  }\r\n}\r\n@keyframes zmdi-spin {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(359deg);\r\n            transform: rotate(359deg);\r\n  }\r\n}\r\n@-webkit-keyframes zmdi-spin-reverse {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(-359deg);\r\n            transform: rotate(-359deg);\r\n  }\r\n}\r\n@keyframes zmdi-spin-reverse {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(-359deg);\r\n            transform: rotate(-359deg);\r\n  }\r\n}\r\n.zmdi-hc-rotate-90 {\r\n  -webkit-transform: rotate(90deg);\r\n      -ms-transform: rotate(90deg);\r\n          transform: rotate(90deg);\r\n}\r\n.zmdi-hc-rotate-180 {\r\n  -webkit-transform: rotate(180deg);\r\n      -ms-transform: rotate(180deg);\r\n          transform: rotate(180deg);\r\n}\r\n.zmdi-hc-rotate-270 {\r\n  -webkit-transform: rotate(270deg);\r\n      -ms-transform: rotate(270deg);\r\n          transform: rotate(270deg);\r\n}\r\n.zmdi-hc-flip-horizontal {\r\n  -webkit-transform: scale(-1, 1);\r\n      -ms-transform: scale(-1, 1);\r\n          transform: scale(-1, 1);\r\n}\r\n.zmdi-hc-flip-vertical {\r\n  -webkit-transform: scale(1, -1);\r\n      -ms-transform: scale(1, -1);\r\n          transform: scale(1, -1);\r\n}\r\n.zmdi-hc-stack {\r\n  position: relative;\r\n  display: inline-block;\r\n  width: 2em;\r\n  height: 2em;\r\n  line-height: 2em;\r\n  vertical-align: middle;\r\n}\r\n.zmdi-hc-stack-1x,\r\n.zmdi-hc-stack-2x {\r\n  position: absolute;\r\n  left: 0;\r\n  width: 100%;\r\n  text-align: center;\r\n}\r\n.zmdi-hc-stack-1x {\r\n  line-height: inherit;\r\n}\r\n.zmdi-hc-stack-2x {\r\n  font-size: 2em;\r\n}\r\n.zmdi-hc-inverse {\r\n  color: #ffffff;\r\n}\r\n/* Material Design Iconic Font uses the Unicode Private Use Area (PUA) to ensure screen\r\n   readers do not read off random characters that represent icons */\r\n.zmdi-3d-rotation:before {\r\n  content: '\\f101';\r\n}\r\n.zmdi-airplane-off:before {\r\n  content: '\\f102';\r\n}\r\n.zmdi-airplane:before {\r\n  content: '\\f103';\r\n}\r\n.zmdi-album:before {\r\n  content: '\\f104';\r\n}\r\n.zmdi-archive:before {\r\n  content: '\\f105';\r\n}\r\n.zmdi-assignment-account:before {\r\n  content: '\\f106';\r\n}\r\n.zmdi-assignment-alert:before {\r\n  content: '\\f107';\r\n}\r\n.zmdi-assignment-check:before {\r\n  content: '\\f108';\r\n}\r\n.zmdi-assignment-o:before {\r\n  content: '\\f109';\r\n}\r\n.zmdi-assignment-return:before {\r\n  content: '\\f10a';\r\n}\r\n.zmdi-assignment-returned:before {\r\n  content: '\\f10b';\r\n}\r\n.zmdi-assignment:before {\r\n  content: '\\f10c';\r\n}\r\n.zmdi-attachment-alt:before {\r\n  content: '\\f10d';\r\n}\r\n.zmdi-attachment:before {\r\n  content: '\\f10e';\r\n}\r\n.zmdi-audio:before {\r\n  content: '\\f10f';\r\n}\r\n.zmdi-badge-check:before {\r\n  content: '\\f110';\r\n}\r\n.zmdi-balance-wallet:before {\r\n  content: '\\f111';\r\n}\r\n.zmdi-balance:before {\r\n  content: '\\f112';\r\n}\r\n.zmdi-battery-alert:before {\r\n  content: '\\f113';\r\n}\r\n.zmdi-battery-flash:before {\r\n  content: '\\f114';\r\n}\r\n.zmdi-battery-unknown:before {\r\n  content: '\\f115';\r\n}\r\n.zmdi-battery:before {\r\n  content: '\\f116';\r\n}\r\n.zmdi-bike:before {\r\n  content: '\\f117';\r\n}\r\n.zmdi-block-alt:before {\r\n  content: '\\f118';\r\n}\r\n.zmdi-block:before {\r\n  content: '\\f119';\r\n}\r\n.zmdi-boat:before {\r\n  content: '\\f11a';\r\n}\r\n.zmdi-book-image:before {\r\n  content: '\\f11b';\r\n}\r\n.zmdi-book:before {\r\n  content: '\\f11c';\r\n}\r\n.zmdi-bookmark-outline:before {\r\n  content: '\\f11d';\r\n}\r\n.zmdi-bookmark:before {\r\n  content: '\\f11e';\r\n}\r\n.zmdi-brush:before {\r\n  content: '\\f11f';\r\n}\r\n.zmdi-bug:before {\r\n  content: '\\f120';\r\n}\r\n.zmdi-bus:before {\r\n  content: '\\f121';\r\n}\r\n.zmdi-cake:before {\r\n  content: '\\f122';\r\n}\r\n.zmdi-car-taxi:before {\r\n  content: '\\f123';\r\n}\r\n.zmdi-car-wash:before {\r\n  content: '\\f124';\r\n}\r\n.zmdi-car:before {\r\n  content: '\\f125';\r\n}\r\n.zmdi-card-giftcard:before {\r\n  content: '\\f126';\r\n}\r\n.zmdi-card-membership:before {\r\n  content: '\\f127';\r\n}\r\n.zmdi-card-travel:before {\r\n  content: '\\f128';\r\n}\r\n.zmdi-card:before {\r\n  content: '\\f129';\r\n}\r\n.zmdi-case-check:before {\r\n  content: '\\f12a';\r\n}\r\n.zmdi-case-download:before {\r\n  content: '\\f12b';\r\n}\r\n.zmdi-case-play:before {\r\n  content: '\\f12c';\r\n}\r\n.zmdi-case:before {\r\n  content: '\\f12d';\r\n}\r\n.zmdi-cast-connected:before {\r\n  content: '\\f12e';\r\n}\r\n.zmdi-cast:before {\r\n  content: '\\f12f';\r\n}\r\n.zmdi-chart-donut:before {\r\n  content: '\\f130';\r\n}\r\n.zmdi-chart:before {\r\n  content: '\\f131';\r\n}\r\n.zmdi-city-alt:before {\r\n  content: '\\f132';\r\n}\r\n.zmdi-city:before {\r\n  content: '\\f133';\r\n}\r\n.zmdi-close-circle-o:before {\r\n  content: '\\f134';\r\n}\r\n.zmdi-close-circle:before {\r\n  content: '\\f135';\r\n}\r\n.zmdi-close:before {\r\n  content: '\\f136';\r\n}\r\n.zmdi-cocktail:before {\r\n  content: '\\f137';\r\n}\r\n.zmdi-code-setting:before {\r\n  content: '\\f138';\r\n}\r\n.zmdi-code-smartphone:before {\r\n  content: '\\f139';\r\n}\r\n.zmdi-code:before {\r\n  content: '\\f13a';\r\n}\r\n.zmdi-coffee:before {\r\n  content: '\\f13b';\r\n}\r\n.zmdi-collection-bookmark:before {\r\n  content: '\\f13c';\r\n}\r\n.zmdi-collection-case-play:before {\r\n  content: '\\f13d';\r\n}\r\n.zmdi-collection-folder-image:before {\r\n  content: '\\f13e';\r\n}\r\n.zmdi-collection-image-o:before {\r\n  content: '\\f13f';\r\n}\r\n.zmdi-collection-image:before {\r\n  content: '\\f140';\r\n}\r\n.zmdi-collection-item-1:before {\r\n  content: '\\f141';\r\n}\r\n.zmdi-collection-item-2:before {\r\n  content: '\\f142';\r\n}\r\n.zmdi-collection-item-3:before {\r\n  content: '\\f143';\r\n}\r\n.zmdi-collection-item-4:before {\r\n  content: '\\f144';\r\n}\r\n.zmdi-collection-item-5:before {\r\n  content: '\\f145';\r\n}\r\n.zmdi-collection-item-6:before {\r\n  content: '\\f146';\r\n}\r\n.zmdi-collection-item-7:before {\r\n  content: '\\f147';\r\n}\r\n.zmdi-collection-item-8:before {\r\n  content: '\\f148';\r\n}\r\n.zmdi-collection-item-9-plus:before {\r\n  content: '\\f149';\r\n}\r\n.zmdi-collection-item-9:before {\r\n  content: '\\f14a';\r\n}\r\n.zmdi-collection-item:before {\r\n  content: '\\f14b';\r\n}\r\n.zmdi-collection-music:before {\r\n  content: '\\f14c';\r\n}\r\n.zmdi-collection-pdf:before {\r\n  content: '\\f14d';\r\n}\r\n.zmdi-collection-plus:before {\r\n  content: '\\f14e';\r\n}\r\n.zmdi-collection-speaker:before {\r\n  content: '\\f14f';\r\n}\r\n.zmdi-collection-text:before {\r\n  content: '\\f150';\r\n}\r\n.zmdi-collection-video:before {\r\n  content: '\\f151';\r\n}\r\n.zmdi-compass:before {\r\n  content: '\\f152';\r\n}\r\n.zmdi-cutlery:before {\r\n  content: '\\f153';\r\n}\r\n.zmdi-delete:before {\r\n  content: '\\f154';\r\n}\r\n.zmdi-dialpad:before {\r\n  content: '\\f155';\r\n}\r\n.zmdi-dns:before {\r\n  content: '\\f156';\r\n}\r\n.zmdi-drink:before {\r\n  content: '\\f157';\r\n}\r\n.zmdi-edit:before {\r\n  content: '\\f158';\r\n}\r\n.zmdi-email-open:before {\r\n  content: '\\f159';\r\n}\r\n.zmdi-email:before {\r\n  content: '\\f15a';\r\n}\r\n.zmdi-eye-off:before {\r\n  content: '\\f15b';\r\n}\r\n.zmdi-eye:before {\r\n  content: '\\f15c';\r\n}\r\n.zmdi-eyedropper:before {\r\n  content: '\\f15d';\r\n}\r\n.zmdi-favorite-outline:before {\r\n  content: '\\f15e';\r\n}\r\n.zmdi-favorite:before {\r\n  content: '\\f15f';\r\n}\r\n.zmdi-filter-list:before {\r\n  content: '\\f160';\r\n}\r\n.zmdi-fire:before {\r\n  content: '\\f161';\r\n}\r\n.zmdi-flag:before {\r\n  content: '\\f162';\r\n}\r\n.zmdi-flare:before {\r\n  content: '\\f163';\r\n}\r\n.zmdi-flash-auto:before {\r\n  content: '\\f164';\r\n}\r\n.zmdi-flash-off:before {\r\n  content: '\\f165';\r\n}\r\n.zmdi-flash:before {\r\n  content: '\\f166';\r\n}\r\n.zmdi-flip:before {\r\n  content: '\\f167';\r\n}\r\n.zmdi-flower-alt:before {\r\n  content: '\\f168';\r\n}\r\n.zmdi-flower:before {\r\n  content: '\\f169';\r\n}\r\n.zmdi-font:before {\r\n  content: '\\f16a';\r\n}\r\n.zmdi-fullscreen-alt:before {\r\n  content: '\\f16b';\r\n}\r\n.zmdi-fullscreen-exit:before {\r\n  content: '\\f16c';\r\n}\r\n.zmdi-fullscreen:before {\r\n  content: '\\f16d';\r\n}\r\n.zmdi-functions:before {\r\n  content: '\\f16e';\r\n}\r\n.zmdi-gas-station:before {\r\n  content: '\\f16f';\r\n}\r\n.zmdi-gesture:before {\r\n  content: '\\f170';\r\n}\r\n.zmdi-globe-alt:before {\r\n  content: '\\f171';\r\n}\r\n.zmdi-globe-lock:before {\r\n  content: '\\f172';\r\n}\r\n.zmdi-globe:before {\r\n  content: '\\f173';\r\n}\r\n.zmdi-graduation-cap:before {\r\n  content: '\\f174';\r\n}\r\n.zmdi-home:before {\r\n  content: '\\f175';\r\n}\r\n.zmdi-hospital-alt:before {\r\n  content: '\\f176';\r\n}\r\n.zmdi-hospital:before {\r\n  content: '\\f177';\r\n}\r\n.zmdi-hotel:before {\r\n  content: '\\f178';\r\n}\r\n.zmdi-hourglass-alt:before {\r\n  content: '\\f179';\r\n}\r\n.zmdi-hourglass-outline:before {\r\n  content: '\\f17a';\r\n}\r\n.zmdi-hourglass:before {\r\n  content: '\\f17b';\r\n}\r\n.zmdi-http:before {\r\n  content: '\\f17c';\r\n}\r\n.zmdi-image-alt:before {\r\n  content: '\\f17d';\r\n}\r\n.zmdi-image-o:before {\r\n  content: '\\f17e';\r\n}\r\n.zmdi-image:before {\r\n  content: '\\f17f';\r\n}\r\n.zmdi-inbox:before {\r\n  content: '\\f180';\r\n}\r\n.zmdi-invert-colors-off:before {\r\n  content: '\\f181';\r\n}\r\n.zmdi-invert-colors:before {\r\n  content: '\\f182';\r\n}\r\n.zmdi-key:before {\r\n  content: '\\f183';\r\n}\r\n.zmdi-label-alt-outline:before {\r\n  content: '\\f184';\r\n}\r\n.zmdi-label-alt:before {\r\n  content: '\\f185';\r\n}\r\n.zmdi-label-heart:before {\r\n  content: '\\f186';\r\n}\r\n.zmdi-label:before {\r\n  content: '\\f187';\r\n}\r\n.zmdi-labels:before {\r\n  content: '\\f188';\r\n}\r\n.zmdi-lamp:before {\r\n  content: '\\f189';\r\n}\r\n.zmdi-landscape:before {\r\n  content: '\\f18a';\r\n}\r\n.zmdi-layers-off:before {\r\n  content: '\\f18b';\r\n}\r\n.zmdi-layers:before {\r\n  content: '\\f18c';\r\n}\r\n.zmdi-library:before {\r\n  content: '\\f18d';\r\n}\r\n.zmdi-link:before {\r\n  content: '\\f18e';\r\n}\r\n.zmdi-lock-open:before {\r\n  content: '\\f18f';\r\n}\r\n.zmdi-lock-outline:before {\r\n  content: '\\f190';\r\n}\r\n.zmdi-lock:before {\r\n  content: '\\f191';\r\n}\r\n.zmdi-mail-reply-all:before {\r\n  content: '\\f192';\r\n}\r\n.zmdi-mail-reply:before {\r\n  content: '\\f193';\r\n}\r\n.zmdi-mail-send:before {\r\n  content: '\\f194';\r\n}\r\n.zmdi-mall:before {\r\n  content: '\\f195';\r\n}\r\n.zmdi-map:before {\r\n  content: '\\f196';\r\n}\r\n.zmdi-menu:before {\r\n  content: '\\f197';\r\n}\r\n.zmdi-money-box:before {\r\n  content: '\\f198';\r\n}\r\n.zmdi-money-off:before {\r\n  content: '\\f199';\r\n}\r\n.zmdi-money:before {\r\n  content: '\\f19a';\r\n}\r\n.zmdi-more-vert:before {\r\n  content: '\\f19b';\r\n}\r\n.zmdi-more:before {\r\n  content: '\\f19c';\r\n}\r\n.zmdi-movie-alt:before {\r\n  content: '\\f19d';\r\n}\r\n.zmdi-movie:before {\r\n  content: '\\f19e';\r\n}\r\n.zmdi-nature-people:before {\r\n  content: '\\f19f';\r\n}\r\n.zmdi-nature:before {\r\n  content: '\\f1a0';\r\n}\r\n.zmdi-navigation:before {\r\n  content: '\\f1a1';\r\n}\r\n.zmdi-open-in-browser:before {\r\n  content: '\\f1a2';\r\n}\r\n.zmdi-open-in-new:before {\r\n  content: '\\f1a3';\r\n}\r\n.zmdi-palette:before {\r\n  content: '\\f1a4';\r\n}\r\n.zmdi-parking:before {\r\n  content: '\\f1a5';\r\n}\r\n.zmdi-pin-account:before {\r\n  content: '\\f1a6';\r\n}\r\n.zmdi-pin-assistant:before {\r\n  content: '\\f1a7';\r\n}\r\n.zmdi-pin-drop:before {\r\n  content: '\\f1a8';\r\n}\r\n.zmdi-pin-help:before {\r\n  content: '\\f1a9';\r\n}\r\n.zmdi-pin-off:before {\r\n  content: '\\f1aa';\r\n}\r\n.zmdi-pin:before {\r\n  content: '\\f1ab';\r\n}\r\n.zmdi-pizza:before {\r\n  content: '\\f1ac';\r\n}\r\n.zmdi-plaster:before {\r\n  content: '\\f1ad';\r\n}\r\n.zmdi-power-setting:before {\r\n  content: '\\f1ae';\r\n}\r\n.zmdi-power:before {\r\n  content: '\\f1af';\r\n}\r\n.zmdi-print:before {\r\n  content: '\\f1b0';\r\n}\r\n.zmdi-puzzle-piece:before {\r\n  content: '\\f1b1';\r\n}\r\n.zmdi-quote:before {\r\n  content: '\\f1b2';\r\n}\r\n.zmdi-railway:before {\r\n  content: '\\f1b3';\r\n}\r\n.zmdi-receipt:before {\r\n  content: '\\f1b4';\r\n}\r\n.zmdi-refresh-alt:before {\r\n  content: '\\f1b5';\r\n}\r\n.zmdi-refresh-sync-alert:before {\r\n  content: '\\f1b6';\r\n}\r\n.zmdi-refresh-sync-off:before {\r\n  content: '\\f1b7';\r\n}\r\n.zmdi-refresh-sync:before {\r\n  content: '\\f1b8';\r\n}\r\n.zmdi-refresh:before {\r\n  content: '\\f1b9';\r\n}\r\n.zmdi-roller:before {\r\n  content: '\\f1ba';\r\n}\r\n.zmdi-ruler:before {\r\n  content: '\\f1bb';\r\n}\r\n.zmdi-scissors:before {\r\n  content: '\\f1bc';\r\n}\r\n.zmdi-screen-rotation-lock:before {\r\n  content: '\\f1bd';\r\n}\r\n.zmdi-screen-rotation:before {\r\n  content: '\\f1be';\r\n}\r\n.zmdi-search-for:before {\r\n  content: '\\f1bf';\r\n}\r\n.zmdi-search-in-file:before {\r\n  content: '\\f1c0';\r\n}\r\n.zmdi-search-in-page:before {\r\n  content: '\\f1c1';\r\n}\r\n.zmdi-search-replace:before {\r\n  content: '\\f1c2';\r\n}\r\n.zmdi-search:before {\r\n  content: '\\f1c3';\r\n}\r\n.zmdi-seat:before {\r\n  content: '\\f1c4';\r\n}\r\n.zmdi-settings-square:before {\r\n  content: '\\f1c5';\r\n}\r\n.zmdi-settings:before {\r\n  content: '\\f1c6';\r\n}\r\n.zmdi-shield-check:before {\r\n  content: '\\f1c7';\r\n}\r\n.zmdi-shield-security:before {\r\n  content: '\\f1c8';\r\n}\r\n.zmdi-shopping-basket:before {\r\n  content: '\\f1c9';\r\n}\r\n.zmdi-shopping-cart-plus:before {\r\n  content: '\\f1ca';\r\n}\r\n.zmdi-shopping-cart:before {\r\n  content: '\\f1cb';\r\n}\r\n.zmdi-sign-in:before {\r\n  content: '\\f1cc';\r\n}\r\n.zmdi-sort-amount-asc:before {\r\n  content: '\\f1cd';\r\n}\r\n.zmdi-sort-amount-desc:before {\r\n  content: '\\f1ce';\r\n}\r\n.zmdi-sort-asc:before {\r\n  content: '\\f1cf';\r\n}\r\n.zmdi-sort-desc:before {\r\n  content: '\\f1d0';\r\n}\r\n.zmdi-spellcheck:before {\r\n  content: '\\f1d1';\r\n}\r\n.zmdi-storage:before {\r\n  content: '\\f1d2';\r\n}\r\n.zmdi-store-24:before {\r\n  content: '\\f1d3';\r\n}\r\n.zmdi-store:before {\r\n  content: '\\f1d4';\r\n}\r\n.zmdi-subway:before {\r\n  content: '\\f1d5';\r\n}\r\n.zmdi-sun:before {\r\n  content: '\\f1d6';\r\n}\r\n.zmdi-tab-unselected:before {\r\n  content: '\\f1d7';\r\n}\r\n.zmdi-tab:before {\r\n  content: '\\f1d8';\r\n}\r\n.zmdi-tag-close:before {\r\n  content: '\\f1d9';\r\n}\r\n.zmdi-tag-more:before {\r\n  content: '\\f1da';\r\n}\r\n.zmdi-tag:before {\r\n  content: '\\f1db';\r\n}\r\n.zmdi-thumb-down:before {\r\n  content: '\\f1dc';\r\n}\r\n.zmdi-thumb-up-down:before {\r\n  content: '\\f1dd';\r\n}\r\n.zmdi-thumb-up:before {\r\n  content: '\\f1de';\r\n}\r\n.zmdi-ticket-star:before {\r\n  content: '\\f1df';\r\n}\r\n.zmdi-toll:before {\r\n  content: '\\f1e0';\r\n}\r\n.zmdi-toys:before {\r\n  content: '\\f1e1';\r\n}\r\n.zmdi-traffic:before {\r\n  content: '\\f1e2';\r\n}\r\n.zmdi-translate:before {\r\n  content: '\\f1e3';\r\n}\r\n.zmdi-triangle-down:before {\r\n  content: '\\f1e4';\r\n}\r\n.zmdi-triangle-up:before {\r\n  content: '\\f1e5';\r\n}\r\n.zmdi-truck:before {\r\n  content: '\\f1e6';\r\n}\r\n.zmdi-turning-sign:before {\r\n  content: '\\f1e7';\r\n}\r\n.zmdi-wallpaper:before {\r\n  content: '\\f1e8';\r\n}\r\n.zmdi-washing-machine:before {\r\n  content: '\\f1e9';\r\n}\r\n.zmdi-window-maximize:before {\r\n  content: '\\f1ea';\r\n}\r\n.zmdi-window-minimize:before {\r\n  content: '\\f1eb';\r\n}\r\n.zmdi-window-restore:before {\r\n  content: '\\f1ec';\r\n}\r\n.zmdi-wrench:before {\r\n  content: '\\f1ed';\r\n}\r\n.zmdi-zoom-in:before {\r\n  content: '\\f1ee';\r\n}\r\n.zmdi-zoom-out:before {\r\n  content: '\\f1ef';\r\n}\r\n.zmdi-alert-circle-o:before {\r\n  content: '\\f1f0';\r\n}\r\n.zmdi-alert-circle:before {\r\n  content: '\\f1f1';\r\n}\r\n.zmdi-alert-octagon:before {\r\n  content: '\\f1f2';\r\n}\r\n.zmdi-alert-polygon:before {\r\n  content: '\\f1f3';\r\n}\r\n.zmdi-alert-triangle:before {\r\n  content: '\\f1f4';\r\n}\r\n.zmdi-help-outline:before {\r\n  content: '\\f1f5';\r\n}\r\n.zmdi-help:before {\r\n  content: '\\f1f6';\r\n}\r\n.zmdi-info-outline:before {\r\n  content: '\\f1f7';\r\n}\r\n.zmdi-info:before {\r\n  content: '\\f1f8';\r\n}\r\n.zmdi-notifications-active:before {\r\n  content: '\\f1f9';\r\n}\r\n.zmdi-notifications-add:before {\r\n  content: '\\f1fa';\r\n}\r\n.zmdi-notifications-none:before {\r\n  content: '\\f1fb';\r\n}\r\n.zmdi-notifications-off:before {\r\n  content: '\\f1fc';\r\n}\r\n.zmdi-notifications-paused:before {\r\n  content: '\\f1fd';\r\n}\r\n.zmdi-notifications:before {\r\n  content: '\\f1fe';\r\n}\r\n.zmdi-account-add:before {\r\n  content: '\\f1ff';\r\n}\r\n.zmdi-account-box-mail:before {\r\n  content: '\\f200';\r\n}\r\n.zmdi-account-box-o:before {\r\n  content: '\\f201';\r\n}\r\n.zmdi-account-box-phone:before {\r\n  content: '\\f202';\r\n}\r\n.zmdi-account-box:before {\r\n  content: '\\f203';\r\n}\r\n.zmdi-account-calendar:before {\r\n  content: '\\f204';\r\n}\r\n.zmdi-account-circle:before {\r\n  content: '\\f205';\r\n}\r\n.zmdi-account-o:before {\r\n  content: '\\f206';\r\n}\r\n.zmdi-account:before {\r\n  content: '\\f207';\r\n}\r\n.zmdi-accounts-add:before {\r\n  content: '\\f208';\r\n}\r\n.zmdi-accounts-alt:before {\r\n  content: '\\f209';\r\n}\r\n.zmdi-accounts-list-alt:before {\r\n  content: '\\f20a';\r\n}\r\n.zmdi-accounts-list:before {\r\n  content: '\\f20b';\r\n}\r\n.zmdi-accounts-outline:before {\r\n  content: '\\f20c';\r\n}\r\n.zmdi-accounts:before {\r\n  content: '\\f20d';\r\n}\r\n.zmdi-face:before {\r\n  content: '\\f20e';\r\n}\r\n.zmdi-female:before {\r\n  content: '\\f20f';\r\n}\r\n.zmdi-male-alt:before {\r\n  content: '\\f210';\r\n}\r\n.zmdi-male-female:before {\r\n  content: '\\f211';\r\n}\r\n.zmdi-male:before {\r\n  content: '\\f212';\r\n}\r\n.zmdi-mood-bad:before {\r\n  content: '\\f213';\r\n}\r\n.zmdi-mood:before {\r\n  content: '\\f214';\r\n}\r\n.zmdi-run:before {\r\n  content: '\\f215';\r\n}\r\n.zmdi-walk:before {\r\n  content: '\\f216';\r\n}\r\n.zmdi-cloud-box:before {\r\n  content: '\\f217';\r\n}\r\n.zmdi-cloud-circle:before {\r\n  content: '\\f218';\r\n}\r\n.zmdi-cloud-done:before {\r\n  content: '\\f219';\r\n}\r\n.zmdi-cloud-download:before {\r\n  content: '\\f21a';\r\n}\r\n.zmdi-cloud-off:before {\r\n  content: '\\f21b';\r\n}\r\n.zmdi-cloud-outline-alt:before {\r\n  content: '\\f21c';\r\n}\r\n.zmdi-cloud-outline:before {\r\n  content: '\\f21d';\r\n}\r\n.zmdi-cloud-upload:before {\r\n  content: '\\f21e';\r\n}\r\n.zmdi-cloud:before {\r\n  content: '\\f21f';\r\n}\r\n.zmdi-download:before {\r\n  content: '\\f220';\r\n}\r\n.zmdi-file-plus:before {\r\n  content: '\\f221';\r\n}\r\n.zmdi-file-text:before {\r\n  content: '\\f222';\r\n}\r\n.zmdi-file:before {\r\n  content: '\\f223';\r\n}\r\n.zmdi-folder-outline:before {\r\n  content: '\\f224';\r\n}\r\n.zmdi-folder-person:before {\r\n  content: '\\f225';\r\n}\r\n.zmdi-folder-star-alt:before {\r\n  content: '\\f226';\r\n}\r\n.zmdi-folder-star:before {\r\n  content: '\\f227';\r\n}\r\n.zmdi-folder:before {\r\n  content: '\\f228';\r\n}\r\n.zmdi-gif:before {\r\n  content: '\\f229';\r\n}\r\n.zmdi-upload:before {\r\n  content: '\\f22a';\r\n}\r\n.zmdi-border-all:before {\r\n  content: '\\f22b';\r\n}\r\n.zmdi-border-bottom:before {\r\n  content: '\\f22c';\r\n}\r\n.zmdi-border-clear:before {\r\n  content: '\\f22d';\r\n}\r\n.zmdi-border-color:before {\r\n  content: '\\f22e';\r\n}\r\n.zmdi-border-horizontal:before {\r\n  content: '\\f22f';\r\n}\r\n.zmdi-border-inner:before {\r\n  content: '\\f230';\r\n}\r\n.zmdi-border-left:before {\r\n  content: '\\f231';\r\n}\r\n.zmdi-border-outer:before {\r\n  content: '\\f232';\r\n}\r\n.zmdi-border-right:before {\r\n  content: '\\f233';\r\n}\r\n.zmdi-border-style:before {\r\n  content: '\\f234';\r\n}\r\n.zmdi-border-top:before {\r\n  content: '\\f235';\r\n}\r\n.zmdi-border-vertical:before {\r\n  content: '\\f236';\r\n}\r\n.zmdi-copy:before {\r\n  content: '\\f237';\r\n}\r\n.zmdi-crop:before {\r\n  content: '\\f238';\r\n}\r\n.zmdi-format-align-center:before {\r\n  content: '\\f239';\r\n}\r\n.zmdi-format-align-justify:before {\r\n  content: '\\f23a';\r\n}\r\n.zmdi-format-align-left:before {\r\n  content: '\\f23b';\r\n}\r\n.zmdi-format-align-right:before {\r\n  content: '\\f23c';\r\n}\r\n.zmdi-format-bold:before {\r\n  content: '\\f23d';\r\n}\r\n.zmdi-format-clear-all:before {\r\n  content: '\\f23e';\r\n}\r\n.zmdi-format-clear:before {\r\n  content: '\\f23f';\r\n}\r\n.zmdi-format-color-fill:before {\r\n  content: '\\f240';\r\n}\r\n.zmdi-format-color-reset:before {\r\n  content: '\\f241';\r\n}\r\n.zmdi-format-color-text:before {\r\n  content: '\\f242';\r\n}\r\n.zmdi-format-indent-decrease:before {\r\n  content: '\\f243';\r\n}\r\n.zmdi-format-indent-increase:before {\r\n  content: '\\f244';\r\n}\r\n.zmdi-format-italic:before {\r\n  content: '\\f245';\r\n}\r\n.zmdi-format-line-spacing:before {\r\n  content: '\\f246';\r\n}\r\n.zmdi-format-list-bulleted:before {\r\n  content: '\\f247';\r\n}\r\n.zmdi-format-list-numbered:before {\r\n  content: '\\f248';\r\n}\r\n.zmdi-format-ltr:before {\r\n  content: '\\f249';\r\n}\r\n.zmdi-format-rtl:before {\r\n  content: '\\f24a';\r\n}\r\n.zmdi-format-size:before {\r\n  content: '\\f24b';\r\n}\r\n.zmdi-format-strikethrough-s:before {\r\n  content: '\\f24c';\r\n}\r\n.zmdi-format-strikethrough:before {\r\n  content: '\\f24d';\r\n}\r\n.zmdi-format-subject:before {\r\n  content: '\\f24e';\r\n}\r\n.zmdi-format-underlined:before {\r\n  content: '\\f24f';\r\n}\r\n.zmdi-format-valign-bottom:before {\r\n  content: '\\f250';\r\n}\r\n.zmdi-format-valign-center:before {\r\n  content: '\\f251';\r\n}\r\n.zmdi-format-valign-top:before {\r\n  content: '\\f252';\r\n}\r\n.zmdi-redo:before {\r\n  content: '\\f253';\r\n}\r\n.zmdi-select-all:before {\r\n  content: '\\f254';\r\n}\r\n.zmdi-space-bar:before {\r\n  content: '\\f255';\r\n}\r\n.zmdi-text-format:before {\r\n  content: '\\f256';\r\n}\r\n.zmdi-transform:before {\r\n  content: '\\f257';\r\n}\r\n.zmdi-undo:before {\r\n  content: '\\f258';\r\n}\r\n.zmdi-wrap-text:before {\r\n  content: '\\f259';\r\n}\r\n.zmdi-comment-alert:before {\r\n  content: '\\f25a';\r\n}\r\n.zmdi-comment-alt-text:before {\r\n  content: '\\f25b';\r\n}\r\n.zmdi-comment-alt:before {\r\n  content: '\\f25c';\r\n}\r\n.zmdi-comment-edit:before {\r\n  content: '\\f25d';\r\n}\r\n.zmdi-comment-image:before {\r\n  content: '\\f25e';\r\n}\r\n.zmdi-comment-list:before {\r\n  content: '\\f25f';\r\n}\r\n.zmdi-comment-more:before {\r\n  content: '\\f260';\r\n}\r\n.zmdi-comment-outline:before {\r\n  content: '\\f261';\r\n}\r\n.zmdi-comment-text-alt:before {\r\n  content: '\\f262';\r\n}\r\n.zmdi-comment-text:before {\r\n  content: '\\f263';\r\n}\r\n.zmdi-comment-video:before {\r\n  content: '\\f264';\r\n}\r\n.zmdi-comment:before {\r\n  content: '\\f265';\r\n}\r\n.zmdi-comments:before {\r\n  content: '\\f266';\r\n}\r\n.zmdi-check-all:before {\r\n  content: '\\f267';\r\n}\r\n.zmdi-check-circle-u:before {\r\n  content: '\\f268';\r\n}\r\n.zmdi-check-circle:before {\r\n  content: '\\f269';\r\n}\r\n.zmdi-check-square:before {\r\n  content: '\\f26a';\r\n}\r\n.zmdi-check:before {\r\n  content: '\\f26b';\r\n}\r\n.zmdi-circle-o:before {\r\n  content: '\\f26c';\r\n}\r\n.zmdi-circle:before {\r\n  content: '\\f26d';\r\n}\r\n.zmdi-dot-circle-alt:before {\r\n  content: '\\f26e';\r\n}\r\n.zmdi-dot-circle:before {\r\n  content: '\\f26f';\r\n}\r\n.zmdi-minus-circle-outline:before {\r\n  content: '\\f270';\r\n}\r\n.zmdi-minus-circle:before {\r\n  content: '\\f271';\r\n}\r\n.zmdi-minus-square:before {\r\n  content: '\\f272';\r\n}\r\n.zmdi-minus:before {\r\n  content: '\\f273';\r\n}\r\n.zmdi-plus-circle-o-duplicate:before {\r\n  content: '\\f274';\r\n}\r\n.zmdi-plus-circle-o:before {\r\n  content: '\\f275';\r\n}\r\n.zmdi-plus-circle:before {\r\n  content: '\\f276';\r\n}\r\n.zmdi-plus-square:before {\r\n  content: '\\f277';\r\n}\r\n.zmdi-plus:before {\r\n  content: '\\f278';\r\n}\r\n.zmdi-square-o:before {\r\n  content: '\\f279';\r\n}\r\n.zmdi-star-circle:before {\r\n  content: '\\f27a';\r\n}\r\n.zmdi-star-half:before {\r\n  content: '\\f27b';\r\n}\r\n.zmdi-star-outline:before {\r\n  content: '\\f27c';\r\n}\r\n.zmdi-star:before {\r\n  content: '\\f27d';\r\n}\r\n.zmdi-bluetooth-connected:before {\r\n  content: '\\f27e';\r\n}\r\n.zmdi-bluetooth-off:before {\r\n  content: '\\f27f';\r\n}\r\n.zmdi-bluetooth-search:before {\r\n  content: '\\f280';\r\n}\r\n.zmdi-bluetooth-setting:before {\r\n  content: '\\f281';\r\n}\r\n.zmdi-bluetooth:before {\r\n  content: '\\f282';\r\n}\r\n.zmdi-camera-add:before {\r\n  content: '\\f283';\r\n}\r\n.zmdi-camera-alt:before {\r\n  content: '\\f284';\r\n}\r\n.zmdi-camera-bw:before {\r\n  content: '\\f285';\r\n}\r\n.zmdi-camera-front:before {\r\n  content: '\\f286';\r\n}\r\n.zmdi-camera-mic:before {\r\n  content: '\\f287';\r\n}\r\n.zmdi-camera-party-mode:before {\r\n  content: '\\f288';\r\n}\r\n.zmdi-camera-rear:before {\r\n  content: '\\f289';\r\n}\r\n.zmdi-camera-roll:before {\r\n  content: '\\f28a';\r\n}\r\n.zmdi-camera-switch:before {\r\n  content: '\\f28b';\r\n}\r\n.zmdi-camera:before {\r\n  content: '\\f28c';\r\n}\r\n.zmdi-card-alert:before {\r\n  content: '\\f28d';\r\n}\r\n.zmdi-card-off:before {\r\n  content: '\\f28e';\r\n}\r\n.zmdi-card-sd:before {\r\n  content: '\\f28f';\r\n}\r\n.zmdi-card-sim:before {\r\n  content: '\\f290';\r\n}\r\n.zmdi-desktop-mac:before {\r\n  content: '\\f291';\r\n}\r\n.zmdi-desktop-windows:before {\r\n  content: '\\f292';\r\n}\r\n.zmdi-device-hub:before {\r\n  content: '\\f293';\r\n}\r\n.zmdi-devices-off:before {\r\n  content: '\\f294';\r\n}\r\n.zmdi-devices:before {\r\n  content: '\\f295';\r\n}\r\n.zmdi-dock:before {\r\n  content: '\\f296';\r\n}\r\n.zmdi-floppy:before {\r\n  content: '\\f297';\r\n}\r\n.zmdi-gamepad:before {\r\n  content: '\\f298';\r\n}\r\n.zmdi-gps-dot:before {\r\n  content: '\\f299';\r\n}\r\n.zmdi-gps-off:before {\r\n  content: '\\f29a';\r\n}\r\n.zmdi-gps:before {\r\n  content: '\\f29b';\r\n}\r\n.zmdi-headset-mic:before {\r\n  content: '\\f29c';\r\n}\r\n.zmdi-headset:before {\r\n  content: '\\f29d';\r\n}\r\n.zmdi-input-antenna:before {\r\n  content: '\\f29e';\r\n}\r\n.zmdi-input-composite:before {\r\n  content: '\\f29f';\r\n}\r\n.zmdi-input-hdmi:before {\r\n  content: '\\f2a0';\r\n}\r\n.zmdi-input-power:before {\r\n  content: '\\f2a1';\r\n}\r\n.zmdi-input-svideo:before {\r\n  content: '\\f2a2';\r\n}\r\n.zmdi-keyboard-hide:before {\r\n  content: '\\f2a3';\r\n}\r\n.zmdi-keyboard:before {\r\n  content: '\\f2a4';\r\n}\r\n.zmdi-laptop-chromebook:before {\r\n  content: '\\f2a5';\r\n}\r\n.zmdi-laptop-mac:before {\r\n  content: '\\f2a6';\r\n}\r\n.zmdi-laptop:before {\r\n  content: '\\f2a7';\r\n}\r\n.zmdi-mic-off:before {\r\n  content: '\\f2a8';\r\n}\r\n.zmdi-mic-outline:before {\r\n  content: '\\f2a9';\r\n}\r\n.zmdi-mic-setting:before {\r\n  content: '\\f2aa';\r\n}\r\n.zmdi-mic:before {\r\n  content: '\\f2ab';\r\n}\r\n.zmdi-mouse:before {\r\n  content: '\\f2ac';\r\n}\r\n.zmdi-network-alert:before {\r\n  content: '\\f2ad';\r\n}\r\n.zmdi-network-locked:before {\r\n  content: '\\f2ae';\r\n}\r\n.zmdi-network-off:before {\r\n  content: '\\f2af';\r\n}\r\n.zmdi-network-outline:before {\r\n  content: '\\f2b0';\r\n}\r\n.zmdi-network-setting:before {\r\n  content: '\\f2b1';\r\n}\r\n.zmdi-network:before {\r\n  content: '\\f2b2';\r\n}\r\n.zmdi-phone-bluetooth:before {\r\n  content: '\\f2b3';\r\n}\r\n.zmdi-phone-end:before {\r\n  content: '\\f2b4';\r\n}\r\n.zmdi-phone-forwarded:before {\r\n  content: '\\f2b5';\r\n}\r\n.zmdi-phone-in-talk:before {\r\n  content: '\\f2b6';\r\n}\r\n.zmdi-phone-locked:before {\r\n  content: '\\f2b7';\r\n}\r\n.zmdi-phone-missed:before {\r\n  content: '\\f2b8';\r\n}\r\n.zmdi-phone-msg:before {\r\n  content: '\\f2b9';\r\n}\r\n.zmdi-phone-paused:before {\r\n  content: '\\f2ba';\r\n}\r\n.zmdi-phone-ring:before {\r\n  content: '\\f2bb';\r\n}\r\n.zmdi-phone-setting:before {\r\n  content: '\\f2bc';\r\n}\r\n.zmdi-phone-sip:before {\r\n  content: '\\f2bd';\r\n}\r\n.zmdi-phone:before {\r\n  content: '\\f2be';\r\n}\r\n.zmdi-portable-wifi-changes:before {\r\n  content: '\\f2bf';\r\n}\r\n.zmdi-portable-wifi-off:before {\r\n  content: '\\f2c0';\r\n}\r\n.zmdi-portable-wifi:before {\r\n  content: '\\f2c1';\r\n}\r\n.zmdi-radio:before {\r\n  content: '\\f2c2';\r\n}\r\n.zmdi-reader:before {\r\n  content: '\\f2c3';\r\n}\r\n.zmdi-remote-control-alt:before {\r\n  content: '\\f2c4';\r\n}\r\n.zmdi-remote-control:before {\r\n  content: '\\f2c5';\r\n}\r\n.zmdi-router:before {\r\n  content: '\\f2c6';\r\n}\r\n.zmdi-scanner:before {\r\n  content: '\\f2c7';\r\n}\r\n.zmdi-smartphone-android:before {\r\n  content: '\\f2c8';\r\n}\r\n.zmdi-smartphone-download:before {\r\n  content: '\\f2c9';\r\n}\r\n.zmdi-smartphone-erase:before {\r\n  content: '\\f2ca';\r\n}\r\n.zmdi-smartphone-info:before {\r\n  content: '\\f2cb';\r\n}\r\n.zmdi-smartphone-iphone:before {\r\n  content: '\\f2cc';\r\n}\r\n.zmdi-smartphone-landscape-lock:before {\r\n  content: '\\f2cd';\r\n}\r\n.zmdi-smartphone-landscape:before {\r\n  content: '\\f2ce';\r\n}\r\n.zmdi-smartphone-lock:before {\r\n  content: '\\f2cf';\r\n}\r\n.zmdi-smartphone-portrait-lock:before {\r\n  content: '\\f2d0';\r\n}\r\n.zmdi-smartphone-ring:before {\r\n  content: '\\f2d1';\r\n}\r\n.zmdi-smartphone-setting:before {\r\n  content: '\\f2d2';\r\n}\r\n.zmdi-smartphone-setup:before {\r\n  content: '\\f2d3';\r\n}\r\n.zmdi-smartphone:before {\r\n  content: '\\f2d4';\r\n}\r\n.zmdi-speaker:before {\r\n  content: '\\f2d5';\r\n}\r\n.zmdi-tablet-android:before {\r\n  content: '\\f2d6';\r\n}\r\n.zmdi-tablet-mac:before {\r\n  content: '\\f2d7';\r\n}\r\n.zmdi-tablet:before {\r\n  content: '\\f2d8';\r\n}\r\n.zmdi-tv-alt-play:before {\r\n  content: '\\f2d9';\r\n}\r\n.zmdi-tv-list:before {\r\n  content: '\\f2da';\r\n}\r\n.zmdi-tv-play:before {\r\n  content: '\\f2db';\r\n}\r\n.zmdi-tv:before {\r\n  content: '\\f2dc';\r\n}\r\n.zmdi-usb:before {\r\n  content: '\\f2dd';\r\n}\r\n.zmdi-videocam-off:before {\r\n  content: '\\f2de';\r\n}\r\n.zmdi-videocam-switch:before {\r\n  content: '\\f2df';\r\n}\r\n.zmdi-videocam:before {\r\n  content: '\\f2e0';\r\n}\r\n.zmdi-watch:before {\r\n  content: '\\f2e1';\r\n}\r\n.zmdi-wifi-alt-2:before {\r\n  content: '\\f2e2';\r\n}\r\n.zmdi-wifi-alt:before {\r\n  content: '\\f2e3';\r\n}\r\n.zmdi-wifi-info:before {\r\n  content: '\\f2e4';\r\n}\r\n.zmdi-wifi-lock:before {\r\n  content: '\\f2e5';\r\n}\r\n.zmdi-wifi-off:before {\r\n  content: '\\f2e6';\r\n}\r\n.zmdi-wifi-outline:before {\r\n  content: '\\f2e7';\r\n}\r\n.zmdi-wifi:before {\r\n  content: '\\f2e8';\r\n}\r\n.zmdi-arrow-left-bottom:before {\r\n  content: '\\f2e9';\r\n}\r\n.zmdi-arrow-left:before {\r\n  content: '\\f2ea';\r\n}\r\n.zmdi-arrow-merge:before {\r\n  content: '\\f2eb';\r\n}\r\n.zmdi-arrow-missed:before {\r\n  content: '\\f2ec';\r\n}\r\n.zmdi-arrow-right-top:before {\r\n  content: '\\f2ed';\r\n}\r\n.zmdi-arrow-right:before {\r\n  content: '\\f2ee';\r\n}\r\n.zmdi-arrow-split:before {\r\n  content: '\\f2ef';\r\n}\r\n.zmdi-arrows:before {\r\n  content: '\\f2f0';\r\n}\r\n.zmdi-caret-down-circle:before {\r\n  content: '\\f2f1';\r\n}\r\n.zmdi-caret-down:before {\r\n  content: '\\f2f2';\r\n}\r\n.zmdi-caret-left-circle:before {\r\n  content: '\\f2f3';\r\n}\r\n.zmdi-caret-left:before {\r\n  content: '\\f2f4';\r\n}\r\n.zmdi-caret-right-circle:before {\r\n  content: '\\f2f5';\r\n}\r\n.zmdi-caret-right:before {\r\n  content: '\\f2f6';\r\n}\r\n.zmdi-caret-up-circle:before {\r\n  content: '\\f2f7';\r\n}\r\n.zmdi-caret-up:before {\r\n  content: '\\f2f8';\r\n}\r\n.zmdi-chevron-down:before {\r\n  content: '\\f2f9';\r\n}\r\n.zmdi-chevron-left:before {\r\n  content: '\\f2fa';\r\n}\r\n.zmdi-chevron-right:before {\r\n  content: '\\f2fb';\r\n}\r\n.zmdi-chevron-up:before {\r\n  content: '\\f2fc';\r\n}\r\n.zmdi-forward:before {\r\n  content: '\\f2fd';\r\n}\r\n.zmdi-long-arrow-down:before {\r\n  content: '\\f2fe';\r\n}\r\n.zmdi-long-arrow-left:before {\r\n  content: '\\f2ff';\r\n}\r\n.zmdi-long-arrow-return:before {\r\n  content: '\\f300';\r\n}\r\n.zmdi-long-arrow-right:before {\r\n  content: '\\f301';\r\n}\r\n.zmdi-long-arrow-tab:before {\r\n  content: '\\f302';\r\n}\r\n.zmdi-long-arrow-up:before {\r\n  content: '\\f303';\r\n}\r\n.zmdi-rotate-ccw:before {\r\n  content: '\\f304';\r\n}\r\n.zmdi-rotate-cw:before {\r\n  content: '\\f305';\r\n}\r\n.zmdi-rotate-left:before {\r\n  content: '\\f306';\r\n}\r\n.zmdi-rotate-right:before {\r\n  content: '\\f307';\r\n}\r\n.zmdi-square-down:before {\r\n  content: '\\f308';\r\n}\r\n.zmdi-square-right:before {\r\n  content: '\\f309';\r\n}\r\n.zmdi-swap-alt:before {\r\n  content: '\\f30a';\r\n}\r\n.zmdi-swap-vertical-circle:before {\r\n  content: '\\f30b';\r\n}\r\n.zmdi-swap-vertical:before {\r\n  content: '\\f30c';\r\n}\r\n.zmdi-swap:before {\r\n  content: '\\f30d';\r\n}\r\n.zmdi-trending-down:before {\r\n  content: '\\f30e';\r\n}\r\n.zmdi-trending-flat:before {\r\n  content: '\\f30f';\r\n}\r\n.zmdi-trending-up:before {\r\n  content: '\\f310';\r\n}\r\n.zmdi-unfold-less:before {\r\n  content: '\\f311';\r\n}\r\n.zmdi-unfold-more:before {\r\n  content: '\\f312';\r\n}\r\n.zmdi-apps:before {\r\n  content: '\\f313';\r\n}\r\n.zmdi-grid-off:before {\r\n  content: '\\f314';\r\n}\r\n.zmdi-grid:before {\r\n  content: '\\f315';\r\n}\r\n.zmdi-view-agenda:before {\r\n  content: '\\f316';\r\n}\r\n.zmdi-view-array:before {\r\n  content: '\\f317';\r\n}\r\n.zmdi-view-carousel:before {\r\n  content: '\\f318';\r\n}\r\n.zmdi-view-column:before {\r\n  content: '\\f319';\r\n}\r\n.zmdi-view-comfy:before {\r\n  content: '\\f31a';\r\n}\r\n.zmdi-view-compact:before {\r\n  content: '\\f31b';\r\n}\r\n.zmdi-view-dashboard:before {\r\n  content: '\\f31c';\r\n}\r\n.zmdi-view-day:before {\r\n  content: '\\f31d';\r\n}\r\n.zmdi-view-headline:before {\r\n  content: '\\f31e';\r\n}\r\n.zmdi-view-list-alt:before {\r\n  content: '\\f31f';\r\n}\r\n.zmdi-view-list:before {\r\n  content: '\\f320';\r\n}\r\n.zmdi-view-module:before {\r\n  content: '\\f321';\r\n}\r\n.zmdi-view-quilt:before {\r\n  content: '\\f322';\r\n}\r\n.zmdi-view-stream:before {\r\n  content: '\\f323';\r\n}\r\n.zmdi-view-subtitles:before {\r\n  content: '\\f324';\r\n}\r\n.zmdi-view-toc:before {\r\n  content: '\\f325';\r\n}\r\n.zmdi-view-web:before {\r\n  content: '\\f326';\r\n}\r\n.zmdi-view-week:before {\r\n  content: '\\f327';\r\n}\r\n.zmdi-widgets:before {\r\n  content: '\\f328';\r\n}\r\n.zmdi-alarm-check:before {\r\n  content: '\\f329';\r\n}\r\n.zmdi-alarm-off:before {\r\n  content: '\\f32a';\r\n}\r\n.zmdi-alarm-plus:before {\r\n  content: '\\f32b';\r\n}\r\n.zmdi-alarm-snooze:before {\r\n  content: '\\f32c';\r\n}\r\n.zmdi-alarm:before {\r\n  content: '\\f32d';\r\n}\r\n.zmdi-calendar-alt:before {\r\n  content: '\\f32e';\r\n}\r\n.zmdi-calendar-check:before {\r\n  content: '\\f32f';\r\n}\r\n.zmdi-calendar-close:before {\r\n  content: '\\f330';\r\n}\r\n.zmdi-calendar-note:before {\r\n  content: '\\f331';\r\n}\r\n.zmdi-calendar:before {\r\n  content: '\\f332';\r\n}\r\n.zmdi-time-countdown:before {\r\n  content: '\\f333';\r\n}\r\n.zmdi-time-interval:before {\r\n  content: '\\f334';\r\n}\r\n.zmdi-time-restore-setting:before {\r\n  content: '\\f335';\r\n}\r\n.zmdi-time-restore:before {\r\n  content: '\\f336';\r\n}\r\n.zmdi-time:before {\r\n  content: '\\f337';\r\n}\r\n.zmdi-timer-off:before {\r\n  content: '\\f338';\r\n}\r\n.zmdi-timer:before {\r\n  content: '\\f339';\r\n}\r\n.zmdi-android-alt:before {\r\n  content: '\\f33a';\r\n}\r\n.zmdi-android:before {\r\n  content: '\\f33b';\r\n}\r\n.zmdi-apple:before {\r\n  content: '\\f33c';\r\n}\r\n.zmdi-behance:before {\r\n  content: '\\f33d';\r\n}\r\n.zmdi-codepen:before {\r\n  content: '\\f33e';\r\n}\r\n.zmdi-dribbble:before {\r\n  content: '\\f33f';\r\n}\r\n.zmdi-dropbox:before {\r\n  content: '\\f340';\r\n}\r\n.zmdi-evernote:before {\r\n  content: '\\f341';\r\n}\r\n.zmdi-facebook-box:before {\r\n  content: '\\f342';\r\n}\r\n.zmdi-facebook:before {\r\n  content: '\\f343';\r\n}\r\n.zmdi-github-box:before {\r\n  content: '\\f344';\r\n}\r\n.zmdi-github:before {\r\n  content: '\\f345';\r\n}\r\n.zmdi-google-drive:before {\r\n  content: '\\f346';\r\n}\r\n.zmdi-google-earth:before {\r\n  content: '\\f347';\r\n}\r\n.zmdi-google-glass:before {\r\n  content: '\\f348';\r\n}\r\n.zmdi-google-maps:before {\r\n  content: '\\f349';\r\n}\r\n.zmdi-google-pages:before {\r\n  content: '\\f34a';\r\n}\r\n.zmdi-google-play:before {\r\n  content: '\\f34b';\r\n}\r\n.zmdi-google-plus-box:before {\r\n  content: '\\f34c';\r\n}\r\n.zmdi-google-plus:before {\r\n  content: '\\f34d';\r\n}\r\n.zmdi-google:before {\r\n  content: '\\f34e';\r\n}\r\n.zmdi-instagram:before {\r\n  content: '\\f34f';\r\n}\r\n.zmdi-language-css3:before {\r\n  content: '\\f350';\r\n}\r\n.zmdi-language-html5:before {\r\n  content: '\\f351';\r\n}\r\n.zmdi-language-javascript:before {\r\n  content: '\\f352';\r\n}\r\n.zmdi-language-python-alt:before {\r\n  content: '\\f353';\r\n}\r\n.zmdi-language-python:before {\r\n  content: '\\f354';\r\n}\r\n.zmdi-lastfm:before {\r\n  content: '\\f355';\r\n}\r\n.zmdi-linkedin-box:before {\r\n  content: '\\f356';\r\n}\r\n.zmdi-paypal:before {\r\n  content: '\\f357';\r\n}\r\n.zmdi-pinterest-box:before {\r\n  content: '\\f358';\r\n}\r\n.zmdi-pocket:before {\r\n  content: '\\f359';\r\n}\r\n.zmdi-polymer:before {\r\n  content: '\\f35a';\r\n}\r\n.zmdi-share:before {\r\n  content: '\\f35b';\r\n}\r\n.zmdi-stackoverflow:before {\r\n  content: '\\f35c';\r\n}\r\n.zmdi-steam-square:before {\r\n  content: '\\f35d';\r\n}\r\n.zmdi-steam:before {\r\n  content: '\\f35e';\r\n}\r\n.zmdi-twitter-box:before {\r\n  content: '\\f35f';\r\n}\r\n.zmdi-twitter:before {\r\n  content: '\\f360';\r\n}\r\n.zmdi-vk:before {\r\n  content: '\\f361';\r\n}\r\n.zmdi-wikipedia:before {\r\n  content: '\\f362';\r\n}\r\n.zmdi-windows:before {\r\n  content: '\\f363';\r\n}\r\n.zmdi-aspect-ratio-alt:before {\r\n  content: '\\f364';\r\n}\r\n.zmdi-aspect-ratio:before {\r\n  content: '\\f365';\r\n}\r\n.zmdi-blur-circular:before {\r\n  content: '\\f366';\r\n}\r\n.zmdi-blur-linear:before {\r\n  content: '\\f367';\r\n}\r\n.zmdi-blur-off:before {\r\n  content: '\\f368';\r\n}\r\n.zmdi-blur:before {\r\n  content: '\\f369';\r\n}\r\n.zmdi-brightness-2:before {\r\n  content: '\\f36a';\r\n}\r\n.zmdi-brightness-3:before {\r\n  content: '\\f36b';\r\n}\r\n.zmdi-brightness-4:before {\r\n  content: '\\f36c';\r\n}\r\n.zmdi-brightness-5:before {\r\n  content: '\\f36d';\r\n}\r\n.zmdi-brightness-6:before {\r\n  content: '\\f36e';\r\n}\r\n.zmdi-brightness-7:before {\r\n  content: '\\f36f';\r\n}\r\n.zmdi-brightness-auto:before {\r\n  content: '\\f370';\r\n}\r\n.zmdi-brightness-setting:before {\r\n  content: '\\f371';\r\n}\r\n.zmdi-broken-image:before {\r\n  content: '\\f372';\r\n}\r\n.zmdi-center-focus-strong:before {\r\n  content: '\\f373';\r\n}\r\n.zmdi-center-focus-weak:before {\r\n  content: '\\f374';\r\n}\r\n.zmdi-compare:before {\r\n  content: '\\f375';\r\n}\r\n.zmdi-crop-16-9:before {\r\n  content: '\\f376';\r\n}\r\n.zmdi-crop-3-2:before {\r\n  content: '\\f377';\r\n}\r\n.zmdi-crop-5-4:before {\r\n  content: '\\f378';\r\n}\r\n.zmdi-crop-7-5:before {\r\n  content: '\\f379';\r\n}\r\n.zmdi-crop-din:before {\r\n  content: '\\f37a';\r\n}\r\n.zmdi-crop-free:before {\r\n  content: '\\f37b';\r\n}\r\n.zmdi-crop-landscape:before {\r\n  content: '\\f37c';\r\n}\r\n.zmdi-crop-portrait:before {\r\n  content: '\\f37d';\r\n}\r\n.zmdi-crop-square:before {\r\n  content: '\\f37e';\r\n}\r\n.zmdi-exposure-alt:before {\r\n  content: '\\f37f';\r\n}\r\n.zmdi-exposure:before {\r\n  content: '\\f380';\r\n}\r\n.zmdi-filter-b-and-w:before {\r\n  content: '\\f381';\r\n}\r\n.zmdi-filter-center-focus:before {\r\n  content: '\\f382';\r\n}\r\n.zmdi-filter-frames:before {\r\n  content: '\\f383';\r\n}\r\n.zmdi-filter-tilt-shift:before {\r\n  content: '\\f384';\r\n}\r\n.zmdi-gradient:before {\r\n  content: '\\f385';\r\n}\r\n.zmdi-grain:before {\r\n  content: '\\f386';\r\n}\r\n.zmdi-graphic-eq:before {\r\n  content: '\\f387';\r\n}\r\n.zmdi-hdr-off:before {\r\n  content: '\\f388';\r\n}\r\n.zmdi-hdr-strong:before {\r\n  content: '\\f389';\r\n}\r\n.zmdi-hdr-weak:before {\r\n  content: '\\f38a';\r\n}\r\n.zmdi-hdr:before {\r\n  content: '\\f38b';\r\n}\r\n.zmdi-iridescent:before {\r\n  content: '\\f38c';\r\n}\r\n.zmdi-leak-off:before {\r\n  content: '\\f38d';\r\n}\r\n.zmdi-leak:before {\r\n  content: '\\f38e';\r\n}\r\n.zmdi-looks:before {\r\n  content: '\\f38f';\r\n}\r\n.zmdi-loupe:before {\r\n  content: '\\f390';\r\n}\r\n.zmdi-panorama-horizontal:before {\r\n  content: '\\f391';\r\n}\r\n.zmdi-panorama-vertical:before {\r\n  content: '\\f392';\r\n}\r\n.zmdi-panorama-wide-angle:before {\r\n  content: '\\f393';\r\n}\r\n.zmdi-photo-size-select-large:before {\r\n  content: '\\f394';\r\n}\r\n.zmdi-photo-size-select-small:before {\r\n  content: '\\f395';\r\n}\r\n.zmdi-picture-in-picture:before {\r\n  content: '\\f396';\r\n}\r\n.zmdi-slideshow:before {\r\n  content: '\\f397';\r\n}\r\n.zmdi-texture:before {\r\n  content: '\\f398';\r\n}\r\n.zmdi-tonality:before {\r\n  content: '\\f399';\r\n}\r\n.zmdi-vignette:before {\r\n  content: '\\f39a';\r\n}\r\n.zmdi-wb-auto:before {\r\n  content: '\\f39b';\r\n}\r\n.zmdi-eject-alt:before {\r\n  content: '\\f39c';\r\n}\r\n.zmdi-eject:before {\r\n  content: '\\f39d';\r\n}\r\n.zmdi-equalizer:before {\r\n  content: '\\f39e';\r\n}\r\n.zmdi-fast-forward:before {\r\n  content: '\\f39f';\r\n}\r\n.zmdi-fast-rewind:before {\r\n  content: '\\f3a0';\r\n}\r\n.zmdi-forward-10:before {\r\n  content: '\\f3a1';\r\n}\r\n.zmdi-forward-30:before {\r\n  content: '\\f3a2';\r\n}\r\n.zmdi-forward-5:before {\r\n  content: '\\f3a3';\r\n}\r\n.zmdi-hearing:before {\r\n  content: '\\f3a4';\r\n}\r\n.zmdi-pause-circle-outline:before {\r\n  content: '\\f3a5';\r\n}\r\n.zmdi-pause-circle:before {\r\n  content: '\\f3a6';\r\n}\r\n.zmdi-pause:before {\r\n  content: '\\f3a7';\r\n}\r\n.zmdi-play-circle-outline:before {\r\n  content: '\\f3a8';\r\n}\r\n.zmdi-play-circle:before {\r\n  content: '\\f3a9';\r\n}\r\n.zmdi-play:before {\r\n  content: '\\f3aa';\r\n}\r\n.zmdi-playlist-audio:before {\r\n  content: '\\f3ab';\r\n}\r\n.zmdi-playlist-plus:before {\r\n  content: '\\f3ac';\r\n}\r\n.zmdi-repeat-one:before {\r\n  content: '\\f3ad';\r\n}\r\n.zmdi-repeat:before {\r\n  content: '\\f3ae';\r\n}\r\n.zmdi-replay-10:before {\r\n  content: '\\f3af';\r\n}\r\n.zmdi-replay-30:before {\r\n  content: '\\f3b0';\r\n}\r\n.zmdi-replay-5:before {\r\n  content: '\\f3b1';\r\n}\r\n.zmdi-replay:before {\r\n  content: '\\f3b2';\r\n}\r\n.zmdi-shuffle:before {\r\n  content: '\\f3b3';\r\n}\r\n.zmdi-skip-next:before {\r\n  content: '\\f3b4';\r\n}\r\n.zmdi-skip-previous:before {\r\n  content: '\\f3b5';\r\n}\r\n.zmdi-stop:before {\r\n  content: '\\f3b6';\r\n}\r\n.zmdi-surround-sound:before {\r\n  content: '\\f3b7';\r\n}\r\n.zmdi-tune:before {\r\n  content: '\\f3b8';\r\n}\r\n.zmdi-volume-down:before {\r\n  content: '\\f3b9';\r\n}\r\n.zmdi-volume-mute:before {\r\n  content: '\\f3ba';\r\n}\r\n.zmdi-volume-off:before {\r\n  content: '\\f3bb';\r\n}\r\n.zmdi-volume-up:before {\r\n  content: '\\f3bc';\r\n}\r\n.zmdi-n-1-square:before {\r\n  content: '\\f3bd';\r\n}\r\n.zmdi-n-2-square:before {\r\n  content: '\\f3be';\r\n}\r\n.zmdi-n-3-square:before {\r\n  content: '\\f3bf';\r\n}\r\n.zmdi-n-4-square:before {\r\n  content: '\\f3c0';\r\n}\r\n.zmdi-n-5-square:before {\r\n  content: '\\f3c1';\r\n}\r\n.zmdi-n-6-square:before {\r\n  content: '\\f3c2';\r\n}\r\n.zmdi-neg-1:before {\r\n  content: '\\f3c3';\r\n}\r\n.zmdi-neg-2:before {\r\n  content: '\\f3c4';\r\n}\r\n.zmdi-plus-1:before {\r\n  content: '\\f3c5';\r\n}\r\n.zmdi-plus-2:before {\r\n  content: '\\f3c6';\r\n}\r\n.zmdi-sec-10:before {\r\n  content: '\\f3c7';\r\n}\r\n.zmdi-sec-3:before {\r\n  content: '\\f3c8';\r\n}\r\n.zmdi-zero:before {\r\n  content: '\\f3c9';\r\n}\r\n.zmdi-airline-seat-flat-angled:before {\r\n  content: '\\f3ca';\r\n}\r\n.zmdi-airline-seat-flat:before {\r\n  content: '\\f3cb';\r\n}\r\n.zmdi-airline-seat-individual-suite:before {\r\n  content: '\\f3cc';\r\n}\r\n.zmdi-airline-seat-legroom-extra:before {\r\n  content: '\\f3cd';\r\n}\r\n.zmdi-airline-seat-legroom-normal:before {\r\n  content: '\\f3ce';\r\n}\r\n.zmdi-airline-seat-legroom-reduced:before {\r\n  content: '\\f3cf';\r\n}\r\n.zmdi-airline-seat-recline-extra:before {\r\n  content: '\\f3d0';\r\n}\r\n.zmdi-airline-seat-recline-normal:before {\r\n  content: '\\f3d1';\r\n}\r\n.zmdi-airplay:before {\r\n  content: '\\f3d2';\r\n}\r\n.zmdi-closed-caption:before {\r\n  content: '\\f3d3';\r\n}\r\n.zmdi-confirmation-number:before {\r\n  content: '\\f3d4';\r\n}\r\n.zmdi-developer-board:before {\r\n  content: '\\f3d5';\r\n}\r\n.zmdi-disc-full:before {\r\n  content: '\\f3d6';\r\n}\r\n.zmdi-explicit:before {\r\n  content: '\\f3d7';\r\n}\r\n.zmdi-flight-land:before {\r\n  content: '\\f3d8';\r\n}\r\n.zmdi-flight-takeoff:before {\r\n  content: '\\f3d9';\r\n}\r\n.zmdi-flip-to-back:before {\r\n  content: '\\f3da';\r\n}\r\n.zmdi-flip-to-front:before {\r\n  content: '\\f3db';\r\n}\r\n.zmdi-group-work:before {\r\n  content: '\\f3dc';\r\n}\r\n.zmdi-hd:before {\r\n  content: '\\f3dd';\r\n}\r\n.zmdi-hq:before {\r\n  content: '\\f3de';\r\n}\r\n.zmdi-markunread-mailbox:before {\r\n  content: '\\f3df';\r\n}\r\n.zmdi-memory:before {\r\n  content: '\\f3e0';\r\n}\r\n.zmdi-nfc:before {\r\n  content: '\\f3e1';\r\n}\r\n.zmdi-play-for-work:before {\r\n  content: '\\f3e2';\r\n}\r\n.zmdi-power-input:before {\r\n  content: '\\f3e3';\r\n}\r\n.zmdi-present-to-all:before {\r\n  content: '\\f3e4';\r\n}\r\n.zmdi-satellite:before {\r\n  content: '\\f3e5';\r\n}\r\n.zmdi-tap-and-play:before {\r\n  content: '\\f3e6';\r\n}\r\n.zmdi-vibration:before {\r\n  content: '\\f3e7';\r\n}\r\n.zmdi-voicemail:before {\r\n  content: '\\f3e8';\r\n}\r\n.zmdi-group:before {\r\n  content: '\\f3e9';\r\n}\r\n.zmdi-rss:before {\r\n  content: '\\f3ea';\r\n}\r\n.zmdi-shape:before {\r\n  content: '\\f3eb';\r\n}\r\n.zmdi-spinner:before {\r\n  content: '\\f3ec';\r\n}\r\n.zmdi-ungroup:before {\r\n  content: '\\f3ed';\r\n}\r\n.zmdi-500px:before {\r\n  content: '\\f3ee';\r\n}\r\n.zmdi-8tracks:before {\r\n  content: '\\f3ef';\r\n}\r\n.zmdi-amazon:before {\r\n  content: '\\f3f0';\r\n}\r\n.zmdi-blogger:before {\r\n  content: '\\f3f1';\r\n}\r\n.zmdi-delicious:before {\r\n  content: '\\f3f2';\r\n}\r\n.zmdi-disqus:before {\r\n  content: '\\f3f3';\r\n}\r\n.zmdi-flattr:before {\r\n  content: '\\f3f4';\r\n}\r\n.zmdi-flickr:before {\r\n  content: '\\f3f5';\r\n}\r\n.zmdi-github-alt:before {\r\n  content: '\\f3f6';\r\n}\r\n.zmdi-google-old:before {\r\n  content: '\\f3f7';\r\n}\r\n.zmdi-linkedin:before {\r\n  content: '\\f3f8';\r\n}\r\n.zmdi-odnoklassniki:before {\r\n  content: '\\f3f9';\r\n}\r\n.zmdi-outlook:before {\r\n  content: '\\f3fa';\r\n}\r\n.zmdi-paypal-alt:before {\r\n  content: '\\f3fb';\r\n}\r\n.zmdi-pinterest:before {\r\n  content: '\\f3fc';\r\n}\r\n.zmdi-playstation:before {\r\n  content: '\\f3fd';\r\n}\r\n.zmdi-reddit:before {\r\n  content: '\\f3fe';\r\n}\r\n.zmdi-skype:before {\r\n  content: '\\f3ff';\r\n}\r\n.zmdi-slideshare:before {\r\n  content: '\\f400';\r\n}\r\n.zmdi-soundcloud:before {\r\n  content: '\\f401';\r\n}\r\n.zmdi-tumblr:before {\r\n  content: '\\f402';\r\n}\r\n.zmdi-twitch:before {\r\n  content: '\\f403';\r\n}\r\n.zmdi-vimeo:before {\r\n  content: '\\f404';\r\n}\r\n.zmdi-whatsapp:before {\r\n  content: '\\f405';\r\n}\r\n.zmdi-xbox:before {\r\n  content: '\\f406';\r\n}\r\n.zmdi-yahoo:before {\r\n  content: '\\f407';\r\n}\r\n.zmdi-youtube-play:before {\r\n  content: '\\f408';\r\n}\r\n.zmdi-youtube:before {\r\n  content: '\\f409';\r\n}\r\n.zmdi-3d-rotation:before {\r\n  content: '\\f101';\r\n}\r\n.zmdi-airplane-off:before {\r\n  content: '\\f102';\r\n}\r\n.zmdi-airplane:before {\r\n  content: '\\f103';\r\n}\r\n.zmdi-album:before {\r\n  content: '\\f104';\r\n}\r\n.zmdi-archive:before {\r\n  content: '\\f105';\r\n}\r\n.zmdi-assignment-account:before {\r\n  content: '\\f106';\r\n}\r\n.zmdi-assignment-alert:before {\r\n  content: '\\f107';\r\n}\r\n.zmdi-assignment-check:before {\r\n  content: '\\f108';\r\n}\r\n.zmdi-assignment-o:before {\r\n  content: '\\f109';\r\n}\r\n.zmdi-assignment-return:before {\r\n  content: '\\f10a';\r\n}\r\n.zmdi-assignment-returned:before {\r\n  content: '\\f10b';\r\n}\r\n.zmdi-assignment:before {\r\n  content: '\\f10c';\r\n}\r\n.zmdi-attachment-alt:before {\r\n  content: '\\f10d';\r\n}\r\n.zmdi-attachment:before {\r\n  content: '\\f10e';\r\n}\r\n.zmdi-audio:before {\r\n  content: '\\f10f';\r\n}\r\n.zmdi-badge-check:before {\r\n  content: '\\f110';\r\n}\r\n.zmdi-balance-wallet:before {\r\n  content: '\\f111';\r\n}\r\n.zmdi-balance:before {\r\n  content: '\\f112';\r\n}\r\n.zmdi-battery-alert:before {\r\n  content: '\\f113';\r\n}\r\n.zmdi-battery-flash:before {\r\n  content: '\\f114';\r\n}\r\n.zmdi-battery-unknown:before {\r\n  content: '\\f115';\r\n}\r\n.zmdi-battery:before {\r\n  content: '\\f116';\r\n}\r\n.zmdi-bike:before {\r\n  content: '\\f117';\r\n}\r\n.zmdi-block-alt:before {\r\n  content: '\\f118';\r\n}\r\n.zmdi-block:before {\r\n  content: '\\f119';\r\n}\r\n.zmdi-boat:before {\r\n  content: '\\f11a';\r\n}\r\n.zmdi-book-image:before {\r\n  content: '\\f11b';\r\n}\r\n.zmdi-book:before {\r\n  content: '\\f11c';\r\n}\r\n.zmdi-bookmark-outline:before {\r\n  content: '\\f11d';\r\n}\r\n.zmdi-bookmark:before {\r\n  content: '\\f11e';\r\n}\r\n.zmdi-brush:before {\r\n  content: '\\f11f';\r\n}\r\n.zmdi-bug:before {\r\n  content: '\\f120';\r\n}\r\n.zmdi-bus:before {\r\n  content: '\\f121';\r\n}\r\n.zmdi-cake:before {\r\n  content: '\\f122';\r\n}\r\n.zmdi-car-taxi:before {\r\n  content: '\\f123';\r\n}\r\n.zmdi-car-wash:before {\r\n  content: '\\f124';\r\n}\r\n.zmdi-car:before {\r\n  content: '\\f125';\r\n}\r\n.zmdi-card-giftcard:before {\r\n  content: '\\f126';\r\n}\r\n.zmdi-card-membership:before {\r\n  content: '\\f127';\r\n}\r\n.zmdi-card-travel:before {\r\n  content: '\\f128';\r\n}\r\n.zmdi-card:before {\r\n  content: '\\f129';\r\n}\r\n.zmdi-case-check:before {\r\n  content: '\\f12a';\r\n}\r\n.zmdi-case-download:before {\r\n  content: '\\f12b';\r\n}\r\n.zmdi-case-play:before {\r\n  content: '\\f12c';\r\n}\r\n.zmdi-case:before {\r\n  content: '\\f12d';\r\n}\r\n.zmdi-cast-connected:before {\r\n  content: '\\f12e';\r\n}\r\n.zmdi-cast:before {\r\n  content: '\\f12f';\r\n}\r\n.zmdi-chart-donut:before {\r\n  content: '\\f130';\r\n}\r\n.zmdi-chart:before {\r\n  content: '\\f131';\r\n}\r\n.zmdi-city-alt:before {\r\n  content: '\\f132';\r\n}\r\n.zmdi-city:before {\r\n  content: '\\f133';\r\n}\r\n.zmdi-close-circle-o:before {\r\n  content: '\\f134';\r\n}\r\n.zmdi-close-circle:before {\r\n  content: '\\f135';\r\n}\r\n.zmdi-close:before {\r\n  content: '\\f136';\r\n}\r\n.zmdi-cocktail:before {\r\n  content: '\\f137';\r\n}\r\n.zmdi-code-setting:before {\r\n  content: '\\f138';\r\n}\r\n.zmdi-code-smartphone:before {\r\n  content: '\\f139';\r\n}\r\n.zmdi-code:before {\r\n  content: '\\f13a';\r\n}\r\n.zmdi-coffee:before {\r\n  content: '\\f13b';\r\n}\r\n.zmdi-collection-bookmark:before {\r\n  content: '\\f13c';\r\n}\r\n.zmdi-collection-case-play:before {\r\n  content: '\\f13d';\r\n}\r\n.zmdi-collection-folder-image:before {\r\n  content: '\\f13e';\r\n}\r\n.zmdi-collection-image-o:before {\r\n  content: '\\f13f';\r\n}\r\n.zmdi-collection-image:before {\r\n  content: '\\f140';\r\n}\r\n.zmdi-collection-item-1:before {\r\n  content: '\\f141';\r\n}\r\n.zmdi-collection-item-2:before {\r\n  content: '\\f142';\r\n}\r\n.zmdi-collection-item-3:before {\r\n  content: '\\f143';\r\n}\r\n.zmdi-collection-item-4:before {\r\n  content: '\\f144';\r\n}\r\n.zmdi-collection-item-5:before {\r\n  content: '\\f145';\r\n}\r\n.zmdi-collection-item-6:before {\r\n  content: '\\f146';\r\n}\r\n.zmdi-collection-item-7:before {\r\n  content: '\\f147';\r\n}\r\n.zmdi-collection-item-8:before {\r\n  content: '\\f148';\r\n}\r\n.zmdi-collection-item-9-plus:before {\r\n  content: '\\f149';\r\n}\r\n.zmdi-collection-item-9:before {\r\n  content: '\\f14a';\r\n}\r\n.zmdi-collection-item:before {\r\n  content: '\\f14b';\r\n}\r\n.zmdi-collection-music:before {\r\n  content: '\\f14c';\r\n}\r\n.zmdi-collection-pdf:before {\r\n  content: '\\f14d';\r\n}\r\n.zmdi-collection-plus:before {\r\n  content: '\\f14e';\r\n}\r\n.zmdi-collection-speaker:before {\r\n  content: '\\f14f';\r\n}\r\n.zmdi-collection-text:before {\r\n  content: '\\f150';\r\n}\r\n.zmdi-collection-video:before {\r\n  content: '\\f151';\r\n}\r\n.zmdi-compass:before {\r\n  content: '\\f152';\r\n}\r\n.zmdi-cutlery:before {\r\n  content: '\\f153';\r\n}\r\n.zmdi-delete:before {\r\n  content: '\\f154';\r\n}\r\n.zmdi-dialpad:before {\r\n  content: '\\f155';\r\n}\r\n.zmdi-dns:before {\r\n  content: '\\f156';\r\n}\r\n.zmdi-drink:before {\r\n  content: '\\f157';\r\n}\r\n.zmdi-edit:before {\r\n  content: '\\f158';\r\n}\r\n.zmdi-email-open:before {\r\n  content: '\\f159';\r\n}\r\n.zmdi-email:before {\r\n  content: '\\f15a';\r\n}\r\n.zmdi-eye-off:before {\r\n  content: '\\f15b';\r\n}\r\n.zmdi-eye:before {\r\n  content: '\\f15c';\r\n}\r\n.zmdi-eyedropper:before {\r\n  content: '\\f15d';\r\n}\r\n.zmdi-favorite-outline:before {\r\n  content: '\\f15e';\r\n}\r\n.zmdi-favorite:before {\r\n  content: '\\f15f';\r\n}\r\n.zmdi-filter-list:before {\r\n  content: '\\f160';\r\n}\r\n.zmdi-fire:before {\r\n  content: '\\f161';\r\n}\r\n.zmdi-flag:before {\r\n  content: '\\f162';\r\n}\r\n.zmdi-flare:before {\r\n  content: '\\f163';\r\n}\r\n.zmdi-flash-auto:before {\r\n  content: '\\f164';\r\n}\r\n.zmdi-flash-off:before {\r\n  content: '\\f165';\r\n}\r\n.zmdi-flash:before {\r\n  content: '\\f166';\r\n}\r\n.zmdi-flip:before {\r\n  content: '\\f167';\r\n}\r\n.zmdi-flower-alt:before {\r\n  content: '\\f168';\r\n}\r\n.zmdi-flower:before {\r\n  content: '\\f169';\r\n}\r\n.zmdi-font:before {\r\n  content: '\\f16a';\r\n}\r\n.zmdi-fullscreen-alt:before {\r\n  content: '\\f16b';\r\n}\r\n.zmdi-fullscreen-exit:before {\r\n  content: '\\f16c';\r\n}\r\n.zmdi-fullscreen:before {\r\n  content: '\\f16d';\r\n}\r\n.zmdi-functions:before {\r\n  content: '\\f16e';\r\n}\r\n.zmdi-gas-station:before {\r\n  content: '\\f16f';\r\n}\r\n.zmdi-gesture:before {\r\n  content: '\\f170';\r\n}\r\n.zmdi-globe-alt:before {\r\n  content: '\\f171';\r\n}\r\n.zmdi-globe-lock:before {\r\n  content: '\\f172';\r\n}\r\n.zmdi-globe:before {\r\n  content: '\\f173';\r\n}\r\n.zmdi-graduation-cap:before {\r\n  content: '\\f174';\r\n}\r\n.zmdi-home:before {\r\n  content: '\\f175';\r\n}\r\n.zmdi-hospital-alt:before {\r\n  content: '\\f176';\r\n}\r\n.zmdi-hospital:before {\r\n  content: '\\f177';\r\n}\r\n.zmdi-hotel:before {\r\n  content: '\\f178';\r\n}\r\n.zmdi-hourglass-alt:before {\r\n  content: '\\f179';\r\n}\r\n.zmdi-hourglass-outline:before {\r\n  content: '\\f17a';\r\n}\r\n.zmdi-hourglass:before {\r\n  content: '\\f17b';\r\n}\r\n.zmdi-http:before {\r\n  content: '\\f17c';\r\n}\r\n.zmdi-image-alt:before {\r\n  content: '\\f17d';\r\n}\r\n.zmdi-image-o:before {\r\n  content: '\\f17e';\r\n}\r\n.zmdi-image:before {\r\n  content: '\\f17f';\r\n}\r\n.zmdi-inbox:before {\r\n  content: '\\f180';\r\n}\r\n.zmdi-invert-colors-off:before {\r\n  content: '\\f181';\r\n}\r\n.zmdi-invert-colors:before {\r\n  content: '\\f182';\r\n}\r\n.zmdi-key:before {\r\n  content: '\\f183';\r\n}\r\n.zmdi-label-alt-outline:before {\r\n  content: '\\f184';\r\n}\r\n.zmdi-label-alt:before {\r\n  content: '\\f185';\r\n}\r\n.zmdi-label-heart:before {\r\n  content: '\\f186';\r\n}\r\n.zmdi-label:before {\r\n  content: '\\f187';\r\n}\r\n.zmdi-labels:before {\r\n  content: '\\f188';\r\n}\r\n.zmdi-lamp:before {\r\n  content: '\\f189';\r\n}\r\n.zmdi-landscape:before {\r\n  content: '\\f18a';\r\n}\r\n.zmdi-layers-off:before {\r\n  content: '\\f18b';\r\n}\r\n.zmdi-layers:before {\r\n  content: '\\f18c';\r\n}\r\n.zmdi-library:before {\r\n  content: '\\f18d';\r\n}\r\n.zmdi-link:before {\r\n  content: '\\f18e';\r\n}\r\n.zmdi-lock-open:before {\r\n  content: '\\f18f';\r\n}\r\n.zmdi-lock-outline:before {\r\n  content: '\\f190';\r\n}\r\n.zmdi-lock:before {\r\n  content: '\\f191';\r\n}\r\n.zmdi-mail-reply-all:before {\r\n  content: '\\f192';\r\n}\r\n.zmdi-mail-reply:before {\r\n  content: '\\f193';\r\n}\r\n.zmdi-mail-send:before {\r\n  content: '\\f194';\r\n}\r\n.zmdi-mall:before {\r\n  content: '\\f195';\r\n}\r\n.zmdi-map:before {\r\n  content: '\\f196';\r\n}\r\n.zmdi-menu:before {\r\n  content: '\\f197';\r\n}\r\n.zmdi-money-box:before {\r\n  content: '\\f198';\r\n}\r\n.zmdi-money-off:before {\r\n  content: '\\f199';\r\n}\r\n.zmdi-money:before {\r\n  content: '\\f19a';\r\n}\r\n.zmdi-more-vert:before {\r\n  content: '\\f19b';\r\n}\r\n.zmdi-more:before {\r\n  content: '\\f19c';\r\n}\r\n.zmdi-movie-alt:before {\r\n  content: '\\f19d';\r\n}\r\n.zmdi-movie:before {\r\n  content: '\\f19e';\r\n}\r\n.zmdi-nature-people:before {\r\n  content: '\\f19f';\r\n}\r\n.zmdi-nature:before {\r\n  content: '\\f1a0';\r\n}\r\n.zmdi-navigation:before {\r\n  content: '\\f1a1';\r\n}\r\n.zmdi-open-in-browser:before {\r\n  content: '\\f1a2';\r\n}\r\n.zmdi-open-in-new:before {\r\n  content: '\\f1a3';\r\n}\r\n.zmdi-palette:before {\r\n  content: '\\f1a4';\r\n}\r\n.zmdi-parking:before {\r\n  content: '\\f1a5';\r\n}\r\n.zmdi-pin-account:before {\r\n  content: '\\f1a6';\r\n}\r\n.zmdi-pin-assistant:before {\r\n  content: '\\f1a7';\r\n}\r\n.zmdi-pin-drop:before {\r\n  content: '\\f1a8';\r\n}\r\n.zmdi-pin-help:before {\r\n  content: '\\f1a9';\r\n}\r\n.zmdi-pin-off:before {\r\n  content: '\\f1aa';\r\n}\r\n.zmdi-pin:before {\r\n  content: '\\f1ab';\r\n}\r\n.zmdi-pizza:before {\r\n  content: '\\f1ac';\r\n}\r\n.zmdi-plaster:before {\r\n  content: '\\f1ad';\r\n}\r\n.zmdi-power-setting:before {\r\n  content: '\\f1ae';\r\n}\r\n.zmdi-power:before {\r\n  content: '\\f1af';\r\n}\r\n.zmdi-print:before {\r\n  content: '\\f1b0';\r\n}\r\n.zmdi-puzzle-piece:before {\r\n  content: '\\f1b1';\r\n}\r\n.zmdi-quote:before {\r\n  content: '\\f1b2';\r\n}\r\n.zmdi-railway:before {\r\n  content: '\\f1b3';\r\n}\r\n.zmdi-receipt:before {\r\n  content: '\\f1b4';\r\n}\r\n.zmdi-refresh-alt:before {\r\n  content: '\\f1b5';\r\n}\r\n.zmdi-refresh-sync-alert:before {\r\n  content: '\\f1b6';\r\n}\r\n.zmdi-refresh-sync-off:before {\r\n  content: '\\f1b7';\r\n}\r\n.zmdi-refresh-sync:before {\r\n  content: '\\f1b8';\r\n}\r\n.zmdi-refresh:before {\r\n  content: '\\f1b9';\r\n}\r\n.zmdi-roller:before {\r\n  content: '\\f1ba';\r\n}\r\n.zmdi-ruler:before {\r\n  content: '\\f1bb';\r\n}\r\n.zmdi-scissors:before {\r\n  content: '\\f1bc';\r\n}\r\n.zmdi-screen-rotation-lock:before {\r\n  content: '\\f1bd';\r\n}\r\n.zmdi-screen-rotation:before {\r\n  content: '\\f1be';\r\n}\r\n.zmdi-search-for:before {\r\n  content: '\\f1bf';\r\n}\r\n.zmdi-search-in-file:before {\r\n  content: '\\f1c0';\r\n}\r\n.zmdi-search-in-page:before {\r\n  content: '\\f1c1';\r\n}\r\n.zmdi-search-replace:before {\r\n  content: '\\f1c2';\r\n}\r\n.zmdi-search:before {\r\n  content: '\\f1c3';\r\n}\r\n.zmdi-seat:before {\r\n  content: '\\f1c4';\r\n}\r\n.zmdi-settings-square:before {\r\n  content: '\\f1c5';\r\n}\r\n.zmdi-settings:before {\r\n  content: '\\f1c6';\r\n}\r\n.zmdi-shield-check:before {\r\n  content: '\\f1c7';\r\n}\r\n.zmdi-shield-security:before {\r\n  content: '\\f1c8';\r\n}\r\n.zmdi-shopping-basket:before {\r\n  content: '\\f1c9';\r\n}\r\n.zmdi-shopping-cart-plus:before {\r\n  content: '\\f1ca';\r\n}\r\n.zmdi-shopping-cart:before {\r\n  content: '\\f1cb';\r\n}\r\n.zmdi-sign-in:before {\r\n  content: '\\f1cc';\r\n}\r\n.zmdi-sort-amount-asc:before {\r\n  content: '\\f1cd';\r\n}\r\n.zmdi-sort-amount-desc:before {\r\n  content: '\\f1ce';\r\n}\r\n.zmdi-sort-asc:before {\r\n  content: '\\f1cf';\r\n}\r\n.zmdi-sort-desc:before {\r\n  content: '\\f1d0';\r\n}\r\n.zmdi-spellcheck:before {\r\n  content: '\\f1d1';\r\n}\r\n.zmdi-storage:before {\r\n  content: '\\f1d2';\r\n}\r\n.zmdi-store-24:before {\r\n  content: '\\f1d3';\r\n}\r\n.zmdi-store:before {\r\n  content: '\\f1d4';\r\n}\r\n.zmdi-subway:before {\r\n  content: '\\f1d5';\r\n}\r\n.zmdi-sun:before {\r\n  content: '\\f1d6';\r\n}\r\n.zmdi-tab-unselected:before {\r\n  content: '\\f1d7';\r\n}\r\n.zmdi-tab:before {\r\n  content: '\\f1d8';\r\n}\r\n.zmdi-tag-close:before {\r\n  content: '\\f1d9';\r\n}\r\n.zmdi-tag-more:before {\r\n  content: '\\f1da';\r\n}\r\n.zmdi-tag:before {\r\n  content: '\\f1db';\r\n}\r\n.zmdi-thumb-down:before {\r\n  content: '\\f1dc';\r\n}\r\n.zmdi-thumb-up-down:before {\r\n  content: '\\f1dd';\r\n}\r\n.zmdi-thumb-up:before {\r\n  content: '\\f1de';\r\n}\r\n.zmdi-ticket-star:before {\r\n  content: '\\f1df';\r\n}\r\n.zmdi-toll:before {\r\n  content: '\\f1e0';\r\n}\r\n.zmdi-toys:before {\r\n  content: '\\f1e1';\r\n}\r\n.zmdi-traffic:before {\r\n  content: '\\f1e2';\r\n}\r\n.zmdi-translate:before {\r\n  content: '\\f1e3';\r\n}\r\n.zmdi-triangle-down:before {\r\n  content: '\\f1e4';\r\n}\r\n.zmdi-triangle-up:before {\r\n  content: '\\f1e5';\r\n}\r\n.zmdi-truck:before {\r\n  content: '\\f1e6';\r\n}\r\n.zmdi-turning-sign:before {\r\n  content: '\\f1e7';\r\n}\r\n.zmdi-wallpaper:before {\r\n  content: '\\f1e8';\r\n}\r\n.zmdi-washing-machine:before {\r\n  content: '\\f1e9';\r\n}\r\n.zmdi-window-maximize:before {\r\n  content: '\\f1ea';\r\n}\r\n.zmdi-window-minimize:before {\r\n  content: '\\f1eb';\r\n}\r\n.zmdi-window-restore:before {\r\n  content: '\\f1ec';\r\n}\r\n.zmdi-wrench:before {\r\n  content: '\\f1ed';\r\n}\r\n.zmdi-zoom-in:before {\r\n  content: '\\f1ee';\r\n}\r\n.zmdi-zoom-out:before {\r\n  content: '\\f1ef';\r\n}\r\n.zmdi-alert-circle-o:before {\r\n  content: '\\f1f0';\r\n}\r\n.zmdi-alert-circle:before {\r\n  content: '\\f1f1';\r\n}\r\n.zmdi-alert-octagon:before {\r\n  content: '\\f1f2';\r\n}\r\n.zmdi-alert-polygon:before {\r\n  content: '\\f1f3';\r\n}\r\n.zmdi-alert-triangle:before {\r\n  content: '\\f1f4';\r\n}\r\n.zmdi-help-outline:before {\r\n  content: '\\f1f5';\r\n}\r\n.zmdi-help:before {\r\n  content: '\\f1f6';\r\n}\r\n.zmdi-info-outline:before {\r\n  content: '\\f1f7';\r\n}\r\n.zmdi-info:before {\r\n  content: '\\f1f8';\r\n}\r\n.zmdi-notifications-active:before {\r\n  content: '\\f1f9';\r\n}\r\n.zmdi-notifications-add:before {\r\n  content: '\\f1fa';\r\n}\r\n.zmdi-notifications-none:before {\r\n  content: '\\f1fb';\r\n}\r\n.zmdi-notifications-off:before {\r\n  content: '\\f1fc';\r\n}\r\n.zmdi-notifications-paused:before {\r\n  content: '\\f1fd';\r\n}\r\n.zmdi-notifications:before {\r\n  content: '\\f1fe';\r\n}\r\n.zmdi-account-add:before {\r\n  content: '\\f1ff';\r\n}\r\n.zmdi-account-box-mail:before {\r\n  content: '\\f200';\r\n}\r\n.zmdi-account-box-o:before {\r\n  content: '\\f201';\r\n}\r\n.zmdi-account-box-phone:before {\r\n  content: '\\f202';\r\n}\r\n.zmdi-account-box:before {\r\n  content: '\\f203';\r\n}\r\n.zmdi-account-calendar:before {\r\n  content: '\\f204';\r\n}\r\n.zmdi-account-circle:before {\r\n  content: '\\f205';\r\n}\r\n.zmdi-account-o:before {\r\n  content: '\\f206';\r\n}\r\n.zmdi-account:before {\r\n  content: '\\f207';\r\n}\r\n.zmdi-accounts-add:before {\r\n  content: '\\f208';\r\n}\r\n.zmdi-accounts-alt:before {\r\n  content: '\\f209';\r\n}\r\n.zmdi-accounts-list-alt:before {\r\n  content: '\\f20a';\r\n}\r\n.zmdi-accounts-list:before {\r\n  content: '\\f20b';\r\n}\r\n.zmdi-accounts-outline:before {\r\n  content: '\\f20c';\r\n}\r\n.zmdi-accounts:before {\r\n  content: '\\f20d';\r\n}\r\n.zmdi-face:before {\r\n  content: '\\f20e';\r\n}\r\n.zmdi-female:before {\r\n  content: '\\f20f';\r\n}\r\n.zmdi-male-alt:before {\r\n  content: '\\f210';\r\n}\r\n.zmdi-male-female:before {\r\n  content: '\\f211';\r\n}\r\n.zmdi-male:before {\r\n  content: '\\f212';\r\n}\r\n.zmdi-mood-bad:before {\r\n  content: '\\f213';\r\n}\r\n.zmdi-mood:before {\r\n  content: '\\f214';\r\n}\r\n.zmdi-run:before {\r\n  content: '\\f215';\r\n}\r\n.zmdi-walk:before {\r\n  content: '\\f216';\r\n}\r\n.zmdi-cloud-box:before {\r\n  content: '\\f217';\r\n}\r\n.zmdi-cloud-circle:before {\r\n  content: '\\f218';\r\n}\r\n.zmdi-cloud-done:before {\r\n  content: '\\f219';\r\n}\r\n.zmdi-cloud-download:before {\r\n  content: '\\f21a';\r\n}\r\n.zmdi-cloud-off:before {\r\n  content: '\\f21b';\r\n}\r\n.zmdi-cloud-outline-alt:before {\r\n  content: '\\f21c';\r\n}\r\n.zmdi-cloud-outline:before {\r\n  content: '\\f21d';\r\n}\r\n.zmdi-cloud-upload:before {\r\n  content: '\\f21e';\r\n}\r\n.zmdi-cloud:before {\r\n  content: '\\f21f';\r\n}\r\n.zmdi-download:before {\r\n  content: '\\f220';\r\n}\r\n.zmdi-file-plus:before {\r\n  content: '\\f221';\r\n}\r\n.zmdi-file-text:before {\r\n  content: '\\f222';\r\n}\r\n.zmdi-file:before {\r\n  content: '\\f223';\r\n}\r\n.zmdi-folder-outline:before {\r\n  content: '\\f224';\r\n}\r\n.zmdi-folder-person:before {\r\n  content: '\\f225';\r\n}\r\n.zmdi-folder-star-alt:before {\r\n  content: '\\f226';\r\n}\r\n.zmdi-folder-star:before {\r\n  content: '\\f227';\r\n}\r\n.zmdi-folder:before {\r\n  content: '\\f228';\r\n}\r\n.zmdi-gif:before {\r\n  content: '\\f229';\r\n}\r\n.zmdi-upload:before {\r\n  content: '\\f22a';\r\n}\r\n.zmdi-border-all:before {\r\n  content: '\\f22b';\r\n}\r\n.zmdi-border-bottom:before {\r\n  content: '\\f22c';\r\n}\r\n.zmdi-border-clear:before {\r\n  content: '\\f22d';\r\n}\r\n.zmdi-border-color:before {\r\n  content: '\\f22e';\r\n}\r\n.zmdi-border-horizontal:before {\r\n  content: '\\f22f';\r\n}\r\n.zmdi-border-inner:before {\r\n  content: '\\f230';\r\n}\r\n.zmdi-border-left:before {\r\n  content: '\\f231';\r\n}\r\n.zmdi-border-outer:before {\r\n  content: '\\f232';\r\n}\r\n.zmdi-border-right:before {\r\n  content: '\\f233';\r\n}\r\n.zmdi-border-style:before {\r\n  content: '\\f234';\r\n}\r\n.zmdi-border-top:before {\r\n  content: '\\f235';\r\n}\r\n.zmdi-border-vertical:before {\r\n  content: '\\f236';\r\n}\r\n.zmdi-copy:before {\r\n  content: '\\f237';\r\n}\r\n.zmdi-crop:before {\r\n  content: '\\f238';\r\n}\r\n.zmdi-format-align-center:before {\r\n  content: '\\f239';\r\n}\r\n.zmdi-format-align-justify:before {\r\n  content: '\\f23a';\r\n}\r\n.zmdi-format-align-left:before {\r\n  content: '\\f23b';\r\n}\r\n.zmdi-format-align-right:before {\r\n  content: '\\f23c';\r\n}\r\n.zmdi-format-bold:before {\r\n  content: '\\f23d';\r\n}\r\n.zmdi-format-clear-all:before {\r\n  content: '\\f23e';\r\n}\r\n.zmdi-format-clear:before {\r\n  content: '\\f23f';\r\n}\r\n.zmdi-format-color-fill:before {\r\n  content: '\\f240';\r\n}\r\n.zmdi-format-color-reset:before {\r\n  content: '\\f241';\r\n}\r\n.zmdi-format-color-text:before {\r\n  content: '\\f242';\r\n}\r\n.zmdi-format-indent-decrease:before {\r\n  content: '\\f243';\r\n}\r\n.zmdi-format-indent-increase:before {\r\n  content: '\\f244';\r\n}\r\n.zmdi-format-italic:before {\r\n  content: '\\f245';\r\n}\r\n.zmdi-format-line-spacing:before {\r\n  content: '\\f246';\r\n}\r\n.zmdi-format-list-bulleted:before {\r\n  content: '\\f247';\r\n}\r\n.zmdi-format-list-numbered:before {\r\n  content: '\\f248';\r\n}\r\n.zmdi-format-ltr:before {\r\n  content: '\\f249';\r\n}\r\n.zmdi-format-rtl:before {\r\n  content: '\\f24a';\r\n}\r\n.zmdi-format-size:before {\r\n  content: '\\f24b';\r\n}\r\n.zmdi-format-strikethrough-s:before {\r\n  content: '\\f24c';\r\n}\r\n.zmdi-format-strikethrough:before {\r\n  content: '\\f24d';\r\n}\r\n.zmdi-format-subject:before {\r\n  content: '\\f24e';\r\n}\r\n.zmdi-format-underlined:before {\r\n  content: '\\f24f';\r\n}\r\n.zmdi-format-valign-bottom:before {\r\n  content: '\\f250';\r\n}\r\n.zmdi-format-valign-center:before {\r\n  content: '\\f251';\r\n}\r\n.zmdi-format-valign-top:before {\r\n  content: '\\f252';\r\n}\r\n.zmdi-redo:before {\r\n  content: '\\f253';\r\n}\r\n.zmdi-select-all:before {\r\n  content: '\\f254';\r\n}\r\n.zmdi-space-bar:before {\r\n  content: '\\f255';\r\n}\r\n.zmdi-text-format:before {\r\n  content: '\\f256';\r\n}\r\n.zmdi-transform:before {\r\n  content: '\\f257';\r\n}\r\n.zmdi-undo:before {\r\n  content: '\\f258';\r\n}\r\n.zmdi-wrap-text:before {\r\n  content: '\\f259';\r\n}\r\n.zmdi-comment-alert:before {\r\n  content: '\\f25a';\r\n}\r\n.zmdi-comment-alt-text:before {\r\n  content: '\\f25b';\r\n}\r\n.zmdi-comment-alt:before {\r\n  content: '\\f25c';\r\n}\r\n.zmdi-comment-edit:before {\r\n  content: '\\f25d';\r\n}\r\n.zmdi-comment-image:before {\r\n  content: '\\f25e';\r\n}\r\n.zmdi-comment-list:before {\r\n  content: '\\f25f';\r\n}\r\n.zmdi-comment-more:before {\r\n  content: '\\f260';\r\n}\r\n.zmdi-comment-outline:before {\r\n  content: '\\f261';\r\n}\r\n.zmdi-comment-text-alt:before {\r\n  content: '\\f262';\r\n}\r\n.zmdi-comment-text:before {\r\n  content: '\\f263';\r\n}\r\n.zmdi-comment-video:before {\r\n  content: '\\f264';\r\n}\r\n.zmdi-comment:before {\r\n  content: '\\f265';\r\n}\r\n.zmdi-comments:before {\r\n  content: '\\f266';\r\n}\r\n.zmdi-check-all:before {\r\n  content: '\\f267';\r\n}\r\n.zmdi-check-circle-u:before {\r\n  content: '\\f268';\r\n}\r\n.zmdi-check-circle:before {\r\n  content: '\\f269';\r\n}\r\n.zmdi-check-square:before {\r\n  content: '\\f26a';\r\n}\r\n.zmdi-check:before {\r\n  content: '\\f26b';\r\n}\r\n.zmdi-circle-o:before {\r\n  content: '\\f26c';\r\n}\r\n.zmdi-circle:before {\r\n  content: '\\f26d';\r\n}\r\n.zmdi-dot-circle-alt:before {\r\n  content: '\\f26e';\r\n}\r\n.zmdi-dot-circle:before {\r\n  content: '\\f26f';\r\n}\r\n.zmdi-minus-circle-outline:before {\r\n  content: '\\f270';\r\n}\r\n.zmdi-minus-circle:before {\r\n  content: '\\f271';\r\n}\r\n.zmdi-minus-square:before {\r\n  content: '\\f272';\r\n}\r\n.zmdi-minus:before {\r\n  content: '\\f273';\r\n}\r\n.zmdi-plus-circle-o-duplicate:before {\r\n  content: '\\f274';\r\n}\r\n.zmdi-plus-circle-o:before {\r\n  content: '\\f275';\r\n}\r\n.zmdi-plus-circle:before {\r\n  content: '\\f276';\r\n}\r\n.zmdi-plus-square:before {\r\n  content: '\\f277';\r\n}\r\n.zmdi-plus:before {\r\n  content: '\\f278';\r\n}\r\n.zmdi-square-o:before {\r\n  content: '\\f279';\r\n}\r\n.zmdi-star-circle:before {\r\n  content: '\\f27a';\r\n}\r\n.zmdi-star-half:before {\r\n  content: '\\f27b';\r\n}\r\n.zmdi-star-outline:before {\r\n  content: '\\f27c';\r\n}\r\n.zmdi-star:before {\r\n  content: '\\f27d';\r\n}\r\n.zmdi-bluetooth-connected:before {\r\n  content: '\\f27e';\r\n}\r\n.zmdi-bluetooth-off:before {\r\n  content: '\\f27f';\r\n}\r\n.zmdi-bluetooth-search:before {\r\n  content: '\\f280';\r\n}\r\n.zmdi-bluetooth-setting:before {\r\n  content: '\\f281';\r\n}\r\n.zmdi-bluetooth:before {\r\n  content: '\\f282';\r\n}\r\n.zmdi-camera-add:before {\r\n  content: '\\f283';\r\n}\r\n.zmdi-camera-alt:before {\r\n  content: '\\f284';\r\n}\r\n.zmdi-camera-bw:before {\r\n  content: '\\f285';\r\n}\r\n.zmdi-camera-front:before {\r\n  content: '\\f286';\r\n}\r\n.zmdi-camera-mic:before {\r\n  content: '\\f287';\r\n}\r\n.zmdi-camera-party-mode:before {\r\n  content: '\\f288';\r\n}\r\n.zmdi-camera-rear:before {\r\n  content: '\\f289';\r\n}\r\n.zmdi-camera-roll:before {\r\n  content: '\\f28a';\r\n}\r\n.zmdi-camera-switch:before {\r\n  content: '\\f28b';\r\n}\r\n.zmdi-camera:before {\r\n  content: '\\f28c';\r\n}\r\n.zmdi-card-alert:before {\r\n  content: '\\f28d';\r\n}\r\n.zmdi-card-off:before {\r\n  content: '\\f28e';\r\n}\r\n.zmdi-card-sd:before {\r\n  content: '\\f28f';\r\n}\r\n.zmdi-card-sim:before {\r\n  content: '\\f290';\r\n}\r\n.zmdi-desktop-mac:before {\r\n  content: '\\f291';\r\n}\r\n.zmdi-desktop-windows:before {\r\n  content: '\\f292';\r\n}\r\n.zmdi-device-hub:before {\r\n  content: '\\f293';\r\n}\r\n.zmdi-devices-off:before {\r\n  content: '\\f294';\r\n}\r\n.zmdi-devices:before {\r\n  content: '\\f295';\r\n}\r\n.zmdi-dock:before {\r\n  content: '\\f296';\r\n}\r\n.zmdi-floppy:before {\r\n  content: '\\f297';\r\n}\r\n.zmdi-gamepad:before {\r\n  content: '\\f298';\r\n}\r\n.zmdi-gps-dot:before {\r\n  content: '\\f299';\r\n}\r\n.zmdi-gps-off:before {\r\n  content: '\\f29a';\r\n}\r\n.zmdi-gps:before {\r\n  content: '\\f29b';\r\n}\r\n.zmdi-headset-mic:before {\r\n  content: '\\f29c';\r\n}\r\n.zmdi-headset:before {\r\n  content: '\\f29d';\r\n}\r\n.zmdi-input-antenna:before {\r\n  content: '\\f29e';\r\n}\r\n.zmdi-input-composite:before {\r\n  content: '\\f29f';\r\n}\r\n.zmdi-input-hdmi:before {\r\n  content: '\\f2a0';\r\n}\r\n.zmdi-input-power:before {\r\n  content: '\\f2a1';\r\n}\r\n.zmdi-input-svideo:before {\r\n  content: '\\f2a2';\r\n}\r\n.zmdi-keyboard-hide:before {\r\n  content: '\\f2a3';\r\n}\r\n.zmdi-keyboard:before {\r\n  content: '\\f2a4';\r\n}\r\n.zmdi-laptop-chromebook:before {\r\n  content: '\\f2a5';\r\n}\r\n.zmdi-laptop-mac:before {\r\n  content: '\\f2a6';\r\n}\r\n.zmdi-laptop:before {\r\n  content: '\\f2a7';\r\n}\r\n.zmdi-mic-off:before {\r\n  content: '\\f2a8';\r\n}\r\n.zmdi-mic-outline:before {\r\n  content: '\\f2a9';\r\n}\r\n.zmdi-mic-setting:before {\r\n  content: '\\f2aa';\r\n}\r\n.zmdi-mic:before {\r\n  content: '\\f2ab';\r\n}\r\n.zmdi-mouse:before {\r\n  content: '\\f2ac';\r\n}\r\n.zmdi-network-alert:before {\r\n  content: '\\f2ad';\r\n}\r\n.zmdi-network-locked:before {\r\n  content: '\\f2ae';\r\n}\r\n.zmdi-network-off:before {\r\n  content: '\\f2af';\r\n}\r\n.zmdi-network-outline:before {\r\n  content: '\\f2b0';\r\n}\r\n.zmdi-network-setting:before {\r\n  content: '\\f2b1';\r\n}\r\n.zmdi-network:before {\r\n  content: '\\f2b2';\r\n}\r\n.zmdi-phone-bluetooth:before {\r\n  content: '\\f2b3';\r\n}\r\n.zmdi-phone-end:before {\r\n  content: '\\f2b4';\r\n}\r\n.zmdi-phone-forwarded:before {\r\n  content: '\\f2b5';\r\n}\r\n.zmdi-phone-in-talk:before {\r\n  content: '\\f2b6';\r\n}\r\n.zmdi-phone-locked:before {\r\n  content: '\\f2b7';\r\n}\r\n.zmdi-phone-missed:before {\r\n  content: '\\f2b8';\r\n}\r\n.zmdi-phone-msg:before {\r\n  content: '\\f2b9';\r\n}\r\n.zmdi-phone-paused:before {\r\n  content: '\\f2ba';\r\n}\r\n.zmdi-phone-ring:before {\r\n  content: '\\f2bb';\r\n}\r\n.zmdi-phone-setting:before {\r\n  content: '\\f2bc';\r\n}\r\n.zmdi-phone-sip:before {\r\n  content: '\\f2bd';\r\n}\r\n.zmdi-phone:before {\r\n  content: '\\f2be';\r\n}\r\n.zmdi-portable-wifi-changes:before {\r\n  content: '\\f2bf';\r\n}\r\n.zmdi-portable-wifi-off:before {\r\n  content: '\\f2c0';\r\n}\r\n.zmdi-portable-wifi:before {\r\n  content: '\\f2c1';\r\n}\r\n.zmdi-radio:before {\r\n  content: '\\f2c2';\r\n}\r\n.zmdi-reader:before {\r\n  content: '\\f2c3';\r\n}\r\n.zmdi-remote-control-alt:before {\r\n  content: '\\f2c4';\r\n}\r\n.zmdi-remote-control:before {\r\n  content: '\\f2c5';\r\n}\r\n.zmdi-router:before {\r\n  content: '\\f2c6';\r\n}\r\n.zmdi-scanner:before {\r\n  content: '\\f2c7';\r\n}\r\n.zmdi-smartphone-android:before {\r\n  content: '\\f2c8';\r\n}\r\n.zmdi-smartphone-download:before {\r\n  content: '\\f2c9';\r\n}\r\n.zmdi-smartphone-erase:before {\r\n  content: '\\f2ca';\r\n}\r\n.zmdi-smartphone-info:before {\r\n  content: '\\f2cb';\r\n}\r\n.zmdi-smartphone-iphone:before {\r\n  content: '\\f2cc';\r\n}\r\n.zmdi-smartphone-landscape-lock:before {\r\n  content: '\\f2cd';\r\n}\r\n.zmdi-smartphone-landscape:before {\r\n  content: '\\f2ce';\r\n}\r\n.zmdi-smartphone-lock:before {\r\n  content: '\\f2cf';\r\n}\r\n.zmdi-smartphone-portrait-lock:before {\r\n  content: '\\f2d0';\r\n}\r\n.zmdi-smartphone-ring:before {\r\n  content: '\\f2d1';\r\n}\r\n.zmdi-smartphone-setting:before {\r\n  content: '\\f2d2';\r\n}\r\n.zmdi-smartphone-setup:before {\r\n  content: '\\f2d3';\r\n}\r\n.zmdi-smartphone:before {\r\n  content: '\\f2d4';\r\n}\r\n.zmdi-speaker:before {\r\n  content: '\\f2d5';\r\n}\r\n.zmdi-tablet-android:before {\r\n  content: '\\f2d6';\r\n}\r\n.zmdi-tablet-mac:before {\r\n  content: '\\f2d7';\r\n}\r\n.zmdi-tablet:before {\r\n  content: '\\f2d8';\r\n}\r\n.zmdi-tv-alt-play:before {\r\n  content: '\\f2d9';\r\n}\r\n.zmdi-tv-list:before {\r\n  content: '\\f2da';\r\n}\r\n.zmdi-tv-play:before {\r\n  content: '\\f2db';\r\n}\r\n.zmdi-tv:before {\r\n  content: '\\f2dc';\r\n}\r\n.zmdi-usb:before {\r\n  content: '\\f2dd';\r\n}\r\n.zmdi-videocam-off:before {\r\n  content: '\\f2de';\r\n}\r\n.zmdi-videocam-switch:before {\r\n  content: '\\f2df';\r\n}\r\n.zmdi-videocam:before {\r\n  content: '\\f2e0';\r\n}\r\n.zmdi-watch:before {\r\n  content: '\\f2e1';\r\n}\r\n.zmdi-wifi-alt-2:before {\r\n  content: '\\f2e2';\r\n}\r\n.zmdi-wifi-alt:before {\r\n  content: '\\f2e3';\r\n}\r\n.zmdi-wifi-info:before {\r\n  content: '\\f2e4';\r\n}\r\n.zmdi-wifi-lock:before {\r\n  content: '\\f2e5';\r\n}\r\n.zmdi-wifi-off:before {\r\n  content: '\\f2e6';\r\n}\r\n.zmdi-wifi-outline:before {\r\n  content: '\\f2e7';\r\n}\r\n.zmdi-wifi:before {\r\n  content: '\\f2e8';\r\n}\r\n.zmdi-arrow-left-bottom:before {\r\n  content: '\\f2e9';\r\n}\r\n.zmdi-arrow-left:before {\r\n  content: '\\f2ea';\r\n}\r\n.zmdi-arrow-merge:before {\r\n  content: '\\f2eb';\r\n}\r\n.zmdi-arrow-missed:before {\r\n  content: '\\f2ec';\r\n}\r\n.zmdi-arrow-right-top:before {\r\n  content: '\\f2ed';\r\n}\r\n.zmdi-arrow-right:before {\r\n  content: '\\f2ee';\r\n}\r\n.zmdi-arrow-split:before {\r\n  content: '\\f2ef';\r\n}\r\n.zmdi-arrows:before {\r\n  content: '\\f2f0';\r\n}\r\n.zmdi-caret-down-circle:before {\r\n  content: '\\f2f1';\r\n}\r\n.zmdi-caret-down:before {\r\n  content: '\\f2f2';\r\n}\r\n.zmdi-caret-left-circle:before {\r\n  content: '\\f2f3';\r\n}\r\n.zmdi-caret-left:before {\r\n  content: '\\f2f4';\r\n}\r\n.zmdi-caret-right-circle:before {\r\n  content: '\\f2f5';\r\n}\r\n.zmdi-caret-right:before {\r\n  content: '\\f2f6';\r\n}\r\n.zmdi-caret-up-circle:before {\r\n  content: '\\f2f7';\r\n}\r\n.zmdi-caret-up:before {\r\n  content: '\\f2f8';\r\n}\r\n.zmdi-chevron-down:before {\r\n  content: '\\f2f9';\r\n}\r\n.zmdi-chevron-left:before {\r\n  content: '\\f2fa';\r\n}\r\n.zmdi-chevron-right:before {\r\n  content: '\\f2fb';\r\n}\r\n.zmdi-chevron-up:before {\r\n  content: '\\f2fc';\r\n}\r\n.zmdi-forward:before {\r\n  content: '\\f2fd';\r\n}\r\n.zmdi-long-arrow-down:before {\r\n  content: '\\f2fe';\r\n}\r\n.zmdi-long-arrow-left:before {\r\n  content: '\\f2ff';\r\n}\r\n.zmdi-long-arrow-return:before {\r\n  content: '\\f300';\r\n}\r\n.zmdi-long-arrow-right:before {\r\n  content: '\\f301';\r\n}\r\n.zmdi-long-arrow-tab:before {\r\n  content: '\\f302';\r\n}\r\n.zmdi-long-arrow-up:before {\r\n  content: '\\f303';\r\n}\r\n.zmdi-rotate-ccw:before {\r\n  content: '\\f304';\r\n}\r\n.zmdi-rotate-cw:before {\r\n  content: '\\f305';\r\n}\r\n.zmdi-rotate-left:before {\r\n  content: '\\f306';\r\n}\r\n.zmdi-rotate-right:before {\r\n  content: '\\f307';\r\n}\r\n.zmdi-square-down:before {\r\n  content: '\\f308';\r\n}\r\n.zmdi-square-right:before {\r\n  content: '\\f309';\r\n}\r\n.zmdi-swap-alt:before {\r\n  content: '\\f30a';\r\n}\r\n.zmdi-swap-vertical-circle:before {\r\n  content: '\\f30b';\r\n}\r\n.zmdi-swap-vertical:before {\r\n  content: '\\f30c';\r\n}\r\n.zmdi-swap:before {\r\n  content: '\\f30d';\r\n}\r\n.zmdi-trending-down:before {\r\n  content: '\\f30e';\r\n}\r\n.zmdi-trending-flat:before {\r\n  content: '\\f30f';\r\n}\r\n.zmdi-trending-up:before {\r\n  content: '\\f310';\r\n}\r\n.zmdi-unfold-less:before {\r\n  content: '\\f311';\r\n}\r\n.zmdi-unfold-more:before {\r\n  content: '\\f312';\r\n}\r\n.zmdi-apps:before {\r\n  content: '\\f313';\r\n}\r\n.zmdi-grid-off:before {\r\n  content: '\\f314';\r\n}\r\n.zmdi-grid:before {\r\n  content: '\\f315';\r\n}\r\n.zmdi-view-agenda:before {\r\n  content: '\\f316';\r\n}\r\n.zmdi-view-array:before {\r\n  content: '\\f317';\r\n}\r\n.zmdi-view-carousel:before {\r\n  content: '\\f318';\r\n}\r\n.zmdi-view-column:before {\r\n  content: '\\f319';\r\n}\r\n.zmdi-view-comfy:before {\r\n  content: '\\f31a';\r\n}\r\n.zmdi-view-compact:before {\r\n  content: '\\f31b';\r\n}\r\n.zmdi-view-dashboard:before {\r\n  content: '\\f31c';\r\n}\r\n.zmdi-view-day:before {\r\n  content: '\\f31d';\r\n}\r\n.zmdi-view-headline:before {\r\n  content: '\\f31e';\r\n}\r\n.zmdi-view-list-alt:before {\r\n  content: '\\f31f';\r\n}\r\n.zmdi-view-list:before {\r\n  content: '\\f320';\r\n}\r\n.zmdi-view-module:before {\r\n  content: '\\f321';\r\n}\r\n.zmdi-view-quilt:before {\r\n  content: '\\f322';\r\n}\r\n.zmdi-view-stream:before {\r\n  content: '\\f323';\r\n}\r\n.zmdi-view-subtitles:before {\r\n  content: '\\f324';\r\n}\r\n.zmdi-view-toc:before {\r\n  content: '\\f325';\r\n}\r\n.zmdi-view-web:before {\r\n  content: '\\f326';\r\n}\r\n.zmdi-view-week:before {\r\n  content: '\\f327';\r\n}\r\n.zmdi-widgets:before {\r\n  content: '\\f328';\r\n}\r\n.zmdi-alarm-check:before {\r\n  content: '\\f329';\r\n}\r\n.zmdi-alarm-off:before {\r\n  content: '\\f32a';\r\n}\r\n.zmdi-alarm-plus:before {\r\n  content: '\\f32b';\r\n}\r\n.zmdi-alarm-snooze:before {\r\n  content: '\\f32c';\r\n}\r\n.zmdi-alarm:before {\r\n  content: '\\f32d';\r\n}\r\n.zmdi-calendar-alt:before {\r\n  content: '\\f32e';\r\n}\r\n.zmdi-calendar-check:before {\r\n  content: '\\f32f';\r\n}\r\n.zmdi-calendar-close:before {\r\n  content: '\\f330';\r\n}\r\n.zmdi-calendar-note:before {\r\n  content: '\\f331';\r\n}\r\n.zmdi-calendar:before {\r\n  content: '\\f332';\r\n}\r\n.zmdi-time-countdown:before {\r\n  content: '\\f333';\r\n}\r\n.zmdi-time-interval:before {\r\n  content: '\\f334';\r\n}\r\n.zmdi-time-restore-setting:before {\r\n  content: '\\f335';\r\n}\r\n.zmdi-time-restore:before {\r\n  content: '\\f336';\r\n}\r\n.zmdi-time:before {\r\n  content: '\\f337';\r\n}\r\n.zmdi-timer-off:before {\r\n  content: '\\f338';\r\n}\r\n.zmdi-timer:before {\r\n  content: '\\f339';\r\n}\r\n.zmdi-android-alt:before {\r\n  content: '\\f33a';\r\n}\r\n.zmdi-android:before {\r\n  content: '\\f33b';\r\n}\r\n.zmdi-apple:before {\r\n  content: '\\f33c';\r\n}\r\n.zmdi-behance:before {\r\n  content: '\\f33d';\r\n}\r\n.zmdi-codepen:before {\r\n  content: '\\f33e';\r\n}\r\n.zmdi-dribbble:before {\r\n  content: '\\f33f';\r\n}\r\n.zmdi-dropbox:before {\r\n  content: '\\f340';\r\n}\r\n.zmdi-evernote:before {\r\n  content: '\\f341';\r\n}\r\n.zmdi-facebook-box:before {\r\n  content: '\\f342';\r\n}\r\n.zmdi-facebook:before {\r\n  content: '\\f343';\r\n}\r\n.zmdi-github-box:before {\r\n  content: '\\f344';\r\n}\r\n.zmdi-github:before {\r\n  content: '\\f345';\r\n}\r\n.zmdi-google-drive:before {\r\n  content: '\\f346';\r\n}\r\n.zmdi-google-earth:before {\r\n  content: '\\f347';\r\n}\r\n.zmdi-google-glass:before {\r\n  content: '\\f348';\r\n}\r\n.zmdi-google-maps:before {\r\n  content: '\\f349';\r\n}\r\n.zmdi-google-pages:before {\r\n  content: '\\f34a';\r\n}\r\n.zmdi-google-play:before {\r\n  content: '\\f34b';\r\n}\r\n.zmdi-google-plus-box:before {\r\n  content: '\\f34c';\r\n}\r\n.zmdi-google-plus:before {\r\n  content: '\\f34d';\r\n}\r\n.zmdi-google:before {\r\n  content: '\\f34e';\r\n}\r\n.zmdi-instagram:before {\r\n  content: '\\f34f';\r\n}\r\n.zmdi-language-css3:before {\r\n  content: '\\f350';\r\n}\r\n.zmdi-language-html5:before {\r\n  content: '\\f351';\r\n}\r\n.zmdi-language-javascript:before {\r\n  content: '\\f352';\r\n}\r\n.zmdi-language-python-alt:before {\r\n  content: '\\f353';\r\n}\r\n.zmdi-language-python:before {\r\n  content: '\\f354';\r\n}\r\n.zmdi-lastfm:before {\r\n  content: '\\f355';\r\n}\r\n.zmdi-linkedin-box:before {\r\n  content: '\\f356';\r\n}\r\n.zmdi-paypal:before {\r\n  content: '\\f357';\r\n}\r\n.zmdi-pinterest-box:before {\r\n  content: '\\f358';\r\n}\r\n.zmdi-pocket:before {\r\n  content: '\\f359';\r\n}\r\n.zmdi-polymer:before {\r\n  content: '\\f35a';\r\n}\r\n.zmdi-share:before {\r\n  content: '\\f35b';\r\n}\r\n.zmdi-stackoverflow:before {\r\n  content: '\\f35c';\r\n}\r\n.zmdi-steam-square:before {\r\n  content: '\\f35d';\r\n}\r\n.zmdi-steam:before {\r\n  content: '\\f35e';\r\n}\r\n.zmdi-twitter-box:before {\r\n  content: '\\f35f';\r\n}\r\n.zmdi-twitter:before {\r\n  content: '\\f360';\r\n}\r\n.zmdi-vk:before {\r\n  content: '\\f361';\r\n}\r\n.zmdi-wikipedia:before {\r\n  content: '\\f362';\r\n}\r\n.zmdi-windows:before {\r\n  content: '\\f363';\r\n}\r\n.zmdi-aspect-ratio-alt:before {\r\n  content: '\\f364';\r\n}\r\n.zmdi-aspect-ratio:before {\r\n  content: '\\f365';\r\n}\r\n.zmdi-blur-circular:before {\r\n  content: '\\f366';\r\n}\r\n.zmdi-blur-linear:before {\r\n  content: '\\f367';\r\n}\r\n.zmdi-blur-off:before {\r\n  content: '\\f368';\r\n}\r\n.zmdi-blur:before {\r\n  content: '\\f369';\r\n}\r\n.zmdi-brightness-2:before {\r\n  content: '\\f36a';\r\n}\r\n.zmdi-brightness-3:before {\r\n  content: '\\f36b';\r\n}\r\n.zmdi-brightness-4:before {\r\n  content: '\\f36c';\r\n}\r\n.zmdi-brightness-5:before {\r\n  content: '\\f36d';\r\n}\r\n.zmdi-brightness-6:before {\r\n  content: '\\f36e';\r\n}\r\n.zmdi-brightness-7:before {\r\n  content: '\\f36f';\r\n}\r\n.zmdi-brightness-auto:before {\r\n  content: '\\f370';\r\n}\r\n.zmdi-brightness-setting:before {\r\n  content: '\\f371';\r\n}\r\n.zmdi-broken-image:before {\r\n  content: '\\f372';\r\n}\r\n.zmdi-center-focus-strong:before {\r\n  content: '\\f373';\r\n}\r\n.zmdi-center-focus-weak:before {\r\n  content: '\\f374';\r\n}\r\n.zmdi-compare:before {\r\n  content: '\\f375';\r\n}\r\n.zmdi-crop-16-9:before {\r\n  content: '\\f376';\r\n}\r\n.zmdi-crop-3-2:before {\r\n  content: '\\f377';\r\n}\r\n.zmdi-crop-5-4:before {\r\n  content: '\\f378';\r\n}\r\n.zmdi-crop-7-5:before {\r\n  content: '\\f379';\r\n}\r\n.zmdi-crop-din:before {\r\n  content: '\\f37a';\r\n}\r\n.zmdi-crop-free:before {\r\n  content: '\\f37b';\r\n}\r\n.zmdi-crop-landscape:before {\r\n  content: '\\f37c';\r\n}\r\n.zmdi-crop-portrait:before {\r\n  content: '\\f37d';\r\n}\r\n.zmdi-crop-square:before {\r\n  content: '\\f37e';\r\n}\r\n.zmdi-exposure-alt:before {\r\n  content: '\\f37f';\r\n}\r\n.zmdi-exposure:before {\r\n  content: '\\f380';\r\n}\r\n.zmdi-filter-b-and-w:before {\r\n  content: '\\f381';\r\n}\r\n.zmdi-filter-center-focus:before {\r\n  content: '\\f382';\r\n}\r\n.zmdi-filter-frames:before {\r\n  content: '\\f383';\r\n}\r\n.zmdi-filter-tilt-shift:before {\r\n  content: '\\f384';\r\n}\r\n.zmdi-gradient:before {\r\n  content: '\\f385';\r\n}\r\n.zmdi-grain:before {\r\n  content: '\\f386';\r\n}\r\n.zmdi-graphic-eq:before {\r\n  content: '\\f387';\r\n}\r\n.zmdi-hdr-off:before {\r\n  content: '\\f388';\r\n}\r\n.zmdi-hdr-strong:before {\r\n  content: '\\f389';\r\n}\r\n.zmdi-hdr-weak:before {\r\n  content: '\\f38a';\r\n}\r\n.zmdi-hdr:before {\r\n  content: '\\f38b';\r\n}\r\n.zmdi-iridescent:before {\r\n  content: '\\f38c';\r\n}\r\n.zmdi-leak-off:before {\r\n  content: '\\f38d';\r\n}\r\n.zmdi-leak:before {\r\n  content: '\\f38e';\r\n}\r\n.zmdi-looks:before {\r\n  content: '\\f38f';\r\n}\r\n.zmdi-loupe:before {\r\n  content: '\\f390';\r\n}\r\n.zmdi-panorama-horizontal:before {\r\n  content: '\\f391';\r\n}\r\n.zmdi-panorama-vertical:before {\r\n  content: '\\f392';\r\n}\r\n.zmdi-panorama-wide-angle:before {\r\n  content: '\\f393';\r\n}\r\n.zmdi-photo-size-select-large:before {\r\n  content: '\\f394';\r\n}\r\n.zmdi-photo-size-select-small:before {\r\n  content: '\\f395';\r\n}\r\n.zmdi-picture-in-picture:before {\r\n  content: '\\f396';\r\n}\r\n.zmdi-slideshow:before {\r\n  content: '\\f397';\r\n}\r\n.zmdi-texture:before {\r\n  content: '\\f398';\r\n}\r\n.zmdi-tonality:before {\r\n  content: '\\f399';\r\n}\r\n.zmdi-vignette:before {\r\n  content: '\\f39a';\r\n}\r\n.zmdi-wb-auto:before {\r\n  content: '\\f39b';\r\n}\r\n.zmdi-eject-alt:before {\r\n  content: '\\f39c';\r\n}\r\n.zmdi-eject:before {\r\n  content: '\\f39d';\r\n}\r\n.zmdi-equalizer:before {\r\n  content: '\\f39e';\r\n}\r\n.zmdi-fast-forward:before {\r\n  content: '\\f39f';\r\n}\r\n.zmdi-fast-rewind:before {\r\n  content: '\\f3a0';\r\n}\r\n.zmdi-forward-10:before {\r\n  content: '\\f3a1';\r\n}\r\n.zmdi-forward-30:before {\r\n  content: '\\f3a2';\r\n}\r\n.zmdi-forward-5:before {\r\n  content: '\\f3a3';\r\n}\r\n.zmdi-hearing:before {\r\n  content: '\\f3a4';\r\n}\r\n.zmdi-pause-circle-outline:before {\r\n  content: '\\f3a5';\r\n}\r\n.zmdi-pause-circle:before {\r\n  content: '\\f3a6';\r\n}\r\n.zmdi-pause:before {\r\n  content: '\\f3a7';\r\n}\r\n.zmdi-play-circle-outline:before {\r\n  content: '\\f3a8';\r\n}\r\n.zmdi-play-circle:before {\r\n  content: '\\f3a9';\r\n}\r\n.zmdi-play:before {\r\n  content: '\\f3aa';\r\n}\r\n.zmdi-playlist-audio:before {\r\n  content: '\\f3ab';\r\n}\r\n.zmdi-playlist-plus:before {\r\n  content: '\\f3ac';\r\n}\r\n.zmdi-repeat-one:before {\r\n  content: '\\f3ad';\r\n}\r\n.zmdi-repeat:before {\r\n  content: '\\f3ae';\r\n}\r\n.zmdi-replay-10:before {\r\n  content: '\\f3af';\r\n}\r\n.zmdi-replay-30:before {\r\n  content: '\\f3b0';\r\n}\r\n.zmdi-replay-5:before {\r\n  content: '\\f3b1';\r\n}\r\n.zmdi-replay:before {\r\n  content: '\\f3b2';\r\n}\r\n.zmdi-shuffle:before {\r\n  content: '\\f3b3';\r\n}\r\n.zmdi-skip-next:before {\r\n  content: '\\f3b4';\r\n}\r\n.zmdi-skip-previous:before {\r\n  content: '\\f3b5';\r\n}\r\n.zmdi-stop:before {\r\n  content: '\\f3b6';\r\n}\r\n.zmdi-surround-sound:before {\r\n  content: '\\f3b7';\r\n}\r\n.zmdi-tune:before {\r\n  content: '\\f3b8';\r\n}\r\n.zmdi-volume-down:before {\r\n  content: '\\f3b9';\r\n}\r\n.zmdi-volume-mute:before {\r\n  content: '\\f3ba';\r\n}\r\n.zmdi-volume-off:before {\r\n  content: '\\f3bb';\r\n}\r\n.zmdi-volume-up:before {\r\n  content: '\\f3bc';\r\n}\r\n.zmdi-n-1-square:before {\r\n  content: '\\f3bd';\r\n}\r\n.zmdi-n-2-square:before {\r\n  content: '\\f3be';\r\n}\r\n.zmdi-n-3-square:before {\r\n  content: '\\f3bf';\r\n}\r\n.zmdi-n-4-square:before {\r\n  content: '\\f3c0';\r\n}\r\n.zmdi-n-5-square:before {\r\n  content: '\\f3c1';\r\n}\r\n.zmdi-n-6-square:before {\r\n  content: '\\f3c2';\r\n}\r\n.zmdi-neg-1:before {\r\n  content: '\\f3c3';\r\n}\r\n.zmdi-neg-2:before {\r\n  content: '\\f3c4';\r\n}\r\n.zmdi-plus-1:before {\r\n  content: '\\f3c5';\r\n}\r\n.zmdi-plus-2:before {\r\n  content: '\\f3c6';\r\n}\r\n.zmdi-sec-10:before {\r\n  content: '\\f3c7';\r\n}\r\n.zmdi-sec-3:before {\r\n  content: '\\f3c8';\r\n}\r\n.zmdi-zero:before {\r\n  content: '\\f3c9';\r\n}\r\n.zmdi-airline-seat-flat-angled:before {\r\n  content: '\\f3ca';\r\n}\r\n.zmdi-airline-seat-flat:before {\r\n  content: '\\f3cb';\r\n}\r\n.zmdi-airline-seat-individual-suite:before {\r\n  content: '\\f3cc';\r\n}\r\n.zmdi-airline-seat-legroom-extra:before {\r\n  content: '\\f3cd';\r\n}\r\n.zmdi-airline-seat-legroom-normal:before {\r\n  content: '\\f3ce';\r\n}\r\n.zmdi-airline-seat-legroom-reduced:before {\r\n  content: '\\f3cf';\r\n}\r\n.zmdi-airline-seat-recline-extra:before {\r\n  content: '\\f3d0';\r\n}\r\n.zmdi-airline-seat-recline-normal:before {\r\n  content: '\\f3d1';\r\n}\r\n.zmdi-airplay:before {\r\n  content: '\\f3d2';\r\n}\r\n.zmdi-closed-caption:before {\r\n  content: '\\f3d3';\r\n}\r\n.zmdi-confirmation-number:before {\r\n  content: '\\f3d4';\r\n}\r\n.zmdi-developer-board:before {\r\n  content: '\\f3d5';\r\n}\r\n.zmdi-disc-full:before {\r\n  content: '\\f3d6';\r\n}\r\n.zmdi-explicit:before {\r\n  content: '\\f3d7';\r\n}\r\n.zmdi-flight-land:before {\r\n  content: '\\f3d8';\r\n}\r\n.zmdi-flight-takeoff:before {\r\n  content: '\\f3d9';\r\n}\r\n.zmdi-flip-to-back:before {\r\n  content: '\\f3da';\r\n}\r\n.zmdi-flip-to-front:before {\r\n  content: '\\f3db';\r\n}\r\n.zmdi-group-work:before {\r\n  content: '\\f3dc';\r\n}\r\n.zmdi-hd:before {\r\n  content: '\\f3dd';\r\n}\r\n.zmdi-hq:before {\r\n  content: '\\f3de';\r\n}\r\n.zmdi-markunread-mailbox:before {\r\n  content: '\\f3df';\r\n}\r\n.zmdi-memory:before {\r\n  content: '\\f3e0';\r\n}\r\n.zmdi-nfc:before {\r\n  content: '\\f3e1';\r\n}\r\n.zmdi-play-for-work:before {\r\n  content: '\\f3e2';\r\n}\r\n.zmdi-power-input:before {\r\n  content: '\\f3e3';\r\n}\r\n.zmdi-present-to-all:before {\r\n  content: '\\f3e4';\r\n}\r\n.zmdi-satellite:before {\r\n  content: '\\f3e5';\r\n}\r\n.zmdi-tap-and-play:before {\r\n  content: '\\f3e6';\r\n}\r\n.zmdi-vibration:before {\r\n  content: '\\f3e7';\r\n}\r\n.zmdi-voicemail:before {\r\n  content: '\\f3e8';\r\n}\r\n.zmdi-group:before {\r\n  content: '\\f3e9';\r\n}\r\n.zmdi-rss:before {\r\n  content: '\\f3ea';\r\n}\r\n.zmdi-shape:before {\r\n  content: '\\f3eb';\r\n}\r\n.zmdi-spinner:before {\r\n  content: '\\f3ec';\r\n}\r\n.zmdi-ungroup:before {\r\n  content: '\\f3ed';\r\n}\r\n.zmdi-500px:before {\r\n  content: '\\f3ee';\r\n}\r\n.zmdi-8tracks:before {\r\n  content: '\\f3ef';\r\n}\r\n.zmdi-amazon:before {\r\n  content: '\\f3f0';\r\n}\r\n.zmdi-blogger:before {\r\n  content: '\\f3f1';\r\n}\r\n.zmdi-delicious:before {\r\n  content: '\\f3f2';\r\n}\r\n.zmdi-disqus:before {\r\n  content: '\\f3f3';\r\n}\r\n.zmdi-flattr:before {\r\n  content: '\\f3f4';\r\n}\r\n.zmdi-flickr:before {\r\n  content: '\\f3f5';\r\n}\r\n.zmdi-github-alt:before {\r\n  content: '\\f3f6';\r\n}\r\n.zmdi-google-old:before {\r\n  content: '\\f3f7';\r\n}\r\n.zmdi-linkedin:before {\r\n  content: '\\f3f8';\r\n}\r\n.zmdi-odnoklassniki:before {\r\n  content: '\\f3f9';\r\n}\r\n.zmdi-outlook:before {\r\n  content: '\\f3fa';\r\n}\r\n.zmdi-paypal-alt:before {\r\n  content: '\\f3fb';\r\n}\r\n.zmdi-pinterest:before {\r\n  content: '\\f3fc';\r\n}\r\n.zmdi-playstation:before {\r\n  content: '\\f3fd';\r\n}\r\n.zmdi-reddit:before {\r\n  content: '\\f3fe';\r\n}\r\n.zmdi-skype:before {\r\n  content: '\\f3ff';\r\n}\r\n.zmdi-slideshare:before {\r\n  content: '\\f400';\r\n}\r\n.zmdi-soundcloud:before {\r\n  content: '\\f401';\r\n}\r\n.zmdi-tumblr:before {\r\n  content: '\\f402';\r\n}\r\n.zmdi-twitch:before {\r\n  content: '\\f403';\r\n}\r\n.zmdi-vimeo:before {\r\n  content: '\\f404';\r\n}\r\n.zmdi-whatsapp:before {\r\n  content: '\\f405';\r\n}\r\n.zmdi-xbox:before {\r\n  content: '\\f406';\r\n}\r\n.zmdi-yahoo:before {\r\n  content: '\\f407';\r\n}\r\n.zmdi-youtube-play:before {\r\n  content: '\\f408';\r\n}\r\n.zmdi-youtube:before {\r\n  content: '\\f409';\r\n}\r\n.zmdi-import-export:before {\r\n  content: '\\f30c';\r\n}\r\n.zmdi-swap-vertical-:before {\r\n  content: '\\f30c';\r\n}\r\n.zmdi-airplanemode-inactive:before {\r\n  content: '\\f102';\r\n}\r\n.zmdi-airplanemode-active:before {\r\n  content: '\\f103';\r\n}\r\n.zmdi-rate-review:before {\r\n  content: '\\f103';\r\n}\r\n.zmdi-comment-sign:before {\r\n  content: '\\f25a';\r\n}\r\n.zmdi-network-warning:before {\r\n  content: '\\f2ad';\r\n}\r\n.zmdi-shopping-cart-add:before {\r\n  content: '\\f1ca';\r\n}\r\n.zmdi-file-add:before {\r\n  content: '\\f221';\r\n}\r\n.zmdi-network-wifi-scan:before {\r\n  content: '\\f2e4';\r\n}\r\n.zmdi-collection-add:before {\r\n  content: '\\f14e';\r\n}\r\n.zmdi-format-playlist-add:before {\r\n  content: '\\f3ac';\r\n}\r\n.zmdi-format-queue-music:before {\r\n  content: '\\f3ab';\r\n}\r\n.zmdi-plus-box:before {\r\n  content: '\\f277';\r\n}\r\n.zmdi-tag-backspace:before {\r\n  content: '\\f1d9';\r\n}\r\n.zmdi-alarm-add:before {\r\n  content: '\\f32b';\r\n}\r\n.zmdi-battery-charging:before {\r\n  content: '\\f114';\r\n}\r\n.zmdi-daydream-setting:before {\r\n  content: '\\f217';\r\n}\r\n.zmdi-more-horiz:before {\r\n  content: '\\f19c';\r\n}\r\n.zmdi-book-photo:before {\r\n  content: '\\f11b';\r\n}\r\n.zmdi-incandescent:before {\r\n  content: '\\f189';\r\n}\r\n.zmdi-wb-iridescent:before {\r\n  content: '\\f38c';\r\n}\r\n.zmdi-calendar-remove:before {\r\n  content: '\\f330';\r\n}\r\n.zmdi-refresh-sync-disabled:before {\r\n  content: '\\f1b7';\r\n}\r\n.zmdi-refresh-sync-problem:before {\r\n  content: '\\f1b6';\r\n}\r\n.zmdi-crop-original:before {\r\n  content: '\\f17e';\r\n}\r\n.zmdi-power-off:before {\r\n  content: '\\f1af';\r\n}\r\n.zmdi-power-off-setting:before {\r\n  content: '\\f1ae';\r\n}\r\n.zmdi-leak-remove:before {\r\n  content: '\\f38d';\r\n}\r\n.zmdi-star-border:before {\r\n  content: '\\f27c';\r\n}\r\n.zmdi-brightness-low:before {\r\n  content: '\\f36d';\r\n}\r\n.zmdi-brightness-medium:before {\r\n  content: '\\f36e';\r\n}\r\n.zmdi-brightness-high:before {\r\n  content: '\\f36f';\r\n}\r\n.zmdi-smartphone-portrait:before {\r\n  content: '\\f2d4';\r\n}\r\n.zmdi-live-tv:before {\r\n  content: '\\f2d9';\r\n}\r\n.zmdi-format-textdirection-l-to-r:before {\r\n  content: '\\f249';\r\n}\r\n.zmdi-format-textdirection-r-to-l:before {\r\n  content: '\\f24a';\r\n}\r\n.zmdi-arrow-back:before {\r\n  content: '\\f2ea';\r\n}\r\n.zmdi-arrow-forward:before {\r\n  content: '\\f2ee';\r\n}\r\n.zmdi-arrow-in:before {\r\n  content: '\\f2e9';\r\n}\r\n.zmdi-arrow-out:before {\r\n  content: '\\f2ed';\r\n}\r\n.zmdi-rotate-90-degrees-ccw:before {\r\n  content: '\\f304';\r\n}\r\n.zmdi-adb:before {\r\n  content: '\\f33a';\r\n}\r\n.zmdi-network-wifi:before {\r\n  content: '\\f2e8';\r\n}\r\n.zmdi-network-wifi-alt:before {\r\n  content: '\\f2e3';\r\n}\r\n.zmdi-network-wifi-lock:before {\r\n  content: '\\f2e5';\r\n}\r\n.zmdi-network-wifi-off:before {\r\n  content: '\\f2e6';\r\n}\r\n.zmdi-network-wifi-outline:before {\r\n  content: '\\f2e7';\r\n}\r\n.zmdi-network-wifi-info:before {\r\n  content: '\\f2e4';\r\n}\r\n.zmdi-layers-clear:before {\r\n  content: '\\f18b';\r\n}\r\n.zmdi-colorize:before {\r\n  content: '\\f15d';\r\n}\r\n.zmdi-format-paint:before {\r\n  content: '\\f1ba';\r\n}\r\n.zmdi-format-quote:before {\r\n  content: '\\f1b2';\r\n}\r\n.zmdi-camera-monochrome-photos:before {\r\n  content: '\\f285';\r\n}\r\n.zmdi-sort-by-alpha:before {\r\n  content: '\\f1cf';\r\n}\r\n.zmdi-folder-shared:before {\r\n  content: '\\f225';\r\n}\r\n.zmdi-folder-special:before {\r\n  content: '\\f226';\r\n}\r\n.zmdi-comment-dots:before {\r\n  content: '\\f260';\r\n}\r\n.zmdi-reorder:before {\r\n  content: '\\f31e';\r\n}\r\n.zmdi-dehaze:before {\r\n  content: '\\f197';\r\n}\r\n.zmdi-sort:before {\r\n  content: '\\f1ce';\r\n}\r\n.zmdi-pages:before {\r\n  content: '\\f34a';\r\n}\r\n.zmdi-stack-overflow:before {\r\n  content: '\\f35c';\r\n}\r\n.zmdi-calendar-account:before {\r\n  content: '\\f204';\r\n}\r\n.zmdi-paste:before {\r\n  content: '\\f109';\r\n}\r\n.zmdi-cut:before {\r\n  content: '\\f1bc';\r\n}\r\n.zmdi-save:before {\r\n  content: '\\f297';\r\n}\r\n.zmdi-smartphone-code:before {\r\n  content: '\\f139';\r\n}\r\n.zmdi-directions-bike:before {\r\n  content: '\\f117';\r\n}\r\n.zmdi-directions-boat:before {\r\n  content: '\\f11a';\r\n}\r\n.zmdi-directions-bus:before {\r\n  content: '\\f121';\r\n}\r\n.zmdi-directions-car:before {\r\n  content: '\\f125';\r\n}\r\n.zmdi-directions-railway:before {\r\n  content: '\\f1b3';\r\n}\r\n.zmdi-directions-run:before {\r\n  content: '\\f215';\r\n}\r\n.zmdi-directions-subway:before {\r\n  content: '\\f1d5';\r\n}\r\n.zmdi-directions-walk:before {\r\n  content: '\\f216';\r\n}\r\n.zmdi-local-hotel:before {\r\n  content: '\\f178';\r\n}\r\n.zmdi-local-activity:before {\r\n  content: '\\f1df';\r\n}\r\n.zmdi-local-play:before {\r\n  content: '\\f1df';\r\n}\r\n.zmdi-local-airport:before {\r\n  content: '\\f103';\r\n}\r\n.zmdi-local-atm:before {\r\n  content: '\\f198';\r\n}\r\n.zmdi-local-bar:before {\r\n  content: '\\f137';\r\n}\r\n.zmdi-local-cafe:before {\r\n  content: '\\f13b';\r\n}\r\n.zmdi-local-car-wash:before {\r\n  content: '\\f124';\r\n}\r\n.zmdi-local-convenience-store:before {\r\n  content: '\\f1d3';\r\n}\r\n.zmdi-local-dining:before {\r\n  content: '\\f153';\r\n}\r\n.zmdi-local-drink:before {\r\n  content: '\\f157';\r\n}\r\n.zmdi-local-florist:before {\r\n  content: '\\f168';\r\n}\r\n.zmdi-local-gas-station:before {\r\n  content: '\\f16f';\r\n}\r\n.zmdi-local-grocery-store:before {\r\n  content: '\\f1cb';\r\n}\r\n.zmdi-local-hospital:before {\r\n  content: '\\f177';\r\n}\r\n.zmdi-local-laundry-service:before {\r\n  content: '\\f1e9';\r\n}\r\n.zmdi-local-library:before {\r\n  content: '\\f18d';\r\n}\r\n.zmdi-local-mall:before {\r\n  content: '\\f195';\r\n}\r\n.zmdi-local-movies:before {\r\n  content: '\\f19d';\r\n}\r\n.zmdi-local-offer:before {\r\n  content: '\\f187';\r\n}\r\n.zmdi-local-parking:before {\r\n  content: '\\f1a5';\r\n}\r\n.zmdi-local-parking:before {\r\n  content: '\\f1a5';\r\n}\r\n.zmdi-local-pharmacy:before {\r\n  content: '\\f176';\r\n}\r\n.zmdi-local-phone:before {\r\n  content: '\\f2be';\r\n}\r\n.zmdi-local-pizza:before {\r\n  content: '\\f1ac';\r\n}\r\n.zmdi-local-post-office:before {\r\n  content: '\\f15a';\r\n}\r\n.zmdi-local-printshop:before {\r\n  content: '\\f1b0';\r\n}\r\n.zmdi-local-see:before {\r\n  content: '\\f28c';\r\n}\r\n.zmdi-local-shipping:before {\r\n  content: '\\f1e6';\r\n}\r\n.zmdi-local-store:before {\r\n  content: '\\f1d4';\r\n}\r\n.zmdi-local-taxi:before {\r\n  content: '\\f123';\r\n}\r\n.zmdi-local-wc:before {\r\n  content: '\\f211';\r\n}\r\n.zmdi-my-location:before {\r\n  content: '\\f299';\r\n}\r\n.zmdi-directions:before {\r\n  content: '\\f1e7';\r\n}\r\n"
  },
  {
    "path": "src/main/resources/static/auth/scss/common/extend.scss",
    "content": "/* @extend display-flex; */\r\ndisplay-flex {\r\n    display: flex;\r\n    display: -webkit-flex;\r\n}\r\n/* @extend list-type-ulli; */\r\nlist-type-ulli {\r\n    list-style-type: none;\r\n    margin: 0;\r\n    padding: 0;\r\n}\r\n"
  },
  {
    "path": "src/main/resources/static/auth/scss/common/fonts.scss",
    "content": "/* poppins-300 - latin */\r\n@font-face {\r\n    font-family: 'Poppins';\r\n    font-style: normal;\r\n    font-weight: 300;\r\n    src: url('../../fonts/poppins/poppins-v5-latin-300.eot'); /* IE9 Compat Modes */\r\n    src: local('Poppins Light'), local('Poppins-Light'),\r\n         url('../../fonts/poppins/poppins-v5-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n         url('../../fonts/poppins/poppins-v5-latin-300.woff2') format('woff2'), /* Super Modern Browsers */\r\n         url('../../fonts/poppins/poppins-v5-latin-300.woff') format('woff'), /* Modern Browsers */\r\n         url('../../fonts/poppins/poppins-v5-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */\r\n         url('../../fonts/poppins/poppins-v5-latin-300.svg#Poppins') format('svg'); /* Legacy iOS */\r\n  }\r\n  /* poppins-300italic - latin */\r\n  @font-face {\r\n    font-family: 'Poppins';\r\n    font-style: italic;\r\n    font-weight: 300;\r\n    src: url('../../fonts/poppins/poppins-v5-latin-300italic.eot'); /* IE9 Compat Modes */\r\n    src: local('Poppins Light Italic'), local('Poppins-LightItalic'),\r\n         url('../../fonts/poppins/poppins-v5-latin-300italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n         url('../../fonts/poppins/poppins-v5-latin-300italic.woff2') format('woff2'), /* Super Modern Browsers */\r\n         url('../../fonts/poppins/poppins-v5-latin-300italic.woff') format('woff'), /* Modern Browsers */\r\n         url('../../fonts/poppins/poppins-v5-latin-300italic.ttf') format('truetype'), /* Safari, Android, iOS */\r\n         url('../../fonts/poppins/poppins-v5-latin-300italic.svg#Poppins') format('svg'); /* Legacy iOS */\r\n  }\r\n  /* poppins-regular - latin */\r\n  @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 400;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-regular.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Regular'), local('Poppins-Regular'),\r\n           url('../../fonts/poppins/poppins-v5-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-regular.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-regular.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-italic - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: italic;\r\n      font-weight: 400;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-italic.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Italic'), local('Poppins-Italic'),\r\n           url('../../fonts/poppins/poppins-v5-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-italic.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-italic.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-500 - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 500;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-500.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Medium'), local('Poppins-Medium'),\r\n           url('../../fonts/poppins/poppins-v5-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-500.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-500.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-500.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-500italic - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: italic;\r\n      font-weight: 500;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-500italic.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Medium Italic'), local('Poppins-MediumItalic'),\r\n           url('../../fonts/poppins/poppins-v5-latin-500italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-500italic.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-500italic.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-500italic.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-500italic.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-600 - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 600;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-600.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins SemiBold'), local('Poppins-SemiBold'),\r\n           url('../../fonts/poppins/poppins-v5-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-600.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-600.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-600.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-700 - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 700;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-700.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Bold'), local('Poppins-Bold'),\r\n           url('../../fonts/poppins/poppins-v5-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-700.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-700.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-700.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-700italic - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: italic;\r\n      font-weight: 700;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-700italic.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Bold Italic'), local('Poppins-BoldItalic'),\r\n           url('../../fonts/poppins/poppins-v5-latin-700italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-700italic.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-700italic.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-700italic.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-700italic.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-800 - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 800;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-800.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins ExtraBold'), local('Poppins-ExtraBold'),\r\n           url('../../fonts/poppins/poppins-v5-latin-800.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-800.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-800.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-800.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-800.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-800italic - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: italic;\r\n      font-weight: 800;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-800italic.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins ExtraBold Italic'), local('Poppins-ExtraBoldItalic'),\r\n           url('../../fonts/poppins/poppins-v5-latin-800italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-800italic.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-800italic.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-800italic.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-800italic.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }\r\n    /* poppins-900 - latin */\r\n    @font-face {\r\n      font-family: 'Poppins';\r\n      font-style: normal;\r\n      font-weight: 900;\r\n      src: url('../../fonts/poppins/poppins-v5-latin-900.eot'); /* IE9 Compat Modes */\r\n      src: local('Poppins Black'), local('Poppins-Black'),\r\n           url('../../fonts/poppins/poppins-v5-latin-900.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */\r\n           url('../../fonts/poppins/poppins-v5-latin-900.woff2') format('woff2'), /* Super Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-900.woff') format('woff'), /* Modern Browsers */\r\n           url('../../fonts/poppins/poppins-v5-latin-900.ttf') format('truetype'), /* Safari, Android, iOS */\r\n           url('../../fonts/poppins/poppins-v5-latin-900.svg#Poppins') format('svg'); /* Legacy iOS */\r\n    }"
  },
  {
    "path": "src/main/resources/static/auth/scss/common/global.scss",
    "content": " a:focus, a:active { text-decoration: none; outline: none; @include transition(all 300ms ease 0s); }\r\ninput, select, textarea { outline: none; @include appearance( unset ); }\r\ninput::-webkit-outer-spin-button, input::-webkit-inner-spin-button {\r\n    @include appearance( none );\r\n    margin: 0;\r\n}\r\ninput:focus, select:focus, textarea:focus { outline: none; @include box-shadow-input(none); }\r\ninput[type=checkbox] { @include appearance( checkbox ); }\r\ninput[type=radio] { @include appearance( radio ); }\r\nimg { max-width: 100%; height: auto; }\r\nfigure { margin: 0; }\r\np { margin-bottom: 0px; font-size: 15px; color: #777;}\r\nh2 { \r\n    line-height: 1.66; \r\n    margin: 0; \r\n    padding: 0;\r\n    font-weight: bold; \r\n    color: $black-color;\r\n    font-family: Poppins;\r\n    font-size: 36px;\r\n}\r\n.main { \r\n    background: #f8f8f8;\r\n}\r\n.clear { clear: both; }\r\nbody {\r\n\tfont-size: 13px;\r\n    line-height: 1.8;\r\n    color: $black-color;\r\n    background: #f8f8f8;\r\n    font-weight: 400;\r\n    font-family: Poppins;\r\n}\r\n.container {\r\n    width: 900px;\r\n    background: #fff;\r\n    margin: 0 auto;\r\n    @include box-shadow(0px 15px 16.83px 0.17px rgba(0, 0, 0, 0.05));\r\n    @include border-radius(20px);\r\n}\r\n  \r\n.display-flex  {\r\n    @extend display-flex;\r\n    @include justify-content(space-between);\r\n    @include align-items(center);\r\n}\r\n\r\n.display-flex-center  {\r\n    @extend display-flex;\r\n    @include justify-content(center);\r\n    @include align-items(center);\r\n}\r\n\r\n.position-center {\r\n    position: absolute;\r\n    top: 50%;\r\n    left: 50%;\r\n    @include transform(translate(-50%,-50%));\r\n}\r\n"
  },
  {
    "path": "src/main/resources/static/auth/scss/common/minxi.scss",
    "content": "// mixin\r\n@mixin border-radius($value) {\r\n    border-radius: $value;\r\n    -moz-border-radius: $value;\r\n    -webkit-border-radius: $value;\r\n    -o-border-radius: $value;\r\n    -ms-border-radius: $value;\r\n}\r\n@mixin background-size($value) {\r\n\tbackground-size: $value;\r\n\t-moz-background-size: $value;\r\n\t-webkit-background-size: $value;\r\n\t-o-background-size: $value;\r\n\t-ms-background-size: $value;\r\n}\r\n@mixin background-gradient-three($color1, $color2, $color3) {\r\n    background: linear-gradient($color1, $color2, $color3);\r\n    background: -moz-linear-gradient($color1, $color2, $color3);\r\n    background: -webkit-linear-gradient($color1, $color2, $color3);\r\n    background: -o-linear-gradient($color1, $color2, $color3);\r\n    background: -ms-linear-gradient($color1, $color2, $color3);\r\n}\r\n@mixin background-gradient-six($color1, $color2, $color3, $color4, $color5, $color6) {\r\n    background: linear-gradient($color1, $color2, $color3, $color4, $color5, $color6);\r\n    background: -moz-linear-gradient($color1, $color2, $color3, $color4, $color5, $color6);\r\n    background: -webkit-linear-gradient($color1, $color2, $color3, $color4, $color5, $color6);\r\n    background: -o-linear-gradient($color1, $color2, $color3, $color4, $color5, $color6);\r\n    background: -ms-linear-gradient($color1, $color2, $color3, $color4, $color5, $color6);\r\n}\r\n@mixin transform($value) {\r\n\ttransform: $value;\r\n\t-moz-transform: $value;\r\n\t-webkit-transform: $value;\r\n\t-o-transform: $value;\r\n\t-ms-transform: $value;\r\n}\r\n@mixin box-shadow($value) {\r\n\tbox-shadow: $value;\r\n\t-moz-box-shadow: $value;\r\n\t-webkit-box-shadow: $value;\r\n\t-o-box-shadow: $value;\r\n\t-ms-box-shadow: $value;\r\n}\r\n@mixin filter($value) {\r\n\tfilter: $value;\r\n\t-moz-filter: $value;\r\n\t-webkit-filter: $value;\r\n\t-o-filter: $value;\r\n\t-ms-filter: $value;\r\n}\r\n@mixin transition($value) {\r\n\ttransition: $value;\r\n\t-moz-transition: $value;\r\n\t-webkit-transition: $value;\r\n\t-o-transition: $value;\r\n\t-ms-transition: $value;\r\n}\r\n@mixin animation($value) {\r\n\tanimation: $value;\r\n\t-moz-animation: $value;\r\n\t-webkit-animation: $value;\r\n\t-o-animation: $value;\r\n\t-ms-animation: $value;\r\n}\r\n@mixin transform-origin($value) {\r\n\ttransform-origin: $value;\r\n\t-moz-transform-origin: $value;\r\n\t-webkit-transform-origin: $value;\r\n\t-o-transform-origin: $value;\r\n\t-ms-transform-origin: $value;\r\n}\r\n@mixin appearance($value) {\r\n\tappearance: $value !important;\r\n\t-moz-appearance: $value !important;\r\n\t-webkit-appearance: $value !important;\r\n\t-o-appearance: $value !important;\r\n\t-ms-appearance: $value !important;\r\n}\r\n@mixin box-shadow-input($value) {\r\n\tbox-shadow: $value !important;\r\n\t-moz-box-shadow: $value !important;\r\n\t-webkit-box-shadow: $value !important;\r\n\t-o-box-shadow: $value !important;\r\n\t-ms-box-shadow: $value !important;\r\n}\r\n\r\n//flex\r\n@mixin flex-wrap($value) {\r\n\tflex-wrap: $value;\r\n\t-moz-flex-wrap: $value;\r\n\t-webkit-flex-wrap: $value;\r\n\t-o-flex-wrap: $value;\r\n\t-ms-flex-wrap: $value;\r\n}\r\n@mixin flex-direction($value) {\r\n\tflex-direction: $value;\r\n\t-moz-flex-direction: $value;\r\n\t-webkit-flex-direction: $value;\r\n\t-o-flex-direction: $value;\r\n\t-ms-flex-direction: $value;\r\n}\r\n@mixin flex-flow($value) {\r\n\tflex-flow: $value;\r\n\t-moz-flex-flow: $value;\r\n\t-webkit-flex-flow: $value;\r\n\t-o-flex-flow: $value;\r\n\t-ms-flex-flow: $value;\r\n}\r\n@mixin justify-content($value) {\r\n\tjustify-content: $value;\r\n\t-moz-justify-content: $value;\r\n\t-webkit-justify-content: $value;\r\n\t-o-justify-content: $value;\r\n\t-ms-justify-content: $value;\r\n}\r\n@mixin align-items($value) {\r\n\talign-items: $value;\r\n\t-moz-align-items: $value;\r\n\t-webkit-align-items: $value;\r\n\t-o-align-items: $value;\r\n\t-ms-align-items: $value;\r\n}\r\n@mixin order($value) {\r\n\torder: $value;\r\n\t-moz-order: $value;\r\n\t-webkit-order: $value;\r\n\t-o-order: $value;\r\n\t-ms-order: $value;\r\n}\r\n@mixin flex($value) {\r\n\tflex: $value;\r\n\t-moz-flex: $value;\r\n\t-webkit-flex: $value;\r\n\t-o-flex: $value;\r\n\t-ms-flex: $value;\r\n}\r\n\r\n\r\n@mixin input-placeholder($value) {\r\n\t&::-webkit-input-placeholder {\r\n\t\tcolor: $value;\r\n\t}\r\n\t&::-moz-placeholder {\r\n\t\tcolor: $value;\r\n\t}\r\n\t&:-ms-input-placeholder {\r\n\t\tcolor: $value;\r\n\t}\r\n\t&:-moz-placeholder {\r\n\t\tcolor: $value;\r\n\t}\r\n}"
  },
  {
    "path": "src/main/resources/static/auth/scss/common/variables.scss",
    "content": "$black-color : #222;\r\n$blue-color : #6dabe4;\r\n$grey-light: #999;"
  },
  {
    "path": "src/main/resources/static/auth/scss/layouts/main.scss",
    "content": ".signup {\r\n    margin-bottom: 150px;\r\n}\r\n.signup-content {\r\n    @extend display-flex;\r\n    padding: 75px 0;\r\n    // flex-flow: wrap;\r\n}\r\n.signup-form, .signup-image, .signin-form, .signin-image{\r\n    width: 50%;\r\n    overflow: hidden;\r\n}\r\n.signup-image {\r\n    margin: 0 55px;\r\n}\r\n.form-title {\r\n    margin-bottom: 33px;\r\n}\r\n.signup-image {\r\n    margin-top: 45px;\r\n}\r\nfigure {\r\n    margin-bottom: 50px;\r\n    text-align: center;\r\n}\r\n.form-submit {\r\n    display: inline-block;\r\n    background: $blue-color;\r\n    color: #fff;\r\n    border-bottom: none;\r\n    width: auto;\r\n    padding: 15px 39px;\r\n    @include border-radius(5px);\r\n    margin-top: 25px;\r\n    cursor: pointer;\r\n    &:hover {\r\n        background: darken($blue-color, 10%);\r\n    }\r\n}\r\n\r\n#signin {\r\n    margin-top: 16px;\r\n}\r\n.signup-image-link {\r\n    font-size: 14px;\r\n    color: $black-color;\r\n    display: block;\r\n    text-align: center;\r\n}\r\n\r\n.term-service {\r\n    font-size: 13px;\r\n    color: $black-color;\r\n}\r\n.signup-form {\r\n    margin-left: 75px;\r\n    margin-right: 75px;\r\n    padding-left: 34px;\r\n}\r\n.register-form {\r\n    width: 100%;\r\n}\r\n.form-group {\r\n    position: relative;\r\n    margin-bottom: 25px;\r\n    overflow: hidden;\r\n    &:last-child {\r\n        margin-bottom: 0px;\r\n    }\r\n}\r\n\r\ninput {\r\n    width: 100%;\r\n    display: block;\r\n    border: none;\r\n    border-bottom: 1px solid $grey-light;\r\n    padding: 6px 30px;\r\n    font-family: Poppins;\r\n    box-sizing: border-box;\r\n    @include input-placeholder($grey-light);\r\n    &:focus {\r\n        border-bottom: 1px solid $black-color;\r\n        @include input-placeholder($black-color);\r\n    }\r\n}\r\n\r\ninput[type=checkbox]:not(old){\r\n  width     : 2em;\r\n  margin    : 0;\r\n  padding   : 0;\r\n  font-size : 1em;\r\n  display: none;\r\n}\r\ninput[type=checkbox]:not(old) + label{\r\n    display      : inline-block;\r\n    line-height  : 1.5em;\r\n    margin-top: 6px;\r\n}\r\ninput[type=checkbox]:not(old) + label > span{\r\n  display          : inline-block;\r\n  width            : 13px;\r\n  height           : 13px;\r\n  margin-right: 15px;\r\n  margin-bottom: 3px;\r\n  border           : 1px solid $grey-light;\r\n  @include border-radius(2px);\r\n  background       : rgb(255,255,255);\r\n  background-image :    -moz-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n  background-image :     -ms-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n  background-image :      -o-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n  background-image : -webkit-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n  background-image :         linear-gradient(rgb(255,255,255),rgb(255,255,255 ));\r\n  vertical-align   : bottom;\r\n}\r\ninput[type=checkbox]:not(old):checked + label > span{\r\n    background-image :    -moz-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n    background-image :     -ms-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n    background-image :      -o-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n    background-image : -webkit-linear-gradient(rgb(255,255,255),rgb(255,255,255));\r\n    background-image :         linear-gradient(rgb(255,255,255),rgb(255,255,255 ));\r\n}\r\ninput[type=checkbox]:not(old):checked + label > span:before{\r\n    content     : '\\f26b';\r\n    display     : block;\r\n    color       : $black-color;\r\n    font-size   : 11px;\r\n    line-height : 1.2;\r\n    text-align  : center;\r\n    font-family: 'Material-Design-Iconic-Font';\r\n    font-weight: bold;\r\n  }\r\n.agree-term {\r\n    display: inline-block;\r\n    width: auto;\r\n}\r\n\r\nlabel {\r\n    position: absolute;\r\n    left: 0;\r\n    top: 50%;\r\n    @include transform(translateY(-50%));\r\n    color: $black-color;\r\n}\r\n.label-has-error {\r\n    top: 22%;\r\n}\r\nlabel.error {\r\n    position: relative;\r\n    //background: url('../images/unchecked.gif') no-repeat;\r\n    background-position-y: 3px;\r\n    padding-left: 20px;\r\n    display: block;\r\n    margin-top: 20px;\r\n}\r\nlabel.valid {\r\n    display: block;\r\n\r\n    position: absolute;\r\n    right: 0;\r\n    left: auto;\r\n    margin-top: -6px;\r\n    width: 20px;\r\n    height: 20px;\r\n    background: transparent;\r\n    &:after {\r\n        font-family: 'Material-Design-Iconic-Font';\r\n        content: '\\f269';\r\n        width: 100%;\r\n        height: 100%;\r\n        position: absolute;\r\n        /* right: 0; */\r\n        font-size: 16px;\r\n        color: green;\r\n    }\r\n}\r\n.label-agree-term {\r\n    position: relative;\r\n    top: 0%;\r\n    @include transform(translateY(0));\r\n}\r\n.material-icons-name {\r\n    font-size: 18px;\r\n}\r\n\r\n\r\n// Login\r\n\r\n.signin-content {\r\n    @extend display-flex;\r\n    padding-top: 67px;\r\n    padding-bottom: 87px;\r\n    // padding: 67px 0;\r\n}\r\n.social-login {\r\n    @extend display-flex;\r\n    @include align-items(center);\r\n    margin-top: 80px;\r\n}\r\n.social-label {\r\n    display: inline-block;\r\n    margin-right: 15px;\r\n}\r\n.socials {\r\n    @extend display-flex;\r\n    @extend list-type-ulli;\r\n    li {\r\n        padding: 5px;\r\n        &:last-child {\r\n            margin-right: 0px;\r\n        }\r\n        a {\r\n            text-decoration: none;\r\n            i {\r\n                width: 30px;\r\n                height: 30px;\r\n                color: #fff;\r\n                font-size: 14px;\r\n                @include border-radius(5px);\r\n                @include transform(translateZ(0));\r\n                -webkit-transition-duration: 0.3s;\r\n                transition-duration: 0.3s;\r\n                -webkit-transition-property: transform;\r\n                transition-property: transform;\r\n                -webkit-transition-timing-function: ease-out;\r\n                transition-timing-function: ease-out;\r\n            }\r\n        }\r\n        &:hover {\r\n            a {\r\n                i {\r\n                    -webkit-transform: scale(1.3) translateZ(0);\r\n                    transform: scale(1.3) translateZ(0); \r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n.zmdi-facebook {\r\n    background: #3b5998;\r\n}\r\n.zmdi-twitter {\r\n    background: #1da0f2;\r\n}\r\n.zmdi-google {\r\n    background: #e72734;\r\n}\r\n.signin-form {\r\n    margin-right: 90px;\r\n    margin-left: 80px;\r\n}\r\n.signin-image {\r\n    margin-left: 110px;\r\n    margin-right: 20px;\r\n    margin-top: 10px;\r\n}\r\n  "
  },
  {
    "path": "src/main/resources/static/auth/scss/layouts/responsive.scss",
    "content": "@media screen and (max-width: 1600px) {\r\n\r\n}\r\n\r\n@media screen and (max-width: 1300px) {\r\n\r\n}\r\n\r\n//end 1200px\r\n@media screen and (max-width: 1200px) {\r\n    .container {\r\n        width: calc( 100% - 30px);\r\n        max-width: 100%;\r\n    }\r\n}\r\n\r\n@media screen and (min-width: 1024px) {\r\n    .container {\r\n        max-width: 1200px;\r\n    }\r\n}\r\n\r\n//end 1200px\r\n@media screen and (max-width: 1024px) {\r\n}\r\n\r\n//end 1024px\r\n@media screen and (max-width: 992px) {\r\n    \r\n}\r\n\r\n//end 992px\r\n@media screen and (max-width: 768px) {\r\n\r\n    .signup-content, .signin-content {\r\n        @include flex-direction(column);\r\n        @include justify-content(center);\r\n    }\r\n    .signup-form {\r\n        margin-left: 0px;\r\n        margin-right: 0px;\r\n        padding-left: 0px;\r\n        /* box-sizing: border-box; */\r\n        padding: 0 30px;\r\n    }\r\n    .signin-image {\r\n        margin-left: 0px;\r\n        margin-right: 0px;\r\n        margin-top: 50px;\r\n        @include order(2);\r\n    }\r\n    .signup-form, .signup-image, .signin-form, .signin-image {\r\n        width: auto;\r\n    }\r\n\r\n    .social-login {\r\n        @include justify-content(center);\r\n    }\r\n    .form-button {\r\n        text-align: center;\r\n    }\r\n    .signin-form {\r\n        @include order(1);\r\n        margin-right: 0px;\r\n        margin-left: 0px;\r\n        padding: 0 30px;\r\n    }\r\n    .form-title {\r\n        text-align: center;\r\n    }\r\n\r\n}\r\n\r\n@media screen and (max-width: 620px)  {\r\n\r\n}\r\n\r\n//end 767px\r\n@media screen and (max-width: 575px) {\r\n\r\n}\r\n\r\n//end 575px\r\n@media screen and (max-width: 480px) {\r\n\r\n}\r\n\r\n//end 480px\r\n@media screen and (max-width: 400px) {\r\n    .social-login {\r\n        @include flex-direction(column);\r\n    }\r\n    .social-label {\r\n        margin-right: 0px;\r\n        margin-bottom: 10px;\r\n    }\r\n}\r\n\r\n//end 400px\r\n\r\n@media screen and (max-width: 320px) {}"
  },
  {
    "path": "src/main/resources/static/auth/scss/style.scss",
    "content": "//Common\r\n@import 'common/extend.scss';\r\n@import 'common/fonts.scss';\r\n@import 'common/minxi.scss';\r\n@import 'common/variables.scss';\r\n@import 'common/global.scss';\r\n\r\n//layout\r\n@import 'layouts/main.scss';\r\n\r\n// Responsive\r\n@import 'layouts/responsive.scss';"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/bootstrap/css/bootstrap-grid.css",
    "content": "@-ms-viewport {\n  width: device-width;\n}\n\nhtml {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  -ms-overflow-style: scrollbar;\n}\n\n*,\n*::before,\n*::after {\n  -webkit-box-sizing: inherit;\n          box-sizing: inherit;\n}\n\n.container {\n  position: relative;\n  margin-left: auto;\n  margin-right: auto;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 576px) {\n  .container {\n    width: 540px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 768px) {\n  .container {\n    width: 720px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 992px) {\n  .container {\n    width: 960px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container {\n    width: 1140px;\n    max-width: 100%;\n  }\n}\n\n.container-fluid {\n  position: relative;\n  margin-left: auto;\n  margin-right: auto;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n.row {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-flex-wrap: wrap;\n      -ms-flex-wrap: wrap;\n          flex-wrap: wrap;\n  margin-right: -15px;\n  margin-left: -15px;\n}\n\n@media (min-width: 576px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.no-gutters > .col,\n.no-gutters > [class*=\"col-\"] {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n  position: relative;\n  width: 100%;\n  min-height: 1px;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n.col {\n  -webkit-flex-basis: 0;\n      -ms-flex-preferred-size: 0;\n          flex-basis: 0;\n  -webkit-box-flex: 1;\n  -webkit-flex-grow: 1;\n      -ms-flex-positive: 1;\n          flex-grow: 1;\n  max-width: 100%;\n}\n\n.col-auto {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 auto;\n      -ms-flex: 0 0 auto;\n          flex: 0 0 auto;\n  width: auto;\n}\n\n.col-1 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 8.333333%;\n      -ms-flex: 0 0 8.333333%;\n          flex: 0 0 8.333333%;\n  max-width: 8.333333%;\n}\n\n.col-2 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 16.666667%;\n      -ms-flex: 0 0 16.666667%;\n          flex: 0 0 16.666667%;\n  max-width: 16.666667%;\n}\n\n.col-3 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 25%;\n      -ms-flex: 0 0 25%;\n          flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.col-4 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 33.333333%;\n      -ms-flex: 0 0 33.333333%;\n          flex: 0 0 33.333333%;\n  max-width: 33.333333%;\n}\n\n.col-5 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 41.666667%;\n      -ms-flex: 0 0 41.666667%;\n          flex: 0 0 41.666667%;\n  max-width: 41.666667%;\n}\n\n.col-6 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 50%;\n      -ms-flex: 0 0 50%;\n          flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.col-7 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 58.333333%;\n      -ms-flex: 0 0 58.333333%;\n          flex: 0 0 58.333333%;\n  max-width: 58.333333%;\n}\n\n.col-8 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 66.666667%;\n      -ms-flex: 0 0 66.666667%;\n          flex: 0 0 66.666667%;\n  max-width: 66.666667%;\n}\n\n.col-9 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 75%;\n      -ms-flex: 0 0 75%;\n          flex: 0 0 75%;\n  max-width: 75%;\n}\n\n.col-10 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 83.333333%;\n      -ms-flex: 0 0 83.333333%;\n          flex: 0 0 83.333333%;\n  max-width: 83.333333%;\n}\n\n.col-11 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 91.666667%;\n      -ms-flex: 0 0 91.666667%;\n          flex: 0 0 91.666667%;\n  max-width: 91.666667%;\n}\n\n.col-12 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 100%;\n      -ms-flex: 0 0 100%;\n          flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.pull-0 {\n  right: auto;\n}\n\n.pull-1 {\n  right: 8.333333%;\n}\n\n.pull-2 {\n  right: 16.666667%;\n}\n\n.pull-3 {\n  right: 25%;\n}\n\n.pull-4 {\n  right: 33.333333%;\n}\n\n.pull-5 {\n  right: 41.666667%;\n}\n\n.pull-6 {\n  right: 50%;\n}\n\n.pull-7 {\n  right: 58.333333%;\n}\n\n.pull-8 {\n  right: 66.666667%;\n}\n\n.pull-9 {\n  right: 75%;\n}\n\n.pull-10 {\n  right: 83.333333%;\n}\n\n.pull-11 {\n  right: 91.666667%;\n}\n\n.pull-12 {\n  right: 100%;\n}\n\n.push-0 {\n  left: auto;\n}\n\n.push-1 {\n  left: 8.333333%;\n}\n\n.push-2 {\n  left: 16.666667%;\n}\n\n.push-3 {\n  left: 25%;\n}\n\n.push-4 {\n  left: 33.333333%;\n}\n\n.push-5 {\n  left: 41.666667%;\n}\n\n.push-6 {\n  left: 50%;\n}\n\n.push-7 {\n  left: 58.333333%;\n}\n\n.push-8 {\n  left: 66.666667%;\n}\n\n.push-9 {\n  left: 75%;\n}\n\n.push-10 {\n  left: 83.333333%;\n}\n\n.push-11 {\n  left: 91.666667%;\n}\n\n.push-12 {\n  left: 100%;\n}\n\n.offset-1 {\n  margin-left: 8.333333%;\n}\n\n.offset-2 {\n  margin-left: 16.666667%;\n}\n\n.offset-3 {\n  margin-left: 25%;\n}\n\n.offset-4 {\n  margin-left: 33.333333%;\n}\n\n.offset-5 {\n  margin-left: 41.666667%;\n}\n\n.offset-6 {\n  margin-left: 50%;\n}\n\n.offset-7 {\n  margin-left: 58.333333%;\n}\n\n.offset-8 {\n  margin-left: 66.666667%;\n}\n\n.offset-9 {\n  margin-left: 75%;\n}\n\n.offset-10 {\n  margin-left: 83.333333%;\n}\n\n.offset-11 {\n  margin-left: 91.666667%;\n}\n\n@media (min-width: 576px) {\n  .col-sm {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-sm-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-sm-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-sm-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-sm-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-sm-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-sm-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-sm-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-sm-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-sm-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-sm-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-sm-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-sm-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-sm-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-sm-0 {\n    right: auto;\n  }\n  .pull-sm-1 {\n    right: 8.333333%;\n  }\n  .pull-sm-2 {\n    right: 16.666667%;\n  }\n  .pull-sm-3 {\n    right: 25%;\n  }\n  .pull-sm-4 {\n    right: 33.333333%;\n  }\n  .pull-sm-5 {\n    right: 41.666667%;\n  }\n  .pull-sm-6 {\n    right: 50%;\n  }\n  .pull-sm-7 {\n    right: 58.333333%;\n  }\n  .pull-sm-8 {\n    right: 66.666667%;\n  }\n  .pull-sm-9 {\n    right: 75%;\n  }\n  .pull-sm-10 {\n    right: 83.333333%;\n  }\n  .pull-sm-11 {\n    right: 91.666667%;\n  }\n  .pull-sm-12 {\n    right: 100%;\n  }\n  .push-sm-0 {\n    left: auto;\n  }\n  .push-sm-1 {\n    left: 8.333333%;\n  }\n  .push-sm-2 {\n    left: 16.666667%;\n  }\n  .push-sm-3 {\n    left: 25%;\n  }\n  .push-sm-4 {\n    left: 33.333333%;\n  }\n  .push-sm-5 {\n    left: 41.666667%;\n  }\n  .push-sm-6 {\n    left: 50%;\n  }\n  .push-sm-7 {\n    left: 58.333333%;\n  }\n  .push-sm-8 {\n    left: 66.666667%;\n  }\n  .push-sm-9 {\n    left: 75%;\n  }\n  .push-sm-10 {\n    left: 83.333333%;\n  }\n  .push-sm-11 {\n    left: 91.666667%;\n  }\n  .push-sm-12 {\n    left: 100%;\n  }\n  .offset-sm-0 {\n    margin-left: 0%;\n  }\n  .offset-sm-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-sm-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-sm-3 {\n    margin-left: 25%;\n  }\n  .offset-sm-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-sm-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-sm-6 {\n    margin-left: 50%;\n  }\n  .offset-sm-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-sm-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-sm-9 {\n    margin-left: 75%;\n  }\n  .offset-sm-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-sm-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 768px) {\n  .col-md {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-md-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-md-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-md-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-md-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-md-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-md-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-md-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-md-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-md-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-md-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-md-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-md-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-md-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-md-0 {\n    right: auto;\n  }\n  .pull-md-1 {\n    right: 8.333333%;\n  }\n  .pull-md-2 {\n    right: 16.666667%;\n  }\n  .pull-md-3 {\n    right: 25%;\n  }\n  .pull-md-4 {\n    right: 33.333333%;\n  }\n  .pull-md-5 {\n    right: 41.666667%;\n  }\n  .pull-md-6 {\n    right: 50%;\n  }\n  .pull-md-7 {\n    right: 58.333333%;\n  }\n  .pull-md-8 {\n    right: 66.666667%;\n  }\n  .pull-md-9 {\n    right: 75%;\n  }\n  .pull-md-10 {\n    right: 83.333333%;\n  }\n  .pull-md-11 {\n    right: 91.666667%;\n  }\n  .pull-md-12 {\n    right: 100%;\n  }\n  .push-md-0 {\n    left: auto;\n  }\n  .push-md-1 {\n    left: 8.333333%;\n  }\n  .push-md-2 {\n    left: 16.666667%;\n  }\n  .push-md-3 {\n    left: 25%;\n  }\n  .push-md-4 {\n    left: 33.333333%;\n  }\n  .push-md-5 {\n    left: 41.666667%;\n  }\n  .push-md-6 {\n    left: 50%;\n  }\n  .push-md-7 {\n    left: 58.333333%;\n  }\n  .push-md-8 {\n    left: 66.666667%;\n  }\n  .push-md-9 {\n    left: 75%;\n  }\n  .push-md-10 {\n    left: 83.333333%;\n  }\n  .push-md-11 {\n    left: 91.666667%;\n  }\n  .push-md-12 {\n    left: 100%;\n  }\n  .offset-md-0 {\n    margin-left: 0%;\n  }\n  .offset-md-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-md-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-md-3 {\n    margin-left: 25%;\n  }\n  .offset-md-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-md-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-md-6 {\n    margin-left: 50%;\n  }\n  .offset-md-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-md-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-md-9 {\n    margin-left: 75%;\n  }\n  .offset-md-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-md-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 992px) {\n  .col-lg {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-lg-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-lg-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-lg-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-lg-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-lg-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-lg-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-lg-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-lg-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-lg-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-lg-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-lg-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-lg-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-lg-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-lg-0 {\n    right: auto;\n  }\n  .pull-lg-1 {\n    right: 8.333333%;\n  }\n  .pull-lg-2 {\n    right: 16.666667%;\n  }\n  .pull-lg-3 {\n    right: 25%;\n  }\n  .pull-lg-4 {\n    right: 33.333333%;\n  }\n  .pull-lg-5 {\n    right: 41.666667%;\n  }\n  .pull-lg-6 {\n    right: 50%;\n  }\n  .pull-lg-7 {\n    right: 58.333333%;\n  }\n  .pull-lg-8 {\n    right: 66.666667%;\n  }\n  .pull-lg-9 {\n    right: 75%;\n  }\n  .pull-lg-10 {\n    right: 83.333333%;\n  }\n  .pull-lg-11 {\n    right: 91.666667%;\n  }\n  .pull-lg-12 {\n    right: 100%;\n  }\n  .push-lg-0 {\n    left: auto;\n  }\n  .push-lg-1 {\n    left: 8.333333%;\n  }\n  .push-lg-2 {\n    left: 16.666667%;\n  }\n  .push-lg-3 {\n    left: 25%;\n  }\n  .push-lg-4 {\n    left: 33.333333%;\n  }\n  .push-lg-5 {\n    left: 41.666667%;\n  }\n  .push-lg-6 {\n    left: 50%;\n  }\n  .push-lg-7 {\n    left: 58.333333%;\n  }\n  .push-lg-8 {\n    left: 66.666667%;\n  }\n  .push-lg-9 {\n    left: 75%;\n  }\n  .push-lg-10 {\n    left: 83.333333%;\n  }\n  .push-lg-11 {\n    left: 91.666667%;\n  }\n  .push-lg-12 {\n    left: 100%;\n  }\n  .offset-lg-0 {\n    margin-left: 0%;\n  }\n  .offset-lg-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-lg-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-lg-3 {\n    margin-left: 25%;\n  }\n  .offset-lg-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-lg-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-lg-6 {\n    margin-left: 50%;\n  }\n  .offset-lg-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-lg-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-lg-9 {\n    margin-left: 75%;\n  }\n  .offset-lg-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-lg-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 1200px) {\n  .col-xl {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-xl-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-xl-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-xl-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-xl-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-xl-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-xl-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-xl-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-xl-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-xl-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-xl-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-xl-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-xl-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-xl-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-xl-0 {\n    right: auto;\n  }\n  .pull-xl-1 {\n    right: 8.333333%;\n  }\n  .pull-xl-2 {\n    right: 16.666667%;\n  }\n  .pull-xl-3 {\n    right: 25%;\n  }\n  .pull-xl-4 {\n    right: 33.333333%;\n  }\n  .pull-xl-5 {\n    right: 41.666667%;\n  }\n  .pull-xl-6 {\n    right: 50%;\n  }\n  .pull-xl-7 {\n    right: 58.333333%;\n  }\n  .pull-xl-8 {\n    right: 66.666667%;\n  }\n  .pull-xl-9 {\n    right: 75%;\n  }\n  .pull-xl-10 {\n    right: 83.333333%;\n  }\n  .pull-xl-11 {\n    right: 91.666667%;\n  }\n  .pull-xl-12 {\n    right: 100%;\n  }\n  .push-xl-0 {\n    left: auto;\n  }\n  .push-xl-1 {\n    left: 8.333333%;\n  }\n  .push-xl-2 {\n    left: 16.666667%;\n  }\n  .push-xl-3 {\n    left: 25%;\n  }\n  .push-xl-4 {\n    left: 33.333333%;\n  }\n  .push-xl-5 {\n    left: 41.666667%;\n  }\n  .push-xl-6 {\n    left: 50%;\n  }\n  .push-xl-7 {\n    left: 58.333333%;\n  }\n  .push-xl-8 {\n    left: 66.666667%;\n  }\n  .push-xl-9 {\n    left: 75%;\n  }\n  .push-xl-10 {\n    left: 83.333333%;\n  }\n  .push-xl-11 {\n    left: 91.666667%;\n  }\n  .push-xl-12 {\n    left: 100%;\n  }\n  .offset-xl-0 {\n    margin-left: 0%;\n  }\n  .offset-xl-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-xl-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-xl-3 {\n    margin-left: 25%;\n  }\n  .offset-xl-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-xl-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-xl-6 {\n    margin-left: 50%;\n  }\n  .offset-xl-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-xl-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-xl-9 {\n    margin-left: 75%;\n  }\n  .offset-xl-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-xl-11 {\n    margin-left: 91.666667%;\n  }\n}\n/*# sourceMappingURL=bootstrap-grid.css.map */"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/bootstrap/css/bootstrap-reboot.css",
    "content": "/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  font-family: sans-serif;\n  line-height: 1.15;\n  -ms-text-size-adjust: 100%;\n  -webkit-text-size-adjust: 100%;\n}\n\nbody {\n  margin: 0;\n}\n\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\nfigcaption,\nfigure,\nmain {\n  display: block;\n}\n\nfigure {\n  margin: 1em 40px;\n}\n\nhr {\n  -webkit-box-sizing: content-box;\n          box-sizing: content-box;\n  height: 0;\n  overflow: visible;\n}\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\na {\n  background-color: transparent;\n  -webkit-text-decoration-skip: objects;\n}\n\na:active,\na:hover {\n  outline-width: 0;\n}\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted;\n}\n\nb,\nstrong {\n  font-weight: inherit;\n}\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\ndfn {\n  font-style: italic;\n}\n\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\nsmall {\n  font-size: 80%;\n}\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\naudio,\nvideo {\n  display: inline-block;\n}\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\nimg {\n  border-style: none;\n}\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0;\n}\n\nbutton,\ninput {\n  overflow: visible;\n}\n\nbutton,\nselect {\n  text-transform: none;\n}\n\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\nlegend {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal;\n}\n\nprogress {\n  display: inline-block;\n  vertical-align: baseline;\n}\n\ntextarea {\n  overflow: auto;\n}\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  padding: 0;\n}\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px;\n}\n\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit;\n}\n\ndetails,\nmenu {\n  display: block;\n}\n\nsummary {\n  display: list-item;\n}\n\ncanvas {\n  display: inline-block;\n}\n\ntemplate {\n  display: none;\n}\n\n[hidden] {\n  display: none;\n}\n\nhtml {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n\n*,\n*::before,\n*::after {\n  -webkit-box-sizing: inherit;\n          box-sizing: inherit;\n}\n\n@-ms-viewport {\n  width: device-width;\n}\n\nhtml {\n  -ms-overflow-style: scrollbar;\n  -webkit-tap-highlight-color: transparent;\n}\n\nbody {\n  font-family: -apple-system, system-ui, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #292b2c;\n  background-color: #fff;\n}\n\n[tabindex=\"-1\"]:focus {\n  outline: none !important;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  margin-top: 0;\n  margin-bottom: .5rem;\n}\n\np {\n  margin-top: 0;\n  margin-bottom: 1rem;\n}\n\nabbr[title],\nabbr[data-original-title] {\n  cursor: help;\n}\n\naddress {\n  margin-bottom: 1rem;\n  font-style: normal;\n  line-height: inherit;\n}\n\nol,\nul,\ndl {\n  margin-top: 0;\n  margin-bottom: 1rem;\n}\n\nol ol,\nul ul,\nol ul,\nul ol {\n  margin-bottom: 0;\n}\n\ndt {\n  font-weight: bold;\n}\n\ndd {\n  margin-bottom: .5rem;\n  margin-left: 0;\n}\n\nblockquote {\n  margin: 0 0 1rem;\n}\n\na {\n  color: #0275d8;\n  text-decoration: none;\n}\n\na:focus, a:hover {\n  color: #014c8c;\n  text-decoration: underline;\n}\n\na:not([href]):not([tabindex]) {\n  color: inherit;\n  text-decoration: none;\n}\n\na:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {\n  color: inherit;\n  text-decoration: none;\n}\n\na:not([href]):not([tabindex]):focus {\n  outline: 0;\n}\n\npre {\n  margin-top: 0;\n  margin-bottom: 1rem;\n  overflow: auto;\n}\n\nfigure {\n  margin: 0 0 1rem;\n}\n\nimg {\n  vertical-align: middle;\n}\n\n[role=\"button\"] {\n  cursor: pointer;\n}\n\na,\narea,\nbutton,\n[role=\"button\"],\ninput,\nlabel,\nselect,\nsummary,\ntextarea {\n  -ms-touch-action: manipulation;\n      touch-action: manipulation;\n}\n\ntable {\n  border-collapse: collapse;\n  background-color: transparent;\n}\n\ncaption {\n  padding-top: 0.75rem;\n  padding-bottom: 0.75rem;\n  color: #636c72;\n  text-align: left;\n  caption-side: bottom;\n}\n\nth {\n  text-align: left;\n}\n\nlabel {\n  display: inline-block;\n  margin-bottom: .5rem;\n}\n\nbutton:focus {\n  outline: 1px dotted;\n  outline: 5px auto -webkit-focus-ring-color;\n}\n\ninput,\nbutton,\nselect,\ntextarea {\n  line-height: inherit;\n}\n\ninput[type=\"radio\"]:disabled,\ninput[type=\"checkbox\"]:disabled {\n  cursor: not-allowed;\n}\n\ninput[type=\"date\"],\ninput[type=\"time\"],\ninput[type=\"datetime-local\"],\ninput[type=\"month\"] {\n  -webkit-appearance: listbox;\n}\n\ntextarea {\n  resize: vertical;\n}\n\nfieldset {\n  min-width: 0;\n  padding: 0;\n  margin: 0;\n  border: 0;\n}\n\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: .5rem;\n  font-size: 1.5rem;\n  line-height: inherit;\n}\n\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n\noutput {\n  display: inline-block;\n}\n\n[hidden] {\n  display: none !important;\n}\n/*# sourceMappingURL=bootstrap-reboot.css.map */"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/bootstrap/css/bootstrap.css",
    "content": "/*!\n * Bootstrap v4.0.0-alpha.6 (https://getbootstrap.com)\n * Copyright 2011-2017 The Bootstrap Authors\n * Copyright 2011-2017 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  font-family: sans-serif;\n  line-height: 1.15;\n  -ms-text-size-adjust: 100%;\n  -webkit-text-size-adjust: 100%;\n}\n\nbody {\n  margin: 0;\n}\n\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\nfigcaption,\nfigure,\nmain {\n  display: block;\n}\n\nfigure {\n  margin: 1em 40px;\n}\n\nhr {\n  -webkit-box-sizing: content-box;\n          box-sizing: content-box;\n  height: 0;\n  overflow: visible;\n}\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\na {\n  background-color: transparent;\n  -webkit-text-decoration-skip: objects;\n}\n\na:active,\na:hover {\n  outline-width: 0;\n}\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted;\n}\n\nb,\nstrong {\n  font-weight: inherit;\n}\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\ndfn {\n  font-style: italic;\n}\n\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\nsmall {\n  font-size: 80%;\n}\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\naudio,\nvideo {\n  display: inline-block;\n}\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\nimg {\n  border-style: none;\n}\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0;\n}\n\nbutton,\ninput {\n  overflow: visible;\n}\n\nbutton,\nselect {\n  text-transform: none;\n}\n\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\nlegend {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal;\n}\n\nprogress {\n  display: inline-block;\n  vertical-align: baseline;\n}\n\ntextarea {\n  overflow: auto;\n}\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n  padding: 0;\n}\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px;\n}\n\n[type=\"search\"]::-webkit-search-cancel-button,\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit;\n}\n\ndetails,\nmenu {\n  display: block;\n}\n\nsummary {\n  display: list-item;\n}\n\ncanvas {\n  display: inline-block;\n}\n\ntemplate {\n  display: none;\n}\n\n[hidden] {\n  display: none;\n}\n\n@media print {\n  *,\n  *::before,\n  *::after,\n  p::first-letter,\n  div::first-letter,\n  blockquote::first-letter,\n  li::first-letter,\n  p::first-line,\n  div::first-line,\n  blockquote::first-line,\n  li::first-line {\n    text-shadow: none !important;\n    -webkit-box-shadow: none !important;\n            box-shadow: none !important;\n  }\n  a,\n  a:visited {\n    text-decoration: underline;\n  }\n  abbr[title]::after {\n    content: \" (\" attr(title) \")\";\n  }\n  pre {\n    white-space: pre-wrap !important;\n  }\n  pre,\n  blockquote {\n    border: 1px solid #999;\n    page-break-inside: avoid;\n  }\n  thead {\n    display: table-header-group;\n  }\n  tr,\n  img {\n    page-break-inside: avoid;\n  }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3;\n  }\n  h2,\n  h3 {\n    page-break-after: avoid;\n  }\n  .navbar {\n    display: none;\n  }\n  .badge {\n    border: 1px solid #000;\n  }\n  .table {\n    border-collapse: collapse !important;\n  }\n  .table td,\n  .table th {\n    background-color: #fff !important;\n  }\n  .table-bordered th,\n  .table-bordered td {\n    border: 1px solid #ddd !important;\n  }\n}\n\nhtml {\n  -webkit-box-sizing: border-box;\n          box-sizing: border-box;\n}\n\n*,\n*::before,\n*::after {\n  -webkit-box-sizing: inherit;\n          box-sizing: inherit;\n}\n\n@-ms-viewport {\n  width: device-width;\n}\n\nhtml {\n  -ms-overflow-style: scrollbar;\n  -webkit-tap-highlight-color: transparent;\n}\n\nbody {\n  font-family: -apple-system, system-ui, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #292b2c;\n  background-color: #fff;\n}\n\n[tabindex=\"-1\"]:focus {\n  outline: none !important;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  margin-top: 0;\n  margin-bottom: .5rem;\n}\n\np {\n  margin-top: 0;\n  margin-bottom: 1rem;\n}\n\nabbr[title],\nabbr[data-original-title] {\n  cursor: help;\n}\n\naddress {\n  margin-bottom: 1rem;\n  font-style: normal;\n  line-height: inherit;\n}\n\nol,\nul,\ndl {\n  margin-top: 0;\n  margin-bottom: 1rem;\n}\n\nol ol,\nul ul,\nol ul,\nul ol {\n  margin-bottom: 0;\n}\n\ndt {\n  font-weight: bold;\n}\n\ndd {\n  margin-bottom: .5rem;\n  margin-left: 0;\n}\n\nblockquote {\n  margin: 0 0 1rem;\n}\n\na {\n  color: #0275d8;\n  text-decoration: none;\n}\n\na:focus, a:hover {\n  color: #014c8c;\n  text-decoration: underline;\n}\n\na:not([href]):not([tabindex]) {\n  color: inherit;\n  text-decoration: none;\n}\n\na:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {\n  color: inherit;\n  text-decoration: none;\n}\n\na:not([href]):not([tabindex]):focus {\n  outline: 0;\n}\n\npre {\n  margin-top: 0;\n  margin-bottom: 1rem;\n  overflow: auto;\n}\n\nfigure {\n  margin: 0 0 1rem;\n}\n\nimg {\n  vertical-align: middle;\n}\n\n[role=\"button\"] {\n  cursor: pointer;\n}\n\na,\narea,\nbutton,\n[role=\"button\"],\ninput,\nlabel,\nselect,\nsummary,\ntextarea {\n  -ms-touch-action: manipulation;\n      touch-action: manipulation;\n}\n\ntable {\n  border-collapse: collapse;\n  background-color: transparent;\n}\n\ncaption {\n  padding-top: 0.75rem;\n  padding-bottom: 0.75rem;\n  color: #636c72;\n  text-align: left;\n  caption-side: bottom;\n}\n\nth {\n  text-align: left;\n}\n\nlabel {\n  display: inline-block;\n  margin-bottom: .5rem;\n}\n\nbutton:focus {\n  outline: 1px dotted;\n  outline: 5px auto -webkit-focus-ring-color;\n}\n\ninput,\nbutton,\nselect,\ntextarea {\n  line-height: inherit;\n}\n\ninput[type=\"radio\"]:disabled,\ninput[type=\"checkbox\"]:disabled {\n  cursor: not-allowed;\n}\n\ninput[type=\"date\"],\ninput[type=\"time\"],\ninput[type=\"datetime-local\"],\ninput[type=\"month\"] {\n  -webkit-appearance: listbox;\n}\n\ntextarea {\n  resize: vertical;\n}\n\nfieldset {\n  min-width: 0;\n  padding: 0;\n  margin: 0;\n  border: 0;\n}\n\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: .5rem;\n  font-size: 1.5rem;\n  line-height: inherit;\n}\n\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n\noutput {\n  display: inline-block;\n}\n\n[hidden] {\n  display: none !important;\n}\n\nh1, h2, h3, h4, h5, h6,\n.h1, .h2, .h3, .h4, .h5, .h6 {\n  margin-bottom: 0.5rem;\n  font-family: inherit;\n  font-weight: 500;\n  line-height: 1.1;\n  color: inherit;\n}\n\nh1, .h1 {\n  font-size: 2.5rem;\n}\n\nh2, .h2 {\n  font-size: 2rem;\n}\n\nh3, .h3 {\n  font-size: 1.75rem;\n}\n\nh4, .h4 {\n  font-size: 1.5rem;\n}\n\nh5, .h5 {\n  font-size: 1.25rem;\n}\n\nh6, .h6 {\n  font-size: 1rem;\n}\n\n.lead {\n  font-size: 1.25rem;\n  font-weight: 300;\n}\n\n.display-1 {\n  font-size: 6rem;\n  font-weight: 300;\n  line-height: 1.1;\n}\n\n.display-2 {\n  font-size: 5.5rem;\n  font-weight: 300;\n  line-height: 1.1;\n}\n\n.display-3 {\n  font-size: 4.5rem;\n  font-weight: 300;\n  line-height: 1.1;\n}\n\n.display-4 {\n  font-size: 3.5rem;\n  font-weight: 300;\n  line-height: 1.1;\n}\n\nhr {\n  margin-top: 1rem;\n  margin-bottom: 1rem;\n  border: 0;\n  border-top: 1px solid rgba(0, 0, 0, 0.1);\n}\n\nsmall,\n.small {\n  font-size: 80%;\n  font-weight: normal;\n}\n\nmark,\n.mark {\n  padding: 0.2em;\n  background-color: #fcf8e3;\n}\n\n.list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n\n.list-inline {\n  padding-left: 0;\n  list-style: none;\n}\n\n.list-inline-item {\n  display: inline-block;\n}\n\n.list-inline-item:not(:last-child) {\n  margin-right: 5px;\n}\n\n.initialism {\n  font-size: 90%;\n  text-transform: uppercase;\n}\n\n.blockquote {\n  padding: 0.5rem 1rem;\n  margin-bottom: 1rem;\n  font-size: 1.25rem;\n  border-left: 0.25rem solid #eceeef;\n}\n\n.blockquote-footer {\n  display: block;\n  font-size: 80%;\n  color: #636c72;\n}\n\n.blockquote-footer::before {\n  content: \"\\2014 \\00A0\";\n}\n\n.blockquote-reverse {\n  padding-right: 1rem;\n  padding-left: 0;\n  text-align: right;\n  border-right: 0.25rem solid #eceeef;\n  border-left: 0;\n}\n\n.blockquote-reverse .blockquote-footer::before {\n  content: \"\";\n}\n\n.blockquote-reverse .blockquote-footer::after {\n  content: \"\\00A0 \\2014\";\n}\n\n.img-fluid {\n  max-width: 100%;\n  height: auto;\n}\n\n.img-thumbnail {\n  padding: 0.25rem;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-radius: 0.25rem;\n  -webkit-transition: all 0.2s ease-in-out;\n  -o-transition: all 0.2s ease-in-out;\n  transition: all 0.2s ease-in-out;\n  max-width: 100%;\n  height: auto;\n}\n\n.figure {\n  display: inline-block;\n}\n\n.figure-img {\n  margin-bottom: 0.5rem;\n  line-height: 1;\n}\n\n.figure-caption {\n  font-size: 90%;\n  color: #636c72;\n}\n\ncode,\nkbd,\npre,\nsamp {\n  font-family: Menlo, Monaco, Consolas, \"Liberation Mono\", \"Courier New\", monospace;\n}\n\ncode {\n  padding: 0.2rem 0.4rem;\n  font-size: 90%;\n  color: #bd4147;\n  background-color: #f7f7f9;\n  border-radius: 0.25rem;\n}\n\na > code {\n  padding: 0;\n  color: inherit;\n  background-color: inherit;\n}\n\nkbd {\n  padding: 0.2rem 0.4rem;\n  font-size: 90%;\n  color: #fff;\n  background-color: #292b2c;\n  border-radius: 0.2rem;\n}\n\nkbd kbd {\n  padding: 0;\n  font-size: 100%;\n  font-weight: bold;\n}\n\npre {\n  display: block;\n  margin-top: 0;\n  margin-bottom: 1rem;\n  font-size: 90%;\n  color: #292b2c;\n}\n\npre code {\n  padding: 0;\n  font-size: inherit;\n  color: inherit;\n  background-color: transparent;\n  border-radius: 0;\n}\n\n.pre-scrollable {\n  max-height: 340px;\n  overflow-y: scroll;\n}\n\n.container {\n  position: relative;\n  margin-left: auto;\n  margin-right: auto;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 576px) {\n  .container {\n    width: 540px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 768px) {\n  .container {\n    width: 720px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 992px) {\n  .container {\n    width: 960px;\n    max-width: 100%;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container {\n    width: 1140px;\n    max-width: 100%;\n  }\n}\n\n.container-fluid {\n  position: relative;\n  margin-left: auto;\n  margin-right: auto;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .container-fluid {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n.row {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-flex-wrap: wrap;\n      -ms-flex-wrap: wrap;\n          flex-wrap: wrap;\n  margin-right: -15px;\n  margin-left: -15px;\n}\n\n@media (min-width: 576px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .row {\n    margin-right: -15px;\n    margin-left: -15px;\n  }\n}\n\n.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.no-gutters > .col,\n.no-gutters > [class*=\"col-\"] {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n  position: relative;\n  width: 100%;\n  min-height: 1px;\n  padding-right: 15px;\n  padding-left: 15px;\n}\n\n@media (min-width: 576px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 768px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 992px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n@media (min-width: 1200px) {\n  .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {\n    padding-right: 15px;\n    padding-left: 15px;\n  }\n}\n\n.col {\n  -webkit-flex-basis: 0;\n      -ms-flex-preferred-size: 0;\n          flex-basis: 0;\n  -webkit-box-flex: 1;\n  -webkit-flex-grow: 1;\n      -ms-flex-positive: 1;\n          flex-grow: 1;\n  max-width: 100%;\n}\n\n.col-auto {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 auto;\n      -ms-flex: 0 0 auto;\n          flex: 0 0 auto;\n  width: auto;\n}\n\n.col-1 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 8.333333%;\n      -ms-flex: 0 0 8.333333%;\n          flex: 0 0 8.333333%;\n  max-width: 8.333333%;\n}\n\n.col-2 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 16.666667%;\n      -ms-flex: 0 0 16.666667%;\n          flex: 0 0 16.666667%;\n  max-width: 16.666667%;\n}\n\n.col-3 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 25%;\n      -ms-flex: 0 0 25%;\n          flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.col-4 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 33.333333%;\n      -ms-flex: 0 0 33.333333%;\n          flex: 0 0 33.333333%;\n  max-width: 33.333333%;\n}\n\n.col-5 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 41.666667%;\n      -ms-flex: 0 0 41.666667%;\n          flex: 0 0 41.666667%;\n  max-width: 41.666667%;\n}\n\n.col-6 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 50%;\n      -ms-flex: 0 0 50%;\n          flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.col-7 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 58.333333%;\n      -ms-flex: 0 0 58.333333%;\n          flex: 0 0 58.333333%;\n  max-width: 58.333333%;\n}\n\n.col-8 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 66.666667%;\n      -ms-flex: 0 0 66.666667%;\n          flex: 0 0 66.666667%;\n  max-width: 66.666667%;\n}\n\n.col-9 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 75%;\n      -ms-flex: 0 0 75%;\n          flex: 0 0 75%;\n  max-width: 75%;\n}\n\n.col-10 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 83.333333%;\n      -ms-flex: 0 0 83.333333%;\n          flex: 0 0 83.333333%;\n  max-width: 83.333333%;\n}\n\n.col-11 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 91.666667%;\n      -ms-flex: 0 0 91.666667%;\n          flex: 0 0 91.666667%;\n  max-width: 91.666667%;\n}\n\n.col-12 {\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 0 100%;\n      -ms-flex: 0 0 100%;\n          flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.pull-0 {\n  right: auto;\n}\n\n.pull-1 {\n  right: 8.333333%;\n}\n\n.pull-2 {\n  right: 16.666667%;\n}\n\n.pull-3 {\n  right: 25%;\n}\n\n.pull-4 {\n  right: 33.333333%;\n}\n\n.pull-5 {\n  right: 41.666667%;\n}\n\n.pull-6 {\n  right: 50%;\n}\n\n.pull-7 {\n  right: 58.333333%;\n}\n\n.pull-8 {\n  right: 66.666667%;\n}\n\n.pull-9 {\n  right: 75%;\n}\n\n.pull-10 {\n  right: 83.333333%;\n}\n\n.pull-11 {\n  right: 91.666667%;\n}\n\n.pull-12 {\n  right: 100%;\n}\n\n.push-0 {\n  left: auto;\n}\n\n.push-1 {\n  left: 8.333333%;\n}\n\n.push-2 {\n  left: 16.666667%;\n}\n\n.push-3 {\n  left: 25%;\n}\n\n.push-4 {\n  left: 33.333333%;\n}\n\n.push-5 {\n  left: 41.666667%;\n}\n\n.push-6 {\n  left: 50%;\n}\n\n.push-7 {\n  left: 58.333333%;\n}\n\n.push-8 {\n  left: 66.666667%;\n}\n\n.push-9 {\n  left: 75%;\n}\n\n.push-10 {\n  left: 83.333333%;\n}\n\n.push-11 {\n  left: 91.666667%;\n}\n\n.push-12 {\n  left: 100%;\n}\n\n.offset-1 {\n  margin-left: 8.333333%;\n}\n\n.offset-2 {\n  margin-left: 16.666667%;\n}\n\n.offset-3 {\n  margin-left: 25%;\n}\n\n.offset-4 {\n  margin-left: 33.333333%;\n}\n\n.offset-5 {\n  margin-left: 41.666667%;\n}\n\n.offset-6 {\n  margin-left: 50%;\n}\n\n.offset-7 {\n  margin-left: 58.333333%;\n}\n\n.offset-8 {\n  margin-left: 66.666667%;\n}\n\n.offset-9 {\n  margin-left: 75%;\n}\n\n.offset-10 {\n  margin-left: 83.333333%;\n}\n\n.offset-11 {\n  margin-left: 91.666667%;\n}\n\n@media (min-width: 576px) {\n  .col-sm {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-sm-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-sm-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-sm-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-sm-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-sm-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-sm-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-sm-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-sm-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-sm-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-sm-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-sm-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-sm-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-sm-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-sm-0 {\n    right: auto;\n  }\n  .pull-sm-1 {\n    right: 8.333333%;\n  }\n  .pull-sm-2 {\n    right: 16.666667%;\n  }\n  .pull-sm-3 {\n    right: 25%;\n  }\n  .pull-sm-4 {\n    right: 33.333333%;\n  }\n  .pull-sm-5 {\n    right: 41.666667%;\n  }\n  .pull-sm-6 {\n    right: 50%;\n  }\n  .pull-sm-7 {\n    right: 58.333333%;\n  }\n  .pull-sm-8 {\n    right: 66.666667%;\n  }\n  .pull-sm-9 {\n    right: 75%;\n  }\n  .pull-sm-10 {\n    right: 83.333333%;\n  }\n  .pull-sm-11 {\n    right: 91.666667%;\n  }\n  .pull-sm-12 {\n    right: 100%;\n  }\n  .push-sm-0 {\n    left: auto;\n  }\n  .push-sm-1 {\n    left: 8.333333%;\n  }\n  .push-sm-2 {\n    left: 16.666667%;\n  }\n  .push-sm-3 {\n    left: 25%;\n  }\n  .push-sm-4 {\n    left: 33.333333%;\n  }\n  .push-sm-5 {\n    left: 41.666667%;\n  }\n  .push-sm-6 {\n    left: 50%;\n  }\n  .push-sm-7 {\n    left: 58.333333%;\n  }\n  .push-sm-8 {\n    left: 66.666667%;\n  }\n  .push-sm-9 {\n    left: 75%;\n  }\n  .push-sm-10 {\n    left: 83.333333%;\n  }\n  .push-sm-11 {\n    left: 91.666667%;\n  }\n  .push-sm-12 {\n    left: 100%;\n  }\n  .offset-sm-0 {\n    margin-left: 0%;\n  }\n  .offset-sm-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-sm-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-sm-3 {\n    margin-left: 25%;\n  }\n  .offset-sm-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-sm-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-sm-6 {\n    margin-left: 50%;\n  }\n  .offset-sm-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-sm-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-sm-9 {\n    margin-left: 75%;\n  }\n  .offset-sm-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-sm-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 768px) {\n  .col-md {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-md-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-md-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-md-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-md-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-md-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-md-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-md-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-md-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-md-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-md-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-md-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-md-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-md-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-md-0 {\n    right: auto;\n  }\n  .pull-md-1 {\n    right: 8.333333%;\n  }\n  .pull-md-2 {\n    right: 16.666667%;\n  }\n  .pull-md-3 {\n    right: 25%;\n  }\n  .pull-md-4 {\n    right: 33.333333%;\n  }\n  .pull-md-5 {\n    right: 41.666667%;\n  }\n  .pull-md-6 {\n    right: 50%;\n  }\n  .pull-md-7 {\n    right: 58.333333%;\n  }\n  .pull-md-8 {\n    right: 66.666667%;\n  }\n  .pull-md-9 {\n    right: 75%;\n  }\n  .pull-md-10 {\n    right: 83.333333%;\n  }\n  .pull-md-11 {\n    right: 91.666667%;\n  }\n  .pull-md-12 {\n    right: 100%;\n  }\n  .push-md-0 {\n    left: auto;\n  }\n  .push-md-1 {\n    left: 8.333333%;\n  }\n  .push-md-2 {\n    left: 16.666667%;\n  }\n  .push-md-3 {\n    left: 25%;\n  }\n  .push-md-4 {\n    left: 33.333333%;\n  }\n  .push-md-5 {\n    left: 41.666667%;\n  }\n  .push-md-6 {\n    left: 50%;\n  }\n  .push-md-7 {\n    left: 58.333333%;\n  }\n  .push-md-8 {\n    left: 66.666667%;\n  }\n  .push-md-9 {\n    left: 75%;\n  }\n  .push-md-10 {\n    left: 83.333333%;\n  }\n  .push-md-11 {\n    left: 91.666667%;\n  }\n  .push-md-12 {\n    left: 100%;\n  }\n  .offset-md-0 {\n    margin-left: 0%;\n  }\n  .offset-md-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-md-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-md-3 {\n    margin-left: 25%;\n  }\n  .offset-md-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-md-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-md-6 {\n    margin-left: 50%;\n  }\n  .offset-md-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-md-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-md-9 {\n    margin-left: 75%;\n  }\n  .offset-md-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-md-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 992px) {\n  .col-lg {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-lg-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-lg-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-lg-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-lg-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-lg-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-lg-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-lg-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-lg-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-lg-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-lg-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-lg-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-lg-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-lg-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-lg-0 {\n    right: auto;\n  }\n  .pull-lg-1 {\n    right: 8.333333%;\n  }\n  .pull-lg-2 {\n    right: 16.666667%;\n  }\n  .pull-lg-3 {\n    right: 25%;\n  }\n  .pull-lg-4 {\n    right: 33.333333%;\n  }\n  .pull-lg-5 {\n    right: 41.666667%;\n  }\n  .pull-lg-6 {\n    right: 50%;\n  }\n  .pull-lg-7 {\n    right: 58.333333%;\n  }\n  .pull-lg-8 {\n    right: 66.666667%;\n  }\n  .pull-lg-9 {\n    right: 75%;\n  }\n  .pull-lg-10 {\n    right: 83.333333%;\n  }\n  .pull-lg-11 {\n    right: 91.666667%;\n  }\n  .pull-lg-12 {\n    right: 100%;\n  }\n  .push-lg-0 {\n    left: auto;\n  }\n  .push-lg-1 {\n    left: 8.333333%;\n  }\n  .push-lg-2 {\n    left: 16.666667%;\n  }\n  .push-lg-3 {\n    left: 25%;\n  }\n  .push-lg-4 {\n    left: 33.333333%;\n  }\n  .push-lg-5 {\n    left: 41.666667%;\n  }\n  .push-lg-6 {\n    left: 50%;\n  }\n  .push-lg-7 {\n    left: 58.333333%;\n  }\n  .push-lg-8 {\n    left: 66.666667%;\n  }\n  .push-lg-9 {\n    left: 75%;\n  }\n  .push-lg-10 {\n    left: 83.333333%;\n  }\n  .push-lg-11 {\n    left: 91.666667%;\n  }\n  .push-lg-12 {\n    left: 100%;\n  }\n  .offset-lg-0 {\n    margin-left: 0%;\n  }\n  .offset-lg-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-lg-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-lg-3 {\n    margin-left: 25%;\n  }\n  .offset-lg-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-lg-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-lg-6 {\n    margin-left: 50%;\n  }\n  .offset-lg-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-lg-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-lg-9 {\n    margin-left: 75%;\n  }\n  .offset-lg-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-lg-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n@media (min-width: 1200px) {\n  .col-xl {\n    -webkit-flex-basis: 0;\n        -ms-flex-preferred-size: 0;\n            flex-basis: 0;\n    -webkit-box-flex: 1;\n    -webkit-flex-grow: 1;\n        -ms-flex-positive: 1;\n            flex-grow: 1;\n    max-width: 100%;\n  }\n  .col-xl-auto {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    width: auto;\n  }\n  .col-xl-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.333333%;\n        -ms-flex: 0 0 8.333333%;\n            flex: 0 0 8.333333%;\n    max-width: 8.333333%;\n  }\n  .col-xl-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.666667%;\n        -ms-flex: 0 0 16.666667%;\n            flex: 0 0 16.666667%;\n    max-width: 16.666667%;\n  }\n  .col-xl-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n        -ms-flex: 0 0 25%;\n            flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .col-xl-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.333333%;\n        -ms-flex: 0 0 33.333333%;\n            flex: 0 0 33.333333%;\n    max-width: 33.333333%;\n  }\n  .col-xl-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.666667%;\n        -ms-flex: 0 0 41.666667%;\n            flex: 0 0 41.666667%;\n    max-width: 41.666667%;\n  }\n  .col-xl-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n        -ms-flex: 0 0 50%;\n            flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .col-xl-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.333333%;\n        -ms-flex: 0 0 58.333333%;\n            flex: 0 0 58.333333%;\n    max-width: 58.333333%;\n  }\n  .col-xl-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.666667%;\n        -ms-flex: 0 0 66.666667%;\n            flex: 0 0 66.666667%;\n    max-width: 66.666667%;\n  }\n  .col-xl-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n        -ms-flex: 0 0 75%;\n            flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .col-xl-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.333333%;\n        -ms-flex: 0 0 83.333333%;\n            flex: 0 0 83.333333%;\n    max-width: 83.333333%;\n  }\n  .col-xl-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.666667%;\n        -ms-flex: 0 0 91.666667%;\n            flex: 0 0 91.666667%;\n    max-width: 91.666667%;\n  }\n  .col-xl-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n        -ms-flex: 0 0 100%;\n            flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .pull-xl-0 {\n    right: auto;\n  }\n  .pull-xl-1 {\n    right: 8.333333%;\n  }\n  .pull-xl-2 {\n    right: 16.666667%;\n  }\n  .pull-xl-3 {\n    right: 25%;\n  }\n  .pull-xl-4 {\n    right: 33.333333%;\n  }\n  .pull-xl-5 {\n    right: 41.666667%;\n  }\n  .pull-xl-6 {\n    right: 50%;\n  }\n  .pull-xl-7 {\n    right: 58.333333%;\n  }\n  .pull-xl-8 {\n    right: 66.666667%;\n  }\n  .pull-xl-9 {\n    right: 75%;\n  }\n  .pull-xl-10 {\n    right: 83.333333%;\n  }\n  .pull-xl-11 {\n    right: 91.666667%;\n  }\n  .pull-xl-12 {\n    right: 100%;\n  }\n  .push-xl-0 {\n    left: auto;\n  }\n  .push-xl-1 {\n    left: 8.333333%;\n  }\n  .push-xl-2 {\n    left: 16.666667%;\n  }\n  .push-xl-3 {\n    left: 25%;\n  }\n  .push-xl-4 {\n    left: 33.333333%;\n  }\n  .push-xl-5 {\n    left: 41.666667%;\n  }\n  .push-xl-6 {\n    left: 50%;\n  }\n  .push-xl-7 {\n    left: 58.333333%;\n  }\n  .push-xl-8 {\n    left: 66.666667%;\n  }\n  .push-xl-9 {\n    left: 75%;\n  }\n  .push-xl-10 {\n    left: 83.333333%;\n  }\n  .push-xl-11 {\n    left: 91.666667%;\n  }\n  .push-xl-12 {\n    left: 100%;\n  }\n  .offset-xl-0 {\n    margin-left: 0%;\n  }\n  .offset-xl-1 {\n    margin-left: 8.333333%;\n  }\n  .offset-xl-2 {\n    margin-left: 16.666667%;\n  }\n  .offset-xl-3 {\n    margin-left: 25%;\n  }\n  .offset-xl-4 {\n    margin-left: 33.333333%;\n  }\n  .offset-xl-5 {\n    margin-left: 41.666667%;\n  }\n  .offset-xl-6 {\n    margin-left: 50%;\n  }\n  .offset-xl-7 {\n    margin-left: 58.333333%;\n  }\n  .offset-xl-8 {\n    margin-left: 66.666667%;\n  }\n  .offset-xl-9 {\n    margin-left: 75%;\n  }\n  .offset-xl-10 {\n    margin-left: 83.333333%;\n  }\n  .offset-xl-11 {\n    margin-left: 91.666667%;\n  }\n}\n\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: 1rem;\n}\n\n.table th,\n.table td {\n  padding: 0.75rem;\n  vertical-align: top;\n  border-top: 1px solid #eceeef;\n}\n\n.table thead th {\n  vertical-align: bottom;\n  border-bottom: 2px solid #eceeef;\n}\n\n.table tbody + tbody {\n  border-top: 2px solid #eceeef;\n}\n\n.table .table {\n  background-color: #fff;\n}\n\n.table-sm th,\n.table-sm td {\n  padding: 0.3rem;\n}\n\n.table-bordered {\n  border: 1px solid #eceeef;\n}\n\n.table-bordered th,\n.table-bordered td {\n  border: 1px solid #eceeef;\n}\n\n.table-bordered thead th,\n.table-bordered thead td {\n  border-bottom-width: 2px;\n}\n\n.table-striped tbody tr:nth-of-type(odd) {\n  background-color: rgba(0, 0, 0, 0.05);\n}\n\n.table-hover tbody tr:hover {\n  background-color: rgba(0, 0, 0, 0.075);\n}\n\n.table-active,\n.table-active > th,\n.table-active > td {\n  background-color: rgba(0, 0, 0, 0.075);\n}\n\n.table-hover .table-active:hover {\n  background-color: rgba(0, 0, 0, 0.075);\n}\n\n.table-hover .table-active:hover > td,\n.table-hover .table-active:hover > th {\n  background-color: rgba(0, 0, 0, 0.075);\n}\n\n.table-success,\n.table-success > th,\n.table-success > td {\n  background-color: #dff0d8;\n}\n\n.table-hover .table-success:hover {\n  background-color: #d0e9c6;\n}\n\n.table-hover .table-success:hover > td,\n.table-hover .table-success:hover > th {\n  background-color: #d0e9c6;\n}\n\n.table-info,\n.table-info > th,\n.table-info > td {\n  background-color: #d9edf7;\n}\n\n.table-hover .table-info:hover {\n  background-color: #c4e3f3;\n}\n\n.table-hover .table-info:hover > td,\n.table-hover .table-info:hover > th {\n  background-color: #c4e3f3;\n}\n\n.table-warning,\n.table-warning > th,\n.table-warning > td {\n  background-color: #fcf8e3;\n}\n\n.table-hover .table-warning:hover {\n  background-color: #faf2cc;\n}\n\n.table-hover .table-warning:hover > td,\n.table-hover .table-warning:hover > th {\n  background-color: #faf2cc;\n}\n\n.table-danger,\n.table-danger > th,\n.table-danger > td {\n  background-color: #f2dede;\n}\n\n.table-hover .table-danger:hover {\n  background-color: #ebcccc;\n}\n\n.table-hover .table-danger:hover > td,\n.table-hover .table-danger:hover > th {\n  background-color: #ebcccc;\n}\n\n.thead-inverse th {\n  color: #fff;\n  background-color: #292b2c;\n}\n\n.thead-default th {\n  color: #464a4c;\n  background-color: #eceeef;\n}\n\n.table-inverse {\n  color: #fff;\n  background-color: #292b2c;\n}\n\n.table-inverse th,\n.table-inverse td,\n.table-inverse thead th {\n  border-color: #fff;\n}\n\n.table-inverse.table-bordered {\n  border: 0;\n}\n\n.table-responsive {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n  -ms-overflow-style: -ms-autohiding-scrollbar;\n}\n\n.table-responsive.table-bordered {\n  border: 0;\n}\n\n.form-control {\n  display: block;\n  width: 100%;\n  padding: 0.5rem 0.75rem;\n  font-size: 1rem;\n  line-height: 1.25;\n  color: #464a4c;\n  background-color: #fff;\n  background-image: none;\n  -webkit-background-clip: padding-box;\n          background-clip: padding-box;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0.25rem;\n  -webkit-transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;\n  transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;\n  -o-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;\n  transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;\n  transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;\n}\n\n.form-control::-ms-expand {\n  background-color: transparent;\n  border: 0;\n}\n\n.form-control:focus {\n  color: #464a4c;\n  background-color: #fff;\n  border-color: #5cb3fd;\n  outline: none;\n}\n\n.form-control::-webkit-input-placeholder {\n  color: #636c72;\n  opacity: 1;\n}\n\n.form-control::-moz-placeholder {\n  color: #636c72;\n  opacity: 1;\n}\n\n.form-control:-ms-input-placeholder {\n  color: #636c72;\n  opacity: 1;\n}\n\n.form-control::placeholder {\n  color: #636c72;\n  opacity: 1;\n}\n\n.form-control:disabled, .form-control[readonly] {\n  background-color: #eceeef;\n  opacity: 1;\n}\n\n.form-control:disabled {\n  cursor: not-allowed;\n}\n\nselect.form-control:not([size]):not([multiple]) {\n  height: calc(2.25rem + 2px);\n}\n\nselect.form-control:focus::-ms-value {\n  color: #464a4c;\n  background-color: #fff;\n}\n\n.form-control-file,\n.form-control-range {\n  display: block;\n}\n\n.col-form-label {\n  padding-top: calc(0.5rem - 1px * 2);\n  padding-bottom: calc(0.5rem - 1px * 2);\n  margin-bottom: 0;\n}\n\n.col-form-label-lg {\n  padding-top: calc(0.75rem - 1px * 2);\n  padding-bottom: calc(0.75rem - 1px * 2);\n  font-size: 1.25rem;\n}\n\n.col-form-label-sm {\n  padding-top: calc(0.25rem - 1px * 2);\n  padding-bottom: calc(0.25rem - 1px * 2);\n  font-size: 0.875rem;\n}\n\n.col-form-legend {\n  padding-top: 0.5rem;\n  padding-bottom: 0.5rem;\n  margin-bottom: 0;\n  font-size: 1rem;\n}\n\n.form-control-static {\n  padding-top: 0.5rem;\n  padding-bottom: 0.5rem;\n  margin-bottom: 0;\n  line-height: 1.25;\n  border: solid transparent;\n  border-width: 1px 0;\n}\n\n.form-control-static.form-control-sm, .input-group-sm > .form-control-static.form-control,\n.input-group-sm > .form-control-static.input-group-addon,\n.input-group-sm > .input-group-btn > .form-control-static.btn, .form-control-static.form-control-lg, .input-group-lg > .form-control-static.form-control,\n.input-group-lg > .form-control-static.input-group-addon,\n.input-group-lg > .input-group-btn > .form-control-static.btn {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.form-control-sm, .input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  padding: 0.25rem 0.5rem;\n  font-size: 0.875rem;\n  border-radius: 0.2rem;\n}\n\nselect.form-control-sm:not([size]):not([multiple]), .input-group-sm > select.form-control:not([size]):not([multiple]),\n.input-group-sm > select.input-group-addon:not([size]):not([multiple]),\n.input-group-sm > .input-group-btn > select.btn:not([size]):not([multiple]) {\n  height: 1.8125rem;\n}\n\n.form-control-lg, .input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  padding: 0.75rem 1.5rem;\n  font-size: 1.25rem;\n  border-radius: 0.3rem;\n}\n\nselect.form-control-lg:not([size]):not([multiple]), .input-group-lg > select.form-control:not([size]):not([multiple]),\n.input-group-lg > select.input-group-addon:not([size]):not([multiple]),\n.input-group-lg > .input-group-btn > select.btn:not([size]):not([multiple]) {\n  height: 3.166667rem;\n}\n\n.form-group {\n  margin-bottom: 1rem;\n}\n\n.form-text {\n  display: block;\n  margin-top: 0.25rem;\n}\n\n.form-check {\n  position: relative;\n  display: block;\n  margin-bottom: 0.5rem;\n}\n\n.form-check.disabled .form-check-label {\n  color: #636c72;\n  cursor: not-allowed;\n}\n\n.form-check-label {\n  padding-left: 1.25rem;\n  margin-bottom: 0;\n  cursor: pointer;\n}\n\n.form-check-input {\n  position: absolute;\n  margin-top: 0.25rem;\n  margin-left: -1.25rem;\n}\n\n.form-check-input:only-child {\n  position: static;\n}\n\n.form-check-inline {\n  display: inline-block;\n}\n\n.form-check-inline .form-check-label {\n  vertical-align: middle;\n}\n\n.form-check-inline + .form-check-inline {\n  margin-left: 0.75rem;\n}\n\n.form-control-feedback {\n  margin-top: 0.25rem;\n}\n\n.form-control-success,\n.form-control-warning,\n.form-control-danger {\n  padding-right: 2.25rem;\n  background-repeat: no-repeat;\n  background-position: center right 0.5625rem;\n  -webkit-background-size: 1.125rem 1.125rem;\n          background-size: 1.125rem 1.125rem;\n}\n\n.has-success .form-control-feedback,\n.has-success .form-control-label,\n.has-success .col-form-label,\n.has-success .form-check-label,\n.has-success .custom-control {\n  color: #5cb85c;\n}\n\n.has-success .form-control {\n  border-color: #5cb85c;\n}\n\n.has-success .input-group-addon {\n  color: #5cb85c;\n  border-color: #5cb85c;\n  background-color: #eaf6ea;\n}\n\n.has-success .form-control-success {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%235cb85c' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3E%3C/svg%3E\");\n}\n\n.has-warning .form-control-feedback,\n.has-warning .form-control-label,\n.has-warning .col-form-label,\n.has-warning .form-check-label,\n.has-warning .custom-control {\n  color: #f0ad4e;\n}\n\n.has-warning .form-control {\n  border-color: #f0ad4e;\n}\n\n.has-warning .input-group-addon {\n  color: #f0ad4e;\n  border-color: #f0ad4e;\n  background-color: white;\n}\n\n.has-warning .form-control-warning {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23f0ad4e' d='M4.4 5.324h-.8v-2.46h.8zm0 1.42h-.8V5.89h.8zM3.76.63L.04 7.075c-.115.2.016.425.26.426h7.397c.242 0 .372-.226.258-.426C6.726 4.924 5.47 2.79 4.253.63c-.113-.174-.39-.174-.494 0z'/%3E%3C/svg%3E\");\n}\n\n.has-danger .form-control-feedback,\n.has-danger .form-control-label,\n.has-danger .col-form-label,\n.has-danger .form-check-label,\n.has-danger .custom-control {\n  color: #d9534f;\n}\n\n.has-danger .form-control {\n  border-color: #d9534f;\n}\n\n.has-danger .input-group-addon {\n  color: #d9534f;\n  border-color: #d9534f;\n  background-color: #fdf7f7;\n}\n\n.has-danger .form-control-danger {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23d9534f' viewBox='-2 -2 7 7'%3E%3Cpath stroke='%23d9534f' d='M0 0l3 3m0-3L0 3'/%3E%3Ccircle r='.5'/%3E%3Ccircle cx='3' r='.5'/%3E%3Ccircle cy='3' r='.5'/%3E%3Ccircle cx='3' cy='3' r='.5'/%3E%3C/svg%3E\");\n}\n\n.form-inline {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-flex-flow: row wrap;\n      -ms-flex-flow: row wrap;\n          flex-flow: row wrap;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n}\n\n.form-inline .form-check {\n  width: 100%;\n}\n\n@media (min-width: 576px) {\n  .form-inline label {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n    -webkit-box-pack: center;\n    -webkit-justify-content: center;\n        -ms-flex-pack: center;\n            justify-content: center;\n    margin-bottom: 0;\n  }\n  .form-inline .form-group {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 auto;\n        -ms-flex: 0 0 auto;\n            flex: 0 0 auto;\n    -webkit-flex-flow: row wrap;\n        -ms-flex-flow: row wrap;\n            flex-flow: row wrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n    margin-bottom: 0;\n  }\n  .form-inline .form-control {\n    display: inline-block;\n    width: auto;\n    vertical-align: middle;\n  }\n  .form-inline .form-control-static {\n    display: inline-block;\n  }\n  .form-inline .input-group {\n    width: auto;\n  }\n  .form-inline .form-control-label {\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .form-check {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n    -webkit-box-pack: center;\n    -webkit-justify-content: center;\n        -ms-flex-pack: center;\n            justify-content: center;\n    width: auto;\n    margin-top: 0;\n    margin-bottom: 0;\n  }\n  .form-inline .form-check-label {\n    padding-left: 0;\n  }\n  .form-inline .form-check-input {\n    position: relative;\n    margin-top: 0;\n    margin-right: 0.25rem;\n    margin-left: 0;\n  }\n  .form-inline .custom-control {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n    -webkit-box-pack: center;\n    -webkit-justify-content: center;\n        -ms-flex-pack: center;\n            justify-content: center;\n    padding-left: 0;\n  }\n  .form-inline .custom-control-indicator {\n    position: static;\n    display: inline-block;\n    margin-right: 0.25rem;\n    vertical-align: text-bottom;\n  }\n  .form-inline .has-feedback .form-control-feedback {\n    top: 0;\n  }\n}\n\n.btn {\n  display: inline-block;\n  font-weight: normal;\n  line-height: 1.25;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: middle;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n  border: 1px solid transparent;\n  padding: 0.5rem 1rem;\n  font-size: 1rem;\n  border-radius: 0.25rem;\n  -webkit-transition: all 0.2s ease-in-out;\n  -o-transition: all 0.2s ease-in-out;\n  transition: all 0.2s ease-in-out;\n}\n\n.btn:focus, .btn:hover {\n  text-decoration: none;\n}\n\n.btn:focus, .btn.focus {\n  outline: 0;\n  -webkit-box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.25);\n          box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.25);\n}\n\n.btn.disabled, .btn:disabled {\n  cursor: not-allowed;\n  opacity: .65;\n}\n\n.btn:active, .btn.active {\n  background-image: none;\n}\n\na.btn.disabled,\nfieldset[disabled] a.btn {\n  pointer-events: none;\n}\n\n.btn-primary {\n  color: #fff;\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.btn-primary:hover {\n  color: #fff;\n  background-color: #025aa5;\n  border-color: #01549b;\n}\n\n.btn-primary:focus, .btn-primary.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.5);\n          box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.5);\n}\n\n.btn-primary.disabled, .btn-primary:disabled {\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.btn-primary:active, .btn-primary.active,\n.show > .btn-primary.dropdown-toggle {\n  color: #fff;\n  background-color: #025aa5;\n  background-image: none;\n  border-color: #01549b;\n}\n\n.btn-secondary {\n  color: #292b2c;\n  background-color: #fff;\n  border-color: #ccc;\n}\n\n.btn-secondary:hover {\n  color: #292b2c;\n  background-color: #e6e6e6;\n  border-color: #adadad;\n}\n\n.btn-secondary:focus, .btn-secondary.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(204, 204, 204, 0.5);\n          box-shadow: 0 0 0 2px rgba(204, 204, 204, 0.5);\n}\n\n.btn-secondary.disabled, .btn-secondary:disabled {\n  background-color: #fff;\n  border-color: #ccc;\n}\n\n.btn-secondary:active, .btn-secondary.active,\n.show > .btn-secondary.dropdown-toggle {\n  color: #292b2c;\n  background-color: #e6e6e6;\n  background-image: none;\n  border-color: #adadad;\n}\n\n.btn-info {\n  color: #fff;\n  background-color: #5bc0de;\n  border-color: #5bc0de;\n}\n\n.btn-info:hover {\n  color: #fff;\n  background-color: #31b0d5;\n  border-color: #2aabd2;\n}\n\n.btn-info:focus, .btn-info.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(91, 192, 222, 0.5);\n          box-shadow: 0 0 0 2px rgba(91, 192, 222, 0.5);\n}\n\n.btn-info.disabled, .btn-info:disabled {\n  background-color: #5bc0de;\n  border-color: #5bc0de;\n}\n\n.btn-info:active, .btn-info.active,\n.show > .btn-info.dropdown-toggle {\n  color: #fff;\n  background-color: #31b0d5;\n  background-image: none;\n  border-color: #2aabd2;\n}\n\n.btn-success {\n  color: #fff;\n  background-color: #5cb85c;\n  border-color: #5cb85c;\n}\n\n.btn-success:hover {\n  color: #fff;\n  background-color: #449d44;\n  border-color: #419641;\n}\n\n.btn-success:focus, .btn-success.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(92, 184, 92, 0.5);\n          box-shadow: 0 0 0 2px rgba(92, 184, 92, 0.5);\n}\n\n.btn-success.disabled, .btn-success:disabled {\n  background-color: #5cb85c;\n  border-color: #5cb85c;\n}\n\n.btn-success:active, .btn-success.active,\n.show > .btn-success.dropdown-toggle {\n  color: #fff;\n  background-color: #449d44;\n  background-image: none;\n  border-color: #419641;\n}\n\n.btn-warning {\n  color: #fff;\n  background-color: #f0ad4e;\n  border-color: #f0ad4e;\n}\n\n.btn-warning:hover {\n  color: #fff;\n  background-color: #ec971f;\n  border-color: #eb9316;\n}\n\n.btn-warning:focus, .btn-warning.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(240, 173, 78, 0.5);\n          box-shadow: 0 0 0 2px rgba(240, 173, 78, 0.5);\n}\n\n.btn-warning.disabled, .btn-warning:disabled {\n  background-color: #f0ad4e;\n  border-color: #f0ad4e;\n}\n\n.btn-warning:active, .btn-warning.active,\n.show > .btn-warning.dropdown-toggle {\n  color: #fff;\n  background-color: #ec971f;\n  background-image: none;\n  border-color: #eb9316;\n}\n\n.btn-danger {\n  color: #fff;\n  background-color: #d9534f;\n  border-color: #d9534f;\n}\n\n.btn-danger:hover {\n  color: #fff;\n  background-color: #c9302c;\n  border-color: #c12e2a;\n}\n\n.btn-danger:focus, .btn-danger.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(217, 83, 79, 0.5);\n          box-shadow: 0 0 0 2px rgba(217, 83, 79, 0.5);\n}\n\n.btn-danger.disabled, .btn-danger:disabled {\n  background-color: #d9534f;\n  border-color: #d9534f;\n}\n\n.btn-danger:active, .btn-danger.active,\n.show > .btn-danger.dropdown-toggle {\n  color: #fff;\n  background-color: #c9302c;\n  background-image: none;\n  border-color: #c12e2a;\n}\n\n.btn-outline-primary {\n  color: #0275d8;\n  background-image: none;\n  background-color: transparent;\n  border-color: #0275d8;\n}\n\n.btn-outline-primary:hover {\n  color: #fff;\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.btn-outline-primary:focus, .btn-outline-primary.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.5);\n          box-shadow: 0 0 0 2px rgba(2, 117, 216, 0.5);\n}\n\n.btn-outline-primary.disabled, .btn-outline-primary:disabled {\n  color: #0275d8;\n  background-color: transparent;\n}\n\n.btn-outline-primary:active, .btn-outline-primary.active,\n.show > .btn-outline-primary.dropdown-toggle {\n  color: #fff;\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.btn-outline-secondary {\n  color: #ccc;\n  background-image: none;\n  background-color: transparent;\n  border-color: #ccc;\n}\n\n.btn-outline-secondary:hover {\n  color: #fff;\n  background-color: #ccc;\n  border-color: #ccc;\n}\n\n.btn-outline-secondary:focus, .btn-outline-secondary.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(204, 204, 204, 0.5);\n          box-shadow: 0 0 0 2px rgba(204, 204, 204, 0.5);\n}\n\n.btn-outline-secondary.disabled, .btn-outline-secondary:disabled {\n  color: #ccc;\n  background-color: transparent;\n}\n\n.btn-outline-secondary:active, .btn-outline-secondary.active,\n.show > .btn-outline-secondary.dropdown-toggle {\n  color: #fff;\n  background-color: #ccc;\n  border-color: #ccc;\n}\n\n.btn-outline-info {\n  color: #5bc0de;\n  background-image: none;\n  background-color: transparent;\n  border-color: #5bc0de;\n}\n\n.btn-outline-info:hover {\n  color: #fff;\n  background-color: #5bc0de;\n  border-color: #5bc0de;\n}\n\n.btn-outline-info:focus, .btn-outline-info.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(91, 192, 222, 0.5);\n          box-shadow: 0 0 0 2px rgba(91, 192, 222, 0.5);\n}\n\n.btn-outline-info.disabled, .btn-outline-info:disabled {\n  color: #5bc0de;\n  background-color: transparent;\n}\n\n.btn-outline-info:active, .btn-outline-info.active,\n.show > .btn-outline-info.dropdown-toggle {\n  color: #fff;\n  background-color: #5bc0de;\n  border-color: #5bc0de;\n}\n\n.btn-outline-success {\n  color: #5cb85c;\n  background-image: none;\n  background-color: transparent;\n  border-color: #5cb85c;\n}\n\n.btn-outline-success:hover {\n  color: #fff;\n  background-color: #5cb85c;\n  border-color: #5cb85c;\n}\n\n.btn-outline-success:focus, .btn-outline-success.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(92, 184, 92, 0.5);\n          box-shadow: 0 0 0 2px rgba(92, 184, 92, 0.5);\n}\n\n.btn-outline-success.disabled, .btn-outline-success:disabled {\n  color: #5cb85c;\n  background-color: transparent;\n}\n\n.btn-outline-success:active, .btn-outline-success.active,\n.show > .btn-outline-success.dropdown-toggle {\n  color: #fff;\n  background-color: #5cb85c;\n  border-color: #5cb85c;\n}\n\n.btn-outline-warning {\n  color: #f0ad4e;\n  background-image: none;\n  background-color: transparent;\n  border-color: #f0ad4e;\n}\n\n.btn-outline-warning:hover {\n  color: #fff;\n  background-color: #f0ad4e;\n  border-color: #f0ad4e;\n}\n\n.btn-outline-warning:focus, .btn-outline-warning.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(240, 173, 78, 0.5);\n          box-shadow: 0 0 0 2px rgba(240, 173, 78, 0.5);\n}\n\n.btn-outline-warning.disabled, .btn-outline-warning:disabled {\n  color: #f0ad4e;\n  background-color: transparent;\n}\n\n.btn-outline-warning:active, .btn-outline-warning.active,\n.show > .btn-outline-warning.dropdown-toggle {\n  color: #fff;\n  background-color: #f0ad4e;\n  border-color: #f0ad4e;\n}\n\n.btn-outline-danger {\n  color: #d9534f;\n  background-image: none;\n  background-color: transparent;\n  border-color: #d9534f;\n}\n\n.btn-outline-danger:hover {\n  color: #fff;\n  background-color: #d9534f;\n  border-color: #d9534f;\n}\n\n.btn-outline-danger:focus, .btn-outline-danger.focus {\n  -webkit-box-shadow: 0 0 0 2px rgba(217, 83, 79, 0.5);\n          box-shadow: 0 0 0 2px rgba(217, 83, 79, 0.5);\n}\n\n.btn-outline-danger.disabled, .btn-outline-danger:disabled {\n  color: #d9534f;\n  background-color: transparent;\n}\n\n.btn-outline-danger:active, .btn-outline-danger.active,\n.show > .btn-outline-danger.dropdown-toggle {\n  color: #fff;\n  background-color: #d9534f;\n  border-color: #d9534f;\n}\n\n.btn-link {\n  font-weight: normal;\n  color: #0275d8;\n  border-radius: 0;\n}\n\n.btn-link, .btn-link:active, .btn-link.active, .btn-link:disabled {\n  background-color: transparent;\n}\n\n.btn-link, .btn-link:focus, .btn-link:active {\n  border-color: transparent;\n}\n\n.btn-link:hover {\n  border-color: transparent;\n}\n\n.btn-link:focus, .btn-link:hover {\n  color: #014c8c;\n  text-decoration: underline;\n  background-color: transparent;\n}\n\n.btn-link:disabled {\n  color: #636c72;\n}\n\n.btn-link:disabled:focus, .btn-link:disabled:hover {\n  text-decoration: none;\n}\n\n.btn-lg, .btn-group-lg > .btn {\n  padding: 0.75rem 1.5rem;\n  font-size: 1.25rem;\n  border-radius: 0.3rem;\n}\n\n.btn-sm, .btn-group-sm > .btn {\n  padding: 0.25rem 0.5rem;\n  font-size: 0.875rem;\n  border-radius: 0.2rem;\n}\n\n.btn-block {\n  display: block;\n  width: 100%;\n}\n\n.btn-block + .btn-block {\n  margin-top: 0.5rem;\n}\n\ninput[type=\"submit\"].btn-block,\ninput[type=\"reset\"].btn-block,\ninput[type=\"button\"].btn-block {\n  width: 100%;\n}\n\n.fade {\n  opacity: 0;\n  -webkit-transition: opacity 0.15s linear;\n  -o-transition: opacity 0.15s linear;\n  transition: opacity 0.15s linear;\n}\n\n.fade.show {\n  opacity: 1;\n}\n\n.collapse {\n  display: none;\n}\n\n.collapse.show {\n  display: block;\n}\n\ntr.collapse.show {\n  display: table-row;\n}\n\ntbody.collapse.show {\n  display: table-row-group;\n}\n\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  -webkit-transition: height 0.35s ease;\n  -o-transition: height 0.35s ease;\n  transition: height 0.35s ease;\n}\n\n.dropup,\n.dropdown {\n  position: relative;\n}\n\n.dropdown-toggle::after {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 0.3em;\n  vertical-align: middle;\n  content: \"\";\n  border-top: 0.3em solid;\n  border-right: 0.3em solid transparent;\n  border-left: 0.3em solid transparent;\n}\n\n.dropdown-toggle:focus {\n  outline: 0;\n}\n\n.dropup .dropdown-toggle::after {\n  border-top: 0;\n  border-bottom: 0.3em solid;\n}\n\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: 1000;\n  display: none;\n  float: left;\n  min-width: 10rem;\n  padding: 0.5rem 0;\n  margin: 0.125rem 0 0;\n  font-size: 1rem;\n  color: #292b2c;\n  text-align: left;\n  list-style: none;\n  background-color: #fff;\n  -webkit-background-clip: padding-box;\n          background-clip: padding-box;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0.25rem;\n}\n\n.dropdown-divider {\n  height: 1px;\n  margin: 0.5rem 0;\n  overflow: hidden;\n  background-color: #eceeef;\n}\n\n.dropdown-item {\n  display: block;\n  width: 100%;\n  padding: 3px 1.5rem;\n  clear: both;\n  font-weight: normal;\n  color: #292b2c;\n  text-align: inherit;\n  white-space: nowrap;\n  background: none;\n  border: 0;\n}\n\n.dropdown-item:focus, .dropdown-item:hover {\n  color: #1d1e1f;\n  text-decoration: none;\n  background-color: #f7f7f9;\n}\n\n.dropdown-item.active, .dropdown-item:active {\n  color: #fff;\n  text-decoration: none;\n  background-color: #0275d8;\n}\n\n.dropdown-item.disabled, .dropdown-item:disabled {\n  color: #636c72;\n  cursor: not-allowed;\n  background-color: transparent;\n}\n\n.show > .dropdown-menu {\n  display: block;\n}\n\n.show > a {\n  outline: 0;\n}\n\n.dropdown-menu-right {\n  right: 0;\n  left: auto;\n}\n\n.dropdown-menu-left {\n  right: auto;\n  left: 0;\n}\n\n.dropdown-header {\n  display: block;\n  padding: 0.5rem 1.5rem;\n  margin-bottom: 0;\n  font-size: 0.875rem;\n  color: #636c72;\n  white-space: nowrap;\n}\n\n.dropdown-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 990;\n}\n\n.dropup .dropdown-menu {\n  top: auto;\n  bottom: 100%;\n  margin-bottom: 0.125rem;\n}\n\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: -webkit-inline-box;\n  display: -webkit-inline-flex;\n  display: -ms-inline-flexbox;\n  display: inline-flex;\n  vertical-align: middle;\n}\n\n.btn-group > .btn,\n.btn-group-vertical > .btn {\n  position: relative;\n  -webkit-box-flex: 0;\n  -webkit-flex: 0 1 auto;\n      -ms-flex: 0 1 auto;\n          flex: 0 1 auto;\n}\n\n.btn-group > .btn:hover,\n.btn-group-vertical > .btn:hover {\n  z-index: 2;\n}\n\n.btn-group > .btn:focus, .btn-group > .btn:active, .btn-group > .btn.active,\n.btn-group-vertical > .btn:focus,\n.btn-group-vertical > .btn:active,\n.btn-group-vertical > .btn.active {\n  z-index: 2;\n}\n\n.btn-group .btn + .btn,\n.btn-group .btn + .btn-group,\n.btn-group .btn-group + .btn,\n.btn-group .btn-group + .btn-group,\n.btn-group-vertical .btn + .btn,\n.btn-group-vertical .btn + .btn-group,\n.btn-group-vertical .btn-group + .btn,\n.btn-group-vertical .btn-group + .btn-group {\n  margin-left: -1px;\n}\n\n.btn-toolbar {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-pack: start;\n  -webkit-justify-content: flex-start;\n      -ms-flex-pack: start;\n          justify-content: flex-start;\n}\n\n.btn-toolbar .input-group {\n  width: auto;\n}\n\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n\n.btn-group > .btn:first-child {\n  margin-left: 0;\n}\n\n.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n\n.btn-group > .btn-group {\n  float: left;\n}\n\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n\n.btn-group > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n\n.btn + .dropdown-toggle-split {\n  padding-right: 0.75rem;\n  padding-left: 0.75rem;\n}\n\n.btn + .dropdown-toggle-split::after {\n  margin-left: 0;\n}\n\n.btn-sm + .dropdown-toggle-split, .btn-group-sm > .btn + .dropdown-toggle-split {\n  padding-right: 0.375rem;\n  padding-left: 0.375rem;\n}\n\n.btn-lg + .dropdown-toggle-split, .btn-group-lg > .btn + .dropdown-toggle-split {\n  padding-right: 1.125rem;\n  padding-left: 1.125rem;\n}\n\n.btn-group-vertical {\n  display: -webkit-inline-box;\n  display: -webkit-inline-flex;\n  display: -ms-inline-flexbox;\n  display: inline-flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -webkit-box-align: start;\n  -webkit-align-items: flex-start;\n      -ms-flex-align: start;\n          align-items: flex-start;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n      -ms-flex-pack: center;\n          justify-content: center;\n}\n\n.btn-group-vertical .btn,\n.btn-group-vertical .btn-group {\n  width: 100%;\n}\n\n.btn-group-vertical > .btn + .btn,\n.btn-group-vertical > .btn + .btn-group,\n.btn-group-vertical > .btn-group + .btn,\n.btn-group-vertical > .btn-group + .btn-group {\n  margin-top: -1px;\n  margin-left: 0;\n}\n\n.btn-group-vertical > .btn:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n\n.btn-group-vertical > .btn:first-child:not(:last-child) {\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n\n.btn-group-vertical > .btn:last-child:not(:first-child) {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n\n[data-toggle=\"buttons\"] > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn input[type=\"checkbox\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"checkbox\"] {\n  position: absolute;\n  clip: rect(0, 0, 0, 0);\n  pointer-events: none;\n}\n\n.input-group {\n  position: relative;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  width: 100%;\n}\n\n.input-group .form-control {\n  position: relative;\n  z-index: 2;\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 auto;\n      -ms-flex: 1 1 auto;\n          flex: 1 1 auto;\n  width: 1%;\n  margin-bottom: 0;\n}\n\n.input-group .form-control:focus, .input-group .form-control:active, .input-group .form-control:hover {\n  z-index: 3;\n}\n\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n      -ms-flex-pack: center;\n          justify-content: center;\n}\n\n.input-group-addon:not(:first-child):not(:last-child),\n.input-group-btn:not(:first-child):not(:last-child),\n.input-group .form-control:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n\n.input-group-addon,\n.input-group-btn {\n  white-space: nowrap;\n  vertical-align: middle;\n}\n\n.input-group-addon {\n  padding: 0.5rem 0.75rem;\n  margin-bottom: 0;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.25;\n  color: #464a4c;\n  text-align: center;\n  background-color: #eceeef;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0.25rem;\n}\n\n.input-group-addon.form-control-sm,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .input-group-addon.btn {\n  padding: 0.25rem 0.5rem;\n  font-size: 0.875rem;\n  border-radius: 0.2rem;\n}\n\n.input-group-addon.form-control-lg,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .input-group-addon.btn {\n  padding: 0.75rem 1.5rem;\n  font-size: 1.25rem;\n  border-radius: 0.3rem;\n}\n\n.input-group-addon input[type=\"radio\"],\n.input-group-addon input[type=\"checkbox\"] {\n  margin-top: 0;\n}\n\n.input-group .form-control:not(:last-child),\n.input-group-addon:not(:last-child),\n.input-group-btn:not(:last-child) > .btn,\n.input-group-btn:not(:last-child) > .btn-group > .btn,\n.input-group-btn:not(:last-child) > .dropdown-toggle,\n.input-group-btn:not(:first-child) > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:not(:first-child) > .btn-group:not(:last-child) > .btn {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n\n.input-group-addon:not(:last-child) {\n  border-right: 0;\n}\n\n.input-group .form-control:not(:first-child),\n.input-group-addon:not(:first-child),\n.input-group-btn:not(:first-child) > .btn,\n.input-group-btn:not(:first-child) > .btn-group > .btn,\n.input-group-btn:not(:first-child) > .dropdown-toggle,\n.input-group-btn:not(:last-child) > .btn:not(:first-child),\n.input-group-btn:not(:last-child) > .btn-group:not(:first-child) > .btn {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n\n.form-control + .input-group-addon:not(:first-child) {\n  border-left: 0;\n}\n\n.input-group-btn {\n  position: relative;\n  font-size: 0;\n  white-space: nowrap;\n}\n\n.input-group-btn > .btn {\n  position: relative;\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 0%;\n      -ms-flex: 1 1 0%;\n          flex: 1 1 0%;\n}\n\n.input-group-btn > .btn + .btn {\n  margin-left: -1px;\n}\n\n.input-group-btn > .btn:focus, .input-group-btn > .btn:active, .input-group-btn > .btn:hover {\n  z-index: 3;\n}\n\n.input-group-btn:not(:last-child) > .btn,\n.input-group-btn:not(:last-child) > .btn-group {\n  margin-right: -1px;\n}\n\n.input-group-btn:not(:first-child) > .btn,\n.input-group-btn:not(:first-child) > .btn-group {\n  z-index: 2;\n  margin-left: -1px;\n}\n\n.input-group-btn:not(:first-child) > .btn:focus, .input-group-btn:not(:first-child) > .btn:active, .input-group-btn:not(:first-child) > .btn:hover,\n.input-group-btn:not(:first-child) > .btn-group:focus,\n.input-group-btn:not(:first-child) > .btn-group:active,\n.input-group-btn:not(:first-child) > .btn-group:hover {\n  z-index: 3;\n}\n\n.custom-control {\n  position: relative;\n  display: -webkit-inline-box;\n  display: -webkit-inline-flex;\n  display: -ms-inline-flexbox;\n  display: inline-flex;\n  min-height: 1.5rem;\n  padding-left: 1.5rem;\n  margin-right: 1rem;\n  cursor: pointer;\n}\n\n.custom-control-input {\n  position: absolute;\n  z-index: -1;\n  opacity: 0;\n}\n\n.custom-control-input:checked ~ .custom-control-indicator {\n  color: #fff;\n  background-color: #0275d8;\n}\n\n.custom-control-input:focus ~ .custom-control-indicator {\n  -webkit-box-shadow: 0 0 0 1px #fff, 0 0 0 3px #0275d8;\n          box-shadow: 0 0 0 1px #fff, 0 0 0 3px #0275d8;\n}\n\n.custom-control-input:active ~ .custom-control-indicator {\n  color: #fff;\n  background-color: #8fcafe;\n}\n\n.custom-control-input:disabled ~ .custom-control-indicator {\n  cursor: not-allowed;\n  background-color: #eceeef;\n}\n\n.custom-control-input:disabled ~ .custom-control-description {\n  color: #636c72;\n  cursor: not-allowed;\n}\n\n.custom-control-indicator {\n  position: absolute;\n  top: 0.25rem;\n  left: 0;\n  display: block;\n  width: 1rem;\n  height: 1rem;\n  pointer-events: none;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n  background-color: #ddd;\n  background-repeat: no-repeat;\n  background-position: center center;\n  -webkit-background-size: 50% 50%;\n          background-size: 50% 50%;\n}\n\n.custom-checkbox .custom-control-indicator {\n  border-radius: 0.25rem;\n}\n\n.custom-checkbox .custom-control-input:checked ~ .custom-control-indicator {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E\");\n}\n\n.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-indicator {\n  background-color: #0275d8;\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E\");\n}\n\n.custom-radio .custom-control-indicator {\n  border-radius: 50%;\n}\n\n.custom-radio .custom-control-input:checked ~ .custom-control-indicator {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E\");\n}\n\n.custom-controls-stacked {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n}\n\n.custom-controls-stacked .custom-control {\n  margin-bottom: 0.25rem;\n}\n\n.custom-controls-stacked .custom-control + .custom-control {\n  margin-left: 0;\n}\n\n.custom-select {\n  display: inline-block;\n  max-width: 100%;\n  height: calc(2.25rem + 2px);\n  padding: 0.375rem 1.75rem 0.375rem 0.75rem;\n  line-height: 1.25;\n  color: #464a4c;\n  vertical-align: middle;\n  background: #fff url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23333' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E\") no-repeat right 0.75rem center;\n  -webkit-background-size: 8px 10px;\n          background-size: 8px 10px;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0.25rem;\n  -moz-appearance: none;\n  -webkit-appearance: none;\n}\n\n.custom-select:focus {\n  border-color: #5cb3fd;\n  outline: none;\n}\n\n.custom-select:focus::-ms-value {\n  color: #464a4c;\n  background-color: #fff;\n}\n\n.custom-select:disabled {\n  color: #636c72;\n  cursor: not-allowed;\n  background-color: #eceeef;\n}\n\n.custom-select::-ms-expand {\n  opacity: 0;\n}\n\n.custom-select-sm {\n  padding-top: 0.375rem;\n  padding-bottom: 0.375rem;\n  font-size: 75%;\n}\n\n.custom-file {\n  position: relative;\n  display: inline-block;\n  max-width: 100%;\n  height: 2.5rem;\n  margin-bottom: 0;\n  cursor: pointer;\n}\n\n.custom-file-input {\n  min-width: 14rem;\n  max-width: 100%;\n  height: 2.5rem;\n  margin: 0;\n  filter: alpha(opacity=0);\n  opacity: 0;\n}\n\n.custom-file-control {\n  position: absolute;\n  top: 0;\n  right: 0;\n  left: 0;\n  z-index: 5;\n  height: 2.5rem;\n  padding: 0.5rem 1rem;\n  line-height: 1.5;\n  color: #464a4c;\n  pointer-events: none;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n  background-color: #fff;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0.25rem;\n}\n\n.custom-file-control:lang(en)::after {\n  content: \"Choose file...\";\n}\n\n.custom-file-control::before {\n  position: absolute;\n  top: -1px;\n  right: -1px;\n  bottom: -1px;\n  z-index: 6;\n  display: block;\n  height: 2.5rem;\n  padding: 0.5rem 1rem;\n  line-height: 1.5;\n  color: #464a4c;\n  background-color: #eceeef;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 0 0.25rem 0.25rem 0;\n}\n\n.custom-file-control:lang(en)::before {\n  content: \"Browse\";\n}\n\n.nav {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  padding-left: 0;\n  margin-bottom: 0;\n  list-style: none;\n}\n\n.nav-link {\n  display: block;\n  padding: 0.5em 1em;\n}\n\n.nav-link:focus, .nav-link:hover {\n  text-decoration: none;\n}\n\n.nav-link.disabled {\n  color: #636c72;\n  cursor: not-allowed;\n}\n\n.nav-tabs {\n  border-bottom: 1px solid #ddd;\n}\n\n.nav-tabs .nav-item {\n  margin-bottom: -1px;\n}\n\n.nav-tabs .nav-link {\n  border: 1px solid transparent;\n  border-top-right-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.nav-tabs .nav-link:focus, .nav-tabs .nav-link:hover {\n  border-color: #eceeef #eceeef #ddd;\n}\n\n.nav-tabs .nav-link.disabled {\n  color: #636c72;\n  background-color: transparent;\n  border-color: transparent;\n}\n\n.nav-tabs .nav-link.active,\n.nav-tabs .nav-item.show .nav-link {\n  color: #464a4c;\n  background-color: #fff;\n  border-color: #ddd #ddd #fff;\n}\n\n.nav-tabs .dropdown-menu {\n  margin-top: -1px;\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n\n.nav-pills .nav-link {\n  border-radius: 0.25rem;\n}\n\n.nav-pills .nav-link.active,\n.nav-pills .nav-item.show .nav-link {\n  color: #fff;\n  cursor: default;\n  background-color: #0275d8;\n}\n\n.nav-fill .nav-item {\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 auto;\n      -ms-flex: 1 1 auto;\n          flex: 1 1 auto;\n  text-align: center;\n}\n\n.nav-justified .nav-item {\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 100%;\n      -ms-flex: 1 1 100%;\n          flex: 1 1 100%;\n  text-align: center;\n}\n\n.tab-content > .tab-pane {\n  display: none;\n}\n\n.tab-content > .active {\n  display: block;\n}\n\n.navbar {\n  position: relative;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  padding: 0.5rem 1rem;\n}\n\n.navbar-brand {\n  display: inline-block;\n  padding-top: .25rem;\n  padding-bottom: .25rem;\n  margin-right: 1rem;\n  font-size: 1.25rem;\n  line-height: inherit;\n  white-space: nowrap;\n}\n\n.navbar-brand:focus, .navbar-brand:hover {\n  text-decoration: none;\n}\n\n.navbar-nav {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  padding-left: 0;\n  margin-bottom: 0;\n  list-style: none;\n}\n\n.navbar-nav .nav-link {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.navbar-text {\n  display: inline-block;\n  padding-top: .425rem;\n  padding-bottom: .425rem;\n}\n\n.navbar-toggler {\n  -webkit-align-self: flex-start;\n      -ms-flex-item-align: start;\n          align-self: flex-start;\n  padding: 0.25rem 0.75rem;\n  font-size: 1.25rem;\n  line-height: 1;\n  background: transparent;\n  border: 1px solid transparent;\n  border-radius: 0.25rem;\n}\n\n.navbar-toggler:focus, .navbar-toggler:hover {\n  text-decoration: none;\n}\n\n.navbar-toggler-icon {\n  display: inline-block;\n  width: 1.5em;\n  height: 1.5em;\n  vertical-align: middle;\n  content: \"\";\n  background: no-repeat center center;\n  -webkit-background-size: 100% 100%;\n          background-size: 100% 100%;\n}\n\n.navbar-toggler-left {\n  position: absolute;\n  left: 1rem;\n}\n\n.navbar-toggler-right {\n  position: absolute;\n  right: 1rem;\n}\n\n@media (max-width: 575px) {\n  .navbar-toggleable .navbar-nav .dropdown-menu {\n    position: static;\n    float: none;\n  }\n  .navbar-toggleable > .container {\n    padding-right: 0;\n    padding-left: 0;\n  }\n}\n\n@media (min-width: 576px) {\n  .navbar-toggleable {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable .navbar-nav {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n  }\n  .navbar-toggleable .navbar-nav .nav-link {\n    padding-right: .5rem;\n    padding-left: .5rem;\n  }\n  .navbar-toggleable > .container {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable .navbar-collapse {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n    width: 100%;\n  }\n  .navbar-toggleable .navbar-toggler {\n    display: none;\n  }\n}\n\n@media (max-width: 767px) {\n  .navbar-toggleable-sm .navbar-nav .dropdown-menu {\n    position: static;\n    float: none;\n  }\n  .navbar-toggleable-sm > .container {\n    padding-right: 0;\n    padding-left: 0;\n  }\n}\n\n@media (min-width: 768px) {\n  .navbar-toggleable-sm {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-sm .navbar-nav {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n  }\n  .navbar-toggleable-sm .navbar-nav .nav-link {\n    padding-right: .5rem;\n    padding-left: .5rem;\n  }\n  .navbar-toggleable-sm > .container {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-sm .navbar-collapse {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n    width: 100%;\n  }\n  .navbar-toggleable-sm .navbar-toggler {\n    display: none;\n  }\n}\n\n@media (max-width: 991px) {\n  .navbar-toggleable-md .navbar-nav .dropdown-menu {\n    position: static;\n    float: none;\n  }\n  .navbar-toggleable-md > .container {\n    padding-right: 0;\n    padding-left: 0;\n  }\n}\n\n@media (min-width: 992px) {\n  .navbar-toggleable-md {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-md .navbar-nav {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n  }\n  .navbar-toggleable-md .navbar-nav .nav-link {\n    padding-right: .5rem;\n    padding-left: .5rem;\n  }\n  .navbar-toggleable-md > .container {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-md .navbar-collapse {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n    width: 100%;\n  }\n  .navbar-toggleable-md .navbar-toggler {\n    display: none;\n  }\n}\n\n@media (max-width: 1199px) {\n  .navbar-toggleable-lg .navbar-nav .dropdown-menu {\n    position: static;\n    float: none;\n  }\n  .navbar-toggleable-lg > .container {\n    padding-right: 0;\n    padding-left: 0;\n  }\n}\n\n@media (min-width: 1200px) {\n  .navbar-toggleable-lg {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-lg .navbar-nav {\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n            flex-direction: row;\n  }\n  .navbar-toggleable-lg .navbar-nav .nav-link {\n    padding-right: .5rem;\n    padding-left: .5rem;\n  }\n  .navbar-toggleable-lg > .container {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-wrap: nowrap;\n        -ms-flex-wrap: nowrap;\n            flex-wrap: nowrap;\n    -webkit-box-align: center;\n    -webkit-align-items: center;\n        -ms-flex-align: center;\n            align-items: center;\n  }\n  .navbar-toggleable-lg .navbar-collapse {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n    width: 100%;\n  }\n  .navbar-toggleable-lg .navbar-toggler {\n    display: none;\n  }\n}\n\n.navbar-toggleable-xl {\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: row;\n      -ms-flex-direction: row;\n          flex-direction: row;\n  -webkit-flex-wrap: nowrap;\n      -ms-flex-wrap: nowrap;\n          flex-wrap: nowrap;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n}\n\n.navbar-toggleable-xl .navbar-nav .dropdown-menu {\n  position: static;\n  float: none;\n}\n\n.navbar-toggleable-xl > .container {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.navbar-toggleable-xl .navbar-nav {\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: row;\n      -ms-flex-direction: row;\n          flex-direction: row;\n}\n\n.navbar-toggleable-xl .navbar-nav .nav-link {\n  padding-right: .5rem;\n  padding-left: .5rem;\n}\n\n.navbar-toggleable-xl > .container {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-flex-wrap: nowrap;\n      -ms-flex-wrap: nowrap;\n          flex-wrap: nowrap;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n}\n\n.navbar-toggleable-xl .navbar-collapse {\n  display: -webkit-box !important;\n  display: -webkit-flex !important;\n  display: -ms-flexbox !important;\n  display: flex !important;\n  width: 100%;\n}\n\n.navbar-toggleable-xl .navbar-toggler {\n  display: none;\n}\n\n.navbar-light .navbar-brand,\n.navbar-light .navbar-toggler {\n  color: rgba(0, 0, 0, 0.9);\n}\n\n.navbar-light .navbar-brand:focus, .navbar-light .navbar-brand:hover,\n.navbar-light .navbar-toggler:focus,\n.navbar-light .navbar-toggler:hover {\n  color: rgba(0, 0, 0, 0.9);\n}\n\n.navbar-light .navbar-nav .nav-link {\n  color: rgba(0, 0, 0, 0.5);\n}\n\n.navbar-light .navbar-nav .nav-link:focus, .navbar-light .navbar-nav .nav-link:hover {\n  color: rgba(0, 0, 0, 0.7);\n}\n\n.navbar-light .navbar-nav .nav-link.disabled {\n  color: rgba(0, 0, 0, 0.3);\n}\n\n.navbar-light .navbar-nav .open > .nav-link,\n.navbar-light .navbar-nav .active > .nav-link,\n.navbar-light .navbar-nav .nav-link.open,\n.navbar-light .navbar-nav .nav-link.active {\n  color: rgba(0, 0, 0, 0.9);\n}\n\n.navbar-light .navbar-toggler {\n  border-color: rgba(0, 0, 0, 0.1);\n}\n\n.navbar-light .navbar-toggler-icon {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E\");\n}\n\n.navbar-light .navbar-text {\n  color: rgba(0, 0, 0, 0.5);\n}\n\n.navbar-inverse .navbar-brand,\n.navbar-inverse .navbar-toggler {\n  color: white;\n}\n\n.navbar-inverse .navbar-brand:focus, .navbar-inverse .navbar-brand:hover,\n.navbar-inverse .navbar-toggler:focus,\n.navbar-inverse .navbar-toggler:hover {\n  color: white;\n}\n\n.navbar-inverse .navbar-nav .nav-link {\n  color: rgba(255, 255, 255, 0.5);\n}\n\n.navbar-inverse .navbar-nav .nav-link:focus, .navbar-inverse .navbar-nav .nav-link:hover {\n  color: rgba(255, 255, 255, 0.75);\n}\n\n.navbar-inverse .navbar-nav .nav-link.disabled {\n  color: rgba(255, 255, 255, 0.25);\n}\n\n.navbar-inverse .navbar-nav .open > .nav-link,\n.navbar-inverse .navbar-nav .active > .nav-link,\n.navbar-inverse .navbar-nav .nav-link.open,\n.navbar-inverse .navbar-nav .nav-link.active {\n  color: white;\n}\n\n.navbar-inverse .navbar-toggler {\n  border-color: rgba(255, 255, 255, 0.1);\n}\n\n.navbar-inverse .navbar-toggler-icon {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E\");\n}\n\n.navbar-inverse .navbar-text {\n  color: rgba(255, 255, 255, 0.5);\n}\n\n.card {\n  position: relative;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  background-color: #fff;\n  border: 1px solid rgba(0, 0, 0, 0.125);\n  border-radius: 0.25rem;\n}\n\n.card-block {\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 auto;\n      -ms-flex: 1 1 auto;\n          flex: 1 1 auto;\n  padding: 1.25rem;\n}\n\n.card-title {\n  margin-bottom: 0.75rem;\n}\n\n.card-subtitle {\n  margin-top: -0.375rem;\n  margin-bottom: 0;\n}\n\n.card-text:last-child {\n  margin-bottom: 0;\n}\n\n.card-link:hover {\n  text-decoration: none;\n}\n\n.card-link + .card-link {\n  margin-left: 1.25rem;\n}\n\n.card > .list-group:first-child .list-group-item:first-child {\n  border-top-right-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.card > .list-group:last-child .list-group-item:last-child {\n  border-bottom-right-radius: 0.25rem;\n  border-bottom-left-radius: 0.25rem;\n}\n\n.card-header {\n  padding: 0.75rem 1.25rem;\n  margin-bottom: 0;\n  background-color: #f7f7f9;\n  border-bottom: 1px solid rgba(0, 0, 0, 0.125);\n}\n\n.card-header:first-child {\n  border-radius: calc(0.25rem - 1px) calc(0.25rem - 1px) 0 0;\n}\n\n.card-footer {\n  padding: 0.75rem 1.25rem;\n  background-color: #f7f7f9;\n  border-top: 1px solid rgba(0, 0, 0, 0.125);\n}\n\n.card-footer:last-child {\n  border-radius: 0 0 calc(0.25rem - 1px) calc(0.25rem - 1px);\n}\n\n.card-header-tabs {\n  margin-right: -0.625rem;\n  margin-bottom: -0.75rem;\n  margin-left: -0.625rem;\n  border-bottom: 0;\n}\n\n.card-header-pills {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem;\n}\n\n.card-primary {\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.card-primary .card-header,\n.card-primary .card-footer {\n  background-color: transparent;\n}\n\n.card-success {\n  background-color: #5cb85c;\n  border-color: #5cb85c;\n}\n\n.card-success .card-header,\n.card-success .card-footer {\n  background-color: transparent;\n}\n\n.card-info {\n  background-color: #5bc0de;\n  border-color: #5bc0de;\n}\n\n.card-info .card-header,\n.card-info .card-footer {\n  background-color: transparent;\n}\n\n.card-warning {\n  background-color: #f0ad4e;\n  border-color: #f0ad4e;\n}\n\n.card-warning .card-header,\n.card-warning .card-footer {\n  background-color: transparent;\n}\n\n.card-danger {\n  background-color: #d9534f;\n  border-color: #d9534f;\n}\n\n.card-danger .card-header,\n.card-danger .card-footer {\n  background-color: transparent;\n}\n\n.card-outline-primary {\n  background-color: transparent;\n  border-color: #0275d8;\n}\n\n.card-outline-secondary {\n  background-color: transparent;\n  border-color: #ccc;\n}\n\n.card-outline-info {\n  background-color: transparent;\n  border-color: #5bc0de;\n}\n\n.card-outline-success {\n  background-color: transparent;\n  border-color: #5cb85c;\n}\n\n.card-outline-warning {\n  background-color: transparent;\n  border-color: #f0ad4e;\n}\n\n.card-outline-danger {\n  background-color: transparent;\n  border-color: #d9534f;\n}\n\n.card-inverse {\n  color: rgba(255, 255, 255, 0.65);\n}\n\n.card-inverse .card-header,\n.card-inverse .card-footer {\n  background-color: transparent;\n  border-color: rgba(255, 255, 255, 0.2);\n}\n\n.card-inverse .card-header,\n.card-inverse .card-footer,\n.card-inverse .card-title,\n.card-inverse .card-blockquote {\n  color: #fff;\n}\n\n.card-inverse .card-link,\n.card-inverse .card-text,\n.card-inverse .card-subtitle,\n.card-inverse .card-blockquote .blockquote-footer {\n  color: rgba(255, 255, 255, 0.65);\n}\n\n.card-inverse .card-link:focus, .card-inverse .card-link:hover {\n  color: #fff;\n}\n\n.card-blockquote {\n  padding: 0;\n  margin-bottom: 0;\n  border-left: 0;\n}\n\n.card-img {\n  border-radius: calc(0.25rem - 1px);\n}\n\n.card-img-overlay {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  padding: 1.25rem;\n}\n\n.card-img-top {\n  border-top-right-radius: calc(0.25rem - 1px);\n  border-top-left-radius: calc(0.25rem - 1px);\n}\n\n.card-img-bottom {\n  border-bottom-right-radius: calc(0.25rem - 1px);\n  border-bottom-left-radius: calc(0.25rem - 1px);\n}\n\n@media (min-width: 576px) {\n  .card-deck {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-flow: row wrap;\n        -ms-flex-flow: row wrap;\n            flex-flow: row wrap;\n  }\n  .card-deck .card {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-flex: 1;\n    -webkit-flex: 1 0 0%;\n        -ms-flex: 1 0 0%;\n            flex: 1 0 0%;\n    -webkit-box-orient: vertical;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: column;\n        -ms-flex-direction: column;\n            flex-direction: column;\n  }\n  .card-deck .card:not(:first-child) {\n    margin-left: 15px;\n  }\n  .card-deck .card:not(:last-child) {\n    margin-right: 15px;\n  }\n}\n\n@media (min-width: 576px) {\n  .card-group {\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-flex-flow: row wrap;\n        -ms-flex-flow: row wrap;\n            flex-flow: row wrap;\n  }\n  .card-group .card {\n    -webkit-box-flex: 1;\n    -webkit-flex: 1 0 0%;\n        -ms-flex: 1 0 0%;\n            flex: 1 0 0%;\n  }\n  .card-group .card + .card {\n    margin-left: 0;\n    border-left: 0;\n  }\n  .card-group .card:first-child {\n    border-bottom-right-radius: 0;\n    border-top-right-radius: 0;\n  }\n  .card-group .card:first-child .card-img-top {\n    border-top-right-radius: 0;\n  }\n  .card-group .card:first-child .card-img-bottom {\n    border-bottom-right-radius: 0;\n  }\n  .card-group .card:last-child {\n    border-bottom-left-radius: 0;\n    border-top-left-radius: 0;\n  }\n  .card-group .card:last-child .card-img-top {\n    border-top-left-radius: 0;\n  }\n  .card-group .card:last-child .card-img-bottom {\n    border-bottom-left-radius: 0;\n  }\n  .card-group .card:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n  .card-group .card:not(:first-child):not(:last-child) .card-img-top,\n  .card-group .card:not(:first-child):not(:last-child) .card-img-bottom {\n    border-radius: 0;\n  }\n}\n\n@media (min-width: 576px) {\n  .card-columns {\n    -webkit-column-count: 3;\n       -moz-column-count: 3;\n            column-count: 3;\n    -webkit-column-gap: 1.25rem;\n       -moz-column-gap: 1.25rem;\n            column-gap: 1.25rem;\n  }\n  .card-columns .card {\n    display: inline-block;\n    width: 100%;\n    margin-bottom: 0.75rem;\n  }\n}\n\n.breadcrumb {\n  padding: 0.75rem 1rem;\n  margin-bottom: 1rem;\n  list-style: none;\n  background-color: #eceeef;\n  border-radius: 0.25rem;\n}\n\n.breadcrumb::after {\n  display: block;\n  content: \"\";\n  clear: both;\n}\n\n.breadcrumb-item {\n  float: left;\n}\n\n.breadcrumb-item + .breadcrumb-item::before {\n  display: inline-block;\n  padding-right: 0.5rem;\n  padding-left: 0.5rem;\n  color: #636c72;\n  content: \"/\";\n}\n\n.breadcrumb-item + .breadcrumb-item:hover::before {\n  text-decoration: underline;\n}\n\n.breadcrumb-item + .breadcrumb-item:hover::before {\n  text-decoration: none;\n}\n\n.breadcrumb-item.active {\n  color: #636c72;\n}\n\n.pagination {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  padding-left: 0;\n  list-style: none;\n  border-radius: 0.25rem;\n}\n\n.page-item:first-child .page-link {\n  margin-left: 0;\n  border-bottom-left-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.page-item:last-child .page-link {\n  border-bottom-right-radius: 0.25rem;\n  border-top-right-radius: 0.25rem;\n}\n\n.page-item.active .page-link {\n  z-index: 2;\n  color: #fff;\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.page-item.disabled .page-link {\n  color: #636c72;\n  pointer-events: none;\n  cursor: not-allowed;\n  background-color: #fff;\n  border-color: #ddd;\n}\n\n.page-link {\n  position: relative;\n  display: block;\n  padding: 0.5rem 0.75rem;\n  margin-left: -1px;\n  line-height: 1.25;\n  color: #0275d8;\n  background-color: #fff;\n  border: 1px solid #ddd;\n}\n\n.page-link:focus, .page-link:hover {\n  color: #014c8c;\n  text-decoration: none;\n  background-color: #eceeef;\n  border-color: #ddd;\n}\n\n.pagination-lg .page-link {\n  padding: 0.75rem 1.5rem;\n  font-size: 1.25rem;\n}\n\n.pagination-lg .page-item:first-child .page-link {\n  border-bottom-left-radius: 0.3rem;\n  border-top-left-radius: 0.3rem;\n}\n\n.pagination-lg .page-item:last-child .page-link {\n  border-bottom-right-radius: 0.3rem;\n  border-top-right-radius: 0.3rem;\n}\n\n.pagination-sm .page-link {\n  padding: 0.25rem 0.5rem;\n  font-size: 0.875rem;\n}\n\n.pagination-sm .page-item:first-child .page-link {\n  border-bottom-left-radius: 0.2rem;\n  border-top-left-radius: 0.2rem;\n}\n\n.pagination-sm .page-item:last-child .page-link {\n  border-bottom-right-radius: 0.2rem;\n  border-top-right-radius: 0.2rem;\n}\n\n.badge {\n  display: inline-block;\n  padding: 0.25em 0.4em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: #fff;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: 0.25rem;\n}\n\n.badge:empty {\n  display: none;\n}\n\n.btn .badge {\n  position: relative;\n  top: -1px;\n}\n\na.badge:focus, a.badge:hover {\n  color: #fff;\n  text-decoration: none;\n  cursor: pointer;\n}\n\n.badge-pill {\n  padding-right: 0.6em;\n  padding-left: 0.6em;\n  border-radius: 10rem;\n}\n\n.badge-default {\n  background-color: #636c72;\n}\n\n.badge-default[href]:focus, .badge-default[href]:hover {\n  background-color: #4b5257;\n}\n\n.badge-primary {\n  background-color: #0275d8;\n}\n\n.badge-primary[href]:focus, .badge-primary[href]:hover {\n  background-color: #025aa5;\n}\n\n.badge-success {\n  background-color: #5cb85c;\n}\n\n.badge-success[href]:focus, .badge-success[href]:hover {\n  background-color: #449d44;\n}\n\n.badge-info {\n  background-color: #5bc0de;\n}\n\n.badge-info[href]:focus, .badge-info[href]:hover {\n  background-color: #31b0d5;\n}\n\n.badge-warning {\n  background-color: #f0ad4e;\n}\n\n.badge-warning[href]:focus, .badge-warning[href]:hover {\n  background-color: #ec971f;\n}\n\n.badge-danger {\n  background-color: #d9534f;\n}\n\n.badge-danger[href]:focus, .badge-danger[href]:hover {\n  background-color: #c9302c;\n}\n\n.jumbotron {\n  padding: 2rem 1rem;\n  margin-bottom: 2rem;\n  background-color: #eceeef;\n  border-radius: 0.3rem;\n}\n\n@media (min-width: 576px) {\n  .jumbotron {\n    padding: 4rem 2rem;\n  }\n}\n\n.jumbotron-hr {\n  border-top-color: #d0d5d8;\n}\n\n.jumbotron-fluid {\n  padding-right: 0;\n  padding-left: 0;\n  border-radius: 0;\n}\n\n.alert {\n  padding: 0.75rem 1.25rem;\n  margin-bottom: 1rem;\n  border: 1px solid transparent;\n  border-radius: 0.25rem;\n}\n\n.alert-heading {\n  color: inherit;\n}\n\n.alert-link {\n  font-weight: bold;\n}\n\n.alert-dismissible .close {\n  position: relative;\n  top: -0.75rem;\n  right: -1.25rem;\n  padding: 0.75rem 1.25rem;\n  color: inherit;\n}\n\n.alert-success {\n  background-color: #dff0d8;\n  border-color: #d0e9c6;\n  color: #3c763d;\n}\n\n.alert-success hr {\n  border-top-color: #c1e2b3;\n}\n\n.alert-success .alert-link {\n  color: #2b542c;\n}\n\n.alert-info {\n  background-color: #d9edf7;\n  border-color: #bcdff1;\n  color: #31708f;\n}\n\n.alert-info hr {\n  border-top-color: #a6d5ec;\n}\n\n.alert-info .alert-link {\n  color: #245269;\n}\n\n.alert-warning {\n  background-color: #fcf8e3;\n  border-color: #faf2cc;\n  color: #8a6d3b;\n}\n\n.alert-warning hr {\n  border-top-color: #f7ecb5;\n}\n\n.alert-warning .alert-link {\n  color: #66512c;\n}\n\n.alert-danger {\n  background-color: #f2dede;\n  border-color: #ebcccc;\n  color: #a94442;\n}\n\n.alert-danger hr {\n  border-top-color: #e4b9b9;\n}\n\n.alert-danger .alert-link {\n  color: #843534;\n}\n\n@-webkit-keyframes progress-bar-stripes {\n  from {\n    background-position: 1rem 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n\n@-o-keyframes progress-bar-stripes {\n  from {\n    background-position: 1rem 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n\n@keyframes progress-bar-stripes {\n  from {\n    background-position: 1rem 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n\n.progress {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  overflow: hidden;\n  font-size: 0.75rem;\n  line-height: 1rem;\n  text-align: center;\n  background-color: #eceeef;\n  border-radius: 0.25rem;\n}\n\n.progress-bar {\n  height: 1rem;\n  color: #fff;\n  background-color: #0275d8;\n}\n\n.progress-bar-striped {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  -webkit-background-size: 1rem 1rem;\n          background-size: 1rem 1rem;\n}\n\n.progress-bar-animated {\n  -webkit-animation: progress-bar-stripes 1s linear infinite;\n       -o-animation: progress-bar-stripes 1s linear infinite;\n          animation: progress-bar-stripes 1s linear infinite;\n}\n\n.media {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-align: start;\n  -webkit-align-items: flex-start;\n      -ms-flex-align: start;\n          align-items: flex-start;\n}\n\n.media-body {\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 0%;\n      -ms-flex: 1 1 0%;\n          flex: 1 1 0%;\n}\n\n.list-group {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  padding-left: 0;\n  margin-bottom: 0;\n}\n\n.list-group-item-action {\n  width: 100%;\n  color: #464a4c;\n  text-align: inherit;\n}\n\n.list-group-item-action .list-group-item-heading {\n  color: #292b2c;\n}\n\n.list-group-item-action:focus, .list-group-item-action:hover {\n  color: #464a4c;\n  text-decoration: none;\n  background-color: #f7f7f9;\n}\n\n.list-group-item-action:active {\n  color: #292b2c;\n  background-color: #eceeef;\n}\n\n.list-group-item {\n  position: relative;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-flex-flow: row wrap;\n      -ms-flex-flow: row wrap;\n          flex-flow: row wrap;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n  padding: 0.75rem 1.25rem;\n  margin-bottom: -1px;\n  background-color: #fff;\n  border: 1px solid rgba(0, 0, 0, 0.125);\n}\n\n.list-group-item:first-child {\n  border-top-right-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.list-group-item:last-child {\n  margin-bottom: 0;\n  border-bottom-right-radius: 0.25rem;\n  border-bottom-left-radius: 0.25rem;\n}\n\n.list-group-item:focus, .list-group-item:hover {\n  text-decoration: none;\n}\n\n.list-group-item.disabled, .list-group-item:disabled {\n  color: #636c72;\n  cursor: not-allowed;\n  background-color: #fff;\n}\n\n.list-group-item.disabled .list-group-item-heading, .list-group-item:disabled .list-group-item-heading {\n  color: inherit;\n}\n\n.list-group-item.disabled .list-group-item-text, .list-group-item:disabled .list-group-item-text {\n  color: #636c72;\n}\n\n.list-group-item.active {\n  z-index: 2;\n  color: #fff;\n  background-color: #0275d8;\n  border-color: #0275d8;\n}\n\n.list-group-item.active .list-group-item-heading,\n.list-group-item.active .list-group-item-heading > small,\n.list-group-item.active .list-group-item-heading > .small {\n  color: inherit;\n}\n\n.list-group-item.active .list-group-item-text {\n  color: #daeeff;\n}\n\n.list-group-flush .list-group-item {\n  border-right: 0;\n  border-left: 0;\n  border-radius: 0;\n}\n\n.list-group-flush:first-child .list-group-item:first-child {\n  border-top: 0;\n}\n\n.list-group-flush:last-child .list-group-item:last-child {\n  border-bottom: 0;\n}\n\n.list-group-item-success {\n  color: #3c763d;\n  background-color: #dff0d8;\n}\n\na.list-group-item-success,\nbutton.list-group-item-success {\n  color: #3c763d;\n}\n\na.list-group-item-success .list-group-item-heading,\nbutton.list-group-item-success .list-group-item-heading {\n  color: inherit;\n}\n\na.list-group-item-success:focus, a.list-group-item-success:hover,\nbutton.list-group-item-success:focus,\nbutton.list-group-item-success:hover {\n  color: #3c763d;\n  background-color: #d0e9c6;\n}\n\na.list-group-item-success.active,\nbutton.list-group-item-success.active {\n  color: #fff;\n  background-color: #3c763d;\n  border-color: #3c763d;\n}\n\n.list-group-item-info {\n  color: #31708f;\n  background-color: #d9edf7;\n}\n\na.list-group-item-info,\nbutton.list-group-item-info {\n  color: #31708f;\n}\n\na.list-group-item-info .list-group-item-heading,\nbutton.list-group-item-info .list-group-item-heading {\n  color: inherit;\n}\n\na.list-group-item-info:focus, a.list-group-item-info:hover,\nbutton.list-group-item-info:focus,\nbutton.list-group-item-info:hover {\n  color: #31708f;\n  background-color: #c4e3f3;\n}\n\na.list-group-item-info.active,\nbutton.list-group-item-info.active {\n  color: #fff;\n  background-color: #31708f;\n  border-color: #31708f;\n}\n\n.list-group-item-warning {\n  color: #8a6d3b;\n  background-color: #fcf8e3;\n}\n\na.list-group-item-warning,\nbutton.list-group-item-warning {\n  color: #8a6d3b;\n}\n\na.list-group-item-warning .list-group-item-heading,\nbutton.list-group-item-warning .list-group-item-heading {\n  color: inherit;\n}\n\na.list-group-item-warning:focus, a.list-group-item-warning:hover,\nbutton.list-group-item-warning:focus,\nbutton.list-group-item-warning:hover {\n  color: #8a6d3b;\n  background-color: #faf2cc;\n}\n\na.list-group-item-warning.active,\nbutton.list-group-item-warning.active {\n  color: #fff;\n  background-color: #8a6d3b;\n  border-color: #8a6d3b;\n}\n\n.list-group-item-danger {\n  color: #a94442;\n  background-color: #f2dede;\n}\n\na.list-group-item-danger,\nbutton.list-group-item-danger {\n  color: #a94442;\n}\n\na.list-group-item-danger .list-group-item-heading,\nbutton.list-group-item-danger .list-group-item-heading {\n  color: inherit;\n}\n\na.list-group-item-danger:focus, a.list-group-item-danger:hover,\nbutton.list-group-item-danger:focus,\nbutton.list-group-item-danger:hover {\n  color: #a94442;\n  background-color: #ebcccc;\n}\n\na.list-group-item-danger.active,\nbutton.list-group-item-danger.active {\n  color: #fff;\n  background-color: #a94442;\n  border-color: #a94442;\n}\n\n.embed-responsive {\n  position: relative;\n  display: block;\n  width: 100%;\n  padding: 0;\n  overflow: hidden;\n}\n\n.embed-responsive::before {\n  display: block;\n  content: \"\";\n}\n\n.embed-responsive .embed-responsive-item,\n.embed-responsive iframe,\n.embed-responsive embed,\n.embed-responsive object,\n.embed-responsive video {\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  border: 0;\n}\n\n.embed-responsive-21by9::before {\n  padding-top: 42.857143%;\n}\n\n.embed-responsive-16by9::before {\n  padding-top: 56.25%;\n}\n\n.embed-responsive-4by3::before {\n  padding-top: 75%;\n}\n\n.embed-responsive-1by1::before {\n  padding-top: 100%;\n}\n\n.close {\n  float: right;\n  font-size: 1.5rem;\n  font-weight: bold;\n  line-height: 1;\n  color: #000;\n  text-shadow: 0 1px 0 #fff;\n  opacity: .5;\n}\n\n.close:focus, .close:hover {\n  color: #000;\n  text-decoration: none;\n  cursor: pointer;\n  opacity: .75;\n}\n\nbutton.close {\n  padding: 0;\n  cursor: pointer;\n  background: transparent;\n  border: 0;\n  -webkit-appearance: none;\n}\n\n.modal-open {\n  overflow: hidden;\n}\n\n.modal {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1050;\n  display: none;\n  overflow: hidden;\n  outline: 0;\n}\n\n.modal.fade .modal-dialog {\n  -webkit-transition: -webkit-transform 0.3s ease-out;\n  transition: -webkit-transform 0.3s ease-out;\n  -o-transition: -o-transform 0.3s ease-out;\n  transition: transform 0.3s ease-out;\n  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out, -o-transform 0.3s ease-out;\n  -webkit-transform: translate(0, -25%);\n       -o-transform: translate(0, -25%);\n          transform: translate(0, -25%);\n}\n\n.modal.show .modal-dialog {\n  -webkit-transform: translate(0, 0);\n       -o-transform: translate(0, 0);\n          transform: translate(0, 0);\n}\n\n.modal-open .modal {\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: 10px;\n}\n\n.modal-content {\n  position: relative;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: vertical;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: column;\n      -ms-flex-direction: column;\n          flex-direction: column;\n  background-color: #fff;\n  -webkit-background-clip: padding-box;\n          background-clip: padding-box;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 0.3rem;\n  outline: 0;\n}\n\n.modal-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1040;\n  background-color: #000;\n}\n\n.modal-backdrop.fade {\n  opacity: 0;\n}\n\n.modal-backdrop.show {\n  opacity: 0.5;\n}\n\n.modal-header {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n  -webkit-box-pack: justify;\n  -webkit-justify-content: space-between;\n      -ms-flex-pack: justify;\n          justify-content: space-between;\n  padding: 15px;\n  border-bottom: 1px solid #eceeef;\n}\n\n.modal-title {\n  margin-bottom: 0;\n  line-height: 1.5;\n}\n\n.modal-body {\n  position: relative;\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 1 auto;\n      -ms-flex: 1 1 auto;\n          flex: 1 1 auto;\n  padding: 15px;\n}\n\n.modal-footer {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n  -webkit-box-pack: end;\n  -webkit-justify-content: flex-end;\n      -ms-flex-pack: end;\n          justify-content: flex-end;\n  padding: 15px;\n  border-top: 1px solid #eceeef;\n}\n\n.modal-footer > :not(:first-child) {\n  margin-left: .25rem;\n}\n\n.modal-footer > :not(:last-child) {\n  margin-right: .25rem;\n}\n\n.modal-scrollbar-measure {\n  position: absolute;\n  top: -9999px;\n  width: 50px;\n  height: 50px;\n  overflow: scroll;\n}\n\n@media (min-width: 576px) {\n  .modal-dialog {\n    max-width: 500px;\n    margin: 30px auto;\n  }\n  .modal-sm {\n    max-width: 300px;\n  }\n}\n\n@media (min-width: 992px) {\n  .modal-lg {\n    max-width: 800px;\n  }\n}\n\n.tooltip {\n  position: absolute;\n  z-index: 1070;\n  display: block;\n  font-family: -apple-system, system-ui, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.5;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  font-size: 0.875rem;\n  word-wrap: break-word;\n  opacity: 0;\n}\n\n.tooltip.show {\n  opacity: 0.9;\n}\n\n.tooltip.tooltip-top, .tooltip.bs-tether-element-attached-bottom {\n  padding: 5px 0;\n  margin-top: -3px;\n}\n\n.tooltip.tooltip-top .tooltip-inner::before, .tooltip.bs-tether-element-attached-bottom .tooltip-inner::before {\n  bottom: 0;\n  left: 50%;\n  margin-left: -5px;\n  content: \"\";\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n\n.tooltip.tooltip-right, .tooltip.bs-tether-element-attached-left {\n  padding: 0 5px;\n  margin-left: 3px;\n}\n\n.tooltip.tooltip-right .tooltip-inner::before, .tooltip.bs-tether-element-attached-left .tooltip-inner::before {\n  top: 50%;\n  left: 0;\n  margin-top: -5px;\n  content: \"\";\n  border-width: 5px 5px 5px 0;\n  border-right-color: #000;\n}\n\n.tooltip.tooltip-bottom, .tooltip.bs-tether-element-attached-top {\n  padding: 5px 0;\n  margin-top: 3px;\n}\n\n.tooltip.tooltip-bottom .tooltip-inner::before, .tooltip.bs-tether-element-attached-top .tooltip-inner::before {\n  top: 0;\n  left: 50%;\n  margin-left: -5px;\n  content: \"\";\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n\n.tooltip.tooltip-left, .tooltip.bs-tether-element-attached-right {\n  padding: 0 5px;\n  margin-left: -3px;\n}\n\n.tooltip.tooltip-left .tooltip-inner::before, .tooltip.bs-tether-element-attached-right .tooltip-inner::before {\n  top: 50%;\n  right: 0;\n  margin-top: -5px;\n  content: \"\";\n  border-width: 5px 0 5px 5px;\n  border-left-color: #000;\n}\n\n.tooltip-inner {\n  max-width: 200px;\n  padding: 3px 8px;\n  color: #fff;\n  text-align: center;\n  background-color: #000;\n  border-radius: 0.25rem;\n}\n\n.tooltip-inner::before {\n  position: absolute;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n\n.popover {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 1060;\n  display: block;\n  max-width: 276px;\n  padding: 1px;\n  font-family: -apple-system, system-ui, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.5;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  font-size: 0.875rem;\n  word-wrap: break-word;\n  background-color: #fff;\n  -webkit-background-clip: padding-box;\n          background-clip: padding-box;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 0.3rem;\n}\n\n.popover.popover-top, .popover.bs-tether-element-attached-bottom {\n  margin-top: -10px;\n}\n\n.popover.popover-top::before, .popover.popover-top::after, .popover.bs-tether-element-attached-bottom::before, .popover.bs-tether-element-attached-bottom::after {\n  left: 50%;\n  border-bottom-width: 0;\n}\n\n.popover.popover-top::before, .popover.bs-tether-element-attached-bottom::before {\n  bottom: -11px;\n  margin-left: -11px;\n  border-top-color: rgba(0, 0, 0, 0.25);\n}\n\n.popover.popover-top::after, .popover.bs-tether-element-attached-bottom::after {\n  bottom: -10px;\n  margin-left: -10px;\n  border-top-color: #fff;\n}\n\n.popover.popover-right, .popover.bs-tether-element-attached-left {\n  margin-left: 10px;\n}\n\n.popover.popover-right::before, .popover.popover-right::after, .popover.bs-tether-element-attached-left::before, .popover.bs-tether-element-attached-left::after {\n  top: 50%;\n  border-left-width: 0;\n}\n\n.popover.popover-right::before, .popover.bs-tether-element-attached-left::before {\n  left: -11px;\n  margin-top: -11px;\n  border-right-color: rgba(0, 0, 0, 0.25);\n}\n\n.popover.popover-right::after, .popover.bs-tether-element-attached-left::after {\n  left: -10px;\n  margin-top: -10px;\n  border-right-color: #fff;\n}\n\n.popover.popover-bottom, .popover.bs-tether-element-attached-top {\n  margin-top: 10px;\n}\n\n.popover.popover-bottom::before, .popover.popover-bottom::after, .popover.bs-tether-element-attached-top::before, .popover.bs-tether-element-attached-top::after {\n  left: 50%;\n  border-top-width: 0;\n}\n\n.popover.popover-bottom::before, .popover.bs-tether-element-attached-top::before {\n  top: -11px;\n  margin-left: -11px;\n  border-bottom-color: rgba(0, 0, 0, 0.25);\n}\n\n.popover.popover-bottom::after, .popover.bs-tether-element-attached-top::after {\n  top: -10px;\n  margin-left: -10px;\n  border-bottom-color: #f7f7f7;\n}\n\n.popover.popover-bottom .popover-title::before, .popover.bs-tether-element-attached-top .popover-title::before {\n  position: absolute;\n  top: 0;\n  left: 50%;\n  display: block;\n  width: 20px;\n  margin-left: -10px;\n  content: \"\";\n  border-bottom: 1px solid #f7f7f7;\n}\n\n.popover.popover-left, .popover.bs-tether-element-attached-right {\n  margin-left: -10px;\n}\n\n.popover.popover-left::before, .popover.popover-left::after, .popover.bs-tether-element-attached-right::before, .popover.bs-tether-element-attached-right::after {\n  top: 50%;\n  border-right-width: 0;\n}\n\n.popover.popover-left::before, .popover.bs-tether-element-attached-right::before {\n  right: -11px;\n  margin-top: -11px;\n  border-left-color: rgba(0, 0, 0, 0.25);\n}\n\n.popover.popover-left::after, .popover.bs-tether-element-attached-right::after {\n  right: -10px;\n  margin-top: -10px;\n  border-left-color: #fff;\n}\n\n.popover-title {\n  padding: 8px 14px;\n  margin-bottom: 0;\n  font-size: 1rem;\n  background-color: #f7f7f7;\n  border-bottom: 1px solid #ebebeb;\n  border-top-right-radius: calc(0.3rem - 1px);\n  border-top-left-radius: calc(0.3rem - 1px);\n}\n\n.popover-title:empty {\n  display: none;\n}\n\n.popover-content {\n  padding: 9px 14px;\n}\n\n.popover::before,\n.popover::after {\n  position: absolute;\n  display: block;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n\n.popover::before {\n  content: \"\";\n  border-width: 11px;\n}\n\n.popover::after {\n  content: \"\";\n  border-width: 10px;\n}\n\n.carousel {\n  position: relative;\n}\n\n.carousel-inner {\n  position: relative;\n  width: 100%;\n  overflow: hidden;\n}\n\n.carousel-item {\n  position: relative;\n  display: none;\n  width: 100%;\n}\n\n@media (-webkit-transform-3d) {\n  .carousel-item {\n    -webkit-transition: -webkit-transform 0.6s ease-in-out;\n    transition: -webkit-transform 0.6s ease-in-out;\n    -o-transition: -o-transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out, -o-transform 0.6s ease-in-out;\n    -webkit-backface-visibility: hidden;\n            backface-visibility: hidden;\n    -webkit-perspective: 1000px;\n            perspective: 1000px;\n  }\n}\n\n@supports ((-webkit-transform: translate3d(0, 0, 0)) or (transform: translate3d(0, 0, 0))) {\n  .carousel-item {\n    -webkit-transition: -webkit-transform 0.6s ease-in-out;\n    transition: -webkit-transform 0.6s ease-in-out;\n    -o-transition: -o-transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out, -o-transform 0.6s ease-in-out;\n    -webkit-backface-visibility: hidden;\n            backface-visibility: hidden;\n    -webkit-perspective: 1000px;\n            perspective: 1000px;\n  }\n}\n\n.carousel-item.active,\n.carousel-item-next,\n.carousel-item-prev {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n}\n\n.carousel-item-next,\n.carousel-item-prev {\n  position: absolute;\n  top: 0;\n}\n\n@media (-webkit-transform-3d) {\n  .carousel-item-next.carousel-item-left,\n  .carousel-item-prev.carousel-item-right {\n    -webkit-transform: translate3d(0, 0, 0);\n            transform: translate3d(0, 0, 0);\n  }\n  .carousel-item-next,\n  .active.carousel-item-right {\n    -webkit-transform: translate3d(100%, 0, 0);\n            transform: translate3d(100%, 0, 0);\n  }\n  .carousel-item-prev,\n  .active.carousel-item-left {\n    -webkit-transform: translate3d(-100%, 0, 0);\n            transform: translate3d(-100%, 0, 0);\n  }\n}\n\n@supports ((-webkit-transform: translate3d(0, 0, 0)) or (transform: translate3d(0, 0, 0))) {\n  .carousel-item-next.carousel-item-left,\n  .carousel-item-prev.carousel-item-right {\n    -webkit-transform: translate3d(0, 0, 0);\n            transform: translate3d(0, 0, 0);\n  }\n  .carousel-item-next,\n  .active.carousel-item-right {\n    -webkit-transform: translate3d(100%, 0, 0);\n            transform: translate3d(100%, 0, 0);\n  }\n  .carousel-item-prev,\n  .active.carousel-item-left {\n    -webkit-transform: translate3d(-100%, 0, 0);\n            transform: translate3d(-100%, 0, 0);\n  }\n}\n\n.carousel-control-prev,\n.carousel-control-next {\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n      -ms-flex-align: center;\n          align-items: center;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n      -ms-flex-pack: center;\n          justify-content: center;\n  width: 15%;\n  color: #fff;\n  text-align: center;\n  opacity: 0.5;\n}\n\n.carousel-control-prev:focus, .carousel-control-prev:hover,\n.carousel-control-next:focus,\n.carousel-control-next:hover {\n  color: #fff;\n  text-decoration: none;\n  outline: 0;\n  opacity: .9;\n}\n\n.carousel-control-prev {\n  left: 0;\n}\n\n.carousel-control-next {\n  right: 0;\n}\n\n.carousel-control-prev-icon,\n.carousel-control-next-icon {\n  display: inline-block;\n  width: 20px;\n  height: 20px;\n  background: transparent no-repeat center center;\n  -webkit-background-size: 100% 100%;\n          background-size: 100% 100%;\n}\n\n.carousel-control-prev-icon {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M4 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E\");\n}\n\n.carousel-control-next-icon {\n  background-image: url(\"data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M1.5 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E\");\n}\n\n.carousel-indicators {\n  position: absolute;\n  right: 0;\n  bottom: 10px;\n  left: 0;\n  z-index: 15;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n      -ms-flex-pack: center;\n          justify-content: center;\n  padding-left: 0;\n  margin-right: 15%;\n  margin-left: 15%;\n  list-style: none;\n}\n\n.carousel-indicators li {\n  position: relative;\n  -webkit-box-flex: 1;\n  -webkit-flex: 1 0 auto;\n      -ms-flex: 1 0 auto;\n          flex: 1 0 auto;\n  max-width: 30px;\n  height: 3px;\n  margin-right: 3px;\n  margin-left: 3px;\n  text-indent: -999px;\n  cursor: pointer;\n  background-color: rgba(255, 255, 255, 0.5);\n}\n\n.carousel-indicators li::before {\n  position: absolute;\n  top: -10px;\n  left: 0;\n  display: inline-block;\n  width: 100%;\n  height: 10px;\n  content: \"\";\n}\n\n.carousel-indicators li::after {\n  position: absolute;\n  bottom: -10px;\n  left: 0;\n  display: inline-block;\n  width: 100%;\n  height: 10px;\n  content: \"\";\n}\n\n.carousel-indicators .active {\n  background-color: #fff;\n}\n\n.carousel-caption {\n  position: absolute;\n  right: 15%;\n  bottom: 20px;\n  left: 15%;\n  z-index: 10;\n  padding-top: 20px;\n  padding-bottom: 20px;\n  color: #fff;\n  text-align: center;\n}\n\n.align-baseline {\n  vertical-align: baseline !important;\n}\n\n.align-top {\n  vertical-align: top !important;\n}\n\n.align-middle {\n  vertical-align: middle !important;\n}\n\n.align-bottom {\n  vertical-align: bottom !important;\n}\n\n.align-text-bottom {\n  vertical-align: text-bottom !important;\n}\n\n.align-text-top {\n  vertical-align: text-top !important;\n}\n\n.bg-faded {\n  background-color: #f7f7f7;\n}\n\n.bg-primary {\n  background-color: #0275d8 !important;\n}\n\na.bg-primary:focus, a.bg-primary:hover {\n  background-color: #025aa5 !important;\n}\n\n.bg-success {\n  background-color: #5cb85c !important;\n}\n\na.bg-success:focus, a.bg-success:hover {\n  background-color: #449d44 !important;\n}\n\n.bg-info {\n  background-color: #5bc0de !important;\n}\n\na.bg-info:focus, a.bg-info:hover {\n  background-color: #31b0d5 !important;\n}\n\n.bg-warning {\n  background-color: #f0ad4e !important;\n}\n\na.bg-warning:focus, a.bg-warning:hover {\n  background-color: #ec971f !important;\n}\n\n.bg-danger {\n  background-color: #d9534f !important;\n}\n\na.bg-danger:focus, a.bg-danger:hover {\n  background-color: #c9302c !important;\n}\n\n.bg-inverse {\n  background-color: #292b2c !important;\n}\n\na.bg-inverse:focus, a.bg-inverse:hover {\n  background-color: #101112 !important;\n}\n\n.border-0 {\n  border: 0 !important;\n}\n\n.border-top-0 {\n  border-top: 0 !important;\n}\n\n.border-right-0 {\n  border-right: 0 !important;\n}\n\n.border-bottom-0 {\n  border-bottom: 0 !important;\n}\n\n.border-left-0 {\n  border-left: 0 !important;\n}\n\n.rounded {\n  border-radius: 0.25rem;\n}\n\n.rounded-top {\n  border-top-right-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.rounded-right {\n  border-bottom-right-radius: 0.25rem;\n  border-top-right-radius: 0.25rem;\n}\n\n.rounded-bottom {\n  border-bottom-right-radius: 0.25rem;\n  border-bottom-left-radius: 0.25rem;\n}\n\n.rounded-left {\n  border-bottom-left-radius: 0.25rem;\n  border-top-left-radius: 0.25rem;\n}\n\n.rounded-circle {\n  border-radius: 50%;\n}\n\n.rounded-0 {\n  border-radius: 0;\n}\n\n.clearfix::after {\n  display: block;\n  content: \"\";\n  clear: both;\n}\n\n.d-none {\n  display: none !important;\n}\n\n.d-inline {\n  display: inline !important;\n}\n\n.d-inline-block {\n  display: inline-block !important;\n}\n\n.d-block {\n  display: block !important;\n}\n\n.d-table {\n  display: table !important;\n}\n\n.d-table-cell {\n  display: table-cell !important;\n}\n\n.d-flex {\n  display: -webkit-box !important;\n  display: -webkit-flex !important;\n  display: -ms-flexbox !important;\n  display: flex !important;\n}\n\n.d-inline-flex {\n  display: -webkit-inline-box !important;\n  display: -webkit-inline-flex !important;\n  display: -ms-inline-flexbox !important;\n  display: inline-flex !important;\n}\n\n@media (min-width: 576px) {\n  .d-sm-none {\n    display: none !important;\n  }\n  .d-sm-inline {\n    display: inline !important;\n  }\n  .d-sm-inline-block {\n    display: inline-block !important;\n  }\n  .d-sm-block {\n    display: block !important;\n  }\n  .d-sm-table {\n    display: table !important;\n  }\n  .d-sm-table-cell {\n    display: table-cell !important;\n  }\n  .d-sm-flex {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n  }\n  .d-sm-inline-flex {\n    display: -webkit-inline-box !important;\n    display: -webkit-inline-flex !important;\n    display: -ms-inline-flexbox !important;\n    display: inline-flex !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .d-md-none {\n    display: none !important;\n  }\n  .d-md-inline {\n    display: inline !important;\n  }\n  .d-md-inline-block {\n    display: inline-block !important;\n  }\n  .d-md-block {\n    display: block !important;\n  }\n  .d-md-table {\n    display: table !important;\n  }\n  .d-md-table-cell {\n    display: table-cell !important;\n  }\n  .d-md-flex {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n  }\n  .d-md-inline-flex {\n    display: -webkit-inline-box !important;\n    display: -webkit-inline-flex !important;\n    display: -ms-inline-flexbox !important;\n    display: inline-flex !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .d-lg-none {\n    display: none !important;\n  }\n  .d-lg-inline {\n    display: inline !important;\n  }\n  .d-lg-inline-block {\n    display: inline-block !important;\n  }\n  .d-lg-block {\n    display: block !important;\n  }\n  .d-lg-table {\n    display: table !important;\n  }\n  .d-lg-table-cell {\n    display: table-cell !important;\n  }\n  .d-lg-flex {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n  }\n  .d-lg-inline-flex {\n    display: -webkit-inline-box !important;\n    display: -webkit-inline-flex !important;\n    display: -ms-inline-flexbox !important;\n    display: inline-flex !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .d-xl-none {\n    display: none !important;\n  }\n  .d-xl-inline {\n    display: inline !important;\n  }\n  .d-xl-inline-block {\n    display: inline-block !important;\n  }\n  .d-xl-block {\n    display: block !important;\n  }\n  .d-xl-table {\n    display: table !important;\n  }\n  .d-xl-table-cell {\n    display: table-cell !important;\n  }\n  .d-xl-flex {\n    display: -webkit-box !important;\n    display: -webkit-flex !important;\n    display: -ms-flexbox !important;\n    display: flex !important;\n  }\n  .d-xl-inline-flex {\n    display: -webkit-inline-box !important;\n    display: -webkit-inline-flex !important;\n    display: -ms-inline-flexbox !important;\n    display: inline-flex !important;\n  }\n}\n\n.flex-first {\n  -webkit-box-ordinal-group: 0;\n  -webkit-order: -1;\n      -ms-flex-order: -1;\n          order: -1;\n}\n\n.flex-last {\n  -webkit-box-ordinal-group: 2;\n  -webkit-order: 1;\n      -ms-flex-order: 1;\n          order: 1;\n}\n\n.flex-unordered {\n  -webkit-box-ordinal-group: 1;\n  -webkit-order: 0;\n      -ms-flex-order: 0;\n          order: 0;\n}\n\n.flex-row {\n  -webkit-box-orient: horizontal !important;\n  -webkit-box-direction: normal !important;\n  -webkit-flex-direction: row !important;\n      -ms-flex-direction: row !important;\n          flex-direction: row !important;\n}\n\n.flex-column {\n  -webkit-box-orient: vertical !important;\n  -webkit-box-direction: normal !important;\n  -webkit-flex-direction: column !important;\n      -ms-flex-direction: column !important;\n          flex-direction: column !important;\n}\n\n.flex-row-reverse {\n  -webkit-box-orient: horizontal !important;\n  -webkit-box-direction: reverse !important;\n  -webkit-flex-direction: row-reverse !important;\n      -ms-flex-direction: row-reverse !important;\n          flex-direction: row-reverse !important;\n}\n\n.flex-column-reverse {\n  -webkit-box-orient: vertical !important;\n  -webkit-box-direction: reverse !important;\n  -webkit-flex-direction: column-reverse !important;\n      -ms-flex-direction: column-reverse !important;\n          flex-direction: column-reverse !important;\n}\n\n.flex-wrap {\n  -webkit-flex-wrap: wrap !important;\n      -ms-flex-wrap: wrap !important;\n          flex-wrap: wrap !important;\n}\n\n.flex-nowrap {\n  -webkit-flex-wrap: nowrap !important;\n      -ms-flex-wrap: nowrap !important;\n          flex-wrap: nowrap !important;\n}\n\n.flex-wrap-reverse {\n  -webkit-flex-wrap: wrap-reverse !important;\n      -ms-flex-wrap: wrap-reverse !important;\n          flex-wrap: wrap-reverse !important;\n}\n\n.justify-content-start {\n  -webkit-box-pack: start !important;\n  -webkit-justify-content: flex-start !important;\n      -ms-flex-pack: start !important;\n          justify-content: flex-start !important;\n}\n\n.justify-content-end {\n  -webkit-box-pack: end !important;\n  -webkit-justify-content: flex-end !important;\n      -ms-flex-pack: end !important;\n          justify-content: flex-end !important;\n}\n\n.justify-content-center {\n  -webkit-box-pack: center !important;\n  -webkit-justify-content: center !important;\n      -ms-flex-pack: center !important;\n          justify-content: center !important;\n}\n\n.justify-content-between {\n  -webkit-box-pack: justify !important;\n  -webkit-justify-content: space-between !important;\n      -ms-flex-pack: justify !important;\n          justify-content: space-between !important;\n}\n\n.justify-content-around {\n  -webkit-justify-content: space-around !important;\n      -ms-flex-pack: distribute !important;\n          justify-content: space-around !important;\n}\n\n.align-items-start {\n  -webkit-box-align: start !important;\n  -webkit-align-items: flex-start !important;\n      -ms-flex-align: start !important;\n          align-items: flex-start !important;\n}\n\n.align-items-end {\n  -webkit-box-align: end !important;\n  -webkit-align-items: flex-end !important;\n      -ms-flex-align: end !important;\n          align-items: flex-end !important;\n}\n\n.align-items-center {\n  -webkit-box-align: center !important;\n  -webkit-align-items: center !important;\n      -ms-flex-align: center !important;\n          align-items: center !important;\n}\n\n.align-items-baseline {\n  -webkit-box-align: baseline !important;\n  -webkit-align-items: baseline !important;\n      -ms-flex-align: baseline !important;\n          align-items: baseline !important;\n}\n\n.align-items-stretch {\n  -webkit-box-align: stretch !important;\n  -webkit-align-items: stretch !important;\n      -ms-flex-align: stretch !important;\n          align-items: stretch !important;\n}\n\n.align-content-start {\n  -webkit-align-content: flex-start !important;\n      -ms-flex-line-pack: start !important;\n          align-content: flex-start !important;\n}\n\n.align-content-end {\n  -webkit-align-content: flex-end !important;\n      -ms-flex-line-pack: end !important;\n          align-content: flex-end !important;\n}\n\n.align-content-center {\n  -webkit-align-content: center !important;\n      -ms-flex-line-pack: center !important;\n          align-content: center !important;\n}\n\n.align-content-between {\n  -webkit-align-content: space-between !important;\n      -ms-flex-line-pack: justify !important;\n          align-content: space-between !important;\n}\n\n.align-content-around {\n  -webkit-align-content: space-around !important;\n      -ms-flex-line-pack: distribute !important;\n          align-content: space-around !important;\n}\n\n.align-content-stretch {\n  -webkit-align-content: stretch !important;\n      -ms-flex-line-pack: stretch !important;\n          align-content: stretch !important;\n}\n\n.align-self-auto {\n  -webkit-align-self: auto !important;\n      -ms-flex-item-align: auto !important;\n              -ms-grid-row-align: auto !important;\n          align-self: auto !important;\n}\n\n.align-self-start {\n  -webkit-align-self: flex-start !important;\n      -ms-flex-item-align: start !important;\n          align-self: flex-start !important;\n}\n\n.align-self-end {\n  -webkit-align-self: flex-end !important;\n      -ms-flex-item-align: end !important;\n          align-self: flex-end !important;\n}\n\n.align-self-center {\n  -webkit-align-self: center !important;\n      -ms-flex-item-align: center !important;\n              -ms-grid-row-align: center !important;\n          align-self: center !important;\n}\n\n.align-self-baseline {\n  -webkit-align-self: baseline !important;\n      -ms-flex-item-align: baseline !important;\n          align-self: baseline !important;\n}\n\n.align-self-stretch {\n  -webkit-align-self: stretch !important;\n      -ms-flex-item-align: stretch !important;\n              -ms-grid-row-align: stretch !important;\n          align-self: stretch !important;\n}\n\n@media (min-width: 576px) {\n  .flex-sm-first {\n    -webkit-box-ordinal-group: 0;\n    -webkit-order: -1;\n        -ms-flex-order: -1;\n            order: -1;\n  }\n  .flex-sm-last {\n    -webkit-box-ordinal-group: 2;\n    -webkit-order: 1;\n        -ms-flex-order: 1;\n            order: 1;\n  }\n  .flex-sm-unordered {\n    -webkit-box-ordinal-group: 1;\n    -webkit-order: 0;\n        -ms-flex-order: 0;\n            order: 0;\n  }\n  .flex-sm-row {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: row !important;\n        -ms-flex-direction: row !important;\n            flex-direction: row !important;\n  }\n  .flex-sm-column {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: column !important;\n        -ms-flex-direction: column !important;\n            flex-direction: column !important;\n  }\n  .flex-sm-row-reverse {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: row-reverse !important;\n        -ms-flex-direction: row-reverse !important;\n            flex-direction: row-reverse !important;\n  }\n  .flex-sm-column-reverse {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: column-reverse !important;\n        -ms-flex-direction: column-reverse !important;\n            flex-direction: column-reverse !important;\n  }\n  .flex-sm-wrap {\n    -webkit-flex-wrap: wrap !important;\n        -ms-flex-wrap: wrap !important;\n            flex-wrap: wrap !important;\n  }\n  .flex-sm-nowrap {\n    -webkit-flex-wrap: nowrap !important;\n        -ms-flex-wrap: nowrap !important;\n            flex-wrap: nowrap !important;\n  }\n  .flex-sm-wrap-reverse {\n    -webkit-flex-wrap: wrap-reverse !important;\n        -ms-flex-wrap: wrap-reverse !important;\n            flex-wrap: wrap-reverse !important;\n  }\n  .justify-content-sm-start {\n    -webkit-box-pack: start !important;\n    -webkit-justify-content: flex-start !important;\n        -ms-flex-pack: start !important;\n            justify-content: flex-start !important;\n  }\n  .justify-content-sm-end {\n    -webkit-box-pack: end !important;\n    -webkit-justify-content: flex-end !important;\n        -ms-flex-pack: end !important;\n            justify-content: flex-end !important;\n  }\n  .justify-content-sm-center {\n    -webkit-box-pack: center !important;\n    -webkit-justify-content: center !important;\n        -ms-flex-pack: center !important;\n            justify-content: center !important;\n  }\n  .justify-content-sm-between {\n    -webkit-box-pack: justify !important;\n    -webkit-justify-content: space-between !important;\n        -ms-flex-pack: justify !important;\n            justify-content: space-between !important;\n  }\n  .justify-content-sm-around {\n    -webkit-justify-content: space-around !important;\n        -ms-flex-pack: distribute !important;\n            justify-content: space-around !important;\n  }\n  .align-items-sm-start {\n    -webkit-box-align: start !important;\n    -webkit-align-items: flex-start !important;\n        -ms-flex-align: start !important;\n            align-items: flex-start !important;\n  }\n  .align-items-sm-end {\n    -webkit-box-align: end !important;\n    -webkit-align-items: flex-end !important;\n        -ms-flex-align: end !important;\n            align-items: flex-end !important;\n  }\n  .align-items-sm-center {\n    -webkit-box-align: center !important;\n    -webkit-align-items: center !important;\n        -ms-flex-align: center !important;\n            align-items: center !important;\n  }\n  .align-items-sm-baseline {\n    -webkit-box-align: baseline !important;\n    -webkit-align-items: baseline !important;\n        -ms-flex-align: baseline !important;\n            align-items: baseline !important;\n  }\n  .align-items-sm-stretch {\n    -webkit-box-align: stretch !important;\n    -webkit-align-items: stretch !important;\n        -ms-flex-align: stretch !important;\n            align-items: stretch !important;\n  }\n  .align-content-sm-start {\n    -webkit-align-content: flex-start !important;\n        -ms-flex-line-pack: start !important;\n            align-content: flex-start !important;\n  }\n  .align-content-sm-end {\n    -webkit-align-content: flex-end !important;\n        -ms-flex-line-pack: end !important;\n            align-content: flex-end !important;\n  }\n  .align-content-sm-center {\n    -webkit-align-content: center !important;\n        -ms-flex-line-pack: center !important;\n            align-content: center !important;\n  }\n  .align-content-sm-between {\n    -webkit-align-content: space-between !important;\n        -ms-flex-line-pack: justify !important;\n            align-content: space-between !important;\n  }\n  .align-content-sm-around {\n    -webkit-align-content: space-around !important;\n        -ms-flex-line-pack: distribute !important;\n            align-content: space-around !important;\n  }\n  .align-content-sm-stretch {\n    -webkit-align-content: stretch !important;\n        -ms-flex-line-pack: stretch !important;\n            align-content: stretch !important;\n  }\n  .align-self-sm-auto {\n    -webkit-align-self: auto !important;\n        -ms-flex-item-align: auto !important;\n                -ms-grid-row-align: auto !important;\n            align-self: auto !important;\n  }\n  .align-self-sm-start {\n    -webkit-align-self: flex-start !important;\n        -ms-flex-item-align: start !important;\n            align-self: flex-start !important;\n  }\n  .align-self-sm-end {\n    -webkit-align-self: flex-end !important;\n        -ms-flex-item-align: end !important;\n            align-self: flex-end !important;\n  }\n  .align-self-sm-center {\n    -webkit-align-self: center !important;\n        -ms-flex-item-align: center !important;\n                -ms-grid-row-align: center !important;\n            align-self: center !important;\n  }\n  .align-self-sm-baseline {\n    -webkit-align-self: baseline !important;\n        -ms-flex-item-align: baseline !important;\n            align-self: baseline !important;\n  }\n  .align-self-sm-stretch {\n    -webkit-align-self: stretch !important;\n        -ms-flex-item-align: stretch !important;\n                -ms-grid-row-align: stretch !important;\n            align-self: stretch !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .flex-md-first {\n    -webkit-box-ordinal-group: 0;\n    -webkit-order: -1;\n        -ms-flex-order: -1;\n            order: -1;\n  }\n  .flex-md-last {\n    -webkit-box-ordinal-group: 2;\n    -webkit-order: 1;\n        -ms-flex-order: 1;\n            order: 1;\n  }\n  .flex-md-unordered {\n    -webkit-box-ordinal-group: 1;\n    -webkit-order: 0;\n        -ms-flex-order: 0;\n            order: 0;\n  }\n  .flex-md-row {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: row !important;\n        -ms-flex-direction: row !important;\n            flex-direction: row !important;\n  }\n  .flex-md-column {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: column !important;\n        -ms-flex-direction: column !important;\n            flex-direction: column !important;\n  }\n  .flex-md-row-reverse {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: row-reverse !important;\n        -ms-flex-direction: row-reverse !important;\n            flex-direction: row-reverse !important;\n  }\n  .flex-md-column-reverse {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: column-reverse !important;\n        -ms-flex-direction: column-reverse !important;\n            flex-direction: column-reverse !important;\n  }\n  .flex-md-wrap {\n    -webkit-flex-wrap: wrap !important;\n        -ms-flex-wrap: wrap !important;\n            flex-wrap: wrap !important;\n  }\n  .flex-md-nowrap {\n    -webkit-flex-wrap: nowrap !important;\n        -ms-flex-wrap: nowrap !important;\n            flex-wrap: nowrap !important;\n  }\n  .flex-md-wrap-reverse {\n    -webkit-flex-wrap: wrap-reverse !important;\n        -ms-flex-wrap: wrap-reverse !important;\n            flex-wrap: wrap-reverse !important;\n  }\n  .justify-content-md-start {\n    -webkit-box-pack: start !important;\n    -webkit-justify-content: flex-start !important;\n        -ms-flex-pack: start !important;\n            justify-content: flex-start !important;\n  }\n  .justify-content-md-end {\n    -webkit-box-pack: end !important;\n    -webkit-justify-content: flex-end !important;\n        -ms-flex-pack: end !important;\n            justify-content: flex-end !important;\n  }\n  .justify-content-md-center {\n    -webkit-box-pack: center !important;\n    -webkit-justify-content: center !important;\n        -ms-flex-pack: center !important;\n            justify-content: center !important;\n  }\n  .justify-content-md-between {\n    -webkit-box-pack: justify !important;\n    -webkit-justify-content: space-between !important;\n        -ms-flex-pack: justify !important;\n            justify-content: space-between !important;\n  }\n  .justify-content-md-around {\n    -webkit-justify-content: space-around !important;\n        -ms-flex-pack: distribute !important;\n            justify-content: space-around !important;\n  }\n  .align-items-md-start {\n    -webkit-box-align: start !important;\n    -webkit-align-items: flex-start !important;\n        -ms-flex-align: start !important;\n            align-items: flex-start !important;\n  }\n  .align-items-md-end {\n    -webkit-box-align: end !important;\n    -webkit-align-items: flex-end !important;\n        -ms-flex-align: end !important;\n            align-items: flex-end !important;\n  }\n  .align-items-md-center {\n    -webkit-box-align: center !important;\n    -webkit-align-items: center !important;\n        -ms-flex-align: center !important;\n            align-items: center !important;\n  }\n  .align-items-md-baseline {\n    -webkit-box-align: baseline !important;\n    -webkit-align-items: baseline !important;\n        -ms-flex-align: baseline !important;\n            align-items: baseline !important;\n  }\n  .align-items-md-stretch {\n    -webkit-box-align: stretch !important;\n    -webkit-align-items: stretch !important;\n        -ms-flex-align: stretch !important;\n            align-items: stretch !important;\n  }\n  .align-content-md-start {\n    -webkit-align-content: flex-start !important;\n        -ms-flex-line-pack: start !important;\n            align-content: flex-start !important;\n  }\n  .align-content-md-end {\n    -webkit-align-content: flex-end !important;\n        -ms-flex-line-pack: end !important;\n            align-content: flex-end !important;\n  }\n  .align-content-md-center {\n    -webkit-align-content: center !important;\n        -ms-flex-line-pack: center !important;\n            align-content: center !important;\n  }\n  .align-content-md-between {\n    -webkit-align-content: space-between !important;\n        -ms-flex-line-pack: justify !important;\n            align-content: space-between !important;\n  }\n  .align-content-md-around {\n    -webkit-align-content: space-around !important;\n        -ms-flex-line-pack: distribute !important;\n            align-content: space-around !important;\n  }\n  .align-content-md-stretch {\n    -webkit-align-content: stretch !important;\n        -ms-flex-line-pack: stretch !important;\n            align-content: stretch !important;\n  }\n  .align-self-md-auto {\n    -webkit-align-self: auto !important;\n        -ms-flex-item-align: auto !important;\n                -ms-grid-row-align: auto !important;\n            align-self: auto !important;\n  }\n  .align-self-md-start {\n    -webkit-align-self: flex-start !important;\n        -ms-flex-item-align: start !important;\n            align-self: flex-start !important;\n  }\n  .align-self-md-end {\n    -webkit-align-self: flex-end !important;\n        -ms-flex-item-align: end !important;\n            align-self: flex-end !important;\n  }\n  .align-self-md-center {\n    -webkit-align-self: center !important;\n        -ms-flex-item-align: center !important;\n                -ms-grid-row-align: center !important;\n            align-self: center !important;\n  }\n  .align-self-md-baseline {\n    -webkit-align-self: baseline !important;\n        -ms-flex-item-align: baseline !important;\n            align-self: baseline !important;\n  }\n  .align-self-md-stretch {\n    -webkit-align-self: stretch !important;\n        -ms-flex-item-align: stretch !important;\n                -ms-grid-row-align: stretch !important;\n            align-self: stretch !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .flex-lg-first {\n    -webkit-box-ordinal-group: 0;\n    -webkit-order: -1;\n        -ms-flex-order: -1;\n            order: -1;\n  }\n  .flex-lg-last {\n    -webkit-box-ordinal-group: 2;\n    -webkit-order: 1;\n        -ms-flex-order: 1;\n            order: 1;\n  }\n  .flex-lg-unordered {\n    -webkit-box-ordinal-group: 1;\n    -webkit-order: 0;\n        -ms-flex-order: 0;\n            order: 0;\n  }\n  .flex-lg-row {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: row !important;\n        -ms-flex-direction: row !important;\n            flex-direction: row !important;\n  }\n  .flex-lg-column {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: column !important;\n        -ms-flex-direction: column !important;\n            flex-direction: column !important;\n  }\n  .flex-lg-row-reverse {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: row-reverse !important;\n        -ms-flex-direction: row-reverse !important;\n            flex-direction: row-reverse !important;\n  }\n  .flex-lg-column-reverse {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: column-reverse !important;\n        -ms-flex-direction: column-reverse !important;\n            flex-direction: column-reverse !important;\n  }\n  .flex-lg-wrap {\n    -webkit-flex-wrap: wrap !important;\n        -ms-flex-wrap: wrap !important;\n            flex-wrap: wrap !important;\n  }\n  .flex-lg-nowrap {\n    -webkit-flex-wrap: nowrap !important;\n        -ms-flex-wrap: nowrap !important;\n            flex-wrap: nowrap !important;\n  }\n  .flex-lg-wrap-reverse {\n    -webkit-flex-wrap: wrap-reverse !important;\n        -ms-flex-wrap: wrap-reverse !important;\n            flex-wrap: wrap-reverse !important;\n  }\n  .justify-content-lg-start {\n    -webkit-box-pack: start !important;\n    -webkit-justify-content: flex-start !important;\n        -ms-flex-pack: start !important;\n            justify-content: flex-start !important;\n  }\n  .justify-content-lg-end {\n    -webkit-box-pack: end !important;\n    -webkit-justify-content: flex-end !important;\n        -ms-flex-pack: end !important;\n            justify-content: flex-end !important;\n  }\n  .justify-content-lg-center {\n    -webkit-box-pack: center !important;\n    -webkit-justify-content: center !important;\n        -ms-flex-pack: center !important;\n            justify-content: center !important;\n  }\n  .justify-content-lg-between {\n    -webkit-box-pack: justify !important;\n    -webkit-justify-content: space-between !important;\n        -ms-flex-pack: justify !important;\n            justify-content: space-between !important;\n  }\n  .justify-content-lg-around {\n    -webkit-justify-content: space-around !important;\n        -ms-flex-pack: distribute !important;\n            justify-content: space-around !important;\n  }\n  .align-items-lg-start {\n    -webkit-box-align: start !important;\n    -webkit-align-items: flex-start !important;\n        -ms-flex-align: start !important;\n            align-items: flex-start !important;\n  }\n  .align-items-lg-end {\n    -webkit-box-align: end !important;\n    -webkit-align-items: flex-end !important;\n        -ms-flex-align: end !important;\n            align-items: flex-end !important;\n  }\n  .align-items-lg-center {\n    -webkit-box-align: center !important;\n    -webkit-align-items: center !important;\n        -ms-flex-align: center !important;\n            align-items: center !important;\n  }\n  .align-items-lg-baseline {\n    -webkit-box-align: baseline !important;\n    -webkit-align-items: baseline !important;\n        -ms-flex-align: baseline !important;\n            align-items: baseline !important;\n  }\n  .align-items-lg-stretch {\n    -webkit-box-align: stretch !important;\n    -webkit-align-items: stretch !important;\n        -ms-flex-align: stretch !important;\n            align-items: stretch !important;\n  }\n  .align-content-lg-start {\n    -webkit-align-content: flex-start !important;\n        -ms-flex-line-pack: start !important;\n            align-content: flex-start !important;\n  }\n  .align-content-lg-end {\n    -webkit-align-content: flex-end !important;\n        -ms-flex-line-pack: end !important;\n            align-content: flex-end !important;\n  }\n  .align-content-lg-center {\n    -webkit-align-content: center !important;\n        -ms-flex-line-pack: center !important;\n            align-content: center !important;\n  }\n  .align-content-lg-between {\n    -webkit-align-content: space-between !important;\n        -ms-flex-line-pack: justify !important;\n            align-content: space-between !important;\n  }\n  .align-content-lg-around {\n    -webkit-align-content: space-around !important;\n        -ms-flex-line-pack: distribute !important;\n            align-content: space-around !important;\n  }\n  .align-content-lg-stretch {\n    -webkit-align-content: stretch !important;\n        -ms-flex-line-pack: stretch !important;\n            align-content: stretch !important;\n  }\n  .align-self-lg-auto {\n    -webkit-align-self: auto !important;\n        -ms-flex-item-align: auto !important;\n                -ms-grid-row-align: auto !important;\n            align-self: auto !important;\n  }\n  .align-self-lg-start {\n    -webkit-align-self: flex-start !important;\n        -ms-flex-item-align: start !important;\n            align-self: flex-start !important;\n  }\n  .align-self-lg-end {\n    -webkit-align-self: flex-end !important;\n        -ms-flex-item-align: end !important;\n            align-self: flex-end !important;\n  }\n  .align-self-lg-center {\n    -webkit-align-self: center !important;\n        -ms-flex-item-align: center !important;\n                -ms-grid-row-align: center !important;\n            align-self: center !important;\n  }\n  .align-self-lg-baseline {\n    -webkit-align-self: baseline !important;\n        -ms-flex-item-align: baseline !important;\n            align-self: baseline !important;\n  }\n  .align-self-lg-stretch {\n    -webkit-align-self: stretch !important;\n        -ms-flex-item-align: stretch !important;\n                -ms-grid-row-align: stretch !important;\n            align-self: stretch !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .flex-xl-first {\n    -webkit-box-ordinal-group: 0;\n    -webkit-order: -1;\n        -ms-flex-order: -1;\n            order: -1;\n  }\n  .flex-xl-last {\n    -webkit-box-ordinal-group: 2;\n    -webkit-order: 1;\n        -ms-flex-order: 1;\n            order: 1;\n  }\n  .flex-xl-unordered {\n    -webkit-box-ordinal-group: 1;\n    -webkit-order: 0;\n        -ms-flex-order: 0;\n            order: 0;\n  }\n  .flex-xl-row {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: row !important;\n        -ms-flex-direction: row !important;\n            flex-direction: row !important;\n  }\n  .flex-xl-column {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: normal !important;\n    -webkit-flex-direction: column !important;\n        -ms-flex-direction: column !important;\n            flex-direction: column !important;\n  }\n  .flex-xl-row-reverse {\n    -webkit-box-orient: horizontal !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: row-reverse !important;\n        -ms-flex-direction: row-reverse !important;\n            flex-direction: row-reverse !important;\n  }\n  .flex-xl-column-reverse {\n    -webkit-box-orient: vertical !important;\n    -webkit-box-direction: reverse !important;\n    -webkit-flex-direction: column-reverse !important;\n        -ms-flex-direction: column-reverse !important;\n            flex-direction: column-reverse !important;\n  }\n  .flex-xl-wrap {\n    -webkit-flex-wrap: wrap !important;\n        -ms-flex-wrap: wrap !important;\n            flex-wrap: wrap !important;\n  }\n  .flex-xl-nowrap {\n    -webkit-flex-wrap: nowrap !important;\n        -ms-flex-wrap: nowrap !important;\n            flex-wrap: nowrap !important;\n  }\n  .flex-xl-wrap-reverse {\n    -webkit-flex-wrap: wrap-reverse !important;\n        -ms-flex-wrap: wrap-reverse !important;\n            flex-wrap: wrap-reverse !important;\n  }\n  .justify-content-xl-start {\n    -webkit-box-pack: start !important;\n    -webkit-justify-content: flex-start !important;\n        -ms-flex-pack: start !important;\n            justify-content: flex-start !important;\n  }\n  .justify-content-xl-end {\n    -webkit-box-pack: end !important;\n    -webkit-justify-content: flex-end !important;\n        -ms-flex-pack: end !important;\n            justify-content: flex-end !important;\n  }\n  .justify-content-xl-center {\n    -webkit-box-pack: center !important;\n    -webkit-justify-content: center !important;\n        -ms-flex-pack: center !important;\n            justify-content: center !important;\n  }\n  .justify-content-xl-between {\n    -webkit-box-pack: justify !important;\n    -webkit-justify-content: space-between !important;\n        -ms-flex-pack: justify !important;\n            justify-content: space-between !important;\n  }\n  .justify-content-xl-around {\n    -webkit-justify-content: space-around !important;\n        -ms-flex-pack: distribute !important;\n            justify-content: space-around !important;\n  }\n  .align-items-xl-start {\n    -webkit-box-align: start !important;\n    -webkit-align-items: flex-start !important;\n        -ms-flex-align: start !important;\n            align-items: flex-start !important;\n  }\n  .align-items-xl-end {\n    -webkit-box-align: end !important;\n    -webkit-align-items: flex-end !important;\n        -ms-flex-align: end !important;\n            align-items: flex-end !important;\n  }\n  .align-items-xl-center {\n    -webkit-box-align: center !important;\n    -webkit-align-items: center !important;\n        -ms-flex-align: center !important;\n            align-items: center !important;\n  }\n  .align-items-xl-baseline {\n    -webkit-box-align: baseline !important;\n    -webkit-align-items: baseline !important;\n        -ms-flex-align: baseline !important;\n            align-items: baseline !important;\n  }\n  .align-items-xl-stretch {\n    -webkit-box-align: stretch !important;\n    -webkit-align-items: stretch !important;\n        -ms-flex-align: stretch !important;\n            align-items: stretch !important;\n  }\n  .align-content-xl-start {\n    -webkit-align-content: flex-start !important;\n        -ms-flex-line-pack: start !important;\n            align-content: flex-start !important;\n  }\n  .align-content-xl-end {\n    -webkit-align-content: flex-end !important;\n        -ms-flex-line-pack: end !important;\n            align-content: flex-end !important;\n  }\n  .align-content-xl-center {\n    -webkit-align-content: center !important;\n        -ms-flex-line-pack: center !important;\n            align-content: center !important;\n  }\n  .align-content-xl-between {\n    -webkit-align-content: space-between !important;\n        -ms-flex-line-pack: justify !important;\n            align-content: space-between !important;\n  }\n  .align-content-xl-around {\n    -webkit-align-content: space-around !important;\n        -ms-flex-line-pack: distribute !important;\n            align-content: space-around !important;\n  }\n  .align-content-xl-stretch {\n    -webkit-align-content: stretch !important;\n        -ms-flex-line-pack: stretch !important;\n            align-content: stretch !important;\n  }\n  .align-self-xl-auto {\n    -webkit-align-self: auto !important;\n        -ms-flex-item-align: auto !important;\n                -ms-grid-row-align: auto !important;\n            align-self: auto !important;\n  }\n  .align-self-xl-start {\n    -webkit-align-self: flex-start !important;\n        -ms-flex-item-align: start !important;\n            align-self: flex-start !important;\n  }\n  .align-self-xl-end {\n    -webkit-align-self: flex-end !important;\n        -ms-flex-item-align: end !important;\n            align-self: flex-end !important;\n  }\n  .align-self-xl-center {\n    -webkit-align-self: center !important;\n        -ms-flex-item-align: center !important;\n                -ms-grid-row-align: center !important;\n            align-self: center !important;\n  }\n  .align-self-xl-baseline {\n    -webkit-align-self: baseline !important;\n        -ms-flex-item-align: baseline !important;\n            align-self: baseline !important;\n  }\n  .align-self-xl-stretch {\n    -webkit-align-self: stretch !important;\n        -ms-flex-item-align: stretch !important;\n                -ms-grid-row-align: stretch !important;\n            align-self: stretch !important;\n  }\n}\n\n.float-left {\n  float: left !important;\n}\n\n.float-right {\n  float: right !important;\n}\n\n.float-none {\n  float: none !important;\n}\n\n@media (min-width: 576px) {\n  .float-sm-left {\n    float: left !important;\n  }\n  .float-sm-right {\n    float: right !important;\n  }\n  .float-sm-none {\n    float: none !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .float-md-left {\n    float: left !important;\n  }\n  .float-md-right {\n    float: right !important;\n  }\n  .float-md-none {\n    float: none !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .float-lg-left {\n    float: left !important;\n  }\n  .float-lg-right {\n    float: right !important;\n  }\n  .float-lg-none {\n    float: none !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .float-xl-left {\n    float: left !important;\n  }\n  .float-xl-right {\n    float: right !important;\n  }\n  .float-xl-none {\n    float: none !important;\n  }\n}\n\n.fixed-top {\n  position: fixed;\n  top: 0;\n  right: 0;\n  left: 0;\n  z-index: 1030;\n}\n\n.fixed-bottom {\n  position: fixed;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1030;\n}\n\n.sticky-top {\n  position: -webkit-sticky;\n  position: sticky;\n  top: 0;\n  z-index: 1030;\n}\n\n.sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  margin: -1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  border: 0;\n}\n\n.sr-only-focusable:active, .sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n\n.w-25 {\n  width: 25% !important;\n}\n\n.w-50 {\n  width: 50% !important;\n}\n\n.w-75 {\n  width: 75% !important;\n}\n\n.w-100 {\n  width: 100% !important;\n}\n\n.h-25 {\n  height: 25% !important;\n}\n\n.h-50 {\n  height: 50% !important;\n}\n\n.h-75 {\n  height: 75% !important;\n}\n\n.h-100 {\n  height: 100% !important;\n}\n\n.mw-100 {\n  max-width: 100% !important;\n}\n\n.mh-100 {\n  max-height: 100% !important;\n}\n\n.m-0 {\n  margin: 0 0 !important;\n}\n\n.mt-0 {\n  margin-top: 0 !important;\n}\n\n.mr-0 {\n  margin-right: 0 !important;\n}\n\n.mb-0 {\n  margin-bottom: 0 !important;\n}\n\n.ml-0 {\n  margin-left: 0 !important;\n}\n\n.mx-0 {\n  margin-right: 0 !important;\n  margin-left: 0 !important;\n}\n\n.my-0 {\n  margin-top: 0 !important;\n  margin-bottom: 0 !important;\n}\n\n.m-1 {\n  margin: 0.25rem 0.25rem !important;\n}\n\n.mt-1 {\n  margin-top: 0.25rem !important;\n}\n\n.mr-1 {\n  margin-right: 0.25rem !important;\n}\n\n.mb-1 {\n  margin-bottom: 0.25rem !important;\n}\n\n.ml-1 {\n  margin-left: 0.25rem !important;\n}\n\n.mx-1 {\n  margin-right: 0.25rem !important;\n  margin-left: 0.25rem !important;\n}\n\n.my-1 {\n  margin-top: 0.25rem !important;\n  margin-bottom: 0.25rem !important;\n}\n\n.m-2 {\n  margin: 0.5rem 0.5rem !important;\n}\n\n.mt-2 {\n  margin-top: 0.5rem !important;\n}\n\n.mr-2 {\n  margin-right: 0.5rem !important;\n}\n\n.mb-2 {\n  margin-bottom: 0.5rem !important;\n}\n\n.ml-2 {\n  margin-left: 0.5rem !important;\n}\n\n.mx-2 {\n  margin-right: 0.5rem !important;\n  margin-left: 0.5rem !important;\n}\n\n.my-2 {\n  margin-top: 0.5rem !important;\n  margin-bottom: 0.5rem !important;\n}\n\n.m-3 {\n  margin: 1rem 1rem !important;\n}\n\n.mt-3 {\n  margin-top: 1rem !important;\n}\n\n.mr-3 {\n  margin-right: 1rem !important;\n}\n\n.mb-3 {\n  margin-bottom: 1rem !important;\n}\n\n.ml-3 {\n  margin-left: 1rem !important;\n}\n\n.mx-3 {\n  margin-right: 1rem !important;\n  margin-left: 1rem !important;\n}\n\n.my-3 {\n  margin-top: 1rem !important;\n  margin-bottom: 1rem !important;\n}\n\n.m-4 {\n  margin: 1.5rem 1.5rem !important;\n}\n\n.mt-4 {\n  margin-top: 1.5rem !important;\n}\n\n.mr-4 {\n  margin-right: 1.5rem !important;\n}\n\n.mb-4 {\n  margin-bottom: 1.5rem !important;\n}\n\n.ml-4 {\n  margin-left: 1.5rem !important;\n}\n\n.mx-4 {\n  margin-right: 1.5rem !important;\n  margin-left: 1.5rem !important;\n}\n\n.my-4 {\n  margin-top: 1.5rem !important;\n  margin-bottom: 1.5rem !important;\n}\n\n.m-5 {\n  margin: 3rem 3rem !important;\n}\n\n.mt-5 {\n  margin-top: 3rem !important;\n}\n\n.mr-5 {\n  margin-right: 3rem !important;\n}\n\n.mb-5 {\n  margin-bottom: 3rem !important;\n}\n\n.ml-5 {\n  margin-left: 3rem !important;\n}\n\n.mx-5 {\n  margin-right: 3rem !important;\n  margin-left: 3rem !important;\n}\n\n.my-5 {\n  margin-top: 3rem !important;\n  margin-bottom: 3rem !important;\n}\n\n.p-0 {\n  padding: 0 0 !important;\n}\n\n.pt-0 {\n  padding-top: 0 !important;\n}\n\n.pr-0 {\n  padding-right: 0 !important;\n}\n\n.pb-0 {\n  padding-bottom: 0 !important;\n}\n\n.pl-0 {\n  padding-left: 0 !important;\n}\n\n.px-0 {\n  padding-right: 0 !important;\n  padding-left: 0 !important;\n}\n\n.py-0 {\n  padding-top: 0 !important;\n  padding-bottom: 0 !important;\n}\n\n.p-1 {\n  padding: 0.25rem 0.25rem !important;\n}\n\n.pt-1 {\n  padding-top: 0.25rem !important;\n}\n\n.pr-1 {\n  padding-right: 0.25rem !important;\n}\n\n.pb-1 {\n  padding-bottom: 0.25rem !important;\n}\n\n.pl-1 {\n  padding-left: 0.25rem !important;\n}\n\n.px-1 {\n  padding-right: 0.25rem !important;\n  padding-left: 0.25rem !important;\n}\n\n.py-1 {\n  padding-top: 0.25rem !important;\n  padding-bottom: 0.25rem !important;\n}\n\n.p-2 {\n  padding: 0.5rem 0.5rem !important;\n}\n\n.pt-2 {\n  padding-top: 0.5rem !important;\n}\n\n.pr-2 {\n  padding-right: 0.5rem !important;\n}\n\n.pb-2 {\n  padding-bottom: 0.5rem !important;\n}\n\n.pl-2 {\n  padding-left: 0.5rem !important;\n}\n\n.px-2 {\n  padding-right: 0.5rem !important;\n  padding-left: 0.5rem !important;\n}\n\n.py-2 {\n  padding-top: 0.5rem !important;\n  padding-bottom: 0.5rem !important;\n}\n\n.p-3 {\n  padding: 1rem 1rem !important;\n}\n\n.pt-3 {\n  padding-top: 1rem !important;\n}\n\n.pr-3 {\n  padding-right: 1rem !important;\n}\n\n.pb-3 {\n  padding-bottom: 1rem !important;\n}\n\n.pl-3 {\n  padding-left: 1rem !important;\n}\n\n.px-3 {\n  padding-right: 1rem !important;\n  padding-left: 1rem !important;\n}\n\n.py-3 {\n  padding-top: 1rem !important;\n  padding-bottom: 1rem !important;\n}\n\n.p-4 {\n  padding: 1.5rem 1.5rem !important;\n}\n\n.pt-4 {\n  padding-top: 1.5rem !important;\n}\n\n.pr-4 {\n  padding-right: 1.5rem !important;\n}\n\n.pb-4 {\n  padding-bottom: 1.5rem !important;\n}\n\n.pl-4 {\n  padding-left: 1.5rem !important;\n}\n\n.px-4 {\n  padding-right: 1.5rem !important;\n  padding-left: 1.5rem !important;\n}\n\n.py-4 {\n  padding-top: 1.5rem !important;\n  padding-bottom: 1.5rem !important;\n}\n\n.p-5 {\n  padding: 3rem 3rem !important;\n}\n\n.pt-5 {\n  padding-top: 3rem !important;\n}\n\n.pr-5 {\n  padding-right: 3rem !important;\n}\n\n.pb-5 {\n  padding-bottom: 3rem !important;\n}\n\n.pl-5 {\n  padding-left: 3rem !important;\n}\n\n.px-5 {\n  padding-right: 3rem !important;\n  padding-left: 3rem !important;\n}\n\n.py-5 {\n  padding-top: 3rem !important;\n  padding-bottom: 3rem !important;\n}\n\n.m-auto {\n  margin: auto !important;\n}\n\n.mt-auto {\n  margin-top: auto !important;\n}\n\n.mr-auto {\n  margin-right: auto !important;\n}\n\n.mb-auto {\n  margin-bottom: auto !important;\n}\n\n.ml-auto {\n  margin-left: auto !important;\n}\n\n.mx-auto {\n  margin-right: auto !important;\n  margin-left: auto !important;\n}\n\n.my-auto {\n  margin-top: auto !important;\n  margin-bottom: auto !important;\n}\n\n@media (min-width: 576px) {\n  .m-sm-0 {\n    margin: 0 0 !important;\n  }\n  .mt-sm-0 {\n    margin-top: 0 !important;\n  }\n  .mr-sm-0 {\n    margin-right: 0 !important;\n  }\n  .mb-sm-0 {\n    margin-bottom: 0 !important;\n  }\n  .ml-sm-0 {\n    margin-left: 0 !important;\n  }\n  .mx-sm-0 {\n    margin-right: 0 !important;\n    margin-left: 0 !important;\n  }\n  .my-sm-0 {\n    margin-top: 0 !important;\n    margin-bottom: 0 !important;\n  }\n  .m-sm-1 {\n    margin: 0.25rem 0.25rem !important;\n  }\n  .mt-sm-1 {\n    margin-top: 0.25rem !important;\n  }\n  .mr-sm-1 {\n    margin-right: 0.25rem !important;\n  }\n  .mb-sm-1 {\n    margin-bottom: 0.25rem !important;\n  }\n  .ml-sm-1 {\n    margin-left: 0.25rem !important;\n  }\n  .mx-sm-1 {\n    margin-right: 0.25rem !important;\n    margin-left: 0.25rem !important;\n  }\n  .my-sm-1 {\n    margin-top: 0.25rem !important;\n    margin-bottom: 0.25rem !important;\n  }\n  .m-sm-2 {\n    margin: 0.5rem 0.5rem !important;\n  }\n  .mt-sm-2 {\n    margin-top: 0.5rem !important;\n  }\n  .mr-sm-2 {\n    margin-right: 0.5rem !important;\n  }\n  .mb-sm-2 {\n    margin-bottom: 0.5rem !important;\n  }\n  .ml-sm-2 {\n    margin-left: 0.5rem !important;\n  }\n  .mx-sm-2 {\n    margin-right: 0.5rem !important;\n    margin-left: 0.5rem !important;\n  }\n  .my-sm-2 {\n    margin-top: 0.5rem !important;\n    margin-bottom: 0.5rem !important;\n  }\n  .m-sm-3 {\n    margin: 1rem 1rem !important;\n  }\n  .mt-sm-3 {\n    margin-top: 1rem !important;\n  }\n  .mr-sm-3 {\n    margin-right: 1rem !important;\n  }\n  .mb-sm-3 {\n    margin-bottom: 1rem !important;\n  }\n  .ml-sm-3 {\n    margin-left: 1rem !important;\n  }\n  .mx-sm-3 {\n    margin-right: 1rem !important;\n    margin-left: 1rem !important;\n  }\n  .my-sm-3 {\n    margin-top: 1rem !important;\n    margin-bottom: 1rem !important;\n  }\n  .m-sm-4 {\n    margin: 1.5rem 1.5rem !important;\n  }\n  .mt-sm-4 {\n    margin-top: 1.5rem !important;\n  }\n  .mr-sm-4 {\n    margin-right: 1.5rem !important;\n  }\n  .mb-sm-4 {\n    margin-bottom: 1.5rem !important;\n  }\n  .ml-sm-4 {\n    margin-left: 1.5rem !important;\n  }\n  .mx-sm-4 {\n    margin-right: 1.5rem !important;\n    margin-left: 1.5rem !important;\n  }\n  .my-sm-4 {\n    margin-top: 1.5rem !important;\n    margin-bottom: 1.5rem !important;\n  }\n  .m-sm-5 {\n    margin: 3rem 3rem !important;\n  }\n  .mt-sm-5 {\n    margin-top: 3rem !important;\n  }\n  .mr-sm-5 {\n    margin-right: 3rem !important;\n  }\n  .mb-sm-5 {\n    margin-bottom: 3rem !important;\n  }\n  .ml-sm-5 {\n    margin-left: 3rem !important;\n  }\n  .mx-sm-5 {\n    margin-right: 3rem !important;\n    margin-left: 3rem !important;\n  }\n  .my-sm-5 {\n    margin-top: 3rem !important;\n    margin-bottom: 3rem !important;\n  }\n  .p-sm-0 {\n    padding: 0 0 !important;\n  }\n  .pt-sm-0 {\n    padding-top: 0 !important;\n  }\n  .pr-sm-0 {\n    padding-right: 0 !important;\n  }\n  .pb-sm-0 {\n    padding-bottom: 0 !important;\n  }\n  .pl-sm-0 {\n    padding-left: 0 !important;\n  }\n  .px-sm-0 {\n    padding-right: 0 !important;\n    padding-left: 0 !important;\n  }\n  .py-sm-0 {\n    padding-top: 0 !important;\n    padding-bottom: 0 !important;\n  }\n  .p-sm-1 {\n    padding: 0.25rem 0.25rem !important;\n  }\n  .pt-sm-1 {\n    padding-top: 0.25rem !important;\n  }\n  .pr-sm-1 {\n    padding-right: 0.25rem !important;\n  }\n  .pb-sm-1 {\n    padding-bottom: 0.25rem !important;\n  }\n  .pl-sm-1 {\n    padding-left: 0.25rem !important;\n  }\n  .px-sm-1 {\n    padding-right: 0.25rem !important;\n    padding-left: 0.25rem !important;\n  }\n  .py-sm-1 {\n    padding-top: 0.25rem !important;\n    padding-bottom: 0.25rem !important;\n  }\n  .p-sm-2 {\n    padding: 0.5rem 0.5rem !important;\n  }\n  .pt-sm-2 {\n    padding-top: 0.5rem !important;\n  }\n  .pr-sm-2 {\n    padding-right: 0.5rem !important;\n  }\n  .pb-sm-2 {\n    padding-bottom: 0.5rem !important;\n  }\n  .pl-sm-2 {\n    padding-left: 0.5rem !important;\n  }\n  .px-sm-2 {\n    padding-right: 0.5rem !important;\n    padding-left: 0.5rem !important;\n  }\n  .py-sm-2 {\n    padding-top: 0.5rem !important;\n    padding-bottom: 0.5rem !important;\n  }\n  .p-sm-3 {\n    padding: 1rem 1rem !important;\n  }\n  .pt-sm-3 {\n    padding-top: 1rem !important;\n  }\n  .pr-sm-3 {\n    padding-right: 1rem !important;\n  }\n  .pb-sm-3 {\n    padding-bottom: 1rem !important;\n  }\n  .pl-sm-3 {\n    padding-left: 1rem !important;\n  }\n  .px-sm-3 {\n    padding-right: 1rem !important;\n    padding-left: 1rem !important;\n  }\n  .py-sm-3 {\n    padding-top: 1rem !important;\n    padding-bottom: 1rem !important;\n  }\n  .p-sm-4 {\n    padding: 1.5rem 1.5rem !important;\n  }\n  .pt-sm-4 {\n    padding-top: 1.5rem !important;\n  }\n  .pr-sm-4 {\n    padding-right: 1.5rem !important;\n  }\n  .pb-sm-4 {\n    padding-bottom: 1.5rem !important;\n  }\n  .pl-sm-4 {\n    padding-left: 1.5rem !important;\n  }\n  .px-sm-4 {\n    padding-right: 1.5rem !important;\n    padding-left: 1.5rem !important;\n  }\n  .py-sm-4 {\n    padding-top: 1.5rem !important;\n    padding-bottom: 1.5rem !important;\n  }\n  .p-sm-5 {\n    padding: 3rem 3rem !important;\n  }\n  .pt-sm-5 {\n    padding-top: 3rem !important;\n  }\n  .pr-sm-5 {\n    padding-right: 3rem !important;\n  }\n  .pb-sm-5 {\n    padding-bottom: 3rem !important;\n  }\n  .pl-sm-5 {\n    padding-left: 3rem !important;\n  }\n  .px-sm-5 {\n    padding-right: 3rem !important;\n    padding-left: 3rem !important;\n  }\n  .py-sm-5 {\n    padding-top: 3rem !important;\n    padding-bottom: 3rem !important;\n  }\n  .m-sm-auto {\n    margin: auto !important;\n  }\n  .mt-sm-auto {\n    margin-top: auto !important;\n  }\n  .mr-sm-auto {\n    margin-right: auto !important;\n  }\n  .mb-sm-auto {\n    margin-bottom: auto !important;\n  }\n  .ml-sm-auto {\n    margin-left: auto !important;\n  }\n  .mx-sm-auto {\n    margin-right: auto !important;\n    margin-left: auto !important;\n  }\n  .my-sm-auto {\n    margin-top: auto !important;\n    margin-bottom: auto !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .m-md-0 {\n    margin: 0 0 !important;\n  }\n  .mt-md-0 {\n    margin-top: 0 !important;\n  }\n  .mr-md-0 {\n    margin-right: 0 !important;\n  }\n  .mb-md-0 {\n    margin-bottom: 0 !important;\n  }\n  .ml-md-0 {\n    margin-left: 0 !important;\n  }\n  .mx-md-0 {\n    margin-right: 0 !important;\n    margin-left: 0 !important;\n  }\n  .my-md-0 {\n    margin-top: 0 !important;\n    margin-bottom: 0 !important;\n  }\n  .m-md-1 {\n    margin: 0.25rem 0.25rem !important;\n  }\n  .mt-md-1 {\n    margin-top: 0.25rem !important;\n  }\n  .mr-md-1 {\n    margin-right: 0.25rem !important;\n  }\n  .mb-md-1 {\n    margin-bottom: 0.25rem !important;\n  }\n  .ml-md-1 {\n    margin-left: 0.25rem !important;\n  }\n  .mx-md-1 {\n    margin-right: 0.25rem !important;\n    margin-left: 0.25rem !important;\n  }\n  .my-md-1 {\n    margin-top: 0.25rem !important;\n    margin-bottom: 0.25rem !important;\n  }\n  .m-md-2 {\n    margin: 0.5rem 0.5rem !important;\n  }\n  .mt-md-2 {\n    margin-top: 0.5rem !important;\n  }\n  .mr-md-2 {\n    margin-right: 0.5rem !important;\n  }\n  .mb-md-2 {\n    margin-bottom: 0.5rem !important;\n  }\n  .ml-md-2 {\n    margin-left: 0.5rem !important;\n  }\n  .mx-md-2 {\n    margin-right: 0.5rem !important;\n    margin-left: 0.5rem !important;\n  }\n  .my-md-2 {\n    margin-top: 0.5rem !important;\n    margin-bottom: 0.5rem !important;\n  }\n  .m-md-3 {\n    margin: 1rem 1rem !important;\n  }\n  .mt-md-3 {\n    margin-top: 1rem !important;\n  }\n  .mr-md-3 {\n    margin-right: 1rem !important;\n  }\n  .mb-md-3 {\n    margin-bottom: 1rem !important;\n  }\n  .ml-md-3 {\n    margin-left: 1rem !important;\n  }\n  .mx-md-3 {\n    margin-right: 1rem !important;\n    margin-left: 1rem !important;\n  }\n  .my-md-3 {\n    margin-top: 1rem !important;\n    margin-bottom: 1rem !important;\n  }\n  .m-md-4 {\n    margin: 1.5rem 1.5rem !important;\n  }\n  .mt-md-4 {\n    margin-top: 1.5rem !important;\n  }\n  .mr-md-4 {\n    margin-right: 1.5rem !important;\n  }\n  .mb-md-4 {\n    margin-bottom: 1.5rem !important;\n  }\n  .ml-md-4 {\n    margin-left: 1.5rem !important;\n  }\n  .mx-md-4 {\n    margin-right: 1.5rem !important;\n    margin-left: 1.5rem !important;\n  }\n  .my-md-4 {\n    margin-top: 1.5rem !important;\n    margin-bottom: 1.5rem !important;\n  }\n  .m-md-5 {\n    margin: 3rem 3rem !important;\n  }\n  .mt-md-5 {\n    margin-top: 3rem !important;\n  }\n  .mr-md-5 {\n    margin-right: 3rem !important;\n  }\n  .mb-md-5 {\n    margin-bottom: 3rem !important;\n  }\n  .ml-md-5 {\n    margin-left: 3rem !important;\n  }\n  .mx-md-5 {\n    margin-right: 3rem !important;\n    margin-left: 3rem !important;\n  }\n  .my-md-5 {\n    margin-top: 3rem !important;\n    margin-bottom: 3rem !important;\n  }\n  .p-md-0 {\n    padding: 0 0 !important;\n  }\n  .pt-md-0 {\n    padding-top: 0 !important;\n  }\n  .pr-md-0 {\n    padding-right: 0 !important;\n  }\n  .pb-md-0 {\n    padding-bottom: 0 !important;\n  }\n  .pl-md-0 {\n    padding-left: 0 !important;\n  }\n  .px-md-0 {\n    padding-right: 0 !important;\n    padding-left: 0 !important;\n  }\n  .py-md-0 {\n    padding-top: 0 !important;\n    padding-bottom: 0 !important;\n  }\n  .p-md-1 {\n    padding: 0.25rem 0.25rem !important;\n  }\n  .pt-md-1 {\n    padding-top: 0.25rem !important;\n  }\n  .pr-md-1 {\n    padding-right: 0.25rem !important;\n  }\n  .pb-md-1 {\n    padding-bottom: 0.25rem !important;\n  }\n  .pl-md-1 {\n    padding-left: 0.25rem !important;\n  }\n  .px-md-1 {\n    padding-right: 0.25rem !important;\n    padding-left: 0.25rem !important;\n  }\n  .py-md-1 {\n    padding-top: 0.25rem !important;\n    padding-bottom: 0.25rem !important;\n  }\n  .p-md-2 {\n    padding: 0.5rem 0.5rem !important;\n  }\n  .pt-md-2 {\n    padding-top: 0.5rem !important;\n  }\n  .pr-md-2 {\n    padding-right: 0.5rem !important;\n  }\n  .pb-md-2 {\n    padding-bottom: 0.5rem !important;\n  }\n  .pl-md-2 {\n    padding-left: 0.5rem !important;\n  }\n  .px-md-2 {\n    padding-right: 0.5rem !important;\n    padding-left: 0.5rem !important;\n  }\n  .py-md-2 {\n    padding-top: 0.5rem !important;\n    padding-bottom: 0.5rem !important;\n  }\n  .p-md-3 {\n    padding: 1rem 1rem !important;\n  }\n  .pt-md-3 {\n    padding-top: 1rem !important;\n  }\n  .pr-md-3 {\n    padding-right: 1rem !important;\n  }\n  .pb-md-3 {\n    padding-bottom: 1rem !important;\n  }\n  .pl-md-3 {\n    padding-left: 1rem !important;\n  }\n  .px-md-3 {\n    padding-right: 1rem !important;\n    padding-left: 1rem !important;\n  }\n  .py-md-3 {\n    padding-top: 1rem !important;\n    padding-bottom: 1rem !important;\n  }\n  .p-md-4 {\n    padding: 1.5rem 1.5rem !important;\n  }\n  .pt-md-4 {\n    padding-top: 1.5rem !important;\n  }\n  .pr-md-4 {\n    padding-right: 1.5rem !important;\n  }\n  .pb-md-4 {\n    padding-bottom: 1.5rem !important;\n  }\n  .pl-md-4 {\n    padding-left: 1.5rem !important;\n  }\n  .px-md-4 {\n    padding-right: 1.5rem !important;\n    padding-left: 1.5rem !important;\n  }\n  .py-md-4 {\n    padding-top: 1.5rem !important;\n    padding-bottom: 1.5rem !important;\n  }\n  .p-md-5 {\n    padding: 3rem 3rem !important;\n  }\n  .pt-md-5 {\n    padding-top: 3rem !important;\n  }\n  .pr-md-5 {\n    padding-right: 3rem !important;\n  }\n  .pb-md-5 {\n    padding-bottom: 3rem !important;\n  }\n  .pl-md-5 {\n    padding-left: 3rem !important;\n  }\n  .px-md-5 {\n    padding-right: 3rem !important;\n    padding-left: 3rem !important;\n  }\n  .py-md-5 {\n    padding-top: 3rem !important;\n    padding-bottom: 3rem !important;\n  }\n  .m-md-auto {\n    margin: auto !important;\n  }\n  .mt-md-auto {\n    margin-top: auto !important;\n  }\n  .mr-md-auto {\n    margin-right: auto !important;\n  }\n  .mb-md-auto {\n    margin-bottom: auto !important;\n  }\n  .ml-md-auto {\n    margin-left: auto !important;\n  }\n  .mx-md-auto {\n    margin-right: auto !important;\n    margin-left: auto !important;\n  }\n  .my-md-auto {\n    margin-top: auto !important;\n    margin-bottom: auto !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .m-lg-0 {\n    margin: 0 0 !important;\n  }\n  .mt-lg-0 {\n    margin-top: 0 !important;\n  }\n  .mr-lg-0 {\n    margin-right: 0 !important;\n  }\n  .mb-lg-0 {\n    margin-bottom: 0 !important;\n  }\n  .ml-lg-0 {\n    margin-left: 0 !important;\n  }\n  .mx-lg-0 {\n    margin-right: 0 !important;\n    margin-left: 0 !important;\n  }\n  .my-lg-0 {\n    margin-top: 0 !important;\n    margin-bottom: 0 !important;\n  }\n  .m-lg-1 {\n    margin: 0.25rem 0.25rem !important;\n  }\n  .mt-lg-1 {\n    margin-top: 0.25rem !important;\n  }\n  .mr-lg-1 {\n    margin-right: 0.25rem !important;\n  }\n  .mb-lg-1 {\n    margin-bottom: 0.25rem !important;\n  }\n  .ml-lg-1 {\n    margin-left: 0.25rem !important;\n  }\n  .mx-lg-1 {\n    margin-right: 0.25rem !important;\n    margin-left: 0.25rem !important;\n  }\n  .my-lg-1 {\n    margin-top: 0.25rem !important;\n    margin-bottom: 0.25rem !important;\n  }\n  .m-lg-2 {\n    margin: 0.5rem 0.5rem !important;\n  }\n  .mt-lg-2 {\n    margin-top: 0.5rem !important;\n  }\n  .mr-lg-2 {\n    margin-right: 0.5rem !important;\n  }\n  .mb-lg-2 {\n    margin-bottom: 0.5rem !important;\n  }\n  .ml-lg-2 {\n    margin-left: 0.5rem !important;\n  }\n  .mx-lg-2 {\n    margin-right: 0.5rem !important;\n    margin-left: 0.5rem !important;\n  }\n  .my-lg-2 {\n    margin-top: 0.5rem !important;\n    margin-bottom: 0.5rem !important;\n  }\n  .m-lg-3 {\n    margin: 1rem 1rem !important;\n  }\n  .mt-lg-3 {\n    margin-top: 1rem !important;\n  }\n  .mr-lg-3 {\n    margin-right: 1rem !important;\n  }\n  .mb-lg-3 {\n    margin-bottom: 1rem !important;\n  }\n  .ml-lg-3 {\n    margin-left: 1rem !important;\n  }\n  .mx-lg-3 {\n    margin-right: 1rem !important;\n    margin-left: 1rem !important;\n  }\n  .my-lg-3 {\n    margin-top: 1rem !important;\n    margin-bottom: 1rem !important;\n  }\n  .m-lg-4 {\n    margin: 1.5rem 1.5rem !important;\n  }\n  .mt-lg-4 {\n    margin-top: 1.5rem !important;\n  }\n  .mr-lg-4 {\n    margin-right: 1.5rem !important;\n  }\n  .mb-lg-4 {\n    margin-bottom: 1.5rem !important;\n  }\n  .ml-lg-4 {\n    margin-left: 1.5rem !important;\n  }\n  .mx-lg-4 {\n    margin-right: 1.5rem !important;\n    margin-left: 1.5rem !important;\n  }\n  .my-lg-4 {\n    margin-top: 1.5rem !important;\n    margin-bottom: 1.5rem !important;\n  }\n  .m-lg-5 {\n    margin: 3rem 3rem !important;\n  }\n  .mt-lg-5 {\n    margin-top: 3rem !important;\n  }\n  .mr-lg-5 {\n    margin-right: 3rem !important;\n  }\n  .mb-lg-5 {\n    margin-bottom: 3rem !important;\n  }\n  .ml-lg-5 {\n    margin-left: 3rem !important;\n  }\n  .mx-lg-5 {\n    margin-right: 3rem !important;\n    margin-left: 3rem !important;\n  }\n  .my-lg-5 {\n    margin-top: 3rem !important;\n    margin-bottom: 3rem !important;\n  }\n  .p-lg-0 {\n    padding: 0 0 !important;\n  }\n  .pt-lg-0 {\n    padding-top: 0 !important;\n  }\n  .pr-lg-0 {\n    padding-right: 0 !important;\n  }\n  .pb-lg-0 {\n    padding-bottom: 0 !important;\n  }\n  .pl-lg-0 {\n    padding-left: 0 !important;\n  }\n  .px-lg-0 {\n    padding-right: 0 !important;\n    padding-left: 0 !important;\n  }\n  .py-lg-0 {\n    padding-top: 0 !important;\n    padding-bottom: 0 !important;\n  }\n  .p-lg-1 {\n    padding: 0.25rem 0.25rem !important;\n  }\n  .pt-lg-1 {\n    padding-top: 0.25rem !important;\n  }\n  .pr-lg-1 {\n    padding-right: 0.25rem !important;\n  }\n  .pb-lg-1 {\n    padding-bottom: 0.25rem !important;\n  }\n  .pl-lg-1 {\n    padding-left: 0.25rem !important;\n  }\n  .px-lg-1 {\n    padding-right: 0.25rem !important;\n    padding-left: 0.25rem !important;\n  }\n  .py-lg-1 {\n    padding-top: 0.25rem !important;\n    padding-bottom: 0.25rem !important;\n  }\n  .p-lg-2 {\n    padding: 0.5rem 0.5rem !important;\n  }\n  .pt-lg-2 {\n    padding-top: 0.5rem !important;\n  }\n  .pr-lg-2 {\n    padding-right: 0.5rem !important;\n  }\n  .pb-lg-2 {\n    padding-bottom: 0.5rem !important;\n  }\n  .pl-lg-2 {\n    padding-left: 0.5rem !important;\n  }\n  .px-lg-2 {\n    padding-right: 0.5rem !important;\n    padding-left: 0.5rem !important;\n  }\n  .py-lg-2 {\n    padding-top: 0.5rem !important;\n    padding-bottom: 0.5rem !important;\n  }\n  .p-lg-3 {\n    padding: 1rem 1rem !important;\n  }\n  .pt-lg-3 {\n    padding-top: 1rem !important;\n  }\n  .pr-lg-3 {\n    padding-right: 1rem !important;\n  }\n  .pb-lg-3 {\n    padding-bottom: 1rem !important;\n  }\n  .pl-lg-3 {\n    padding-left: 1rem !important;\n  }\n  .px-lg-3 {\n    padding-right: 1rem !important;\n    padding-left: 1rem !important;\n  }\n  .py-lg-3 {\n    padding-top: 1rem !important;\n    padding-bottom: 1rem !important;\n  }\n  .p-lg-4 {\n    padding: 1.5rem 1.5rem !important;\n  }\n  .pt-lg-4 {\n    padding-top: 1.5rem !important;\n  }\n  .pr-lg-4 {\n    padding-right: 1.5rem !important;\n  }\n  .pb-lg-4 {\n    padding-bottom: 1.5rem !important;\n  }\n  .pl-lg-4 {\n    padding-left: 1.5rem !important;\n  }\n  .px-lg-4 {\n    padding-right: 1.5rem !important;\n    padding-left: 1.5rem !important;\n  }\n  .py-lg-4 {\n    padding-top: 1.5rem !important;\n    padding-bottom: 1.5rem !important;\n  }\n  .p-lg-5 {\n    padding: 3rem 3rem !important;\n  }\n  .pt-lg-5 {\n    padding-top: 3rem !important;\n  }\n  .pr-lg-5 {\n    padding-right: 3rem !important;\n  }\n  .pb-lg-5 {\n    padding-bottom: 3rem !important;\n  }\n  .pl-lg-5 {\n    padding-left: 3rem !important;\n  }\n  .px-lg-5 {\n    padding-right: 3rem !important;\n    padding-left: 3rem !important;\n  }\n  .py-lg-5 {\n    padding-top: 3rem !important;\n    padding-bottom: 3rem !important;\n  }\n  .m-lg-auto {\n    margin: auto !important;\n  }\n  .mt-lg-auto {\n    margin-top: auto !important;\n  }\n  .mr-lg-auto {\n    margin-right: auto !important;\n  }\n  .mb-lg-auto {\n    margin-bottom: auto !important;\n  }\n  .ml-lg-auto {\n    margin-left: auto !important;\n  }\n  .mx-lg-auto {\n    margin-right: auto !important;\n    margin-left: auto !important;\n  }\n  .my-lg-auto {\n    margin-top: auto !important;\n    margin-bottom: auto !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .m-xl-0 {\n    margin: 0 0 !important;\n  }\n  .mt-xl-0 {\n    margin-top: 0 !important;\n  }\n  .mr-xl-0 {\n    margin-right: 0 !important;\n  }\n  .mb-xl-0 {\n    margin-bottom: 0 !important;\n  }\n  .ml-xl-0 {\n    margin-left: 0 !important;\n  }\n  .mx-xl-0 {\n    margin-right: 0 !important;\n    margin-left: 0 !important;\n  }\n  .my-xl-0 {\n    margin-top: 0 !important;\n    margin-bottom: 0 !important;\n  }\n  .m-xl-1 {\n    margin: 0.25rem 0.25rem !important;\n  }\n  .mt-xl-1 {\n    margin-top: 0.25rem !important;\n  }\n  .mr-xl-1 {\n    margin-right: 0.25rem !important;\n  }\n  .mb-xl-1 {\n    margin-bottom: 0.25rem !important;\n  }\n  .ml-xl-1 {\n    margin-left: 0.25rem !important;\n  }\n  .mx-xl-1 {\n    margin-right: 0.25rem !important;\n    margin-left: 0.25rem !important;\n  }\n  .my-xl-1 {\n    margin-top: 0.25rem !important;\n    margin-bottom: 0.25rem !important;\n  }\n  .m-xl-2 {\n    margin: 0.5rem 0.5rem !important;\n  }\n  .mt-xl-2 {\n    margin-top: 0.5rem !important;\n  }\n  .mr-xl-2 {\n    margin-right: 0.5rem !important;\n  }\n  .mb-xl-2 {\n    margin-bottom: 0.5rem !important;\n  }\n  .ml-xl-2 {\n    margin-left: 0.5rem !important;\n  }\n  .mx-xl-2 {\n    margin-right: 0.5rem !important;\n    margin-left: 0.5rem !important;\n  }\n  .my-xl-2 {\n    margin-top: 0.5rem !important;\n    margin-bottom: 0.5rem !important;\n  }\n  .m-xl-3 {\n    margin: 1rem 1rem !important;\n  }\n  .mt-xl-3 {\n    margin-top: 1rem !important;\n  }\n  .mr-xl-3 {\n    margin-right: 1rem !important;\n  }\n  .mb-xl-3 {\n    margin-bottom: 1rem !important;\n  }\n  .ml-xl-3 {\n    margin-left: 1rem !important;\n  }\n  .mx-xl-3 {\n    margin-right: 1rem !important;\n    margin-left: 1rem !important;\n  }\n  .my-xl-3 {\n    margin-top: 1rem !important;\n    margin-bottom: 1rem !important;\n  }\n  .m-xl-4 {\n    margin: 1.5rem 1.5rem !important;\n  }\n  .mt-xl-4 {\n    margin-top: 1.5rem !important;\n  }\n  .mr-xl-4 {\n    margin-right: 1.5rem !important;\n  }\n  .mb-xl-4 {\n    margin-bottom: 1.5rem !important;\n  }\n  .ml-xl-4 {\n    margin-left: 1.5rem !important;\n  }\n  .mx-xl-4 {\n    margin-right: 1.5rem !important;\n    margin-left: 1.5rem !important;\n  }\n  .my-xl-4 {\n    margin-top: 1.5rem !important;\n    margin-bottom: 1.5rem !important;\n  }\n  .m-xl-5 {\n    margin: 3rem 3rem !important;\n  }\n  .mt-xl-5 {\n    margin-top: 3rem !important;\n  }\n  .mr-xl-5 {\n    margin-right: 3rem !important;\n  }\n  .mb-xl-5 {\n    margin-bottom: 3rem !important;\n  }\n  .ml-xl-5 {\n    margin-left: 3rem !important;\n  }\n  .mx-xl-5 {\n    margin-right: 3rem !important;\n    margin-left: 3rem !important;\n  }\n  .my-xl-5 {\n    margin-top: 3rem !important;\n    margin-bottom: 3rem !important;\n  }\n  .p-xl-0 {\n    padding: 0 0 !important;\n  }\n  .pt-xl-0 {\n    padding-top: 0 !important;\n  }\n  .pr-xl-0 {\n    padding-right: 0 !important;\n  }\n  .pb-xl-0 {\n    padding-bottom: 0 !important;\n  }\n  .pl-xl-0 {\n    padding-left: 0 !important;\n  }\n  .px-xl-0 {\n    padding-right: 0 !important;\n    padding-left: 0 !important;\n  }\n  .py-xl-0 {\n    padding-top: 0 !important;\n    padding-bottom: 0 !important;\n  }\n  .p-xl-1 {\n    padding: 0.25rem 0.25rem !important;\n  }\n  .pt-xl-1 {\n    padding-top: 0.25rem !important;\n  }\n  .pr-xl-1 {\n    padding-right: 0.25rem !important;\n  }\n  .pb-xl-1 {\n    padding-bottom: 0.25rem !important;\n  }\n  .pl-xl-1 {\n    padding-left: 0.25rem !important;\n  }\n  .px-xl-1 {\n    padding-right: 0.25rem !important;\n    padding-left: 0.25rem !important;\n  }\n  .py-xl-1 {\n    padding-top: 0.25rem !important;\n    padding-bottom: 0.25rem !important;\n  }\n  .p-xl-2 {\n    padding: 0.5rem 0.5rem !important;\n  }\n  .pt-xl-2 {\n    padding-top: 0.5rem !important;\n  }\n  .pr-xl-2 {\n    padding-right: 0.5rem !important;\n  }\n  .pb-xl-2 {\n    padding-bottom: 0.5rem !important;\n  }\n  .pl-xl-2 {\n    padding-left: 0.5rem !important;\n  }\n  .px-xl-2 {\n    padding-right: 0.5rem !important;\n    padding-left: 0.5rem !important;\n  }\n  .py-xl-2 {\n    padding-top: 0.5rem !important;\n    padding-bottom: 0.5rem !important;\n  }\n  .p-xl-3 {\n    padding: 1rem 1rem !important;\n  }\n  .pt-xl-3 {\n    padding-top: 1rem !important;\n  }\n  .pr-xl-3 {\n    padding-right: 1rem !important;\n  }\n  .pb-xl-3 {\n    padding-bottom: 1rem !important;\n  }\n  .pl-xl-3 {\n    padding-left: 1rem !important;\n  }\n  .px-xl-3 {\n    padding-right: 1rem !important;\n    padding-left: 1rem !important;\n  }\n  .py-xl-3 {\n    padding-top: 1rem !important;\n    padding-bottom: 1rem !important;\n  }\n  .p-xl-4 {\n    padding: 1.5rem 1.5rem !important;\n  }\n  .pt-xl-4 {\n    padding-top: 1.5rem !important;\n  }\n  .pr-xl-4 {\n    padding-right: 1.5rem !important;\n  }\n  .pb-xl-4 {\n    padding-bottom: 1.5rem !important;\n  }\n  .pl-xl-4 {\n    padding-left: 1.5rem !important;\n  }\n  .px-xl-4 {\n    padding-right: 1.5rem !important;\n    padding-left: 1.5rem !important;\n  }\n  .py-xl-4 {\n    padding-top: 1.5rem !important;\n    padding-bottom: 1.5rem !important;\n  }\n  .p-xl-5 {\n    padding: 3rem 3rem !important;\n  }\n  .pt-xl-5 {\n    padding-top: 3rem !important;\n  }\n  .pr-xl-5 {\n    padding-right: 3rem !important;\n  }\n  .pb-xl-5 {\n    padding-bottom: 3rem !important;\n  }\n  .pl-xl-5 {\n    padding-left: 3rem !important;\n  }\n  .px-xl-5 {\n    padding-right: 3rem !important;\n    padding-left: 3rem !important;\n  }\n  .py-xl-5 {\n    padding-top: 3rem !important;\n    padding-bottom: 3rem !important;\n  }\n  .m-xl-auto {\n    margin: auto !important;\n  }\n  .mt-xl-auto {\n    margin-top: auto !important;\n  }\n  .mr-xl-auto {\n    margin-right: auto !important;\n  }\n  .mb-xl-auto {\n    margin-bottom: auto !important;\n  }\n  .ml-xl-auto {\n    margin-left: auto !important;\n  }\n  .mx-xl-auto {\n    margin-right: auto !important;\n    margin-left: auto !important;\n  }\n  .my-xl-auto {\n    margin-top: auto !important;\n    margin-bottom: auto !important;\n  }\n}\n\n.text-justify {\n  text-align: justify !important;\n}\n\n.text-nowrap {\n  white-space: nowrap !important;\n}\n\n.text-truncate {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n\n.text-left {\n  text-align: left !important;\n}\n\n.text-right {\n  text-align: right !important;\n}\n\n.text-center {\n  text-align: center !important;\n}\n\n@media (min-width: 576px) {\n  .text-sm-left {\n    text-align: left !important;\n  }\n  .text-sm-right {\n    text-align: right !important;\n  }\n  .text-sm-center {\n    text-align: center !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .text-md-left {\n    text-align: left !important;\n  }\n  .text-md-right {\n    text-align: right !important;\n  }\n  .text-md-center {\n    text-align: center !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .text-lg-left {\n    text-align: left !important;\n  }\n  .text-lg-right {\n    text-align: right !important;\n  }\n  .text-lg-center {\n    text-align: center !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .text-xl-left {\n    text-align: left !important;\n  }\n  .text-xl-right {\n    text-align: right !important;\n  }\n  .text-xl-center {\n    text-align: center !important;\n  }\n}\n\n.text-lowercase {\n  text-transform: lowercase !important;\n}\n\n.text-uppercase {\n  text-transform: uppercase !important;\n}\n\n.text-capitalize {\n  text-transform: capitalize !important;\n}\n\n.font-weight-normal {\n  font-weight: normal;\n}\n\n.font-weight-bold {\n  font-weight: bold;\n}\n\n.font-italic {\n  font-style: italic;\n}\n\n.text-white {\n  color: #fff !important;\n}\n\n.text-muted {\n  color: #636c72 !important;\n}\n\na.text-muted:focus, a.text-muted:hover {\n  color: #4b5257 !important;\n}\n\n.text-primary {\n  color: #0275d8 !important;\n}\n\na.text-primary:focus, a.text-primary:hover {\n  color: #025aa5 !important;\n}\n\n.text-success {\n  color: #5cb85c !important;\n}\n\na.text-success:focus, a.text-success:hover {\n  color: #449d44 !important;\n}\n\n.text-info {\n  color: #5bc0de !important;\n}\n\na.text-info:focus, a.text-info:hover {\n  color: #31b0d5 !important;\n}\n\n.text-warning {\n  color: #f0ad4e !important;\n}\n\na.text-warning:focus, a.text-warning:hover {\n  color: #ec971f !important;\n}\n\n.text-danger {\n  color: #d9534f !important;\n}\n\na.text-danger:focus, a.text-danger:hover {\n  color: #c9302c !important;\n}\n\n.text-gray-dark {\n  color: #292b2c !important;\n}\n\na.text-gray-dark:focus, a.text-gray-dark:hover {\n  color: #101112 !important;\n}\n\n.text-hide {\n  font: 0/0 a;\n  color: transparent;\n  text-shadow: none;\n  background-color: transparent;\n  border: 0;\n}\n\n.invisible {\n  visibility: hidden !important;\n}\n\n.hidden-xs-up {\n  display: none !important;\n}\n\n@media (max-width: 575px) {\n  .hidden-xs-down {\n    display: none !important;\n  }\n}\n\n@media (min-width: 576px) {\n  .hidden-sm-up {\n    display: none !important;\n  }\n}\n\n@media (max-width: 767px) {\n  .hidden-sm-down {\n    display: none !important;\n  }\n}\n\n@media (min-width: 768px) {\n  .hidden-md-up {\n    display: none !important;\n  }\n}\n\n@media (max-width: 991px) {\n  .hidden-md-down {\n    display: none !important;\n  }\n}\n\n@media (min-width: 992px) {\n  .hidden-lg-up {\n    display: none !important;\n  }\n}\n\n@media (max-width: 1199px) {\n  .hidden-lg-down {\n    display: none !important;\n  }\n}\n\n@media (min-width: 1200px) {\n  .hidden-xl-up {\n    display: none !important;\n  }\n}\n\n.hidden-xl-down {\n  display: none !important;\n}\n\n.visible-print-block {\n  display: none !important;\n}\n\n@media print {\n  .visible-print-block {\n    display: block !important;\n  }\n}\n\n.visible-print-inline {\n  display: none !important;\n}\n\n@media print {\n  .visible-print-inline {\n    display: inline !important;\n  }\n}\n\n.visible-print-inline-block {\n  display: none !important;\n}\n\n@media print {\n  .visible-print-inline-block {\n    display: inline-block !important;\n  }\n}\n\n@media print {\n  .hidden-print {\n    display: none !important;\n  }\n}\n/*# sourceMappingURL=bootstrap.css.map */"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/bootstrap/js/bootstrap.js",
    "content": "/*!\n * Bootstrap v4.0.0-alpha.6 (https://getbootstrap.com)\n * Copyright 2011-2017 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n\nif (typeof jQuery === 'undefined') {\n  throw new Error('Bootstrap\\'s JavaScript requires jQuery. jQuery must be included before Bootstrap\\'s JavaScript.')\n}\n\n+function ($) {\n  var version = $.fn.jquery.split(' ')[0].split('.')\n  if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 4)) {\n    throw new Error('Bootstrap\\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0')\n  }\n}(jQuery);\n\n\n+function () {\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): util.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Util = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Private TransitionEnd Helpers\n   * ------------------------------------------------------------------------\n   */\n\n  var transition = false;\n\n  var MAX_UID = 1000000;\n\n  var TransitionEndEvent = {\n    WebkitTransition: 'webkitTransitionEnd',\n    MozTransition: 'transitionend',\n    OTransition: 'oTransitionEnd otransitionend',\n    transition: 'transitionend'\n  };\n\n  // shoutout AngusCroll (https://goo.gl/pxwQGp)\n  function toType(obj) {\n    return {}.toString.call(obj).match(/\\s([a-zA-Z]+)/)[1].toLowerCase();\n  }\n\n  function isElement(obj) {\n    return (obj[0] || obj).nodeType;\n  }\n\n  function getSpecialTransitionEndEvent() {\n    return {\n      bindType: transition.end,\n      delegateType: transition.end,\n      handle: function handle(event) {\n        if ($(event.target).is(this)) {\n          return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params\n        }\n        return undefined;\n      }\n    };\n  }\n\n  function transitionEndTest() {\n    if (window.QUnit) {\n      return false;\n    }\n\n    var el = document.createElement('bootstrap');\n\n    for (var name in TransitionEndEvent) {\n      if (el.style[name] !== undefined) {\n        return {\n          end: TransitionEndEvent[name]\n        };\n      }\n    }\n\n    return false;\n  }\n\n  function transitionEndEmulator(duration) {\n    var _this = this;\n\n    var called = false;\n\n    $(this).one(Util.TRANSITION_END, function () {\n      called = true;\n    });\n\n    setTimeout(function () {\n      if (!called) {\n        Util.triggerTransitionEnd(_this);\n      }\n    }, duration);\n\n    return this;\n  }\n\n  function setTransitionEndSupport() {\n    transition = transitionEndTest();\n\n    $.fn.emulateTransitionEnd = transitionEndEmulator;\n\n    if (Util.supportsTransitionEnd()) {\n      $.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();\n    }\n  }\n\n  /**\n   * --------------------------------------------------------------------------\n   * Public Util Api\n   * --------------------------------------------------------------------------\n   */\n\n  var Util = {\n\n    TRANSITION_END: 'bsTransitionEnd',\n\n    getUID: function getUID(prefix) {\n      do {\n        // eslint-disable-next-line no-bitwise\n        prefix += ~~(Math.random() * MAX_UID); // \"~~\" acts like a faster Math.floor() here\n      } while (document.getElementById(prefix));\n      return prefix;\n    },\n    getSelectorFromElement: function getSelectorFromElement(element) {\n      var selector = element.getAttribute('data-target');\n\n      if (!selector) {\n        selector = element.getAttribute('href') || '';\n        selector = /^#[a-z]/i.test(selector) ? selector : null;\n      }\n\n      return selector;\n    },\n    reflow: function reflow(element) {\n      return element.offsetHeight;\n    },\n    triggerTransitionEnd: function triggerTransitionEnd(element) {\n      $(element).trigger(transition.end);\n    },\n    supportsTransitionEnd: function supportsTransitionEnd() {\n      return Boolean(transition);\n    },\n    typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) {\n      for (var property in configTypes) {\n        if (configTypes.hasOwnProperty(property)) {\n          var expectedTypes = configTypes[property];\n          var value = config[property];\n          var valueType = value && isElement(value) ? 'element' : toType(value);\n\n          if (!new RegExp(expectedTypes).test(valueType)) {\n            throw new Error(componentName.toUpperCase() + ': ' + ('Option \"' + property + '\" provided type \"' + valueType + '\" ') + ('but expected type \"' + expectedTypes + '\".'));\n          }\n        }\n      }\n    }\n  };\n\n  setTransitionEndSupport();\n\n  return Util;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): alert.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Alert = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'alert';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.alert';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 150;\n\n  var Selector = {\n    DISMISS: '[data-dismiss=\"alert\"]'\n  };\n\n  var Event = {\n    CLOSE: 'close' + EVENT_KEY,\n    CLOSED: 'closed' + EVENT_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    ALERT: 'alert',\n    FADE: 'fade',\n    SHOW: 'show'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Alert = function () {\n    function Alert(element) {\n      _classCallCheck(this, Alert);\n\n      this._element = element;\n    }\n\n    // getters\n\n    // public\n\n    Alert.prototype.close = function close(element) {\n      element = element || this._element;\n\n      var rootElement = this._getRootElement(element);\n      var customEvent = this._triggerCloseEvent(rootElement);\n\n      if (customEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      this._removeElement(rootElement);\n    };\n\n    Alert.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n      this._element = null;\n    };\n\n    // private\n\n    Alert.prototype._getRootElement = function _getRootElement(element) {\n      var selector = Util.getSelectorFromElement(element);\n      var parent = false;\n\n      if (selector) {\n        parent = $(selector)[0];\n      }\n\n      if (!parent) {\n        parent = $(element).closest('.' + ClassName.ALERT)[0];\n      }\n\n      return parent;\n    };\n\n    Alert.prototype._triggerCloseEvent = function _triggerCloseEvent(element) {\n      var closeEvent = $.Event(Event.CLOSE);\n\n      $(element).trigger(closeEvent);\n      return closeEvent;\n    };\n\n    Alert.prototype._removeElement = function _removeElement(element) {\n      var _this2 = this;\n\n      $(element).removeClass(ClassName.SHOW);\n\n      if (!Util.supportsTransitionEnd() || !$(element).hasClass(ClassName.FADE)) {\n        this._destroyElement(element);\n        return;\n      }\n\n      $(element).one(Util.TRANSITION_END, function (event) {\n        return _this2._destroyElement(element, event);\n      }).emulateTransitionEnd(TRANSITION_DURATION);\n    };\n\n    Alert.prototype._destroyElement = function _destroyElement(element) {\n      $(element).detach().trigger(Event.CLOSED).remove();\n    };\n\n    // static\n\n    Alert._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var $element = $(this);\n        var data = $element.data(DATA_KEY);\n\n        if (!data) {\n          data = new Alert(this);\n          $element.data(DATA_KEY, data);\n        }\n\n        if (config === 'close') {\n          data[config](this);\n        }\n      });\n    };\n\n    Alert._handleDismiss = function _handleDismiss(alertInstance) {\n      return function (event) {\n        if (event) {\n          event.preventDefault();\n        }\n\n        alertInstance.close(this);\n      };\n    };\n\n    _createClass(Alert, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }]);\n\n    return Alert;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert()));\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Alert._jQueryInterface;\n  $.fn[NAME].Constructor = Alert;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Alert._jQueryInterface;\n  };\n\n  return Alert;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): button.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Button = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'button';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.button';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n\n  var ClassName = {\n    ACTIVE: 'active',\n    BUTTON: 'btn',\n    FOCUS: 'focus'\n  };\n\n  var Selector = {\n    DATA_TOGGLE_CARROT: '[data-toggle^=\"button\"]',\n    DATA_TOGGLE: '[data-toggle=\"buttons\"]',\n    INPUT: 'input',\n    ACTIVE: '.active',\n    BUTTON: '.btn'\n  };\n\n  var Event = {\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,\n    FOCUS_BLUR_DATA_API: 'focus' + EVENT_KEY + DATA_API_KEY + ' ' + ('blur' + EVENT_KEY + DATA_API_KEY)\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Button = function () {\n    function Button(element) {\n      _classCallCheck(this, Button);\n\n      this._element = element;\n    }\n\n    // getters\n\n    // public\n\n    Button.prototype.toggle = function toggle() {\n      var triggerChangeEvent = true;\n      var rootElement = $(this._element).closest(Selector.DATA_TOGGLE)[0];\n\n      if (rootElement) {\n        var input = $(this._element).find(Selector.INPUT)[0];\n\n        if (input) {\n          if (input.type === 'radio') {\n            if (input.checked && $(this._element).hasClass(ClassName.ACTIVE)) {\n              triggerChangeEvent = false;\n            } else {\n              var activeElement = $(rootElement).find(Selector.ACTIVE)[0];\n\n              if (activeElement) {\n                $(activeElement).removeClass(ClassName.ACTIVE);\n              }\n            }\n          }\n\n          if (triggerChangeEvent) {\n            input.checked = !$(this._element).hasClass(ClassName.ACTIVE);\n            $(input).trigger('change');\n          }\n\n          input.focus();\n        }\n      }\n\n      this._element.setAttribute('aria-pressed', !$(this._element).hasClass(ClassName.ACTIVE));\n\n      if (triggerChangeEvent) {\n        $(this._element).toggleClass(ClassName.ACTIVE);\n      }\n    };\n\n    Button.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n      this._element = null;\n    };\n\n    // static\n\n    Button._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n\n        if (!data) {\n          data = new Button(this);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (config === 'toggle') {\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(Button, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }]);\n\n    return Button;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {\n    event.preventDefault();\n\n    var button = event.target;\n\n    if (!$(button).hasClass(ClassName.BUTTON)) {\n      button = $(button).closest(Selector.BUTTON);\n    }\n\n    Button._jQueryInterface.call($(button), 'toggle');\n  }).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {\n    var button = $(event.target).closest(Selector.BUTTON)[0];\n    $(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type));\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Button._jQueryInterface;\n  $.fn[NAME].Constructor = Button;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Button._jQueryInterface;\n  };\n\n  return Button;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): carousel.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Carousel = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'carousel';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.carousel';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 600;\n  var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key\n  var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key\n\n  var Default = {\n    interval: 5000,\n    keyboard: true,\n    slide: false,\n    pause: 'hover',\n    wrap: true\n  };\n\n  var DefaultType = {\n    interval: '(number|boolean)',\n    keyboard: 'boolean',\n    slide: '(boolean|string)',\n    pause: '(string|boolean)',\n    wrap: 'boolean'\n  };\n\n  var Direction = {\n    NEXT: 'next',\n    PREV: 'prev',\n    LEFT: 'left',\n    RIGHT: 'right'\n  };\n\n  var Event = {\n    SLIDE: 'slide' + EVENT_KEY,\n    SLID: 'slid' + EVENT_KEY,\n    KEYDOWN: 'keydown' + EVENT_KEY,\n    MOUSEENTER: 'mouseenter' + EVENT_KEY,\n    MOUSELEAVE: 'mouseleave' + EVENT_KEY,\n    LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    CAROUSEL: 'carousel',\n    ACTIVE: 'active',\n    SLIDE: 'slide',\n    RIGHT: 'carousel-item-right',\n    LEFT: 'carousel-item-left',\n    NEXT: 'carousel-item-next',\n    PREV: 'carousel-item-prev',\n    ITEM: 'carousel-item'\n  };\n\n  var Selector = {\n    ACTIVE: '.active',\n    ACTIVE_ITEM: '.active.carousel-item',\n    ITEM: '.carousel-item',\n    NEXT_PREV: '.carousel-item-next, .carousel-item-prev',\n    INDICATORS: '.carousel-indicators',\n    DATA_SLIDE: '[data-slide], [data-slide-to]',\n    DATA_RIDE: '[data-ride=\"carousel\"]'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Carousel = function () {\n    function Carousel(element, config) {\n      _classCallCheck(this, Carousel);\n\n      this._items = null;\n      this._interval = null;\n      this._activeElement = null;\n\n      this._isPaused = false;\n      this._isSliding = false;\n\n      this._config = this._getConfig(config);\n      this._element = $(element)[0];\n      this._indicatorsElement = $(this._element).find(Selector.INDICATORS)[0];\n\n      this._addEventListeners();\n    }\n\n    // getters\n\n    // public\n\n    Carousel.prototype.next = function next() {\n      if (this._isSliding) {\n        throw new Error('Carousel is sliding');\n      }\n      this._slide(Direction.NEXT);\n    };\n\n    Carousel.prototype.nextWhenVisible = function nextWhenVisible() {\n      // Don't call next when the page isn't visible\n      if (!document.hidden) {\n        this.next();\n      }\n    };\n\n    Carousel.prototype.prev = function prev() {\n      if (this._isSliding) {\n        throw new Error('Carousel is sliding');\n      }\n      this._slide(Direction.PREVIOUS);\n    };\n\n    Carousel.prototype.pause = function pause(event) {\n      if (!event) {\n        this._isPaused = true;\n      }\n\n      if ($(this._element).find(Selector.NEXT_PREV)[0] && Util.supportsTransitionEnd()) {\n        Util.triggerTransitionEnd(this._element);\n        this.cycle(true);\n      }\n\n      clearInterval(this._interval);\n      this._interval = null;\n    };\n\n    Carousel.prototype.cycle = function cycle(event) {\n      if (!event) {\n        this._isPaused = false;\n      }\n\n      if (this._interval) {\n        clearInterval(this._interval);\n        this._interval = null;\n      }\n\n      if (this._config.interval && !this._isPaused) {\n        this._interval = setInterval((document.visibilityState ? this.nextWhenVisible : this.next).bind(this), this._config.interval);\n      }\n    };\n\n    Carousel.prototype.to = function to(index) {\n      var _this3 = this;\n\n      this._activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];\n\n      var activeIndex = this._getItemIndex(this._activeElement);\n\n      if (index > this._items.length - 1 || index < 0) {\n        return;\n      }\n\n      if (this._isSliding) {\n        $(this._element).one(Event.SLID, function () {\n          return _this3.to(index);\n        });\n        return;\n      }\n\n      if (activeIndex === index) {\n        this.pause();\n        this.cycle();\n        return;\n      }\n\n      var direction = index > activeIndex ? Direction.NEXT : Direction.PREVIOUS;\n\n      this._slide(direction, this._items[index]);\n    };\n\n    Carousel.prototype.dispose = function dispose() {\n      $(this._element).off(EVENT_KEY);\n      $.removeData(this._element, DATA_KEY);\n\n      this._items = null;\n      this._config = null;\n      this._element = null;\n      this._interval = null;\n      this._isPaused = null;\n      this._isSliding = null;\n      this._activeElement = null;\n      this._indicatorsElement = null;\n    };\n\n    // private\n\n    Carousel.prototype._getConfig = function _getConfig(config) {\n      config = $.extend({}, Default, config);\n      Util.typeCheckConfig(NAME, config, DefaultType);\n      return config;\n    };\n\n    Carousel.prototype._addEventListeners = function _addEventListeners() {\n      var _this4 = this;\n\n      if (this._config.keyboard) {\n        $(this._element).on(Event.KEYDOWN, function (event) {\n          return _this4._keydown(event);\n        });\n      }\n\n      if (this._config.pause === 'hover' && !('ontouchstart' in document.documentElement)) {\n        $(this._element).on(Event.MOUSEENTER, function (event) {\n          return _this4.pause(event);\n        }).on(Event.MOUSELEAVE, function (event) {\n          return _this4.cycle(event);\n        });\n      }\n    };\n\n    Carousel.prototype._keydown = function _keydown(event) {\n      if (/input|textarea/i.test(event.target.tagName)) {\n        return;\n      }\n\n      switch (event.which) {\n        case ARROW_LEFT_KEYCODE:\n          event.preventDefault();\n          this.prev();\n          break;\n        case ARROW_RIGHT_KEYCODE:\n          event.preventDefault();\n          this.next();\n          break;\n        default:\n          return;\n      }\n    };\n\n    Carousel.prototype._getItemIndex = function _getItemIndex(element) {\n      this._items = $.makeArray($(element).parent().find(Selector.ITEM));\n      return this._items.indexOf(element);\n    };\n\n    Carousel.prototype._getItemByDirection = function _getItemByDirection(direction, activeElement) {\n      var isNextDirection = direction === Direction.NEXT;\n      var isPrevDirection = direction === Direction.PREVIOUS;\n      var activeIndex = this._getItemIndex(activeElement);\n      var lastItemIndex = this._items.length - 1;\n      var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex;\n\n      if (isGoingToWrap && !this._config.wrap) {\n        return activeElement;\n      }\n\n      var delta = direction === Direction.PREVIOUS ? -1 : 1;\n      var itemIndex = (activeIndex + delta) % this._items.length;\n\n      return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex];\n    };\n\n    Carousel.prototype._triggerSlideEvent = function _triggerSlideEvent(relatedTarget, eventDirectionName) {\n      var slideEvent = $.Event(Event.SLIDE, {\n        relatedTarget: relatedTarget,\n        direction: eventDirectionName\n      });\n\n      $(this._element).trigger(slideEvent);\n\n      return slideEvent;\n    };\n\n    Carousel.prototype._setActiveIndicatorElement = function _setActiveIndicatorElement(element) {\n      if (this._indicatorsElement) {\n        $(this._indicatorsElement).find(Selector.ACTIVE).removeClass(ClassName.ACTIVE);\n\n        var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)];\n\n        if (nextIndicator) {\n          $(nextIndicator).addClass(ClassName.ACTIVE);\n        }\n      }\n    };\n\n    Carousel.prototype._slide = function _slide(direction, element) {\n      var _this5 = this;\n\n      var activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];\n      var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement);\n\n      var isCycling = Boolean(this._interval);\n\n      var directionalClassName = void 0;\n      var orderClassName = void 0;\n      var eventDirectionName = void 0;\n\n      if (direction === Direction.NEXT) {\n        directionalClassName = ClassName.LEFT;\n        orderClassName = ClassName.NEXT;\n        eventDirectionName = Direction.LEFT;\n      } else {\n        directionalClassName = ClassName.RIGHT;\n        orderClassName = ClassName.PREV;\n        eventDirectionName = Direction.RIGHT;\n      }\n\n      if (nextElement && $(nextElement).hasClass(ClassName.ACTIVE)) {\n        this._isSliding = false;\n        return;\n      }\n\n      var slideEvent = this._triggerSlideEvent(nextElement, eventDirectionName);\n      if (slideEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      if (!activeElement || !nextElement) {\n        // some weirdness is happening, so we bail\n        return;\n      }\n\n      this._isSliding = true;\n\n      if (isCycling) {\n        this.pause();\n      }\n\n      this._setActiveIndicatorElement(nextElement);\n\n      var slidEvent = $.Event(Event.SLID, {\n        relatedTarget: nextElement,\n        direction: eventDirectionName\n      });\n\n      if (Util.supportsTransitionEnd() && $(this._element).hasClass(ClassName.SLIDE)) {\n\n        $(nextElement).addClass(orderClassName);\n\n        Util.reflow(nextElement);\n\n        $(activeElement).addClass(directionalClassName);\n        $(nextElement).addClass(directionalClassName);\n\n        $(activeElement).one(Util.TRANSITION_END, function () {\n          $(nextElement).removeClass(directionalClassName + ' ' + orderClassName).addClass(ClassName.ACTIVE);\n\n          $(activeElement).removeClass(ClassName.ACTIVE + ' ' + orderClassName + ' ' + directionalClassName);\n\n          _this5._isSliding = false;\n\n          setTimeout(function () {\n            return $(_this5._element).trigger(slidEvent);\n          }, 0);\n        }).emulateTransitionEnd(TRANSITION_DURATION);\n      } else {\n        $(activeElement).removeClass(ClassName.ACTIVE);\n        $(nextElement).addClass(ClassName.ACTIVE);\n\n        this._isSliding = false;\n        $(this._element).trigger(slidEvent);\n      }\n\n      if (isCycling) {\n        this.cycle();\n      }\n    };\n\n    // static\n\n    Carousel._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n        var _config = $.extend({}, Default, $(this).data());\n\n        if ((typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object') {\n          $.extend(_config, config);\n        }\n\n        var action = typeof config === 'string' ? config : _config.slide;\n\n        if (!data) {\n          data = new Carousel(this, _config);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'number') {\n          data.to(config);\n        } else if (typeof action === 'string') {\n          if (data[action] === undefined) {\n            throw new Error('No method named \"' + action + '\"');\n          }\n          data[action]();\n        } else if (_config.interval) {\n          data.pause();\n          data.cycle();\n        }\n      });\n    };\n\n    Carousel._dataApiClickHandler = function _dataApiClickHandler(event) {\n      var selector = Util.getSelectorFromElement(this);\n\n      if (!selector) {\n        return;\n      }\n\n      var target = $(selector)[0];\n\n      if (!target || !$(target).hasClass(ClassName.CAROUSEL)) {\n        return;\n      }\n\n      var config = $.extend({}, $(target).data(), $(this).data());\n      var slideIndex = this.getAttribute('data-slide-to');\n\n      if (slideIndex) {\n        config.interval = false;\n      }\n\n      Carousel._jQueryInterface.call($(target), config);\n\n      if (slideIndex) {\n        $(target).data(DATA_KEY).to(slideIndex);\n      }\n\n      event.preventDefault();\n    };\n\n    _createClass(Carousel, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }]);\n\n    return Carousel;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DATA_SLIDE, Carousel._dataApiClickHandler);\n\n  $(window).on(Event.LOAD_DATA_API, function () {\n    $(Selector.DATA_RIDE).each(function () {\n      var $carousel = $(this);\n      Carousel._jQueryInterface.call($carousel, $carousel.data());\n    });\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Carousel._jQueryInterface;\n  $.fn[NAME].Constructor = Carousel;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Carousel._jQueryInterface;\n  };\n\n  return Carousel;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): collapse.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Collapse = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'collapse';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.collapse';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 600;\n\n  var Default = {\n    toggle: true,\n    parent: ''\n  };\n\n  var DefaultType = {\n    toggle: 'boolean',\n    parent: 'string'\n  };\n\n  var Event = {\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    SHOW: 'show',\n    COLLAPSE: 'collapse',\n    COLLAPSING: 'collapsing',\n    COLLAPSED: 'collapsed'\n  };\n\n  var Dimension = {\n    WIDTH: 'width',\n    HEIGHT: 'height'\n  };\n\n  var Selector = {\n    ACTIVES: '.card > .show, .card > .collapsing',\n    DATA_TOGGLE: '[data-toggle=\"collapse\"]'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Collapse = function () {\n    function Collapse(element, config) {\n      _classCallCheck(this, Collapse);\n\n      this._isTransitioning = false;\n      this._element = element;\n      this._config = this._getConfig(config);\n      this._triggerArray = $.makeArray($('[data-toggle=\"collapse\"][href=\"#' + element.id + '\"],' + ('[data-toggle=\"collapse\"][data-target=\"#' + element.id + '\"]')));\n\n      this._parent = this._config.parent ? this._getParent() : null;\n\n      if (!this._config.parent) {\n        this._addAriaAndCollapsedClass(this._element, this._triggerArray);\n      }\n\n      if (this._config.toggle) {\n        this.toggle();\n      }\n    }\n\n    // getters\n\n    // public\n\n    Collapse.prototype.toggle = function toggle() {\n      if ($(this._element).hasClass(ClassName.SHOW)) {\n        this.hide();\n      } else {\n        this.show();\n      }\n    };\n\n    Collapse.prototype.show = function show() {\n      var _this6 = this;\n\n      if (this._isTransitioning) {\n        throw new Error('Collapse is transitioning');\n      }\n\n      if ($(this._element).hasClass(ClassName.SHOW)) {\n        return;\n      }\n\n      var actives = void 0;\n      var activesData = void 0;\n\n      if (this._parent) {\n        actives = $.makeArray($(this._parent).find(Selector.ACTIVES));\n        if (!actives.length) {\n          actives = null;\n        }\n      }\n\n      if (actives) {\n        activesData = $(actives).data(DATA_KEY);\n        if (activesData && activesData._isTransitioning) {\n          return;\n        }\n      }\n\n      var startEvent = $.Event(Event.SHOW);\n      $(this._element).trigger(startEvent);\n      if (startEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      if (actives) {\n        Collapse._jQueryInterface.call($(actives), 'hide');\n        if (!activesData) {\n          $(actives).data(DATA_KEY, null);\n        }\n      }\n\n      var dimension = this._getDimension();\n\n      $(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING);\n\n      this._element.style[dimension] = 0;\n      this._element.setAttribute('aria-expanded', true);\n\n      if (this._triggerArray.length) {\n        $(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true);\n      }\n\n      this.setTransitioning(true);\n\n      var complete = function complete() {\n        $(_this6._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.SHOW);\n\n        _this6._element.style[dimension] = '';\n\n        _this6.setTransitioning(false);\n\n        $(_this6._element).trigger(Event.SHOWN);\n      };\n\n      if (!Util.supportsTransitionEnd()) {\n        complete();\n        return;\n      }\n\n      var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);\n      var scrollSize = 'scroll' + capitalizedDimension;\n\n      $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n\n      this._element.style[dimension] = this._element[scrollSize] + 'px';\n    };\n\n    Collapse.prototype.hide = function hide() {\n      var _this7 = this;\n\n      if (this._isTransitioning) {\n        throw new Error('Collapse is transitioning');\n      }\n\n      if (!$(this._element).hasClass(ClassName.SHOW)) {\n        return;\n      }\n\n      var startEvent = $.Event(Event.HIDE);\n      $(this._element).trigger(startEvent);\n      if (startEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      var dimension = this._getDimension();\n      var offsetDimension = dimension === Dimension.WIDTH ? 'offsetWidth' : 'offsetHeight';\n\n      this._element.style[dimension] = this._element[offsetDimension] + 'px';\n\n      Util.reflow(this._element);\n\n      $(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.SHOW);\n\n      this._element.setAttribute('aria-expanded', false);\n\n      if (this._triggerArray.length) {\n        $(this._triggerArray).addClass(ClassName.COLLAPSED).attr('aria-expanded', false);\n      }\n\n      this.setTransitioning(true);\n\n      var complete = function complete() {\n        _this7.setTransitioning(false);\n        $(_this7._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN);\n      };\n\n      this._element.style[dimension] = '';\n\n      if (!Util.supportsTransitionEnd()) {\n        complete();\n        return;\n      }\n\n      $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n    };\n\n    Collapse.prototype.setTransitioning = function setTransitioning(isTransitioning) {\n      this._isTransitioning = isTransitioning;\n    };\n\n    Collapse.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n\n      this._config = null;\n      this._parent = null;\n      this._element = null;\n      this._triggerArray = null;\n      this._isTransitioning = null;\n    };\n\n    // private\n\n    Collapse.prototype._getConfig = function _getConfig(config) {\n      config = $.extend({}, Default, config);\n      config.toggle = Boolean(config.toggle); // coerce string values\n      Util.typeCheckConfig(NAME, config, DefaultType);\n      return config;\n    };\n\n    Collapse.prototype._getDimension = function _getDimension() {\n      var hasWidth = $(this._element).hasClass(Dimension.WIDTH);\n      return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT;\n    };\n\n    Collapse.prototype._getParent = function _getParent() {\n      var _this8 = this;\n\n      var parent = $(this._config.parent)[0];\n      var selector = '[data-toggle=\"collapse\"][data-parent=\"' + this._config.parent + '\"]';\n\n      $(parent).find(selector).each(function (i, element) {\n        _this8._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);\n      });\n\n      return parent;\n    };\n\n    Collapse.prototype._addAriaAndCollapsedClass = function _addAriaAndCollapsedClass(element, triggerArray) {\n      if (element) {\n        var isOpen = $(element).hasClass(ClassName.SHOW);\n        element.setAttribute('aria-expanded', isOpen);\n\n        if (triggerArray.length) {\n          $(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen);\n        }\n      }\n    };\n\n    // static\n\n    Collapse._getTargetFromElement = function _getTargetFromElement(element) {\n      var selector = Util.getSelectorFromElement(element);\n      return selector ? $(selector)[0] : null;\n    };\n\n    Collapse._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var $this = $(this);\n        var data = $this.data(DATA_KEY);\n        var _config = $.extend({}, Default, $this.data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config);\n\n        if (!data && _config.toggle && /show|hide/.test(config)) {\n          _config.toggle = false;\n        }\n\n        if (!data) {\n          data = new Collapse(this, _config);\n          $this.data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(Collapse, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }]);\n\n    return Collapse;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {\n    event.preventDefault();\n\n    var target = Collapse._getTargetFromElement(this);\n    var data = $(target).data(DATA_KEY);\n    var config = data ? 'toggle' : $(this).data();\n\n    Collapse._jQueryInterface.call($(target), config);\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Collapse._jQueryInterface;\n  $.fn[NAME].Constructor = Collapse;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Collapse._jQueryInterface;\n  };\n\n  return Collapse;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): dropdown.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Dropdown = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'dropdown';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.dropdown';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key\n  var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key\n  var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key\n  var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse)\n\n  var Event = {\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    CLICK: 'click' + EVENT_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,\n    FOCUSIN_DATA_API: 'focusin' + EVENT_KEY + DATA_API_KEY,\n    KEYDOWN_DATA_API: 'keydown' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    BACKDROP: 'dropdown-backdrop',\n    DISABLED: 'disabled',\n    SHOW: 'show'\n  };\n\n  var Selector = {\n    BACKDROP: '.dropdown-backdrop',\n    DATA_TOGGLE: '[data-toggle=\"dropdown\"]',\n    FORM_CHILD: '.dropdown form',\n    ROLE_MENU: '[role=\"menu\"]',\n    ROLE_LISTBOX: '[role=\"listbox\"]',\n    NAVBAR_NAV: '.navbar-nav',\n    VISIBLE_ITEMS: '[role=\"menu\"] li:not(.disabled) a, ' + '[role=\"listbox\"] li:not(.disabled) a'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Dropdown = function () {\n    function Dropdown(element) {\n      _classCallCheck(this, Dropdown);\n\n      this._element = element;\n\n      this._addEventListeners();\n    }\n\n    // getters\n\n    // public\n\n    Dropdown.prototype.toggle = function toggle() {\n      if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {\n        return false;\n      }\n\n      var parent = Dropdown._getParentFromElement(this);\n      var isActive = $(parent).hasClass(ClassName.SHOW);\n\n      Dropdown._clearMenus();\n\n      if (isActive) {\n        return false;\n      }\n\n      if ('ontouchstart' in document.documentElement && !$(parent).closest(Selector.NAVBAR_NAV).length) {\n\n        // if mobile we use a backdrop because click events don't delegate\n        var dropdown = document.createElement('div');\n        dropdown.className = ClassName.BACKDROP;\n        $(dropdown).insertBefore(this);\n        $(dropdown).on('click', Dropdown._clearMenus);\n      }\n\n      var relatedTarget = {\n        relatedTarget: this\n      };\n      var showEvent = $.Event(Event.SHOW, relatedTarget);\n\n      $(parent).trigger(showEvent);\n\n      if (showEvent.isDefaultPrevented()) {\n        return false;\n      }\n\n      this.focus();\n      this.setAttribute('aria-expanded', true);\n\n      $(parent).toggleClass(ClassName.SHOW);\n      $(parent).trigger($.Event(Event.SHOWN, relatedTarget));\n\n      return false;\n    };\n\n    Dropdown.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n      $(this._element).off(EVENT_KEY);\n      this._element = null;\n    };\n\n    // private\n\n    Dropdown.prototype._addEventListeners = function _addEventListeners() {\n      $(this._element).on(Event.CLICK, this.toggle);\n    };\n\n    // static\n\n    Dropdown._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n\n        if (!data) {\n          data = new Dropdown(this);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config].call(this);\n        }\n      });\n    };\n\n    Dropdown._clearMenus = function _clearMenus(event) {\n      if (event && event.which === RIGHT_MOUSE_BUTTON_WHICH) {\n        return;\n      }\n\n      var backdrop = $(Selector.BACKDROP)[0];\n      if (backdrop) {\n        backdrop.parentNode.removeChild(backdrop);\n      }\n\n      var toggles = $.makeArray($(Selector.DATA_TOGGLE));\n\n      for (var i = 0; i < toggles.length; i++) {\n        var parent = Dropdown._getParentFromElement(toggles[i]);\n        var relatedTarget = {\n          relatedTarget: toggles[i]\n        };\n\n        if (!$(parent).hasClass(ClassName.SHOW)) {\n          continue;\n        }\n\n        if (event && (event.type === 'click' && /input|textarea/i.test(event.target.tagName) || event.type === 'focusin') && $.contains(parent, event.target)) {\n          continue;\n        }\n\n        var hideEvent = $.Event(Event.HIDE, relatedTarget);\n        $(parent).trigger(hideEvent);\n        if (hideEvent.isDefaultPrevented()) {\n          continue;\n        }\n\n        toggles[i].setAttribute('aria-expanded', 'false');\n\n        $(parent).removeClass(ClassName.SHOW).trigger($.Event(Event.HIDDEN, relatedTarget));\n      }\n    };\n\n    Dropdown._getParentFromElement = function _getParentFromElement(element) {\n      var parent = void 0;\n      var selector = Util.getSelectorFromElement(element);\n\n      if (selector) {\n        parent = $(selector)[0];\n      }\n\n      return parent || element.parentNode;\n    };\n\n    Dropdown._dataApiKeydownHandler = function _dataApiKeydownHandler(event) {\n      if (!/(38|40|27|32)/.test(event.which) || /input|textarea/i.test(event.target.tagName)) {\n        return;\n      }\n\n      event.preventDefault();\n      event.stopPropagation();\n\n      if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {\n        return;\n      }\n\n      var parent = Dropdown._getParentFromElement(this);\n      var isActive = $(parent).hasClass(ClassName.SHOW);\n\n      if (!isActive && event.which !== ESCAPE_KEYCODE || isActive && event.which === ESCAPE_KEYCODE) {\n\n        if (event.which === ESCAPE_KEYCODE) {\n          var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];\n          $(toggle).trigger('focus');\n        }\n\n        $(this).trigger('click');\n        return;\n      }\n\n      var items = $(parent).find(Selector.VISIBLE_ITEMS).get();\n\n      if (!items.length) {\n        return;\n      }\n\n      var index = items.indexOf(event.target);\n\n      if (event.which === ARROW_UP_KEYCODE && index > 0) {\n        // up\n        index--;\n      }\n\n      if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) {\n        // down\n        index++;\n      }\n\n      if (index < 0) {\n        index = 0;\n      }\n\n      items[index].focus();\n    };\n\n    _createClass(Dropdown, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }]);\n\n    return Dropdown;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.KEYDOWN_DATA_API, Selector.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_MENU, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_LISTBOX, Dropdown._dataApiKeydownHandler).on(Event.CLICK_DATA_API + ' ' + Event.FOCUSIN_DATA_API, Dropdown._clearMenus).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, Dropdown.prototype.toggle).on(Event.CLICK_DATA_API, Selector.FORM_CHILD, function (e) {\n    e.stopPropagation();\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Dropdown._jQueryInterface;\n  $.fn[NAME].Constructor = Dropdown;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Dropdown._jQueryInterface;\n  };\n\n  return Dropdown;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): modal.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Modal = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'modal';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.modal';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 300;\n  var BACKDROP_TRANSITION_DURATION = 150;\n  var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key\n\n  var Default = {\n    backdrop: true,\n    keyboard: true,\n    focus: true,\n    show: true\n  };\n\n  var DefaultType = {\n    backdrop: '(boolean|string)',\n    keyboard: 'boolean',\n    focus: 'boolean',\n    show: 'boolean'\n  };\n\n  var Event = {\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    FOCUSIN: 'focusin' + EVENT_KEY,\n    RESIZE: 'resize' + EVENT_KEY,\n    CLICK_DISMISS: 'click.dismiss' + EVENT_KEY,\n    KEYDOWN_DISMISS: 'keydown.dismiss' + EVENT_KEY,\n    MOUSEUP_DISMISS: 'mouseup.dismiss' + EVENT_KEY,\n    MOUSEDOWN_DISMISS: 'mousedown.dismiss' + EVENT_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    SCROLLBAR_MEASURER: 'modal-scrollbar-measure',\n    BACKDROP: 'modal-backdrop',\n    OPEN: 'modal-open',\n    FADE: 'fade',\n    SHOW: 'show'\n  };\n\n  var Selector = {\n    DIALOG: '.modal-dialog',\n    DATA_TOGGLE: '[data-toggle=\"modal\"]',\n    DATA_DISMISS: '[data-dismiss=\"modal\"]',\n    FIXED_CONTENT: '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Modal = function () {\n    function Modal(element, config) {\n      _classCallCheck(this, Modal);\n\n      this._config = this._getConfig(config);\n      this._element = element;\n      this._dialog = $(element).find(Selector.DIALOG)[0];\n      this._backdrop = null;\n      this._isShown = false;\n      this._isBodyOverflowing = false;\n      this._ignoreBackdropClick = false;\n      this._isTransitioning = false;\n      this._originalBodyPadding = 0;\n      this._scrollbarWidth = 0;\n    }\n\n    // getters\n\n    // public\n\n    Modal.prototype.toggle = function toggle(relatedTarget) {\n      return this._isShown ? this.hide() : this.show(relatedTarget);\n    };\n\n    Modal.prototype.show = function show(relatedTarget) {\n      var _this9 = this;\n\n      if (this._isTransitioning) {\n        throw new Error('Modal is transitioning');\n      }\n\n      if (Util.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {\n        this._isTransitioning = true;\n      }\n      var showEvent = $.Event(Event.SHOW, {\n        relatedTarget: relatedTarget\n      });\n\n      $(this._element).trigger(showEvent);\n\n      if (this._isShown || showEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      this._isShown = true;\n\n      this._checkScrollbar();\n      this._setScrollbar();\n\n      $(document.body).addClass(ClassName.OPEN);\n\n      this._setEscapeEvent();\n      this._setResizeEvent();\n\n      $(this._element).on(Event.CLICK_DISMISS, Selector.DATA_DISMISS, function (event) {\n        return _this9.hide(event);\n      });\n\n      $(this._dialog).on(Event.MOUSEDOWN_DISMISS, function () {\n        $(_this9._element).one(Event.MOUSEUP_DISMISS, function (event) {\n          if ($(event.target).is(_this9._element)) {\n            _this9._ignoreBackdropClick = true;\n          }\n        });\n      });\n\n      this._showBackdrop(function () {\n        return _this9._showElement(relatedTarget);\n      });\n    };\n\n    Modal.prototype.hide = function hide(event) {\n      var _this10 = this;\n\n      if (event) {\n        event.preventDefault();\n      }\n\n      if (this._isTransitioning) {\n        throw new Error('Modal is transitioning');\n      }\n\n      var transition = Util.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE);\n      if (transition) {\n        this._isTransitioning = true;\n      }\n\n      var hideEvent = $.Event(Event.HIDE);\n      $(this._element).trigger(hideEvent);\n\n      if (!this._isShown || hideEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      this._isShown = false;\n\n      this._setEscapeEvent();\n      this._setResizeEvent();\n\n      $(document).off(Event.FOCUSIN);\n\n      $(this._element).removeClass(ClassName.SHOW);\n\n      $(this._element).off(Event.CLICK_DISMISS);\n      $(this._dialog).off(Event.MOUSEDOWN_DISMISS);\n\n      if (transition) {\n        $(this._element).one(Util.TRANSITION_END, function (event) {\n          return _this10._hideModal(event);\n        }).emulateTransitionEnd(TRANSITION_DURATION);\n      } else {\n        this._hideModal();\n      }\n    };\n\n    Modal.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n\n      $(window, document, this._element, this._backdrop).off(EVENT_KEY);\n\n      this._config = null;\n      this._element = null;\n      this._dialog = null;\n      this._backdrop = null;\n      this._isShown = null;\n      this._isBodyOverflowing = null;\n      this._ignoreBackdropClick = null;\n      this._originalBodyPadding = null;\n      this._scrollbarWidth = null;\n    };\n\n    // private\n\n    Modal.prototype._getConfig = function _getConfig(config) {\n      config = $.extend({}, Default, config);\n      Util.typeCheckConfig(NAME, config, DefaultType);\n      return config;\n    };\n\n    Modal.prototype._showElement = function _showElement(relatedTarget) {\n      var _this11 = this;\n\n      var transition = Util.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE);\n\n      if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) {\n        // don't move modals dom position\n        document.body.appendChild(this._element);\n      }\n\n      this._element.style.display = 'block';\n      this._element.removeAttribute('aria-hidden');\n      this._element.scrollTop = 0;\n\n      if (transition) {\n        Util.reflow(this._element);\n      }\n\n      $(this._element).addClass(ClassName.SHOW);\n\n      if (this._config.focus) {\n        this._enforceFocus();\n      }\n\n      var shownEvent = $.Event(Event.SHOWN, {\n        relatedTarget: relatedTarget\n      });\n\n      var transitionComplete = function transitionComplete() {\n        if (_this11._config.focus) {\n          _this11._element.focus();\n        }\n        _this11._isTransitioning = false;\n        $(_this11._element).trigger(shownEvent);\n      };\n\n      if (transition) {\n        $(this._dialog).one(Util.TRANSITION_END, transitionComplete).emulateTransitionEnd(TRANSITION_DURATION);\n      } else {\n        transitionComplete();\n      }\n    };\n\n    Modal.prototype._enforceFocus = function _enforceFocus() {\n      var _this12 = this;\n\n      $(document).off(Event.FOCUSIN) // guard against infinite focus loop\n      .on(Event.FOCUSIN, function (event) {\n        if (document !== event.target && _this12._element !== event.target && !$(_this12._element).has(event.target).length) {\n          _this12._element.focus();\n        }\n      });\n    };\n\n    Modal.prototype._setEscapeEvent = function _setEscapeEvent() {\n      var _this13 = this;\n\n      if (this._isShown && this._config.keyboard) {\n        $(this._element).on(Event.KEYDOWN_DISMISS, function (event) {\n          if (event.which === ESCAPE_KEYCODE) {\n            _this13.hide();\n          }\n        });\n      } else if (!this._isShown) {\n        $(this._element).off(Event.KEYDOWN_DISMISS);\n      }\n    };\n\n    Modal.prototype._setResizeEvent = function _setResizeEvent() {\n      var _this14 = this;\n\n      if (this._isShown) {\n        $(window).on(Event.RESIZE, function (event) {\n          return _this14._handleUpdate(event);\n        });\n      } else {\n        $(window).off(Event.RESIZE);\n      }\n    };\n\n    Modal.prototype._hideModal = function _hideModal() {\n      var _this15 = this;\n\n      this._element.style.display = 'none';\n      this._element.setAttribute('aria-hidden', 'true');\n      this._isTransitioning = false;\n      this._showBackdrop(function () {\n        $(document.body).removeClass(ClassName.OPEN);\n        _this15._resetAdjustments();\n        _this15._resetScrollbar();\n        $(_this15._element).trigger(Event.HIDDEN);\n      });\n    };\n\n    Modal.prototype._removeBackdrop = function _removeBackdrop() {\n      if (this._backdrop) {\n        $(this._backdrop).remove();\n        this._backdrop = null;\n      }\n    };\n\n    Modal.prototype._showBackdrop = function _showBackdrop(callback) {\n      var _this16 = this;\n\n      var animate = $(this._element).hasClass(ClassName.FADE) ? ClassName.FADE : '';\n\n      if (this._isShown && this._config.backdrop) {\n        var doAnimate = Util.supportsTransitionEnd() && animate;\n\n        this._backdrop = document.createElement('div');\n        this._backdrop.className = ClassName.BACKDROP;\n\n        if (animate) {\n          $(this._backdrop).addClass(animate);\n        }\n\n        $(this._backdrop).appendTo(document.body);\n\n        $(this._element).on(Event.CLICK_DISMISS, function (event) {\n          if (_this16._ignoreBackdropClick) {\n            _this16._ignoreBackdropClick = false;\n            return;\n          }\n          if (event.target !== event.currentTarget) {\n            return;\n          }\n          if (_this16._config.backdrop === 'static') {\n            _this16._element.focus();\n          } else {\n            _this16.hide();\n          }\n        });\n\n        if (doAnimate) {\n          Util.reflow(this._backdrop);\n        }\n\n        $(this._backdrop).addClass(ClassName.SHOW);\n\n        if (!callback) {\n          return;\n        }\n\n        if (!doAnimate) {\n          callback();\n          return;\n        }\n\n        $(this._backdrop).one(Util.TRANSITION_END, callback).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);\n      } else if (!this._isShown && this._backdrop) {\n        $(this._backdrop).removeClass(ClassName.SHOW);\n\n        var callbackRemove = function callbackRemove() {\n          _this16._removeBackdrop();\n          if (callback) {\n            callback();\n          }\n        };\n\n        if (Util.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {\n          $(this._backdrop).one(Util.TRANSITION_END, callbackRemove).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);\n        } else {\n          callbackRemove();\n        }\n      } else if (callback) {\n        callback();\n      }\n    };\n\n    // ----------------------------------------------------------------------\n    // the following methods are used to handle overflowing modals\n    // todo (fat): these should probably be refactored out of modal.js\n    // ----------------------------------------------------------------------\n\n    Modal.prototype._handleUpdate = function _handleUpdate() {\n      this._adjustDialog();\n    };\n\n    Modal.prototype._adjustDialog = function _adjustDialog() {\n      var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\n\n      if (!this._isBodyOverflowing && isModalOverflowing) {\n        this._element.style.paddingLeft = this._scrollbarWidth + 'px';\n      }\n\n      if (this._isBodyOverflowing && !isModalOverflowing) {\n        this._element.style.paddingRight = this._scrollbarWidth + 'px';\n      }\n    };\n\n    Modal.prototype._resetAdjustments = function _resetAdjustments() {\n      this._element.style.paddingLeft = '';\n      this._element.style.paddingRight = '';\n    };\n\n    Modal.prototype._checkScrollbar = function _checkScrollbar() {\n      this._isBodyOverflowing = document.body.clientWidth < window.innerWidth;\n      this._scrollbarWidth = this._getScrollbarWidth();\n    };\n\n    Modal.prototype._setScrollbar = function _setScrollbar() {\n      var bodyPadding = parseInt($(Selector.FIXED_CONTENT).css('padding-right') || 0, 10);\n\n      this._originalBodyPadding = document.body.style.paddingRight || '';\n\n      if (this._isBodyOverflowing) {\n        document.body.style.paddingRight = bodyPadding + this._scrollbarWidth + 'px';\n      }\n    };\n\n    Modal.prototype._resetScrollbar = function _resetScrollbar() {\n      document.body.style.paddingRight = this._originalBodyPadding;\n    };\n\n    Modal.prototype._getScrollbarWidth = function _getScrollbarWidth() {\n      // thx d.walsh\n      var scrollDiv = document.createElement('div');\n      scrollDiv.className = ClassName.SCROLLBAR_MEASURER;\n      document.body.appendChild(scrollDiv);\n      var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n      document.body.removeChild(scrollDiv);\n      return scrollbarWidth;\n    };\n\n    // static\n\n    Modal._jQueryInterface = function _jQueryInterface(config, relatedTarget) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n        var _config = $.extend({}, Modal.Default, $(this).data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config);\n\n        if (!data) {\n          data = new Modal(this, _config);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config](relatedTarget);\n        } else if (_config.show) {\n          data.show(relatedTarget);\n        }\n      });\n    };\n\n    _createClass(Modal, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }]);\n\n    return Modal;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {\n    var _this17 = this;\n\n    var target = void 0;\n    var selector = Util.getSelectorFromElement(this);\n\n    if (selector) {\n      target = $(selector)[0];\n    }\n\n    var config = $(target).data(DATA_KEY) ? 'toggle' : $.extend({}, $(target).data(), $(this).data());\n\n    if (this.tagName === 'A' || this.tagName === 'AREA') {\n      event.preventDefault();\n    }\n\n    var $target = $(target).one(Event.SHOW, function (showEvent) {\n      if (showEvent.isDefaultPrevented()) {\n        // only register focus restorer if modal will actually get shown\n        return;\n      }\n\n      $target.one(Event.HIDDEN, function () {\n        if ($(_this17).is(':visible')) {\n          _this17.focus();\n        }\n      });\n    });\n\n    Modal._jQueryInterface.call($(target), config, this);\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Modal._jQueryInterface;\n  $.fn[NAME].Constructor = Modal;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Modal._jQueryInterface;\n  };\n\n  return Modal;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): scrollspy.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar ScrollSpy = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'scrollspy';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.scrollspy';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n\n  var Default = {\n    offset: 10,\n    method: 'auto',\n    target: ''\n  };\n\n  var DefaultType = {\n    offset: 'number',\n    method: 'string',\n    target: '(string|element)'\n  };\n\n  var Event = {\n    ACTIVATE: 'activate' + EVENT_KEY,\n    SCROLL: 'scroll' + EVENT_KEY,\n    LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    DROPDOWN_ITEM: 'dropdown-item',\n    DROPDOWN_MENU: 'dropdown-menu',\n    NAV_LINK: 'nav-link',\n    NAV: 'nav',\n    ACTIVE: 'active'\n  };\n\n  var Selector = {\n    DATA_SPY: '[data-spy=\"scroll\"]',\n    ACTIVE: '.active',\n    LIST_ITEM: '.list-item',\n    LI: 'li',\n    LI_DROPDOWN: 'li.dropdown',\n    NAV_LINKS: '.nav-link',\n    DROPDOWN: '.dropdown',\n    DROPDOWN_ITEMS: '.dropdown-item',\n    DROPDOWN_TOGGLE: '.dropdown-toggle'\n  };\n\n  var OffsetMethod = {\n    OFFSET: 'offset',\n    POSITION: 'position'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var ScrollSpy = function () {\n    function ScrollSpy(element, config) {\n      var _this18 = this;\n\n      _classCallCheck(this, ScrollSpy);\n\n      this._element = element;\n      this._scrollElement = element.tagName === 'BODY' ? window : element;\n      this._config = this._getConfig(config);\n      this._selector = this._config.target + ' ' + Selector.NAV_LINKS + ',' + (this._config.target + ' ' + Selector.DROPDOWN_ITEMS);\n      this._offsets = [];\n      this._targets = [];\n      this._activeTarget = null;\n      this._scrollHeight = 0;\n\n      $(this._scrollElement).on(Event.SCROLL, function (event) {\n        return _this18._process(event);\n      });\n\n      this.refresh();\n      this._process();\n    }\n\n    // getters\n\n    // public\n\n    ScrollSpy.prototype.refresh = function refresh() {\n      var _this19 = this;\n\n      var autoMethod = this._scrollElement !== this._scrollElement.window ? OffsetMethod.POSITION : OffsetMethod.OFFSET;\n\n      var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method;\n\n      var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0;\n\n      this._offsets = [];\n      this._targets = [];\n\n      this._scrollHeight = this._getScrollHeight();\n\n      var targets = $.makeArray($(this._selector));\n\n      targets.map(function (element) {\n        var target = void 0;\n        var targetSelector = Util.getSelectorFromElement(element);\n\n        if (targetSelector) {\n          target = $(targetSelector)[0];\n        }\n\n        if (target && (target.offsetWidth || target.offsetHeight)) {\n          // todo (fat): remove sketch reliance on jQuery position/offset\n          return [$(target)[offsetMethod]().top + offsetBase, targetSelector];\n        }\n        return null;\n      }).filter(function (item) {\n        return item;\n      }).sort(function (a, b) {\n        return a[0] - b[0];\n      }).forEach(function (item) {\n        _this19._offsets.push(item[0]);\n        _this19._targets.push(item[1]);\n      });\n    };\n\n    ScrollSpy.prototype.dispose = function dispose() {\n      $.removeData(this._element, DATA_KEY);\n      $(this._scrollElement).off(EVENT_KEY);\n\n      this._element = null;\n      this._scrollElement = null;\n      this._config = null;\n      this._selector = null;\n      this._offsets = null;\n      this._targets = null;\n      this._activeTarget = null;\n      this._scrollHeight = null;\n    };\n\n    // private\n\n    ScrollSpy.prototype._getConfig = function _getConfig(config) {\n      config = $.extend({}, Default, config);\n\n      if (typeof config.target !== 'string') {\n        var id = $(config.target).attr('id');\n        if (!id) {\n          id = Util.getUID(NAME);\n          $(config.target).attr('id', id);\n        }\n        config.target = '#' + id;\n      }\n\n      Util.typeCheckConfig(NAME, config, DefaultType);\n\n      return config;\n    };\n\n    ScrollSpy.prototype._getScrollTop = function _getScrollTop() {\n      return this._scrollElement === window ? this._scrollElement.pageYOffset : this._scrollElement.scrollTop;\n    };\n\n    ScrollSpy.prototype._getScrollHeight = function _getScrollHeight() {\n      return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);\n    };\n\n    ScrollSpy.prototype._getOffsetHeight = function _getOffsetHeight() {\n      return this._scrollElement === window ? window.innerHeight : this._scrollElement.offsetHeight;\n    };\n\n    ScrollSpy.prototype._process = function _process() {\n      var scrollTop = this._getScrollTop() + this._config.offset;\n      var scrollHeight = this._getScrollHeight();\n      var maxScroll = this._config.offset + scrollHeight - this._getOffsetHeight();\n\n      if (this._scrollHeight !== scrollHeight) {\n        this.refresh();\n      }\n\n      if (scrollTop >= maxScroll) {\n        var target = this._targets[this._targets.length - 1];\n\n        if (this._activeTarget !== target) {\n          this._activate(target);\n        }\n        return;\n      }\n\n      if (this._activeTarget && scrollTop < this._offsets[0] && this._offsets[0] > 0) {\n        this._activeTarget = null;\n        this._clear();\n        return;\n      }\n\n      for (var i = this._offsets.length; i--;) {\n        var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (this._offsets[i + 1] === undefined || scrollTop < this._offsets[i + 1]);\n\n        if (isActiveTarget) {\n          this._activate(this._targets[i]);\n        }\n      }\n    };\n\n    ScrollSpy.prototype._activate = function _activate(target) {\n      this._activeTarget = target;\n\n      this._clear();\n\n      var queries = this._selector.split(',');\n      queries = queries.map(function (selector) {\n        return selector + '[data-target=\"' + target + '\"],' + (selector + '[href=\"' + target + '\"]');\n      });\n\n      var $link = $(queries.join(','));\n\n      if ($link.hasClass(ClassName.DROPDOWN_ITEM)) {\n        $link.closest(Selector.DROPDOWN).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);\n        $link.addClass(ClassName.ACTIVE);\n      } else {\n        // todo (fat) this is kinda sus...\n        // recursively add actives to tested nav-links\n        $link.parents(Selector.LI).find('> ' + Selector.NAV_LINKS).addClass(ClassName.ACTIVE);\n      }\n\n      $(this._scrollElement).trigger(Event.ACTIVATE, {\n        relatedTarget: target\n      });\n    };\n\n    ScrollSpy.prototype._clear = function _clear() {\n      $(this._selector).filter(Selector.ACTIVE).removeClass(ClassName.ACTIVE);\n    };\n\n    // static\n\n    ScrollSpy._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n        var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config;\n\n        if (!data) {\n          data = new ScrollSpy(this, _config);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(ScrollSpy, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }]);\n\n    return ScrollSpy;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(window).on(Event.LOAD_DATA_API, function () {\n    var scrollSpys = $.makeArray($(Selector.DATA_SPY));\n\n    for (var i = scrollSpys.length; i--;) {\n      var $spy = $(scrollSpys[i]);\n      ScrollSpy._jQueryInterface.call($spy, $spy.data());\n    }\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = ScrollSpy._jQueryInterface;\n  $.fn[NAME].Constructor = ScrollSpy;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return ScrollSpy._jQueryInterface;\n  };\n\n  return ScrollSpy;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): tab.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Tab = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'tab';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.tab';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var DATA_API_KEY = '.data-api';\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 150;\n\n  var Event = {\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n  };\n\n  var ClassName = {\n    DROPDOWN_MENU: 'dropdown-menu',\n    ACTIVE: 'active',\n    DISABLED: 'disabled',\n    FADE: 'fade',\n    SHOW: 'show'\n  };\n\n  var Selector = {\n    A: 'a',\n    LI: 'li',\n    DROPDOWN: '.dropdown',\n    LIST: 'ul:not(.dropdown-menu), ol:not(.dropdown-menu), nav:not(.dropdown-menu)',\n    FADE_CHILD: '> .nav-item .fade, > .fade',\n    ACTIVE: '.active',\n    ACTIVE_CHILD: '> .nav-item > .active, > .active',\n    DATA_TOGGLE: '[data-toggle=\"tab\"], [data-toggle=\"pill\"]',\n    DROPDOWN_TOGGLE: '.dropdown-toggle',\n    DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Tab = function () {\n    function Tab(element) {\n      _classCallCheck(this, Tab);\n\n      this._element = element;\n    }\n\n    // getters\n\n    // public\n\n    Tab.prototype.show = function show() {\n      var _this20 = this;\n\n      if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $(this._element).hasClass(ClassName.ACTIVE) || $(this._element).hasClass(ClassName.DISABLED)) {\n        return;\n      }\n\n      var target = void 0;\n      var previous = void 0;\n      var listElement = $(this._element).closest(Selector.LIST)[0];\n      var selector = Util.getSelectorFromElement(this._element);\n\n      if (listElement) {\n        previous = $.makeArray($(listElement).find(Selector.ACTIVE));\n        previous = previous[previous.length - 1];\n      }\n\n      var hideEvent = $.Event(Event.HIDE, {\n        relatedTarget: this._element\n      });\n\n      var showEvent = $.Event(Event.SHOW, {\n        relatedTarget: previous\n      });\n\n      if (previous) {\n        $(previous).trigger(hideEvent);\n      }\n\n      $(this._element).trigger(showEvent);\n\n      if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      if (selector) {\n        target = $(selector)[0];\n      }\n\n      this._activate(this._element, listElement);\n\n      var complete = function complete() {\n        var hiddenEvent = $.Event(Event.HIDDEN, {\n          relatedTarget: _this20._element\n        });\n\n        var shownEvent = $.Event(Event.SHOWN, {\n          relatedTarget: previous\n        });\n\n        $(previous).trigger(hiddenEvent);\n        $(_this20._element).trigger(shownEvent);\n      };\n\n      if (target) {\n        this._activate(target, target.parentNode, complete);\n      } else {\n        complete();\n      }\n    };\n\n    Tab.prototype.dispose = function dispose() {\n      $.removeClass(this._element, DATA_KEY);\n      this._element = null;\n    };\n\n    // private\n\n    Tab.prototype._activate = function _activate(element, container, callback) {\n      var _this21 = this;\n\n      var active = $(container).find(Selector.ACTIVE_CHILD)[0];\n      var isTransitioning = callback && Util.supportsTransitionEnd() && (active && $(active).hasClass(ClassName.FADE) || Boolean($(container).find(Selector.FADE_CHILD)[0]));\n\n      var complete = function complete() {\n        return _this21._transitionComplete(element, active, isTransitioning, callback);\n      };\n\n      if (active && isTransitioning) {\n        $(active).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n      } else {\n        complete();\n      }\n\n      if (active) {\n        $(active).removeClass(ClassName.SHOW);\n      }\n    };\n\n    Tab.prototype._transitionComplete = function _transitionComplete(element, active, isTransitioning, callback) {\n      if (active) {\n        $(active).removeClass(ClassName.ACTIVE);\n\n        var dropdownChild = $(active.parentNode).find(Selector.DROPDOWN_ACTIVE_CHILD)[0];\n\n        if (dropdownChild) {\n          $(dropdownChild).removeClass(ClassName.ACTIVE);\n        }\n\n        active.setAttribute('aria-expanded', false);\n      }\n\n      $(element).addClass(ClassName.ACTIVE);\n      element.setAttribute('aria-expanded', true);\n\n      if (isTransitioning) {\n        Util.reflow(element);\n        $(element).addClass(ClassName.SHOW);\n      } else {\n        $(element).removeClass(ClassName.FADE);\n      }\n\n      if (element.parentNode && $(element.parentNode).hasClass(ClassName.DROPDOWN_MENU)) {\n\n        var dropdownElement = $(element).closest(Selector.DROPDOWN)[0];\n        if (dropdownElement) {\n          $(dropdownElement).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);\n        }\n\n        element.setAttribute('aria-expanded', true);\n      }\n\n      if (callback) {\n        callback();\n      }\n    };\n\n    // static\n\n    Tab._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var $this = $(this);\n        var data = $this.data(DATA_KEY);\n\n        if (!data) {\n          data = new Tab(this);\n          $this.data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(Tab, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }]);\n\n    return Tab;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * Data Api implementation\n   * ------------------------------------------------------------------------\n   */\n\n  $(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {\n    event.preventDefault();\n    Tab._jQueryInterface.call($(this), 'show');\n  });\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Tab._jQueryInterface;\n  $.fn[NAME].Constructor = Tab;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Tab._jQueryInterface;\n  };\n\n  return Tab;\n}(jQuery);\n\n/* global Tether */\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): tooltip.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Tooltip = function ($) {\n\n  /**\n   * Check for Tether dependency\n   * Tether - http://tether.io/\n   */\n  if (typeof Tether === 'undefined') {\n    throw new Error('Bootstrap tooltips require Tether (http://tether.io/)');\n  }\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'tooltip';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.tooltip';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n  var TRANSITION_DURATION = 150;\n  var CLASS_PREFIX = 'bs-tether';\n\n  var Default = {\n    animation: true,\n    template: '<div class=\"tooltip\" role=\"tooltip\">' + '<div class=\"tooltip-inner\"></div></div>',\n    trigger: 'hover focus',\n    title: '',\n    delay: 0,\n    html: false,\n    selector: false,\n    placement: 'top',\n    offset: '0 0',\n    constraints: [],\n    container: false\n  };\n\n  var DefaultType = {\n    animation: 'boolean',\n    template: 'string',\n    title: '(string|element|function)',\n    trigger: 'string',\n    delay: '(number|object)',\n    html: 'boolean',\n    selector: '(string|boolean)',\n    placement: '(string|function)',\n    offset: 'string',\n    constraints: 'array',\n    container: '(string|element|boolean)'\n  };\n\n  var AttachmentMap = {\n    TOP: 'bottom center',\n    RIGHT: 'middle left',\n    BOTTOM: 'top center',\n    LEFT: 'middle right'\n  };\n\n  var HoverState = {\n    SHOW: 'show',\n    OUT: 'out'\n  };\n\n  var Event = {\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    INSERTED: 'inserted' + EVENT_KEY,\n    CLICK: 'click' + EVENT_KEY,\n    FOCUSIN: 'focusin' + EVENT_KEY,\n    FOCUSOUT: 'focusout' + EVENT_KEY,\n    MOUSEENTER: 'mouseenter' + EVENT_KEY,\n    MOUSELEAVE: 'mouseleave' + EVENT_KEY\n  };\n\n  var ClassName = {\n    FADE: 'fade',\n    SHOW: 'show'\n  };\n\n  var Selector = {\n    TOOLTIP: '.tooltip',\n    TOOLTIP_INNER: '.tooltip-inner'\n  };\n\n  var TetherClass = {\n    element: false,\n    enabled: false\n  };\n\n  var Trigger = {\n    HOVER: 'hover',\n    FOCUS: 'focus',\n    CLICK: 'click',\n    MANUAL: 'manual'\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Tooltip = function () {\n    function Tooltip(element, config) {\n      _classCallCheck(this, Tooltip);\n\n      // private\n      this._isEnabled = true;\n      this._timeout = 0;\n      this._hoverState = '';\n      this._activeTrigger = {};\n      this._isTransitioning = false;\n      this._tether = null;\n\n      // protected\n      this.element = element;\n      this.config = this._getConfig(config);\n      this.tip = null;\n\n      this._setListeners();\n    }\n\n    // getters\n\n    // public\n\n    Tooltip.prototype.enable = function enable() {\n      this._isEnabled = true;\n    };\n\n    Tooltip.prototype.disable = function disable() {\n      this._isEnabled = false;\n    };\n\n    Tooltip.prototype.toggleEnabled = function toggleEnabled() {\n      this._isEnabled = !this._isEnabled;\n    };\n\n    Tooltip.prototype.toggle = function toggle(event) {\n      if (event) {\n        var dataKey = this.constructor.DATA_KEY;\n        var context = $(event.currentTarget).data(dataKey);\n\n        if (!context) {\n          context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n          $(event.currentTarget).data(dataKey, context);\n        }\n\n        context._activeTrigger.click = !context._activeTrigger.click;\n\n        if (context._isWithActiveTrigger()) {\n          context._enter(null, context);\n        } else {\n          context._leave(null, context);\n        }\n      } else {\n\n        if ($(this.getTipElement()).hasClass(ClassName.SHOW)) {\n          this._leave(null, this);\n          return;\n        }\n\n        this._enter(null, this);\n      }\n    };\n\n    Tooltip.prototype.dispose = function dispose() {\n      clearTimeout(this._timeout);\n\n      this.cleanupTether();\n\n      $.removeData(this.element, this.constructor.DATA_KEY);\n\n      $(this.element).off(this.constructor.EVENT_KEY);\n      $(this.element).closest('.modal').off('hide.bs.modal');\n\n      if (this.tip) {\n        $(this.tip).remove();\n      }\n\n      this._isEnabled = null;\n      this._timeout = null;\n      this._hoverState = null;\n      this._activeTrigger = null;\n      this._tether = null;\n\n      this.element = null;\n      this.config = null;\n      this.tip = null;\n    };\n\n    Tooltip.prototype.show = function show() {\n      var _this22 = this;\n\n      if ($(this.element).css('display') === 'none') {\n        throw new Error('Please use show on visible elements');\n      }\n\n      var showEvent = $.Event(this.constructor.Event.SHOW);\n      if (this.isWithContent() && this._isEnabled) {\n        if (this._isTransitioning) {\n          throw new Error('Tooltip is transitioning');\n        }\n        $(this.element).trigger(showEvent);\n\n        var isInTheDom = $.contains(this.element.ownerDocument.documentElement, this.element);\n\n        if (showEvent.isDefaultPrevented() || !isInTheDom) {\n          return;\n        }\n\n        var tip = this.getTipElement();\n        var tipId = Util.getUID(this.constructor.NAME);\n\n        tip.setAttribute('id', tipId);\n        this.element.setAttribute('aria-describedby', tipId);\n\n        this.setContent();\n\n        if (this.config.animation) {\n          $(tip).addClass(ClassName.FADE);\n        }\n\n        var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement;\n\n        var attachment = this._getAttachment(placement);\n\n        var container = this.config.container === false ? document.body : $(this.config.container);\n\n        $(tip).data(this.constructor.DATA_KEY, this).appendTo(container);\n\n        $(this.element).trigger(this.constructor.Event.INSERTED);\n\n        this._tether = new Tether({\n          attachment: attachment,\n          element: tip,\n          target: this.element,\n          classes: TetherClass,\n          classPrefix: CLASS_PREFIX,\n          offset: this.config.offset,\n          constraints: this.config.constraints,\n          addTargetClasses: false\n        });\n\n        Util.reflow(tip);\n        this._tether.position();\n\n        $(tip).addClass(ClassName.SHOW);\n\n        var complete = function complete() {\n          var prevHoverState = _this22._hoverState;\n          _this22._hoverState = null;\n          _this22._isTransitioning = false;\n\n          $(_this22.element).trigger(_this22.constructor.Event.SHOWN);\n\n          if (prevHoverState === HoverState.OUT) {\n            _this22._leave(null, _this22);\n          }\n        };\n\n        if (Util.supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {\n          this._isTransitioning = true;\n          $(this.tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(Tooltip._TRANSITION_DURATION);\n          return;\n        }\n\n        complete();\n      }\n    };\n\n    Tooltip.prototype.hide = function hide(callback) {\n      var _this23 = this;\n\n      var tip = this.getTipElement();\n      var hideEvent = $.Event(this.constructor.Event.HIDE);\n      if (this._isTransitioning) {\n        throw new Error('Tooltip is transitioning');\n      }\n      var complete = function complete() {\n        if (_this23._hoverState !== HoverState.SHOW && tip.parentNode) {\n          tip.parentNode.removeChild(tip);\n        }\n\n        _this23.element.removeAttribute('aria-describedby');\n        $(_this23.element).trigger(_this23.constructor.Event.HIDDEN);\n        _this23._isTransitioning = false;\n        _this23.cleanupTether();\n\n        if (callback) {\n          callback();\n        }\n      };\n\n      $(this.element).trigger(hideEvent);\n\n      if (hideEvent.isDefaultPrevented()) {\n        return;\n      }\n\n      $(tip).removeClass(ClassName.SHOW);\n\n      this._activeTrigger[Trigger.CLICK] = false;\n      this._activeTrigger[Trigger.FOCUS] = false;\n      this._activeTrigger[Trigger.HOVER] = false;\n\n      if (Util.supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {\n        this._isTransitioning = true;\n        $(tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n      } else {\n        complete();\n      }\n\n      this._hoverState = '';\n    };\n\n    // protected\n\n    Tooltip.prototype.isWithContent = function isWithContent() {\n      return Boolean(this.getTitle());\n    };\n\n    Tooltip.prototype.getTipElement = function getTipElement() {\n      return this.tip = this.tip || $(this.config.template)[0];\n    };\n\n    Tooltip.prototype.setContent = function setContent() {\n      var $tip = $(this.getTipElement());\n\n      this.setElementContent($tip.find(Selector.TOOLTIP_INNER), this.getTitle());\n\n      $tip.removeClass(ClassName.FADE + ' ' + ClassName.SHOW);\n\n      this.cleanupTether();\n    };\n\n    Tooltip.prototype.setElementContent = function setElementContent($element, content) {\n      var html = this.config.html;\n      if ((typeof content === 'undefined' ? 'undefined' : _typeof(content)) === 'object' && (content.nodeType || content.jquery)) {\n        // content is a DOM node or a jQuery\n        if (html) {\n          if (!$(content).parent().is($element)) {\n            $element.empty().append(content);\n          }\n        } else {\n          $element.text($(content).text());\n        }\n      } else {\n        $element[html ? 'html' : 'text'](content);\n      }\n    };\n\n    Tooltip.prototype.getTitle = function getTitle() {\n      var title = this.element.getAttribute('data-original-title');\n\n      if (!title) {\n        title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title;\n      }\n\n      return title;\n    };\n\n    Tooltip.prototype.cleanupTether = function cleanupTether() {\n      if (this._tether) {\n        this._tether.destroy();\n      }\n    };\n\n    // private\n\n    Tooltip.prototype._getAttachment = function _getAttachment(placement) {\n      return AttachmentMap[placement.toUpperCase()];\n    };\n\n    Tooltip.prototype._setListeners = function _setListeners() {\n      var _this24 = this;\n\n      var triggers = this.config.trigger.split(' ');\n\n      triggers.forEach(function (trigger) {\n        if (trigger === 'click') {\n          $(_this24.element).on(_this24.constructor.Event.CLICK, _this24.config.selector, function (event) {\n            return _this24.toggle(event);\n          });\n        } else if (trigger !== Trigger.MANUAL) {\n          var eventIn = trigger === Trigger.HOVER ? _this24.constructor.Event.MOUSEENTER : _this24.constructor.Event.FOCUSIN;\n          var eventOut = trigger === Trigger.HOVER ? _this24.constructor.Event.MOUSELEAVE : _this24.constructor.Event.FOCUSOUT;\n\n          $(_this24.element).on(eventIn, _this24.config.selector, function (event) {\n            return _this24._enter(event);\n          }).on(eventOut, _this24.config.selector, function (event) {\n            return _this24._leave(event);\n          });\n        }\n\n        $(_this24.element).closest('.modal').on('hide.bs.modal', function () {\n          return _this24.hide();\n        });\n      });\n\n      if (this.config.selector) {\n        this.config = $.extend({}, this.config, {\n          trigger: 'manual',\n          selector: ''\n        });\n      } else {\n        this._fixTitle();\n      }\n    };\n\n    Tooltip.prototype._fixTitle = function _fixTitle() {\n      var titleType = _typeof(this.element.getAttribute('data-original-title'));\n      if (this.element.getAttribute('title') || titleType !== 'string') {\n        this.element.setAttribute('data-original-title', this.element.getAttribute('title') || '');\n        this.element.setAttribute('title', '');\n      }\n    };\n\n    Tooltip.prototype._enter = function _enter(event, context) {\n      var dataKey = this.constructor.DATA_KEY;\n\n      context = context || $(event.currentTarget).data(dataKey);\n\n      if (!context) {\n        context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n        $(event.currentTarget).data(dataKey, context);\n      }\n\n      if (event) {\n        context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true;\n      }\n\n      if ($(context.getTipElement()).hasClass(ClassName.SHOW) || context._hoverState === HoverState.SHOW) {\n        context._hoverState = HoverState.SHOW;\n        return;\n      }\n\n      clearTimeout(context._timeout);\n\n      context._hoverState = HoverState.SHOW;\n\n      if (!context.config.delay || !context.config.delay.show) {\n        context.show();\n        return;\n      }\n\n      context._timeout = setTimeout(function () {\n        if (context._hoverState === HoverState.SHOW) {\n          context.show();\n        }\n      }, context.config.delay.show);\n    };\n\n    Tooltip.prototype._leave = function _leave(event, context) {\n      var dataKey = this.constructor.DATA_KEY;\n\n      context = context || $(event.currentTarget).data(dataKey);\n\n      if (!context) {\n        context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n        $(event.currentTarget).data(dataKey, context);\n      }\n\n      if (event) {\n        context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false;\n      }\n\n      if (context._isWithActiveTrigger()) {\n        return;\n      }\n\n      clearTimeout(context._timeout);\n\n      context._hoverState = HoverState.OUT;\n\n      if (!context.config.delay || !context.config.delay.hide) {\n        context.hide();\n        return;\n      }\n\n      context._timeout = setTimeout(function () {\n        if (context._hoverState === HoverState.OUT) {\n          context.hide();\n        }\n      }, context.config.delay.hide);\n    };\n\n    Tooltip.prototype._isWithActiveTrigger = function _isWithActiveTrigger() {\n      for (var trigger in this._activeTrigger) {\n        if (this._activeTrigger[trigger]) {\n          return true;\n        }\n      }\n\n      return false;\n    };\n\n    Tooltip.prototype._getConfig = function _getConfig(config) {\n      config = $.extend({}, this.constructor.Default, $(this.element).data(), config);\n\n      if (config.delay && typeof config.delay === 'number') {\n        config.delay = {\n          show: config.delay,\n          hide: config.delay\n        };\n      }\n\n      Util.typeCheckConfig(NAME, config, this.constructor.DefaultType);\n\n      return config;\n    };\n\n    Tooltip.prototype._getDelegateConfig = function _getDelegateConfig() {\n      var config = {};\n\n      if (this.config) {\n        for (var key in this.config) {\n          if (this.constructor.Default[key] !== this.config[key]) {\n            config[key] = this.config[key];\n          }\n        }\n      }\n\n      return config;\n    };\n\n    // static\n\n    Tooltip._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n        var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config;\n\n        if (!data && /dispose|hide/.test(config)) {\n          return;\n        }\n\n        if (!data) {\n          data = new Tooltip(this, _config);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(Tooltip, null, [{\n      key: 'VERSION',\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }, {\n      key: 'NAME',\n      get: function get() {\n        return NAME;\n      }\n    }, {\n      key: 'DATA_KEY',\n      get: function get() {\n        return DATA_KEY;\n      }\n    }, {\n      key: 'Event',\n      get: function get() {\n        return Event;\n      }\n    }, {\n      key: 'EVENT_KEY',\n      get: function get() {\n        return EVENT_KEY;\n      }\n    }, {\n      key: 'DefaultType',\n      get: function get() {\n        return DefaultType;\n      }\n    }]);\n\n    return Tooltip;\n  }();\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Tooltip._jQueryInterface;\n  $.fn[NAME].Constructor = Tooltip;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Tooltip._jQueryInterface;\n  };\n\n  return Tooltip;\n}(jQuery);\n\n/**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.0.0-alpha.6): popover.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n\nvar Popover = function ($) {\n\n  /**\n   * ------------------------------------------------------------------------\n   * Constants\n   * ------------------------------------------------------------------------\n   */\n\n  var NAME = 'popover';\n  var VERSION = '4.0.0-alpha.6';\n  var DATA_KEY = 'bs.popover';\n  var EVENT_KEY = '.' + DATA_KEY;\n  var JQUERY_NO_CONFLICT = $.fn[NAME];\n\n  var Default = $.extend({}, Tooltip.Default, {\n    placement: 'right',\n    trigger: 'click',\n    content: '',\n    template: '<div class=\"popover\" role=\"tooltip\">' + '<h3 class=\"popover-title\"></h3>' + '<div class=\"popover-content\"></div></div>'\n  });\n\n  var DefaultType = $.extend({}, Tooltip.DefaultType, {\n    content: '(string|element|function)'\n  });\n\n  var ClassName = {\n    FADE: 'fade',\n    SHOW: 'show'\n  };\n\n  var Selector = {\n    TITLE: '.popover-title',\n    CONTENT: '.popover-content'\n  };\n\n  var Event = {\n    HIDE: 'hide' + EVENT_KEY,\n    HIDDEN: 'hidden' + EVENT_KEY,\n    SHOW: 'show' + EVENT_KEY,\n    SHOWN: 'shown' + EVENT_KEY,\n    INSERTED: 'inserted' + EVENT_KEY,\n    CLICK: 'click' + EVENT_KEY,\n    FOCUSIN: 'focusin' + EVENT_KEY,\n    FOCUSOUT: 'focusout' + EVENT_KEY,\n    MOUSEENTER: 'mouseenter' + EVENT_KEY,\n    MOUSELEAVE: 'mouseleave' + EVENT_KEY\n  };\n\n  /**\n   * ------------------------------------------------------------------------\n   * Class Definition\n   * ------------------------------------------------------------------------\n   */\n\n  var Popover = function (_Tooltip) {\n    _inherits(Popover, _Tooltip);\n\n    function Popover() {\n      _classCallCheck(this, Popover);\n\n      return _possibleConstructorReturn(this, _Tooltip.apply(this, arguments));\n    }\n\n    // overrides\n\n    Popover.prototype.isWithContent = function isWithContent() {\n      return this.getTitle() || this._getContent();\n    };\n\n    Popover.prototype.getTipElement = function getTipElement() {\n      return this.tip = this.tip || $(this.config.template)[0];\n    };\n\n    Popover.prototype.setContent = function setContent() {\n      var $tip = $(this.getTipElement());\n\n      // we use append for html objects to maintain js events\n      this.setElementContent($tip.find(Selector.TITLE), this.getTitle());\n      this.setElementContent($tip.find(Selector.CONTENT), this._getContent());\n\n      $tip.removeClass(ClassName.FADE + ' ' + ClassName.SHOW);\n\n      this.cleanupTether();\n    };\n\n    // private\n\n    Popover.prototype._getContent = function _getContent() {\n      return this.element.getAttribute('data-content') || (typeof this.config.content === 'function' ? this.config.content.call(this.element) : this.config.content);\n    };\n\n    // static\n\n    Popover._jQueryInterface = function _jQueryInterface(config) {\n      return this.each(function () {\n        var data = $(this).data(DATA_KEY);\n        var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' ? config : null;\n\n        if (!data && /destroy|hide/.test(config)) {\n          return;\n        }\n\n        if (!data) {\n          data = new Popover(this, _config);\n          $(this).data(DATA_KEY, data);\n        }\n\n        if (typeof config === 'string') {\n          if (data[config] === undefined) {\n            throw new Error('No method named \"' + config + '\"');\n          }\n          data[config]();\n        }\n      });\n    };\n\n    _createClass(Popover, null, [{\n      key: 'VERSION',\n\n\n      // getters\n\n      get: function get() {\n        return VERSION;\n      }\n    }, {\n      key: 'Default',\n      get: function get() {\n        return Default;\n      }\n    }, {\n      key: 'NAME',\n      get: function get() {\n        return NAME;\n      }\n    }, {\n      key: 'DATA_KEY',\n      get: function get() {\n        return DATA_KEY;\n      }\n    }, {\n      key: 'Event',\n      get: function get() {\n        return Event;\n      }\n    }, {\n      key: 'EVENT_KEY',\n      get: function get() {\n        return EVENT_KEY;\n      }\n    }, {\n      key: 'DefaultType',\n      get: function get() {\n        return DefaultType;\n      }\n    }]);\n\n    return Popover;\n  }(Tooltip);\n\n  /**\n   * ------------------------------------------------------------------------\n   * jQuery\n   * ------------------------------------------------------------------------\n   */\n\n  $.fn[NAME] = Popover._jQueryInterface;\n  $.fn[NAME].Constructor = Popover;\n  $.fn[NAME].noConflict = function () {\n    $.fn[NAME] = JQUERY_NO_CONFLICT;\n    return Popover._jQueryInterface;\n  };\n\n  return Popover;\n}(jQuery);\n\n}();\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/chartist-init.css",
    "content": ".ct-sm-line-chart,\n.ct-area-ln-chart,\n#ct-polar-chart,\n.ct-svg-chartct-bar-chart, .total-revenue, .chartist-chart {\n    position: relative;\n}\n\n.ct-sm-line-chart .ct-series-a .ct-line,\n.ct-bar-chart .ct-series-a .ct-bar,\n.ct-sm-line-chart .ct-series-a .ct-point,\n.ct-donute-chart .ct-series-a .ct-slice-donut,\n.ct-gauge-chart .ct-series-a .ct-slice-donut,\n.ct-area-ln-chart .ct-series-a .ct-line,\n.ct-area-ln-chart .ct-series-a .ct-point,\n.ct-animation-chart .ct-series-a .ct-line,\n.ct-animation-chart .ct-series-a .ct-point,\n.ct-svg-chart .ct-series-a .ct-line,\n.user-analytics .ct-series-a .ct-line,\n.user-analytics .ct-series-a .ct-point{\n    stroke: #009efb;\n}\n\n.ct-sm-line-chart .ct-series-b .ct-line,\n.ct-bar-chart .ct-series-b .ct-bar,\n.ct-sm-line-chart .ct-series-b .ct-point,\n.ct-donute-chart .ct-series-b .ct-slice-donut,\n.ct-gauge-chart .ct-series-b .ct-slice-donut,\n.ct-animation-chart .ct-series-b .ct-line,\n.ct-animation-chart .ct-series-b .ct-point,\n.ct-svg-chart .ct-series-b .ct-line {\n    stroke: #f62d51;\n}\n\n.ct-sm-line-chart .ct-series-c .ct-line,\n.ct-sm-line-chart .ct-series-c .ct-point,\n.ct-donute-chart .ct-series-c .ct-slice-donut,\n.ct-gauge-chart .ct-series-c .ct-slice-donut,\n.ct-animation-chart .ct-series-c .ct-line,\n.ct-animation-chart .ct-series-c .ct-point,\n.ct-svg-chart .ct-series-c .ct-line {\n    stroke: #26c6da;\n}\n\n.ct-gauge-chart .ct-series-d .ct-slice-donut,\n.ct-donute-chart .ct-series-d .ct-slice-donut {\n    stroke: #ffbc34;\n}\n\n.ct-donute-chart .ct-series-e .ct-slice-donut {\n    stroke: #4c5667;\n}\n\n.ct-donute-chart .ct-series-f .ct-slice-donut {\n    stroke: #02bec9;\n}\n\n.ct-area-ln-chart .ct-series-a .ct-area,\n.ct-svg-chart .ct-series-a .ct-area {\n    fill: #009efb;\n}\n.user-analytics .ct-series-a .ct-area{\n    fill:none;\n}\n\n/*Android vs ios chart*/\n.andvios .ct-series-a .ct-line,\n.andvios .ct-series-b .ct-line\n{\n    stroke: transparent;\n   \n}\n.andvios .ct-series-a .ct-point, .andvios .ct-series-b .ct-point{\n    stroke-width:3px;\n    stroke:#26c6da;\n}\n.andvios .ct-series-a .ct-area{\n    fill:#1eacbe;\n    fill-opacity:0.3;\n}\n.andvios .ct-series-b .ct-area{\n    fill:#26c6da;\n    fill-opacity:0.7;\n}\n/*Bandwidth data usege*/\n.usage .ct-series-a .ct-line{\n    stroke:#fff;\n}\n.usage .ct-series-a .ct-point{\n    stroke-width:0px;\n}\n.usage .ct-series-a .ct-area{\n    fill-opacity:0;\n}\n\n/*Download stats */\n.download-state .ct-series-b .ct-bar, .download-state .ct-series-a .ct-bar{\n     stroke-width:3px;\n}\n.download-state .ct-series-b .ct-bar{\n    stroke:#26c6da;\n}\n.download-state .ct-series-a .ct-bar{\n    stroke:#7460ee;\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/chartist-init.js",
    "content": "//Simple line chart \n\nnew Chartist.Line('.ct-sm-line-chart', {\n  labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'],\n  series: [\n    [12, 9, 7, 8, 5],\n    [2, 1, 3.5, 7, 3],\n    [1, 3, 4, 5, 6]\n  ]\n}, {\n  fullWidth: true,\n  \n  plugins: [\n    Chartist.plugins.tooltip()\n  ],\n  chartPadding: {\n    right: 40\n  }\n});\n\n// line chart with area\n\nnew Chartist.Line('.ct-area-ln-chart', {\n  labels: [1, 2, 3, 4, 5, 6, 7, 8],\n  series: [\n    [5, 9, 7, 8, 5, 3, 5, 4]\n  ]\n}, {\n  low: 0,\n\n  plugins: [\n    Chartist.plugins.tooltip()\n  ],\n  showArea: true\n});\n\n// ct-polar-chart\nnew Chartist.Line('#ct-polar-chart', {\n  labels: [1, 2, 3, 4, 5, 6, 7, 8],\n  series: [\n    [1, 2, 3, 1, -2, 0, 1, 0],\n    [-2, -1, -2, -1, -2.5, -1, -2, -1],\n    [0, 0, 0, 1, 2, 2.5, 2, 1],\n    [2.5, 2, 1, 0.5, 1, 0.5, -1, -2.5]\n  ]\n}, {\n  high: 3,\n  low: -3,\n  chartPadding: {\n    left: -20,\n    top:10,\n  },\n  showArea: true,\n  showLine: false,\n  showPoint: true,\n  fullWidth: true,\n  plugins: [\n    Chartist.plugins.tooltip()\n  ],\n  axisX: {\n    showLabel: true,\n    showGrid: true\n  },\n  axisY: {\n    showLabel: false,\n    showGrid: true\n  }\n});\n\n// ct-animation-chart\n\nvar chart = new Chartist.Line('.ct-animation-chart', {\n  labels: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12'],\n  series: [\n    [12, 9, 7, 8, 5, 4, 6, 2, 3, 3, 4, 6],\n    [4,  5, 3, 7, 3, 5, 5, 3, 4, 4, 5, 5],\n    [5,  3, 4, 5, 6, 3, 3, 4, 5, 6, 3, 4]\n  ]\n}, {\n  low: 0\n});\n\n// Let's put a sequence number aside so we can use it in the event callbacks\nvar seq = 0,\n  delays = 80,\n  durations = 500;\n\n// Once the chart is fully created we reset the sequence\nchart.on('created', function() {\n  seq = 0;\n});\n\n// On each drawn element by Chartist we use the Chartist.Svg API to trigger SMIL animations\nchart.on('draw', function(data) {\n  seq++;\n\n  if(data.type === 'line') {\n    // If the drawn element is a line we do a simple opacity fade in. This could also be achieved using CSS3 animations.\n    data.element.animate({\n      opacity: {\n        // The delay when we like to start the animation\n        begin: seq * delays + 1000,\n        // Duration of the animation\n        dur: durations,\n        // The value where the animation should start\n        from: 0,\n        // The value where it should end\n        to: 1\n      }\n    });\n  } else if(data.type === 'label' && data.axis === 'x') {\n    data.element.animate({\n      y: {\n        begin: seq * delays,\n        dur: durations,\n        from: data.y + 100,\n        to: data.y,\n        // We can specify an easing function from Chartist.Svg.Easing\n        easing: 'easeOutQuart'\n      }\n    });\n  } else if(data.type === 'label' && data.axis === 'y') {\n    data.element.animate({\n      x: {\n        begin: seq * delays,\n        dur: durations,\n        from: data.x - 100,\n        to: data.x,\n        easing: 'easeOutQuart'\n      }\n    });\n  } else if(data.type === 'point') {\n    data.element.animate({\n      x1: {\n        begin: seq * delays,\n        dur: durations,\n        from: data.x - 10,\n        to: data.x,\n        easing: 'easeOutQuart'\n      },\n      x2: {\n        begin: seq * delays,\n        dur: durations,\n        from: data.x - 10,\n        to: data.x,\n        easing: 'easeOutQuart'\n      },\n      opacity: {\n        begin: seq * delays,\n        dur: durations,\n        from: 0,\n        to: 1,\n        easing: 'easeOutQuart'\n      }\n    });\n  } else if(data.type === 'grid') {\n    // Using data.axis we get x or y which we can use to construct our animation definition objects\n    var pos1Animation = {\n      begin: seq * delays,\n      dur: durations,\n      from: data[data.axis.units.pos + '1'] - 30,\n      to: data[data.axis.units.pos + '1'],\n      easing: 'easeOutQuart'\n    };\n\n    var pos2Animation = {\n      begin: seq * delays,\n      dur: durations,\n      from: data[data.axis.units.pos + '2'] - 100,\n      to: data[data.axis.units.pos + '2'],\n      easing: 'easeOutQuart'\n    };\n\n    var animations = {};\n    animations[data.axis.units.pos + '1'] = pos1Animation;\n    animations[data.axis.units.pos + '2'] = pos2Animation;\n    animations['opacity'] = {\n      begin: seq * delays,\n      dur: durations,\n      from: 0,\n      to: 1,\n      easing: 'easeOutQuart'\n    };\n\n    data.element.animate(animations);\n  }\n});\n\n// For the sake of the example we update the chart every time it's created with a delay of 10 seconds\nchart.on('created', function() {\n  if(window.__exampleAnimateTimeout) {\n    clearTimeout(window.__exampleAnimateTimeout);\n    window.__exampleAnimateTimeout = null;\n  }\n  window.__exampleAnimateTimeout = setTimeout(chart.update.bind(chart), 12000);\n});\n\n// SVG Path animation graph\nvar chart = new Chartist.Line('.ct-svg-chart', {\n  labels: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n  series: [\n    [1, 5, 2, 5, 4, 3],\n    [2, 3, 4, 8, 1, 2],\n    [5, 4, 3, 2, 1, 0.5]\n  ]\n}, {\n  low: 0,\n  showArea: true,\n  showPoint: false,\n  fullWidth: true\n});\n\nchart.on('draw', function(data) {\n  if(data.type === 'line' || data.type === 'area') {\n    data.element.animate({\n      d: {\n        begin: 2000 * data.index,\n        dur: 2000,\n        from: data.path.clone().scale(1, 0).translate(0, data.chartRect.height()).stringify(),\n        to: data.path.clone().stringify(),\n        easing: Chartist.Svg.Easing.easeOutQuint\n      }\n    });\n  }\n});\n\n// Bar chart\n\nvar data = {\n  labels: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n  series: [\n    [5, 4, 3, 7, 5, 10, 3, 4, 8, 10, 6, 8],\n    [3, 2, 9, 5, 4, 6, 4, 6, 7, 8, 7, 4]\n  ]\n};\n\nvar options = {\n  seriesBarDistance: 10\n};\n\nvar responsiveOptions = [\n  ['screen and (max-width: 640px)', {\n    seriesBarDistance: 5,\n\n    axisX: {\n      labelInterpolationFnc: function (value) {\n        return value[0];\n      }\n    }\n  }]\n];\n\nnew Chartist.Bar('.ct-bar-chart', data, options, responsiveOptions);\n\n\n// ct-gauge-chart\n\nnew Chartist.Pie('.ct-gauge-chart', {\n  series: [20, 10, 30, 40]\n}, {\n  donut: true,\n  donutWidth: 60,\n  startAngle: 270,\n  total: 200,\n  low:0,\n  showLabel: false\n});\n\n// Animated Donute chart\nvar chart = new Chartist.Pie('.ct-donute-chart', {\n  series: [10, 20, 50, 20, 5, 50, 15],\n  labels: [1, 2, 3, 4, 5, 6, 7]\n}, {\n  donut: true,\n  showLabel: false\n});\n\nchart.on('draw', function(data) {\n  if(data.type === 'slice') {\n    // Get the total path length in order to use for dash array animation\n    var pathLength = data.element._node.getTotalLength();\n\n    // Set a dasharray that matches the path length as prerequisite to animate dashoffset\n    data.element.attr({\n      'stroke-dasharray': pathLength + 'px ' + pathLength + 'px'\n    });\n\n    // Create animation definition while also assigning an ID to the animation for later sync usage\n    var animationDefinition = {\n      'stroke-dashoffset': {\n        id: 'anim' + data.index,\n        dur: 1000,\n        from: -pathLength + 'px',\n        to:  '0px',\n        easing: Chartist.Svg.Easing.easeOutQuint,\n        // We need to use `fill: 'freeze'` otherwise our animation will fall back to initial (not visible)\n        fill: 'freeze'\n      }\n    };\n\n    // If this was not the first slice, we need to time the animation so that it uses the end sync event of the previous animation\n    if(data.index !== 0) {\n      animationDefinition['stroke-dashoffset'].begin = 'anim' + (data.index - 1) + '.end';\n    }\n\n    // We need to set an initial value before the animation starts as we are not in guided mode which would do that for us\n    data.element.attr({\n      'stroke-dashoffset': -pathLength + 'px'\n    });\n\n    // We can't use guided mode as the animations need to rely on setting begin manually\n    // See http://gionkunz.github.io/chartist-js/api-documentation.html#chartistsvg-function-animate\n    data.element.animate(animationDefinition, false);\n  }\n});\n\n// For the sake of the example we update the chart every time it's created with a delay of 8 seconds\nchart.on('created', function() {\n  if(window.__anim21278907124) {\n    clearTimeout(window.__anim21278907124);\n    window.__anim21278907124 = null;\n  }\n  window.__anim21278907124 = setTimeout(chart.update.bind(chart), 10000);\n});\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/chartist.css",
    "content": ".ct-label {\n  fill: rgba(0, 0, 0, 0.4);\n  color: rgba(0, 0, 0, 0.4);\n  font-size: 0.75rem;\n  line-height: 1; }\n\n.ct-chart-line .ct-label, .ct-chart-bar .ct-label {\n  display: block;\n  display: -webkit-box;\n  display: -moz-box;\n  display: -ms-flexbox;\n  display: -webkit-flex;\n  display: flex; }\n\n.ct-label.ct-horizontal.ct-start {\n  -webkit-box-align: flex-end;\n  -webkit-align-items: flex-end;\n  -ms-flex-align: flex-end;\n  align-items: flex-end;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: start; }\n\n.ct-label.ct-horizontal.ct-end {\n  -webkit-box-align: flex-start;\n  -webkit-align-items: flex-start;\n  -ms-flex-align: flex-start;\n  align-items: flex-start;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: start; }\n\n.ct-label.ct-vertical.ct-start {\n  -webkit-box-align: flex-end;\n  -webkit-align-items: flex-end;\n  -ms-flex-align: flex-end;\n  align-items: flex-end;\n  -webkit-box-pack: flex-end;\n  -webkit-justify-content: flex-end;\n  -ms-flex-pack: flex-end;\n  justify-content: flex-end;\n  text-align: right;\n  text-anchor: end; }\n\n.ct-label.ct-vertical.ct-end {\n  -webkit-box-align: flex-end;\n  -webkit-align-items: flex-end;\n  -ms-flex-align: flex-end;\n  align-items: flex-end;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: start; }\n\n.ct-chart-bar .ct-label.ct-horizontal.ct-start {\n  -webkit-box-align: flex-end;\n  -webkit-align-items: flex-end;\n  -ms-flex-align: flex-end;\n  align-items: flex-end;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n  -ms-flex-pack: center;\n  justify-content: center;\n  text-align: center;\n  text-anchor: start; }\n\n.ct-chart-bar .ct-label.ct-horizontal.ct-end {\n  -webkit-box-align: flex-start;\n  -webkit-align-items: flex-start;\n  -ms-flex-align: flex-start;\n  align-items: flex-start;\n  -webkit-box-pack: center;\n  -webkit-justify-content: center;\n  -ms-flex-pack: center;\n  justify-content: center;\n  text-align: center;\n  text-anchor: start; }\n\n.ct-chart-bar.ct-horizontal-bars .ct-label.ct-horizontal.ct-start {\n  -webkit-box-align: flex-end;\n  -webkit-align-items: flex-end;\n  -ms-flex-align: flex-end;\n  align-items: flex-end;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: start; }\n\n.ct-chart-bar.ct-horizontal-bars .ct-label.ct-horizontal.ct-end {\n  -webkit-box-align: flex-start;\n  -webkit-align-items: flex-start;\n  -ms-flex-align: flex-start;\n  align-items: flex-start;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: start; }\n\n.ct-chart-bar.ct-horizontal-bars .ct-label.ct-vertical.ct-start {\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n  -ms-flex-align: center;\n  align-items: center;\n  -webkit-box-pack: flex-end;\n  -webkit-justify-content: flex-end;\n  -ms-flex-pack: flex-end;\n  justify-content: flex-end;\n  text-align: right;\n  text-anchor: end; }\n\n.ct-chart-bar.ct-horizontal-bars .ct-label.ct-vertical.ct-end {\n  -webkit-box-align: center;\n  -webkit-align-items: center;\n  -ms-flex-align: center;\n  align-items: center;\n  -webkit-box-pack: flex-start;\n  -webkit-justify-content: flex-start;\n  -ms-flex-pack: flex-start;\n  justify-content: flex-start;\n  text-align: left;\n  text-anchor: end; }\n\n.ct-grid {\n  stroke: rgba(0, 0, 0, 0.2);\n  stroke-width: 1px;\n  stroke-dasharray: 2px; }\n\n.ct-point {\n  stroke-width: 10px;\n  stroke-linecap: round; }\n\n.ct-line {\n  fill: none;\n  stroke-width: 4px; }\n\n.ct-area {\n  stroke: none;\n  fill-opacity: 0.1; }\n\n.ct-bar {\n  fill: none;\n  stroke-width: 10px; }\n\n.ct-slice-donut {\n  fill: none;\n  stroke-width: 60px; }\n\n.ct-series-a .ct-point, .ct-series-a .ct-line, .ct-series-a .ct-bar, .ct-series-a .ct-slice-donut {\n  stroke: #d70206; }\n.ct-series-a .ct-slice-pie, .ct-series-a .ct-area {\n  fill: #d70206; }\n\n.ct-series-b .ct-point, .ct-series-b .ct-line, .ct-series-b .ct-bar, .ct-series-b .ct-slice-donut {\n  stroke: #f05b4f; }\n.ct-series-b .ct-slice-pie, .ct-series-b .ct-area {\n  fill: #f05b4f; }\n\n.ct-series-c .ct-point, .ct-series-c .ct-line, .ct-series-c .ct-bar, .ct-series-c .ct-slice-donut {\n  stroke: #f4c63d; }\n.ct-series-c .ct-slice-pie, .ct-series-c .ct-area {\n  fill: #f4c63d; }\n\n.ct-series-d .ct-point, .ct-series-d .ct-line, .ct-series-d .ct-bar, .ct-series-d .ct-slice-donut {\n  stroke: #d17905; }\n.ct-series-d .ct-slice-pie, .ct-series-d .ct-area {\n  fill: #d17905; }\n\n.ct-series-e .ct-point, .ct-series-e .ct-line, .ct-series-e .ct-bar, .ct-series-e .ct-slice-donut {\n  stroke: #453d3f; }\n.ct-series-e .ct-slice-pie, .ct-series-e .ct-area {\n  fill: #453d3f; }\n\n.ct-series-f .ct-point, .ct-series-f .ct-line, .ct-series-f .ct-bar, .ct-series-f .ct-slice-donut {\n  stroke: #59922b; }\n.ct-series-f .ct-slice-pie, .ct-series-f .ct-area {\n  fill: #59922b; }\n\n.ct-series-g .ct-point, .ct-series-g .ct-line, .ct-series-g .ct-bar, .ct-series-g .ct-slice-donut {\n  stroke: #0544d3; }\n.ct-series-g .ct-slice-pie, .ct-series-g .ct-area {\n  fill: #0544d3; }\n\n.ct-series-h .ct-point, .ct-series-h .ct-line, .ct-series-h .ct-bar, .ct-series-h .ct-slice-donut {\n  stroke: #6b0392; }\n.ct-series-h .ct-slice-pie, .ct-series-h .ct-area {\n  fill: #6b0392; }\n\n.ct-series-i .ct-point, .ct-series-i .ct-line, .ct-series-i .ct-bar, .ct-series-i .ct-slice-donut {\n  stroke: #f05b4f; }\n.ct-series-i .ct-slice-pie, .ct-series-i .ct-area {\n  fill: #f05b4f; }\n\n.ct-series-j .ct-point, .ct-series-j .ct-line, .ct-series-j .ct-bar, .ct-series-j .ct-slice-donut {\n  stroke: #dda458; }\n.ct-series-j .ct-slice-pie, .ct-series-j .ct-area {\n  fill: #dda458; }\n\n.ct-series-k .ct-point, .ct-series-k .ct-line, .ct-series-k .ct-bar, .ct-series-k .ct-slice-donut {\n  stroke: #eacf7d; }\n.ct-series-k .ct-slice-pie, .ct-series-k .ct-area {\n  fill: #eacf7d; }\n\n.ct-series-l .ct-point, .ct-series-l .ct-line, .ct-series-l .ct-bar, .ct-series-l .ct-slice-donut {\n  stroke: #86797d; }\n.ct-series-l .ct-slice-pie, .ct-series-l .ct-area {\n  fill: #86797d; }\n\n.ct-series-m .ct-point, .ct-series-m .ct-line, .ct-series-m .ct-bar, .ct-series-m .ct-slice-donut {\n  stroke: #b2c326; }\n.ct-series-m .ct-slice-pie, .ct-series-m .ct-area {\n  fill: #b2c326; }\n\n.ct-series-n .ct-point, .ct-series-n .ct-line, .ct-series-n .ct-bar, .ct-series-n .ct-slice-donut {\n  stroke: #6188e2; }\n.ct-series-n .ct-slice-pie, .ct-series-n .ct-area {\n  fill: #6188e2; }\n\n.ct-series-o .ct-point, .ct-series-o .ct-line, .ct-series-o .ct-bar, .ct-series-o .ct-slice-donut {\n  stroke: #a748ca; }\n.ct-series-o .ct-slice-pie, .ct-series-o .ct-area {\n  fill: #a748ca; }\n\n.ct-square {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-square:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 100%; }\n  .ct-square:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-square > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-minor-second {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-minor-second:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 93.75%; }\n  .ct-minor-second:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-minor-second > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-second {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-second:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 88.8888888889%; }\n  .ct-major-second:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-second > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-minor-third {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-minor-third:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 83.3333333333%; }\n  .ct-minor-third:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-minor-third > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-third {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-third:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 80%; }\n  .ct-major-third:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-third > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-perfect-fourth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-perfect-fourth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 75%; }\n  .ct-perfect-fourth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-perfect-fourth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-perfect-fifth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-perfect-fifth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 66.6666666667%; }\n  .ct-perfect-fifth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-perfect-fifth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-minor-sixth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-minor-sixth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 62.5%; }\n  .ct-minor-sixth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-minor-sixth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-golden-section {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-golden-section:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 61.804697157%; }\n  .ct-golden-section:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-golden-section > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-sixth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-sixth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 60%; }\n  .ct-major-sixth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-sixth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-minor-seventh {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-minor-seventh:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 56.25%; }\n  .ct-minor-seventh:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-minor-seventh > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-seventh {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-seventh:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 53.3333333333%; }\n  .ct-major-seventh:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-seventh > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-octave {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-octave:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 50%; }\n  .ct-octave:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-octave > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-tenth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-tenth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 40%; }\n  .ct-major-tenth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-tenth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-eleventh {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-eleventh:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 37.5%; }\n  .ct-major-eleventh:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-eleventh > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-major-twelfth {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-major-twelfth:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 33.3333333333%; }\n  .ct-major-twelfth:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-major-twelfth > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.ct-double-octave {\n  display: block;\n  position: relative;\n  width: 100%; }\n  .ct-double-octave:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: 25%; }\n  .ct-double-octave:after {\n    content: \"\";\n    display: table;\n    clear: both; }\n  .ct-double-octave > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n/*# sourceMappingURL=chartist.css.map */"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/chartist.js",
    "content": "(function (root, factory) {\n  if (typeof define === 'function' && define.amd) {\n    // AMD. Register as an anonymous module unless amdModuleId is set\n    define([], function () {\n      return (root['Chartist'] = factory());\n    });\n  } else if (typeof exports === 'object') {\n    // Node. Does not work with strict CommonJS, but\n    // only CommonJS-like environments that support module.exports,\n    // like Node.\n    module.exports = factory();\n  } else {\n    root['Chartist'] = factory();\n  }\n}(this, function () {\n\n/* Chartist.js 0.9.7\n * Copyright © 2016 Gion Kunz\n * Free to use under either the WTFPL license or the MIT license.\n * https://raw.githubusercontent.com/gionkunz/chartist-js/master/LICENSE-WTFPL\n * https://raw.githubusercontent.com/gionkunz/chartist-js/master/LICENSE-MIT\n */\n/**\n * The core module of Chartist that is mainly providing static functions and higher level functions for chart modules.\n *\n * @module Chartist.Core\n */\nvar Chartist = {\n  version: '0.9.7'\n};\n\n(function (window, document, Chartist) {\n  'use strict';\n\n  /**\n   * This object contains all namespaces used within Chartist.\n   *\n   * @memberof Chartist.Core\n   * @type {{svg: string, xmlns: string, xhtml: string, xlink: string, ct: string}}\n   */\n  Chartist.namespaces = {\n    svg: 'http://www.w3.org/2000/svg',\n    xmlns: 'http://www.w3.org/2000/xmlns/',\n    xhtml: 'http://www.w3.org/1999/xhtml',\n    xlink: 'http://www.w3.org/1999/xlink',\n    ct: 'http://gionkunz.github.com/chartist-js/ct'\n  };\n\n  /**\n   * Helps to simplify functional style code\n   *\n   * @memberof Chartist.Core\n   * @param {*} n This exact value will be returned by the noop function\n   * @return {*} The same value that was provided to the n parameter\n   */\n  Chartist.noop = function (n) {\n    return n;\n  };\n\n  /**\n   * Generates a-z from a number 0 to 26\n   *\n   * @memberof Chartist.Core\n   * @param {Number} n A number from 0 to 26 that will result in a letter a-z\n   * @return {String} A character from a-z based on the input number n\n   */\n  Chartist.alphaNumerate = function (n) {\n    // Limit to a-z\n    return String.fromCharCode(97 + n % 26);\n  };\n\n  /**\n   * Simple recursive object extend\n   *\n   * @memberof Chartist.Core\n   * @param {Object} target Target object where the source will be merged into\n   * @param {Object...} sources This object (objects) will be merged into target and then target is returned\n   * @return {Object} An object that has the same reference as target but is extended and merged with the properties of source\n   */\n  Chartist.extend = function (target) {\n    target = target || {};\n\n    var sources = Array.prototype.slice.call(arguments, 1);\n    sources.forEach(function(source) {\n      for (var prop in source) {\n        if (typeof source[prop] === 'object' && source[prop] !== null && !(source[prop] instanceof Array)) {\n          target[prop] = Chartist.extend({}, target[prop], source[prop]);\n        } else {\n          target[prop] = source[prop];\n        }\n      }\n    });\n\n    return target;\n  };\n\n  /**\n   * Replaces all occurrences of subStr in str with newSubStr and returns a new string.\n   *\n   * @memberof Chartist.Core\n   * @param {String} str\n   * @param {String} subStr\n   * @param {String} newSubStr\n   * @return {String}\n   */\n  Chartist.replaceAll = function(str, subStr, newSubStr) {\n    return str.replace(new RegExp(subStr, 'g'), newSubStr);\n  };\n\n  /**\n   * Converts a number to a string with a unit. If a string is passed then this will be returned unmodified.\n   *\n   * @memberof Chartist.Core\n   * @param {Number} value\n   * @param {String} unit\n   * @return {String} Returns the passed number value with unit.\n   */\n  Chartist.ensureUnit = function(value, unit) {\n    if(typeof value === 'number') {\n      value = value + unit;\n    }\n\n    return value;\n  };\n\n  /**\n   * Converts a number or string to a quantity object.\n   *\n   * @memberof Chartist.Core\n   * @param {String|Number} input\n   * @return {Object} Returns an object containing the value as number and the unit as string.\n   */\n  Chartist.quantity = function(input) {\n    if (typeof input === 'string') {\n      var match = (/^(\\d+)\\s*(.*)$/g).exec(input);\n      return {\n        value : +match[1],\n        unit: match[2] || undefined\n      };\n    }\n    return { value: input };\n  };\n\n  /**\n   * This is a wrapper around document.querySelector that will return the query if it's already of type Node\n   *\n   * @memberof Chartist.Core\n   * @param {String|Node} query The query to use for selecting a Node or a DOM node that will be returned directly\n   * @return {Node}\n   */\n  Chartist.querySelector = function(query) {\n    return query instanceof Node ? query : document.querySelector(query);\n  };\n\n  /**\n   * Functional style helper to produce array with given length initialized with undefined values\n   *\n   * @memberof Chartist.Core\n   * @param length\n   * @return {Array}\n   */\n  Chartist.times = function(length) {\n    return Array.apply(null, new Array(length));\n  };\n\n  /**\n   * Sum helper to be used in reduce functions\n   *\n   * @memberof Chartist.Core\n   * @param previous\n   * @param current\n   * @return {*}\n   */\n  Chartist.sum = function(previous, current) {\n    return previous + (current ? current : 0);\n  };\n\n  /**\n   * Multiply helper to be used in `Array.map` for multiplying each value of an array with a factor.\n   *\n   * @memberof Chartist.Core\n   * @param {Number} factor\n   * @returns {Function} Function that can be used in `Array.map` to multiply each value in an array\n   */\n  Chartist.mapMultiply = function(factor) {\n    return function(num) {\n      return num * factor;\n    };\n  };\n\n  /**\n   * Add helper to be used in `Array.map` for adding a addend to each value of an array.\n   *\n   * @memberof Chartist.Core\n   * @param {Number} addend\n   * @returns {Function} Function that can be used in `Array.map` to add a addend to each value in an array\n   */\n  Chartist.mapAdd = function(addend) {\n    return function(num) {\n      return num + addend;\n    };\n  };\n\n  /**\n   * Map for multi dimensional arrays where their nested arrays will be mapped in serial. The output array will have the length of the largest nested array. The callback function is called with variable arguments where each argument is the nested array value (or undefined if there are no more values).\n   *\n   * @memberof Chartist.Core\n   * @param arr\n   * @param cb\n   * @return {Array}\n   */\n  Chartist.serialMap = function(arr, cb) {\n    var result = [],\n        length = Math.max.apply(null, arr.map(function(e) {\n          return e.length;\n        }));\n\n    Chartist.times(length).forEach(function(e, index) {\n      var args = arr.map(function(e) {\n        return e[index];\n      });\n\n      result[index] = cb.apply(null, args);\n    });\n\n    return result;\n  };\n\n  /**\n   * This helper function can be used to round values with certain precision level after decimal. This is used to prevent rounding errors near float point precision limit.\n   *\n   * @memberof Chartist.Core\n   * @param {Number} value The value that should be rounded with precision\n   * @param {Number} [digits] The number of digits after decimal used to do the rounding\n   * @returns {number} Rounded value\n   */\n  Chartist.roundWithPrecision = function(value, digits) {\n    var precision = Math.pow(10, digits || Chartist.precision);\n    return Math.round(value * precision) / precision;\n  };\n\n  /**\n   * Precision level used internally in Chartist for rounding. If you require more decimal places you can increase this number.\n   *\n   * @memberof Chartist.Core\n   * @type {number}\n   */\n  Chartist.precision = 8;\n\n  /**\n   * A map with characters to escape for strings to be safely used as attribute values.\n   *\n   * @memberof Chartist.Core\n   * @type {Object}\n   */\n  Chartist.escapingMap = {\n    '&': '&amp;',\n    '<': '&lt;',\n    '>': '&gt;',\n    '\"': '&quot;',\n    '\\'': '&#039;'\n  };\n\n  /**\n   * This function serializes arbitrary data to a string. In case of data that can't be easily converted to a string, this function will create a wrapper object and serialize the data using JSON.stringify. The outcoming string will always be escaped using Chartist.escapingMap.\n   * If called with null or undefined the function will return immediately with null or undefined.\n   *\n   * @memberof Chartist.Core\n   * @param {Number|String|Object} data\n   * @return {String}\n   */\n  Chartist.serialize = function(data) {\n    if(data === null || data === undefined) {\n      return data;\n    } else if(typeof data === 'number') {\n      data = ''+data;\n    } else if(typeof data === 'object') {\n      data = JSON.stringify({data: data});\n    }\n\n    return Object.keys(Chartist.escapingMap).reduce(function(result, key) {\n      return Chartist.replaceAll(result, key, Chartist.escapingMap[key]);\n    }, data);\n  };\n\n  /**\n   * This function de-serializes a string previously serialized with Chartist.serialize. The string will always be unescaped using Chartist.escapingMap before it's returned. Based on the input value the return type can be Number, String or Object. JSON.parse is used with try / catch to see if the unescaped string can be parsed into an Object and this Object will be returned on success.\n   *\n   * @memberof Chartist.Core\n   * @param {String} data\n   * @return {String|Number|Object}\n   */\n  Chartist.deserialize = function(data) {\n    if(typeof data !== 'string') {\n      return data;\n    }\n\n    data = Object.keys(Chartist.escapingMap).reduce(function(result, key) {\n      return Chartist.replaceAll(result, Chartist.escapingMap[key], key);\n    }, data);\n\n    try {\n      data = JSON.parse(data);\n      data = data.data !== undefined ? data.data : data;\n    } catch(e) {}\n\n    return data;\n  };\n\n  /**\n   * Create or reinitialize the SVG element for the chart\n   *\n   * @memberof Chartist.Core\n   * @param {Node} container The containing DOM Node object that will be used to plant the SVG element\n   * @param {String} width Set the width of the SVG element. Default is 100%\n   * @param {String} height Set the height of the SVG element. Default is 100%\n   * @param {String} className Specify a class to be added to the SVG element\n   * @return {Object} The created/reinitialized SVG element\n   */\n  Chartist.createSvg = function (container, width, height, className) {\n    var svg;\n\n    width = width || '100%';\n    height = height || '100%';\n\n    // Check if there is a previous SVG element in the container that contains the Chartist XML namespace and remove it\n    // Since the DOM API does not support namespaces we need to manually search the returned list http://www.w3.org/TR/selectors-api/\n    Array.prototype.slice.call(container.querySelectorAll('svg')).filter(function filterChartistSvgObjects(svg) {\n      return svg.getAttributeNS(Chartist.namespaces.xmlns, 'ct');\n    }).forEach(function removePreviousElement(svg) {\n      container.removeChild(svg);\n    });\n\n    // Create svg object with width and height or use 100% as default\n    svg = new Chartist.Svg('svg').attr({\n      width: width,\n      height: height\n    }).addClass(className).attr({\n      style: 'width: ' + width + '; height: ' + height + ';'\n    });\n\n    // Add the DOM node to our container\n    container.appendChild(svg._node);\n\n    return svg;\n  };\n\n  /**\n   * Ensures that the data object passed as second argument to the charts is present and correctly initialized.\n   *\n   * @param  {Object} data The data object that is passed as second argument to the charts\n   * @return {Object} The normalized data object\n   */\n  Chartist.normalizeData = function(data) {\n    // Ensure data is present otherwise enforce\n    data = data || {series: [], labels: []};\n    data.series = data.series || [];\n    data.labels = data.labels || [];\n\n    // Check if we should generate some labels based on existing series data\n    if (data.series.length > 0 && data.labels.length === 0) {\n      var normalized = Chartist.getDataArray(data),\n          labelCount;\n\n      // If all elements of the normalized data array are arrays we're dealing with\n      // data from Bar or Line charts and we need to find the largest series if they are un-even\n      if (normalized.every(function(value) {\n        return value instanceof Array;\n      })) {\n        // Getting the series with the the most elements\n        labelCount = Math.max.apply(null, normalized.map(function(series) {\n          return series.length;\n        }));\n      } else {\n        // We're dealing with Pie data so we just take the normalized array length\n        labelCount = normalized.length;\n      }\n\n      // Setting labels to an array with emptry strings using our labelCount estimated above\n      data.labels = Chartist.times(labelCount).map(function() {\n        return '';\n      });\n    }\n    return data;\n  };\n\n  /**\n   * Reverses the series, labels and series data arrays.\n   *\n   * @memberof Chartist.Core\n   * @param data\n   */\n  Chartist.reverseData = function(data) {\n    data.labels.reverse();\n    data.series.reverse();\n    for (var i = 0; i < data.series.length; i++) {\n      if(typeof(data.series[i]) === 'object' && data.series[i].data !== undefined) {\n        data.series[i].data.reverse();\n      } else if(data.series[i] instanceof Array) {\n        data.series[i].reverse();\n      }\n    }\n  };\n\n  /**\n   * Convert data series into plain array\n   *\n   * @memberof Chartist.Core\n   * @param {Object} data The series object that contains the data to be visualized in the chart\n   * @param {Boolean} reverse If true the whole data is reversed by the getDataArray call. This will modify the data object passed as first parameter. The labels as well as the series order is reversed. The whole series data arrays are reversed too.\n   * @param {Boolean} multi Create a multi dimensional array from a series data array where a value object with `x` and `y` values will be created.\n   * @return {Array} A plain array that contains the data to be visualized in the chart\n   */\n  Chartist.getDataArray = function (data, reverse, multi) {\n    // If the data should be reversed but isn't we need to reverse it\n    // If it's reversed but it shouldn't we need to reverse it back\n    // That's required to handle data updates correctly and to reflect the responsive configurations\n    if(reverse && !data.reversed || !reverse && data.reversed) {\n      Chartist.reverseData(data);\n      data.reversed = !data.reversed;\n    }\n\n    // Recursively walks through nested arrays and convert string values to numbers and objects with value properties\n    // to values. Check the tests in data core -> data normalization for a detailed specification of expected values\n    function recursiveConvert(value) {\n      if(Chartist.isFalseyButZero(value)) {\n        // This is a hole in data and we should return undefined\n        return undefined;\n      } else if((value.data || value) instanceof Array) {\n        return (value.data || value).map(recursiveConvert);\n      } else if(value.hasOwnProperty('value')) {\n        return recursiveConvert(value.value);\n      } else {\n        if(multi) {\n          var multiValue = {};\n\n          // Single series value arrays are assumed to specify the Y-Axis value\n          // For example: [1, 2] => [{x: undefined, y: 1}, {x: undefined, y: 2}]\n          // If multi is a string then it's assumed that it specified which dimension should be filled as default\n          if(typeof multi === 'string') {\n            multiValue[multi] = Chartist.getNumberOrUndefined(value);\n          } else {\n            multiValue.y = Chartist.getNumberOrUndefined(value);\n          }\n\n          multiValue.x = value.hasOwnProperty('x') ? Chartist.getNumberOrUndefined(value.x) : multiValue.x;\n          multiValue.y = value.hasOwnProperty('y') ? Chartist.getNumberOrUndefined(value.y) : multiValue.y;\n\n          return multiValue;\n\n        } else {\n          return Chartist.getNumberOrUndefined(value);\n        }\n      }\n    }\n\n    return data.series.map(recursiveConvert);\n  };\n\n  /**\n   * Converts a number into a padding object.\n   *\n   * @memberof Chartist.Core\n   * @param {Object|Number} padding\n   * @param {Number} [fallback] This value is used to fill missing values if a incomplete padding object was passed\n   * @returns {Object} Returns a padding object containing top, right, bottom, left properties filled with the padding number passed in as argument. If the argument is something else than a number (presumably already a correct padding object) then this argument is directly returned.\n   */\n  Chartist.normalizePadding = function(padding, fallback) {\n    fallback = fallback || 0;\n\n    return typeof padding === 'number' ? {\n      top: padding,\n      right: padding,\n      bottom: padding,\n      left: padding\n    } : {\n      top: typeof padding.top === 'number' ? padding.top : fallback,\n      right: typeof padding.right === 'number' ? padding.right : fallback,\n      bottom: typeof padding.bottom === 'number' ? padding.bottom : fallback,\n      left: typeof padding.left === 'number' ? padding.left : fallback\n    };\n  };\n\n  Chartist.getMetaData = function(series, index) {\n    var value = series.data ? series.data[index] : series[index];\n    return value ? Chartist.serialize(value.meta) : undefined;\n  };\n\n  /**\n   * Calculate the order of magnitude for the chart scale\n   *\n   * @memberof Chartist.Core\n   * @param {Number} value The value Range of the chart\n   * @return {Number} The order of magnitude\n   */\n  Chartist.orderOfMagnitude = function (value) {\n    return Math.floor(Math.log(Math.abs(value)) / Math.LN10);\n  };\n\n  /**\n   * Project a data length into screen coordinates (pixels)\n   *\n   * @memberof Chartist.Core\n   * @param {Object} axisLength The svg element for the chart\n   * @param {Number} length Single data value from a series array\n   * @param {Object} bounds All the values to set the bounds of the chart\n   * @return {Number} The projected data length in pixels\n   */\n  Chartist.projectLength = function (axisLength, length, bounds) {\n    return length / bounds.range * axisLength;\n  };\n\n  /**\n   * Get the height of the area in the chart for the data series\n   *\n   * @memberof Chartist.Core\n   * @param {Object} svg The svg element for the chart\n   * @param {Object} options The Object that contains all the optional values for the chart\n   * @return {Number} The height of the area in the chart for the data series\n   */\n  Chartist.getAvailableHeight = function (svg, options) {\n    return Math.max((Chartist.quantity(options.height).value || svg.height()) - (options.chartPadding.top +  options.chartPadding.bottom) - options.axisX.offset, 0);\n  };\n\n  /**\n   * Get highest and lowest value of data array. This Array contains the data that will be visualized in the chart.\n   *\n   * @memberof Chartist.Core\n   * @param {Array} data The array that contains the data to be visualized in the chart\n   * @param {Object} options The Object that contains the chart options\n   * @param {String} dimension Axis dimension 'x' or 'y' used to access the correct value and high / low configuration\n   * @return {Object} An object that contains the highest and lowest value that will be visualized on the chart.\n   */\n  Chartist.getHighLow = function (data, options, dimension) {\n    // TODO: Remove workaround for deprecated global high / low config. Axis high / low configuration is preferred\n    options = Chartist.extend({}, options, dimension ? options['axis' + dimension.toUpperCase()] : {});\n\n    var highLow = {\n        high: options.high === undefined ? -Number.MAX_VALUE : +options.high,\n        low: options.low === undefined ? Number.MAX_VALUE : +options.low\n      };\n    var findHigh = options.high === undefined;\n    var findLow = options.low === undefined;\n\n    // Function to recursively walk through arrays and find highest and lowest number\n    function recursiveHighLow(data) {\n      if(data === undefined) {\n        return undefined;\n      } else if(data instanceof Array) {\n        for (var i = 0; i < data.length; i++) {\n          recursiveHighLow(data[i]);\n        }\n      } else {\n        var value = dimension ? +data[dimension] : +data;\n\n        if (findHigh && value > highLow.high) {\n          highLow.high = value;\n        }\n\n        if (findLow && value < highLow.low) {\n          highLow.low = value;\n        }\n      }\n    }\n\n    // Start to find highest and lowest number recursively\n    if(findHigh || findLow) {\n      recursiveHighLow(data);\n    }\n\n    // Overrides of high / low based on reference value, it will make sure that the invisible reference value is\n    // used to generate the chart. This is useful when the chart always needs to contain the position of the\n    // invisible reference value in the view i.e. for bipolar scales.\n    if (options.referenceValue || options.referenceValue === 0) {\n      highLow.high = Math.max(options.referenceValue, highLow.high);\n      highLow.low = Math.min(options.referenceValue, highLow.low);\n    }\n\n    // If high and low are the same because of misconfiguration or flat data (only the same value) we need\n    // to set the high or low to 0 depending on the polarity\n    if (highLow.high <= highLow.low) {\n      // If both values are 0 we set high to 1\n      if (highLow.low === 0) {\n        highLow.high = 1;\n      } else if (highLow.low < 0) {\n        // If we have the same negative value for the bounds we set bounds.high to 0\n        highLow.high = 0;\n      } else if (highLow.high > 0) {\n        // If we have the same positive value for the bounds we set bounds.low to 0\n        highLow.low = 0;\n      } else {\n        // If data array was empty, values are Number.MAX_VALUE and -Number.MAX_VALUE. Set bounds to prevent errors\n        highLow.high = 1;\n        highLow.low = 0;\n      }\n    }\n\n    return highLow;\n  };\n\n  /**\n   * Checks if the value is a valid number or string with a number.\n   *\n   * @memberof Chartist.Core\n   * @param value\n   * @returns {Boolean}\n   */\n  Chartist.isNum = function(value) {\n    return !isNaN(value) && isFinite(value);\n  };\n\n  /**\n   * Returns true on all falsey values except the numeric value 0.\n   *\n   * @memberof Chartist.Core\n   * @param value\n   * @returns {boolean}\n   */\n  Chartist.isFalseyButZero = function(value) {\n    return !value && value !== 0;\n  };\n\n  /**\n   * Returns a number if the passed parameter is a valid number or the function will return undefined. On all other values than a valid number, this function will return undefined.\n   *\n   * @memberof Chartist.Core\n   * @param value\n   * @returns {*}\n   */\n  Chartist.getNumberOrUndefined = function(value) {\n    return isNaN(+value) ? undefined : +value;\n  };\n\n  /**\n   * Gets a value from a dimension `value.x` or `value.y` while returning value directly if it's a valid numeric value. If the value is not numeric and it's falsey this function will return undefined.\n   *\n   * @param value\n   * @param dimension\n   * @returns {*}\n   */\n  Chartist.getMultiValue = function(value, dimension) {\n    if(Chartist.isNum(value)) {\n      return +value;\n    } else if(value) {\n      return value[dimension || 'y'] || 0;\n    } else {\n      return 0;\n    }\n  };\n\n  /**\n   * Pollard Rho Algorithm to find smallest factor of an integer value. There are more efficient algorithms for factorization, but this one is quite efficient and not so complex.\n   *\n   * @memberof Chartist.Core\n   * @param {Number} num An integer number where the smallest factor should be searched for\n   * @returns {Number} The smallest integer factor of the parameter num.\n   */\n  Chartist.rho = function(num) {\n    if(num === 1) {\n      return num;\n    }\n\n    function gcd(p, q) {\n      if (p % q === 0) {\n        return q;\n      } else {\n        return gcd(q, p % q);\n      }\n    }\n\n    function f(x) {\n      return x * x + 1;\n    }\n\n    var x1 = 2, x2 = 2, divisor;\n    if (num % 2 === 0) {\n      return 2;\n    }\n\n    do {\n      x1 = f(x1) % num;\n      x2 = f(f(x2)) % num;\n      divisor = gcd(Math.abs(x1 - x2), num);\n    } while (divisor === 1);\n\n    return divisor;\n  };\n\n  /**\n   * Calculate and retrieve all the bounds for the chart and return them in one array\n   *\n   * @memberof Chartist.Core\n   * @param {Number} axisLength The length of the Axis used for\n   * @param {Object} highLow An object containing a high and low property indicating the value range of the chart.\n   * @param {Number} scaleMinSpace The minimum projected length a step should result in\n   * @param {Boolean} onlyInteger\n   * @return {Object} All the values to set the bounds of the chart\n   */\n  Chartist.getBounds = function (axisLength, highLow, scaleMinSpace, onlyInteger) {\n    var i,\n      optimizationCounter = 0,\n      newMin,\n      newMax,\n      bounds = {\n        high: highLow.high,\n        low: highLow.low\n      };\n\n    bounds.valueRange = bounds.high - bounds.low;\n    bounds.oom = Chartist.orderOfMagnitude(bounds.valueRange);\n    bounds.step = Math.pow(10, bounds.oom);\n    bounds.min = Math.floor(bounds.low / bounds.step) * bounds.step;\n    bounds.max = Math.ceil(bounds.high / bounds.step) * bounds.step;\n    bounds.range = bounds.max - bounds.min;\n    bounds.numberOfSteps = Math.round(bounds.range / bounds.step);\n\n    // Optimize scale step by checking if subdivision is possible based on horizontalGridMinSpace\n    // If we are already below the scaleMinSpace value we will scale up\n    var length = Chartist.projectLength(axisLength, bounds.step, bounds);\n    var scaleUp = length < scaleMinSpace;\n    var smallestFactor = onlyInteger ? Chartist.rho(bounds.range) : 0;\n\n    // First check if we should only use integer steps and if step 1 is still larger than scaleMinSpace so we can use 1\n    if(onlyInteger && Chartist.projectLength(axisLength, 1, bounds) >= scaleMinSpace) {\n      bounds.step = 1;\n    } else if(onlyInteger && smallestFactor < bounds.step && Chartist.projectLength(axisLength, smallestFactor, bounds) >= scaleMinSpace) {\n      // If step 1 was too small, we can try the smallest factor of range\n      // If the smallest factor is smaller than the current bounds.step and the projected length of smallest factor\n      // is larger than the scaleMinSpace we should go for it.\n      bounds.step = smallestFactor;\n    } else {\n      // Trying to divide or multiply by 2 and find the best step value\n      while (true) {\n        if (scaleUp && Chartist.projectLength(axisLength, bounds.step, bounds) <= scaleMinSpace) {\n          bounds.step *= 2;\n        } else if (!scaleUp && Chartist.projectLength(axisLength, bounds.step / 2, bounds) >= scaleMinSpace) {\n          bounds.step /= 2;\n          if(onlyInteger && bounds.step % 1 !== 0) {\n            bounds.step *= 2;\n            break;\n          }\n        } else {\n          break;\n        }\n\n        if(optimizationCounter++ > 1000) {\n          throw new Error('Exceeded maximum number of iterations while optimizing scale step!');\n        }\n      }\n    }\n\n    // Narrow min and max based on new step\n    newMin = bounds.min;\n    newMax = bounds.max;\n    while(newMin + bounds.step <= bounds.low) {\n      newMin += bounds.step;\n    }\n    while(newMax - bounds.step >= bounds.high) {\n      newMax -= bounds.step;\n    }\n    bounds.min = newMin;\n    bounds.max = newMax;\n    bounds.range = bounds.max - bounds.min;\n\n    bounds.values = [];\n    for (i = bounds.min; i <= bounds.max; i += bounds.step) {\n      bounds.values.push(Chartist.roundWithPrecision(i));\n    }\n\n    return bounds;\n  };\n\n  /**\n   * Calculate cartesian coordinates of polar coordinates\n   *\n   * @memberof Chartist.Core\n   * @param {Number} centerX X-axis coordinates of center point of circle segment\n   * @param {Number} centerY X-axis coordinates of center point of circle segment\n   * @param {Number} radius Radius of circle segment\n   * @param {Number} angleInDegrees Angle of circle segment in degrees\n   * @return {{x:Number, y:Number}} Coordinates of point on circumference\n   */\n  Chartist.polarToCartesian = function (centerX, centerY, radius, angleInDegrees) {\n    var angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0;\n\n    return {\n      x: centerX + (radius * Math.cos(angleInRadians)),\n      y: centerY + (radius * Math.sin(angleInRadians))\n    };\n  };\n\n  /**\n   * Initialize chart drawing rectangle (area where chart is drawn) x1,y1 = bottom left / x2,y2 = top right\n   *\n   * @memberof Chartist.Core\n   * @param {Object} svg The svg element for the chart\n   * @param {Object} options The Object that contains all the optional values for the chart\n   * @param {Number} [fallbackPadding] The fallback padding if partial padding objects are used\n   * @return {Object} The chart rectangles coordinates inside the svg element plus the rectangles measurements\n   */\n  Chartist.createChartRect = function (svg, options, fallbackPadding) {\n    var hasAxis = !!(options.axisX || options.axisY);\n    var yAxisOffset = hasAxis ? options.axisY.offset : 0;\n    var xAxisOffset = hasAxis ? options.axisX.offset : 0;\n    // If width or height results in invalid value (including 0) we fallback to the unitless settings or even 0\n    var width = svg.width() || Chartist.quantity(options.width).value || 0;\n    var height = svg.height() || Chartist.quantity(options.height).value || 0;\n    var normalizedPadding = Chartist.normalizePadding(options.chartPadding, fallbackPadding);\n\n    // If settings were to small to cope with offset (legacy) and padding, we'll adjust\n    width = Math.max(width, yAxisOffset + normalizedPadding.left + normalizedPadding.right);\n    height = Math.max(height, xAxisOffset + normalizedPadding.top + normalizedPadding.bottom);\n\n    var chartRect = {\n      padding: normalizedPadding,\n      width: function () {\n        return this.x2 - this.x1;\n      },\n      height: function () {\n        return this.y1 - this.y2;\n      }\n    };\n\n    if(hasAxis) {\n      if (options.axisX.position === 'start') {\n        chartRect.y2 = normalizedPadding.top + xAxisOffset;\n        chartRect.y1 = Math.max(height - normalizedPadding.bottom, chartRect.y2 + 1);\n      } else {\n        chartRect.y2 = normalizedPadding.top;\n        chartRect.y1 = Math.max(height - normalizedPadding.bottom - xAxisOffset, chartRect.y2 + 1);\n      }\n\n      if (options.axisY.position === 'start') {\n        chartRect.x1 = normalizedPadding.left + yAxisOffset;\n        chartRect.x2 = Math.max(width - normalizedPadding.right, chartRect.x1 + 1);\n      } else {\n        chartRect.x1 = normalizedPadding.left;\n        chartRect.x2 = Math.max(width - normalizedPadding.right - yAxisOffset, chartRect.x1 + 1);\n      }\n    } else {\n      chartRect.x1 = normalizedPadding.left;\n      chartRect.x2 = Math.max(width - normalizedPadding.right, chartRect.x1 + 1);\n      chartRect.y2 = normalizedPadding.top;\n      chartRect.y1 = Math.max(height - normalizedPadding.bottom, chartRect.y2 + 1);\n    }\n\n    return chartRect;\n  };\n\n  /**\n   * Creates a grid line based on a projected value.\n   *\n   * @memberof Chartist.Core\n   * @param position\n   * @param index\n   * @param axis\n   * @param offset\n   * @param length\n   * @param group\n   * @param classes\n   * @param eventEmitter\n   */\n  Chartist.createGrid = function(position, index, axis, offset, length, group, classes, eventEmitter) {\n    var positionalData = {};\n    positionalData[axis.units.pos + '1'] = position;\n    positionalData[axis.units.pos + '2'] = position;\n    positionalData[axis.counterUnits.pos + '1'] = offset;\n    positionalData[axis.counterUnits.pos + '2'] = offset + length;\n\n    var gridElement = group.elem('line', positionalData, classes.join(' '));\n\n    // Event for grid draw\n    eventEmitter.emit('draw',\n      Chartist.extend({\n        type: 'grid',\n        axis: axis,\n        index: index,\n        group: group,\n        element: gridElement\n      }, positionalData)\n    );\n  };\n\n  /**\n   * Creates a label based on a projected value and an axis.\n   *\n   * @memberof Chartist.Core\n   * @param position\n   * @param length\n   * @param index\n   * @param labels\n   * @param axis\n   * @param axisOffset\n   * @param labelOffset\n   * @param group\n   * @param classes\n   * @param useForeignObject\n   * @param eventEmitter\n   */\n  Chartist.createLabel = function(position, length, index, labels, axis, axisOffset, labelOffset, group, classes, useForeignObject, eventEmitter) {\n    var labelElement;\n    var positionalData = {};\n\n    positionalData[axis.units.pos] = position + labelOffset[axis.units.pos];\n    positionalData[axis.counterUnits.pos] = labelOffset[axis.counterUnits.pos];\n    positionalData[axis.units.len] = length;\n    positionalData[axis.counterUnits.len] = axisOffset - 10;\n\n    if(useForeignObject) {\n      // We need to set width and height explicitly to px as span will not expand with width and height being\n      // 100% in all browsers\n      var content = '<span class=\"' + classes.join(' ') + '\" style=\"' +\n        axis.units.len + ': ' + Math.round(positionalData[axis.units.len]) + 'px; ' +\n        axis.counterUnits.len + ': ' + Math.round(positionalData[axis.counterUnits.len]) + 'px\">' +\n        labels[index] + '</span>';\n\n      labelElement = group.foreignObject(content, Chartist.extend({\n        style: 'overflow: visible;'\n      }, positionalData));\n    } else {\n      labelElement = group.elem('text', positionalData, classes.join(' ')).text(labels[index]);\n    }\n\n    eventEmitter.emit('draw', Chartist.extend({\n      type: 'label',\n      axis: axis,\n      index: index,\n      group: group,\n      element: labelElement,\n      text: labels[index]\n    }, positionalData));\n  };\n\n  /**\n   * Helper to read series specific options from options object. It automatically falls back to the global option if\n   * there is no option in the series options.\n   *\n   * @param {Object} series Series object\n   * @param {Object} options Chartist options object\n   * @param {string} key The options key that should be used to obtain the options\n   * @returns {*}\n   */\n  Chartist.getSeriesOption = function(series, options, key) {\n    if(series.name && options.series && options.series[series.name]) {\n      var seriesOptions = options.series[series.name];\n      return seriesOptions.hasOwnProperty(key) ? seriesOptions[key] : options[key];\n    } else {\n      return options[key];\n    }\n  };\n\n  /**\n   * Provides options handling functionality with callback for options changes triggered by responsive options and media query matches\n   *\n   * @memberof Chartist.Core\n   * @param {Object} options Options set by user\n   * @param {Array} responsiveOptions Optional functions to add responsive behavior to chart\n   * @param {Object} eventEmitter The event emitter that will be used to emit the options changed events\n   * @return {Object} The consolidated options object from the defaults, base and matching responsive options\n   */\n  Chartist.optionsProvider = function (options, responsiveOptions, eventEmitter) {\n    var baseOptions = Chartist.extend({}, options),\n      currentOptions,\n      mediaQueryListeners = [],\n      i;\n\n    function updateCurrentOptions(preventChangedEvent) {\n      var previousOptions = currentOptions;\n      currentOptions = Chartist.extend({}, baseOptions);\n\n      if (responsiveOptions) {\n        for (i = 0; i < responsiveOptions.length; i++) {\n          var mql = window.matchMedia(responsiveOptions[i][0]);\n          if (mql.matches) {\n            currentOptions = Chartist.extend(currentOptions, responsiveOptions[i][1]);\n          }\n        }\n      }\n\n      if(eventEmitter && !preventChangedEvent) {\n        eventEmitter.emit('optionsChanged', {\n          previousOptions: previousOptions,\n          currentOptions: currentOptions\n        });\n      }\n    }\n\n    function removeMediaQueryListeners() {\n      mediaQueryListeners.forEach(function(mql) {\n        mql.removeListener(updateCurrentOptions);\n      });\n    }\n\n    if (!window.matchMedia) {\n      throw 'window.matchMedia not found! Make sure you\\'re using a polyfill.';\n    } else if (responsiveOptions) {\n\n      for (i = 0; i < responsiveOptions.length; i++) {\n        var mql = window.matchMedia(responsiveOptions[i][0]);\n        mql.addListener(updateCurrentOptions);\n        mediaQueryListeners.push(mql);\n      }\n    }\n    // Execute initially so we get the correct options\n    updateCurrentOptions(true);\n\n    return {\n      removeMediaQueryListeners: removeMediaQueryListeners,\n      getCurrentOptions: function getCurrentOptions() {\n        return Chartist.extend({}, currentOptions);\n      }\n    };\n  };\n\n}(window, document, Chartist));\n;/**\n * Chartist path interpolation functions.\n *\n * @module Chartist.Interpolation\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  Chartist.Interpolation = {};\n\n  /**\n   * This interpolation function does not smooth the path and the result is only containing lines and no curves.\n   *\n   * @example\n   * var chart = new Chartist.Line('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5],\n   *   series: [[1, 2, 8, 1, 7]]\n   * }, {\n   *   lineSmooth: Chartist.Interpolation.none({\n   *     fillHoles: false\n   *   })\n   * });\n   *\n   *\n   * @memberof Chartist.Interpolation\n   * @return {Function}\n   */\n  Chartist.Interpolation.none = function(options) {\n    var defaultOptions = {\n      fillHoles: false\n    };\n    options = Chartist.extend({}, defaultOptions, options);\n    return function none(pathCoordinates, valueData) {\n      var path = new Chartist.Svg.Path();\n      var hole = true;\n\n      for(var i = 0; i < pathCoordinates.length; i += 2) {\n        var currX = pathCoordinates[i];\n        var currY = pathCoordinates[i + 1];\n        var currData = valueData[i / 2];\n\n        if(currData.value !== undefined) {\n\n          if(hole) {\n            path.move(currX, currY, false, currData);\n          } else {\n            path.line(currX, currY, false, currData);\n          }\n\n          hole = false;\n        } else if(!options.fillHoles) {\n          hole = true;\n        }\n      }\n\n      return path;\n    };\n  };\n\n  /**\n   * Simple smoothing creates horizontal handles that are positioned with a fraction of the length between two data points. You can use the divisor option to specify the amount of smoothing.\n   *\n   * Simple smoothing can be used instead of `Chartist.Smoothing.cardinal` if you'd like to get rid of the artifacts it produces sometimes. Simple smoothing produces less flowing lines but is accurate by hitting the points and it also doesn't swing below or above the given data point.\n   *\n   * All smoothing functions within Chartist are factory functions that accept an options parameter. The simple interpolation function accepts one configuration parameter `divisor`, between 1 and ∞, which controls the smoothing characteristics.\n   *\n   * @example\n   * var chart = new Chartist.Line('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5],\n   *   series: [[1, 2, 8, 1, 7]]\n   * }, {\n   *   lineSmooth: Chartist.Interpolation.simple({\n   *     divisor: 2,\n   *     fillHoles: false\n   *   })\n   * });\n   *\n   *\n   * @memberof Chartist.Interpolation\n   * @param {Object} options The options of the simple interpolation factory function.\n   * @return {Function}\n   */\n  Chartist.Interpolation.simple = function(options) {\n    var defaultOptions = {\n      divisor: 2,\n      fillHoles: false\n    };\n    options = Chartist.extend({}, defaultOptions, options);\n\n    var d = 1 / Math.max(1, options.divisor);\n\n    return function simple(pathCoordinates, valueData) {\n      var path = new Chartist.Svg.Path();\n      var prevX, prevY, prevData;\n\n      for(var i = 0; i < pathCoordinates.length; i += 2) {\n        var currX = pathCoordinates[i];\n        var currY = pathCoordinates[i + 1];\n        var length = (currX - prevX) * d;\n        var currData = valueData[i / 2];\n\n        if(currData.value !== undefined) {\n\n          if(prevData === undefined) {\n            path.move(currX, currY, false, currData);\n          } else {\n            path.curve(\n              prevX + length,\n              prevY,\n              currX - length,\n              currY,\n              currX,\n              currY,\n              false,\n              currData\n            );\n          }\n\n          prevX = currX;\n          prevY = currY;\n          prevData = currData;\n        } else if(!options.fillHoles) {\n          prevX = currX = prevData = undefined;\n        }\n      }\n\n      return path;\n    };\n  };\n\n  /**\n   * Cardinal / Catmull-Rome spline interpolation is the default smoothing function in Chartist. It produces nice results where the splines will always meet the points. It produces some artifacts though when data values are increased or decreased rapidly. The line may not follow a very accurate path and if the line should be accurate this smoothing function does not produce the best results.\n   *\n   * Cardinal splines can only be created if there are more than two data points. If this is not the case this smoothing will fallback to `Chartist.Smoothing.none`.\n   *\n   * All smoothing functions within Chartist are factory functions that accept an options parameter. The cardinal interpolation function accepts one configuration parameter `tension`, between 0 and 1, which controls the smoothing intensity.\n   *\n   * @example\n   * var chart = new Chartist.Line('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5],\n   *   series: [[1, 2, 8, 1, 7]]\n   * }, {\n   *   lineSmooth: Chartist.Interpolation.cardinal({\n   *     tension: 1,\n   *     fillHoles: false\n   *   })\n   * });\n   *\n   * @memberof Chartist.Interpolation\n   * @param {Object} options The options of the cardinal factory function.\n   * @return {Function}\n   */\n  Chartist.Interpolation.cardinal = function(options) {\n    var defaultOptions = {\n      tension: 1,\n      fillHoles: false\n    };\n\n    options = Chartist.extend({}, defaultOptions, options);\n\n    var t = Math.min(1, Math.max(0, options.tension)),\n      c = 1 - t;\n\n    // This function will help us to split pathCoordinates and valueData into segments that also contain pathCoordinates\n    // and valueData. This way the existing functions can be reused and the segment paths can be joined afterwards.\n    // This functionality is necessary to treat \"holes\" in the line charts\n    function splitIntoSegments(pathCoordinates, valueData) {\n      var segments = [];\n      var hole = true;\n\n      for(var i = 0; i < pathCoordinates.length; i += 2) {\n        // If this value is a \"hole\" we set the hole flag\n        if(valueData[i / 2].value === undefined) {\n          if(!options.fillHoles) {\n            hole = true;\n          }\n        } else {\n          // If it's a valid value we need to check if we're coming out of a hole and create a new empty segment\n          if(hole) {\n            segments.push({\n              pathCoordinates: [],\n              valueData: []\n            });\n            // As we have a valid value now, we are not in a \"hole\" anymore\n            hole = false;\n          }\n\n          // Add to the segment pathCoordinates and valueData\n          segments[segments.length - 1].pathCoordinates.push(pathCoordinates[i], pathCoordinates[i + 1]);\n          segments[segments.length - 1].valueData.push(valueData[i / 2]);\n        }\n      }\n\n      return segments;\n    }\n\n    return function cardinal(pathCoordinates, valueData) {\n      // First we try to split the coordinates into segments\n      // This is necessary to treat \"holes\" in line charts\n      var segments = splitIntoSegments(pathCoordinates, valueData);\n\n      if(!segments.length) {\n        // If there were no segments return 'Chartist.Interpolation.none'\n        return Chartist.Interpolation.none()([]);\n      } else if(segments.length > 1) {\n        // If the split resulted in more that one segment we need to interpolate each segment individually and join them\n        // afterwards together into a single path.\n          var paths = [];\n        // For each segment we will recurse the cardinal function\n        segments.forEach(function(segment) {\n          paths.push(cardinal(segment.pathCoordinates, segment.valueData));\n        });\n        // Join the segment path data into a single path and return\n        return Chartist.Svg.Path.join(paths);\n      } else {\n        // If there was only one segment we can proceed regularly by using pathCoordinates and valueData from the first\n        // segment\n        pathCoordinates = segments[0].pathCoordinates;\n        valueData = segments[0].valueData;\n\n        // If less than two points we need to fallback to no smoothing\n        if(pathCoordinates.length <= 4) {\n          return Chartist.Interpolation.none()(pathCoordinates, valueData);\n        }\n\n        var path = new Chartist.Svg.Path().move(pathCoordinates[0], pathCoordinates[1], false, valueData[0]),\n          z;\n\n        for (var i = 0, iLen = pathCoordinates.length; iLen - 2 * !z > i; i += 2) {\n          var p = [\n            {x: +pathCoordinates[i - 2], y: +pathCoordinates[i - 1]},\n            {x: +pathCoordinates[i], y: +pathCoordinates[i + 1]},\n            {x: +pathCoordinates[i + 2], y: +pathCoordinates[i + 3]},\n            {x: +pathCoordinates[i + 4], y: +pathCoordinates[i + 5]}\n          ];\n          if (z) {\n            if (!i) {\n              p[0] = {x: +pathCoordinates[iLen - 2], y: +pathCoordinates[iLen - 1]};\n            } else if (iLen - 4 === i) {\n              p[3] = {x: +pathCoordinates[0], y: +pathCoordinates[1]};\n            } else if (iLen - 2 === i) {\n              p[2] = {x: +pathCoordinates[0], y: +pathCoordinates[1]};\n              p[3] = {x: +pathCoordinates[2], y: +pathCoordinates[3]};\n            }\n          } else {\n            if (iLen - 4 === i) {\n              p[3] = p[2];\n            } else if (!i) {\n              p[0] = {x: +pathCoordinates[i], y: +pathCoordinates[i + 1]};\n            }\n          }\n\n          path.curve(\n            (t * (-p[0].x + 6 * p[1].x + p[2].x) / 6) + (c * p[2].x),\n            (t * (-p[0].y + 6 * p[1].y + p[2].y) / 6) + (c * p[2].y),\n            (t * (p[1].x + 6 * p[2].x - p[3].x) / 6) + (c * p[2].x),\n            (t * (p[1].y + 6 * p[2].y - p[3].y) / 6) + (c * p[2].y),\n            p[2].x,\n            p[2].y,\n            false,\n            valueData[(i + 2) / 2]\n          );\n        }\n\n        return path;\n      }\n    };\n  };\n\n  /**\n   * Step interpolation will cause the line chart to move in steps rather than diagonal or smoothed lines. This interpolation will create additional points that will also be drawn when the `showPoint` option is enabled.\n   *\n   * All smoothing functions within Chartist are factory functions that accept an options parameter. The step interpolation function accepts one configuration parameter `postpone`, that can be `true` or `false`. The default value is `true` and will cause the step to occur where the value actually changes. If a different behaviour is needed where the step is shifted to the left and happens before the actual value, this option can be set to `false`.\n   *\n   * @example\n   * var chart = new Chartist.Line('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5],\n   *   series: [[1, 2, 8, 1, 7]]\n   * }, {\n   *   lineSmooth: Chartist.Interpolation.step({\n   *     postpone: true,\n   *     fillHoles: false\n   *   })\n   * });\n   *\n   * @memberof Chartist.Interpolation\n   * @param options\n   * @returns {Function}\n   */\n  Chartist.Interpolation.step = function(options) {\n    var defaultOptions = {\n      postpone: true,\n      fillHoles: false\n    };\n\n    options = Chartist.extend({}, defaultOptions, options);\n\n    return function step(pathCoordinates, valueData) {\n      var path = new Chartist.Svg.Path();\n\n      var prevX, prevY, prevData;\n\n      for (var i = 0; i < pathCoordinates.length; i += 2) {\n        var currX = pathCoordinates[i];\n        var currY = pathCoordinates[i + 1];\n        var currData = valueData[i / 2];\n\n        // If the current point is also not a hole we can draw the step lines\n        if(currData.value !== undefined) {\n          if(prevData === undefined) {\n            path.move(currX, currY, false, currData);\n          } else {\n            if(options.postpone) {\n              // If postponed we should draw the step line with the value of the previous value\n              path.line(currX, prevY, false, prevData);\n            } else {\n              // If not postponed we should draw the step line with the value of the current value\n              path.line(prevX, currY, false, currData);\n            }\n            // Line to the actual point (this should only be a Y-Axis movement\n            path.line(currX, currY, false, currData);\n          }\n\n          prevX = currX;\n          prevY = currY;\n          prevData = currData;\n        } else if(!options.fillHoles) {\n          prevX = prevY = prevData = undefined;\n        }\n      }\n\n      return path;\n    };\n  };\n\n}(window, document, Chartist));\n;/**\n * A very basic event module that helps to generate and catch events.\n *\n * @module Chartist.Event\n */\n/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  Chartist.EventEmitter = function () {\n    var handlers = [];\n\n    /**\n     * Add an event handler for a specific event\n     *\n     * @memberof Chartist.Event\n     * @param {String} event The event name\n     * @param {Function} handler A event handler function\n     */\n    function addEventHandler(event, handler) {\n      handlers[event] = handlers[event] || [];\n      handlers[event].push(handler);\n    }\n\n    /**\n     * Remove an event handler of a specific event name or remove all event handlers for a specific event.\n     *\n     * @memberof Chartist.Event\n     * @param {String} event The event name where a specific or all handlers should be removed\n     * @param {Function} [handler] An optional event handler function. If specified only this specific handler will be removed and otherwise all handlers are removed.\n     */\n    function removeEventHandler(event, handler) {\n      // Only do something if there are event handlers with this name existing\n      if(handlers[event]) {\n        // If handler is set we will look for a specific handler and only remove this\n        if(handler) {\n          handlers[event].splice(handlers[event].indexOf(handler), 1);\n          if(handlers[event].length === 0) {\n            delete handlers[event];\n          }\n        } else {\n          // If no handler is specified we remove all handlers for this event\n          delete handlers[event];\n        }\n      }\n    }\n\n    /**\n     * Use this function to emit an event. All handlers that are listening for this event will be triggered with the data parameter.\n     *\n     * @memberof Chartist.Event\n     * @param {String} event The event name that should be triggered\n     * @param {*} data Arbitrary data that will be passed to the event handler callback functions\n     */\n    function emit(event, data) {\n      // Only do something if there are event handlers with this name existing\n      if(handlers[event]) {\n        handlers[event].forEach(function(handler) {\n          handler(data);\n        });\n      }\n\n      // Emit event to star event handlers\n      if(handlers['*']) {\n        handlers['*'].forEach(function(starHandler) {\n          starHandler(event, data);\n        });\n      }\n    }\n\n    return {\n      addEventHandler: addEventHandler,\n      removeEventHandler: removeEventHandler,\n      emit: emit\n    };\n  };\n\n}(window, document, Chartist));\n;/**\n * This module provides some basic prototype inheritance utilities.\n *\n * @module Chartist.Class\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  function listToArray(list) {\n    var arr = [];\n    if (list.length) {\n      for (var i = 0; i < list.length; i++) {\n        arr.push(list[i]);\n      }\n    }\n    return arr;\n  }\n\n  /**\n   * Method to extend from current prototype.\n   *\n   * @memberof Chartist.Class\n   * @param {Object} properties The object that serves as definition for the prototype that gets created for the new class. This object should always contain a constructor property that is the desired constructor for the newly created class.\n   * @param {Object} [superProtoOverride] By default extens will use the current class prototype or Chartist.class. With this parameter you can specify any super prototype that will be used.\n   * @return {Function} Constructor function of the new class\n   *\n   * @example\n   * var Fruit = Class.extend({\n     * color: undefined,\n     *   sugar: undefined,\n     *\n     *   constructor: function(color, sugar) {\n     *     this.color = color;\n     *     this.sugar = sugar;\n     *   },\n     *\n     *   eat: function() {\n     *     this.sugar = 0;\n     *     return this;\n     *   }\n     * });\n   *\n   * var Banana = Fruit.extend({\n     *   length: undefined,\n     *\n     *   constructor: function(length, sugar) {\n     *     Banana.super.constructor.call(this, 'Yellow', sugar);\n     *     this.length = length;\n     *   }\n     * });\n   *\n   * var banana = new Banana(20, 40);\n   * console.log('banana instanceof Fruit', banana instanceof Fruit);\n   * console.log('Fruit is prototype of banana', Fruit.prototype.isPrototypeOf(banana));\n   * console.log('bananas prototype is Fruit', Object.getPrototypeOf(banana) === Fruit.prototype);\n   * console.log(banana.sugar);\n   * console.log(banana.eat().sugar);\n   * console.log(banana.color);\n   */\n  function extend(properties, superProtoOverride) {\n    var superProto = superProtoOverride || this.prototype || Chartist.Class;\n    var proto = Object.create(superProto);\n\n    Chartist.Class.cloneDefinitions(proto, properties);\n\n    var constr = function() {\n      var fn = proto.constructor || function () {},\n        instance;\n\n      // If this is linked to the Chartist namespace the constructor was not called with new\n      // To provide a fallback we will instantiate here and return the instance\n      instance = this === Chartist ? Object.create(proto) : this;\n      fn.apply(instance, Array.prototype.slice.call(arguments, 0));\n\n      // If this constructor was not called with new we need to return the instance\n      // This will not harm when the constructor has been called with new as the returned value is ignored\n      return instance;\n    };\n\n    constr.prototype = proto;\n    constr.super = superProto;\n    constr.extend = this.extend;\n\n    return constr;\n  }\n\n  // Variable argument list clones args > 0 into args[0] and retruns modified args[0]\n  function cloneDefinitions() {\n    var args = listToArray(arguments);\n    var target = args[0];\n\n    args.splice(1, args.length - 1).forEach(function (source) {\n      Object.getOwnPropertyNames(source).forEach(function (propName) {\n        // If this property already exist in target we delete it first\n        delete target[propName];\n        // Define the property with the descriptor from source\n        Object.defineProperty(target, propName,\n          Object.getOwnPropertyDescriptor(source, propName));\n      });\n    });\n\n    return target;\n  }\n\n  Chartist.Class = {\n    extend: extend,\n    cloneDefinitions: cloneDefinitions\n  };\n\n}(window, document, Chartist));\n;/**\n * Base for all chart types. The methods in Chartist.Base are inherited to all chart types.\n *\n * @module Chartist.Base\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  // TODO: Currently we need to re-draw the chart on window resize. This is usually very bad and will affect performance.\n  // This is done because we can't work with relative coordinates when drawing the chart because SVG Path does not\n  // work with relative positions yet. We need to check if we can do a viewBox hack to switch to percentage.\n  // See http://mozilla.6506.n7.nabble.com/Specyfing-paths-with-percentages-unit-td247474.html\n  // Update: can be done using the above method tested here: http://codepen.io/gionkunz/pen/KDvLj\n  // The problem is with the label offsets that can't be converted into percentage and affecting the chart container\n  /**\n   * Updates the chart which currently does a full reconstruction of the SVG DOM\n   *\n   * @param {Object} [data] Optional data you'd like to set for the chart before it will update. If not specified the update method will use the data that is already configured with the chart.\n   * @param {Object} [options] Optional options you'd like to add to the previous options for the chart before it will update. If not specified the update method will use the options that have been already configured with the chart.\n   * @param {Boolean} [override] If set to true, the passed options will be used to extend the options that have been configured already. Otherwise the chart default options will be used as the base\n   * @memberof Chartist.Base\n   */\n  function update(data, options, override) {\n    if(data) {\n      this.data = data;\n      // Event for data transformation that allows to manipulate the data before it gets rendered in the charts\n      this.eventEmitter.emit('data', {\n        type: 'update',\n        data: this.data\n      });\n    }\n\n    if(options) {\n      this.options = Chartist.extend({}, override ? this.options : this.defaultOptions, options);\n\n      // If chartist was not initialized yet, we just set the options and leave the rest to the initialization\n      // Otherwise we re-create the optionsProvider at this point\n      if(!this.initializeTimeoutId) {\n        this.optionsProvider.removeMediaQueryListeners();\n        this.optionsProvider = Chartist.optionsProvider(this.options, this.responsiveOptions, this.eventEmitter);\n      }\n    }\n\n    // Only re-created the chart if it has been initialized yet\n    if(!this.initializeTimeoutId) {\n      this.createChart(this.optionsProvider.getCurrentOptions());\n    }\n\n    // Return a reference to the chart object to chain up calls\n    return this;\n  }\n\n  /**\n   * This method can be called on the API object of each chart and will un-register all event listeners that were added to other components. This currently includes a window.resize listener as well as media query listeners if any responsive options have been provided. Use this function if you need to destroy and recreate Chartist charts dynamically.\n   *\n   * @memberof Chartist.Base\n   */\n  function detach() {\n    // Only detach if initialization already occurred on this chart. If this chart still hasn't initialized (therefore\n    // the initializationTimeoutId is still a valid timeout reference, we will clear the timeout\n    if(!this.initializeTimeoutId) {\n      window.removeEventListener('resize', this.resizeListener);\n      this.optionsProvider.removeMediaQueryListeners();\n    } else {\n      window.clearTimeout(this.initializeTimeoutId);\n    }\n\n    return this;\n  }\n\n  /**\n   * Use this function to register event handlers. The handler callbacks are synchronous and will run in the main thread rather than the event loop.\n   *\n   * @memberof Chartist.Base\n   * @param {String} event Name of the event. Check the examples for supported events.\n   * @param {Function} handler The handler function that will be called when an event with the given name was emitted. This function will receive a data argument which contains event data. See the example for more details.\n   */\n  function on(event, handler) {\n    this.eventEmitter.addEventHandler(event, handler);\n    return this;\n  }\n\n  /**\n   * Use this function to un-register event handlers. If the handler function parameter is omitted all handlers for the given event will be un-registered.\n   *\n   * @memberof Chartist.Base\n   * @param {String} event Name of the event for which a handler should be removed\n   * @param {Function} [handler] The handler function that that was previously used to register a new event handler. This handler will be removed from the event handler list. If this parameter is omitted then all event handlers for the given event are removed from the list.\n   */\n  function off(event, handler) {\n    this.eventEmitter.removeEventHandler(event, handler);\n    return this;\n  }\n\n  function initialize() {\n    // Add window resize listener that re-creates the chart\n    window.addEventListener('resize', this.resizeListener);\n\n    // Obtain current options based on matching media queries (if responsive options are given)\n    // This will also register a listener that is re-creating the chart based on media changes\n    this.optionsProvider = Chartist.optionsProvider(this.options, this.responsiveOptions, this.eventEmitter);\n    // Register options change listener that will trigger a chart update\n    this.eventEmitter.addEventHandler('optionsChanged', function() {\n      this.update();\n    }.bind(this));\n\n    // Before the first chart creation we need to register us with all plugins that are configured\n    // Initialize all relevant plugins with our chart object and the plugin options specified in the config\n    if(this.options.plugins) {\n      this.options.plugins.forEach(function(plugin) {\n        if(plugin instanceof Array) {\n          plugin[0](this, plugin[1]);\n        } else {\n          plugin(this);\n        }\n      }.bind(this));\n    }\n\n    // Event for data transformation that allows to manipulate the data before it gets rendered in the charts\n    this.eventEmitter.emit('data', {\n      type: 'initial',\n      data: this.data\n    });\n\n    // Create the first chart\n    this.createChart(this.optionsProvider.getCurrentOptions());\n\n    // As chart is initialized from the event loop now we can reset our timeout reference\n    // This is important if the chart gets initialized on the same element twice\n    this.initializeTimeoutId = undefined;\n  }\n\n  /**\n   * Constructor of chart base class.\n   *\n   * @param query\n   * @param data\n   * @param defaultOptions\n   * @param options\n   * @param responsiveOptions\n   * @constructor\n   */\n  function Base(query, data, defaultOptions, options, responsiveOptions) {\n    this.container = Chartist.querySelector(query);\n    this.data = data;\n    this.defaultOptions = defaultOptions;\n    this.options = options;\n    this.responsiveOptions = responsiveOptions;\n    this.eventEmitter = Chartist.EventEmitter();\n    this.supportsForeignObject = Chartist.Svg.isSupported('Extensibility');\n    this.supportsAnimations = Chartist.Svg.isSupported('AnimationEventsAttribute');\n    this.resizeListener = function resizeListener(){\n      this.update();\n    }.bind(this);\n\n    if(this.container) {\n      // If chartist was already initialized in this container we are detaching all event listeners first\n      if(this.container.__chartist__) {\n        this.container.__chartist__.detach();\n      }\n\n      this.container.__chartist__ = this;\n    }\n\n    // Using event loop for first draw to make it possible to register event listeners in the same call stack where\n    // the chart was created.\n    this.initializeTimeoutId = setTimeout(initialize.bind(this), 0);\n  }\n\n  // Creating the chart base class\n  Chartist.Base = Chartist.Class.extend({\n    constructor: Base,\n    optionsProvider: undefined,\n    container: undefined,\n    svg: undefined,\n    eventEmitter: undefined,\n    createChart: function() {\n      throw new Error('Base chart type can\\'t be instantiated!');\n    },\n    update: update,\n    detach: detach,\n    on: on,\n    off: off,\n    version: Chartist.version,\n    supportsForeignObject: false\n  });\n\n}(window, document, Chartist));\n;/**\n * Chartist SVG module for simple SVG DOM abstraction\n *\n * @module Chartist.Svg\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  /**\n   * Chartist.Svg creates a new SVG object wrapper with a starting element. You can use the wrapper to fluently create sub-elements and modify them.\n   *\n   * @memberof Chartist.Svg\n   * @constructor\n   * @param {String|Element} name The name of the SVG element to create or an SVG dom element which should be wrapped into Chartist.Svg\n   * @param {Object} attributes An object with properties that will be added as attributes to the SVG element that is created. Attributes with undefined values will not be added.\n   * @param {String} className This class or class list will be added to the SVG element\n   * @param {Object} parent The parent SVG wrapper object where this newly created wrapper and it's element will be attached to as child\n   * @param {Boolean} insertFirst If this param is set to true in conjunction with a parent element the newly created element will be added as first child element in the parent element\n   */\n  function Svg(name, attributes, className, parent, insertFirst) {\n    // If Svg is getting called with an SVG element we just return the wrapper\n    if(name instanceof Element) {\n      this._node = name;\n    } else {\n      this._node = document.createElementNS(Chartist.namespaces.svg, name);\n\n      // If this is an SVG element created then custom namespace\n      if(name === 'svg') {\n        this.attr({\n          'xmlns:ct': Chartist.namespaces.ct\n        });\n      }\n    }\n\n    if(attributes) {\n      this.attr(attributes);\n    }\n\n    if(className) {\n      this.addClass(className);\n    }\n\n    if(parent) {\n      if (insertFirst && parent._node.firstChild) {\n        parent._node.insertBefore(this._node, parent._node.firstChild);\n      } else {\n        parent._node.appendChild(this._node);\n      }\n    }\n  }\n\n  /**\n   * Set attributes on the current SVG element of the wrapper you're currently working on.\n   *\n   * @memberof Chartist.Svg\n   * @param {Object|String} attributes An object with properties that will be added as attributes to the SVG element that is created. Attributes with undefined values will not be added. If this parameter is a String then the function is used as a getter and will return the attribute value.\n   * @param {String} ns If specified, the attribute will be obtained using getAttributeNs. In order to write namepsaced attributes you can use the namespace:attribute notation within the attributes object.\n   * @return {Object|String} The current wrapper object will be returned so it can be used for chaining or the attribute value if used as getter function.\n   */\n  function attr(attributes, ns) {\n    if(typeof attributes === 'string') {\n      if(ns) {\n        return this._node.getAttributeNS(ns, attributes);\n      } else {\n        return this._node.getAttribute(attributes);\n      }\n    }\n\n    Object.keys(attributes).forEach(function(key) {\n      // If the attribute value is undefined we can skip this one\n      if(attributes[key] === undefined) {\n        return;\n      }\n\n      if (key.indexOf(':') !== -1) {\n        var namespacedAttribute = key.split(':');\n        this._node.setAttributeNS(Chartist.namespaces[namespacedAttribute[0]], key, attributes[key]);\n      } else {\n        this._node.setAttribute(key, attributes[key]);\n      }\n    }.bind(this));\n\n    return this;\n  }\n\n  /**\n   * Create a new SVG element whose wrapper object will be selected for further operations. This way you can also create nested groups easily.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} name The name of the SVG element that should be created as child element of the currently selected element wrapper\n   * @param {Object} [attributes] An object with properties that will be added as attributes to the SVG element that is created. Attributes with undefined values will not be added.\n   * @param {String} [className] This class or class list will be added to the SVG element\n   * @param {Boolean} [insertFirst] If this param is set to true in conjunction with a parent element the newly created element will be added as first child element in the parent element\n   * @return {Chartist.Svg} Returns a Chartist.Svg wrapper object that can be used to modify the containing SVG data\n   */\n  function elem(name, attributes, className, insertFirst) {\n    return new Chartist.Svg(name, attributes, className, this, insertFirst);\n  }\n\n  /**\n   * Returns the parent Chartist.SVG wrapper object\n   *\n   * @memberof Chartist.Svg\n   * @return {Chartist.Svg} Returns a Chartist.Svg wrapper around the parent node of the current node. If the parent node is not existing or it's not an SVG node then this function will return null.\n   */\n  function parent() {\n    return this._node.parentNode instanceof SVGElement ? new Chartist.Svg(this._node.parentNode) : null;\n  }\n\n  /**\n   * This method returns a Chartist.Svg wrapper around the root SVG element of the current tree.\n   *\n   * @memberof Chartist.Svg\n   * @return {Chartist.Svg} The root SVG element wrapped in a Chartist.Svg element\n   */\n  function root() {\n    var node = this._node;\n    while(node.nodeName !== 'svg') {\n      node = node.parentNode;\n    }\n    return new Chartist.Svg(node);\n  }\n\n  /**\n   * Find the first child SVG element of the current element that matches a CSS selector. The returned object is a Chartist.Svg wrapper.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} selector A CSS selector that is used to query for child SVG elements\n   * @return {Chartist.Svg} The SVG wrapper for the element found or null if no element was found\n   */\n  function querySelector(selector) {\n    var foundNode = this._node.querySelector(selector);\n    return foundNode ? new Chartist.Svg(foundNode) : null;\n  }\n\n  /**\n   * Find the all child SVG elements of the current element that match a CSS selector. The returned object is a Chartist.Svg.List wrapper.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} selector A CSS selector that is used to query for child SVG elements\n   * @return {Chartist.Svg.List} The SVG wrapper list for the element found or null if no element was found\n   */\n  function querySelectorAll(selector) {\n    var foundNodes = this._node.querySelectorAll(selector);\n    return foundNodes.length ? new Chartist.Svg.List(foundNodes) : null;\n  }\n\n  /**\n   * This method creates a foreignObject (see https://developer.mozilla.org/en-US/docs/Web/SVG/Element/foreignObject) that allows to embed HTML content into a SVG graphic. With the help of foreignObjects you can enable the usage of regular HTML elements inside of SVG where they are subject for SVG positioning and transformation but the Browser will use the HTML rendering capabilities for the containing DOM.\n   *\n   * @memberof Chartist.Svg\n   * @param {Node|String} content The DOM Node, or HTML string that will be converted to a DOM Node, that is then placed into and wrapped by the foreignObject\n   * @param {String} [attributes] An object with properties that will be added as attributes to the foreignObject element that is created. Attributes with undefined values will not be added.\n   * @param {String} [className] This class or class list will be added to the SVG element\n   * @param {Boolean} [insertFirst] Specifies if the foreignObject should be inserted as first child\n   * @return {Chartist.Svg} New wrapper object that wraps the foreignObject element\n   */\n  function foreignObject(content, attributes, className, insertFirst) {\n    // If content is string then we convert it to DOM\n    // TODO: Handle case where content is not a string nor a DOM Node\n    if(typeof content === 'string') {\n      var container = document.createElement('div');\n      container.innerHTML = content;\n      content = container.firstChild;\n    }\n\n    // Adding namespace to content element\n    content.setAttribute('xmlns', Chartist.namespaces.xmlns);\n\n    // Creating the foreignObject without required extension attribute (as described here\n    // http://www.w3.org/TR/SVG/extend.html#ForeignObjectElement)\n    var fnObj = this.elem('foreignObject', attributes, className, insertFirst);\n\n    // Add content to foreignObjectElement\n    fnObj._node.appendChild(content);\n\n    return fnObj;\n  }\n\n  /**\n   * This method adds a new text element to the current Chartist.Svg wrapper.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} t The text that should be added to the text element that is created\n   * @return {Chartist.Svg} The same wrapper object that was used to add the newly created element\n   */\n  function text(t) {\n    this._node.appendChild(document.createTextNode(t));\n    return this;\n  }\n\n  /**\n   * This method will clear all child nodes of the current wrapper object.\n   *\n   * @memberof Chartist.Svg\n   * @return {Chartist.Svg} The same wrapper object that got emptied\n   */\n  function empty() {\n    while (this._node.firstChild) {\n      this._node.removeChild(this._node.firstChild);\n    }\n\n    return this;\n  }\n\n  /**\n   * This method will cause the current wrapper to remove itself from its parent wrapper. Use this method if you'd like to get rid of an element in a given DOM structure.\n   *\n   * @memberof Chartist.Svg\n   * @return {Chartist.Svg} The parent wrapper object of the element that got removed\n   */\n  function remove() {\n    this._node.parentNode.removeChild(this._node);\n    return this.parent();\n  }\n\n  /**\n   * This method will replace the element with a new element that can be created outside of the current DOM.\n   *\n   * @memberof Chartist.Svg\n   * @param {Chartist.Svg} newElement The new Chartist.Svg object that will be used to replace the current wrapper object\n   * @return {Chartist.Svg} The wrapper of the new element\n   */\n  function replace(newElement) {\n    this._node.parentNode.replaceChild(newElement._node, this._node);\n    return newElement;\n  }\n\n  /**\n   * This method will append an element to the current element as a child.\n   *\n   * @memberof Chartist.Svg\n   * @param {Chartist.Svg} element The Chartist.Svg element that should be added as a child\n   * @param {Boolean} [insertFirst] Specifies if the element should be inserted as first child\n   * @return {Chartist.Svg} The wrapper of the appended object\n   */\n  function append(element, insertFirst) {\n    if(insertFirst && this._node.firstChild) {\n      this._node.insertBefore(element._node, this._node.firstChild);\n    } else {\n      this._node.appendChild(element._node);\n    }\n\n    return this;\n  }\n\n  /**\n   * Returns an array of class names that are attached to the current wrapper element. This method can not be chained further.\n   *\n   * @memberof Chartist.Svg\n   * @return {Array} A list of classes or an empty array if there are no classes on the current element\n   */\n  function classes() {\n    return this._node.getAttribute('class') ? this._node.getAttribute('class').trim().split(/\\s+/) : [];\n  }\n\n  /**\n   * Adds one or a space separated list of classes to the current element and ensures the classes are only existing once.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} names A white space separated list of class names\n   * @return {Chartist.Svg} The wrapper of the current element\n   */\n  function addClass(names) {\n    this._node.setAttribute('class',\n      this.classes(this._node)\n        .concat(names.trim().split(/\\s+/))\n        .filter(function(elem, pos, self) {\n          return self.indexOf(elem) === pos;\n        }).join(' ')\n    );\n\n    return this;\n  }\n\n  /**\n   * Removes one or a space separated list of classes from the current element.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} names A white space separated list of class names\n   * @return {Chartist.Svg} The wrapper of the current element\n   */\n  function removeClass(names) {\n    var removedClasses = names.trim().split(/\\s+/);\n\n    this._node.setAttribute('class', this.classes(this._node).filter(function(name) {\n      return removedClasses.indexOf(name) === -1;\n    }).join(' '));\n\n    return this;\n  }\n\n  /**\n   * Removes all classes from the current element.\n   *\n   * @memberof Chartist.Svg\n   * @return {Chartist.Svg} The wrapper of the current element\n   */\n  function removeAllClasses() {\n    this._node.setAttribute('class', '');\n\n    return this;\n  }\n\n  /**\n   * Get element height using `getBoundingClientRect`\n   *\n   * @memberof Chartist.Svg\n   * @return {Number} The elements height in pixels\n   */\n  function height() {\n    return this._node.getBoundingClientRect().height;\n  }\n\n  /**\n   * Get element width using `getBoundingClientRect`\n   *\n   * @memberof Chartist.Core\n   * @return {Number} The elements width in pixels\n   */\n  function width() {\n    return this._node.getBoundingClientRect().width;\n  }\n\n  /**\n   * The animate function lets you animate the current element with SMIL animations. You can add animations for multiple attributes at the same time by using an animation definition object. This object should contain SMIL animation attributes. Please refer to http://www.w3.org/TR/SVG/animate.html for a detailed specification about the available animation attributes. Additionally an easing property can be passed in the animation definition object. This can be a string with a name of an easing function in `Chartist.Svg.Easing` or an array with four numbers specifying a cubic Bézier curve.\n   * **An animations object could look like this:**\n   * ```javascript\n   * element.animate({\n   *   opacity: {\n   *     dur: 1000,\n   *     from: 0,\n   *     to: 1\n   *   },\n   *   x1: {\n   *     dur: '1000ms',\n   *     from: 100,\n   *     to: 200,\n   *     easing: 'easeOutQuart'\n   *   },\n   *   y1: {\n   *     dur: '2s',\n   *     from: 0,\n   *     to: 100\n   *   }\n   * });\n   * ```\n   * **Automatic unit conversion**\n   * For the `dur` and the `begin` animate attribute you can also omit a unit by passing a number. The number will automatically be converted to milli seconds.\n   * **Guided mode**\n   * The default behavior of SMIL animations with offset using the `begin` attribute is that the attribute will keep it's original value until the animation starts. Mostly this behavior is not desired as you'd like to have your element attributes already initialized with the animation `from` value even before the animation starts. Also if you don't specify `fill=\"freeze\"` on an animate element or if you delete the animation after it's done (which is done in guided mode) the attribute will switch back to the initial value. This behavior is also not desired when performing simple one-time animations. For one-time animations you'd want to trigger animations immediately instead of relative to the document begin time. That's why in guided mode Chartist.Svg will also use the `begin` property to schedule a timeout and manually start the animation after the timeout. If you're using multiple SMIL definition objects for an attribute (in an array), guided mode will be disabled for this attribute, even if you explicitly enabled it.\n   * If guided mode is enabled the following behavior is added:\n   * - Before the animation starts (even when delayed with `begin`) the animated attribute will be set already to the `from` value of the animation\n   * - `begin` is explicitly set to `indefinite` so it can be started manually without relying on document begin time (creation)\n   * - The animate element will be forced to use `fill=\"freeze\"`\n   * - The animation will be triggered with `beginElement()` in a timeout where `begin` of the definition object is interpreted in milli seconds. If no `begin` was specified the timeout is triggered immediately.\n   * - After the animation the element attribute value will be set to the `to` value of the animation\n   * - The animate element is deleted from the DOM\n   *\n   * @memberof Chartist.Svg\n   * @param {Object} animations An animations object where the property keys are the attributes you'd like to animate. The properties should be objects again that contain the SMIL animation attributes (usually begin, dur, from, and to). The property begin and dur is auto converted (see Automatic unit conversion). You can also schedule multiple animations for the same attribute by passing an Array of SMIL definition objects. Attributes that contain an array of SMIL definition objects will not be executed in guided mode.\n   * @param {Boolean} guided Specify if guided mode should be activated for this animation (see Guided mode). If not otherwise specified, guided mode will be activated.\n   * @param {Object} eventEmitter If specified, this event emitter will be notified when an animation starts or ends.\n   * @return {Chartist.Svg} The current element where the animation was added\n   */\n  function animate(animations, guided, eventEmitter) {\n    if(guided === undefined) {\n      guided = true;\n    }\n\n    Object.keys(animations).forEach(function createAnimateForAttributes(attribute) {\n\n      function createAnimate(animationDefinition, guided) {\n        var attributeProperties = {},\n          animate,\n          timeout,\n          easing;\n\n        // Check if an easing is specified in the definition object and delete it from the object as it will not\n        // be part of the animate element attributes.\n        if(animationDefinition.easing) {\n          // If already an easing Bézier curve array we take it or we lookup a easing array in the Easing object\n          easing = animationDefinition.easing instanceof Array ?\n            animationDefinition.easing :\n            Chartist.Svg.Easing[animationDefinition.easing];\n          delete animationDefinition.easing;\n        }\n\n        // If numeric dur or begin was provided we assume milli seconds\n        animationDefinition.begin = Chartist.ensureUnit(animationDefinition.begin, 'ms');\n        animationDefinition.dur = Chartist.ensureUnit(animationDefinition.dur, 'ms');\n\n        if(easing) {\n          animationDefinition.calcMode = 'spline';\n          animationDefinition.keySplines = easing.join(' ');\n          animationDefinition.keyTimes = '0;1';\n        }\n\n        // Adding \"fill: freeze\" if we are in guided mode and set initial attribute values\n        if(guided) {\n          animationDefinition.fill = 'freeze';\n          // Animated property on our element should already be set to the animation from value in guided mode\n          attributeProperties[attribute] = animationDefinition.from;\n          this.attr(attributeProperties);\n\n          // In guided mode we also set begin to indefinite so we can trigger the start manually and put the begin\n          // which needs to be in ms aside\n          timeout = Chartist.quantity(animationDefinition.begin || 0).value;\n          animationDefinition.begin = 'indefinite';\n        }\n\n        animate = this.elem('animate', Chartist.extend({\n          attributeName: attribute\n        }, animationDefinition));\n\n        if(guided) {\n          // If guided we take the value that was put aside in timeout and trigger the animation manually with a timeout\n          setTimeout(function() {\n            // If beginElement fails we set the animated attribute to the end position and remove the animate element\n            // This happens if the SMIL ElementTimeControl interface is not supported or any other problems occured in\n            // the browser. (Currently FF 34 does not support animate elements in foreignObjects)\n            try {\n              animate._node.beginElement();\n            } catch(err) {\n              // Set animated attribute to current animated value\n              attributeProperties[attribute] = animationDefinition.to;\n              this.attr(attributeProperties);\n              // Remove the animate element as it's no longer required\n              animate.remove();\n            }\n          }.bind(this), timeout);\n        }\n\n        if(eventEmitter) {\n          animate._node.addEventListener('beginEvent', function handleBeginEvent() {\n            eventEmitter.emit('animationBegin', {\n              element: this,\n              animate: animate._node,\n              params: animationDefinition\n            });\n          }.bind(this));\n        }\n\n        animate._node.addEventListener('endEvent', function handleEndEvent() {\n          if(eventEmitter) {\n            eventEmitter.emit('animationEnd', {\n              element: this,\n              animate: animate._node,\n              params: animationDefinition\n            });\n          }\n\n          if(guided) {\n            // Set animated attribute to current animated value\n            attributeProperties[attribute] = animationDefinition.to;\n            this.attr(attributeProperties);\n            // Remove the animate element as it's no longer required\n            animate.remove();\n          }\n        }.bind(this));\n      }\n\n      // If current attribute is an array of definition objects we create an animate for each and disable guided mode\n      if(animations[attribute] instanceof Array) {\n        animations[attribute].forEach(function(animationDefinition) {\n          createAnimate.bind(this)(animationDefinition, false);\n        }.bind(this));\n      } else {\n        createAnimate.bind(this)(animations[attribute], guided);\n      }\n\n    }.bind(this));\n\n    return this;\n  }\n\n  Chartist.Svg = Chartist.Class.extend({\n    constructor: Svg,\n    attr: attr,\n    elem: elem,\n    parent: parent,\n    root: root,\n    querySelector: querySelector,\n    querySelectorAll: querySelectorAll,\n    foreignObject: foreignObject,\n    text: text,\n    empty: empty,\n    remove: remove,\n    replace: replace,\n    append: append,\n    classes: classes,\n    addClass: addClass,\n    removeClass: removeClass,\n    removeAllClasses: removeAllClasses,\n    height: height,\n    width: width,\n    animate: animate\n  });\n\n  /**\n   * This method checks for support of a given SVG feature like Extensibility, SVG-animation or the like. Check http://www.w3.org/TR/SVG11/feature for a detailed list.\n   *\n   * @memberof Chartist.Svg\n   * @param {String} feature The SVG 1.1 feature that should be checked for support.\n   * @return {Boolean} True of false if the feature is supported or not\n   */\n  Chartist.Svg.isSupported = function(feature) {\n    return document.implementation.hasFeature('http://www.w3.org/TR/SVG11/feature#' + feature, '1.1');\n  };\n\n  /**\n   * This Object contains some standard easing cubic bezier curves. Then can be used with their name in the `Chartist.Svg.animate`. You can also extend the list and use your own name in the `animate` function. Click the show code button to see the available bezier functions.\n   *\n   * @memberof Chartist.Svg\n   */\n  var easingCubicBeziers = {\n    easeInSine: [0.47, 0, 0.745, 0.715],\n    easeOutSine: [0.39, 0.575, 0.565, 1],\n    easeInOutSine: [0.445, 0.05, 0.55, 0.95],\n    easeInQuad: [0.55, 0.085, 0.68, 0.53],\n    easeOutQuad: [0.25, 0.46, 0.45, 0.94],\n    easeInOutQuad: [0.455, 0.03, 0.515, 0.955],\n    easeInCubic: [0.55, 0.055, 0.675, 0.19],\n    easeOutCubic: [0.215, 0.61, 0.355, 1],\n    easeInOutCubic: [0.645, 0.045, 0.355, 1],\n    easeInQuart: [0.895, 0.03, 0.685, 0.22],\n    easeOutQuart: [0.165, 0.84, 0.44, 1],\n    easeInOutQuart: [0.77, 0, 0.175, 1],\n    easeInQuint: [0.755, 0.05, 0.855, 0.06],\n    easeOutQuint: [0.23, 1, 0.32, 1],\n    easeInOutQuint: [0.86, 0, 0.07, 1],\n    easeInExpo: [0.95, 0.05, 0.795, 0.035],\n    easeOutExpo: [0.19, 1, 0.22, 1],\n    easeInOutExpo: [1, 0, 0, 1],\n    easeInCirc: [0.6, 0.04, 0.98, 0.335],\n    easeOutCirc: [0.075, 0.82, 0.165, 1],\n    easeInOutCirc: [0.785, 0.135, 0.15, 0.86],\n    easeInBack: [0.6, -0.28, 0.735, 0.045],\n    easeOutBack: [0.175, 0.885, 0.32, 1.275],\n    easeInOutBack: [0.68, -0.55, 0.265, 1.55]\n  };\n\n  Chartist.Svg.Easing = easingCubicBeziers;\n\n  /**\n   * This helper class is to wrap multiple `Chartist.Svg` elements into a list where you can call the `Chartist.Svg` functions on all elements in the list with one call. This is helpful when you'd like to perform calls with `Chartist.Svg` on multiple elements.\n   * An instance of this class is also returned by `Chartist.Svg.querySelectorAll`.\n   *\n   * @memberof Chartist.Svg\n   * @param {Array<Node>|NodeList} nodeList An Array of SVG DOM nodes or a SVG DOM NodeList (as returned by document.querySelectorAll)\n   * @constructor\n   */\n  function SvgList(nodeList) {\n    var list = this;\n\n    this.svgElements = [];\n    for(var i = 0; i < nodeList.length; i++) {\n      this.svgElements.push(new Chartist.Svg(nodeList[i]));\n    }\n\n    // Add delegation methods for Chartist.Svg\n    Object.keys(Chartist.Svg.prototype).filter(function(prototypeProperty) {\n      return ['constructor',\n          'parent',\n          'querySelector',\n          'querySelectorAll',\n          'replace',\n          'append',\n          'classes',\n          'height',\n          'width'].indexOf(prototypeProperty) === -1;\n    }).forEach(function(prototypeProperty) {\n      list[prototypeProperty] = function() {\n        var args = Array.prototype.slice.call(arguments, 0);\n        list.svgElements.forEach(function(element) {\n          Chartist.Svg.prototype[prototypeProperty].apply(element, args);\n        });\n        return list;\n      };\n    });\n  }\n\n  Chartist.Svg.List = Chartist.Class.extend({\n    constructor: SvgList\n  });\n}(window, document, Chartist));\n;/**\n * Chartist SVG path module for SVG path description creation and modification.\n *\n * @module Chartist.Svg.Path\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  /**\n   * Contains the descriptors of supported element types in a SVG path. Currently only move, line and curve are supported.\n   *\n   * @memberof Chartist.Svg.Path\n   * @type {Object}\n   */\n  var elementDescriptions = {\n    m: ['x', 'y'],\n    l: ['x', 'y'],\n    c: ['x1', 'y1', 'x2', 'y2', 'x', 'y'],\n    a: ['rx', 'ry', 'xAr', 'lAf', 'sf', 'x', 'y']\n  };\n\n  /**\n   * Default options for newly created SVG path objects.\n   *\n   * @memberof Chartist.Svg.Path\n   * @type {Object}\n   */\n  var defaultOptions = {\n    // The accuracy in digit count after the decimal point. This will be used to round numbers in the SVG path. If this option is set to false then no rounding will be performed.\n    accuracy: 3\n  };\n\n  function element(command, params, pathElements, pos, relative, data) {\n    var pathElement = Chartist.extend({\n      command: relative ? command.toLowerCase() : command.toUpperCase()\n    }, params, data ? { data: data } : {} );\n\n    pathElements.splice(pos, 0, pathElement);\n  }\n\n  function forEachParam(pathElements, cb) {\n    pathElements.forEach(function(pathElement, pathElementIndex) {\n      elementDescriptions[pathElement.command.toLowerCase()].forEach(function(paramName, paramIndex) {\n        cb(pathElement, paramName, pathElementIndex, paramIndex, pathElements);\n      });\n    });\n  }\n\n  /**\n   * Used to construct a new path object.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Boolean} close If set to true then this path will be closed when stringified (with a Z at the end)\n   * @param {Object} options Options object that overrides the default objects. See default options for more details.\n   * @constructor\n   */\n  function SvgPath(close, options) {\n    this.pathElements = [];\n    this.pos = 0;\n    this.close = close;\n    this.options = Chartist.extend({}, defaultOptions, options);\n  }\n\n  /**\n   * Gets or sets the current position (cursor) inside of the path. You can move around the cursor freely but limited to 0 or the count of existing elements. All modifications with element functions will insert new elements at the position of this cursor.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} [pos] If a number is passed then the cursor is set to this position in the path element array.\n   * @return {Chartist.Svg.Path|Number} If the position parameter was passed then the return value will be the path object for easy call chaining. If no position parameter was passed then the current position is returned.\n   */\n  function position(pos) {\n    if(pos !== undefined) {\n      this.pos = Math.max(0, Math.min(this.pathElements.length, pos));\n      return this;\n    } else {\n      return this.pos;\n    }\n  }\n\n  /**\n   * Removes elements from the path starting at the current position.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} count Number of path elements that should be removed from the current position.\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function remove(count) {\n    this.pathElements.splice(this.pos, count);\n    return this;\n  }\n\n  /**\n   * Use this function to add a new move SVG path element.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} x The x coordinate for the move element.\n   * @param {Number} y The y coordinate for the move element.\n   * @param {Boolean} [relative] If set to true the move element will be created with relative coordinates (lowercase letter)\n   * @param {*} [data] Any data that should be stored with the element object that will be accessible in pathElement\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function move(x, y, relative, data) {\n    element('M', {\n      x: +x,\n      y: +y\n    }, this.pathElements, this.pos++, relative, data);\n    return this;\n  }\n\n  /**\n   * Use this function to add a new line SVG path element.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} x The x coordinate for the line element.\n   * @param {Number} y The y coordinate for the line element.\n   * @param {Boolean} [relative] If set to true the line element will be created with relative coordinates (lowercase letter)\n   * @param {*} [data] Any data that should be stored with the element object that will be accessible in pathElement\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function line(x, y, relative, data) {\n    element('L', {\n      x: +x,\n      y: +y\n    }, this.pathElements, this.pos++, relative, data);\n    return this;\n  }\n\n  /**\n   * Use this function to add a new curve SVG path element.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} x1 The x coordinate for the first control point of the bezier curve.\n   * @param {Number} y1 The y coordinate for the first control point of the bezier curve.\n   * @param {Number} x2 The x coordinate for the second control point of the bezier curve.\n   * @param {Number} y2 The y coordinate for the second control point of the bezier curve.\n   * @param {Number} x The x coordinate for the target point of the curve element.\n   * @param {Number} y The y coordinate for the target point of the curve element.\n   * @param {Boolean} [relative] If set to true the curve element will be created with relative coordinates (lowercase letter)\n   * @param {*} [data] Any data that should be stored with the element object that will be accessible in pathElement\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function curve(x1, y1, x2, y2, x, y, relative, data) {\n    element('C', {\n      x1: +x1,\n      y1: +y1,\n      x2: +x2,\n      y2: +y2,\n      x: +x,\n      y: +y\n    }, this.pathElements, this.pos++, relative, data);\n    return this;\n  }\n\n  /**\n   * Use this function to add a new non-bezier curve SVG path element.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} rx The radius to be used for the x-axis of the arc.\n   * @param {Number} ry The radius to be used for the y-axis of the arc.\n   * @param {Number} xAr Defines the orientation of the arc\n   * @param {Number} lAf Large arc flag\n   * @param {Number} sf Sweep flag\n   * @param {Number} x The x coordinate for the target point of the curve element.\n   * @param {Number} y The y coordinate for the target point of the curve element.\n   * @param {Boolean} [relative] If set to true the curve element will be created with relative coordinates (lowercase letter)\n   * @param {*} [data] Any data that should be stored with the element object that will be accessible in pathElement\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function arc(rx, ry, xAr, lAf, sf, x, y, relative, data) {\n    element('A', {\n      rx: +rx,\n      ry: +ry,\n      xAr: +xAr,\n      lAf: +lAf,\n      sf: +sf,\n      x: +x,\n      y: +y\n    }, this.pathElements, this.pos++, relative, data);\n    return this;\n  }\n\n  /**\n   * Parses an SVG path seen in the d attribute of path elements, and inserts the parsed elements into the existing path object at the current cursor position. Any closing path indicators (Z at the end of the path) will be ignored by the parser as this is provided by the close option in the options of the path object.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {String} path Any SVG path that contains move (m), line (l) or curve (c) components.\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function parse(path) {\n    // Parsing the SVG path string into an array of arrays [['M', '10', '10'], ['L', '100', '100']]\n    var chunks = path.replace(/([A-Za-z])([0-9])/g, '$1 $2')\n      .replace(/([0-9])([A-Za-z])/g, '$1 $2')\n      .split(/[\\s,]+/)\n      .reduce(function(result, element) {\n        if(element.match(/[A-Za-z]/)) {\n          result.push([]);\n        }\n\n        result[result.length - 1].push(element);\n        return result;\n      }, []);\n\n    // If this is a closed path we remove the Z at the end because this is determined by the close option\n    if(chunks[chunks.length - 1][0].toUpperCase() === 'Z') {\n      chunks.pop();\n    }\n\n    // Using svgPathElementDescriptions to map raw path arrays into objects that contain the command and the parameters\n    // For example {command: 'M', x: '10', y: '10'}\n    var elements = chunks.map(function(chunk) {\n        var command = chunk.shift(),\n          description = elementDescriptions[command.toLowerCase()];\n\n        return Chartist.extend({\n          command: command\n        }, description.reduce(function(result, paramName, index) {\n          result[paramName] = +chunk[index];\n          return result;\n        }, {}));\n      });\n\n    // Preparing a splice call with the elements array as var arg params and insert the parsed elements at the current position\n    var spliceArgs = [this.pos, 0];\n    Array.prototype.push.apply(spliceArgs, elements);\n    Array.prototype.splice.apply(this.pathElements, spliceArgs);\n    // Increase the internal position by the element count\n    this.pos += elements.length;\n\n    return this;\n  }\n\n  /**\n   * This function renders to current SVG path object into a final SVG string that can be used in the d attribute of SVG path elements. It uses the accuracy option to round big decimals. If the close parameter was set in the constructor of this path object then a path closing Z will be appended to the output string.\n   *\n   * @memberof Chartist.Svg.Path\n   * @return {String}\n   */\n  function stringify() {\n    var accuracyMultiplier = Math.pow(10, this.options.accuracy);\n\n    return this.pathElements.reduce(function(path, pathElement) {\n        var params = elementDescriptions[pathElement.command.toLowerCase()].map(function(paramName) {\n          return this.options.accuracy ?\n            (Math.round(pathElement[paramName] * accuracyMultiplier) / accuracyMultiplier) :\n            pathElement[paramName];\n        }.bind(this));\n\n        return path + pathElement.command + params.join(',');\n      }.bind(this), '') + (this.close ? 'Z' : '');\n  }\n\n  /**\n   * Scales all elements in the current SVG path object. There is an individual parameter for each coordinate. Scaling will also be done for control points of curves, affecting the given coordinate.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} x The number which will be used to scale the x, x1 and x2 of all path elements.\n   * @param {Number} y The number which will be used to scale the y, y1 and y2 of all path elements.\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function scale(x, y) {\n    forEachParam(this.pathElements, function(pathElement, paramName) {\n      pathElement[paramName] *= paramName[0] === 'x' ? x : y;\n    });\n    return this;\n  }\n\n  /**\n   * Translates all elements in the current SVG path object. The translation is relative and there is an individual parameter for each coordinate. Translation will also be done for control points of curves, affecting the given coordinate.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Number} x The number which will be used to translate the x, x1 and x2 of all path elements.\n   * @param {Number} y The number which will be used to translate the y, y1 and y2 of all path elements.\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function translate(x, y) {\n    forEachParam(this.pathElements, function(pathElement, paramName) {\n      pathElement[paramName] += paramName[0] === 'x' ? x : y;\n    });\n    return this;\n  }\n\n  /**\n   * This function will run over all existing path elements and then loop over their attributes. The callback function will be called for every path element attribute that exists in the current path.\n   * The method signature of the callback function looks like this:\n   * ```javascript\n   * function(pathElement, paramName, pathElementIndex, paramIndex, pathElements)\n   * ```\n   * If something else than undefined is returned by the callback function, this value will be used to replace the old value. This allows you to build custom transformations of path objects that can't be achieved using the basic transformation functions scale and translate.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Function} transformFnc The callback function for the transformation. Check the signature in the function description.\n   * @return {Chartist.Svg.Path} The current path object for easy call chaining.\n   */\n  function transform(transformFnc) {\n    forEachParam(this.pathElements, function(pathElement, paramName, pathElementIndex, paramIndex, pathElements) {\n      var transformed = transformFnc(pathElement, paramName, pathElementIndex, paramIndex, pathElements);\n      if(transformed || transformed === 0) {\n        pathElement[paramName] = transformed;\n      }\n    });\n    return this;\n  }\n\n  /**\n   * This function clones a whole path object with all its properties. This is a deep clone and path element objects will also be cloned.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Boolean} [close] Optional option to set the new cloned path to closed. If not specified or false, the original path close option will be used.\n   * @return {Chartist.Svg.Path}\n   */\n  function clone(close) {\n    var c = new Chartist.Svg.Path(close || this.close);\n    c.pos = this.pos;\n    c.pathElements = this.pathElements.slice().map(function cloneElements(pathElement) {\n      return Chartist.extend({}, pathElement);\n    });\n    c.options = Chartist.extend({}, this.options);\n    return c;\n  }\n\n  /**\n   * Split a Svg.Path object by a specific command in the path chain. The path chain will be split and an array of newly created paths objects will be returned. This is useful if you'd like to split an SVG path by it's move commands, for example, in order to isolate chunks of drawings.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {String} command The command you'd like to use to split the path\n   * @return {Array<Chartist.Svg.Path>}\n   */\n  function splitByCommand(command) {\n    var split = [\n      new Chartist.Svg.Path()\n    ];\n\n    this.pathElements.forEach(function(pathElement) {\n      if(pathElement.command === command.toUpperCase() && split[split.length - 1].pathElements.length !== 0) {\n        split.push(new Chartist.Svg.Path());\n      }\n\n      split[split.length - 1].pathElements.push(pathElement);\n    });\n\n    return split;\n  }\n\n  /**\n   * This static function on `Chartist.Svg.Path` is joining multiple paths together into one paths.\n   *\n   * @memberof Chartist.Svg.Path\n   * @param {Array<Chartist.Svg.Path>} paths A list of paths to be joined together. The order is important.\n   * @param {boolean} close If the newly created path should be a closed path\n   * @param {Object} options Path options for the newly created path.\n   * @return {Chartist.Svg.Path}\n   */\n\n  function join(paths, close, options) {\n    var joinedPath = new Chartist.Svg.Path(close, options);\n    for(var i = 0; i < paths.length; i++) {\n      var path = paths[i];\n      for(var j = 0; j < path.pathElements.length; j++) {\n        joinedPath.pathElements.push(path.pathElements[j]);\n      }\n    }\n    return joinedPath;\n  }\n\n  Chartist.Svg.Path = Chartist.Class.extend({\n    constructor: SvgPath,\n    position: position,\n    remove: remove,\n    move: move,\n    line: line,\n    curve: curve,\n    arc: arc,\n    scale: scale,\n    translate: translate,\n    transform: transform,\n    parse: parse,\n    stringify: stringify,\n    clone: clone,\n    splitByCommand: splitByCommand\n  });\n\n  Chartist.Svg.Path.elementDescriptions = elementDescriptions;\n  Chartist.Svg.Path.join = join;\n}(window, document, Chartist));\n;/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  var axisUnits = {\n    x: {\n      pos: 'x',\n      len: 'width',\n      dir: 'horizontal',\n      rectStart: 'x1',\n      rectEnd: 'x2',\n      rectOffset: 'y2'\n    },\n    y: {\n      pos: 'y',\n      len: 'height',\n      dir: 'vertical',\n      rectStart: 'y2',\n      rectEnd: 'y1',\n      rectOffset: 'x1'\n    }\n  };\n\n  function Axis(units, chartRect, ticks, options) {\n    this.units = units;\n    this.counterUnits = units === axisUnits.x ? axisUnits.y : axisUnits.x;\n    this.chartRect = chartRect;\n    this.axisLength = chartRect[units.rectEnd] - chartRect[units.rectStart];\n    this.gridOffset = chartRect[units.rectOffset];\n    this.ticks = ticks;\n    this.options = options;\n  }\n\n  function createGridAndLabels(gridGroup, labelGroup, useForeignObject, chartOptions, eventEmitter) {\n    var axisOptions = chartOptions['axis' + this.units.pos.toUpperCase()];\n    var projectedValues = this.ticks.map(this.projectValue.bind(this));\n    var labelValues = this.ticks.map(axisOptions.labelInterpolationFnc);\n\n    projectedValues.forEach(function(projectedValue, index) {\n      var labelOffset = {\n        x: 0,\n        y: 0\n      };\n\n      // TODO: Find better solution for solving this problem\n      // Calculate how much space we have available for the label\n      var labelLength;\n      if(projectedValues[index + 1]) {\n        // If we still have one label ahead, we can calculate the distance to the next tick / label\n        labelLength = projectedValues[index + 1] - projectedValue;\n      } else {\n        // If we don't have a label ahead and we have only two labels in total, we just take the remaining distance to\n        // on the whole axis length. We limit that to a minimum of 30 pixel, so that labels close to the border will\n        // still be visible inside of the chart padding.\n        labelLength = Math.max(this.axisLength - projectedValue, 30);\n      }\n\n      // Skip grid lines and labels where interpolated label values are falsey (execpt for 0)\n      if(Chartist.isFalseyButZero(labelValues[index]) && labelValues[index] !== '') {\n        return;\n      }\n\n      // Transform to global coordinates using the chartRect\n      // We also need to set the label offset for the createLabel function\n      if(this.units.pos === 'x') {\n        projectedValue = this.chartRect.x1 + projectedValue;\n        labelOffset.x = chartOptions.axisX.labelOffset.x;\n\n        // If the labels should be positioned in start position (top side for vertical axis) we need to set a\n        // different offset as for positioned with end (bottom)\n        if(chartOptions.axisX.position === 'start') {\n          labelOffset.y = this.chartRect.padding.top + chartOptions.axisX.labelOffset.y + (useForeignObject ? 5 : 20);\n        } else {\n          labelOffset.y = this.chartRect.y1 + chartOptions.axisX.labelOffset.y + (useForeignObject ? 5 : 20);\n        }\n      } else {\n        projectedValue = this.chartRect.y1 - projectedValue;\n        labelOffset.y = chartOptions.axisY.labelOffset.y - (useForeignObject ? labelLength : 0);\n\n        // If the labels should be positioned in start position (left side for horizontal axis) we need to set a\n        // different offset as for positioned with end (right side)\n        if(chartOptions.axisY.position === 'start') {\n          labelOffset.x = useForeignObject ? this.chartRect.padding.left + chartOptions.axisY.labelOffset.x : this.chartRect.x1 - 10;\n        } else {\n          labelOffset.x = this.chartRect.x2 + chartOptions.axisY.labelOffset.x + 10;\n        }\n      }\n\n      if(axisOptions.showGrid) {\n        Chartist.createGrid(projectedValue, index, this, this.gridOffset, this.chartRect[this.counterUnits.len](), gridGroup, [\n          chartOptions.classNames.grid,\n          chartOptions.classNames[this.units.dir]\n        ], eventEmitter);\n      }\n\n      if(axisOptions.showLabel) {\n        Chartist.createLabel(projectedValue, labelLength, index, labelValues, this, axisOptions.offset, labelOffset, labelGroup, [\n          chartOptions.classNames.label,\n          chartOptions.classNames[this.units.dir],\n          chartOptions.classNames[axisOptions.position]\n        ], useForeignObject, eventEmitter);\n      }\n    }.bind(this));\n  }\n\n  Chartist.Axis = Chartist.Class.extend({\n    constructor: Axis,\n    createGridAndLabels: createGridAndLabels,\n    projectValue: function(value, index, data) {\n      throw new Error('Base axis can\\'t be instantiated!');\n    }\n  });\n\n  Chartist.Axis.units = axisUnits;\n\n}(window, document, Chartist));\n;/**\n * The auto scale axis uses standard linear scale projection of values along an axis. It uses order of magnitude to find a scale automatically and evaluates the available space in order to find the perfect amount of ticks for your chart.\n * **Options**\n * The following options are used by this axis in addition to the default axis options outlined in the axis configuration of the chart default settings.\n * ```javascript\n * var options = {\n *   // If high is specified then the axis will display values explicitly up to this value and the computed maximum from the data is ignored\n *   high: 100,\n *   // If low is specified then the axis will display values explicitly down to this value and the computed minimum from the data is ignored\n *   low: 0,\n *   // This option will be used when finding the right scale division settings. The amount of ticks on the scale will be determined so that as many ticks as possible will be displayed, while not violating this minimum required space (in pixel).\n *   scaleMinSpace: 20,\n *   // Can be set to true or false. If set to true, the scale will be generated with whole numbers only.\n *   onlyInteger: true,\n *   // The reference value can be used to make sure that this value will always be on the chart. This is especially useful on bipolar charts where the bipolar center always needs to be part of the chart.\n *   referenceValue: 5\n * };\n * ```\n *\n * @module Chartist.AutoScaleAxis\n */\n/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  function AutoScaleAxis(axisUnit, data, chartRect, options) {\n    // Usually we calculate highLow based on the data but this can be overriden by a highLow object in the options\n    var highLow = options.highLow || Chartist.getHighLow(data.normalized, options, axisUnit.pos);\n    this.bounds = Chartist.getBounds(chartRect[axisUnit.rectEnd] - chartRect[axisUnit.rectStart], highLow, options.scaleMinSpace || 20, options.onlyInteger);\n    this.range = {\n      min: this.bounds.min,\n      max: this.bounds.max\n    };\n\n    Chartist.AutoScaleAxis.super.constructor.call(this,\n      axisUnit,\n      chartRect,\n      this.bounds.values,\n      options);\n  }\n\n  function projectValue(value) {\n    return this.axisLength * (+Chartist.getMultiValue(value, this.units.pos) - this.bounds.min) / this.bounds.range;\n  }\n\n  Chartist.AutoScaleAxis = Chartist.Axis.extend({\n    constructor: AutoScaleAxis,\n    projectValue: projectValue\n  });\n\n}(window, document, Chartist));\n;/**\n * The fixed scale axis uses standard linear projection of values along an axis. It makes use of a divisor option to divide the range provided from the minimum and maximum value or the options high and low that will override the computed minimum and maximum.\n * **Options**\n * The following options are used by this axis in addition to the default axis options outlined in the axis configuration of the chart default settings.\n * ```javascript\n * var options = {\n *   // If high is specified then the axis will display values explicitly up to this value and the computed maximum from the data is ignored\n *   high: 100,\n *   // If low is specified then the axis will display values explicitly down to this value and the computed minimum from the data is ignored\n *   low: 0,\n *   // If specified then the value range determined from minimum to maximum (or low and high) will be divided by this number and ticks will be generated at those division points. The default divisor is 1.\n *   divisor: 4,\n *   // If ticks is explicitly set, then the axis will not compute the ticks with the divisor, but directly use the data in ticks to determine at what points on the axis a tick need to be generated.\n *   ticks: [1, 10, 20, 30]\n * };\n * ```\n *\n * @module Chartist.FixedScaleAxis\n */\n/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  function FixedScaleAxis(axisUnit, data, chartRect, options) {\n    var highLow = options.highLow || Chartist.getHighLow(data.normalized, options, axisUnit.pos);\n    this.divisor = options.divisor || 1;\n    this.ticks = options.ticks || Chartist.times(this.divisor).map(function(value, index) {\n      return highLow.low + (highLow.high - highLow.low) / this.divisor * index;\n    }.bind(this));\n    this.ticks.sort(function(a, b) {\n      return a - b;\n    });\n    this.range = {\n      min: highLow.low,\n      max: highLow.high\n    };\n\n    Chartist.FixedScaleAxis.super.constructor.call(this,\n      axisUnit,\n      chartRect,\n      this.ticks,\n      options);\n\n    this.stepLength = this.axisLength / this.divisor;\n  }\n\n  function projectValue(value) {\n    return this.axisLength * (+Chartist.getMultiValue(value, this.units.pos) - this.range.min) / (this.range.max - this.range.min);\n  }\n\n  Chartist.FixedScaleAxis = Chartist.Axis.extend({\n    constructor: FixedScaleAxis,\n    projectValue: projectValue\n  });\n\n}(window, document, Chartist));\n;/**\n * The step axis for step based charts like bar chart or step based line charts. It uses a fixed amount of ticks that will be equally distributed across the whole axis length. The projection is done using the index of the data value rather than the value itself and therefore it's only useful for distribution purpose.\n * **Options**\n * The following options are used by this axis in addition to the default axis options outlined in the axis configuration of the chart default settings.\n * ```javascript\n * var options = {\n *   // Ticks to be used to distribute across the axis length. As this axis type relies on the index of the value rather than the value, arbitrary data that can be converted to a string can be used as ticks.\n *   ticks: ['One', 'Two', 'Three'],\n *   // If set to true the full width will be used to distribute the values where the last value will be at the maximum of the axis length. If false the spaces between the ticks will be evenly distributed instead.\n *   stretch: true\n * };\n * ```\n *\n * @module Chartist.StepAxis\n */\n/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  function StepAxis(axisUnit, data, chartRect, options) {\n    Chartist.StepAxis.super.constructor.call(this,\n      axisUnit,\n      chartRect,\n      options.ticks,\n      options);\n\n    this.stepLength = this.axisLength / (options.ticks.length - (options.stretch ? 1 : 0));\n  }\n\n  function projectValue(value, index) {\n    return this.stepLength * index;\n  }\n\n  Chartist.StepAxis = Chartist.Axis.extend({\n    constructor: StepAxis,\n    projectValue: projectValue\n  });\n\n}(window, document, Chartist));\n;/**\n * The Chartist line chart can be used to draw Line or Scatter charts. If used in the browser you can access the global `Chartist` namespace where you find the `Line` function as a main entry point.\n *\n * For examples on how to use the line chart please check the examples of the `Chartist.Line` method.\n *\n * @module Chartist.Line\n */\n/* global Chartist */\n(function(window, document, Chartist){\n  'use strict';\n\n  /**\n   * Default options in line charts. Expand the code view to see a detailed list of options with comments.\n   *\n   * @memberof Chartist.Line\n   */\n  var defaultOptions = {\n    // Options for X-Axis\n    axisX: {\n      // The offset of the labels to the chart area\n      offset: 30,\n      // Position where labels are placed. Can be set to `start` or `end` where `start` is equivalent to left or top on vertical axis and `end` is equivalent to right or bottom on horizontal axis.\n      position: 'end',\n      // Allows you to correct label positioning on this axis by positive or negative x and y offset.\n      labelOffset: {\n        x: 0,\n        y: 0\n      },\n      // If labels should be shown or not\n      showLabel: true,\n      // If the axis grid should be drawn or not\n      showGrid: true,\n      // Interpolation function that allows you to intercept the value from the axis label\n      labelInterpolationFnc: Chartist.noop,\n      // Set the axis type to be used to project values on this axis. If not defined, Chartist.StepAxis will be used for the X-Axis, where the ticks option will be set to the labels in the data and the stretch option will be set to the global fullWidth option. This type can be changed to any axis constructor available (e.g. Chartist.FixedScaleAxis), where all axis options should be present here.\n      type: undefined\n    },\n    // Options for Y-Axis\n    axisY: {\n      // The offset of the labels to the chart area\n      offset: 40,\n      // Position where labels are placed. Can be set to `start` or `end` where `start` is equivalent to left or top on vertical axis and `end` is equivalent to right or bottom on horizontal axis.\n      position: 'start',\n      // Allows you to correct label positioning on this axis by positive or negative x and y offset.\n      labelOffset: {\n        x: 0,\n        y: 0\n      },\n      // If labels should be shown or not\n      showLabel: true,\n      // If the axis grid should be drawn or not\n      showGrid: true,\n      // Interpolation function that allows you to intercept the value from the axis label\n      labelInterpolationFnc: Chartist.noop,\n      // Set the axis type to be used to project values on this axis. If not defined, Chartist.AutoScaleAxis will be used for the Y-Axis, where the high and low options will be set to the global high and low options. This type can be changed to any axis constructor available (e.g. Chartist.FixedScaleAxis), where all axis options should be present here.\n      type: undefined,\n      // This value specifies the minimum height in pixel of the scale steps\n      scaleMinSpace: 20,\n      // Use only integer values (whole numbers) for the scale steps\n      onlyInteger: false\n    },\n    // Specify a fixed width for the chart as a string (i.e. '100px' or '50%')\n    width: undefined,\n    // Specify a fixed height for the chart as a string (i.e. '100px' or '50%')\n    height: undefined,\n    // If the line should be drawn or not\n    showLine: true,\n    // If dots should be drawn or not\n    showPoint: true,\n    // If the line chart should draw an area\n    showArea: false,\n    // The base for the area chart that will be used to close the area shape (is normally 0)\n    areaBase: 0,\n    // Specify if the lines should be smoothed. This value can be true or false where true will result in smoothing using the default smoothing interpolation function Chartist.Interpolation.cardinal and false results in Chartist.Interpolation.none. You can also choose other smoothing / interpolation functions available in the Chartist.Interpolation module, or write your own interpolation function. Check the examples for a brief description.\n    lineSmooth: true,\n    // Overriding the natural low of the chart allows you to zoom in or limit the charts lowest displayed value\n    low: undefined,\n    // Overriding the natural high of the chart allows you to zoom in or limit the charts highest displayed value\n    high: undefined,\n    // Padding of the chart drawing area to the container element and labels as a number or padding object {top: 5, right: 5, bottom: 5, left: 5}\n    chartPadding: {\n      top: 15,\n      right: 15,\n      bottom: 5,\n      left: 10\n    },\n    // When set to true, the last grid line on the x-axis is not drawn and the chart elements will expand to the full available width of the chart. For the last label to be drawn correctly you might need to add chart padding or offset the last label with a draw event handler.\n    fullWidth: false,\n    // If true the whole data is reversed including labels, the series order as well as the whole series data arrays.\n    reverseData: false,\n    // Override the class names that get used to generate the SVG structure of the chart\n    classNames: {\n      chart: 'ct-chart-line',\n      label: 'ct-label',\n      labelGroup: 'ct-labels',\n      series: 'ct-series',\n      line: 'ct-line',\n      point: 'ct-point',\n      area: 'ct-area',\n      grid: 'ct-grid',\n      gridGroup: 'ct-grids',\n      vertical: 'ct-vertical',\n      horizontal: 'ct-horizontal',\n      start: 'ct-start',\n      end: 'ct-end'\n    }\n  };\n\n  /**\n   * Creates a new chart\n   *\n   */\n  function createChart(options) {\n    this.data = Chartist.normalizeData(this.data);\n    var data = {\n      raw: this.data,\n      normalized: Chartist.getDataArray(this.data, options.reverseData, true)\n    };\n\n    // Create new svg object\n    this.svg = Chartist.createSvg(this.container, options.width, options.height, options.classNames.chart);\n    // Create groups for labels, grid and series\n    var gridGroup = this.svg.elem('g').addClass(options.classNames.gridGroup);\n    var seriesGroup = this.svg.elem('g');\n    var labelGroup = this.svg.elem('g').addClass(options.classNames.labelGroup);\n\n    var chartRect = Chartist.createChartRect(this.svg, options, defaultOptions.padding);\n    var axisX, axisY;\n\n    if(options.axisX.type === undefined) {\n      axisX = new Chartist.StepAxis(Chartist.Axis.units.x, data, chartRect, Chartist.extend({}, options.axisX, {\n        ticks: data.raw.labels,\n        stretch: options.fullWidth\n      }));\n    } else {\n      axisX = options.axisX.type.call(Chartist, Chartist.Axis.units.x, data, chartRect, options.axisX);\n    }\n\n    if(options.axisY.type === undefined) {\n      axisY = new Chartist.AutoScaleAxis(Chartist.Axis.units.y, data, chartRect, Chartist.extend({}, options.axisY, {\n        high: Chartist.isNum(options.high) ? options.high : options.axisY.high,\n        low: Chartist.isNum(options.low) ? options.low : options.axisY.low\n      }));\n    } else {\n      axisY = options.axisY.type.call(Chartist, Chartist.Axis.units.y, data, chartRect, options.axisY);\n    }\n\n    axisX.createGridAndLabels(gridGroup, labelGroup, this.supportsForeignObject, options, this.eventEmitter);\n    axisY.createGridAndLabels(gridGroup, labelGroup, this.supportsForeignObject, options, this.eventEmitter);\n\n    // Draw the series\n    data.raw.series.forEach(function(series, seriesIndex) {\n      var seriesElement = seriesGroup.elem('g');\n\n      // Write attributes to series group element. If series name or meta is undefined the attributes will not be written\n      seriesElement.attr({\n        'ct:series-name': series.name,\n        'ct:meta': Chartist.serialize(series.meta)\n      });\n\n      // Use series class from series data or if not set generate one\n      seriesElement.addClass([\n        options.classNames.series,\n        (series.className || options.classNames.series + '-' + Chartist.alphaNumerate(seriesIndex))\n      ].join(' '));\n\n      var pathCoordinates = [],\n        pathData = [];\n\n      data.normalized[seriesIndex].forEach(function(value, valueIndex) {\n        var p = {\n          x: chartRect.x1 + axisX.projectValue(value, valueIndex, data.normalized[seriesIndex]),\n          y: chartRect.y1 - axisY.projectValue(value, valueIndex, data.normalized[seriesIndex])\n        };\n        pathCoordinates.push(p.x, p.y);\n        pathData.push({\n          value: value,\n          valueIndex: valueIndex,\n          meta: Chartist.getMetaData(series, valueIndex)\n        });\n      }.bind(this));\n\n      var seriesOptions = {\n        lineSmooth: Chartist.getSeriesOption(series, options, 'lineSmooth'),\n        showPoint: Chartist.getSeriesOption(series, options, 'showPoint'),\n        showLine: Chartist.getSeriesOption(series, options, 'showLine'),\n        showArea: Chartist.getSeriesOption(series, options, 'showArea'),\n        areaBase: Chartist.getSeriesOption(series, options, 'areaBase')\n      };\n\n      var smoothing = typeof seriesOptions.lineSmooth === 'function' ?\n        seriesOptions.lineSmooth : (seriesOptions.lineSmooth ? Chartist.Interpolation.cardinal() : Chartist.Interpolation.none());\n      // Interpolating path where pathData will be used to annotate each path element so we can trace back the original\n      // index, value and meta data\n      var path = smoothing(pathCoordinates, pathData);\n\n      // If we should show points we need to create them now to avoid secondary loop\n      // Points are drawn from the pathElements returned by the interpolation function\n      // Small offset for Firefox to render squares correctly\n      if (seriesOptions.showPoint) {\n\n        path.pathElements.forEach(function(pathElement) {\n          var point = seriesElement.elem('line', {\n            x1: pathElement.x,\n            y1: pathElement.y,\n            x2: pathElement.x + 0.01,\n            y2: pathElement.y\n          }, options.classNames.point).attr({\n            'ct:value': [pathElement.data.value.x, pathElement.data.value.y].filter(Chartist.isNum).join(','),\n            'ct:meta': pathElement.data.meta\n          });\n\n          this.eventEmitter.emit('draw', {\n            type: 'point',\n            value: pathElement.data.value,\n            index: pathElement.data.valueIndex,\n            meta: pathElement.data.meta,\n            series: series,\n            seriesIndex: seriesIndex,\n            axisX: axisX,\n            axisY: axisY,\n            group: seriesElement,\n            element: point,\n            x: pathElement.x,\n            y: pathElement.y\n          });\n        }.bind(this));\n      }\n\n      if(seriesOptions.showLine) {\n        var line = seriesElement.elem('path', {\n          d: path.stringify()\n        }, options.classNames.line, true);\n\n        this.eventEmitter.emit('draw', {\n          type: 'line',\n          values: data.normalized[seriesIndex],\n          path: path.clone(),\n          chartRect: chartRect,\n          index: seriesIndex,\n          series: series,\n          seriesIndex: seriesIndex,\n          axisX: axisX,\n          axisY: axisY,\n          group: seriesElement,\n          element: line\n        });\n      }\n\n      // Area currently only works with axes that support a range!\n      if(seriesOptions.showArea && axisY.range) {\n        // If areaBase is outside the chart area (< min or > max) we need to set it respectively so that\n        // the area is not drawn outside the chart area.\n        var areaBase = Math.max(Math.min(seriesOptions.areaBase, axisY.range.max), axisY.range.min);\n\n        // We project the areaBase value into screen coordinates\n        var areaBaseProjected = chartRect.y1 - axisY.projectValue(areaBase);\n\n        // In order to form the area we'll first split the path by move commands so we can chunk it up into segments\n        path.splitByCommand('M').filter(function onlySolidSegments(pathSegment) {\n          // We filter only \"solid\" segments that contain more than one point. Otherwise there's no need for an area\n          return pathSegment.pathElements.length > 1;\n        }).map(function convertToArea(solidPathSegments) {\n          // Receiving the filtered solid path segments we can now convert those segments into fill areas\n          var firstElement = solidPathSegments.pathElements[0];\n          var lastElement = solidPathSegments.pathElements[solidPathSegments.pathElements.length - 1];\n\n          // Cloning the solid path segment with closing option and removing the first move command from the clone\n          // We then insert a new move that should start at the area base and draw a straight line up or down\n          // at the end of the path we add an additional straight line to the projected area base value\n          // As the closing option is set our path will be automatically closed\n          return solidPathSegments.clone(true)\n            .position(0)\n            .remove(1)\n            .move(firstElement.x, areaBaseProjected)\n            .line(firstElement.x, firstElement.y)\n            .position(solidPathSegments.pathElements.length + 1)\n            .line(lastElement.x, areaBaseProjected);\n\n        }).forEach(function createArea(areaPath) {\n          // For each of our newly created area paths, we'll now create path elements by stringifying our path objects\n          // and adding the created DOM elements to the correct series group\n          var area = seriesElement.elem('path', {\n            d: areaPath.stringify()\n          }, options.classNames.area, true);\n\n          // Emit an event for each area that was drawn\n          this.eventEmitter.emit('draw', {\n            type: 'area',\n            values: data.normalized[seriesIndex],\n            path: areaPath.clone(),\n            series: series,\n            seriesIndex: seriesIndex,\n            axisX: axisX,\n            axisY: axisY,\n            chartRect: chartRect,\n            index: seriesIndex,\n            group: seriesElement,\n            element: area\n          });\n        }.bind(this));\n      }\n    }.bind(this));\n\n    this.eventEmitter.emit('created', {\n      bounds: axisY.bounds,\n      chartRect: chartRect,\n      axisX: axisX,\n      axisY: axisY,\n      svg: this.svg,\n      options: options\n    });\n  }\n\n  /**\n   * This method creates a new line chart.\n   *\n   * @memberof Chartist.Line\n   * @param {String|Node} query A selector query string or directly a DOM element\n   * @param {Object} data The data object that needs to consist of a labels and a series array\n   * @param {Object} [options] The options object with options that override the default options. Check the examples for a detailed list.\n   * @param {Array} [responsiveOptions] Specify an array of responsive option arrays which are a media query and options object pair => [[mediaQueryString, optionsObject],[more...]]\n   * @return {Object} An object which exposes the API for the created chart\n   *\n   * @example\n   * // Create a simple line chart\n   * var data = {\n   *   // A labels array that can contain any sort of values\n   *   labels: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri'],\n   *   // Our series array that contains series objects or in this case series data arrays\n   *   series: [\n   *     [5, 2, 4, 2, 0]\n   *   ]\n   * };\n   *\n   * // As options we currently only set a static size of 300x200 px\n   * var options = {\n   *   width: '300px',\n   *   height: '200px'\n   * };\n   *\n   * // In the global name space Chartist we call the Line function to initialize a line chart. As a first parameter we pass in a selector where we would like to get our chart created. Second parameter is the actual data object and as a third parameter we pass in our options\n   * new Chartist.Line('.ct-chart', data, options);\n   *\n   * @example\n   * // Use specific interpolation function with configuration from the Chartist.Interpolation module\n   *\n   * var chart = new Chartist.Line('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5],\n   *   series: [\n   *     [1, 1, 8, 1, 7]\n   *   ]\n   * }, {\n   *   lineSmooth: Chartist.Interpolation.cardinal({\n   *     tension: 0.2\n   *   })\n   * });\n   *\n   * @example\n   * // Create a line chart with responsive options\n   *\n   * var data = {\n   *   // A labels array that can contain any sort of values\n   *   labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'],\n   *   // Our series array that contains series objects or in this case series data arrays\n   *   series: [\n   *     [5, 2, 4, 2, 0]\n   *   ]\n   * };\n   *\n   * // In addition to the regular options we specify responsive option overrides that will override the default configutation based on the matching media queries.\n   * var responsiveOptions = [\n   *   ['screen and (min-width: 641px) and (max-width: 1024px)', {\n   *     showPoint: false,\n   *     axisX: {\n   *       labelInterpolationFnc: function(value) {\n   *         // Will return Mon, Tue, Wed etc. on medium screens\n   *         return value.slice(0, 3);\n   *       }\n   *     }\n   *   }],\n   *   ['screen and (max-width: 640px)', {\n   *     showLine: false,\n   *     axisX: {\n   *       labelInterpolationFnc: function(value) {\n   *         // Will return M, T, W etc. on small screens\n   *         return value[0];\n   *       }\n   *     }\n   *   }]\n   * ];\n   *\n   * new Chartist.Line('.ct-chart', data, null, responsiveOptions);\n   *\n   */\n  function Line(query, data, options, responsiveOptions) {\n    Chartist.Line.super.constructor.call(this,\n      query,\n      data,\n      defaultOptions,\n      Chartist.extend({}, defaultOptions, options),\n      responsiveOptions);\n  }\n\n  // Creating line chart type in Chartist namespace\n  Chartist.Line = Chartist.Base.extend({\n    constructor: Line,\n    createChart: createChart\n  });\n\n}(window, document, Chartist));\n;/**\n * The bar chart module of Chartist that can be used to draw unipolar or bipolar bar and grouped bar charts.\n *\n * @module Chartist.Bar\n */\n/* global Chartist */\n(function(window, document, Chartist){\n  'use strict';\n\n  /**\n   * Default options in bar charts. Expand the code view to see a detailed list of options with comments.\n   *\n   * @memberof Chartist.Bar\n   */\n  var defaultOptions = {\n    // Options for X-Axis\n    axisX: {\n      // The offset of the chart drawing area to the border of the container\n      offset: 30,\n      // Position where labels are placed. Can be set to `start` or `end` where `start` is equivalent to left or top on vertical axis and `end` is equivalent to right or bottom on horizontal axis.\n      position: 'end',\n      // Allows you to correct label positioning on this axis by positive or negative x and y offset.\n      labelOffset: {\n        x: 0,\n        y: 0\n      },\n      // If labels should be shown or not\n      showLabel: true,\n      // If the axis grid should be drawn or not\n      showGrid: true,\n      // Interpolation function that allows you to intercept the value from the axis label\n      labelInterpolationFnc: Chartist.noop,\n      // This value specifies the minimum width in pixel of the scale steps\n      scaleMinSpace: 30,\n      // Use only integer values (whole numbers) for the scale steps\n      onlyInteger: false\n    },\n    // Options for Y-Axis\n    axisY: {\n      // The offset of the chart drawing area to the border of the container\n      offset: 40,\n      // Position where labels are placed. Can be set to `start` or `end` where `start` is equivalent to left or top on vertical axis and `end` is equivalent to right or bottom on horizontal axis.\n      position: 'start',\n      // Allows you to correct label positioning on this axis by positive or negative x and y offset.\n      labelOffset: {\n        x: 0,\n        y: 0\n      },\n      // If labels should be shown or not\n      showLabel: true,\n      // If the axis grid should be drawn or not\n      showGrid: true,\n      // Interpolation function that allows you to intercept the value from the axis label\n      labelInterpolationFnc: Chartist.noop,\n      // This value specifies the minimum height in pixel of the scale steps\n      scaleMinSpace: 20,\n      // Use only integer values (whole numbers) for the scale steps\n      onlyInteger: false\n    },\n    // Specify a fixed width for the chart as a string (i.e. '100px' or '50%')\n    width: undefined,\n    // Specify a fixed height for the chart as a string (i.e. '100px' or '50%')\n    height: undefined,\n    // Overriding the natural high of the chart allows you to zoom in or limit the charts highest displayed value\n    high: undefined,\n    // Overriding the natural low of the chart allows you to zoom in or limit the charts lowest displayed value\n    low: undefined,\n    // Padding of the chart drawing area to the container element and labels as a number or padding object {top: 5, right: 5, bottom: 5, left: 5}\n    chartPadding: {\n      top: 15,\n      right: 15,\n      bottom: 5,\n      left: 10\n    },\n    // Specify the distance in pixel of bars in a group\n    seriesBarDistance: 15,\n    // If set to true this property will cause the series bars to be stacked. Check the `stackMode` option for further stacking options.\n    stackBars: false,\n    // If set to 'overlap' this property will force the stacked bars to draw from the zero line.\n    // If set to 'accumulate' this property will form a total for each series point. This will also influence the y-axis and the overall bounds of the chart. In stacked mode the seriesBarDistance property will have no effect.\n    stackMode: 'accumulate',\n    // Inverts the axes of the bar chart in order to draw a horizontal bar chart. Be aware that you also need to invert your axis settings as the Y Axis will now display the labels and the X Axis the values.\n    horizontalBars: false,\n    // If set to true then each bar will represent a series and the data array is expected to be a one dimensional array of data values rather than a series array of series. This is useful if the bar chart should represent a profile rather than some data over time.\n    distributeSeries: false,\n    // If true the whole data is reversed including labels, the series order as well as the whole series data arrays.\n    reverseData: false,\n    // Override the class names that get used to generate the SVG structure of the chart\n    classNames: {\n      chart: 'ct-chart-bar',\n      horizontalBars: 'ct-horizontal-bars',\n      label: 'ct-label',\n      labelGroup: 'ct-labels',\n      series: 'ct-series',\n      bar: 'ct-bar',\n      grid: 'ct-grid',\n      gridGroup: 'ct-grids',\n      vertical: 'ct-vertical',\n      horizontal: 'ct-horizontal',\n      start: 'ct-start',\n      end: 'ct-end'\n    }\n  };\n\n  /**\n   * Creates a new chart\n   *\n   */\n  function createChart(options) {\n    this.data = Chartist.normalizeData(this.data);\n    var data = {\n      raw: this.data,\n      normalized: options.distributeSeries ? Chartist.getDataArray(this.data, options.reverseData, options.horizontalBars ? 'x' : 'y').map(function(value) {\n        return [value];\n      }) : Chartist.getDataArray(this.data, options.reverseData, options.horizontalBars ? 'x' : 'y')\n    };\n\n    var highLow;\n\n    // Create new svg element\n    this.svg = Chartist.createSvg(\n      this.container,\n      options.width,\n      options.height,\n      options.classNames.chart + (options.horizontalBars ? ' ' + options.classNames.horizontalBars : '')\n    );\n\n    // Drawing groups in correct order\n    var gridGroup = this.svg.elem('g').addClass(options.classNames.gridGroup);\n    var seriesGroup = this.svg.elem('g');\n    var labelGroup = this.svg.elem('g').addClass(options.classNames.labelGroup);\n\n    if(options.stackBars && data.normalized.length !== 0) {\n      // If stacked bars we need to calculate the high low from stacked values from each series\n      var serialSums = Chartist.serialMap(data.normalized, function serialSums() {\n        return Array.prototype.slice.call(arguments).map(function(value) {\n          return value;\n        }).reduce(function(prev, curr) {\n          return {\n            x: prev.x + (curr && curr.x) || 0,\n            y: prev.y + (curr && curr.y) || 0\n          };\n        }, {x: 0, y: 0});\n      });\n\n      highLow = Chartist.getHighLow([serialSums], Chartist.extend({}, options, {\n        referenceValue: 0\n      }), options.horizontalBars ? 'x' : 'y');\n    } else {\n      highLow = Chartist.getHighLow(data.normalized, Chartist.extend({}, options, {\n        referenceValue: 0\n      }), options.horizontalBars ? 'x' : 'y');\n    }\n    // Overrides of high / low from settings\n    highLow.high = +options.high || (options.high === 0 ? 0 : highLow.high);\n    highLow.low = +options.low || (options.low === 0 ? 0 : highLow.low);\n\n    var chartRect = Chartist.createChartRect(this.svg, options, defaultOptions.padding);\n\n    var valueAxis,\n      labelAxisTicks,\n      labelAxis,\n      axisX,\n      axisY;\n\n    // We need to set step count based on some options combinations\n    if(options.distributeSeries && options.stackBars) {\n      // If distributed series are enabled and bars need to be stacked, we'll only have one bar and therefore should\n      // use only the first label for the step axis\n      labelAxisTicks = data.raw.labels.slice(0, 1);\n    } else {\n      // If distributed series are enabled but stacked bars aren't, we should use the series labels\n      // If we are drawing a regular bar chart with two dimensional series data, we just use the labels array\n      // as the bars are normalized\n      labelAxisTicks = data.raw.labels;\n    }\n\n    // Set labelAxis and valueAxis based on the horizontalBars setting. This setting will flip the axes if necessary.\n    if(options.horizontalBars) {\n      if(options.axisX.type === undefined) {\n        valueAxis = axisX = new Chartist.AutoScaleAxis(Chartist.Axis.units.x, data, chartRect, Chartist.extend({}, options.axisX, {\n          highLow: highLow,\n          referenceValue: 0\n        }));\n      } else {\n        valueAxis = axisX = options.axisX.type.call(Chartist, Chartist.Axis.units.x, data, chartRect, Chartist.extend({}, options.axisX, {\n          highLow: highLow,\n          referenceValue: 0\n        }));\n      }\n\n      if(options.axisY.type === undefined) {\n        labelAxis = axisY = new Chartist.StepAxis(Chartist.Axis.units.y, data, chartRect, {\n          ticks: labelAxisTicks\n        });\n      } else {\n        labelAxis = axisY = options.axisY.type.call(Chartist, Chartist.Axis.units.y, data, chartRect, options.axisY);\n      }\n    } else {\n      if(options.axisX.type === undefined) {\n        labelAxis = axisX = new Chartist.StepAxis(Chartist.Axis.units.x, data, chartRect, {\n          ticks: labelAxisTicks\n        });\n      } else {\n        labelAxis = axisX = options.axisX.type.call(Chartist, Chartist.Axis.units.x, data, chartRect, options.axisX);\n      }\n\n      if(options.axisY.type === undefined) {\n        valueAxis = axisY = new Chartist.AutoScaleAxis(Chartist.Axis.units.y, data, chartRect, Chartist.extend({}, options.axisY, {\n          highLow: highLow,\n          referenceValue: 0\n        }));\n      } else {\n        valueAxis = axisY = options.axisY.type.call(Chartist, Chartist.Axis.units.y, data, chartRect, Chartist.extend({}, options.axisY, {\n          highLow: highLow,\n          referenceValue: 0\n        }));\n      }\n    }\n\n    // Projected 0 point\n    var zeroPoint = options.horizontalBars ? (chartRect.x1 + valueAxis.projectValue(0)) : (chartRect.y1 - valueAxis.projectValue(0));\n    // Used to track the screen coordinates of stacked bars\n    var stackedBarValues = [];\n\n    labelAxis.createGridAndLabels(gridGroup, labelGroup, this.supportsForeignObject, options, this.eventEmitter);\n    valueAxis.createGridAndLabels(gridGroup, labelGroup, this.supportsForeignObject, options, this.eventEmitter);\n\n    // Draw the series\n    data.raw.series.forEach(function(series, seriesIndex) {\n      // Calculating bi-polar value of index for seriesOffset. For i = 0..4 biPol will be -1.5, -0.5, 0.5, 1.5 etc.\n      var biPol = seriesIndex - (data.raw.series.length - 1) / 2;\n      // Half of the period width between vertical grid lines used to position bars\n      var periodHalfLength;\n      // Current series SVG element\n      var seriesElement;\n\n      // We need to set periodHalfLength based on some options combinations\n      if(options.distributeSeries && !options.stackBars) {\n        // If distributed series are enabled but stacked bars aren't, we need to use the length of the normaizedData array\n        // which is the series count and divide by 2\n        periodHalfLength = labelAxis.axisLength / data.normalized.length / 2;\n      } else if(options.distributeSeries && options.stackBars) {\n        // If distributed series and stacked bars are enabled we'll only get one bar so we should just divide the axis\n        // length by 2\n        periodHalfLength = labelAxis.axisLength / 2;\n      } else {\n        // On regular bar charts we should just use the series length\n        periodHalfLength = labelAxis.axisLength / data.normalized[seriesIndex].length / 2;\n      }\n\n      // Adding the series group to the series element\n      seriesElement = seriesGroup.elem('g');\n\n      // Write attributes to series group element. If series name or meta is undefined the attributes will not be written\n      seriesElement.attr({\n        'ct:series-name': series.name,\n        'ct:meta': Chartist.serialize(series.meta)\n      });\n\n      // Use series class from series data or if not set generate one\n      seriesElement.addClass([\n        options.classNames.series,\n        (series.className || options.classNames.series + '-' + Chartist.alphaNumerate(seriesIndex))\n      ].join(' '));\n\n      data.normalized[seriesIndex].forEach(function(value, valueIndex) {\n        var projected,\n          bar,\n          previousStack,\n          labelAxisValueIndex;\n\n        // We need to set labelAxisValueIndex based on some options combinations\n        if(options.distributeSeries && !options.stackBars) {\n          // If distributed series are enabled but stacked bars aren't, we can use the seriesIndex for later projection\n          // on the step axis for label positioning\n          labelAxisValueIndex = seriesIndex;\n        } else if(options.distributeSeries && options.stackBars) {\n          // If distributed series and stacked bars are enabled, we will only get one bar and therefore always use\n          // 0 for projection on the label step axis\n          labelAxisValueIndex = 0;\n        } else {\n          // On regular bar charts we just use the value index to project on the label step axis\n          labelAxisValueIndex = valueIndex;\n        }\n\n        // We need to transform coordinates differently based on the chart layout\n        if(options.horizontalBars) {\n          projected = {\n            x: chartRect.x1 + valueAxis.projectValue(value && value.x ? value.x : 0, valueIndex, data.normalized[seriesIndex]),\n            y: chartRect.y1 - labelAxis.projectValue(value && value.y ? value.y : 0, labelAxisValueIndex, data.normalized[seriesIndex])\n          };\n        } else {\n          projected = {\n            x: chartRect.x1 + labelAxis.projectValue(value && value.x ? value.x : 0, labelAxisValueIndex, data.normalized[seriesIndex]),\n            y: chartRect.y1 - valueAxis.projectValue(value && value.y ? value.y : 0, valueIndex, data.normalized[seriesIndex])\n          }\n        }\n\n        // If the label axis is a step based axis we will offset the bar into the middle of between two steps using\n        // the periodHalfLength value. Also we do arrange the different series so that they align up to each other using\n        // the seriesBarDistance. If we don't have a step axis, the bar positions can be chosen freely so we should not\n        // add any automated positioning.\n        if(labelAxis instanceof Chartist.StepAxis) {\n          // Offset to center bar between grid lines, but only if the step axis is not stretched\n          if(!labelAxis.options.stretch) {\n            projected[labelAxis.units.pos] += periodHalfLength * (options.horizontalBars ? -1 : 1);\n          }\n          // Using bi-polar offset for multiple series if no stacked bars or series distribution is used\n          projected[labelAxis.units.pos] += (options.stackBars || options.distributeSeries) ? 0 : biPol * options.seriesBarDistance * (options.horizontalBars ? -1 : 1);\n        }\n\n        // Enter value in stacked bar values used to remember previous screen value for stacking up bars\n        previousStack = stackedBarValues[valueIndex] || zeroPoint;\n        stackedBarValues[valueIndex] = previousStack - (zeroPoint - projected[labelAxis.counterUnits.pos]);\n\n        // Skip if value is undefined\n        if(value === undefined) {\n          return;\n        }\n\n        var positions = {};\n        positions[labelAxis.units.pos + '1'] = projected[labelAxis.units.pos];\n        positions[labelAxis.units.pos + '2'] = projected[labelAxis.units.pos];\n\n        if(options.stackBars && (options.stackMode === 'accumulate' || !options.stackMode)) {\n          // Stack mode: accumulate (default)\n          // If bars are stacked we use the stackedBarValues reference and otherwise base all bars off the zero line\n          // We want backwards compatibility, so the expected fallback without the 'stackMode' option\n          // to be the original behaviour (accumulate)\n          positions[labelAxis.counterUnits.pos + '1'] = previousStack;\n          positions[labelAxis.counterUnits.pos + '2'] = stackedBarValues[valueIndex];\n        } else {\n          // Draw from the zero line normally\n          // This is also the same code for Stack mode: overlap\n          positions[labelAxis.counterUnits.pos + '1'] = zeroPoint;\n          positions[labelAxis.counterUnits.pos + '2'] = projected[labelAxis.counterUnits.pos];\n        }\n\n        // Limit x and y so that they are within the chart rect\n        positions.x1 = Math.min(Math.max(positions.x1, chartRect.x1), chartRect.x2);\n        positions.x2 = Math.min(Math.max(positions.x2, chartRect.x1), chartRect.x2);\n        positions.y1 = Math.min(Math.max(positions.y1, chartRect.y2), chartRect.y1);\n        positions.y2 = Math.min(Math.max(positions.y2, chartRect.y2), chartRect.y1);\n\n        // Create bar element\n        bar = seriesElement.elem('line', positions, options.classNames.bar).attr({\n          'ct:value': [value.x, value.y].filter(Chartist.isNum).join(','),\n          'ct:meta': Chartist.getMetaData(series, valueIndex)\n        });\n\n        this.eventEmitter.emit('draw', Chartist.extend({\n          type: 'bar',\n          value: value,\n          index: valueIndex,\n          meta: Chartist.getMetaData(series, valueIndex),\n          series: series,\n          seriesIndex: seriesIndex,\n          axisX: axisX,\n          axisY: axisY,\n          chartRect: chartRect,\n          group: seriesElement,\n          element: bar\n        }, positions));\n      }.bind(this));\n    }.bind(this));\n\n    this.eventEmitter.emit('created', {\n      bounds: valueAxis.bounds,\n      chartRect: chartRect,\n      axisX: axisX,\n      axisY: axisY,\n      svg: this.svg,\n      options: options\n    });\n  }\n\n  /**\n   * This method creates a new bar chart and returns API object that you can use for later changes.\n   *\n   * @memberof Chartist.Bar\n   * @param {String|Node} query A selector query string or directly a DOM element\n   * @param {Object} data The data object that needs to consist of a labels and a series array\n   * @param {Object} [options] The options object with options that override the default options. Check the examples for a detailed list.\n   * @param {Array} [responsiveOptions] Specify an array of responsive option arrays which are a media query and options object pair => [[mediaQueryString, optionsObject],[more...]]\n   * @return {Object} An object which exposes the API for the created chart\n   *\n   * @example\n   * // Create a simple bar chart\n   * var data = {\n   *   labels: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri'],\n   *   series: [\n   *     [5, 2, 4, 2, 0]\n   *   ]\n   * };\n   *\n   * // In the global name space Chartist we call the Bar function to initialize a bar chart. As a first parameter we pass in a selector where we would like to get our chart created and as a second parameter we pass our data object.\n   * new Chartist.Bar('.ct-chart', data);\n   *\n   * @example\n   * // This example creates a bipolar grouped bar chart where the boundaries are limitted to -10 and 10\n   * new Chartist.Bar('.ct-chart', {\n   *   labels: [1, 2, 3, 4, 5, 6, 7],\n   *   series: [\n   *     [1, 3, 2, -5, -3, 1, -6],\n   *     [-5, -2, -4, -1, 2, -3, 1]\n   *   ]\n   * }, {\n   *   seriesBarDistance: 12,\n   *   low: -10,\n   *   high: 10\n   * });\n   *\n   */\n  function Bar(query, data, options, responsiveOptions) {\n    Chartist.Bar.super.constructor.call(this,\n      query,\n      data,\n      defaultOptions,\n      Chartist.extend({}, defaultOptions, options),\n      responsiveOptions);\n  }\n\n  // Creating bar chart type in Chartist namespace\n  Chartist.Bar = Chartist.Base.extend({\n    constructor: Bar,\n    createChart: createChart\n  });\n\n}(window, document, Chartist));\n;/**\n * The pie chart module of Chartist that can be used to draw pie, donut or gauge charts\n *\n * @module Chartist.Pie\n */\n/* global Chartist */\n(function(window, document, Chartist) {\n  'use strict';\n\n  /**\n   * Default options in line charts. Expand the code view to see a detailed list of options with comments.\n   *\n   * @memberof Chartist.Pie\n   */\n  var defaultOptions = {\n    // Specify a fixed width for the chart as a string (i.e. '100px' or '50%')\n    width: undefined,\n    // Specify a fixed height for the chart as a string (i.e. '100px' or '50%')\n    height: undefined,\n    // Padding of the chart drawing area to the container element and labels as a number or padding object {top: 5, right: 5, bottom: 5, left: 5}\n    chartPadding: 5,\n    // Override the class names that are used to generate the SVG structure of the chart\n    classNames: {\n      chartPie: 'ct-chart-pie',\n      chartDonut: 'ct-chart-donut',\n      series: 'ct-series',\n      slicePie: 'ct-slice-pie',\n      sliceDonut: 'ct-slice-donut',\n      label: 'ct-label'\n    },\n    // The start angle of the pie chart in degrees where 0 points north. A higher value offsets the start angle clockwise.\n    startAngle: 0,\n    // An optional total you can specify. By specifying a total value, the sum of the values in the series must be this total in order to draw a full pie. You can use this parameter to draw only parts of a pie or gauge charts.\n    total: undefined,\n    // If specified the donut CSS classes will be used and strokes will be drawn instead of pie slices.\n    donut: false,\n    // Specify the donut stroke width, currently done in javascript for convenience. May move to CSS styles in the future.\n    // This option can be set as number or string to specify a relative width (i.e. 100 or '30%').\n    donutWidth: 60,\n    // If a label should be shown or not\n    showLabel: true,\n    // Label position offset from the standard position which is half distance of the radius. This value can be either positive or negative. Positive values will position the label away from the center.\n    labelOffset: 0,\n    // This option can be set to 'inside', 'outside' or 'center'. Positioned with 'inside' the labels will be placed on half the distance of the radius to the border of the Pie by respecting the 'labelOffset'. The 'outside' option will place the labels at the border of the pie and 'center' will place the labels in the absolute center point of the chart. The 'center' option only makes sense in conjunction with the 'labelOffset' option.\n    labelPosition: 'inside',\n    // An interpolation function for the label value\n    labelInterpolationFnc: Chartist.noop,\n    // Label direction can be 'neutral', 'explode' or 'implode'. The labels anchor will be positioned based on those settings as well as the fact if the labels are on the right or left side of the center of the chart. Usually explode is useful when labels are positioned far away from the center.\n    labelDirection: 'neutral',\n    // If true the whole data is reversed including labels, the series order as well as the whole series data arrays.\n    reverseData: false,\n    // If true empty values will be ignored to avoid drawing unncessary slices and labels\n    ignoreEmptyValues: false\n  };\n\n  /**\n   * Determines SVG anchor position based on direction and center parameter\n   *\n   * @param center\n   * @param label\n   * @param direction\n   * @return {string}\n   */\n  function determineAnchorPosition(center, label, direction) {\n    var toTheRight = label.x > center.x;\n\n    if(toTheRight && direction === 'explode' ||\n      !toTheRight && direction === 'implode') {\n      return 'start';\n    } else if(toTheRight && direction === 'implode' ||\n      !toTheRight && direction === 'explode') {\n      return 'end';\n    } else {\n      return 'middle';\n    }\n  }\n\n  /**\n   * Creates the pie chart\n   *\n   * @param options\n   */\n  function createChart(options) {\n    this.data = Chartist.normalizeData(this.data);\n    var seriesGroups = [],\n      labelsGroup,\n      chartRect,\n      radius,\n      labelRadius,\n      totalDataSum,\n      startAngle = options.startAngle,\n      dataArray = Chartist.getDataArray(this.data, options.reverseData);\n\n    // Create SVG.js draw\n    this.svg = Chartist.createSvg(this.container, options.width, options.height,options.donut ? options.classNames.chartDonut : options.classNames.chartPie);\n    // Calculate charting rect\n    chartRect = Chartist.createChartRect(this.svg, options, defaultOptions.padding);\n    // Get biggest circle radius possible within chartRect\n    radius = Math.min(chartRect.width() / 2, chartRect.height() / 2);\n    // Calculate total of all series to get reference value or use total reference from optional options\n    totalDataSum = options.total || dataArray.reduce(function(previousValue, currentValue) {\n      return previousValue + currentValue;\n    }, 0);\n\n    var donutWidth = Chartist.quantity(options.donutWidth);\n    if (donutWidth.unit === '%') {\n      donutWidth.value *= radius / 100;\n    }\n\n    // If this is a donut chart we need to adjust our radius to enable strokes to be drawn inside\n    // Unfortunately this is not possible with the current SVG Spec\n    // See this proposal for more details: http://lists.w3.org/Archives/Public/www-svg/2003Oct/0000.html\n    radius -= options.donut ? donutWidth.value / 2  : 0;\n\n    // If labelPosition is set to `outside` or a donut chart is drawn then the label position is at the radius,\n    // if regular pie chart it's half of the radius\n    if(options.labelPosition === 'outside' || options.donut) {\n      labelRadius = radius;\n    } else if(options.labelPosition === 'center') {\n      // If labelPosition is center we start with 0 and will later wait for the labelOffset\n      labelRadius = 0;\n    } else {\n      // Default option is 'inside' where we use half the radius so the label will be placed in the center of the pie\n      // slice\n      labelRadius = radius / 2;\n    }\n    // Add the offset to the labelRadius where a negative offset means closed to the center of the chart\n    labelRadius += options.labelOffset;\n\n    // Calculate end angle based on total sum and current data value and offset with padding\n    var center = {\n      x: chartRect.x1 + chartRect.width() / 2,\n      y: chartRect.y2 + chartRect.height() / 2\n    };\n\n    // Check if there is only one non-zero value in the series array.\n    var hasSingleValInSeries = this.data.series.filter(function(val) {\n      return val.hasOwnProperty('value') ? val.value !== 0 : val !== 0;\n    }).length === 1;\n\n    //if we need to show labels we create the label group now\n    if(options.showLabel) {\n      labelsGroup = this.svg.elem('g', null, null, true);\n    }\n\n    // Draw the series\n    // initialize series groups\n    for (var i = 0; i < this.data.series.length; i++) {\n      // If current value is zero and we are ignoring empty values then skip to next value\n      if (dataArray[i] === 0 && options.ignoreEmptyValues) continue;\n\n      var series = this.data.series[i];\n      seriesGroups[i] = this.svg.elem('g', null, null, true);\n\n      // If the series is an object and contains a name or meta data we add a custom attribute\n      seriesGroups[i].attr({\n        'ct:series-name': series.name\n      });\n\n      // Use series class from series data or if not set generate one\n      seriesGroups[i].addClass([\n        options.classNames.series,\n        (series.className || options.classNames.series + '-' + Chartist.alphaNumerate(i))\n      ].join(' '));\n\n      var endAngle = startAngle + dataArray[i] / totalDataSum * 360;\n\n      // Use slight offset so there are no transparent hairline issues\n      var overlappigStartAngle = Math.max(0, startAngle - (i === 0 || hasSingleValInSeries ? 0 : 0.2));\n\n      // If we need to draw the arc for all 360 degrees we need to add a hack where we close the circle\n      // with Z and use 359.99 degrees\n      if(endAngle - overlappigStartAngle >= 359.99) {\n        endAngle = overlappigStartAngle + 359.99;\n      }\n\n      var start = Chartist.polarToCartesian(center.x, center.y, radius, overlappigStartAngle),\n        end = Chartist.polarToCartesian(center.x, center.y, radius, endAngle);\n\n      // Create a new path element for the pie chart. If this isn't a donut chart we should close the path for a correct stroke\n      var path = new Chartist.Svg.Path(!options.donut)\n        .move(end.x, end.y)\n        .arc(radius, radius, 0, endAngle - startAngle > 180, 0, start.x, start.y);\n\n      // If regular pie chart (no donut) we add a line to the center of the circle for completing the pie\n      if(!options.donut) {\n        path.line(center.x, center.y);\n      }\n\n      // Create the SVG path\n      // If this is a donut chart we add the donut class, otherwise just a regular slice\n      var pathElement = seriesGroups[i].elem('path', {\n        d: path.stringify()\n      }, options.donut ? options.classNames.sliceDonut : options.classNames.slicePie);\n\n      // Adding the pie series value to the path\n      pathElement.attr({\n        'ct:value': dataArray[i],\n        'ct:meta': Chartist.serialize(series.meta)\n      });\n\n      // If this is a donut, we add the stroke-width as style attribute\n      if(options.donut) {\n        pathElement.attr({\n          'style': 'stroke-width: ' + donutWidth.value + 'px'\n        });\n      }\n\n      // Fire off draw event\n      this.eventEmitter.emit('draw', {\n        type: 'slice',\n        value: dataArray[i],\n        totalDataSum: totalDataSum,\n        index: i,\n        meta: series.meta,\n        series: series,\n        group: seriesGroups[i],\n        element: pathElement,\n        path: path.clone(),\n        center: center,\n        radius: radius,\n        startAngle: startAngle,\n        endAngle: endAngle\n      });\n\n      // If we need to show labels we need to add the label for this slice now\n      if(options.showLabel) {\n        // Position at the labelRadius distance from center and between start and end angle\n        var labelPosition = Chartist.polarToCartesian(center.x, center.y, labelRadius, startAngle + (endAngle - startAngle) / 2),\n          interpolatedValue = options.labelInterpolationFnc(this.data.labels && !Chartist.isFalseyButZero(this.data.labels[i]) ? this.data.labels[i] : dataArray[i], i);\n\n        if(interpolatedValue || interpolatedValue === 0) {\n          var labelElement = labelsGroup.elem('text', {\n            dx: labelPosition.x,\n            dy: labelPosition.y,\n            'text-anchor': determineAnchorPosition(center, labelPosition, options.labelDirection)\n          }, options.classNames.label).text('' + interpolatedValue);\n\n          // Fire off draw event\n          this.eventEmitter.emit('draw', {\n            type: 'label',\n            index: i,\n            group: labelsGroup,\n            element: labelElement,\n            text: '' + interpolatedValue,\n            x: labelPosition.x,\n            y: labelPosition.y\n          });\n        }\n      }\n\n      // Set next startAngle to current endAngle.\n      // (except for last slice)\n      startAngle = endAngle;\n    }\n\n    this.eventEmitter.emit('created', {\n      chartRect: chartRect,\n      svg: this.svg,\n      options: options\n    });\n  }\n\n  /**\n   * This method creates a new pie chart and returns an object that can be used to redraw the chart.\n   *\n   * @memberof Chartist.Pie\n   * @param {String|Node} query A selector query string or directly a DOM element\n   * @param {Object} data The data object in the pie chart needs to have a series property with a one dimensional data array. The values will be normalized against each other and don't necessarily need to be in percentage. The series property can also be an array of value objects that contain a value property and a className property to override the CSS class name for the series group.\n   * @param {Object} [options] The options object with options that override the default options. Check the examples for a detailed list.\n   * @param {Array} [responsiveOptions] Specify an array of responsive option arrays which are a media query and options object pair => [[mediaQueryString, optionsObject],[more...]]\n   * @return {Object} An object with a version and an update method to manually redraw the chart\n   *\n   * @example\n   * // Simple pie chart example with four series\n   * new Chartist.Pie('.ct-chart', {\n   *   series: [10, 2, 4, 3]\n   * });\n   *\n   * @example\n   * // Drawing a donut chart\n   * new Chartist.Pie('.ct-chart', {\n   *   series: [10, 2, 4, 3]\n   * }, {\n   *   donut: true\n   * });\n   *\n   * @example\n   * // Using donut, startAngle and total to draw a gauge chart\n   * new Chartist.Pie('.ct-chart', {\n   *   series: [20, 10, 30, 40]\n   * }, {\n   *   donut: true,\n   *   donutWidth: 20,\n   *   startAngle: 270,\n   *   total: 200\n   * });\n   *\n   * @example\n   * // Drawing a pie chart with padding and labels that are outside the pie\n   * new Chartist.Pie('.ct-chart', {\n   *   series: [20, 10, 30, 40]\n   * }, {\n   *   chartPadding: 30,\n   *   labelOffset: 50,\n   *   labelDirection: 'explode'\n   * });\n   *\n   * @example\n   * // Overriding the class names for individual series as well as a name and meta data.\n   * // The name will be written as ct:series-name attribute and the meta data will be serialized and written\n   * // to a ct:meta attribute.\n   * new Chartist.Pie('.ct-chart', {\n   *   series: [{\n   *     value: 20,\n   *     name: 'Series 1',\n   *     className: 'my-custom-class-one',\n   *     meta: 'Meta One'\n   *   }, {\n   *     value: 10,\n   *     name: 'Series 2',\n   *     className: 'my-custom-class-two',\n   *     meta: 'Meta Two'\n   *   }, {\n   *     value: 70,\n   *     name: 'Series 3',\n   *     className: 'my-custom-class-three',\n   *     meta: 'Meta Three'\n   *   }]\n   * });\n   */\n  function Pie(query, data, options, responsiveOptions) {\n    Chartist.Pie.super.constructor.call(this,\n      query,\n      data,\n      defaultOptions,\n      Chartist.extend({}, defaultOptions, options),\n      responsiveOptions);\n  }\n\n  // Creating pie chart type in Chartist namespace\n  Chartist.Pie = Chartist.Base.extend({\n    constructor: Pie,\n    createChart: createChart,\n    determineAnchorPosition: determineAnchorPosition\n  });\n\n}(window, document, Chartist));\n\nreturn Chartist;\n\n}));\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/scss/chartist.scss",
    "content": "@import \"settings/chartist-settings\";\n\n@mixin ct-responsive-svg-container($width: 100%, $ratio: $ct-container-ratio) {\n  display: block;\n  position: relative;\n  width: $width;\n\n  &:before {\n    display: block;\n    float: left;\n    content: \"\";\n    width: 0;\n    height: 0;\n    padding-bottom: $ratio * 100%;\n  }\n\n  &:after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > svg {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n  }\n}\n\n@mixin ct-align-justify($ct-text-align: $ct-text-align, $ct-text-justify: $ct-text-justify) {\n  -webkit-box-align: $ct-text-align;\n  -webkit-align-items: $ct-text-align;\n  -ms-flex-align: $ct-text-align;\n  align-items: $ct-text-align;\n  -webkit-box-pack: $ct-text-justify;\n  -webkit-justify-content: $ct-text-justify;\n  -ms-flex-pack: $ct-text-justify;\n  justify-content: $ct-text-justify;\n  // Fallback to text-align for non-flex browsers\n  @if($ct-text-justify == 'flex-start') {\n    text-align: left;\n  } @else if ($ct-text-justify == 'flex-end') {\n    text-align: right;\n  } @else {\n    text-align: center;\n  }\n}\n\n@mixin ct-flex() {\n  // Fallback to block\n  display: block;\n  display: -webkit-box;\n  display: -moz-box;\n  display: -ms-flexbox;\n  display: -webkit-flex;\n  display: flex;\n}\n\n@mixin ct-chart-label($ct-text-color: $ct-text-color, $ct-text-size: $ct-text-size, $ct-text-line-height: $ct-text-line-height) {\n  fill: $ct-text-color;\n  color: $ct-text-color;\n  font-size: $ct-text-size;\n  line-height: $ct-text-line-height;\n}\n\n@mixin ct-chart-grid($ct-grid-color: $ct-grid-color, $ct-grid-width: $ct-grid-width, $ct-grid-dasharray: $ct-grid-dasharray) {\n  stroke: $ct-grid-color;\n  stroke-width: $ct-grid-width;\n\n  @if ($ct-grid-dasharray) {\n    stroke-dasharray: $ct-grid-dasharray;\n  }\n}\n\n@mixin ct-chart-point($ct-point-size: $ct-point-size, $ct-point-shape: $ct-point-shape) {\n  stroke-width: $ct-point-size;\n  stroke-linecap: $ct-point-shape;\n}\n\n@mixin ct-chart-line($ct-line-width: $ct-line-width, $ct-line-dasharray: $ct-line-dasharray) {\n  fill: none;\n  stroke-width: $ct-line-width;\n\n  @if ($ct-line-dasharray) {\n    stroke-dasharray: $ct-line-dasharray;\n  }\n}\n\n@mixin ct-chart-area($ct-area-opacity: $ct-area-opacity) {\n  stroke: none;\n  fill-opacity: $ct-area-opacity;\n}\n\n@mixin ct-chart-bar($ct-bar-width: $ct-bar-width) {\n  fill: none;\n  stroke-width: $ct-bar-width;\n}\n\n@mixin ct-chart-donut($ct-donut-width: $ct-donut-width) {\n  fill: none;\n  stroke-width: $ct-donut-width;\n}\n\n@mixin ct-chart-series-color($color) {\n  .#{$ct-class-point}, .#{$ct-class-line}, .#{$ct-class-bar}, .#{$ct-class-slice-donut} {\n    stroke: $color;\n  }\n\n  .#{$ct-class-slice-pie}, .#{$ct-class-area} {\n    fill: $color;\n  }\n}\n\n@mixin ct-chart($ct-container-ratio: $ct-container-ratio, $ct-text-color: $ct-text-color, $ct-text-size: $ct-text-size, $ct-grid-color: $ct-grid-color, $ct-grid-width: $ct-grid-width, $ct-grid-dasharray: $ct-grid-dasharray, $ct-point-size: $ct-point-size, $ct-point-shape: $ct-point-shape, $ct-line-width: $ct-line-width, $ct-bar-width: $ct-bar-width, $ct-donut-width: $ct-donut-width, $ct-series-names: $ct-series-names, $ct-series-colors: $ct-series-colors) {\n\n  .#{$ct-class-label} {\n    @include ct-chart-label($ct-text-color, $ct-text-size);\n  }\n\n  .#{$ct-class-chart-line} .#{$ct-class-label},\n  .#{$ct-class-chart-bar} .#{$ct-class-label} {\n    @include ct-flex();\n  }\n\n  .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-start} {\n    @include ct-align-justify(flex-end, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-end} {\n    @include ct-align-justify(flex-start, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-label}.#{$ct-class-vertical}.#{$ct-class-start} {\n    @include ct-align-justify(flex-end, flex-end);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: end;\n  }\n\n  .#{$ct-class-label}.#{$ct-class-vertical}.#{$ct-class-end} {\n    @include ct-align-justify(flex-end, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-chart-bar} .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-start} {\n    @include ct-align-justify(flex-end, center);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-chart-bar} .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-end} {\n    @include ct-align-justify(flex-start, center);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-chart-bar}.#{$ct-class-horizontal-bars} .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-start} {\n    @include ct-align-justify(flex-end, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-chart-bar}.#{$ct-class-horizontal-bars} .#{$ct-class-label}.#{$ct-class-horizontal}.#{$ct-class-end} {\n    @include ct-align-justify(flex-start, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: start;\n  }\n\n  .#{$ct-class-chart-bar}.#{$ct-class-horizontal-bars} .#{$ct-class-label}.#{$ct-class-vertical}.#{$ct-class-start} {\n    //@include ct-chart-label($ct-text-color, $ct-text-size, center, $ct-vertical-text-justify);\n    @include ct-align-justify(center, flex-end);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: end;\n  }\n\n  .#{$ct-class-chart-bar}.#{$ct-class-horizontal-bars} .#{$ct-class-label}.#{$ct-class-vertical}.#{$ct-class-end} {\n    @include ct-align-justify(center, flex-start);\n    // Fallback for browsers that don't support foreignObjects\n    text-anchor: end;\n  }\n\n  .#{$ct-class-grid} {\n    @include ct-chart-grid($ct-grid-color, $ct-grid-width, $ct-grid-dasharray);\n  }\n\n  .#{$ct-class-point} {\n    @include ct-chart-point($ct-point-size, $ct-point-shape);\n  }\n\n  .#{$ct-class-line} {\n    @include ct-chart-line($ct-line-width);\n  }\n\n  .#{$ct-class-area} {\n    @include ct-chart-area();\n  }\n\n  .#{$ct-class-bar} {\n    @include ct-chart-bar($ct-bar-width);\n  }\n\n  .#{$ct-class-slice-donut} {\n    @include ct-chart-donut($ct-donut-width);\n  }\n\n  @if $ct-include-colored-series {\n    @for $i from 0 to length($ct-series-names) {\n      .#{$ct-class-series}-#{nth($ct-series-names, $i + 1)} {\n        $color: nth($ct-series-colors, $i + 1);\n\n        @include ct-chart-series-color($color);\n      }\n    }\n  }\n}\n\n@if $ct-include-classes {\n  @include ct-chart();\n\n  @if $ct-include-alternative-responsive-containers {\n    @for $i from 0 to length($ct-scales-names) {\n      .#{nth($ct-scales-names, $i + 1)} {\n        @include ct-responsive-svg-container($ratio: nth($ct-scales, $i + 1));\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-js/dist/scss/settings/_chartist-settings.scss",
    "content": "// Scales for responsive SVG containers\n$ct-scales: ((1), (15/16), (8/9), (5/6), (4/5), (3/4), (2/3), (5/8), (1/1.618), (3/5), (9/16), (8/15), (1/2), (2/5), (3/8), (1/3), (1/4)) !default;\n$ct-scales-names: (ct-square, ct-minor-second, ct-major-second, ct-minor-third, ct-major-third, ct-perfect-fourth, ct-perfect-fifth, ct-minor-sixth, ct-golden-section, ct-major-sixth, ct-minor-seventh, ct-major-seventh, ct-octave, ct-major-tenth, ct-major-eleventh, ct-major-twelfth, ct-double-octave) !default;\n\n// Class names to be used when generating CSS\n$ct-class-chart: ct-chart !default;\n$ct-class-chart-line: ct-chart-line !default;\n$ct-class-chart-bar: ct-chart-bar !default;\n$ct-class-horizontal-bars: ct-horizontal-bars !default;\n$ct-class-chart-pie: ct-chart-pie !default;\n$ct-class-chart-donut: ct-chart-donut !default;\n$ct-class-label: ct-label !default;\n$ct-class-series: ct-series !default;\n$ct-class-line: ct-line !default;\n$ct-class-point: ct-point !default;\n$ct-class-area: ct-area !default;\n$ct-class-bar: ct-bar !default;\n$ct-class-slice-pie: ct-slice-pie !default;\n$ct-class-slice-donut: ct-slice-donut !default;\n$ct-class-grid: ct-grid !default;\n$ct-class-vertical: ct-vertical !default;\n$ct-class-horizontal: ct-horizontal !default;\n$ct-class-start: ct-start !default;\n$ct-class-end: ct-end !default;\n\n// Container ratio\n$ct-container-ratio: (1/1.618) !default;\n\n// Text styles for labels\n$ct-text-color: rgba(0, 0, 0, 0.4) !default;\n$ct-text-size: 0.75rem !default;\n$ct-text-align: flex-start !default;\n$ct-text-justify: flex-start !default;\n$ct-text-line-height: 1;\n\n// Grid styles\n$ct-grid-color: rgba(0, 0, 0, 0.2) !default;\n$ct-grid-dasharray: 2px !default;\n$ct-grid-width: 1px !default;\n\n// Line chart properties\n$ct-line-width: 4px !default;\n$ct-line-dasharray: false !default;\n$ct-point-size: 10px !default;\n// Line chart point, can be either round or square\n$ct-point-shape: round !default;\n// Area fill transparency between 0 and 1\n$ct-area-opacity: 0.1 !default;\n\n// Bar chart bar width\n$ct-bar-width: 10px !default;\n\n// Donut width (If donut width is to big it can cause issues where the shape gets distorted)\n$ct-donut-width: 60px !default;\n\n// If set to true it will include the default classes and generate CSS output. If you're planning to use the mixins you\n// should set this property to false\n$ct-include-classes: true !default;\n\n// If this is set to true the CSS will contain colored series. You can extend or change the color with the\n// properties below\n$ct-include-colored-series: $ct-include-classes !default;\n\n// If set to true this will include all responsive container variations using the scales defined at the top of the script\n$ct-include-alternative-responsive-containers: $ct-include-classes !default;\n\n// Series names and colors. This can be extended or customized as desired. Just add more series and colors.\n$ct-series-names: (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o) !default;\n$ct-series-colors: (\n  #d70206,\n  #f05b4f,\n  #f4c63d,\n  #d17905,\n  #453d3f,\n  #59922b,\n  #0544d3,\n  #6b0392,\n  #f05b4f,\n  #dda458,\n  #eacf7d,\n  #86797d,\n  #b2c326,\n  #6188e2,\n  #a748ca\n) !default;\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/.gitignore",
    "content": "# Logs\nlogs\n*.log\n\n# Runtime data\npids\n*.pid\n*.seed\n\n# Directory for instrumented libs generated by jscoverage/JSCover\nlib-cov\n\n# Coverage directory used by tools like istanbul\ncoverage\n\n# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)\n.grunt\n\n# Compiled binary addons (http://nodejs.org/api/addons.html)\nbuild/Release\n\n# Dependency directory\n# Commenting this out is preferred by some people, see\n# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git-\nnode_modules\n\n# Users Environment Variables\n.lock-wscript\n\nbower_components\n\n#Sass Cache\n.sass-cache\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/CHANGELOG.md",
    "content": "# Chartist Plugin Tooltip Changelog\n\n### master\n\n### 0.0.11\n* [BUGFIX] Tooltips now working properly on Firefox\n* [ENHANCEMENT] Added custom tooltip using options.tooltipFnc\n\n### 0.0.10\n* [BUGFIX] Set currency default to `undefined`. Fixes issue in chartist.js 0.7.4.\n\n### 0.0.9\n* [BUGFIX] Fixed new pie chart label mechanism\n\n### 0.0.8\n* [BUGFIX] Removed Ember reference\n* [ENHANCEMENT] For pie chart tooltips also take the labels into account if no meta is given\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/Gruntfile.js",
    "content": "/**\n * Grunt Configurations\n * ====================\n *\n * Seperate tasks and configurations are declared in '/tasks'.\n *\n * Link: https://github.com/firstandthird/load-grunt-config\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n\n  // tracks how long a tasks take\n  require('time-grunt')(grunt);\n\n  // load task and configurations\n  require('load-grunt-config')(grunt, {\n    configPath: __dirname +  '/tasks',\n    data: {\n      pkg: grunt.file.readJSON('package.json'),\n      year: new Date().getFullYear()\n    }\n  });\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/LICENSE",
    "content": "The MIT License (MIT)\n\nCopyright (c) 2015 Markus Padourek\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/README.md",
    "content": "# Tooltip plugin for Chartist.js\n\nThis plugin provides quick and easy tooltips for your chartist charts. Touch support is planned soon.\n\nPlease visit http://gionkunz.github.io/chartist-js/plugins.html for more information.\n\nNPM package: https://www.npmjs.com/package/chartist-plugin-tooltips\n\n## Available options and their defaults\n\n```javascript\nvar defaultOptions = {\n  currency: undefined, //accepts '£', '$', '€', etc.\n  //e.g. 4000 => €4,000\n  tooltipFnc: undefined, //accepts function\n  //build custom tooltip\n  transformTooltipTextFnc: undefined, // accepts function\n  // transform tooltip text\n  class: undefined, // accecpts 'class1', 'class1 class2', etc.\n  //adds class(es) to tooltip wrapper\n  anchorToPoint: false, //accepts true or false\n  //tooltips do not follow mouse movement -- they are anchored to the point / bar.\n  appendToBody: false //accepts true or false\n  //appends tooltips to body instead of chart container\n};\n```\n\n## Sample usage in Chartist.js\n\n`bower install chartist-plugin-tooltip --save`\n\nWith descriptive text:\n```js\nvar chart = new Chartist.Line('.ct-chart', {\n  labels: [1, 2, 3],\n  series: [\n    [\n      {meta: 'description', value: 1},\n      {meta: 'description', value: 5},\n      {meta: 'description', value: 3}\n    ],\n    [\n      {meta: 'other description', value: 2},\n      {meta: 'other description', value: 4},\n      {meta: 'other description', value: 2}\n    ]\n  ]\n}, {\n  plugins: [\n    Chartist.plugins.tooltip()\n  ]\n});\n```\n\nWithout descriptive text:\n```js\nvar chart = new Chartist.Line('.ct-chart', {\n  labels: [1, 2, 3, 4, 5, 6, 7],\n  series: [\n    [1, 5, 3, 4, 6, 2, 3],\n    [2, 4, 2, 5, 4, 3, 6]\n  ]\n}, {\n  plugins: [\n    Chartist.plugins.tooltip()\n  ]\n});\n```\n\nWith options text:\n```js\nvar chart = new Chartist.Line('.ct-chart', {\n  labels: [1, 2, 3],\n  series: [\n    [\n      {meta: 'description', value: 1},\n      {meta: 'description', value: 5},\n      {meta: 'description', value: 3}\n    ],\n    [\n      {meta: 'other description', value: 2},\n      {meta: 'other description', value: 4},\n      {meta: 'other description', value: 2}\n    ]\n  ]\n}, {\n  plugins: [\n    Chartist.plugins.tooltip({\n      currency: '$',\n      class: 'class1 class2',\n      appendToBody: true\n    })\n  ]\n});\n```\n\n\n\n## Custom point element.\n\nIn ChartistJS you can replace default element with smth different.\nThere is a pretty [demo](https://gionkunz.github.io/chartist-js/examples.html) (*USING EVENTS TO REPLACE GRAPHICS*).\nAnd if you want the tooltip to work fine with a new element, you need to include two more properties:\n\n```javascript\n'ct:value': data.value.y,\n'ct:meta': data.meta,\n```\n\nSo the final code could look like this. Here is a [live demo](https://jsfiddle.net/AlexanderKozhevin/aapycL87/)\n```javascript\nchart.on('draw', function(data) {\n  // If the draw event was triggered from drawing a point on the line chart\n  if(data.type === 'point') {\n    // We are creating a new path SVG element that draws a triangle around the point coordinates\n\n    var circle = new Chartist.Svg('circle', {\n      cx: [data.x],\n      cy: [data.y],\n      r: [5],\n      'ct:value': data.value.y,\n      'ct:meta': data.meta,\n      class: 'my-cool-point',\n    }, 'ct-area');\n\n    // With data.element we get the Chartist SVG wrapper and we can replace the original point drawn by Chartist with our newly created triangle\n    data.element.replace(circle);\n  }\n});\n```\n\n```javascript\nplugins: [\n      Chartist.plugins.tooltip({\n        appendToBody: true,\n        pointClass: 'my-cool-point'\n      })\n\n    ]\n\n```\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/bower.json",
    "content": "{\n  \"name\": \"chartist-plugin-tooltip\",\n  \"main\": [\n    \"./dist/chartist-plugin-tooltip.min.js\",\n    \"./dist/chartist-plugin-tooltip.css\"\n  ],\n  \"dependencies\": {\n    \"chartist\": \"~0.9.4\"\n  },\n  \"ignore\": [\n    \".*\",\n    \"Gruntfile.js\",\n    \"package.json\",\n    \"node_modules\",\n    \"src\",\n    \"test\"\n  ]\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/dist/LICENSE",
    "content": "The MIT License (MIT)\n\nCopyright (c) 2015 Markus Padourek\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/dist/chartist-plugin-tooltip.css",
    "content": ".chartist-tooltip {\n  position: absolute;\n  display: inline-block;\n  opacity: 0;\n  min-width: 50px;\n  padding: 5px 10px;\n  border-radius: 5px;\n  background: #313131;\n  color: #fff;\n  font-weight: 500;\n  text-align: center;\n  pointer-events: none;\n  z-index: 1;\n  -webkit-transition: opacity .2s linear;\n  -moz-transition: opacity .2s linear;\n  -o-transition: opacity .2s linear;\n  transition: opacity .2s linear; }\n\n/*.chartist-tooltip:before {\n    content: \"\";\n    position: absolute;\n    top: 100%;\n    left: 50%;\n    width: 0;\n    height: 0;\n    margin-left: -5px;\n    border: 5px solid transparent;\n    border-top-color: #313131; }\n*/\n.chartist-tooltip.tooltip-show {\n    opacity: 1; }\n\n.ct-area, .ct-line {\n  pointer-events: none; }\n\n/*# sourceMappingURL=chartist-plugin-tooltip.css.map */\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/dist/chartist-plugin-tooltip.js",
    "content": "(function (root, factory) {\n  if (typeof define === 'function' && define.amd) {\n    // AMD. Register as an anonymous module.\n    define([\"chartist\"], function (Chartist) {\n      return (root.returnExportsGlobal = factory(Chartist));\n    });\n  } else if (typeof exports === 'object') {\n    // Node. Does not work with strict CommonJS, but\n    // only CommonJS-like enviroments that support module.exports,\n    // like Node.\n    module.exports = factory(require(\"chartist\"));\n  } else {\n    root['Chartist.plugins.tooltips'] = factory(Chartist);\n  }\n}(this, function (Chartist) {\n\n  /**\n   * Chartist.js plugin to display a data label on top of the points in a line chart.\n   *\n   */\n  /* global Chartist */\n  (function (window, document, Chartist) {\n    'use strict';\n\n    var defaultOptions = {\n      currency: undefined,\n      currencyFormatCallback: undefined,\n      tooltipOffset: {\n        x: 0,\n        y: -20\n      },\n      anchorToPoint: false,\n      appendToBody: false,\n      class: undefined,\n      pointClass: 'ct-point'\n    };\n\n    Chartist.plugins = Chartist.plugins || {};\n    Chartist.plugins.tooltip = function (options) {\n      options = Chartist.extend({}, defaultOptions, options);\n\n      return function tooltip(chart) {\n        var tooltipSelector = options.pointClass;\n        if (chart instanceof Chartist.Bar) {\n          tooltipSelector = 'ct-bar';\n        } else if (chart instanceof Chartist.Pie) {\n          // Added support for donut graph\n          if (chart.options.donut) {\n            tooltipSelector = 'ct-slice-donut';\n          } else {\n            tooltipSelector = 'ct-slice-pie';\n          }\n        }\n\n        var $chart = chart.container;\n        var $toolTip = $chart.querySelector('.chartist-tooltip');\n        if (!$toolTip) {\n          $toolTip = document.createElement('div');\n          $toolTip.className = (!options.class) ? 'chartist-tooltip' : 'chartist-tooltip ' + options.class;\n          if (!options.appendToBody) {\n            $chart.appendChild($toolTip);\n          } else {\n            document.body.appendChild($toolTip);\n          }\n        }\n        var height = $toolTip.offsetHeight;\n        var width = $toolTip.offsetWidth;\n\n        hide($toolTip);\n\n        function on(event, selector, callback) {\n          $chart.addEventListener(event, function (e) {\n            if (!selector || hasClass(e.target, selector))\n              callback(e);\n          });\n        }\n\n        on('mouseover', tooltipSelector, function (event) {\n          var $point = event.target;\n          var tooltipText = '';\n\n          var isPieChart = (chart instanceof Chartist.Pie) ? $point : $point.parentNode;\n          var seriesName = (isPieChart) ? $point.parentNode.getAttribute('ct:meta') || $point.parentNode.getAttribute('ct:series-name') : '';\n          var meta = $point.getAttribute('ct:meta') || seriesName || '';\n          var hasMeta = !!meta;\n          var value = $point.getAttribute('ct:value');\n\n          if (options.transformTooltipTextFnc && typeof options.transformTooltipTextFnc === 'function') {\n            value = options.transformTooltipTextFnc(value);\n          }\n\n          if (options.tooltipFnc && typeof options.tooltipFnc === 'function') {\n            tooltipText = options.tooltipFnc(meta, value);\n          } else {\n            if (options.metaIsHTML) {\n              var txt = document.createElement('textarea');\n              txt.innerHTML = meta;\n              meta = txt.value;\n            }\n\n            meta = '<span class=\"chartist-tooltip-meta\">' + meta + '</span>';\n\n            if (hasMeta) {\n              tooltipText += meta + '<br>';\n            } else {\n              // For Pie Charts also take the labels into account\n              // Could add support for more charts here as well!\n              if (chart instanceof Chartist.Pie) {\n                var label = next($point, 'ct-label');\n                if (label) {\n                  tooltipText += text(label) + '<br>';\n                }\n              }\n            }\n\n            if (value) {\n              if (options.currency) {\n                if (options.currencyFormatCallback != undefined) {\n                  value = options.currencyFormatCallback(value, options);\n                } else {\n                  value = options.currency + value.replace(/(\\d)(?=(\\d{3})+(?:\\.\\d+)?$)/g, '$1,');\n                }\n              }\n              value = '<span class=\"chartist-tooltip-value\">' + value + '</span>';\n              tooltipText += value;\n            }\n          }\n\n          if(tooltipText) {\n            $toolTip.innerHTML = tooltipText;\n            setPosition(event);\n            show($toolTip);\n\n            // Remember height and width to avoid wrong position in IE\n            height = $toolTip.offsetHeight;\n            width = $toolTip.offsetWidth;\n          }\n        });\n\n        on('mouseout', tooltipSelector, function () {\n          hide($toolTip);\n        });\n\n        on('mousemove', null, function (event) {\n          if (false === options.anchorToPoint)\n            setPosition(event);\n        });\n\n        function setPosition(event) {\n          height = height || $toolTip.offsetHeight;\n          width = width || $toolTip.offsetWidth;\n          var offsetX = - width / 2 + options.tooltipOffset.x\n          var offsetY = - height + options.tooltipOffset.y;\n          var anchorX, anchorY;\n\n          if (!options.appendToBody) {\n            var box = $chart.getBoundingClientRect();\n            var left = event.pageX - box.left - window.pageXOffset ;\n            var top = event.pageY - box.top - window.pageYOffset ;\n\n            if (true === options.anchorToPoint && event.target.x2 && event.target.y2) {\n              anchorX = parseInt(event.target.x2.baseVal.value);\n              anchorY = parseInt(event.target.y2.baseVal.value);\n            }\n\n            $toolTip.style.top = (anchorY || top) + offsetY + 'px';\n            $toolTip.style.left = (anchorX || left) + offsetX + 'px';\n          } else {\n            $toolTip.style.top = event.pageY + offsetY + 'px';\n            $toolTip.style.left = event.pageX + offsetX + 'px';\n          }\n        }\n      }\n    };\n\n    function show(element) {\n      if(!hasClass(element, 'tooltip-show')) {\n        element.className = element.className + ' tooltip-show';\n      }\n    }\n\n    function hide(element) {\n      var regex = new RegExp('tooltip-show' + '\\\\s*', 'gi');\n      element.className = element.className.replace(regex, '').trim();\n    }\n\n    function hasClass(element, className) {\n      return (' ' + element.getAttribute('class') + ' ').indexOf(' ' + className + ' ') > -1;\n    }\n\n    function next(element, className) {\n      do {\n        element = element.nextSibling;\n      } while (element && !hasClass(element, className));\n      return element;\n    }\n\n    function text(element) {\n      return element.innerText || element.textContent;\n    }\n\n  } (window, document, Chartist));\n\n  return Chartist.plugins.tooltips;\n\n}));\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/package.json",
    "content": "{\n  \"name\": \"chartist-plugin-tooltips\",\n  \"description\": \"Point Labels Plugin for Chartist.js\",\n  \"version\": \"0.0.17\",\n  \"author\": \"Markus Padourek\",\n  \"homepage\": \"https://github.com/Globegitter/chartist-plugin-tooltip\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/Globegitter/chartist-plugin-tooltip.git\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/Globegitter/chartist-plugin-tooltip/issues\"\n  },\n  \"keywords\": [\n    \"chartist\",\n    \"plugin\",\n    \"tooltip\"\n  ],\n  \"files\": [\n    \"dist\",\n    \"LICENSE\",\n    \"package.json\",\n    \"README.md\"\n  ],\n  \"main\": \"dist/chartist-plugin-tooltip.js\",\n  \"browser\": \"dist/chartist-plugin-tooltip.js\",\n  \"licenses\": [\n    {\n      \"type\": \"MIT\",\n      \"url\": \"https://github.com/Globegitter/chartist-plugin-tooltip/blob/master/LICENSE\"\n    }\n  ],\n  \"dependencies\": {},\n  \"devDependencies\": {\n    \"chartist\": \"~0.7.3\",\n    \"grunt\": \"^0.4.5\",\n    \"grunt-contrib-clean\": \"^0.6.0\",\n    \"grunt-contrib-copy\": \"^0.7.0\",\n    \"grunt-contrib-jasmine\": \"~0.8.1\",\n    \"grunt-contrib-jshint\": \"~0.10.0\",\n    \"grunt-contrib-sass\": \"^0.9.2\",\n    \"grunt-contrib-uglify\": \"^0.6.0\",\n    \"grunt-newer\": \"^0.8.0\",\n    \"grunt-umd\": \"~2.2.1\",\n    \"jasmine-fixture\": \"~1.2.2\",\n    \"jshint-stylish\": \"~1.0.0\",\n    \"load-grunt-config\": \"^0.16.0\",\n    \"time-grunt\": \"^1.0.0\"\n  },\n  \"engines\": {\n    \"node\": \">=0.10.0\"\n  },\n  \"scripts\": {\n    \"test\": \"grunt test\",\n    \"preversion\": \"grunt test\",\n    \"version\": \"grunt build && git add -A .\"\n  },\n  \"config\": {\n    \"banner\": \"/* chartist-plugin-tooltip <%= pkg.version %>\\n * Copyright © <%= year %> Markus Padourek\\n * Free to use under the WTFPL license.\\n * http://www.wtfpl.net/\\n */\\n\",\n    \"src\": \"src\",\n    \"dist\": \"dist\",\n    \"tmp\": \".tmp\",\n    \"test\": \"test\",\n    \"src_name\": \"chartist-plugin-tooltip\"\n  },\n  \"directories\": {\n    \"test\": \"test\"\n  },\n  \"license\": \"MIT\"\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/src/css/chartist-plugin-tooltip.css",
    "content": ".chartist-tooltip {\n  position: absolute;\n  display: inline-block;\n  opacity: 0;\n  min-width: 5em;\n  padding: .5em;\n  background: #F4C63D;\n  color: #453D3F;\n  font-family: Oxygen,Helvetica,Arial,sans-serif;\n  font-weight: 700;\n  text-align: center;\n  pointer-events: none;\n  z-index: 1;\n  -webkit-transition: opacity .2s linear;\n  -moz-transition: opacity .2s linear;\n  -o-transition: opacity .2s linear;\n  transition: opacity .2s linear; }\n  .chartist-tooltip:before {\n    content: \"\";\n    position: absolute;\n    top: 100%;\n    left: 50%;\n    width: 0;\n    height: 0;\n    margin-left: -15px;\n    border: 15px solid transparent;\n    border-top-color: #F4C63D; }\n  .chartist-tooltip.tooltip-show {\n    opacity: 1; }\n\n.ct-area, .ct-line {\n  pointer-events: none; }\n\n/*# sourceMappingURL=chartist-plugin-tooltip.css.map */\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/src/scripts/chartist-plugin-tooltip.js",
    "content": "/**\n * Chartist.js plugin to display a data label on top of the points in a line chart.\n *\n */\n/* global Chartist */\n(function (window, document, Chartist) {\n  'use strict';\n\n  var defaultOptions = {\n    currency: undefined,\n    currencyFormatCallback: undefined,\n    tooltipOffset: {\n      x: 0,\n      y: -20\n    },\n    anchorToPoint: false,\n    appendToBody: false,\n    class: undefined,\n    pointClass: 'ct-point'\n  };\n\n  Chartist.plugins = Chartist.plugins || {};\n  Chartist.plugins.tooltip = function (options) {\n    options = Chartist.extend({}, defaultOptions, options);\n\n    return function tooltip(chart) {\n      var tooltipSelector = options.pointClass;\n      if (chart instanceof Chartist.Bar) {\n        tooltipSelector = 'ct-bar';\n      } else if (chart instanceof Chartist.Pie) {\n        // Added support for donut graph\n        if (chart.options.donut) {\n          tooltipSelector = 'ct-slice-donut';\n        } else {\n          tooltipSelector = 'ct-slice-pie';\n        }\n      }\n\n      var $chart = chart.container;\n      var $toolTip = $chart.querySelector('.chartist-tooltip');\n      if (!$toolTip) {\n        $toolTip = document.createElement('div');\n        $toolTip.className = (!options.class) ? 'chartist-tooltip' : 'chartist-tooltip ' + options.class;\n        if (!options.appendToBody) {\n          $chart.appendChild($toolTip);\n        } else {\n          document.body.appendChild($toolTip);\n        }\n      }\n      var height = $toolTip.offsetHeight;\n      var width = $toolTip.offsetWidth;\n\n      hide($toolTip);\n\n      function on(event, selector, callback) {\n        $chart.addEventListener(event, function (e) {\n          if (!selector || hasClass(e.target, selector))\n            callback(e);\n        });\n      }\n\n      on('mouseover', tooltipSelector, function (event) {\n        var $point = event.target;\n        var tooltipText = '';\n\n        var isPieChart = (chart instanceof Chartist.Pie) ? $point : $point.parentNode;\n        var seriesName = (isPieChart) ? $point.parentNode.getAttribute('ct:meta') || $point.parentNode.getAttribute('ct:series-name') : '';\n        var meta = $point.getAttribute('ct:meta') || seriesName || '';\n        var hasMeta = !!meta;\n        var value = $point.getAttribute('ct:value');\n\n        if (options.transformTooltipTextFnc && typeof options.transformTooltipTextFnc === 'function') {\n          value = options.transformTooltipTextFnc(value);\n        }\n\n        if (options.tooltipFnc && typeof options.tooltipFnc === 'function') {\n          tooltipText = options.tooltipFnc(meta, value);\n        } else {\n          if (options.metaIsHTML) {\n            var txt = document.createElement('textarea');\n            txt.innerHTML = meta;\n            meta = txt.value;\n          }\n\n          meta = '<span class=\"chartist-tooltip-meta\">' + meta + '</span>';\n\n          if (hasMeta) {\n            tooltipText += meta + '<br>';\n          } else {\n            // For Pie Charts also take the labels into account\n            // Could add support for more charts here as well!\n            if (chart instanceof Chartist.Pie) {\n              var label = next($point, 'ct-label');\n              if (label) {\n                tooltipText += text(label) + '<br>';\n              }\n            }\n          }\n\n          if (value) {\n            if (options.currency) {\n              if (options.currencyFormatCallback != undefined) {\n                value = options.currencyFormatCallback(value, options);\n              } else {\n                value = options.currency + value.replace(/(\\d)(?=(\\d{3})+(?:\\.\\d+)?$)/g, '$1,');\n              }\n            }\n            value = '<span class=\"chartist-tooltip-value\">' + value + '</span>';\n            tooltipText += value;\n          }\n        }\n\n        if(tooltipText) {\n          $toolTip.innerHTML = tooltipText;\n          setPosition(event);\n          show($toolTip);\n\n          // Remember height and width to avoid wrong position in IE\n          height = $toolTip.offsetHeight;\n          width = $toolTip.offsetWidth;\n        }\n      });\n\n      on('mouseout', tooltipSelector, function () {\n        hide($toolTip);\n      });\n\n      on('mousemove', null, function (event) {\n        if (false === options.anchorToPoint)\n          setPosition(event);\n      });\n\n      function setPosition(event) {\n        height = height || $toolTip.offsetHeight;\n        width = width || $toolTip.offsetWidth;\n        var offsetX = - width / 2 + options.tooltipOffset.x\n        var offsetY = - height + options.tooltipOffset.y;\n        var anchorX, anchorY;\n\n        if (!options.appendToBody) {\n          var box = $chart.getBoundingClientRect();\n          var left = event.pageX - box.left - window.pageXOffset ;\n          var top = event.pageY - box.top - window.pageYOffset ;\n\n          if (true === options.anchorToPoint && event.target.x2 && event.target.y2) {\n            anchorX = parseInt(event.target.x2.baseVal.value);\n            anchorY = parseInt(event.target.y2.baseVal.value);\n          }\n\n          $toolTip.style.top = (anchorY || top) + offsetY + 'px';\n          $toolTip.style.left = (anchorX || left) + offsetX + 'px';\n        } else {\n          $toolTip.style.top = event.pageY + offsetY + 'px';\n          $toolTip.style.left = event.pageX + offsetX + 'px';\n        }\n      }\n    }\n  };\n\n  function show(element) {\n    if(!hasClass(element, 'tooltip-show')) {\n      element.className = element.className + ' tooltip-show';\n    }\n  }\n\n  function hide(element) {\n    var regex = new RegExp('tooltip-show' + '\\\\s*', 'gi');\n    element.className = element.className.replace(regex, '').trim();\n  }\n\n  function hasClass(element, className) {\n    return (' ' + element.getAttribute('class') + ' ').indexOf(' ' + className + ' ') > -1;\n  }\n\n  function next(element, className) {\n    do {\n      element = element.nextSibling;\n    } while (element && !hasClass(element, className));\n    return element;\n  }\n\n  function text(element) {\n    return element.innerText || element.textContent;\n  }\n\n} (window, document, Chartist));\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/src/scss/chartist-plugin-tooltip.scss",
    "content": "$chart-tooltip-bg: #F4C63D;\n$chart-tooltip-color: #453D3F;\n.chartist-tooltip {\n  position: absolute;\n  display: inline-block;\n  opacity: 0;\n  min-width: 5em;\n  padding: .5em;\n  background: $chart-tooltip-bg;\n  color: $chart-tooltip-color;\n  font-family: Oxygen,Helvetica,Arial,sans-serif;\n  font-weight: 700;\n  text-align: center;\n  pointer-events: none;\n  z-index: 1;\n  -webkit-transition: opacity .2s linear;\n  -moz-transition: opacity .2s linear;\n  -o-transition: opacity .2s linear;\n  transition: opacity .2s linear;\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 100%;\n    left: 50%;\n    width: 0;\n    height: 0;\n    margin-left: -15px;\n    border: 15px solid transparent;\n    border-top-color: $chart-tooltip-bg;\n  }\n  &.tooltip-show {\n    opacity: 1;\n  }\n}\n\n.ct-area, .ct-line {\n  pointer-events: none;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/aliases.yml",
    "content": "# Grunt Commands\n# ==============\n#\n# Use `grunt` in the root directory to select and run a specific task.\n\ndefault:\n  - 'test'\n  - 'build'\n\n# create the plugin\nbuild:\n  - 'clean:dist'\n  - 'sass:dist'\n  - 'copy:dist'\n  - 'umd'\n  - 'uglify:dist'\n\n# tests\ntest:\n  - 'clean:tmp'\n  - 'jasmine'\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/clean.js",
    "content": "/**\n * clean\n * =====\n *\n * Remove temporary and unused files.\n *\n * Link: https://github.com/gruntjs/grunt-contrib-clean\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    tmp: '<%= pkg.config.tmp %>',\n    dist: '<%= pkg.config.dist %>'\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/copy.js",
    "content": "/**\n * copy\n * ====\n *\n * Copies remaining files to places other tasks can use.\n *\n * Link: https://github.com/gruntjs/grunt-contrib-copy\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    dist: {\n      files: [\n        {\n          dest: '<%= pkg.config.dist %>/',\n          src: 'LICENSE'\n        },\n        {\n          cwd: '<%= pkg.config.src %>',\n          expand: true,\n          flatten: true,\n          filter: 'isFile',\n          dest: '<%= pkg.config.dist %>/',\n          src: 'css/**',\n        }\n      ]\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/jasmine.js",
    "content": "/**\n * jasmine\n * =======\n *\n * Test settings\n *\n * Link: https://github.com/gruntjs/grunt-contrib-jasmine\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    dist: {\n      src: [\n        'bower_components/chartist/dist/chartist.js',\n        '<%= pkg.config.src %>/scripts/<%= pkg.config.src_name %>.js'\n      ],\n      options: {\n        specs: '<%= pkg.config.test %>/spec/**/spec-*.js',\n        helpers: '<%= pkg.config.test %>/spec/**/helper-*.js',\n        phantomjs: {\n          'ignore-ssl-errors': true\n        }\n      }\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/jshint.js",
    "content": "/**\n * jshint\n * ======\n *\n * Make sure code styles are up to par and there are no obvious mistakes.\n *\n * Link: https://github.com/gruntjs/grunt-contrib-jshint\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    options: {\n      jshintrc: '.jshintrc',\n      reporter: require('jshint-stylish')\n    },\n    all: [\n      'Gruntfile.js',\n      '<%= pkg.config.src %>/{,*/}*.js',\n      '<%= pkg.config.site %>/scripts/{,*/}*.js'\n    ],\n    test: {\n      options: {\n        jshintrc: '<%= pkg.config.test %>/.jshintrc'\n      },\n      src: ['<%= pkg.config.test %>/spec/{,*/}*.js']\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/sass.js",
    "content": "/**\n * sass\n * ======\n *\n * Compile scss to css\n *\n * Link: https://github.com/gruntjs/grunt-contrib-sass\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    dist: {\n      files: [{\n        expand: true,\n        cwd: '<%= pkg.config.src %>/scss',\n        src: ['*.scss'],\n        dest: '<%= pkg.config.src %>/css',\n        ext: '.css'\n      }]\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/uglify.js",
    "content": "/**\n * uglify\n * ======\n *\n * Minify the library.\n *\n * Link: https://github.com/gruntjs/grunt-contrib-uglify\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    dist: {\n      options: {\n        banner: '<%= pkg.config.banner %>',\n        sourceMap: true,\n        sourceMapIncludeSources: true\n      },\n      files: {\n        '<%= pkg.config.dist %>/<%= pkg.config.src_name %>.min.js': ['<%= pkg.config.dist %>/<%= pkg.config.src_name %>.js']\n      }\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/tasks/umd.js",
    "content": "/**\n * umd\n * ===\n *\n * Wraps the library into an universal module definition (AMD + CommonJS + Global).\n *\n * Link: https://github.com/bebraw/grunt-umd\n */\n\n'use strict';\n\nmodule.exports = function (grunt) {\n  return {\n    dist: {\n      src: '<%= pkg.config.src %>/scripts/<%= pkg.config.src_name %>.js',\n      dest: '<%= pkg.config.dist %>/<%= pkg.config.src_name %>.js',\n      objectToExport: 'Chartist.plugins.tooltips',\n      deps: {\n        default: ['Chartist'],\n        amd: ['chartist'],\n        cjs: ['chartist'],\n        global: ['Chartist']\n      },\n      indent: '  '\n    }\n  };\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/test/.jshintrc",
    "content": "{\n  \"node\": true,\n  \"browser\": true,\n  \"esnext\": true,\n  \"bitwise\": true,\n  \"camelcase\": true,\n  \"curly\": true,\n  \"eqeqeq\": true,\n  \"immed\": true,\n  \"indent\": 2,\n  \"latedef\": true,\n  \"newcap\": true,\n  \"noarg\": true,\n  \"quotmark\": \"single\",\n  \"regexp\": true,\n  \"undef\": true,\n  \"unused\": true,\n  \"strict\": true,\n  \"trailing\": true,\n  \"smarttabs\": true,\n  \"globals\": {\n    \"after\": false,\n    \"afterEach\": false,\n    \"angular\": false,\n    \"before\": false,\n    \"beforeEach\": false,\n    \"browser\": false,\n    \"describe\": false,\n    \"expect\": false,\n    \"inject\": false,\n    \"it\": false,\n    \"jasmine\": false,\n    \"spyOn\": false\n  }\n}\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/test/runner.html",
    "content": "<!doctype html>\n<html lang=\"en\">\n<head>\n  <title>End2end Test Runner</title>\n</head>\n<body>\n<header class=\"page-header\">\n  <h1>Chartist.js\n    <small> Simple responsive charts</small>\n  </h1>\n  <div class=\"limiter\">\n    <figure>\n      <svg id=\"chartist-guy\"></svg>\n    </figure>\n  </div>\n</header>\n\n<article class=\"main\" role=\"main\">\n  <section class=\"documentation-section\">\n    <header>\n      <h2>Chart CSS animation example</h2>\n    </header>\n    <div class=\"content\">\n      <div class=\"chart-container\">\n        <svg id=\"chart\"></svg>\n      </div>\n    </div>\n    <aside class=\"side-notes\">\n      <p>Specifying the style of your chart in CSS is not only cleaner but also enables you to use awesome CSS\n        animations\n        and transitions to be applied to your SVG elements!</p>\n    </aside>\n  </section>\n</article>\n</body>\n</html>"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/chartist-plugin-tooltip-master/test/spec/spec-tooltip.js",
    "content": "describe('ctPointLabels', function () {\n  'use strict';\n\n  var chart;\n  var listeners;\n  var event;\n\n  beforeEach(function () {\n    listeners = {};\n    chart = {\n      container : document.createElement('div'),\n      on : function(event) {}\n    };\n    event = {\n      target: document.createElement('div')\n    };\n    event.target.className = 'ct-point';\n    event.target.setAttribute('ct:value', '42');\n    event.originalEvent = {\n      layerY: 0,\n      layerX: 0\n    };\n\n    chart.container.addEventListener = function(event, listener) {\n      listeners[event] = listener;\n    }\n\n    var tooltip = window.Chartist.plugins.tooltip({class: 'foo'});\n    tooltip(chart);\n  });\n\n  function getTooltip() {\n    return chart.container.querySelector('div.chartist-tooltip');\n  }\n\n  function hasClass(el, cls) {\n    return el.className && new RegExp(\"(\\\\s|^)\" + cls + \"(\\\\s|$)\").test(el.className);\n  }\n\n  it('should be defined in chartist', function () {\n    expect(window.Chartist.plugins.tooltip).toBeDefined();\n  });\n\n  it('should append tooltip', function() {\n    expect(getTooltip()).toBeDefined();\n  });\n\n  it('should not append tooltip twice', function() {\n    expect(getTooltip()).toBeDefined();\n    window.Chartist.plugins.tooltip()(chart);\n    var all = chart.container.querySelectorAll('div.chartist-tooltip');\n    expect(all.length).toBe(1);\n  });\n\n  it('should hide tooltip', function() {\n    expect(hasClass(getTooltip(), 'tooltip-show')).toBe(false);\n  });\n\n  it('should show tooltip on mouse enter', function() {\n    listeners['mouseover'](event);\n    expect(hasClass(getTooltip(), 'tooltip-show')).toBe(true);\n  });\n\n  it('should hide tooltip on mouse leave', function() {\n    listeners['mouseover'](event);\n    listeners['mouseout'](event);\n    expect(hasClass(getTooltip(), 'tooltip-show')).toBe(false);\n  });\n\n  it('should set tooltip text', function() {\n    listeners['mouseover'](event);\n    expect(getTooltip().innerHTML).toContain('42');\n  });\n\n  it('should set tooltip position', function() {\n    event.pageX = 100;\n    event.pageY = 200;\n    listeners['mousemove'](event);\n    expect(getTooltip().style.left).toMatch(/^\\d+px$/);\n    expect(getTooltip().style.top).toMatch(/^\\d+px$/);\n  });\n  \n  it('should set additional class', function(){\n    expect(hasClass(getTooltip(), 'foo')).toBe(true);\n  });\n});\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/API.md",
    "content": "# D3 API Reference\n\nD3 4.0 is a [collection of modules](https://github.com/d3) that are designed to work together; you can use the modules independently, or you can use them together as part of the default build. The source and documentation for each module is available in its repository. Follow the links below to learn more. For changes between 3.x and 4.0, see [CHANGES](https://github.com/d3/d3/blob/master/CHANGES.md); see also the [3.x reference](https://github.com/d3/d3-3.x-api-reference/blob/master/API-Reference.md).\n\n* [Arrays](#arrays-d3-array) ([Statistics](#statistics), [Search](#search), [Transformations](#transformations), [Histograms](#histograms))\n* [Axes](#axes-d3-axis)\n* [Brushes](#brushes-d3-brush)\n* [Chords](#chords-d3-chord)\n* [Collections](#collections-d3-collection) ([Objects](#objects), [Maps](#maps), [Sets](#sets), [Nests](#nests))\n* [Colors](#colors-d3-color)\n* [Dispatches](#dispatches-d3-dispatch)\n* [Dragging](#dragging-d3-drag)\n* [Delimiter-Separated Values](#delimiter-separated-values-d3-dsv)\n* [Easings](#easings-d3-ease)\n* [Forces](#forces-d3-force)\n* [Number Formats](#number-formats-d3-format)\n* [Geographies](#geographies-d3-geo) ([Paths](#paths), [Projections](#projections), [Spherical Math](#spherical-math), [Spherical Shapes](#spherical-shapes), [Streams](#streams), [Transforms](#transforms))\n* [Hierarchies](#hierarchies-d3-hierarchy)\n* [Interpolators](#interpolators-d3-interpolate)\n* [Paths](#paths-d3-path)\n* [Polygons](#polygons-d3-polygon)\n* [Quadtrees](#quadtrees-d3-quadtree)\n* [Queues](#queues-d3-queue)\n* [Random Numbers](#random-numbers-d3-random)\n* [Requests](#requests-d3-request)\n* [Scales](#scales-d3-scale) ([Continuous](#continuous-scales), [Sequential](#sequential-scales), [Quantize](#quantize-scales), [Ordinal](#ordinal-scales))\n* [Selections](#selections-d3-selection) ([Selecting](#selecting-elements), [Modifying](#modifying-elements), [Data](#joining-data), [Events](#handling-events), [Control](#control-flow), [Local Variables](#local-variables), [Namespaces](#namespaces))\n* [Shapes](#shapes-d3-shape) ([Arcs](#arcs), [Pies](#pies), [Lines](#lines), [Areas](#areas), [Curves](#curves), [Links](#links), [Symbols](#symbols), [Stacks](#stacks))\n* [Time Formats](#time-formats-d3-time-format)\n* [Time Intervals](#time-intervals-d3-time)\n* [Timers](#timers-d3-timer)\n* [Transitions](#transitions-d3-transition)\n* [Voronoi Diagrams](#voronoi-diagrams-d3-voronoi)\n* [Zooming](#zooming-d3-zoom)\n\nD3 uses [semantic versioning](http://semver.org/). The current version is exposed as d3.version.\n\n## [Arrays (d3-array)](https://github.com/d3/d3-array)\n\nArray manipulation, ordering, searching, summarizing, etc.\n\n### [Statistics](https://github.com/d3/d3-array/blob/master/README.md#statistics)\n\nMethods for computing basic summary statistics.\n\n* [d3.min](https://github.com/d3/d3-array/blob/master/README.md#min) - compute the minimum value in an array.\n* [d3.max](https://github.com/d3/d3-array/blob/master/README.md#max) - compute the maximum value in an array.\n* [d3.extent](https://github.com/d3/d3-array/blob/master/README.md#extent) - compute the minimum and maximum value in an array.\n* [d3.sum](https://github.com/d3/d3-array/blob/master/README.md#sum) - compute the sum of an array of numbers.\n* [d3.mean](https://github.com/d3/d3-array/blob/master/README.md#mean) - compute the arithmetic mean of an array of numbers.\n* [d3.median](https://github.com/d3/d3-array/blob/master/README.md#median) - compute the median of an array of numbers (the 0.5-quantile).\n* [d3.quantile](https://github.com/d3/d3-array/blob/master/README.md#quantile) - compute a quantile for a sorted array of numbers.\n* [d3.variance](https://github.com/d3/d3-array/blob/master/README.md#variance) - compute the variance of an array of numbers.\n* [d3.deviation](https://github.com/d3/d3-array/blob/master/README.md#deviation) - compute the standard deviation of an array of numbers.\n\n### [Search](https://github.com/d3/d3-array/blob/master/README.md#search)\n\nMethods for searching arrays for a specific element.\n\n* [d3.scan](https://github.com/d3/d3-array/blob/master/README.md#scan) - linear search for an element using a comparator.\n* [d3.bisect](https://github.com/d3/d3-array/blob/master/README.md#bisect) - binary search for a value in a sorted array.\n* [d3.bisectRight](https://github.com/d3/d3-array/blob/master/README.md#bisectRight) - binary search for a value in a sorted array.\n* [d3.bisectLeft](https://github.com/d3/d3-array/blob/master/README.md#bisectLeft) - binary search for a value in a sorted array.\n* [d3.bisector](https://github.com/d3/d3-array/blob/master/README.md#bisector) - bisect using an accessor or comparator.\n* [*bisector*.left](https://github.com/d3/d3-array/blob/master/README.md#bisector_left) - bisectLeft, with the given comparator.\n* [*bisector*.right](https://github.com/d3/d3-array/blob/master/README.md#bisector_right) - bisectRight, with the given comparator.\n* [d3.ascending](https://github.com/d3/d3-array/blob/master/README.md#ascending) - compute the natural order of two values.\n* [d3.descending](https://github.com/d3/d3-array/blob/master/README.md#descending) - compute the natural order of two values.\n\n### [Transformations](https://github.com/d3/d3-array/blob/master/README.md#transformations)\n\nMethods for transforming arrays and for generating new arrays.\n\n* [d3.cross](https://github.com/d3/d3-array/blob/master/README.md#cross) - compute the Cartesian product of two arrays.\n* [d3.merge](https://github.com/d3/d3-array/blob/master/README.md#merge) - merge multiple arrays into one array.\n* [d3.pairs](https://github.com/d3/d3-array/blob/master/README.md#pairs) - create an array of adjacent pairs of elements.\n* [d3.permute](https://github.com/d3/d3-array/blob/master/README.md#permute) - reorder an array of elements according to an array of indexes.\n* [d3.shuffle](https://github.com/d3/d3-array/blob/master/README.md#shuffle) - randomize the order of an array.\n* [d3.ticks](https://github.com/d3/d3-array/blob/master/README.md#ticks) - generate representative values from a numeric interval.\n* [d3.tickIncrement](https://github.com/d3/d3-array/blob/master/README.md#tickIncrement) - generate representative values from a numeric interval.\n* [d3.tickStep](https://github.com/d3/d3-array/blob/master/README.md#tickStep) - generate representative values from a numeric interval.\n* [d3.range](https://github.com/d3/d3-array/blob/master/README.md#range) - generate a range of numeric values.\n* [d3.transpose](https://github.com/d3/d3-array/blob/master/README.md#transpose) - transpose an array of arrays.\n* [d3.zip](https://github.com/d3/d3-array/blob/master/README.md#zip) - transpose a variable number of arrays.\n\n### [Histograms](https://github.com/d3/d3-array/blob/master/README.md#histograms)\n\nBin discrete samples into continuous, non-overlapping intervals.\n\n* [d3.histogram](https://github.com/d3/d3-array/blob/master/README.md#histogram) - create a new histogram generator.\n* [*histogram*](https://github.com/d3/d3-array/blob/master/README.md#_histogram) - compute the histogram for the given array of samples.\n* [*histogram*.value](https://github.com/d3/d3-array/blob/master/README.md#histogram_value) - specify a value accessor for each sample.\n* [*histogram*.domain](https://github.com/d3/d3-array/blob/master/README.md#histogram_domain) - specify the interval of observable values.\n* [*histogram*.thresholds](https://github.com/d3/d3-array/blob/master/README.md#histogram_thresholds) - specify how values are divided into bins.\n* [d3.thresholdFreedmanDiaconis](https://github.com/d3/d3-array/blob/master/README.md#thresholdFreedmanDiaconis) - the Freedman–Diaconis binning rule.\n* [d3.thresholdScott](https://github.com/d3/d3-array/blob/master/README.md#thresholdScott) - Scott’s normal reference binning rule.\n* [d3.thresholdSturges](https://github.com/d3/d3-array/blob/master/README.md#thresholdSturges) - Sturges’ binning formula.\n\n## [Axes (d3-axis)](https://github.com/d3/d3-axis)\n\nHuman-readable reference marks for scales.\n\n* [d3.axisTop](https://github.com/d3/d3-axis/blob/master/README.md#axisTop) - create a new top-oriented axis generator.\n* [d3.axisRight](https://github.com/d3/d3-axis/blob/master/README.md#axisRight) - create a new right-oriented axis generator.\n* [d3.axisBottom](https://github.com/d3/d3-axis/blob/master/README.md#axisBottom) - create a new bottom-oriented axis generator.\n* [d3.axisLeft](https://github.com/d3/d3-axis/blob/master/README.md#axisLeft) - create a new left-oriented axis generator.\n* [*axis*](https://github.com/d3/d3-axis/blob/master/README.md#_axis) - generate an axis for the given selection.\n* [*axis*.scale](https://github.com/d3/d3-axis/blob/master/README.md#axis_scale) - set the scale.\n* [*axis*.ticks](https://github.com/d3/d3-axis/blob/master/README.md#axis_ticks) - customize how ticks are generated and formatted.\n* [*axis*.tickArguments](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickArguments) - customize how ticks are generated and formatted.\n* [*axis*.tickValues](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickValues) - set the tick values explicitly.\n* [*axis*.tickFormat](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickFormat) - set the tick format explicitly.\n* [*axis*.tickSize](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSize) - set the size of the ticks.\n* [*axis*.tickSizeInner](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSizeInner) - set the size of inner ticks.\n* [*axis*.tickSizeOuter](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSizeOuter) - set the size of outer (extent) ticks.\n* [*axis*.tickPadding](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickPadding) - set the padding between ticks and labels.\n\n## [Brushes (d3-brush)](https://github.com/d3/d3-brush)\n\nSelect a one- or two-dimensional region using the mouse or touch.\n\n* [d3.brush](https://github.com/d3/d3-brush/blob/master/README.md#brush) - create a new two-dimensional brush.\n* [d3.brushX](https://github.com/d3/d3-brush/blob/master/README.md#brushX) - create a brush along the *x*-dimension.\n* [d3.brushY](https://github.com/d3/d3-brush/blob/master/README.md#brushY) - create a brush along the *y*-dimension.\n* [*brush*](https://github.com/d3/d3-brush/blob/master/README.md#_brush) - apply the brush to a selection.\n* [*brush*.move](https://github.com/d3/d3-brush/blob/master/README.md#brush_move) - move the brush selection.\n* [*brush*.extent](https://github.com/d3/d3-brush/blob/master/README.md#brush_extent) - define the brushable region.\n* [*brush*.filter](https://github.com/d3/d3-brush/blob/master/README.md#brush_filter) - control which input events initiate brushing.\n* [*brush*.handleSize](https://github.com/d3/d3-brush/blob/master/README.md#brush_handleSize) - set the size of the brush handles.\n* [*brush*.on](https://github.com/d3/d3-brush/blob/master/README.md#brush_on) - listen for brush events.\n* [d3.brushSelection](https://github.com/d3/d3-brush/blob/master/README.md#brushSelection) - get the brush selection for a given node.\n\n## [Chords (d3-chord)](https://github.com/d3/d3-chord)\n\n* [d3.chord](https://github.com/d3/d3-chord/blob/master/README.md#chord) - create a new chord layout.\n* [*chord*](https://github.com/d3/d3-chord/blob/master/README.md#_chord) - compute the layout for the given matrix.\n* [*chord*.padAngle](https://github.com/d3/d3-chord/blob/master/README.md#chord_padAngle) - set the padding between adjacent groups.\n* [*chord*.sortGroups](https://github.com/d3/d3-chord/blob/master/README.md#chord_sortGroups) - define the group order.\n* [*chord*.sortSubgroups](https://github.com/d3/d3-chord/blob/master/README.md#chord_sortSubgroups) - define the source and target order within groups.\n* [*chord*.sortChords](https://github.com/d3/d3-chord/blob/master/README.md#chord_sortChords) - define the chord order across groups.\n* [d3.ribbon](https://github.com/d3/d3-chord/blob/master/README.md#ribbon) - create a ribbon shape generator.\n* [*ribbon*](https://github.com/d3/d3-chord/blob/master/README.md#_ribbon) - generate a ribbon shape.\n* [*ribbon*.source](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_source) - set the source accessor.\n* [*ribbon*.target](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_target) - set the target accessor.\n* [*ribbon*.radius](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_radius) - set the ribbon source or target radius.\n* [*ribbon*.startAngle](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_startAngle) - set the ribbon source or target start angle.\n* [*ribbon*.endAngle](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_endAngle) - set the ribbon source or target end angle.\n* [*ribbon*.context](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_context) - set the render context.\n\n## [Collections (d3-collection)](https://github.com/d3/d3-collection)\n\nHandy data structures for elements keyed by string.\n\n### [Objects](https://github.com/d3/d3-collection/blob/master/README.md#objects)\n\nMethods for converting associative arrays (objects) to arrays.\n\n* [d3.keys](https://github.com/d3/d3-collection/blob/master/README.md#keys) - list the keys of an associative array.\n* [d3.values](https://github.com/d3/d3-collection/blob/master/README.md#values) - list the values of an associated array.\n* [d3.entries](https://github.com/d3/d3-collection/blob/master/README.md#entries) - list the key-value entries of an associative array.\n\n### [Maps](https://github.com/d3/d3-collection/blob/master/README.md#maps)\n\nLike ES6 Map, but with string keys and a few other differences.\n\n* [d3.map](https://github.com/d3/d3-collection/blob/master/README.md#map) - create a new, empty map.\n* [*map*.has](https://github.com/d3/d3-collection/blob/master/README.md#map_has) - returns true if the map contains the given key.\n* [*map*.get](https://github.com/d3/d3-collection/blob/master/README.md#map_get) - get the value for the given key.\n* [*map*.set](https://github.com/d3/d3-collection/blob/master/README.md#map_set) - set the value for the given key.\n* [*map*.remove](https://github.com/d3/d3-collection/blob/master/README.md#map_remove) - remove the entry for given key.\n* [*map*.clear](https://github.com/d3/d3-collection/blob/master/README.md#map_clear) - remove all entries.\n* [*map*.keys](https://github.com/d3/d3-collection/blob/master/README.md#map_keys) - get the array of keys.\n* [*map*.values](https://github.com/d3/d3-collection/blob/master/README.md#map_values) - get the array of values.\n* [*map*.entries](https://github.com/d3/d3-collection/blob/master/README.md#map_entries) - get the array of entries (key-values objects).\n* [*map*.each](https://github.com/d3/d3-collection/blob/master/README.md#map_each) - call a function for each entry.\n* [*map*.empty](https://github.com/d3/d3-collection/blob/master/README.md#map_empty) - returns false if the map has at least one entry.\n* [*map*.size](https://github.com/d3/d3-collection/blob/master/README.md#map_size) - compute the number of entries.\n\n### [Sets](https://github.com/d3/d3-collection/blob/master/README.md#sets)\n\nLike ES6 Set, but with string keys and a few other differences.\n\n* [d3.set](https://github.com/d3/d3-collection/blob/master/README.md#set) - create a new, empty set.\n* [*set*.has](https://github.com/d3/d3-collection/blob/master/README.md#set_has) - returns true if the set contains the given value.\n* [*set*.add](https://github.com/d3/d3-collection/blob/master/README.md#set_add) - add the given value.\n* [*set*.remove](https://github.com/d3/d3-collection/blob/master/README.md#set_remove) - remove the given value.\n* [*set*.clear](https://github.com/d3/d3-collection/blob/master/README.md#set_clear) - remove all values.\n* [*set*.values](https://github.com/d3/d3-collection/blob/master/README.md#set_values) - get the array of values.\n* [*set*.each](https://github.com/d3/d3-collection/blob/master/README.md#set_each) - call a function for each value.\n* [*set*.empty](https://github.com/d3/d3-collection/blob/master/README.md#set_empty) - returns true if the set has at least one value.\n* [*set*.size](https://github.com/d3/d3-collection/blob/master/README.md#set_size) - compute the number of values.\n\n### [Nests](https://github.com/d3/d3-collection/blob/master/README.md#nests)\n\nGroup data into arbitrary hierarchies.\n\n* [d3.nest](https://github.com/d3/d3-collection/blob/master/README.md#nest) - create a new nest generator.\n* [*nest*.key](https://github.com/d3/d3-collection/blob/master/README.md#nest_key) - add a level to the nest hierarchy.\n* [*nest*.sortKeys](https://github.com/d3/d3-collection/blob/master/README.md#nest_sortKeys) - sort the current nest level by key.\n* [*nest*.sortValues](https://github.com/d3/d3-collection/blob/master/README.md#nest_sortValues) - sort the leaf nest level by value.\n* [*nest*.rollup](https://github.com/d3/d3-collection/blob/master/README.md#nest_rollup) - specify a rollup function for leaf values.\n* [*nest*.map](https://github.com/d3/d3-collection/blob/master/README.md#nest_map) - generate the nest, returning a map.\n* [*nest*.object](https://github.com/d3/d3-collection/blob/master/README.md#nest_object) - generate the nest, returning an associative array.\n* [*nest*.entries](https://github.com/d3/d3-collection/blob/master/README.md#nest_entries) - generate the nest, returning an array of key-values tuples.\n\n## [Colors (d3-color)](https://github.com/d3/d3-color)\n\nColor manipulation and color space conversion.\n\n* [d3.color](https://github.com/d3/d3-color/blob/master/README.md#color) - parse the given CSS color specifier.\n* [*color*.rgb](https://github.com/d3/d3-color/blob/master/README.md#color_rgb) - compute the RGB equivalent of this color.\n* [*color*.brighter](https://github.com/d3/d3-color/blob/master/README.md#color_brighter) - create a brighter copy of this color.\n* [*color*.darker](https://github.com/d3/d3-color/blob/master/README.md#color_darker) - create a darker copy of this color.\n* [*color*.displayable](https://github.com/d3/d3-color/blob/master/README.md#color_displayable) - returns true if the color is displayable on standard hardware.\n* [*color*.toString](https://github.com/d3/d3-color/blob/master/README.md#color_toString) - format the color as an RGB hexadecimal string.\n* [d3.rgb](https://github.com/d3/d3-color/blob/master/README.md#rgb) - create a new RGB color.\n* [d3.hsl](https://github.com/d3/d3-color/blob/master/README.md#hsl) - create a new HSL color.\n* [d3.lab](https://github.com/d3/d3-color/blob/master/README.md#lab) - create a new Lab color.\n* [d3.hcl](https://github.com/d3/d3-color/blob/master/README.md#hcl) - create a new HCL color.\n* [d3.cubehelix](https://github.com/d3/d3-color/blob/master/README.md#cubehelix) - create a new Cubehelix color.\n\n## [Dispatches (d3-dispatch)](https://github.com/d3/d3-dispatch)\n\nSeparate concerns using named callbacks.\n\n* [d3.dispatch](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch) - create a custom event dispatcher.\n* [*dispatch*.on](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_on) - register or unregister an event listener.\n* [*dispatch*.copy](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_copy) - create a copy of a dispatcher.\n* [*dispatch*.*call*](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_call) - dispatch an event to registered listeners.\n* [*dispatch*.*apply*](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_apply) - dispatch an event to registered listeners.\n\n## [Dragging (d3-drag)](https://github.com/d3/d3-drag)\n\nDrag and drop SVG, HTML or Canvas using mouse or touch input.\n\n* [d3.drag](https://github.com/d3/d3-drag/blob/master/README.md#drag) - create a drag behavior.\n* [*drag*](https://github.com/d3/d3-drag/blob/master/README.md#_drag) - apply the drag behavior to a selection.\n* [*drag*.container](https://github.com/d3/d3-drag/blob/master/README.md#drag_container) - set the coordinate system.\n* [*drag*.filter](https://github.com/d3/d3-drag/blob/master/README.md#drag_filter) - ignore some initiating input events.\n* [*drag*.subject](https://github.com/d3/d3-drag/blob/master/README.md#drag_subject) - set the thing being dragged.\n* [*drag*.clickDistance](https://github.com/d3/d3-drag/blob/master/README.md#drag_clickDistance) - set the click distance threshold.\n* [*drag*.on](https://github.com/d3/d3-drag/blob/master/README.md#drag_on) - listen for drag events.\n* [*event*.on](https://github.com/d3/d3-drag/blob/master/README.md#event_on) - listen for drag events on the current gesture.\n* [d3.dragDisable](https://github.com/d3/d3-drag/blob/master/README.md#dragDisable) -\n* [d3.dragEnable](https://github.com/d3/d3-drag/blob/master/README.md#dragEnable) -\n\n## [Delimiter-Separated Values (d3-dsv)](https://github.com/d3/d3-dsv)\n\nParse and format delimiter-separated values, most commonly CSV and TSV.\n\n* [d3.dsvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#dsvFormat) - create a new parser and formatter for the given delimiter.\n* [*dsv*.parse](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_parse) - parse the given string, returning an array of objects.\n* [*dsv*.parseRows](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_parseRows) - parse the given string, returning an array of rows.\n* [*dsv*.format](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_format) - format the given array of objects.\n* [*dsv*.formatRows](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_formatRows) - format the given array of rows.\n* [d3.csvParse](https://github.com/d3/d3-dsv/blob/master/README.md#csvParse) - parse the given CSV string, returning an array of objects.\n* [d3.csvParseRows](https://github.com/d3/d3-dsv/blob/master/README.md#csvParseRows) - parse the given CSV string, returning an array of rows.\n* [d3.csvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#csvFormat) - format the given array of objects as CSV.\n* [d3.csvFormatRows](https://github.com/d3/d3-dsv/blob/master/README.md#csvFormatRows) - format the given array of rows as CSV.\n* [d3.tsvParse](https://github.com/d3/d3-dsv/blob/master/README.md#tsvParse) - parse the given TSV string, returning an array of objects.\n* [d3.tsvParseRows](https://github.com/d3/d3-dsv/blob/master/README.md#tsvParseRows) - parse the given TSV string, returning an array of rows.\n* [d3.tsvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#tsvFormat) - format the given array of objects as TSV.\n* [d3.tsvFormatRows](https://github.com/d3/d3-dsv/blob/master/README.md#tsvFormatRows) - format the given array of rows as TSV.\n\n## [Easings (d3-ease)](https://github.com/d3/d3-ease)\n\nEasing functions for smooth animation.\n\n* [*ease*](https://github.com/d3/d3-ease/blob/master/README.md#_ease) - ease the given normalized time.\n* [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear) - linear easing; the identity function.\n* [d3.easePolyIn](https://github.com/d3/d3-ease/blob/master/README.md#easePolyIn) - polynomial easing; raises time to the given power.\n* [d3.easePolyOut](https://github.com/d3/d3-ease/blob/master/README.md#easePolyOut) - reverse polynomial easing.\n* [d3.easePolyInOut](https://github.com/d3/d3-ease/blob/master/README.md#easePolyInOut) - symmetric polynomial easing.\n* [*poly*.exponent](https://github.com/d3/d3-ease/blob/master/README.md#poly_exponent) - specify the polynomial exponent.\n* [d3.easeQuad](https://github.com/d3/d3-ease/blob/master/README.md#easeQuad) - an alias for easeQuadInOut.\n* [d3.easeQuadIn](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadIn) - quadratic easing; squares time.\n* [d3.easeQuadOut](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadOut) - reverse quadratic easing.\n* [d3.easeQuadInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadInOut) - symmetric quadratic easing.\n* [d3.easeCubic](https://github.com/d3/d3-ease/blob/master/README.md#easeCubic) - an alias for easeCubicInOut.\n* [d3.easeCubicIn](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicIn) - cubic easing; cubes time.\n* [d3.easeCubicOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicOut) - reverse cubic easing.\n* [d3.easeCubicInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicInOut) - symmetric cubic easing.\n* [d3.easeSin](https://github.com/d3/d3-ease/blob/master/README.md#easeSin) - an alias for easeSinInOut.\n* [d3.easeSinIn](https://github.com/d3/d3-ease/blob/master/README.md#easeSinIn) - sinusoidal easing.\n* [d3.easeSinOut](https://github.com/d3/d3-ease/blob/master/README.md#easeSinOut) - reverse sinusoidal easing.\n* [d3.easeSinInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeSinInOut) - symmetric sinusoidal easing.\n* [d3.easeExp](https://github.com/d3/d3-ease/blob/master/README.md#easeExp) - an alias for easeExpInOut.\n* [d3.easeExpIn](https://github.com/d3/d3-ease/blob/master/README.md#easeExpIn) - exponential easing.\n* [d3.easeExpOut](https://github.com/d3/d3-ease/blob/master/README.md#easeExpOut) - reverse exponential easing.\n* [d3.easeExpInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeExpInOut) - symmetric exponential easing.\n* [d3.easeCircle](https://github.com/d3/d3-ease/blob/master/README.md#easeCircle) - an alias for easeCircleInOut.\n* [d3.easeCircleIn](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleIn) - circular easing.\n* [d3.easeCircleOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleOut) - reverse circular easing.\n* [d3.easeCircleInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleInOut) - symmetric circular easing.\n* [d3.easeElastic](https://github.com/d3/d3-ease/blob/master/README.md#easeElastic) - an alias for easeElasticOut.\n* [d3.easeElasticIn](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticIn) - elastic easing, like a rubber band.\n* [d3.easeElasticOut](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticOut) - reverse elastic easing.\n* [d3.easeElasticInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticInOut) - symmetric elastic easing.\n* [*elastic*.amplitude](https://github.com/d3/d3-ease/blob/master/README.md#elastic_amplitude) - specify the elastic amplitude.\n* [*elastic*.period](https://github.com/d3/d3-ease/blob/master/README.md#elastic_period) - specify the elastic period.\n* [d3.easeBack](https://github.com/d3/d3-ease/blob/master/README.md#easeBack) - an alias for easeBackInOut.\n* [d3.easeBackIn](https://github.com/d3/d3-ease/blob/master/README.md#easeBackIn) - anticipatory easing, like a dancer bending his knees before jumping.\n* [d3.easeBackOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBackOut) - reverse anticipatory easing.\n* [d3.easeBackInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBackInOut) - symmetric anticipatory easing.\n* [*back*.overshoot](https://github.com/d3/d3-ease/blob/master/README.md#back_overshoot) - specify the amount of overshoot.\n* [d3.easeBounce](https://github.com/d3/d3-ease/blob/master/README.md#easeBounce) - an alias for easeBounceOut.\n* [d3.easeBounceIn](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceIn) - bounce easing, like a rubber ball.\n* [d3.easeBounceOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceOut) - reverse bounce easing.\n* [d3.easeBounceInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceInOut) - symmetric bounce easing.\n\n## [Forces (d3-force)](https://github.com/d3/d3-force)\n\nForce-directed graph layout using velocity Verlet integration.\n\n* [d3.forceSimulation](https://github.com/d3/d3-force/blob/master/README.md#forceSimulation) - create a new force simulation.\n* [*simulation*.restart](https://github.com/d3/d3-force/blob/master/README.md#simulation_restart) - reheat and restart the simulation’s timer.\n* [*simulation*.stop](https://github.com/d3/d3-force/blob/master/README.md#simulation_stop) - stop the simulation’s timer.\n* [*simulation*.tick](https://github.com/d3/d3-force/blob/master/README.md#simulation_tick) - advance the simulation one step.\n* [*simulation*.nodes](https://github.com/d3/d3-force/blob/master/README.md#simulation_nodes) - set the simulation’s nodes.\n* [*simulation*.alpha](https://github.com/d3/d3-force/blob/master/README.md#simulation_alpha) - set the current alpha.\n* [*simulation*.alphaMin](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaMin) - set the minimum alpha threshold.\n* [*simulation*.alphaDecay](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaDecay) - set the alpha exponential decay rate.\n* [*simulation*.alphaTarget](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaTarget) - set the target alpha.\n* [*simulation*.velocityDecay](https://github.com/d3/d3-force/blob/master/README.md#simulation_velocityDecay) - set the velocity decay rate.\n* [*simulation*.force](https://github.com/d3/d3-force/blob/master/README.md#simulation_force) - add or remove a force.\n* [*simulation*.find](https://github.com/d3/d3-force/blob/master/README.md#simulation_find) - find the closest node to the given position.\n* [*simulation*.on](https://github.com/d3/d3-force/blob/master/README.md#simulation_on) - add or remove an event listener.\n* [*force*](https://github.com/d3/d3-force/blob/master/README.md#_force) - apply the force.\n* [*force*.initialize](https://github.com/d3/d3-force/blob/master/README.md#force_initialize) - initialize the force with the given nodes.\n* [d3.forceCenter](https://github.com/d3/d3-force/blob/master/README.md#forceCenter) - create a centering force.\n* [*center*.x](https://github.com/d3/d3-force/blob/master/README.md#center_x) - set the center *x*-coordinate.\n* [*center*.y](https://github.com/d3/d3-force/blob/master/README.md#center_y) - set the center *y*-coordinate.\n* [d3.forceCollide](https://github.com/d3/d3-force/blob/master/README.md#forceCollide) - create a circle collision force.\n* [*collide*.radius](https://github.com/d3/d3-force/blob/master/README.md#collide_radius) - set the circle radius.\n* [*collide*.strength](https://github.com/d3/d3-force/blob/master/README.md#collide_strength) - set the collision resolution strength.\n* [*collide*.iterations](https://github.com/d3/d3-force/blob/master/README.md#collide_iterations) - set the number of iterations.\n* [d3.forceLink](https://github.com/d3/d3-force/blob/master/README.md#forceLink) - create a link force.\n* [*link*.links](https://github.com/d3/d3-force/blob/master/README.md#link_links) - set the array of links.\n* [*link*.id](https://github.com/d3/d3-force/blob/master/README.md#link_id) - link nodes by numeric index or string identifier.\n* [*link*.distance](https://github.com/d3/d3-force/blob/master/README.md#link_distance) - set the link distance.\n* [*link*.strength](https://github.com/d3/d3-force/blob/master/README.md#link_strength) - set the link strength.\n* [*link*.iterations](https://github.com/d3/d3-force/blob/master/README.md#link_iterations) - set the number of iterations.\n* [d3.forceManyBody](https://github.com/d3/d3-force/blob/master/README.md#forceManyBody) - create a many-body force.\n* [*manyBody*.strength](https://github.com/d3/d3-force/blob/master/README.md#manyBody_strength) - set the force strength.\n* [*manyBody*.theta](https://github.com/d3/d3-force/blob/master/README.md#manyBody_theta) - set the Barnes–Hut approximation accuracy.\n* [*manyBody*.distanceMin](https://github.com/d3/d3-force/blob/master/README.md#manyBody_distanceMin) - limit the force when nodes are close.\n* [*manyBody*.distanceMax](https://github.com/d3/d3-force/blob/master/README.md#manyBody_distanceMax) - limit the force when nodes are far.\n* [d3.forceX](https://github.com/d3/d3-force/blob/master/README.md#forceX) - create an *x*-positioning force.\n* [*x*.strength](https://github.com/d3/d3-force/blob/master/README.md#x_strength) - set the force strength.\n* [*x*.x](https://github.com/d3/d3-force/blob/master/README.md#x_x) - set the target *x*-coordinate.\n* [d3.forceY](https://github.com/d3/d3-force/blob/master/README.md#forceY) - create an *y*-positioning force.\n* [*y*.strength](https://github.com/d3/d3-force/blob/master/README.md#y_strength) - set the force strength.\n* [*y*.y](https://github.com/d3/d3-force/blob/master/README.md#y_y) - set the target *y*-coordinate.\n\n## [Number Formats (d3-format)](https://github.com/d3/d3-format)\n\nFormat numbers for human consumption.\n\n* [d3.format](https://github.com/d3/d3-format/blob/master/README.md#format) - alias for *locale*.format on the default locale.\n* [d3.formatPrefix](https://github.com/d3/d3-format/blob/master/README.md#formatPrefix) - alias for *locale*.formatPrefix on the default locale.\n* [d3.formatSpecifier](https://github.com/d3/d3-format/blob/master/README.md#formatSpecifier) - parse a number format specifier.\n* [d3.formatLocale](https://github.com/d3/d3-format/blob/master/README.md#formatLocale) - define a custom locale.\n* [d3.formatDefaultLocale](https://github.com/d3/d3-format/blob/master/README.md#formatDefaultLocale) - define the default locale.\n* [*locale*.format](https://github.com/d3/d3-format/blob/master/README.md#locale_format) - create a number format.\n* [*locale*.formatPrefix](https://github.com/d3/d3-format/blob/master/README.md#locale_formatPrefix) - create a SI-prefix number format.\n* [d3.precisionFixed](https://github.com/d3/d3-format/blob/master/README.md#precisionFixed) - compute decimal precision for fixed-point notation.\n* [d3.precisionPrefix](https://github.com/d3/d3-format/blob/master/README.md#precisionPrefix) - compute decimal precision for SI-prefix notation.\n* [d3.precisionRound](https://github.com/d3/d3-format/blob/master/README.md#precisionRound) - compute significant digits for rounded notation.\n\n## [Geographies (d3-geo)](https://github.com/d3/d3-geo)\n\nGeographic projections, shapes and math.\n\n### [Paths](https://github.com/d3/d3-geo/blob/master/README.md#paths)\n\n* [d3.geoPath](https://github.com/d3/d3-geo/blob/master/README.md#geoPath) - create a new geographic path generator.\n* [*path*](https://github.com/d3/d3-geo/blob/master/README.md#_path) - project and render the specified feature.\n* [*path*.area](https://github.com/d3/d3-geo/blob/master/README.md#path_area) - compute the projected planar area of a given feature.\n* [*path*.bounds](https://github.com/d3/d3-geo/blob/master/README.md#path_bounds) - compute the projected planar bounding box of a given feature.\n* [*path*.centroid](https://github.com/d3/d3-geo/blob/master/README.md#path_centroid) - compute the projected planar centroid of a given feature.\n* [*path*.measure](https://github.com/d3/d3-geo/blob/master/README.md#path_measure) - compute the projected planar length of a given feature.\n* [*path*.projection](https://github.com/d3/d3-geo/blob/master/README.md#path_projection) - set the geographic projection.\n* [*path*.context](https://github.com/d3/d3-geo/blob/master/README.md#path_context) - set the render context.\n* [*path*.pointRadius](https://github.com/d3/d3-geo/blob/master/README.md#path_pointRadius) - set the radius to display point features.\n\n### [Projections](https://github.com/d3/d3-geo/blob/master/README.md#projections)\n\n* [*projection*](https://github.com/d3/d3-geo/blob/master/README.md#_projection) - project the specified point from the sphere to the plane.\n* [*projection*.invert](https://github.com/d3/d3-geo/blob/master/README.md#projection_invert) - unproject the specified point from the plane to the sphere.\n* [*projection*.stream](https://github.com/d3/d3-geo/blob/master/README.md#projection_stream) - wrap the specified stream to project geometry.\n* [*projection*.clipAngle](https://github.com/d3/d3-geo/blob/master/README.md#projection_clipAngle) - set the radius of the clip circle.\n* [*projection*.clipExtent](https://github.com/d3/d3-geo/blob/master/README.md#projection_clipExtent) - set the viewport clip extent, in pixels.\n* [*projection*.scale](https://github.com/d3/d3-geo/blob/master/README.md#projection_scale) - set the scale factor.\n* [*projection*.translate](https://github.com/d3/d3-geo/blob/master/README.md#projection_translate) - set the translation offset.\n* [*projection*.fitExtent](https://github.com/d3/d3-geo/blob/master/README.md#projection_fitExtent) - set the scale and translate to fit a GeoJSON object.\n* [*projection*.fitSize](https://github.com/d3/d3-geo/blob/master/README.md#projection_fitSize) - set the scale and translate to fit a GeoJSON object.\n* [*projection*.center](https://github.com/d3/d3-geo/blob/master/README.md#projection_center) - set the center point.\n* [*projection*.rotate](https://github.com/d3/d3-geo/blob/master/README.md#projection_rotate) - set the three-axis spherical rotation angles.\n* [*projection*.precision](https://github.com/d3/d3-geo/blob/master/README.md#projection_precision) - set the precision threshold for adaptive sampling.\n* [d3.geoAlbers](https://github.com/d3/d3-geo/blob/master/README.md#geoAlbers) - the Albers equal-area conic projection.\n* [d3.geoAlbersUsa](https://github.com/d3/d3-geo/blob/master/README.md#geoAlbersUsa) - a composite Albers projection for the United States.\n* [d3.geoAzimuthalEqualArea](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEqualArea) - the azimuthal equal-area projection.\n* [d3.geoAzimuthalEquidistant](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEquidistant) - the azimuthal equidistant projection.\n* [d3.geoConicConformal](https://github.com/d3/d3-geo/blob/master/README.md#geoConicConformal) - the conic conformal projection.\n* [d3.geoConicEqualArea](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEqualArea) - the conic equal-area (Albers) projection.\n* [d3.geoConicEquidistant](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEquidistant) - the conic equidistant projection.\n* [*conic*.parallels](https://github.com/d3/d3-geo/blob/master/README.md#conic_parallels) - set the two standard parallels.\n* [d3.geoEquirectangular](https://github.com/d3/d3-geo/blob/master/README.md#geoEquirectangular) - the equirectangular (plate carreé) projection.\n* [d3.geoGnomonic](https://github.com/d3/d3-geo/blob/master/README.md#geoGnomonic) - the gnomonic projection.\n* [d3.geoMercator](https://github.com/d3/d3-geo/blob/master/README.md#geoMercator) - the spherical Mercator projection.\n* [d3.geoOrthographic](https://github.com/d3/d3-geo/blob/master/README.md#geoOrthographic) - the azimuthal orthographic projection.\n* [d3.geoStereographic](https://github.com/d3/d3-geo/blob/master/README.md#geoStereographic) - the azimuthal stereographic projection.\n* [d3.geoTransverseMercator](https://github.com/d3/d3-geo/blob/master/README.md#geoTransverseMercator) - the transverse spherical Mercator projection.\n* [*project*](https://github.com/d3/d3-geo/blob/master/README.md#_project) - project the specified point from the sphere to the plane.\n* [*project*.invert](https://github.com/d3/d3-geo/blob/master/README.md#project_invert) - unproject the specified point from the plane to the sphere.\n* [d3.geoProjection](https://github.com/d3/d3-geo/blob/master/README.md#geoProjection) - create a custom projection.\n* [d3.geoProjectionMutator](https://github.com/d3/d3-geo/blob/master/README.md#geoProjectionMutator) - create a custom configurable projection.\n* [d3.geoAzimuthalEqualAreaRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEqualAreaRaw) -\n* [d3.geoAzimuthalEquidistantRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEquidistantRaw) -\n* [d3.geoConicConformalRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoConicConformalRaw) -\n* [d3.geoConicEqualAreaRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEqualAreaRaw) -\n* [d3.geoConicEquidistantRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEquidistantRaw) -\n* [d3.geoEquirectangularRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoEquirectangularRaw) -\n* [d3.geoGnomonicRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoGnomonicRaw) -\n* [d3.geoMercatorRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoMercatorRaw) -\n* [d3.geoOrthographicRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoOrthographicRaw) -\n* [d3.geoStereographicRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoStereographicRaw) -\n* [d3.geoTransverseMercatorRaw](https://github.com/d3/d3-geo/blob/master/README.md#geoTransverseMercatorRaw) -\n\n### [Spherical Math](https://github.com/d3/d3-geo/blob/master/README.md#spherical-math)\n\n* [d3.geoArea](https://github.com/d3/d3-geo/blob/master/README.md#geoArea) - compute the spherical area of a given feature.\n* [d3.geoBounds](https://github.com/d3/d3-geo/blob/master/README.md#geoBounds) - compute the latitude-longitude bounding box for a given feature.\n* [d3.geoCentroid](https://github.com/d3/d3-geo/blob/master/README.md#geoCentroid) - compute the spherical centroid of a given feature.\n* [d3.geoContains](https://github.com/d3/d3-geo/blob/master/README.md#geoContains) - test whether a point is inside a given feature.\n* [d3.geoDistance](https://github.com/d3/d3-geo/blob/master/README.md#geoDistance) - compute the great-arc distance between two points.\n* [d3.geoLength](https://github.com/d3/d3-geo/blob/master/README.md#geoLength) - compute the length of a line string or the perimeter of a polygon.\n* [d3.geoInterpolate](https://github.com/d3/d3-geo/blob/master/README.md#geoInterpolate) - interpolate between two points along a great arc.\n* [d3.geoRotation](https://github.com/d3/d3-geo/blob/master/README.md#geoRotation) - create a rotation function for the specified angles.\n* [*rotation*](https://github.com/d3/d3-geo/blob/master/README.md#_rotation) - rotate the given point around the sphere.\n* [*rotation*.invert](https://github.com/d3/d3-geo/blob/master/README.md#rotation_invert) - unrotate the given point around the sphere.\n\n### [Spherical Shapes](https://github.com/d3/d3-geo/blob/master/README.md#spherical-shapes)\n\n* [d3.geoCircle](https://github.com/d3/d3-geo/blob/master/README.md#geoCircle) - create a circle generator.\n* [*circle*](https://github.com/d3/d3-geo/blob/master/README.md#_circle) - generate a piecewise circle as a Polygon.\n* [*circle*.center](https://github.com/d3/d3-geo/blob/master/README.md#circle_center) - specify the circle center in latitude and longitude.\n* [*circle*.radius](https://github.com/d3/d3-geo/blob/master/README.md#circle_radius) - specify the angular radius in degrees.\n* [*circle*.precision](https://github.com/d3/d3-geo/blob/master/README.md#circle_precision) - specify the precision of the piecewise circle.\n* [d3.geoGraticule](https://github.com/d3/d3-geo/blob/master/README.md#geoGraticule) - create a graticule generator.\n* [*graticule*](https://github.com/d3/d3-geo/blob/master/README.md#_graticule) - generate a MultiLineString of meridians and parallels.\n* [*graticule*.lines](https://github.com/d3/d3-geo/blob/master/README.md#graticule_lines) - generate an array of LineStrings of meridians and parallels.\n* [*graticule*.outline](https://github.com/d3/d3-geo/blob/master/README.md#graticule_outline) - generate a Polygon of the graticule’s extent.\n* [*graticule*.extent](https://github.com/d3/d3-geo/blob/master/README.md#graticule_extent) - get or set the major & minor extents.\n* [*graticule*.extentMajor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_extentMajor) - get or set the major extent.\n* [*graticule*.extentMinor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_extentMinor) - get or set the minor extent.\n* [*graticule*.step](https://github.com/d3/d3-geo/blob/master/README.md#graticule_step) - get or set the major & minor step intervals.\n* [*graticule*.stepMajor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_stepMajor) - get or set the major step intervals.\n* [*graticule*.stepMinor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_stepMinor) - get or set the minor step intervals.\n* [*graticule*.precision](https://github.com/d3/d3-geo/blob/master/README.md#graticule_precision) - get or set the latitudinal precision.\n* [d3.geoGraticule10](https://github.com/d3/d3-geo/blob/master/README.md#geoGraticule10) - generate the default 10° global graticule.\n\n#### [Streams](https://github.com/d3/d3-geo/blob/master/README.md#streams)\n\n* [d3.geoStream](https://github.com/d3/d3-geo/blob/master/README.md#geoStream) - convert a GeoJSON object to a geometry stream.\n* [*stream*.point](https://github.com/d3/d3-geo/blob/master/README.md#stream_point) -\n* [*stream*.lineStart](https://github.com/d3/d3-geo/blob/master/README.md#stream_lineStart) -\n* [*stream*.lineEnd](https://github.com/d3/d3-geo/blob/master/README.md#stream_lineEnd) -\n* [*stream*.polygonStart](https://github.com/d3/d3-geo/blob/master/README.md#stream_polygonStart) -\n* [*stream*.polygonEnd](https://github.com/d3/d3-geo/blob/master/README.md#stream_polygonEnd) -\n* [*stream*.sphere](https://github.com/d3/d3-geo/blob/master/README.md#stream_sphere) -\n\n### [Transforms](https://github.com/d3/d3-geo/blob/master/README.md#transforms)\n\n* [d3.geoIdentity](https://github.com/d3/d3-geo/blob/master/README.md#geoIdentity) - scale, translate or clip planar geometry.\n* [*identity*.reflectX](https://github.com/d3/d3-geo/blob/master/README.md#identity_reflectX) - reflect the *x*-dimension.\n* [*identity*.reflectY](https://github.com/d3/d3-geo/blob/master/README.md#identity_reflectY) - reflect the *y*-dimension.\n* [d3.geoTransform](https://github.com/d3/d3-geo/blob/master/README.md#geoTransform) - define a custom geometry transform.\n\n## [Hierarchies (d3-hierarchy)](https://github.com/d3/d3-hierarchy)\n\nLayout algorithms for visualizing hierarchical data.\n\n* [d3.hierarchy](https://github.com/d3/d3-hierarchy/blob/master/README.md#hierarchy) - constructs a root node from hierarchical data.\n* [*node*.ancestors](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_ancestors) - generate an array of ancestors.\n* [*node*.descendants](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_descendants) - generate an array of descendants.\n* [*node*.leaves](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_leaves) - generate an array of leaves.\n* [*node*.path](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_path) - generate the shortest path to another node.\n* [*node*.links](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_links) - generate an array of links.\n* [*node*.sum](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_sum) - evaluate and aggregate quantitative values.\n* [*node*.sort](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_sort) - sort all descendant siblings.\n* [*node*.count](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_count) - count the number of leaves.\n* [*node*.each](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_each) - breadth-first traversal.\n* [*node*.eachAfter](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_eachAfter) - post-order traversal.\n* [*node*.eachBefore](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_eachBefore) - pre-order traversal.\n* [*node*.copy](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_copy) - copy a hierarchy.\n* [d3.stratify](https://github.com/d3/d3-hierarchy/blob/master/README.md#stratify) - create a new stratify operator.\n* [*stratify*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_stratify) - construct a root node from tabular data.\n* [*stratify*.id](https://github.com/d3/d3-hierarchy/blob/master/README.md#stratify_id) - set the node id accessor.\n* [*stratify*.parentId](https://github.com/d3/d3-hierarchy/blob/master/README.md#stratify_parentId) - set the parent node id accessor.\n* [d3.cluster](https://github.com/d3/d3-hierarchy/blob/master/README.md#cluster) - create a new cluster (dendrogram) layout.\n* [*cluster*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_cluster) - layout the specified hierarchy in a dendrogram.\n* [*cluster*.size](https://github.com/d3/d3-hierarchy/blob/master/README.md#cluster_size) - set the layout size.\n* [*cluster*.nodeSize](https://github.com/d3/d3-hierarchy/blob/master/README.md#cluster_nodeSize) - set the node size.\n* [*cluster*.separation](https://github.com/d3/d3-hierarchy/blob/master/README.md#cluster_separation) - set the separation between leaves.\n* [d3.tree](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree) - create a new tidy tree layout.\n* [*tree*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_tree) - layout the specified hierarchy in a tidy tree.\n* [*tree*.size](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree_size) - set the layout size.\n* [*tree*.nodeSize](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree_nodeSize) - set the node size.\n* [*tree*.separation](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree_separation) - set the separation between nodes.\n* [d3.treemap](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap) - create a new treemap layout.\n* [*treemap*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_treemap) - layout the specified hierarchy as a treemap.\n* [*treemap*.tile](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_tile) - set the tiling method.\n* [*treemap*.size](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_size) - set the layout size.\n* [*treemap*.round](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_round) - set whether the output coordinates are rounded.\n* [*treemap*.padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_padding) - set the padding.\n* [*treemap*.paddingInner](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingInner) - set the padding between siblings.\n* [*treemap*.paddingOuter](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingOuter) - set the padding between parent and children.\n* [*treemap*.paddingTop](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingTop) - set the padding between the parent’s top edge and children.\n* [*treemap*.paddingRight](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingRight) - set the padding between the parent’s right edge and children.\n* [*treemap*.paddingBottom](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingBottom) - set the padding between the parent’s bottom edge and children.\n* [*treemap*.paddingLeft](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingLeft) - set the padding between the parent’s left edge and children.\n* [d3.treemapBinary](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapBinary) - tile using a balanced binary tree.\n* [d3.treemapDice](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapDice) - tile into a horizontal row.\n* [d3.treemapSlice](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapSlice) - tile into a vertical column.\n* [d3.treemapSliceDice](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapSliceDice) - alternate between slicing and dicing.\n* [d3.treemapSquarify](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapSquarify) - tile using squarified rows per Bruls *et. al.*\n* [d3.treemapResquarify](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapResquarify) - like d3.treemapSquarify, but performs stable updates.\n* [*squarify*.ratio](https://github.com/d3/d3-hierarchy/blob/master/README.md#squarify_ratio) - set the desired rectangle aspect ratio.\n* [d3.partition](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition) - create a new partition (icicle or sunburst) layout.\n* [*partition*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_partition) - layout the specified hierarchy as a partition diagram.\n* [*partition*.size](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition_size) - set the layout size.\n* [*partition*.round](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition_round) - set whether the output coordinates are rounded.\n* [*partition*.padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition_padding) - set the padding.\n* [d3.pack](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack) - create a new circle-packing layout.\n* [*pack*](https://github.com/d3/d3-hierarchy/blob/master/README.md#_pack) - layout the specified hierarchy using circle-packing.\n* [*pack*.radius](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack_radius) - set the radius accessor.\n* [*pack*.size](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack_size) - set the layout size.\n* [*pack*.padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack_padding) - set the padding.\n* [d3.packSiblings](https://github.com/d3/d3-hierarchy/blob/master/README.md#packSiblings) - pack the specified array of circles.\n* [d3.packEnclose](https://github.com/d3/d3-hierarchy/blob/master/README.md#packEnclose) - enclose the specified array of circles.\n\n## [Interpolators (d3-interpolate)](https://github.com/d3/d3-interpolate)\n\nInterpolate numbers, colors, strings, arrays, objects, whatever!\n\n* [d3.interpolate](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolate) - interpolate arbitrary values.\n* [d3.interpolateArray](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateArray) - interpolate arrays of arbitrary values.\n* [d3.interpolateDate](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateDate) - interpolate dates.\n* [d3.interpolateNumber](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateNumber) - interpolate numbers.\n* [d3.interpolateObject](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateObject) - interpolate arbitrary objects.\n* [d3.interpolateRound](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRound) - interpolate integers.\n* [d3.interpolateString](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateString) - interpolate strings with embedded numbers.\n* [d3.interpolateTransformCss](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformCss) - interpolate 2D CSS transforms.\n* [d3.interpolateTransformSvg](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformSvg) - interpolate 2D SVG transforms.\n* [d3.interpolateZoom](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateZoom) - zoom and pan between two views.\n* [d3.interpolateRgb](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgb) - interpolate RGB colors.\n* [d3.interpolateRgbBasis](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgbBasis) - generate a B-spline through a set of colors.\n* [d3.interpolateRgbBasisClosed](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgbBasisClosed) - generate a closed B-spline through a set of colors.\n* [d3.interpolateHsl](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHsl) - interpolate HSL colors.\n* [d3.interpolateHslLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHslLong) - interpolate HSL colors, the long way.\n* [d3.interpolateLab](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateLab) - interpolate Lab colors.\n* [d3.interpolateHcl](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHcl) - interpolate HCL colors.\n* [d3.interpolateHclLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHclLong) - interpolate HCL colors, the long way.\n* [d3.interpolateCubehelix](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateCubehelix) - interpolate Cubehelix colors.\n* [d3.interpolateCubehelixLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateCubehelixLong) - interpolate Cubehelix colors, the long way.\n* [*interpolate*.gamma](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolate_gamma) - apply gamma correction during interpolation.\n* [d3.interpolateBasis](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateBasis) - generate a B-spline through a set of values.\n* [d3.interpolateBasisClosed](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateBasisClosed) - generate a closed B-spline through a set of values.\n* [d3.quantize](https://github.com/d3/d3-interpolate/blob/master/README.md#quantize) - generate uniformly-spaced samples from an interpolator.\n\n## [Paths (d3-path)](https://github.com/d3/d3-path)\n\nSerialize Canvas path commands to SVG.\n\n* [d3.path](https://github.com/d3/d3-path/blob/master/README.md#path) - create a new path serializer.\n* [*path*.moveTo](https://github.com/d3/d3-path/blob/master/README.md#path_moveTo) - move to the given point.\n* [*path*.closePath](https://github.com/d3/d3-path/blob/master/README.md#path_closePath) - close the current subpath.\n* [*path*.lineTo](https://github.com/d3/d3-path/blob/master/README.md#path_lineTo) - draw a straight line segment.\n* [*path*.quadraticCurveTo](https://github.com/d3/d3-path/blob/master/README.md#path_quadraticCurveTo) - draw a quadratic Bézier segment.\n* [*path*.bezierCurveTo](https://github.com/d3/d3-path/blob/master/README.md#path_bezierCurveTo) - draw a cubic Bézier segment.\n* [*path*.arcTo](https://github.com/d3/d3-path/blob/master/README.md#path_arcTo) - draw a circular arc segment.\n* [*path*.arc](https://github.com/d3/d3-path/blob/master/README.md#path_arc) - draw a circular arc segment.\n* [*path*.rect](https://github.com/d3/d3-path/blob/master/README.md#path_rect) - draw a rectangle.\n* [*path*.toString](https://github.com/d3/d3-path/blob/master/README.md#path_toString) - serialize to an SVG path data string.\n\n## [Polygons (d3-polygon)](https://github.com/d3/d3-polygon)\n\nGeometric operations for two-dimensional polygons.\n\n* [d3.polygonArea](https://github.com/d3/d3-polygon/blob/master/README.md#polygonArea) - compute the area of the given polygon.\n* [d3.polygonCentroid](https://github.com/d3/d3-polygon/blob/master/README.md#polygonCentroid) - compute the centroid of the given polygon.\n* [d3.polygonHull](https://github.com/d3/d3-polygon/blob/master/README.md#polygonHull) - compute the convex hull of the given points.\n* [d3.polygonContains](https://github.com/d3/d3-polygon/blob/master/README.md#polygonContains) - test whether a point is inside a polygon.\n* [d3.polygonLength](https://github.com/d3/d3-polygon/blob/master/README.md#polygonLength) - compute the length of the given polygon’s perimeter.\n\n## [Quadtrees (d3-quadtree)](https://github.com/d3/d3-quadtree)\n\nTwo-dimensional recursive spatial subdivision.\n\n* [d3.quadtree](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree) - create a new, empty quadtree.\n* [*quadtree*.x](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_x) - set the *x* accessor.\n* [*quadtree*.y](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_y) - set the *y* accessor.\n* [*quadtree*.add](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_add) - add a datum to a quadtree.\n* [*quadtree*.addAll](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_addAll) -\n* [*quadtree*.remove](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_remove) - remove a datum from a quadtree.\n* [*quadtree*.removeAll](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_removeAll) -\n* [*quadtree*.copy](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_copy) - create a copy of a quadtree.\n* [*quadtree*.root](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_root) - get the quadtree’s root node.\n* [*quadtree*.data](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_data) - retrieve all data from the quadtree.\n* [*quadtree*.size](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_size) - count the number of data in the quadtree.\n* [*quadtree*.find](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_find) - quickly find the closest datum in a quadtree.\n* [*quadtree*.visit](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_visit) - selectively visit nodes in a quadtree.\n* [*quadtree*.visitAfter](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_visitAfter) - visit all nodes in a quadtree.\n* [*quadtree*.cover](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_cover) - extend the quadtree to cover a point.\n* [*quadtree*.extent](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_extent) - extend the quadtree to cover an extent.\n\n## [Queues (d3-queue)](https://github.com/d3/d3-queue)\n\nEvaluate asynchronous tasks with configurable concurrency.\n\n* [d3.queue](https://github.com/d3/d3-queue/blob/master/README.md#queue) - manage the concurrent evaluation of asynchronous tasks.\n* [*queue*.defer](https://github.com/d3/d3-queue/blob/master/README.md#queue_defer) - register a task for evaluation.\n* [*queue*.abort](https://github.com/d3/d3-queue/blob/master/README.md#queue_abort) - abort any active tasks and cancel any pending ones.\n* [*queue*.await](https://github.com/d3/d3-queue/blob/master/README.md#queue_await) - register a callback for when tasks complete.\n* [*queue*.awaitAll](https://github.com/d3/d3-queue/blob/master/README.md#queue_awaitAll) - register a callback for when tasks complete.\n\n## [Random Numbers (d3-random)](https://github.com/d3/d3-random)\n\nGenerate random numbers from various distributions.\n\n* [d3.randomUniform](https://github.com/d3/d3-random/blob/master/README.md#randomUniform) - from a uniform distribution.\n* [d3.randomNormal](https://github.com/d3/d3-random/blob/master/README.md#randomNormal) - from a normal distribution.\n* [d3.randomLogNormal](https://github.com/d3/d3-random/blob/master/README.md#randomLogNormal) - from a log-normal distribution.\n* [d3.randomBates](https://github.com/d3/d3-random/blob/master/README.md#randomBates) - from a Bates distribution.\n* [d3.randomIrwinHall](https://github.com/d3/d3-random/blob/master/README.md#randomIrwinHall) - from an Irwin–Hall distribution.\n* [d3.randomExponential](https://github.com/d3/d3-random/blob/master/README.md#randomExponential) - from an exponential distribution.\n* [*random*.source](https://github.com/d3/d3-random/blob/master/README.md#random_source) - set the source of randomness.\n\n## [Requests (d3-request)](https://github.com/d3/d3-request)\n\nA convenient alternative to asynchronous XMLHttpRequest.\n\n* [d3.request](https://github.com/d3/d3-request/blob/master/README.md#request) - make an asynchronous request.\n* [*request*.header](https://github.com/d3/d3-request/blob/master/README.md#request_header) - set a request header.\n* [*request*.user](https://github.com/d3/d3-request/blob/master/README.md#request_user) - set the user for authentication.\n* [*request*.password](https://github.com/d3/d3-request/blob/master/README.md#request_password) - set the password for authentication.\n* [*request*.mimeType](https://github.com/d3/d3-request/blob/master/README.md#request_mimeType) - set the MIME type.\n* [*request*.timeout](https://github.com/d3/d3-request/blob/master/README.md#request_timeout) - set the timeout in milliseconds.\n* [*request*.responseType](https://github.com/d3/d3-request/blob/master/README.md#request_responseType) - set the response type.\n* [*request*.response](https://github.com/d3/d3-request/blob/master/README.md#request_response) - set the response function.\n* [*request*.get](https://github.com/d3/d3-request/blob/master/README.md#request_get) - send a GET request.\n* [*request*.post](https://github.com/d3/d3-request/blob/master/README.md#request_post) - send a POST request.\n* [*request*.send](https://github.com/d3/d3-request/blob/master/README.md#request_send) - set the request.\n* [*request*.abort](https://github.com/d3/d3-request/blob/master/README.md#request_abort) - abort the request.\n* [*request*.on](https://github.com/d3/d3-request/blob/master/README.md#request_on) - listen for a request event.\n* [d3.csv](https://github.com/d3/d3-request/blob/master/README.md#csv) - get a comma-separated values (CSV) file.\n* [d3.html](https://github.com/d3/d3-request/blob/master/README.md#html) - get an HTML file.\n* [d3.json](https://github.com/d3/d3-request/blob/master/README.md#json) - get a JSON file.\n* [d3.text](https://github.com/d3/d3-request/blob/master/README.md#text) - get a plain text file.\n* [d3.tsv](https://github.com/d3/d3-request/blob/master/README.md#tsv) - get a tab-separated values (TSV) file.\n* [d3.xml](https://github.com/d3/d3-request/blob/master/README.md#xml) - get an XML file.\n\n## [Scales (d3-scale)](https://github.com/d3/d3-scale)\n\nEncodings that map abstract data to visual representation.\n\n### [Continuous Scales](https://github.com/d3/d3-scale/blob/master/README.md#continuous-scales)\n\nMap a continuous, quantitative domain to a continuous range.\n\n* [*continuous*](https://github.com/d3/d3-scale/blob/master/README.md#_continuous) - compute the range value corresponding to a given domain value.\n* [*continuous*.invert](https://github.com/d3/d3-scale/blob/master/README.md#continuous_invert) - compute the domain value corresponding to a given range value.\n* [*continuous*.domain](https://github.com/d3/d3-scale/blob/master/README.md#continuous_domain) - set the input domain.\n* [*continuous*.range](https://github.com/d3/d3-scale/blob/master/README.md#continuous_range) - set the output range.\n* [*continuous*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#continuous_rangeRound) - set the output range and enable rounding.\n* [*continuous*.clamp](https://github.com/d3/d3-scale/blob/master/README.md#continuous_clamp) - enable clamping to the domain or range.\n* [*continuous*.interpolate](https://github.com/d3/d3-scale/blob/master/README.md#continuous_interpolate) - set the output interpolator.\n* [*continuous*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#continuous_ticks) - compute representative values from the domain.\n* [*continuous*.tickFormat](https://github.com/d3/d3-scale/blob/master/README.md#continuous_tickFormat) - format ticks for human consumption.\n* [*continuous*.nice](https://github.com/d3/d3-scale/blob/master/README.md#continuous_nice) - extend the domain to nice round numbers.\n* [*continuous*.copy](https://github.com/d3/d3-scale/blob/master/README.md#continuous_copy) - create a copy of this scale.\n* [d3.scaleLinear](https://github.com/d3/d3-scale/blob/master/README.md#scaleLinear) - create a quantitative linear scale.\n* [d3.scalePow](https://github.com/d3/d3-scale/blob/master/README.md#scalePow) - create a quantitative power scale.\n* [*pow*](https://github.com/d3/d3-scale/blob/master/README.md#_pow) - compute the range value corresponding to a given domain value.\n* [*pow*.invert](https://github.com/d3/d3-scale/blob/master/README.md#pow_invert) - compute the domain value corresponding to a given range value.\n* [*pow*.exponent](https://github.com/d3/d3-scale/blob/master/README.md#pow_exponent) - set the power exponent.\n* [*pow*.domain](https://github.com/d3/d3-scale/blob/master/README.md#pow_domain) - set the input domain.\n* [*pow*.range](https://github.com/d3/d3-scale/blob/master/README.md#pow_range) - set the output range.\n* [*pow*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#pow_rangeRound) - set the output range and enable rounding.\n* [*pow*.clamp](https://github.com/d3/d3-scale/blob/master/README.md#pow_clamp) - enable clamping to the domain or range.\n* [*pow*.interpolate](https://github.com/d3/d3-scale/blob/master/README.md#pow_interpolate) - set the output interpolator.\n* [*pow*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#pow_ticks) - compute representative values from the domain.\n* [*pow*.tickFormat](https://github.com/d3/d3-scale/blob/master/README.md#pow_tickFormat) - format ticks for human consumption.\n* [*pow*.nice](https://github.com/d3/d3-scale/blob/master/README.md#pow_nice) - extend the domain to nice round numbers.\n* [*pow*.copy](https://github.com/d3/d3-scale/blob/master/README.md#pow_copy) - create a copy of this scale.\n* [d3.scaleSqrt](https://github.com/d3/d3-scale/blob/master/README.md#scaleSqrt) - create a quantitative power scale with exponent 0.5.\n* [d3.scaleLog](https://github.com/d3/d3-scale/blob/master/README.md#scaleLog) - create a quantitative logarithmic scale.\n* [*log*](https://github.com/d3/d3-scale/blob/master/README.md#_log) - compute the range value corresponding to a given domain value.\n* [*log*.invert](https://github.com/d3/d3-scale/blob/master/README.md#log_invert) - compute the domain value corresponding to a given range value.\n* [*log*.base](https://github.com/d3/d3-scale/blob/master/README.md#log_base) - set the logarithm base.\n* [*log*.domain](https://github.com/d3/d3-scale/blob/master/README.md#log_domain) - set the input domain.\n* [*log*.range](https://github.com/d3/d3-scale/blob/master/README.md#log_range) - set the output range.\n* [*log*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#log_rangeRound) - set the output range and enable rounding.\n* [*log*.clamp](https://github.com/d3/d3-scale/blob/master/README.md#log_clamp) - enable clamping to the domain or range.\n* [*log*.interpolate](https://github.com/d3/d3-scale/blob/master/README.md#log_interpolate) - set the output interpolator.\n* [*log*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#log_ticks) - compute representative values from the domain.\n* [*log*.tickFormat](https://github.com/d3/d3-scale/blob/master/README.md#log_tickFormat) - format ticks for human consumption.\n* [*log*.nice](https://github.com/d3/d3-scale/blob/master/README.md#log_nice) - extend the domain to nice round numbers.\n* [*log*.copy](https://github.com/d3/d3-scale/blob/master/README.md#log_copy) - create a copy of this scale.\n* [d3.scaleIdentity](https://github.com/d3/d3-scale/blob/master/README.md#identity) - create a quantitative identity scale.\n* [d3.scaleTime](https://github.com/d3/d3-scale/blob/master/README.md#scaleTime) - create a linear scale for time.\n* [*time*](https://github.com/d3/d3-scale/blob/master/README.md#_time) - compute the range value corresponding to a given domain value.\n* [*time*.invert](https://github.com/d3/d3-scale/blob/master/README.md#time_invert) - compute the domain value corresponding to a given range value.\n* [*time*.domain](https://github.com/d3/d3-scale/blob/master/README.md#time_domain) - set the input domain.\n* [*time*.range](https://github.com/d3/d3-scale/blob/master/README.md#time_range) - set the output range.\n* [*time*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#time_rangeRound) - set the output range and enable rounding.\n* [*time*.clamp](https://github.com/d3/d3-scale/blob/master/README.md#time_clamp) - enable clamping to the domain or range.\n* [*time*.interpolate](https://github.com/d3/d3-scale/blob/master/README.md#time_interpolate) - set the output interpolator.\n* [*time*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#time_ticks) - compute representative values from the domain.\n* [*time*.tickFormat](https://github.com/d3/d3-scale/blob/master/README.md#time_tickFormat) - format ticks for human consumption.\n* [*time*.nice](https://github.com/d3/d3-scale/blob/master/README.md#time_nice) - extend the domain to nice round times.\n* [*time*.copy](https://github.com/d3/d3-scale/blob/master/README.md#time_copy) - create a copy of this scale.\n* [d3.scaleUtc](https://github.com/d3/d3-scale/blob/master/README.md#scaleUtc) - create a linear scale for UTC.\n\n### [Sequential Scales](https://github.com/d3/d3-scale/blob/master/README.md#sequential-scales)\n\nMap a continuous, quantitative domain to a continuous, fixed interpolator.\n\n* [d3.scaleSequential](https://github.com/d3/d3-scale/blob/master/README.md#scaleSequential) - create a sequential scale.\n* [*sequential*.interpolator](https://github.com/d3/d3-scale/blob/master/README.md#sequential_interpolator) - set the scale’s output interpolator.\n* [d3.interpolateViridis](https://github.com/d3/d3-scale/blob/master/README.md#interpolateViridis) - a dark-to-light color scheme.\n* [d3.interpolateInferno](https://github.com/d3/d3-scale/blob/master/README.md#interpolateInferno) - a dark-to-light color scheme.\n* [d3.interpolateMagma](https://github.com/d3/d3-scale/blob/master/README.md#interpolateMagma) - a dark-to-light color scheme.\n* [d3.interpolatePlasma](https://github.com/d3/d3-scale/blob/master/README.md#interpolatePlasma) - a dark-to-light color scheme.\n* [d3.interpolateWarm](https://github.com/d3/d3-scale/blob/master/README.md#interpolateWarm) - a rotating-hue color scheme.\n* [d3.interpolateCool](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCool) - a rotating-hue color scheme.\n* [d3.interpolateRainbow](https://github.com/d3/d3-scale/blob/master/README.md#interpolateRainbow) - a cyclical rotating-hue color scheme.\n* [d3.interpolateCubehelixDefault](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCubehelixDefault) - a dark-to-light, rotating-hue color scheme.\n\n### [Quantize Scales](https://github.com/d3/d3-scale/blob/master/README.md#quantize-scales)\n\nMap a continuous, quantitative domain to a discrete range.\n\n* [d3.scaleQuantize](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantize) - create a uniform quantizing linear scale.\n* [*quantize*](https://github.com/d3/d3-scale/blob/master/README.md#_quantize) - compute the range value corresponding to a given domain value.\n* [*quantize*.invertExtent](https://github.com/d3/d3-scale/blob/master/README.md#quantize_invertExtent) - compute the domain values corresponding to a given range value.\n* [*quantize*.domain](https://github.com/d3/d3-scale/blob/master/README.md#quantize_domain) - set the input domain.\n* [*quantize*.range](https://github.com/d3/d3-scale/blob/master/README.md#quantize_range) - set the output range.\n* [*quantize*.nice](https://github.com/d3/d3-scale/blob/master/README.md#quantize_nice) - extend the domain to nice round numbers.\n* [*quantize*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#quantize_ticks) - compute representative values from the domain.\n* [*quantize*.tickFormat](https://github.com/d3/d3-scale/blob/master/README.md#quantize_tickFormat) - format ticks for human consumption.\n* [*quantize*.copy](https://github.com/d3/d3-scale/blob/master/README.md#quantize_copy) - create a copy of this scale.\n* [d3.scaleQuantile](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantile) - create a quantile quantizing linear scale.\n* [*quantile*](https://github.com/d3/d3-scale/blob/master/README.md#_quantile) - compute the range value corresponding to a given domain value.\n* [*quantile*.invertExtent](https://github.com/d3/d3-scale/blob/master/README.md#quantile_invertExtent) - compute the domain values corresponding to a given range value.\n* [*quantile*.domain](https://github.com/d3/d3-scale/blob/master/README.md#quantile_domain) - set the input domain.\n* [*quantile*.range](https://github.com/d3/d3-scale/blob/master/README.md#quantile_range) - set the output range.\n* [*quantile*.quantiles](https://github.com/d3/d3-scale/blob/master/README.md#quantile_quantiles) - get the quantile thresholds.\n* [*quantile*.copy](https://github.com/d3/d3-scale/blob/master/README.md#quantile_copy) - create a copy of this scale.\n* [d3.scaleThreshold](https://github.com/d3/d3-scale/blob/master/README.md#scaleThreshold) - create an arbitrary quantizing linear scale.\n* [*threshold*](https://github.com/d3/d3-scale/blob/master/README.md#_threshold) - compute the range value corresponding to a given domain value.\n* [*threshold*.invertExtent](https://github.com/d3/d3-scale/blob/master/README.md#threshold_invertExtent) - compute the domain values corresponding to a given range value.\n* [*threshold*.domain](https://github.com/d3/d3-scale/blob/master/README.md#threshold_domain) - set the input domain.\n* [*threshold*.range](https://github.com/d3/d3-scale/blob/master/README.md#threshold_range) - set the output range.\n* [*threshold*.copy](https://github.com/d3/d3-scale/blob/master/README.md#threshold_copy) - create a copy of this scale.\n\n### [Ordinal Scales](https://github.com/d3/d3-scale/blob/master/README.md#ordinal-scales)\n\nMap a discrete domain to a discrete range.\n\n* [d3.scaleOrdinal](https://github.com/d3/d3-scale/blob/master/README.md#scaleOrdinal) - create an ordinal scale.\n* [*ordinal*](https://github.com/d3/d3-scale/blob/master/README.md#_ordinal) - compute the range value corresponding to a given domain value.\n* [*ordinal*.domain](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_domain) - set the input domain.\n* [*ordinal*.range](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_range) - set the output range.\n* [*ordinal*.unknown](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_unknown) - set the output value for unknown inputs.\n* [*ordinal*.copy](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_copy) - create a copy of this scale.\n* [d3.scaleImplicit](https://github.com/d3/d3-scale/blob/master/README.md#scaleImplicit) - a special unknown value for implicit domains.\n* [d3.scaleBand](https://github.com/d3/d3-scale/blob/master/README.md#scaleBand) - create an ordinal band scale.\n* [*band*](https://github.com/d3/d3-scale/blob/master/README.md#_band) - compute the band start corresponding to a given domain value.\n* [*band*.domain](https://github.com/d3/d3-scale/blob/master/README.md#band_domain) - set the input domain.\n* [*band*.range](https://github.com/d3/d3-scale/blob/master/README.md#band_range) - set the output range.\n* [*band*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#band_rangeRound) - set the output range and enable rounding.\n* [*band*.round](https://github.com/d3/d3-scale/blob/master/README.md#band_round) - enable rounding.\n* [*band*.paddingInner](https://github.com/d3/d3-scale/blob/master/README.md#band_paddingInner) - set padding between bands.\n* [*band*.paddingOuter](https://github.com/d3/d3-scale/blob/master/README.md#band_paddingOuter) - set padding outside the first and last bands.\n* [*band*.padding](https://github.com/d3/d3-scale/blob/master/README.md#band_padding) - set padding outside and between bands.\n* [*band*.align](https://github.com/d3/d3-scale/blob/master/README.md#band_align) - set band alignment, if there is extra space.\n* [*band*.bandwidth](https://github.com/d3/d3-scale/blob/master/README.md#band_bandwidth) - get the width of each band.\n* [*band*.step](https://github.com/d3/d3-scale/blob/master/README.md#band_step) - get the distance between the starts of adjacent bands.\n* [*band*.copy](https://github.com/d3/d3-scale/blob/master/README.md#band_copy) - create a copy of this scale.\n* [d3.scalePoint](https://github.com/d3/d3-scale/blob/master/README.md#scalePoint) - create an ordinal point scale.\n* [*point*](https://github.com/d3/d3-scale/blob/master/README.md#_point) - compute the point corresponding to a given domain value.\n* [*point*.domain](https://github.com/d3/d3-scale/blob/master/README.md#point_domain) - set the input domain.\n* [*point*.range](https://github.com/d3/d3-scale/blob/master/README.md#point_range) - set the output range.\n* [*point*.rangeRound](https://github.com/d3/d3-scale/blob/master/README.md#point_rangeRound) - set the output range and enable rounding.\n* [*point*.round](https://github.com/d3/d3-scale/blob/master/README.md#point_round) - enable rounding.\n* [*point*.padding](https://github.com/d3/d3-scale/blob/master/README.md#point_padding) - set padding outside the first and last point.\n* [*point*.align](https://github.com/d3/d3-scale/blob/master/README.md#point_align) - set point alignment, if there is extra space.\n* [*point*.bandwidth](https://github.com/d3/d3-scale/blob/master/README.md#point_bandwidth) - returns zero.\n* [*point*.step](https://github.com/d3/d3-scale/blob/master/README.md#point_step) - get the distance between the starts of adjacent points.\n* [*point*.copy](https://github.com/d3/d3-scale/blob/master/README.md#point_copy) - create a copy of this scale.\n* [d3.schemeCategory10](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory10) - a categorical scheme with 10 colors.\n* [d3.schemeCategory20](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20) - a categorical scheme with 20 colors.\n* [d3.schemeCategory20b](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20b) - a categorical scheme with 20 colors.\n* [d3.schemeCategory20c](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20c) - a categorical scheme with 20 colors.\n\n## [Selections (d3-selection)](https://github.com/d3/d3-selection)\n\nTransform the DOM by selecting elements and joining to data.\n\n### [Selecting Elements](https://github.com/d3/d3-selection/blob/master/README.md#selecting-elements)\n\n* [d3.selection](https://github.com/d3/d3-selection/blob/master/README.md#selection) - select the root document element.\n* [d3.select](https://github.com/d3/d3-selection/blob/master/README.md#select) - select an element from the document.\n* [d3.selectAll](https://github.com/d3/d3-selection/blob/master/README.md#selectAll) - select multiple elements from the document.\n* [*selection*.select](https://github.com/d3/d3-selection/blob/master/README.md#selection_select) - select a descendant element for each selected element.\n* [*selection*.selectAll](https://github.com/d3/d3-selection/blob/master/README.md#selection_selectAll) - select multiple descendants for each selected element.\n* [*selection*.filter](https://github.com/d3/d3-selection/blob/master/README.md#selection_filter) - filter elements based on data.\n* [*selection*.merge](https://github.com/d3/d3-selection/blob/master/README.md#selection_merge) - merge this selection with another.\n* [d3.matcher](https://github.com/d3/d3-selection/blob/master/README.md#matcher) - test whether an element matches a selector.\n* [d3.selector](https://github.com/d3/d3-selection/blob/master/README.md#selector) - select an element.\n* [d3.selectorAll](https://github.com/d3/d3-selection/blob/master/README.md#selectorAll) - select elements.\n* [d3.window](https://github.com/d3/d3-selection/blob/master/README.md#window) - get a node’s owner window.\n* [d3.style](https://github.com/d3/d3-selection/blob/master/README.md#style) - get a node’s current style value.\n\n### [Modifying Elements](https://github.com/d3/d3-selection/blob/master/README.md#modifying-elements)\n\n* [*selection*.attr](https://github.com/d3/d3-selection/blob/master/README.md#selection_attr) - get or set an attribute.\n* [*selection*.classed](https://github.com/d3/d3-selection/blob/master/README.md#selection_classed) - get, add or remove CSS classes.\n* [*selection*.style](https://github.com/d3/d3-selection/blob/master/README.md#selection_style) - get or set a style property.\n* [*selection*.property](https://github.com/d3/d3-selection/blob/master/README.md#selection_property) - get or set a (raw) property.\n* [*selection*.text](https://github.com/d3/d3-selection/blob/master/README.md#selection_text) - get or set the text content.\n* [*selection*.html](https://github.com/d3/d3-selection/blob/master/README.md#selection_html) - get or set the inner HTML.\n* [*selection*.append](https://github.com/d3/d3-selection/blob/master/README.md#selection_append) - create, append and select new elements.\n* [*selection*.insert](https://github.com/d3/d3-selection/blob/master/README.md#selection_insert) - create, insert and select new elements.\n* [*selection*.remove](https://github.com/d3/d3-selection/blob/master/README.md#selection_remove) - remove elements from the document.\n* [*selection*.sort](https://github.com/d3/d3-selection/blob/master/README.md#selection_sort) - sort elements in the document based on data.\n* [*selection*.order](https://github.com/d3/d3-selection/blob/master/README.md#selection_order) - reorders elements in the document to match the selection.\n* [*selection*.raise](https://github.com/d3/d3-selection/blob/master/README.md#selection_raise) - reorders each element as the last child of its parent.\n* [*selection*.lower](https://github.com/d3/d3-selection/blob/master/README.md#selection_lower) - reorders each element as the first child of its parent.\n* [d3.creator](https://github.com/d3/d3-selection/blob/master/README.md#creator) - create an element by name.\n\n### [Joining Data](https://github.com/d3/d3-selection/blob/master/README.md#joining-data)\n\n* [*selection*.data](https://github.com/d3/d3-selection/blob/master/README.md#selection_data) - join elements to data.\n* [*selection*.enter](https://github.com/d3/d3-selection/blob/master/README.md#selection_enter) - get the enter selection (data missing elements).\n* [*selection*.exit](https://github.com/d3/d3-selection/blob/master/README.md#selection_exit) - get the exit selection (elements missing data).\n* [*selection*.datum](https://github.com/d3/d3-selection/blob/master/README.md#selection_datum) - get or set element data (without joining).\n\n### [Handling Events](https://github.com/d3/d3-selection/blob/master/README.md#handling-events)\n\n* [*selection*.on](https://github.com/d3/d3-selection/blob/master/README.md#selection_on) - add or remove event listeners.\n* [*selection*.dispatch](https://github.com/d3/d3-selection/blob/master/README.md#selection_dispatch) - dispatch a custom event.\n* [d3.event](https://github.com/d3/d3-selection/blob/master/README.md#event) - the current user event, during interaction.\n* [d3.customEvent](https://github.com/d3/d3-selection/blob/master/README.md#customEvent) - temporarily define a custom event.\n* [d3.mouse](https://github.com/d3/d3-selection/blob/master/README.md#mouse) - get the mouse position relative to a given container.\n* [d3.touch](https://github.com/d3/d3-selection/blob/master/README.md#touch) - get a touch position relative to a given container.\n* [d3.touches](https://github.com/d3/d3-selection/blob/master/README.md#touches) - get the touch positions relative to a given container.\n\n### [Control Flow](https://github.com/d3/d3-selection/blob/master/README.md#control-flow)\n\n* [*selection*.each](https://github.com/d3/d3-selection/blob/master/README.md#selection_each) - call a function for each element.\n* [*selection*.call](https://github.com/d3/d3-selection/blob/master/README.md#selection_call) - call a function with this selection.\n* [*selection*.empty](https://github.com/d3/d3-selection/blob/master/README.md#selection_empty) - returns true if this selection is empty.\n* [*selection*.nodes](https://github.com/d3/d3-selection/blob/master/README.md#selection_nodes) - returns an array of all selected elements.\n* [*selection*.node](https://github.com/d3/d3-selection/blob/master/README.md#selection_node) - returns the first (non-null) element.\n* [*selection*.size](https://github.com/d3/d3-selection/blob/master/README.md#selection_size) - returns the count of elements.\n\n### [Local Variables](https://github.com/d3/d3-selection/blob/master/README.md#local-variables)\n\n* [d3.local](https://github.com/d3/d3-selection/blob/master/README.md#local) - declares a new local variable.\n* [*local*.set](https://github.com/d3/d3-selection/blob/master/README.md#local_set) - set a local variable’s value.\n* [*local*.get](https://github.com/d3/d3-selection/blob/master/README.md#local_get) - get a local variable’s value.\n* [*local*.remove](https://github.com/d3/d3-selection/blob/master/README.md#local_remove) - delete a local variable.\n* [*local*.toString](https://github.com/d3/d3-selection/blob/master/README.md#local_toString) - get the property identifier of a local variable.\n\n### [Namespaces](https://github.com/d3/d3-selection/blob/master/README.md#namespaces)\n\n* [d3.namespace](https://github.com/d3/d3-selection/blob/master/README.md#namespace) - qualify a prefixed XML name, such as “xlink:href”.\n* [d3.namespaces](https://github.com/d3/d3-selection/blob/master/README.md#namespaces) - the built-in XML namespaces.\n\n## [Shapes (d3-shape)](https://github.com/d3/d3-shape)\n\nGraphical primitives for visualization.\n\n### [Arcs](https://github.com/d3/d3-shape/blob/master/README.md#arcs)\n\nCircular or annular sectors, as in a pie or donut chart.\n\n* [d3.arc](https://github.com/d3/d3-shape/blob/master/README.md#arc) - create a new arc generator.\n* [*arc*](https://github.com/d3/d3-shape/blob/master/README.md#_arc) - generate an arc for the given datum.\n* [*arc*.centroid](https://github.com/d3/d3-shape/blob/master/README.md#arc_centroid) - compute an arc’s midpoint.\n* [*arc*.innerRadius](https://github.com/d3/d3-shape/blob/master/README.md#arc_innerRadius) - set the inner radius.\n* [*arc*.outerRadius](https://github.com/d3/d3-shape/blob/master/README.md#arc_outerRadius) - set the outer radius.\n* [*arc*.cornerRadius](https://github.com/d3/d3-shape/blob/master/README.md#arc_cornerRadius) - set the corner radius, for rounded corners.\n* [*arc*.startAngle](https://github.com/d3/d3-shape/blob/master/README.md#arc_startAngle) - set the start angle.\n* [*arc*.endAngle](https://github.com/d3/d3-shape/blob/master/README.md#arc_endAngle) - set the end angle.\n* [*arc*.padAngle](https://github.com/d3/d3-shape/blob/master/README.md#arc_padAngle) - set the angle between adjacent arcs, for padded arcs.\n* [*arc*.padRadius](https://github.com/d3/d3-shape/blob/master/README.md#arc_padRadius) - set the radius at which to linearize padding.\n* [*arc*.context](https://github.com/d3/d3-shape/blob/master/README.md#arc_context) - set the rendering context.\n\n### [Pies](https://github.com/d3/d3-shape/blob/master/README.md#pies)\n\nCompute the necessary angles to represent a tabular dataset as a pie or donut chart.\n\n* [d3.pie](https://github.com/d3/d3-shape/blob/master/README.md#pie) - create a new pie generator.\n* [*pie*](https://github.com/d3/d3-shape/blob/master/README.md#_pie) - compute the arc angles for the given dataset.\n* [*pie*.value](https://github.com/d3/d3-shape/blob/master/README.md#pie_value) - set the value accessor.\n* [*pie*.sort](https://github.com/d3/d3-shape/blob/master/README.md#pie_sort) - set the sort order comparator.\n* [*pie*.sortValues](https://github.com/d3/d3-shape/blob/master/README.md#pie_sortValues) - set the sort order comparator.\n* [*pie*.startAngle](https://github.com/d3/d3-shape/blob/master/README.md#pie_startAngle) - set the overall start angle.\n* [*pie*.endAngle](https://github.com/d3/d3-shape/blob/master/README.md#pie_endAngle) - set the overall end angle.\n* [*pie*.padAngle](https://github.com/d3/d3-shape/blob/master/README.md#pie_padAngle) - set the pad angle between adjacent arcs.\n\n### [Lines](https://github.com/d3/d3-shape/blob/master/README.md#lines)\n\nA spline or polyline, as in a line chart.\n\n* [d3.line](https://github.com/d3/d3-shape/blob/master/README.md#line) - create a new line generator.\n* [*line*](https://github.com/d3/d3-shape/blob/master/README.md#_line) - generate a line for the given dataset.\n* [*line*.x](https://github.com/d3/d3-shape/blob/master/README.md#line_x) - set the *x* accessor.\n* [*line*.y](https://github.com/d3/d3-shape/blob/master/README.md#line_y) - set the *y* accessor.\n* [*line*.defined](https://github.com/d3/d3-shape/blob/master/README.md#line_defined) - set the defined accessor.\n* [*line*.curve](https://github.com/d3/d3-shape/blob/master/README.md#line_curve) - set the curve interpolator.\n* [*line*.context](https://github.com/d3/d3-shape/blob/master/README.md#line_context) - set the rendering context.\n* [d3.radialLine](https://github.com/d3/d3-shape/blob/master/README.md#radialLine) - create a new radial line generator.\n* [*radialLine*](https://github.com/d3/d3-shape/blob/master/README.md#_radialLine) - generate a line for the given dataset.\n* [*radialLine*.angle](https://github.com/d3/d3-shape/blob/master/README.md#radialLine_angle) - set the angle accessor.\n* [*radialLine*.radius](https://github.com/d3/d3-shape/blob/master/README.md#radialLine_radius) - set the radius accessor.\n* [*radialLine*.defined](https://github.com/d3/d3-shape/blob/master/README.md#radialLine_defined) - set the defined accessor.\n* [*radialLine*.curve](https://github.com/d3/d3-shape/blob/master/README.md#radialLine_curve) - set the curve interpolator.\n* [*radialLine*.context](https://github.com/d3/d3-shape/blob/master/README.md#radialLine_context) - set the rendering context.\n\n### [Areas](https://github.com/d3/d3-shape/blob/master/README.md#areas)\n\nAn area, defined by a bounding topline and baseline, as in an area chart.\n\n* [d3.area](https://github.com/d3/d3-shape/blob/master/README.md#area) - create a new area generator.\n* [*area*](https://github.com/d3/d3-shape/blob/master/README.md#_area) - generate an area for the given dataset.\n* [*area*.x](https://github.com/d3/d3-shape/blob/master/README.md#area_x) - set the *x0* and *x1* accessors.\n* [*area*.x0](https://github.com/d3/d3-shape/blob/master/README.md#area_x0) - set the baseline *x* accessor.\n* [*area*.x1](https://github.com/d3/d3-shape/blob/master/README.md#area_x1) - set the topline *x* accessor.\n* [*area*.y](https://github.com/d3/d3-shape/blob/master/README.md#area_y) - set the *y0* and *y1* accessors.\n* [*area*.y0](https://github.com/d3/d3-shape/blob/master/README.md#area_y0) - set the baseline *y* accessor.\n* [*area*.y1](https://github.com/d3/d3-shape/blob/master/README.md#area_y1) - set the topline *y* accessor.\n* [*area*.defined](https://github.com/d3/d3-shape/blob/master/README.md#area_defined) - set the defined accessor.\n* [*area*.curve](https://github.com/d3/d3-shape/blob/master/README.md#area_curve) - set the curve interpolator.\n* [*area*.context](https://github.com/d3/d3-shape/blob/master/README.md#area_context) - set the rendering context.\n* [*area*.lineX0](https://github.com/d3/d3-shape/blob/master/README.md#area_lineX0) - derive a line for the left edge of an area.\n* [*area*.lineX1](https://github.com/d3/d3-shape/blob/master/README.md#area_lineX1) - derive a line for the right edge of an area.\n* [*area*.lineY0](https://github.com/d3/d3-shape/blob/master/README.md#area_lineY0) - derive a line for the top edge of an area.\n* [*area*.lineY1](https://github.com/d3/d3-shape/blob/master/README.md#area_lineY1) - derive a line for the bottom edge of an area.\n* [d3.radialArea](https://github.com/d3/d3-shape/blob/master/README.md#radialArea) - create a new radial area generator.\n* [*radialArea*](https://github.com/d3/d3-shape/blob/master/README.md#_radialArea) - generate an area for the given dataset.\n* [*radialArea*.angle](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_angle) - set the start and end angle accessors.\n* [*radialArea*.startAngle](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_startAngle) - set the start angle accessor.\n* [*radialArea*.endAngle](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_endAngle) - set the end angle accessor.\n* [*radialArea*.radius](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_radius) - set the inner and outer radius accessors.\n* [*radialArea*.innerRadius](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_innerRadius) - set the inner radius accessor.\n* [*radialArea*.outerRadius](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_outerRadius) - set the outer radius accessor.\n* [*radialArea*.defined](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_defined) - set the defined accessor.\n* [*radialArea*.curve](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_curve) - set the curve interpolator.\n* [*radialArea*.context](https://github.com/d3/d3-shape/blob/master/README.md#radialArea_context) - set the rendering context.\n* [*radialArea*.lineStartAngle](https://github.com/d3/d3-shape/blob/master/README.md#area_lineStartAngle) - derive a line for the start edge of an area.\n* [*radialArea*.lineEndAngle](https://github.com/d3/d3-shape/blob/master/README.md#area_lineEndAngle) - derive a line for the end edge of an area.\n* [*radialArea*.lineInnerRadius](https://github.com/d3/d3-shape/blob/master/README.md#area_lineInnerRadius) - derive a line for the inner edge of an area.\n* [*radialArea*.lineOuterRadius](https://github.com/d3/d3-shape/blob/master/README.md#area_lineOuterRadius) - derive a line for the outer edge of an area.\n\n### [Curves](https://github.com/d3/d3-shape/blob/master/README.md#curves)\n\nInterpolate between points to produce a continuous shape.\n\n* [d3.curveBasis](https://github.com/d3/d3-shape/blob/master/README.md#curveBasis) - a cubic basis spline, repeating the end points.\n* [d3.curveBasisClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveBasisClosed) - a closed cubic basis spline.\n* [d3.curveBasisOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveBasisOpen) - a cubic basis spline.\n* [d3.curveBundle](https://github.com/d3/d3-shape/blob/master/README.md#curveBundle) - a straightened cubic basis spline.\n* [*bundle*.beta](https://github.com/d3/d3-shape/blob/master/README.md#bundle_beta) - set the bundle tension *beta*.\n* [d3.curveCardinal](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinal) - a cubic cardinal spline, with one-sided difference at each end.\n* [d3.curveCardinalClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinalClosed) - a closed cubic cardinal spline.\n* [d3.curveCardinalOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinalOpen) - a cubic cardinal spline.\n* [*cardinal*.tension](https://github.com/d3/d3-shape/blob/master/README.md#cardinal_tension) - set the cardinal spline tension.\n* [d3.curveCatmullRom](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRom) - a cubic Catmull–Rom spline, with one-sided difference at each end.\n* [d3.curveCatmullRomClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRomClosed) - a closed cubic Catmull–Rom spline.\n* [d3.curveCatmullRomOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRomOpen) - a cubic Catmull–Rom spline.\n* [*catmullRom*.alpha](https://github.com/d3/d3-shape/blob/master/README.md#catmullRom_alpha) - set the Catmull–Rom parameter *alpha*.\n* [d3.curveLinear](https://github.com/d3/d3-shape/blob/master/README.md#curveLinear) - a polyline.\n* [d3.curveLinearClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveLinearClosed) - a closed polyline.\n* [d3.curveMonotoneX](https://github.com/d3/d3-shape/blob/master/README.md#curveMonotoneX) - a cubic spline that, given monotonicity in *x*, preserves it in *y*.\n* [d3.curveMonotoneY](https://github.com/d3/d3-shape/blob/master/README.md#curveMonotoneY) - a cubic spline that, given monotonicity in *y*, preserves it in *x*.\n* [d3.curveNatural](https://github.com/d3/d3-shape/blob/master/README.md#curveNatural) - a natural cubic spline.\n* [d3.curveStep](https://github.com/d3/d3-shape/blob/master/README.md#curveStep) - a piecewise constant function.\n* [d3.curveStepAfter](https://github.com/d3/d3-shape/blob/master/README.md#curveStepAfter) - a piecewise constant function.\n* [d3.curveStepBefore](https://github.com/d3/d3-shape/blob/master/README.md#curveStepBefore) - a piecewise constant function.\n* [*curve*.areaStart](https://github.com/d3/d3-shape/blob/master/README.md#curve_areaStart) - start a new area segment.\n* [*curve*.areaEnd](https://github.com/d3/d3-shape/blob/master/README.md#curve_areaEnd) - end the current area segment.\n* [*curve*.lineStart](https://github.com/d3/d3-shape/blob/master/README.md#curve_lineStart) - start a new line segment.\n* [*curve*.lineEnd](https://github.com/d3/d3-shape/blob/master/README.md#curve_lineEnd) - end the current line segment.\n* [*curve*.point](https://github.com/d3/d3-shape/blob/master/README.md#curve_point) - add a point to the current line segment.\n\n### [Links](https://github.com/d3/d3-shape/blob/master/README.md#links)\n\nA smooth cubic Bézier curve from a source to a target.\n\n* [d3.linkVertical](https://github.com/d3/d3-shape/blob/master/README.md#linkVertical) - create a new vertical link generator.\n* [d3.linkHorizontal](https://github.com/d3/d3-shape/blob/master/README.md#linkHorizontal) - create a new horizontal link generator.\n* [*link*](https://github.com/d3/d3-shape/blob/master/README.md#_link) - generate a link.\n* [*link*.source](https://github.com/d3/d3-shape/blob/master/README.md#link_source) - set the source accessor.\n* [*link*.target](https://github.com/d3/d3-shape/blob/master/README.md#link_target) - set the target accessor.\n* [*link*.x](https://github.com/d3/d3-shape/blob/master/README.md#link_x) - set the point *x*-accessor.\n* [*link*.y](https://github.com/d3/d3-shape/blob/master/README.md#link_y) - set the point *y*-accessor.\n* [d3.linkRadial](https://github.com/d3/d3-shape/blob/master/README.md#linkRadial) - create a new radial link generator.\n* [*radialLink*.angle](https://github.com/d3/d3-shape/blob/master/README.md#radialLink_angle) - set the point *angle* accessor.\n* [*radialLink*.radius](https://github.com/d3/d3-shape/blob/master/README.md#radialLink_radius) - set the point *radius* accessor.\n\n### [Symbols](https://github.com/d3/d3-shape/blob/master/README.md#symbols)\n\nA categorical shape encoding, as in a scatterplot.\n\n* [d3.symbol](https://github.com/d3/d3-shape/blob/master/README.md#symbol) - create a new symbol generator.\n* [*symbol*](https://github.com/d3/d3-shape/blob/master/README.md#_symbol) - generate a symbol for the given datum.\n* [*symbol*.type](https://github.com/d3/d3-shape/blob/master/README.md#symbol_type) - set the symbol type.\n* [*symbol*.size](https://github.com/d3/d3-shape/blob/master/README.md#symbol_size) - set the size of the symbol in square pixels.\n* [*symbol*.context](https://github.com/d3/d3-shape/blob/master/README.md#symbol_context) - set the rendering context.\n* [d3.symbols](https://github.com/d3/d3-shape/blob/master/README.md#symbols) - the array of built-in symbol types.\n* [d3.symbolCircle](https://github.com/d3/d3-shape/blob/master/README.md#symbolCircle) - a circle.\n* [d3.symbolCross](https://github.com/d3/d3-shape/blob/master/README.md#symbolCross) - a Greek cross with arms of equal length.\n* [d3.symbolDiamond](https://github.com/d3/d3-shape/blob/master/README.md#symbolDiamond) - a rhombus.\n* [d3.symbolSquare](https://github.com/d3/d3-shape/blob/master/README.md#symbolSquare) - a square.\n* [d3.symbolStar](https://github.com/d3/d3-shape/blob/master/README.md#symbolStar) - a pentagonal star (pentagram).\n* [d3.symbolTriangle](https://github.com/d3/d3-shape/blob/master/README.md#symbolTriangle) - an up-pointing triangle.\n* [d3.symbolWye](https://github.com/d3/d3-shape/blob/master/README.md#symbolWye) - a Y shape.\n* [*symbolType*.draw](https://github.com/d3/d3-shape/blob/master/README.md#symbolType_draw) - draw this symbol to the given context.\n\n### [Stacks](https://github.com/d3/d3-shape/blob/master/README.md#stacks)\n\nStack shapes, placing one adjacent to another, as in a stacked bar chart.\n\n* [d3.stack](https://github.com/d3/d3-shape/blob/master/README.md#stack) - create a new stack generator.\n* [*stack*](https://github.com/d3/d3-shape/blob/master/README.md#_stack) - generate a stack for the given dataset.\n* [*stack*.keys](https://github.com/d3/d3-shape/blob/master/README.md#stack_keys) - set the keys accessor.\n* [*stack*.value](https://github.com/d3/d3-shape/blob/master/README.md#stack_value) - set the value accessor.\n* [*stack*.order](https://github.com/d3/d3-shape/blob/master/README.md#stack_order) - set the order accessor.\n* [*stack*.offset](https://github.com/d3/d3-shape/blob/master/README.md#stack_offset) - set the offset accessor.\n* [d3.stackOrderAscending](https://github.com/d3/d3-shape/blob/master/README.md#stackOrderAscending) - put the smallest series on bottom.\n* [d3.stackOrderDescending](https://github.com/d3/d3-shape/blob/master/README.md#stackOrderDescending) - put the largest series on bottom.\n* [d3.stackOrderInsideOut](https://github.com/d3/d3-shape/blob/master/README.md#stackOrderInsideOut) - put larger series in the middle.\n* [d3.stackOrderNone](https://github.com/d3/d3-shape/blob/master/README.md#stackOrderNone) - use the given series order.\n* [d3.stackOrderReverse](https://github.com/d3/d3-shape/blob/master/README.md#stackOrderReverse) - use the reverse of the given series order.\n* [d3.stackOffsetExpand](https://github.com/d3/d3-shape/blob/master/README.md#stackOffsetExpand) - normalize the baseline to zero and topline to one.\n* [d3.stackOffsetDiverging](https://github.com/d3/d3-shape/blob/master/README.md#stackOffsetDiverging) - positive above zero; negative below zero.\n* [d3.stackOffsetNone](https://github.com/d3/d3-shape/blob/master/README.md#stackOffsetNone) - apply a zero baseline.\n* [d3.stackOffsetSilhouette](https://github.com/d3/d3-shape/blob/master/README.md#stackOffsetSilhouette) - center the streamgraph around zero.\n* [d3.stackOffsetWiggle](https://github.com/d3/d3-shape/blob/master/README.md#stackOffsetWiggle) - minimize streamgraph wiggling.\n\n## [Time Formats (d3-time-format)](https://github.com/d3/d3-time-format)\n\nParse and format times, inspired by strptime and strftime.\n\n* [d3.timeFormat](https://github.com/d3/d3-time-format/blob/master/README.md#timeFormat) - alias for *locale*.format on the default locale.\n* [d3.timeParse](https://github.com/d3/d3-time-format/blob/master/README.md#timeParse) - alias for *locale*.parse on the default locale.\n* [d3.utcFormat](https://github.com/d3/d3-time-format/blob/master/README.md#utcFormat) -  alias for *locale*.utcFormat on the default locale.\n* [d3.utcParse](https://github.com/d3/d3-time-format/blob/master/README.md#utcParse) -  alias for *locale*.utcParse on the default locale.\n* [d3.isoFormat](https://github.com/d3/d3-time-format/blob/master/README.md#isoFormat) - an ISO 8601 UTC formatter.\n* [d3.isoParse](https://github.com/d3/d3-time-format/blob/master/README.md#isoParse) - an ISO 8601 UTC parser.\n* [d3.timeFormatLocale](https://github.com/d3/d3-time-format/blob/master/README.md#timeFormatLocale) - define a custom locale.\n* [d3.timeFormatDefaultLocale](https://github.com/d3/d3-time-format/blob/master/README.md#timeFormatDefaultLocale) - define the default locale.\n* [*locale*.format](https://github.com/d3/d3-time-format/blob/master/README.md#locale_format) - create a time formatter.\n* [*locale*.parse](https://github.com/d3/d3-time-format/blob/master/README.md#locale_parse) - create a time parser.\n* [*locale*.utcFormat](https://github.com/d3/d3-time-format/blob/master/README.md#locale_utcFormat) - create a UTC formatter.\n* [*locale*.utcParse](https://github.com/d3/d3-time-format/blob/master/README.md#locale_utcParse) - create a UTC parser.\n\n## [Time Intervals (d3-time)](https://github.com/d3/d3-time)\n\nA calculator for humanity’s peculiar conventions of time.\n\n* [d3.timeInterval](https://github.com/d3/d3-time/blob/master/README.md#timeInterval) - implement a new custom time interval.\n* [*interval*](https://github.com/d3/d3-time/blob/master/README.md#_interval) - alias for *interval*.floor.\n* [*interval*.floor](https://github.com/d3/d3-time/blob/master/README.md#interval_floor) - round down to the nearest boundary.\n* [*interval*.round](https://github.com/d3/d3-time/blob/master/README.md#interval_round) - round to the nearest boundary.\n* [*interval*.ceil](https://github.com/d3/d3-time/blob/master/README.md#interval_ceil) - round up to the nearest boundary.\n* [*interval*.offset](https://github.com/d3/d3-time/blob/master/README.md#interval_offset) - offset a date by some number of intervals.\n* [*interval*.range](https://github.com/d3/d3-time/blob/master/README.md#interval_range) - generate a range of dates at interval boundaries.\n* [*interval*.filter](https://github.com/d3/d3-time/blob/master/README.md#interval_filter) - create a filtered subset of this interval.\n* [*interval*.every](https://github.com/d3/d3-time/blob/master/README.md#interval_every) - create a filtered subset of this interval.\n* [*interval*.count](https://github.com/d3/d3-time/blob/master/README.md#interval_count) - count interval boundaries between two dates.\n* [d3.timeMillisecond](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond), [d3.utcMillisecond](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond) - the millisecond interval.\n* [d3.timeMilliseconds](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond), [d3.utcMilliseconds](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond) - aliases for millisecond.range.\n* [d3.timeSecond](https://github.com/d3/d3-time/blob/master/README.md#timeSecond), [d3.utcSecond](https://github.com/d3/d3-time/blob/master/README.md#timeSecond) - the second interval.\n* [d3.timeSeconds](https://github.com/d3/d3-time/blob/master/README.md#timeSecond), [d3.utcSeconds](https://github.com/d3/d3-time/blob/master/README.md#timeSecond) - aliases for second.range.\n* [d3.timeMinute](https://github.com/d3/d3-time/blob/master/README.md#timeMinute), [d3.utcMinute](https://github.com/d3/d3-time/blob/master/README.md#timeMinute) - the minute interval.\n* [d3.timeMinutes](https://github.com/d3/d3-time/blob/master/README.md#timeMinute), [d3.utcMinutes](https://github.com/d3/d3-time/blob/master/README.md#timeMinute) - aliases for minute.range.\n* [d3.timeHour](https://github.com/d3/d3-time/blob/master/README.md#timeHour), [d3.utcHour](https://github.com/d3/d3-time/blob/master/README.md#timeHour) - the hour interval.\n* [d3.timeHours](https://github.com/d3/d3-time/blob/master/README.md#timeHour), [d3.utcHours](https://github.com/d3/d3-time/blob/master/README.md#timeHour) - aliases for hour.range.\n* [d3.timeDay](https://github.com/d3/d3-time/blob/master/README.md#timeDay), [d3.utcDay](https://github.com/d3/d3-time/blob/master/README.md#timeDay) - the day interval.\n* [d3.timeDays](https://github.com/d3/d3-time/blob/master/README.md#timeDay), [d3.utcDays](https://github.com/d3/d3-time/blob/master/README.md#timeDay) - aliases for day.range.\n* [d3.timeWeek](https://github.com/d3/d3-time/blob/master/README.md#timeWeek), [d3.utcWeek](https://github.com/d3/d3-time/blob/master/README.md#timeWeek) - aliases for sunday.\n* [d3.timeWeeks](https://github.com/d3/d3-time/blob/master/README.md#timeWeek), [d3.utcWeeks](https://github.com/d3/d3-time/blob/master/README.md#timeWeek) - aliases for week.range.\n* [d3.timeSunday](https://github.com/d3/d3-time/blob/master/README.md#timeSunday), [d3.utcSunday](https://github.com/d3/d3-time/blob/master/README.md#timeSunday) - the week interval, starting on Sunday.\n* [d3.timeSundays](https://github.com/d3/d3-time/blob/master/README.md#timeSunday), [d3.utcSundays](https://github.com/d3/d3-time/blob/master/README.md#timeSunday) - aliases for sunday.range.\n* [d3.timeMonday](https://github.com/d3/d3-time/blob/master/README.md#timeMonday), [d3.utcMonday](https://github.com/d3/d3-time/blob/master/README.md#timeMonday) - the week interval, starting on Monday.\n* [d3.timeMondays](https://github.com/d3/d3-time/blob/master/README.md#timeMonday), [d3.utcMondays](https://github.com/d3/d3-time/blob/master/README.md#timeMonday) - aliases for monday.range.\n* [d3.timeTuesday](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday), [d3.utcTuesday](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday) - the week interval, starting on Tuesday.\n* [d3.timeTuesdays](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday), [d3.utcTuesdays](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday) - aliases for tuesday.range.\n* [d3.timeWednesday](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday), [d3.utcWednesday](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday) - the week interval, starting on Wednesday.\n* [d3.timeWednesdays](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday), [d3.utcWednesdays](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday) - aliases for wednesday.range.\n* [d3.timeThursday](https://github.com/d3/d3-time/blob/master/README.md#timeThursday), [d3.utcThursday](https://github.com/d3/d3-time/blob/master/README.md#timeThursday) - the week interval, starting on Thursday.\n* [d3.timeThursdays](https://github.com/d3/d3-time/blob/master/README.md#timeThursday), [d3.utcThursdays](https://github.com/d3/d3-time/blob/master/README.md#timeThursday) - aliases for thursday.range.\n* [d3.timeFriday](https://github.com/d3/d3-time/blob/master/README.md#timeFriday), [d3.utcFriday](https://github.com/d3/d3-time/blob/master/README.md#timeFriday) - the week interval, starting on Friday.\n* [d3.timeFridays](https://github.com/d3/d3-time/blob/master/README.md#timeFriday), [d3.utcFridays](https://github.com/d3/d3-time/blob/master/README.md#timeFriday) - aliases for friday.range.\n* [d3.timeSaturday](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday), [d3.utcSaturday](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday) - the week interval, starting on Saturday.\n* [d3.timeSaturdays](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday), [d3.utcSaturdays](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday) - aliases for saturday.range.\n* [d3.timeMonth](https://github.com/d3/d3-time/blob/master/README.md#timeMonth), [d3.utcMonth](https://github.com/d3/d3-time/blob/master/README.md#timeMonth) - the month interval.\n* [d3.timeMonths](https://github.com/d3/d3-time/blob/master/README.md#timeMonth), [d3.utcMonths](https://github.com/d3/d3-time/blob/master/README.md#timeMonth) - aliases for month.range.\n* [d3.timeYear](https://github.com/d3/d3-time/blob/master/README.md#timeYear), [d3.utcYear](https://github.com/d3/d3-time/blob/master/README.md#timeYear) - the year interval.\n* [d3.timeYears](https://github.com/d3/d3-time/blob/master/README.md#timeYear), [d3.utcYears](https://github.com/d3/d3-time/blob/master/README.md#timeYear) - aliases for year.range.\n\n## [Timers (d3-timer)](https://github.com/d3/d3-timer)\n\nAn efficient queue for managing thousands of concurrent animations.\n\n* [d3.now](https://github.com/d3/d3-timer/blob/master/README.md#now) - get the current high-resolution time.\n* [d3.timer](https://github.com/d3/d3-timer/blob/master/README.md#timer) - schedule a new timer.\n* [*timer*.restart](https://github.com/d3/d3-timer/blob/master/README.md#timer_restart) - reset the timer’s start time and callback.\n* [*timer*.stop](https://github.com/d3/d3-timer/blob/master/README.md#timer_stop) - stop the timer.\n* [d3.timerFlush](https://github.com/d3/d3-timer/blob/master/README.md#timerFlush) - immediately execute any eligible timers.\n* [d3.timeout](https://github.com/d3/d3-timer/blob/master/README.md#timeout) - schedule a timer that stops on its first callback.\n* [d3.interval](https://github.com/d3/d3-timer/blob/master/README.md#interval) - schedule a timer that is called with a configurable period.\n\n## [Transitions (d3-transition)](https://github.com/d3/d3-transition)\n\nAnimated transitions for [selections](#selections).\n\n* [*selection*.transition](https://github.com/d3/d3-transition/blob/master/README.md#selection_transition) - schedule a transition for the selected elements.\n* [*selection*.interrupt](https://github.com/d3/d3-transition/blob/master/README.md#selection_interrupt) - interrupt and cancel transitions on the selected elements.\n* [d3.transition](https://github.com/d3/d3-transition/blob/master/README.md#transition) - schedule a transition on the root document element.\n* [*transition*.select](https://github.com/d3/d3-transition/blob/master/README.md#transition_select) - schedule a transition on the selected elements.\n* [*transition*.selectAll](https://github.com/d3/d3-transition/blob/master/README.md#transition_selectAll) - schedule a transition on the selected elements.\n* [*transition*.filter](https://github.com/d3/d3-transition/blob/master/README.md#transition_filter) - filter elements based on data.\n* [*transition*.merge](https://github.com/d3/d3-transition/blob/master/README.md#transition_merge) - merge this transition with another.\n* [*transition*.selection](https://github.com/d3/d3-transition/blob/master/README.md#transition_selection) - returns a selection for this transition.\n* [*transition*.transition](https://github.com/d3/d3-transition/blob/master/README.md#transition_transition) - schedule a new transition following this one.\n* [*transition*.call](https://github.com/d3/d3-transition/blob/master/README.md#transition_call) - call a function with this transition.\n* [*transition*.nodes](https://github.com/d3/d3-transition/blob/master/README.md#transition_nodes) - returns an array of all selected elements.\n* [*transition*.node](https://github.com/d3/d3-transition/blob/master/README.md#transition_node) - returns the first (non-null) element.\n* [*transition*.size](https://github.com/d3/d3-transition/blob/master/README.md#transition_size) - returns the count of elements.\n* [*transition*.empty](https://github.com/d3/d3-transition/blob/master/README.md#transition_empty) - returns true if this transition is empty.\n* [*transition*.each](https://github.com/d3/d3-transition/blob/master/README.md#transition_each) - call a function for each element.\n* [*transition*.on](https://github.com/d3/d3-transition/blob/master/README.md#transition_on) - add or remove transition event listeners.\n* [*transition*.attr](https://github.com/d3/d3-transition/blob/master/README.md#transition_attr) - tween the given attribute using the default interpolator.\n* [*transition*.attrTween](https://github.com/d3/d3-transition/blob/master/README.md#transition_attrTween) - tween the given attribute using a custom interpolator.\n* [*transition*.style](https://github.com/d3/d3-transition/blob/master/README.md#transition_style) - tween the given style property using the default interpolator.\n* [*transition*.styleTween](https://github.com/d3/d3-transition/blob/master/README.md#transition_styleTween) - tween the given style property using a custom interpolator.\n* [*transition*.text](https://github.com/d3/d3-transition/blob/master/README.md#transition_text) - set the text content when the transition starts.\n* [*transition*.remove](https://github.com/d3/d3-transition/blob/master/README.md#transition_remove) - remove the selected elements when the transition ends.\n* [*transition*.tween](https://github.com/d3/d3-transition/blob/master/README.md#transition_tween) - run custom code during the transition.\n* [*transition*.delay](https://github.com/d3/d3-transition/blob/master/README.md#transition_delay) - specify per-element delay in milliseconds.\n* [*transition*.duration](https://github.com/d3/d3-transition/blob/master/README.md#transition_duration) - specify per-element duration in milliseconds.\n* [*transition*.ease](https://github.com/d3/d3-transition/blob/master/README.md#transition_ease) - specify the easing function.\n* [d3.active](https://github.com/d3/d3-transition/blob/master/README.md#active) - select the active transition for a given node.\n* [d3.interrupt](https://github.com/d3/d3-transition/blob/master/README.md#interrupt) -\n\n## [Voronoi Diagrams (d3-voronoi)](https://github.com/d3/d3-voronoi)\n\nCompute the Voronoi diagram of a given set of points.\n\n* [d3.voronoi](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi) - create a new Voronoi generator.\n* [*voronoi*](https://github.com/d3/d3-voronoi/blob/master/README.md#_voronoi) - generate a new Voronoi diagram for the given points.\n* [*voronoi*.polygons](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_polygons) - compute the Voronoi polygons for the given points.\n* [*voronoi*.triangles](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_triangles) - compute the Delaunay triangles for the given points.\n* [*voronoi*.links](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_links) - compute the Delaunay links for the given points.\n* [*voronoi*.x](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_x) - set the *x* accessor.\n* [*voronoi*.y](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_y) - set the *y* accessor.\n* [*voronoi*.extent](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_extent) - set the observed extent of points.\n* [*voronoi*.size](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_size) - set the observed extent of points.\n* [*diagram*.polygons](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_polygons) - compute the polygons for this Voronoi diagram.\n* [*diagram*.triangles](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_triangles) - compute the triangles for this Voronoi diagram.\n* [*diagram*.links](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_links) - compute the links for this Voronoi diagram.\n* [*diagram*.find](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_find) - find the closest point in this Voronoi diagram.\n\n## [Zooming (d3-zoom)](https://github.com/d3/d3-zoom)\n\nPan and zoom SVG, HTML or Canvas using mouse or touch input.\n\n* [d3.zoom](https://github.com/d3/d3-zoom/blob/master/README.md#zoom) - create a zoom behavior.\n* [*zoom*](https://github.com/d3/d3-zoom/blob/master/README.md#_zoom) - apply the zoom behavior to the selected elements.\n* [*zoom*.transform](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_transform) - change the transform for the selected elements.\n* [*zoom*.translateBy](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_translateBy) - translate the transform for the selected elements.\n* [*zoom*.scaleBy](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_scaleBy) - scale the transform for the selected elements.\n* [*zoom*.scaleTo](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_scaleTo) - scale the transform for the selected elements.\n* [*zoom*.filter](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_filter) - control which input events initiate zooming.\n* [*zoom*.clickDistance](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_clickDistance) - set the click distance threshold.\n* [*zoom*.extent](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_extent) - set the extent of the viewport.\n* [*zoom*.scaleExtent](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_scaleExtent) - set the allowed scale range.\n* [*zoom*.translateExtent](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_translateExtent) - set the extent of the zoomable world.\n* [*zoom*.duration](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_duration) - set the duration of zoom transitions.\n* [*zoom*.interpolate](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_interpolate) - control the interpolation of zoom transitions.\n* [*zoom*.on](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_on) - listen for zoom events.\n* [d3.zoomTransform](https://github.com/d3/d3-zoom/blob/master/README.md#zoomTransform) - get the zoom transform for a given element.\n* [*transform*.scale](https://github.com/d3/d3-zoom/blob/master/README.md#transform_scale) - scale a transform by the specified amount.\n* [*transform*.translate](https://github.com/d3/d3-zoom/blob/master/README.md#transform_translate) - translate a transform by the specified amount.\n* [*transform*.apply](https://github.com/d3/d3-zoom/blob/master/README.md#transform_apply) - apply the transform to the given point.\n* [*transform*.applyX](https://github.com/d3/d3-zoom/blob/master/README.md#transform_applyX) - apply the transform to the given *x*-coordinate.\n* [*transform*.applyY](https://github.com/d3/d3-zoom/blob/master/README.md#transform_applyY) - apply the transform to the given *y*-coordinate.\n* [*transform*.invert](https://github.com/d3/d3-zoom/blob/master/README.md#transform_invert) - unapply the transform to the given point.\n* [*transform*.invertX](https://github.com/d3/d3-zoom/blob/master/README.md#transform_invertX) - unapply the transform to the given *x*-coordinate.\n* [*transform*.invertY](https://github.com/d3/d3-zoom/blob/master/README.md#transform_invertY) - unapply the transform to the given *y*-coordinate.\n* [*transform*.rescaleX](https://github.com/d3/d3-zoom/blob/master/README.md#transform_rescaleX) - apply the transform to an *x*-scale’s domain.\n* [*transform*.rescaleY](https://github.com/d3/d3-zoom/blob/master/README.md#transform_rescaleY) - apply the transform to a *y*-scale’s domain.\n* [*transform*.toString](https://github.com/d3/d3-zoom/blob/master/README.md#transform_toString) - format the transform as an SVG transform string.\n* [d3.zoomIdentity](https://github.com/d3/d3-zoom/blob/master/README.md#zoomIdentity) - the identity transform.\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/CHANGES.md",
    "content": "# Changes in D3 4.0\n\nD3 4.0 is modular. Instead of one library, D3 is now [many small libraries](#table-of-contents) that are designed to work together. You can pick and choose which parts to use as you see fit. Each library is maintained in its own repository, allowing decentralized ownership and independent release cycles. The default bundle combines about thirty of these microlibraries.\n\n```html\n<script src=\"https://d3js.org/d3.v4.js\"></script>\n```\n\nAs before, you can load optional plugins on top of the default bundle, such as [ColorBrewer scales](https://github.com/d3/d3-scale-chromatic):\n\n```html\n<script src=\"https://d3js.org/d3.v4.js\"></script>\n<script src=\"https://d3js.org/d3-scale-chromatic.v0.3.js\"></script>\n```\n\nYou are not required to use the default bundle! If you’re just using [d3-selection](https://github.com/d3/d3-selection), use it as a standalone library. Like the default bundle, you can load D3 microlibraries using vanilla script tags or RequireJS (great for HTTP/2!):\n\n```html\n<script src=\"https://d3js.org/d3-selection.v1.js\"></script>\n```\n\nYou can also `cat` D3 microlibraries into a custom bundle, or use tools such as [Webpack](https://webpack.github.io/) and [Rollup](http://rollupjs.org/) to create [optimized bundles](https://bl.ocks.org/mbostock/bb09af4c39c79cffcde4). Custom bundles are great for applications that use a subset of D3’s features; for example, a React chart library might use D3 for scales and shapes, and React to manipulate the DOM. The D3 microlibraries are written as [ES6 modules](http://www.2ality.com/2014/09/es6-modules-final.html), and Rollup lets you pick at the symbol level to produce smaller bundles.\n\nSmall files are nice, but modularity is also about making D3 more *fun*. Microlibraries are easier to understand, develop and test. They make it easier for new people to get involved and contribute. They reduce the distinction between a “core module” and a “plugin”, and increase the pace of development in D3 features.\n\nIf you don’t care about modularity, you can mostly ignore this change and keep using the default bundle. However, there is one unavoidable consequence of adopting ES6 modules: every symbol in D3 4.0 now shares a flat namespace rather than the nested one of D3 3.x. For example, d3.scale.linear is now d3.scaleLinear, and d3.layout.treemap is now d3.treemap. The adoption of ES6 modules also means that D3 is now written exclusively in [strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) and has better readability. And there have been many other significant improvements to D3’s features! (Nearly all of the code from D3 3.x has been rewritten.) These changes are covered below.\n\n### Other Global Changes\n\nThe default [UMD bundle](https://github.com/umdjs/umd) is now [anonymous](https://github.com/requirejs/requirejs/wiki/Updating-existing-libraries#register-as-an-anonymous-module-). No `d3` global is exported if AMD or CommonJS is detected. In a vanilla environment, the D3 microlibraries share the `d3` global, even if you load them independently; thus, code you write is the same whether or not you use the default bundle. (See [Let’s Make a (D3) Plugin](https://bost.ocks.org/mike/d3-plugin/) for more.) The generated bundle is no longer stored in the Git repository; Bower has been repointed to [d3-bower](https://github.com/mbostock-bower/d3-bower), and you can find the generated files on [npm](https://unpkg.com/d3) or attached to the [latest release](https://github.com/d3/d3/releases/latest). The non-minified default bundle is no longer mangled, making it more readable and preserving inline comments.\n\nTo the consternation of some users, 3.x employed Unicode variable names such as λ, φ, τ and π for a concise representation of mathematical operations. A downside of this approach was that a SyntaxError would occur if you loaded the non-minified D3 using ISO-8859-1 instead of UTF-8. 3.x also used Unicode string literals, such as the SI-prefix µ for 1e-6. 4.0 uses only ASCII variable names and ASCII string literals (see [rollup-plugin-ascii](https://github.com/mbostock/rollup-plugin-ascii)), avoiding encoding problems.\n\n### Table of Contents\n\n* [Arrays](#arrays-d3-array)\n* [Axes](#axes-d3-axis)\n* [Brushes](#brushes-d3-brush)\n* [Chords](#chords-d3-chord)\n* [Collections](#collections-d3-collection)\n* [Colors](#colors-d3-color)\n* [Dispatches](#dispatches-d3-dispatch)\n* [Dragging](#dragging-d3-drag)\n* [Delimiter-Separated Values](#delimiter-separated-values-d3-dsv)\n* [Easings](#easings-d3-ease)\n* [Forces](#forces-d3-force)\n* [Number Formats](#number-formats-d3-format)\n* [Geographies](#geographies-d3-geo)\n* [Hierarchies](#hierarchies-d3-hierarchy)\n* [Internals](#internals)\n* [Interpolators](#interpolators-d3-interpolate)\n* [Paths](#paths-d3-path)\n* [Polygons](#polygons-d3-polygon)\n* [Quadtrees](#quadtrees-d3-quadtree)\n* [Queues](#queues-d3-queue)\n* [Random Numbers](#random-numbers-d3-random)\n* [Requests](#requests-d3-request)\n* [Scales](#scales-d3-scale)\n* [Selections](#selections-d3-selection)\n* [Shapes](#shapes-d3-shape)\n* [Time Formats](#time-formats-d3-time-format)\n* [Time Intervals](#time-intervals-d3-time)\n* [Timers](#timers-d3-timer)\n* [Transitions](#transitions-d3-transition)\n* [Voronoi Diagrams](#voronoi-diagrams-d3-voronoi)\n* [Zooming](#zooming-d3-zoom)\n\n## [Arrays (d3-array)](https://github.com/d3/d3-array/blob/master/README.md)\n\nThe new [d3.scan](https://github.com/d3/d3-array/blob/master/README.md#scan) method performs a linear scan of an array, returning the index of the least element according to the specified comparator. This is similar to [d3.min](https://github.com/d3/d3-array/blob/master/README.md#min) and [d3.max](https://github.com/d3/d3-array/blob/master/README.md#max), except you can use it to find the position of an extreme element, rather than just calculate an extreme value.\n\n```js\nvar data = [\n  {name: \"Alice\", value: 2},\n  {name: \"Bob\", value: 3},\n  {name: \"Carol\", value: 1},\n  {name: \"Dwayne\", value: 5}\n];\n\nvar i = d3.scan(data, function(a, b) { return a.value - b.value; }); // 2\ndata[i]; // {name: \"Carol\", value: 1}\n```\n\nThe new [d3.ticks](https://github.com/d3/d3-array/blob/master/README.md#ticks) and [d3.tickStep](https://github.com/d3/d3-array/blob/master/README.md#tickStep) methods are useful for generating human-readable numeric ticks. These methods are a low-level alternative to [*continuous*.ticks](https://github.com/d3/d3-scale/blob/master/README.md#continuous_ticks) from [d3-scale](https://github.com/d3/d3-scale). The new implementation is also more accurate, returning the optimal number of ticks as measured by relative error.\n\n```js\nvar ticks = d3.ticks(0, 10, 5); // [0, 2, 4, 6, 8, 10]\n```\n\nThe [d3.range](https://github.com/d3/d3-array/blob/master/README.md#range) method no longer makes an elaborate attempt to avoid floating-point error when *step* is not an integer. The returned values are strictly defined as *start* + *i* \\* *step*, where *i* is an integer. (Learn more about [floating point math](http://0.30000000000000004.com/).) d3.range returns the empty array for infinite ranges, rather than throwing an error.\n\nThe method signature for optional accessors has been changed to be more consistent with array methods such as [*array*.forEach](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach): the accessor is passed the current element (*d*), the index (*i*), and the array (*data*), with *this* as undefined. This affects [d3.min](https://github.com/d3/d3-array/blob/master/README.md#min), [d3.max](https://github.com/d3/d3-array/blob/master/README.md#max), [d3.extent](https://github.com/d3/d3-array/blob/master/README.md#extent), [d3.sum](https://github.com/d3/d3-array/blob/master/README.md#sum), [d3.mean](https://github.com/d3/d3-array/blob/master/README.md#mean), [d3.median](https://github.com/d3/d3-array/blob/master/README.md#median), [d3.quantile](https://github.com/d3/d3-array/blob/master/README.md#quantile), [d3.variance](https://github.com/d3/d3-array/blob/master/README.md#variance) and [d3.deviation](https://github.com/d3/d3-array/blob/master/README.md#deviation). The [d3.quantile](https://github.com/d3/d3-array/blob/master/README.md#quantile) method previously did not take an accessor. Some methods with optional arguments now treat those arguments as missing if they are null or undefined, rather than strictly checking arguments.length.\n\nThe new [d3.histogram](https://github.com/d3/d3-array/blob/master/README.md#histograms) API replaces d3.layout.histogram. Rather than exposing *bin*.x and *bin*.dx on each returned bin, the histogram exposes *bin*.x0 and *bin*.x1, guaranteeing that *bin*.x0 is exactly equal to *bin*.x1 on the preceeding bin. The “frequency” and “probability” modes are no longer supported; each bin is simply an array of elements from the input data, so *bin*.length is equal to D3 3.x’s *bin*.y in frequency mode. To compute a probability distribution, divide the number of elements in each bin by the total number of elements.\n\nThe *histogram*.range method has been renamed [*histogram*.domain](https://github.com/d3/d3-array/blob/master/README.md#histogram_domain) for consistency with scales. The *histogram*.bins method has been renamed [*histogram*.thresholds](https://github.com/d3/d3-array/blob/master/README.md#histogram_thresholds), and no longer accepts an upper value: *n* thresholds will produce *n* + 1 bins. If you specify a desired number of bins rather than thresholds, d3.histogram now uses [d3.ticks](https://github.com/d3/d3-array/blob/master/README.md#ticks) to compute nice bin thresholds. In addition to the default Sturges’ formula, D3 now implements the [Freedman-Diaconis rule](https://github.com/d3/d3-array/blob/master/README.md#thresholdFreedmanDiaconis) and [Scott’s normal reference rule](https://github.com/d3/d3-array/blob/master/README.md#thresholdScott).\n\n## [Axes (d3-axis)](https://github.com/d3/d3-axis/blob/master/README.md)\n\nTo render axes properly in D3 3.x, you needed to style them:\n\n```html\n<style>\n\n.axis path,\n.axis line {\n  fill: none;\n  stroke: #000;\n  shape-rendering: crispEdges;\n}\n\n.axis text {\n  font: 10px sans-serif;\n}\n\n</style>\n<script>\n\nd3.select(\".axis\")\n    .call(d3.svg.axis()\n        .scale(x)\n        .orient(\"bottom\"));\n\n</script>\n```\n\nIf you didn’t, you saw this:\n\n<img src=\"https://raw.githubusercontent.com/d3/d3/master/img/axis-v3.png\" width=\"100%\" height=\"105\">\n\nD3 4.0 provides default styles and shorter syntax. In place of d3.svg.axis and *axis*.orient, D3 4.0 now provides four constructors for each orientation: [d3.axisTop](https://github.com/d3/d3-axis/blob/master/README.md#axisTop), [d3.axisRight](https://github.com/d3/d3-axis/blob/master/README.md#axisRight), [d3.axisBottom](https://github.com/d3/d3-axis/blob/master/README.md#axisBottom), [d3.axisLeft](https://github.com/d3/d3-axis/blob/master/README.md#axisLeft). These constructors accept a scale, so you can reduce all of the above to:\n\n```html\n<script>\n\nd3.select(\".axis\")\n    .call(d3.axisBottom(x));\n\n</script>\n```\n\nAnd get this:\n\n<img src=\"https://raw.githubusercontent.com/d3/d3/master/img/axis-v4.png\" width=\"100%\" height=\"105\">\n\nAs before, you can customize the axis appearance either by applying stylesheets or by modifying the axis elements. The default appearance has been changed slightly to offset the axis by a half-pixel;  this fixes a crisp-edges rendering issue on Safari where the axis would be drawn two-pixels thick.\n\nThere’s now an [*axis*.tickArguments](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickArguments) method, as an alternative to [*axis*.ticks](https://github.com/d3/d3-axis/blob/master/README.md#axis_ticks) that also allows the axis tick arguments to be inspected. The [*axis*.tickSize](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSize) method has been changed to only allow a single argument when setting the tick size. The *axis*.innerTickSize and *axis*.outerTickSize methods have been renamed [*axis*.tickSizeInner](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSizeInner) and [*axis*.tickSizeOuter](https://github.com/d3/d3-axis/blob/master/README.md#axis_tickSizeOuter), respectively.\n\n## [Brushes (d3-brush)](https://github.com/d3/d3-brush/blob/master/README.md)\n\nReplacing d3.svg.brush, there are now three classes of brush for brushing along the *x*-dimension, the *y*-dimension, or both: [d3.brushX](https://github.com/d3/d3-brush/blob/master/README.md#brushX), [d3.brushY](https://github.com/d3/d3-brush/blob/master/README.md#brushY), [d3.brush](https://github.com/d3/d3-brush/blob/master/README.md#brush). Brushes are no longer dependent on [scales](#scales-d3-scale); instead, each brush defines a selection in screen coordinates. This selection can be [inverted](https://github.com/d3/d3-scale/blob/master/README.md#continuous_invert) if you want to compute the corresponding data domain. And rather than rely on the scales’ ranges to determine the brushable area, there is now a [*brush*.extent](https://github.com/d3/d3-brush/blob/master/README.md#brush_extent) method for setting it. If you do not set the brush extent, it defaults to the full extent of the owner SVG element. The *brush*.clamp method has also been eliminated; brushing is always restricted to the brushable area defined by the brush extent.\n\nBrushes no longer store the active brush selection (*i.e.*, the highlighted region; the brush’s position) internally. The brush’s position is now stored on any elements to which the brush has been applied. The brush’s position is available as *event*.selection within a brush event or by calling [d3.brushSelection](https://github.com/d3/d3-brush/blob/master/README.md#brushSelection) on a given *element*. To move the brush programmatically, use [*brush*.move](https://github.com/d3/d3-brush/blob/master/README.md#brush_move) with a given [selection](#selections-d3-selection) or [transition](#transitions-d3-transition); see the [brush snapping example](https://bl.ocks.org/mbostock/6232537). The *brush*.event method has been removed.\n\nBrush interaction has been improved. By default, brushes now ignore right-clicks intended for the context menu; you can change this behavior using [*brush*.filter](https://github.com/d3/d3-brush/blob/master/README.md#brush_filter). Brushes also ignore emulated mouse events on iOS. Holding down SHIFT (⇧) while brushing locks the *x*- or *y*-position of the brush. Holding down META (⌘) while clicking and dragging starts a new selection, rather than translating the existing selection.\n\nThe default appearance of the brush has also been improved and slightly simplified. Previously it was necessary to apply styles to the brush to give it a reasonable appearance, such as:\n\n```css\n.brush .extent {\n  stroke: #fff;\n  fill-opacity: .125;\n  shape-rendering: crispEdges;\n}\n```\n\nThese styles are now applied by default as attributes; if you want to customize the brush appearance, you can still apply external styles or modify the brush elements. (D3 4.0 features a similar improvement to [axes](#axes-d3-axis).) A new [*brush*.handleSize](https://github.com/d3/d3-brush/blob/master/README.md#brush_handleSize) method lets you override the brush handle size; it defaults to six pixels.\n\nThe brush now consumes handled events, making it easier to combine with other interactive behaviors such as [dragging](#dragging-d3-drag) and [zooming](#zooming-d3-zoom). The *brushstart* and *brushend* events have been renamed to *start* and *end*, respectively. The brush event no longer reports a *event*.mode to distinguish between resizing and dragging the brush.\n\n## [Chords (d3-chord)](https://github.com/d3/d3-chord/blob/master/README.md)\n\nPursuant to the great namespace flattening:\n\n* d3.layout.chord ↦ [d3.chord](https://github.com/d3/d3-chord/blob/master/README.md#chord)\n* d3.svg.chord ↦ [d3.ribbon](https://github.com/d3/d3-chord/blob/master/README.md#ribbon)\n\nFor consistency with [*arc*.padAngle](https://github.com/d3/d3-shape/blob/master/README.md#arc_padAngle), *chord*.padding has also been renamed to [*ribbon*.padAngle](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_padAngle). A new [*ribbon*.context](https://github.com/d3/d3-chord/blob/master/README.md#ribbon_context) method lets you render chord diagrams to Canvas! See also [d3-path](#paths-d3-path).\n\n## [Collections (d3-collection)](https://github.com/d3/d3-collection/blob/master/README.md)\n\nThe [d3.set](https://github.com/d3/d3-collection/blob/master/README.md#set) constructor now accepts an existing set for making a copy. If you pass an array to d3.set, you can also pass a value accessor. This accessor takes the standard arguments: the current element (*d*), the index (*i*), and the array (*data*), with *this* undefined. For example:\n\n```js\nvar yields = [\n  {yield: 22.13333, variety: \"Manchuria\",        year: 1932, site: \"Grand Rapids\"},\n  {yield: 26.76667, variety: \"Peatland\",         year: 1932, site: \"Grand Rapids\"},\n  {yield: 28.10000, variety: \"No. 462\",          year: 1931, site: \"Duluth\"},\n  {yield: 38.50000, variety: \"Svansota\",         year: 1932, site: \"Waseca\"},\n  {yield: 40.46667, variety: \"Svansota\",         year: 1931, site: \"Crookston\"},\n  {yield: 36.03333, variety: \"Peatland\",         year: 1932, site: \"Waseca\"},\n  {yield: 34.46667, variety: \"Wisconsin No. 38\", year: 1931, site: \"Grand Rapids\"}\n];\n\nvar sites = d3.set(yields, function(d) { return d.site; }); // Grand Rapids, Duluth, Waseca, Crookston\n```\n\nThe [d3.map](https://github.com/d3/d3-collection/blob/master/README.md#map) constructor also follows the standard array accessor argument pattern.\n\nThe *map*.forEach and *set*.forEach methods have been renamed to [*map*.each](https://github.com/d3/d3-collection/blob/master/README.md#map_each) and [*set*.each](https://github.com/d3/d3-collection/blob/master/README.md#set_each) respectively. The order of arguments for *map*.each has also been changed to *value*, *key* and *map*, while the order of arguments for *set*.each is now *value*, *value* and *set*. This is closer to ES6 [*map*.forEach](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach) and [*set*.forEach](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set/forEach). Also like ES6 Map and Set, *map*.set and *set*.add now return the current collection (rather than the added value) to facilitate method chaining. New [*map*.clear](https://github.com/d3/d3-collection/blob/master/README.md#map_clear) and [*set*.clear](https://github.com/d3/d3-collection/blob/master/README.md#set_clear) methods can be used to empty collections.\n\nThe [*nest*.map](https://github.com/d3/d3-collection/blob/master/README.md#nest_map) method now always returns a d3.map instance. For a plain object, use [*nest*.object](https://github.com/d3/d3-collection/blob/master/README.md#nest_object) instead. When used in conjunction with [*nest*.rollup](https://github.com/d3/d3-collection/blob/master/README.md#nest_rollup), [*nest*.entries](https://github.com/d3/d3-collection/blob/master/README.md#nest_entries) now returns {key, value} objects for the leaf entries, instead of {key, values}. This makes *nest*.rollup easier to use in conjunction with [hierarchies](#hierarchies-d3-hierarchy), as in this [Nest Treemap example](https://bl.ocks.org/mbostock/2838bf53e0e65f369f476afd653663a2).\n\n## [Colors (d3-color)](https://github.com/d3/d3-color/blob/master/README.md)\n\nAll colors now have opacity exposed as *color*.opacity, which is a number in [0, 1]. You can pass an optional opacity argument to the color space constructors [d3.rgb](https://github.com/d3/d3-color/blob/master/README.md#rgb), [d3.hsl](https://github.com/d3/d3-color/blob/master/README.md#hsl), [d3.lab](https://github.com/d3/d3-color/blob/master/README.md#lab), [d3.hcl](https://github.com/d3/d3-color/blob/master/README.md#hcl) or [d3.cubehelix](https://github.com/d3/d3-color/blob/master/README.md#cubehelix).\n\nYou can now parse rgba(…) and hsla(…) CSS color specifiers or the string “transparent” using [d3.color](https://github.com/d3/d3-color/blob/master/README.md#color). The “transparent” color is defined as an RGB color with zero opacity and undefined red, green and blue channels; this differs slightly from CSS which defines it as transparent black, but is useful for simplifying color interpolation logic where either the starting or ending color has undefined channels. The [*color*.toString](https://github.com/d3/d3-color/blob/master/README.md#color_toString) method now likewise returns an rgb(…) or rgba(…) string with integer channel values, not the hexadecimal RGB format, consistent with CSS computed values. This improves performance by short-circuiting transitions when the element’s starting style matches its ending style.\n\nThe new [d3.color](https://github.com/d3/d3-color/blob/master/README.md#color) method is the primary method for parsing colors: it returns a d3.color instance in the appropriate color space, or null if the CSS color specifier is invalid. For example:\n\n```js\nvar red = d3.color(\"hsl(0, 80%, 50%)\"); // {h: 0, l: 0.5, s: 0.8, opacity: 1}\n```\n\nThe parsing implementation is now more robust. For example, you can no longer mix integers and percentages in rgb(…), and it correctly handles whitespace, decimal points, number signs, and other edge cases. The color space constructors d3.rgb, d3.hsl, d3.lab, d3.hcl and d3.cubehelix now always return a copy of the input color, converted to the corresponding color space. While [*color*.rgb](https://github.com/d3/d3-color/blob/master/README.md#color_rgb) remains, *rgb*.hsl has been removed; use d3.hsl to convert a color to the RGB color space.\n\nThe RGB color space no longer greedily quantizes and clamps channel values when creating colors, improving accuracy in color space conversion. Quantization and clamping now occurs in *color*.toString when formatting a color for display. You can use the new [*color*.displayable](https://github.com/d3/d3-color/blob/master/README.md#color_displayable) to test whether a color is [out-of-gamut](https://en.wikipedia.org/wiki/Gamut).\n\nThe [*rgb*.brighter](https://github.com/d3/d3-color/blob/master/README.md#rgb_brighter) method no longer special-cases black. This is a multiplicative operator, defining a new color *r*′, *g*′, *b*′ where *r*′ = *r* × *pow*(0.7, *k*), *g*′ = *g* × *pow*(0.7, *k*) and *b*′ = *b* × *pow*(0.7, *k*); a brighter black is still black.\n\nThere’s a new [d3.cubehelix](https://github.com/d3/d3-color/blob/master/README.md#cubehelix) color space, generalizing Dave Green’s color scheme! (See also [d3.interpolateCubehelixDefault](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCubehelixDefault) from [d3-scale](#scales-d3-scale).) You can continue to define your own custom color spaces, too; see [d3-hsv](https://github.com/d3/d3-hsv) for an example.\n\n## [Dispatches (d3-dispatch)](https://github.com/d3/d3-dispatch/blob/master/README.md)\n\nRather than decorating the *dispatch* object with each event type, the dispatch object now exposes generic [*dispatch*.call](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_call) and [*dispatch*.apply](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_apply) methods which take the *type* string as the first argument. For example, in D3 3.x, you might say:\n\n```js\ndispatcher.foo.call(that, \"Hello, Foo!\");\n```\n\nTo dispatch a *foo* event in D3 4.0, you’d say:\n\n```js\ndispatcher.call(\"foo\", that, \"Hello, Foo!\");\n```\n\nThe [*dispatch*.on](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_on) method now accepts multiple typenames, allowing you to add or remove listeners for multiple events simultaneously. For example, to send both *foo* and *bar* events to the same listener:\n\n```js\ndispatcher.on(\"foo bar\", function(message) {\n  console.log(message);\n});\n```\n\nThis matches the new behavior of [*selection*.on](https://github.com/d3/d3-selection/blob/master/README.md#selection_on) in [d3-selection](#selections-d3-selection). The *dispatch*.on method now validates that the specifier *listener* is a function, rather than throwing an error in the future.\n\nThe new implementation d3.dispatch is faster, using fewer closures to improve performance. There’s also a new [*dispatch*.copy](https://github.com/d3/d3-dispatch/blob/master/README.md#dispatch_copy) method for making a copy of a dispatcher; this is used by [d3-transition](#transitions-d3-transition) to improve the performance of transitions in the common case where all elements in a transition have the same transition event listeners.\n\n## [Dragging (d3-drag)](https://github.com/d3/d3-drag/blob/master/README.md)\n\nThe drag behavior d3.behavior.drag has been renamed to d3.drag. The *drag*.origin method has been replaced by [*drag*.subject](https://github.com/d3/d3-drag/blob/master/README.md#drag_subject), which allows you to define the thing being dragged at the start of a drag gesture. This is particularly useful with Canvas, where draggable objects typically share a Canvas element (as opposed to SVG, where draggable objects typically have distinct DOM elements); see the [circle dragging example](https://bl.ocks.org/mbostock/444757cc9f0fde320a5f469cd36860f4).\n\nA new [*drag*.container](https://github.com/d3/d3-drag/blob/master/README.md#drag_container) method lets you override the parent element that defines the drag gesture coordinate system. This defaults to the parent node of the element to which the drag behavior was applied. For dragging on Canvas elements, you probably want to use the Canvas element as the container.\n\n[Drag events](https://github.com/d3/d3-drag/blob/master/README.md#drag-events) now expose an [*event*.on](https://github.com/d3/d3-drag/blob/master/README.md#event_on) method for registering temporary listeners for duration of the current drag gesture; these listeners can capture state for the current gesture, such as the thing being dragged. A new *event*.active property lets you detect whether multiple (multitouch) drag gestures are active concurrently. The *dragstart* and *dragend* events have been renamed to *start* and *end*. By default, drag behaviors now ignore right-clicks intended for the context menu; use [*drag*.filter](https://github.com/d3/d3-drag/blob/master/README.md#drag_filter) to control which events are ignored. The drag behavior also ignores emulated mouse events on iOS. The drag behavior now consumes handled events, making it easier to combine with other interactive behaviors such as [zooming](#zooming-d3-zoom).\n\nThe new [d3.dragEnable](https://github.com/d3/d3-drag/blob/master/README.md#dragEnable) and [d3.dragDisable](https://github.com/d3/d3-drag/blob/master/README.md#dragDisable) methods provide a low-level API for implementing drag gestures across browsers and devices. These methods are also used by other D3 components, such as the [brush](#brushes-d3-brush).\n\n## [Delimiter-Separated Values (d3-dsv)](https://github.com/d3/d3-dsv/blob/master/README.md)\n\nPursuant to the great namespace flattening, various CSV and TSV methods have new names:\n\n* d3.csv.parse ↦ [d3.csvParse](https://github.com/d3/d3-dsv/blob/master/README.md#csvParse)\n* d3.csv.parseRows ↦ [d3.csvParseRows](https://github.com/d3/d3-dsv/blob/master/README.md#csvParseRows)\n* d3.csv.format ↦ [d3.csvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#csvFormat)\n* d3.csv.formatRows ↦ [d3.csvFormatRows](https://github.com/d3/d3-dsv/blob/master/README.md#csvFormatRows)\n* d3.tsv.parse ↦ [d3.tsvParse](https://github.com/d3/d3-dsv/blob/master/README.md#tsvParse)\n* d3.tsv.parseRows ↦ [d3.tsvParseRows](https://github.com/d3/d3-dsv/blob/master/README.md#tsvParseRows)\n* d3.tsv.format ↦ [d3.tsvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#tsvFormat)\n* d3.tsv.formatRows ↦ [d3.tsvFormatRows](https://github.com/d3/d3-dsv/blob/master/README.md#tsvFormatRows)\n\nThe [d3.csv](https://github.com/d3/d3-request/blob/master/README.md#csv) and [d3.tsv](https://github.com/d3/d3-request/blob/master/README.md#tsv) methods for loading files of the corresponding formats have not been renamed, however! Those are defined in [d3-request](#requests-d3-request).There’s no longer a d3.dsv method, which served the triple purpose of defining a DSV formatter, a DSV parser and a DSV requestor; instead, there’s just [d3.dsvFormat](https://github.com/d3/d3-dsv/blob/master/README.md#dsvFormat) which you can use to define a DSV formatter and parser. You can use [*request*.response](https://github.com/d3/d3-request/blob/master/README.md#request_response) to make a request and then parse the response body, or just use [d3.text](https://github.com/d3/d3-request/blob/master/README.md#text).\n\nThe [*dsv*.parse](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_parse) method now exposes the column names and their input order as *data*.columns. For example:\n\n```js\nd3.csv(\"cars.csv\", function(error, data) {\n  if (error) throw error;\n  console.log(data.columns); // [\"Year\", \"Make\", \"Model\", \"Length\"]\n});\n```\n\nYou can likewise pass an optional array of column names to [*dsv*.format](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_format) to format only a subset of columns, or to specify the column order explicitly:\n\n```js\nvar string = d3.csvFormat(data, [\"Year\", \"Model\", \"Length\"]);\n```\n\nThe parser is a bit faster and the formatter is a bit more robust: inputs are coerced to strings before formatting, fixing an obscure crash, and deprecated support for falling back to [*dsv*.formatRows](https://github.com/d3/d3-dsv/blob/master/README.md#dsv_formatRows) when the input *data* is an array of arrays has been removed.\n\n## [Easings (d3-ease)](https://github.com/d3/d3-ease/blob/master/README.md)\n\nD3 3.x used strings, such as “cubic-in-out”, to identify easing methods; these strings could be passed to d3.ease or *transition*.ease. D3 4.0 uses symbols instead, such as [d3.easeCubicInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicInOut). Symbols are simpler and cleaner. They work well with Rollup to produce smaller custom bundles. You can still define your own custom easing function, too, if desired. Here’s the full list of equivalents:\n\n* linear ↦ [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear)¹\n* linear-in ↦ [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear)¹\n* linear-out ↦ [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear)¹\n* linear-in-out ↦ [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear)¹\n* linear-out-in ↦ [d3.easeLinear](https://github.com/d3/d3-ease/blob/master/README.md#easeLinear)¹\n* poly-in ↦ [d3.easePolyIn](https://github.com/d3/d3-ease/blob/master/README.md#easePolyIn)\n* poly-out ↦ [d3.easePolyOut](https://github.com/d3/d3-ease/blob/master/README.md#easePolyOut)\n* poly-in-out ↦ [d3.easePolyInOut](https://github.com/d3/d3-ease/blob/master/README.md#easePolyInOut)\n* poly-out-in ↦ REMOVED²\n* quad-in ↦ [d3.easeQuadIn](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadIn)\n* quad-out ↦ [d3.easeQuadOut](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadOut)\n* quad-in-out ↦ [d3.easeQuadInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeQuadInOut)\n* quad-out-in ↦ REMOVED²\n* cubic-in ↦ [d3.easeCubicIn](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicIn)\n* cubic-out ↦ [d3.easeCubicOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicOut)\n* cubic-in-out ↦ [d3.easeCubicInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicInOut)\n* cubic-out-in ↦ REMOVED²\n* sin-in ↦ [d3.easeSinIn](https://github.com/d3/d3-ease/blob/master/README.md#easeSinIn)\n* sin-out ↦ [d3.easeSinOut](https://github.com/d3/d3-ease/blob/master/README.md#easeSinOut)\n* sin-in-out ↦ [d3.easeSinInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeSinInOut)\n* sin-out-in ↦ REMOVED²\n* exp-in ↦ [d3.easeExpIn](https://github.com/d3/d3-ease/blob/master/README.md#easeExpIn)\n* exp-out ↦ [d3.easeExpOut](https://github.com/d3/d3-ease/blob/master/README.md#easeExpOut)\n* exp-in-out ↦ [d3.easeExpInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeExpInOut)\n* exp-out-in ↦ REMOVED²\n* circle-in ↦ [d3.easeCircleIn](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleIn)\n* circle-out ↦ [d3.easeCircleOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleOut)\n* circle-in-out ↦ [d3.easeCircleInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCircleInOut)\n* circle-out-in ↦ REMOVED²\n* elastic-in ↦ [d3.easeElasticOut](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticOut)²\n* elastic-out ↦ [d3.easeElasticIn](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticIn)²\n* elastic-in-out ↦ REMOVED²\n* elastic-out-in ↦ [d3.easeElasticInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeElasticInOut)²\n* back-in ↦ [d3.easeBackIn](https://github.com/d3/d3-ease/blob/master/README.md#easeBackIn)\n* back-out ↦ [d3.easeBackOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBackOut)\n* back-in-out ↦ [d3.easeBackInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBackInOut)\n* back-out-in ↦ REMOVED²\n* bounce-in ↦ [d3.easeBounceOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceOut)²\n* bounce-out ↦ [d3.easeBounceIn](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceIn)²\n* bounce-in-out ↦ REMOVED²\n* bounce-out-in ↦ [d3.easeBounceInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeBounceInOut)²\n\n¹ The -in, -out and -in-out variants of linear easing are identical, so there’s just d3.easeLinear.\n<br>² Elastic and bounce easing were inadvertently reversed in 3.x, so 4.0 eliminates -out-in easing!\n\nFor convenience, there are also default aliases for each easing method. For example, [d3.easeCubic](https://github.com/d3/d3-ease/blob/master/README.md#easeCubic) is an alias for [d3.easeCubicInOut](https://github.com/d3/d3-ease/blob/master/README.md#easeCubicInOut). Most default to -in-out; the exceptions are [d3.easeBounce](https://github.com/d3/d3-ease/blob/master/README.md#easeBounce) and [d3.easeElastic](https://github.com/d3/d3-ease/blob/master/README.md#easeElastic), which default to -out.\n\nRather than pass optional arguments to d3.ease or *transition*.ease, parameterizable easing functions now have named parameters: [*poly*.exponent](https://github.com/d3/d3-ease/blob/master/README.md#poly_exponent), [*elastic*.amplitude](https://github.com/d3/d3-ease/blob/master/README.md#elastic_amplitude), [*elastic*.period](https://github.com/d3/d3-ease/blob/master/README.md#elastic_period) and [*back*.overshoot](https://github.com/d3/d3-ease/blob/master/README.md#back_overshoot). For example, in D3 3.x you might say:\n\n```js\nvar e = d3.ease(\"elastic-out-in\", 1.2);\n```\n\nThe equivalent in D3 4.0 is:\n\n```js\nvar e = d3.easeElastic.amplitude(1.2);\n```\n\nMany of the easing functions have been optimized for performance and accuracy. Several bugs have been fixed, as well, such as the interpretation of the overshoot parameter for back easing, and the period parameter for elastic easing. Also, [d3-transition](#transitions-d3-transition) now explicitly guarantees that the last tick of the transition happens at exactly *t* = 1, avoiding floating point errors in some easing functions.\n\nThere’s now a nice [visual reference](https://github.com/d3/d3-ease/blob/master/README.md) and an [animated reference](https://bl.ocks.org/mbostock/248bac3b8e354a9103c4) to the new easing functions, too!\n\n## [Forces (d3-force)](https://github.com/d3/d3-force/blob/master/README.md)\n\nThe force layout d3.layout.force has been renamed to d3.forceSimulation. The force simulation now uses [velocity Verlet integration](https://en.wikipedia.org/wiki/Verlet_integration#Velocity_Verlet) rather than position Verlet, tracking the nodes’ positions (*node*.x, *node*.y) and velocities (*node*.vx, *node*.vy) rather than their previous positions (*node*.px, *node*.py).\n\nRather than hard-coding a set of built-in forces, the force simulation is now extensible: you specify which forces you want! The approach affords greater flexibility through composition. The new forces are more flexible, too: force parameters can typically be configured per-node or per-link. There are separate positioning forces for [*x*](https://github.com/d3/d3-force/blob/master/README.md#forceX) and [*y*](https://github.com/d3/d3-force/blob/master/README.md#forceY) that replace *force*.gravity; [*x*.x](https://github.com/d3/d3-force/blob/master/README.md#x_x) and [*y*.y](https://github.com/d3/d3-force/blob/master/README.md#y_y) replace *force*.size. The new [link force](https://github.com/d3/d3-force/blob/master/README.md#forceLink) replaces *force*.linkStrength and employs better default heuristics to improve stability. The new [many-body force](https://github.com/d3/d3-force/blob/master/README.md#forceManyBody) replaces *force*.charge and supports a new [minimum-distance parameter](https://github.com/d3/d3-force/blob/master/README.md#manyBody_distanceMin) and performance improvements thanks to 4.0’s [new quadtrees](#quadtrees-d3-quadtree). There are also brand-new forces for [centering nodes](https://github.com/d3/d3-force/blob/master/README.md#forceCenter) and [collision resolution](https://github.com/d3/d3-force/blob/master/README.md#forceCollision).\n\nThe new forces and simulation have been carefully crafted to avoid nondeterminism. Rather than initializing nodes randomly, if the nodes do not have preset positions, they are placed in a phyllotaxis pattern:\n\n<img alt=\"Phyllotaxis\" src=\"https://raw.githubusercontent.com/d3/d3-force/master/img/phyllotaxis.png\" width=\"420\" height=\"219\">\n\nRandom jitter is still needed to resolve link, collision and many-body forces if there are coincident nodes, but at least in the common case, the force simulation (and the resulting force-directed graph layout) is now consistent across browsers and reloads. D3 no longer plays dice!\n\nThe force simulation has several new methods for greater control over heating, such as [*simulation*.alphaMin](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaMin) and [*simulation*.alphaDecay](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaDecay), and the internal timer. Calling [*simulation*.alpha](https://github.com/d3/d3-force/blob/master/README.md#simulation_alpha) now has no effect on the internal timer, which is controlled independently via [*simulation*.stop](https://github.com/d3/d3-force/blob/master/README.md#simulation_stop) and [*simulation*.restart](https://github.com/d3/d3-force/blob/master/README.md#simulation_restart). The force layout’s internal timer now starts automatically on creation, removing *force*.start. As in 3.x, you can advance the simulation manually using [*simulation*.tick](https://github.com/d3/d3-force/blob/master/README.md#simulation_tick). The *force*.friction parameter is replaced by *simulation*.velocityDecay. A new [*simulation*.alphaTarget](https://github.com/d3/d3-force/blob/master/README.md#simulation_alphaTarget) method allows you to set the desired alpha (temperature) of the simulation, such that the simulation can be smoothly reheated during interaction, and then smoothly cooled again. This improves the stability of the graph during interaction.\n\nThe force layout no longer depends on the [drag behavior](#dragging-d3-drag), though you can certainly create [draggable force-directed graphs](https://bl.ocks.org/mbostock/ad70335eeef6d167bc36fd3c04378048)! Set *node*.fx and *node*.fy to fix a node’s position. As an alternative to a [Voronoi](#voronoi-d3-voronoi) SVG overlay, you can now use [*simulation*.find](https://github.com/d3/d3-force/blob/master/README.md#simulation_find) to find the closest node to a pointer.\n\n## [Number Formats (d3-format)](https://github.com/d3/d3-format/blob/master/README.md)\n\nIf a precision is not specified, the formatting behavior has changed: there is now a default precision of 6 for all directives except *none*, which defaults to 12. In 3.x, if you did not specify a precision, the number was formatted using its shortest unique representation (per [*number*.toString](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toString)); this could lead to unexpected digits due to [floating point math](http://0.30000000000000004.com/). The new default precision in 4.0 produces more consistent results:\n\n```js\nvar f = d3.format(\"e\");\nf(42);        // \"4.200000e+1\"\nf(0.1 + 0.2); // \"3.000000e-1\"\n```\n\nTo trim insignificant trailing zeroes, use the *none* directive, which is similar `g`. For example:\n\n```js\nvar f = d3.format(\".3\");\nf(0.12345);   // \"0.123\"\nf(0.10000);   // \"0.1\"\nf(0.1 + 0.2); // \"0.3\"\n```\n\nUnder the hood, number formatting has improved accuracy with very large and very small numbers by using [*number*.toExponential](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toExponential) rather than [Math.log](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/log) to extract the mantissa and exponent. Negative zero (-0, an IEEE 754 construct) and very small numbers that round to zero are now formatted as unsigned zero. The inherently unsafe d3.round method has been removed, along with d3.requote.\n\nThe [d3.formatPrefix](https://github.com/d3/d3-format/blob/master/README.md#formatPrefix) method has been changed. Rather than returning an SI-prefix string, it returns an SI-prefix format function for a given *specifier* and reference *value*. For example, to format thousands:\n\n```js\nvar f = d3.formatPrefix(\",.0\", 1e3);\nf(1e3); // \"1k\"\nf(1e4); // \"10k\"\nf(1e5); // \"100k\"\nf(1e6); // \"1,000k\"\n```\n\nUnlike the `s` format directive, d3.formatPrefix always employs the same SI-prefix, producing consistent results:\n\n```js\nvar f = d3.format(\".0s\");\nf(1e3); // \"1k\"\nf(1e4); // \"10k\"\nf(1e5); // \"100k\"\nf(1e6); // \"1M\"\n```\n\nThe new `(` sign option uses parentheses for negative values. This is particularly useful in conjunction with `$`. For example:\n\n```js\nd3.format(\"+.0f\")(-42);  // \"-42\"\nd3.format(\"(.0f\")(-42);  // \"(42)\"\nd3.format(\"+$.0f\")(-42); // \"-$42\"\nd3.format(\"($.0f\")(-42); // \"($42)\"\n```\n\nThe new `=` align option places any sign and symbol to the left of any padding:\n\n```js\nd3.format(\">6d\")(-42);  // \"   -42\"\nd3.format(\"=6d\")(-42);  // \"-   42\"\nd3.format(\">(6d\")(-42); // \"  (42)\"\nd3.format(\"=(6d\")(-42); // \"(  42)\"\n```\n\nThe `b`, `o`, `d` and `x` directives now round to the nearest integer, rather than returning the empty string for non-integers:\n\n```js\nd3.format(\"b\")(41.9); // \"101010\"\nd3.format(\"o\")(41.9); // \"52\"\nd3.format(\"d\")(41.9); // \"42\"\nd3.format(\"x\")(41.9); // \"2a\"\n```\n\nThe `c` directive is now for character data (*i.e.*, literal strings), not for character codes. The is useful if you just want to apply padding and alignment and don’t care about formatting numbers. For example, the infamous [left-pad](http://blog.npmjs.org/post/141577284765/kik-left-pad-and-npm) (as well as center- and right-pad!) can be conveniently implemented as:\n\n```js\nd3.format(\">10c\")(\"foo\"); // \"       foo\"\nd3.format(\"^10c\")(\"foo\"); // \"   foo    \"\nd3.format(\"<10c\")(\"foo\"); // \"foo       \"\n```\n\nThere are several new methods for computing suggested decimal precisions; these are used by [d3-scale](#scales-d3-scale) for tick formatting, and are helpful for implementing custom number formats: [d3.precisionFixed](https://github.com/d3/d3-format/blob/master/README.md#precisionFixed), [d3.precisionPrefix](https://github.com/d3/d3-format/blob/master/README.md#precisionPrefix) and [d3.precisionRound](https://github.com/d3/d3-format/blob/master/README.md#precisionRound). There’s also a new [d3.formatSpecifier](https://github.com/d3/d3-format/blob/master/README.md#formatSpecifier) method for parsing, validating and debugging format specifiers; it’s also good for deriving related format specifiers, such as when you want to substitute the precision automatically.\n\nYou can now set the default locale using [d3.formatDefaultLocale](https://github.com/d3/d3-format/blob/master/README.md#formatDefaultLocale)! The locales are published as [JSON](https://github.com/d3/d3-request/blob/master/README.md#json) to [npm](https://unpkg.com/d3-format/locale/).\n\n## [Geographies (d3-geo)](https://github.com/d3/d3-geo/blob/master/README.md)\n\nPursuant to the great namespace flattening, various methods have new names:\n\n* d3.geo.graticule ↦ [d3.geoGraticule](https://github.com/d3/d3-geo/blob/master/README.md#geoGraticule)\n* d3.geo.circle ↦ [d3.geoCircle](https://github.com/d3/d3-geo/blob/master/README.md#geoCircle)\n* d3.geo.area ↦ [d3.geoArea](https://github.com/d3/d3-geo/blob/master/README.md#geoArea)\n* d3.geo.bounds ↦ [d3.geoBounds](https://github.com/d3/d3-geo/blob/master/README.md#geoBounds)\n* d3.geo.centroid ↦ [d3.geoCentroid](https://github.com/d3/d3-geo/blob/master/README.md#geoCentroid)\n* d3.geo.distance ↦ [d3.geoDistance](https://github.com/d3/d3-geo/blob/master/README.md#geoDistance)\n* d3.geo.interpolate ↦ [d3.geoInterpolate](https://github.com/d3/d3-geo/blob/master/README.md#geoInterpolate)\n* d3.geo.length ↦ [d3.geoLength](https://github.com/d3/d3-geo/blob/master/README.md#geoLength)\n* d3.geo.rotation ↦ [d3.geoRotation](https://github.com/d3/d3-geo/blob/master/README.md#geoRotation)\n* d3.geo.stream ↦ [d3.geoStream](https://github.com/d3/d3-geo/blob/master/README.md#geoStream)\n* d3.geo.path ↦ [d3.geoPath](https://github.com/d3/d3-geo/blob/master/README.md#geoPath)\n* d3.geo.projection ↦ [d3.geoProjection](https://github.com/d3/d3-geo/blob/master/README.md#geoProjection)\n* d3.geo.projectionMutator ↦ [d3.geoProjectionMutator](https://github.com/d3/d3-geo/blob/master/README.md#geoProjectionMutator)\n* d3.geo.albers ↦ [d3.geoAlbers](https://github.com/d3/d3-geo/blob/master/README.md#geoAlbers)\n* d3.geo.albersUsa ↦ [d3.geoAlbersUsa](https://github.com/d3/d3-geo/blob/master/README.md#geoAlbersUsa)\n* d3.geo.azimuthalEqualArea ↦ [d3.geoAzimuthalEqualArea](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEqualArea)\n* d3.geo.azimuthalEquidistant ↦ [d3.geoAzimuthalEquidistant](https://github.com/d3/d3-geo/blob/master/README.md#geoAzimuthalEquidistant)\n* d3.geo.conicConformal ↦ [d3.geoConicConformal](https://github.com/d3/d3-geo/blob/master/README.md#geoConicConformal)\n* d3.geo.conicEqualArea ↦ [d3.geoConicEqualArea](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEqualArea)\n* d3.geo.conicEquidistant ↦ [d3.geoConicEquidistant](https://github.com/d3/d3-geo/blob/master/README.md#geoConicEquidistant)\n* d3.geo.equirectangular ↦ [d3.geoEquirectangular](https://github.com/d3/d3-geo/blob/master/README.md#geoEquirectangular)\n* d3.geo.gnomonic ↦ [d3.geoGnomonic](https://github.com/d3/d3-geo/blob/master/README.md#geoGnomonic)\n* d3.geo.mercator ↦ [d3.geoMercator](https://github.com/d3/d3-geo/blob/master/README.md#geoMercator)\n* d3.geo.orthographic ↦ [d3.geoOrthographic](https://github.com/d3/d3-geo/blob/master/README.md#geoOrthographic)\n* d3.geo.stereographic ↦ [d3.geoStereographic](https://github.com/d3/d3-geo/blob/master/README.md#geoStereographic)\n* d3.geo.transverseMercator ↦ [d3.geoTransverseMercator](https://github.com/d3/d3-geo/blob/master/README.md#geoTransverseMercator)\n\nAlso renamed for consistency:\n\n* *circle*.origin ↦ [*circle*.center](https://github.com/d3/d3-geo/blob/master/README.md#circle_center)\n* *circle*.angle ↦ [*circle*.radius](https://github.com/d3/d3-geo/blob/master/README.md#circle_radius)\n* *graticule*.majorExtent ↦ [*graticule*.extentMajor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_extentMajor)\n* *graticule*.minorExtent ↦ [*graticule*.extentMinor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_extentMinor)\n* *graticule*.majorStep ↦ [*graticule*.stepMajor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_stepMajor)\n* *graticule*.minorStep ↦ [*graticule*.stepMinor](https://github.com/d3/d3-geo/blob/master/README.md#graticule_stepMinor)\n\nProjections now have more appropriate defaults. For example, [d3.geoOrthographic](https://github.com/d3/d3-geo/blob/master/README.md#geoOrthographic) has a 90° clip angle by default, showing only the front hemisphere, and [d3.geoGnomonic](https://github.com/d3/d3-geo/blob/master/README.md#geoGnomonic) has a default 60° clip angle. The default [projection](https://github.com/d3/d3-geo/blob/master/README.md#path_projection) for [d3.geoPath](https://github.com/d3/d3-geo/blob/master/README.md#geoPath) is now null rather than [d3.geoAlbersUsa](https://github.com/d3/d3-geo/blob/master/README.md#geoAlbersUsa); a null projection is used with [pre-projected geometry](https://bl.ocks.org/mbostock/5557726) and is typically faster to render.\n\n“Fallback projections”—when you pass a function rather than a projection to [*path*.projection](https://github.com/d3/d3-geo/blob/master/README.md#path_projection)—are no longer supported. For geographic projections, use [d3.geoProjection](https://github.com/d3/d3-geo/blob/master/README.md#geoProjection) or [d3.geoProjectionMutator](https://github.com/d3/d3-geo/blob/master/README.md#geoProjectionMutator) to define a custom projection. For arbitrary geometry transformations, implement the [stream interface](https://github.com/d3/d3-geo/blob/master/README.md#streams); see also [d3.geoTransform](https://github.com/d3/d3-geo/blob/master/README.md#geoTransform). The “raw” projections (e.g., d3.geo.equirectangular.raw) are no longer exported.\n\n## [Hierarchies (d3-hierarchy)](https://github.com/d3/d3-hierarchy/blob/master/README.md)\n\nPursuant to the great namespace flattening:\n\n* d3.layout.cluster ↦ [d3.cluster](https://github.com/d3/d3-hierarchy/blob/master/README.md#cluster)\n* d3.layout.hierarchy ↦ [d3.hierarchy](https://github.com/d3/d3-hierarchy/blob/master/README.md#hierarchy)\n* d3.layout.pack ↦ [d3.pack](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack)\n* d3.layout.partition ↦ [d3.partition](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition)\n* d3.layout.tree ↦ [d3.tree](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree)\n* d3.layout.treemap ↦ [d3.treemap](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap)\n\nAs an alternative to using JSON to represent hierarchical data (such as the “flare.json format” used by many D3 examples), the new [d3.stratify](https://github.com/d3/d3-hierarchy/blob/master/README.md#stratify) operator simplifies the conversion of tabular data to hierarchical data! This is convenient if you already have data in a tabular format, such as the result of a SQL query or a CSV file:\n\n```\nname,parent\nEve,\nCain,Eve\nSeth,Eve\nEnos,Seth\nNoam,Seth\nAbel,Eve\nAwan,Eve\nEnoch,Awan\nAzura,Eve\n```\n\nTo convert this to a root [*node*](https://github.com/d3/d3-hierarchy/blob/master/README.md#hierarchy):\n\n```js\nvar root = d3.stratify()\n    .id(function(d) { return d.name; })\n    .parentId(function(d) { return d.parent; })\n    (nodes);\n```\n\nThe resulting *root* can be passed to [d3.tree](https://github.com/d3/d3-hierarchy/blob/master/README.md#tree) to produce a tree diagram like this:\n\n<img src=\"https://raw.githubusercontent.com/d3/d3/master/img/stratify.png\" width=\"298\" height=\"137\">\n\nRoot nodes can also be created from JSON data using [d3.hierarchy](https://github.com/d3/d3-hierarchy/blob/master/README.md#hierarchy). The hierarchy layouts now take these root nodes as input rather than operating directly on JSON data, which helps to provide a cleaner separation between the input data and the computed layout. (For example, use [*node*.copy](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_copy) to isolate layout changes.) It also simplifies the API: rather than each hierarchy layout needing to implement value and sorting accessors, there are now generic [*node*.sum](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_sum) and [*node*.sort](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_sort) methods that work with any hierarchy layout.\n\nThe new d3.hierarchy API also provides a richer set of methods for manipulating hierarchical data. For example, to generate an array of all nodes in topological order, use [*node*.descendants](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_descendants); for just leaf nodes, use [*node*.leaves](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_leaves). To highlight the ancestors of a given *node* on mouseover, use [*node*.ancestors](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_ancestors). To generate an array of {source, target} links for a given hierarchy, use [*node*.links](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_links); this replaces *treemap*.links and similar methods on the other layouts. The new [*node*.path](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_path) method replaces d3.layout.bundle; see also [d3.curveBundle](https://github.com/d3/d3-shape/blob/master/README.md#curveBundle) for hierarchical edge bundling.\n\nThe hierarchy layouts have been rewritten using new, non-recursive traversal methods ([*node*.each](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_each), [*node*.eachAfter](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_eachAfter) and [*node*.eachBefore](https://github.com/d3/d3-hierarchy/blob/master/README.md#node_eachBefore)), improving performance on large datasets. The d3.tree layout no longer uses a *node*.\\_ field to store temporary state during layout.\n\nTreemap tiling is now [extensible](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap-tiling) via [*treemap*.tile](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_tile)! The default squarified tiling algorithm, [d3.treemapSquarify](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapSquarify), has been completely rewritten, improving performance and fixing bugs in padding and rounding. The *treemap*.sticky method has been replaced with the [d3.treemapResquarify](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapResquarify), which is identical to d3.treemapSquarify except it performs stable neighbor-preserving updates. The *treemap*.ratio method has been replaced with [*squarify*.ratio](https://github.com/d3/d3-hierarchy/blob/master/README.md#squarify_ratio). And there’s a new [d3.treemapBinary](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemapBinary) for binary treemaps!\n\nTreemap padding has also been improved. The treemap now distinguishes between [outer padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingOuter) that separates a parent from its children, and [inner padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingInner) that separates adjacent siblings. You can set the [top-](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingTop), [right-](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingRight), [bottom-](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingBottom) and [left-](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap_paddingLeft)outer padding separately. There are new examples for the traditional [nested treemap](https://bl.ocks.org/mbostock/911ad09bdead40ec0061) and for Lü and Fogarty’s [cascaded treemap](https://bl.ocks.org/mbostock/f85ffb3a5ac518598043). And there’s a new example demonstrating [d3.nest with d3.treemap](https://bl.ocks.org/mbostock/2838bf53e0e65f369f476afd653663a2).\n\nThe space-filling layouts [d3.treemap](https://github.com/d3/d3-hierarchy/blob/master/README.md#treemap) and [d3.partition](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition) now output *x0*, *x1*, *y0*, *y1* on each node instead of *x0*, *dx*, *y0*, *dy*. This improves accuracy by ensuring that the edges of adjacent cells are exactly equal, rather than sometimes being slightly off due to floating point math. The partition layout now supports [rounding](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition_round) and [padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#partition_padding).\n\nThe circle-packing layout, [d3.pack](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack), has been completely rewritten to better implement Wang et al.’s algorithm, fixing major bugs and improving results! Welzl’s algorithm is now used to compute the exact [smallest enclosing circle](https://bl.ocks.org/mbostock/29c534ff0b270054a01c) for each parent, rather than the approximate answer used by Wang et al. The 3.x output is shown on the left; 4.0 is shown on the right:\n\n<img alt=\"Circle Packing in 3.x\" src=\"https://raw.githubusercontent.com/d3/d3/master/img/pack-v3.png\" width=\"420\" height=\"420\"> <img alt=\"Circle Packing in 4.0\" src=\"https://raw.githubusercontent.com/d3/d3/master/img/pack-v4.png\" width=\"420\" height=\"420\">\n\nA non-hierarchical implementation is also available as [d3.packSiblings](https://github.com/d3/d3-hierarchy/blob/master/README.md#packSiblings), and the smallest enclosing circle implementation is available as [d3.packEnclose](https://github.com/d3/d3-hierarchy/blob/master/README.md#packEnclose). [Pack padding](https://github.com/d3/d3-hierarchy/blob/master/README.md#pack_padding) now applies between a parent and its children, as well as between adjacent siblings. In addition, you can now specify padding as a function that is computed dynamically for each parent.\n\n## Internals\n\nThe d3.rebind method has been removed. (See the [3.x source](https://github.com/d3/d3/blob/v3.5.17/src/core/rebind.js).) If you want to wrap a getter-setter method, the recommend pattern is to implement a wrapper method and check the return value. For example, given a *component* that uses an internal [*dispatch*](#dispatches-d3-dispatch), *component*.on can rebind *dispatch*.on as follows:\n\n```js\ncomponent.on = function() {\n  var value = dispatch.on.apply(dispatch, arguments);\n  return value === dispatch ? component : value;\n};\n```\n\nThe d3.functor method has been removed. (See the [3.x source](https://github.com/d3/d3/blob/v3.5.17/src/core/functor.js).) If you want to promote a constant value to a function, the recommended pattern is to implement a closure that returns the constant value. If desired, you can use a helper method as follows:\n\n```js\nfunction constant(x) {\n  return function() {\n    return x;\n  };\n}\n```\n\nGiven a value *x*, to promote *x* to a function if it is not already:\n\n```js\nvar fx = typeof x === \"function\" ? x : constant(x);\n```\n\n## [Interpolators (d3-interpolate)](https://github.com/d3/d3-interpolate/blob/master/README.md)\n\nThe [d3.interpolate](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolate) method no longer delegates to d3.interpolators, which has been removed; its behavior is now defined by the library. It is now slightly faster in the common case that *b* is a number. It only uses [d3.interpolateRgb](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgb) if *b* is a valid CSS color specifier (and not approximately one). And if the end value *b* is null, undefined, true or false, d3.interpolate now returns a constant function which always returns *b*.\n\nThe behavior of [d3.interpolateObject](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateObject) and [d3.interpolateArray](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateArray) has changed slightly with respect to properties or elements in the start value *a* that do not exist in the end value *b*: these properties and elements are now ignored, such that the ending value of the interpolator at *t* = 1 is now precisely equal to *b*. So, in 3.x:\n\n```js\nd3.interpolateObject({foo: 2, bar: 1}, {foo: 3})(0.5); // {bar: 1, foo: 2.5} in 3.x\n```\n\nWhereas in 4.0, *a*.bar is ignored:\n\n```js\nd3.interpolateObject({foo: 2, bar: 1}, {foo: 3})(0.5); // {foo: 2.5} in 4.0\n```\n\nIf *a* or *b* are undefined or not an object, they are now implicitly converted to the empty object or empty array as appropriate, rather than throwing a TypeError.\n\nThe d3.interpolateTransform interpolator has been renamed to [d3.interpolateTransformSvg](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformSvg), and there is a new [d3.interpolateTransformCss](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformCss) to interpolate CSS transforms! This allows [d3-transition](#transitions-d3-transition) to automatically interpolate both the SVG [transform attribute](https://www.w3.org/TR/SVG/coords.html#TransformAttribute) and the CSS [transform style property](https://www.w3.org/TR/css-transforms-1/#transform-property). (Note, however, that only 2D CSS transforms are supported.) The d3.transform method has been removed.\n\nColor space interpolators now interpolate opacity (see [d3-color](#colors-d3-color)) and return rgb(…) or rgba(…) CSS color specifier strings rather than using the RGB hexadecimal format. This is necessary to support opacity interpolation, but is also beneficial because it matches CSS computed values. When a channel in the start color *a* is undefined, color interpolators now use the corresponding channel value from the end color *b*, or *vice versa*. This logic previously applied to some channels (such as saturation in HSL), but now applies to all channels in all color spaces, and is especially useful when interpolating to or from transparent.\n\nThere are now “long” versions of cylindrical color space interpolators: [d3.interpolateHslLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHslLong), [d3.interpolateHclLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateHclLong) and [d3.interpolateCubehelixLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateCubehelixLong). These interpolators use linear interpolation of hue, rather than using the shortest path around the 360° hue circle. See [d3.interpolateRainbow](https://github.com/d3/d3-scale/blob/master/README.md#interpolateRainbow) for an example. The Cubehelix color space is now supported by [d3-color](#colors-d3-color), and so there are now [d3.interpolateCubehelix](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateCubehelix) and [d3.interpolateCubehelixLong](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateCubehelixLong) interpolators.\n\n[Gamma-corrected color interpolation](https://web.archive.org/web/20160112115812/http://www.4p8.com/eric.brasseur/gamma.html) is now supported for both RGB and Cubehelix color spaces as [*interpolate*.gamma](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolate_gamma). For example, to interpolate from purple to orange with a gamma of 2.2 in RGB space:\n\n```js\nvar interpolate = d3.interpolateRgb.gamma(2.2)(\"purple\", \"orange\");\n```\n\nThere are new interpolators for uniform non-rational [B-splines](https://en.wikipedia.org/wiki/B-spline)! These are useful for smoothly interpolating between an arbitrary sequence of values from *t* = 0 to *t* = 1, such as to generate a smooth color gradient from a discrete set of colors. The [d3.interpolateBasis](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateBasis) and [d3.interpolateBasisClosed](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateBasisClosed) interpolators generate one-dimensional B-splines, while [d3.interpolateRgbBasis](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgbBasis) and [d3.interpolateRgbBasisClosed](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateRgbBasisClosed) generate three-dimensional B-splines through RGB color space. These are used by [d3-scale-chromatic](https://github.com/d3/d3-scale-chromatic) to generate continuous color scales from ColorBrewer’s discrete color schemes, such as [PiYG](https://bl.ocks.org/mbostock/048d21cf747371b11884f75ad896e5a5).\n\nThere’s also now a [d3.quantize](https://github.com/d3/d3-interpolate/blob/master/README.md#quantize) method for generating uniformly-spaced discrete samples from a continuous interpolator. This is useful for taking one of the built-in color scales (such as [d3.interpolateViridis](https://github.com/d3/d3-scale/blob/master/README.md#interpolateViridis)) and quantizing it for use with [d3.scaleQuantize](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantize), [d3.scaleQuantile](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantile) or [d3.scaleThreshold](https://github.com/d3/d3-scale/blob/master/README.md#scaleThreshold).\n\n## [Paths (d3-path)](https://github.com/d3/d3-path/blob/master/README.md)\n\nThe [d3.path](https://github.com/d3/d3-path/blob/master/README.md#path) serializer implements the [CanvasPathMethods API](https://www.w3.org/TR/2dcontext/#canvaspathmethods), allowing you to write code that can render to either Canvas or SVG. For example, given some code that draws to a canvas:\n\n```js\nfunction drawCircle(context, radius) {\n  context.moveTo(radius, 0);\n  context.arc(0, 0, radius, 0, 2 * Math.PI);\n}\n```\n\nYou can render to SVG as follows:\n\n```js\nvar context = d3.path();\ndrawCircle(context, 40);\npathElement.setAttribute(\"d\", context.toString());\n```\n\nThe path serializer enables [d3-shape](#shapes-d3-shape) to support both Canvas and SVG; see [*line*.context](https://github.com/d3/d3-shape/blob/master/README.md#line_context) and [*area*.context](https://github.com/d3/d3-shape/blob/master/README.md#area_context), for example.\n\n## [Polygons (d3-polygon)](https://github.com/d3/d3-polygon/blob/master/README.md)\n\nThere’s no longer a d3.geom.polygon constructor; instead you just pass an array of vertices to the polygon methods. So instead of *polygon*.area and *polygon*.centroid, there’s [d3.polygonArea](https://github.com/d3/d3-polygon/blob/master/README.md#polygonArea) and [d3.polygonCentroid](https://github.com/d3/d3-polygon/blob/master/README.md#polygonCentroid). There are also new [d3.polygonContains](https://github.com/d3/d3-polygon/blob/master/README.md#polygonContains) and [d3.polygonLength](https://github.com/d3/d3-polygon/blob/master/README.md#polygonLength) methods. There’s no longer an equivalent to *polygon*.clip, but if [Sutherland–Hodgman clipping](https://en.wikipedia.org/wiki/Sutherland–Hodgman_algorithm) is needed, please [file a feature request](https://github.com/d3/d3-polygon/issues).\n\nThe d3.geom.hull operator has been simplified: instead of an operator with *hull*.x and *hull*.y accessors, there’s just the [d3.polygonHull](https://github.com/d3/d3-polygon/blob/master/README.md#polygonHull) method which takes an array of points and returns the convex hull.\n\n## [Quadtrees (d3-quadtree)](https://github.com/d3/d3-quadtree/blob/master/README.md)\n\nThe d3.geom.quadtree method has been replaced by [d3.quadtree](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree). 4.0 removes the concept of quadtree “generators” (configurable functions that build a quadtree from an array of data); there are now just quadtrees, which you can create via d3.quadtree and add data to via [*quadtree*.add](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_add) and [*quadtree*.addAll](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_addAll). This code in 3.x:\n\n```js\nvar quadtree = d3.geom.quadtree()\n    .extent([[0, 0], [width, height]])\n    (data);\n```\n\nCan be rewritten in 4.0 as:\n\n```js\nvar quadtree = d3.quadtree()\n    .extent([[0, 0], [width, height]])\n    .addAll(data);\n```\n\nThe new quadtree implementation is vastly improved! It is no longer recursive, avoiding stack overflows when there are large numbers of coincident points. The internal storage is now more efficient, and the implementation is also faster; constructing a quadtree of 1M normally-distributed points takes about one second in 4.0, as compared to three seconds in 3.x.\n\nThe change in [internal *node* structure](https://github.com/d3/d3-quadtree/blob/master/README.md#nodes) affects [*quadtree*.visit](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_visit): use *node*.length to distinguish leaf nodes from internal nodes. For example, to iterate over all data in a quadtree:\n\n```js\nquadtree.visit(function(node) {\n  if (!node.length) {\n    do {\n      console.log(node.data);\n    } while (node = node.next)\n  }\n});\n```\n\nThere’s a new [*quadtree*.visitAfter](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_visitAfter) method for visiting nodes in post-order traversal. This feature is used in [d3-force](#forces-d3-force) to implement the [Barnes–Hut approximation](https://en.wikipedia.org/wiki/Barnes–Hut_simulation).\n\nYou can now remove data from a quadtree using [*quadtree*.remove](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_remove) and [*quadtree*.removeAll](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_removeAll). When adding data to a quadtree, the quadtree will now expand its extent by repeated doubling if the new point is outside the existing extent of the quadtree. There are also [*quadtree*.extent](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_extent) and [*quadtree*.cover](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_cover) methods for explicitly expanding the extent of the quadtree after creation.\n\nQuadtrees support several new utility methods: [*quadtree*.copy](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_copy) returns a copy of the quadtree sharing the same data; [*quadtree*.data](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_data) generates an array of all data in the quadtree; [*quadtree*.size](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_size) returns the number of data points in the quadtree; and [*quadtree*.root](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_root) returns the root node, which is useful for manual traversal of the quadtree. The [*quadtree*.find](https://github.com/d3/d3-quadtree/blob/master/README.md#quadtree_find) method now takes an optional search radius, which is useful for pointer-based selection in [force-directed graphs](https://bl.ocks.org/mbostock/ad70335eeef6d167bc36fd3c04378048).\n\n## [Queues (d3-queue)](https://github.com/d3/d3-queue/blob/master/README.md)\n\nFormerly known as Queue.js and queue-async, [d3.queue](https://github.com/d3/d3-queue) is now included in the default bundle, making it easy to load data files in parallel. It has been rewritten with fewer closures to improve performance, and there are now stricter checks in place to guarantee well-defined behavior. You can now use instanceof d3.queue and inspect the queue’s internal private state.\n\n## [Random Numbers (d3-random)](https://github.com/d3/d3-random/blob/master/README.md)\n\nPursuant to the great namespace flattening, the random number generators have new names:\n\n* d3.random.normal ↦ [d3.randomNormal](https://github.com/d3/d3-random/blob/master/README.md#randomNormal)\n* d3.random.logNormal ↦ [d3.randomLogNormal](https://github.com/d3/d3-random/blob/master/README.md#randomLogNormal)\n* d3.random.bates ↦ [d3.randomBates](https://github.com/d3/d3-random/blob/master/README.md#randomBates)\n* d3.random.irwinHall ↦ [d3.randomIrwinHall](https://github.com/d3/d3-random/blob/master/README.md#randomIrwinHall)\n\nThere are also new random number generators for [exponential](https://github.com/d3/d3-random/blob/master/README.md#randomExponential) and [uniform](https://github.com/d3/d3-random/blob/master/README.md#randomUniform) distributions. The [normal](https://github.com/d3/d3-random/blob/master/README.md#randomNormal) and [log-normal](https://github.com/d3/d3-random/blob/master/README.md#randomLogNormal) random generators have been optimized.\n\n## [Requests (d3-request)](https://github.com/d3/d3-request/blob/master/README.md)\n\nThe d3.xhr method has been renamed to [d3.request](https://github.com/d3/d3-request/blob/master/README.md#request). Basic authentication is now supported using [*request*.user](https://github.com/d3/d3-request/blob/master/README.md#request_user) and [*request*.password](https://github.com/d3/d3-request/blob/master/README.md#request_password). You can now configure a timeout using [*request*.timeout](https://github.com/d3/d3-request/blob/master/README.md#request_timeout).\n\nIf an error occurs, the corresponding [ProgressEvent](https://xhr.spec.whatwg.org/#interface-progressevent) of type “error” is now passed to the error listener, rather than the [XMLHttpRequest](https://xhr.spec.whatwg.org/#interface-xmlhttprequest). Likewise, the ProgressEvent is passed to progress event listeners, rather than using [d3.event](https://github.com/d3/d3-selection/blob/master/README.md#event). If [d3.xml](https://github.com/d3/d3-request/blob/master/README.md#xml) encounters an error parsing XML, this error is now reported to error listeners rather than returning a null response.\n\nThe [d3.request](https://github.com/d3/d3-request/blob/master/README.md#request), [d3.text](https://github.com/d3/d3-request/blob/master/README.md#text) and [d3.xml](https://github.com/d3/d3-request/blob/master/README.md#xml) methods no longer take an optional mime type as the second argument; use [*request*.mimeType](https://github.com/d3/d3-request/blob/master/README.md#request_mimeType) instead. For example:\n\n```js\nd3.xml(\"file.svg\").mimeType(\"image/svg+xml\").get(function(error, svg) {\n  …\n});\n```\n\nWith the exception of [d3.html](https://github.com/d3/d3-request/blob/master/README.md#html) and [d3.xml](https://github.com/d3/d3-request/blob/master/README.md#xml), Node is now supported via [node-XMLHttpRequest](https://github.com/driverdan/node-XMLHttpRequest).\n\n## [Scales (d3-scale)](https://github.com/d3/d3-scale/blob/master/README.md)\n\nPursuant to the great namespace flattening:\n\n* d3.scale.linear ↦ [d3.scaleLinear](https://github.com/d3/d3-scale/blob/master/README.md#scaleLinear)\n* d3.scale.sqrt ↦ [d3.scaleSqrt](https://github.com/d3/d3-scale/blob/master/README.md#scaleSqrt)\n* d3.scale.pow ↦ [d3.scalePow](https://github.com/d3/d3-scale/blob/master/README.md#scalePow)\n* d3.scale.log ↦ [d3.scaleLog](https://github.com/d3/d3-scale/blob/master/README.md#scaleLog)\n* d3.scale.quantize ↦ [d3.scaleQuantize](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantize)\n* d3.scale.threshold ↦ [d3.scaleThreshold](https://github.com/d3/d3-scale/blob/master/README.md#scaleThreshold)\n* d3.scale.quantile ↦ [d3.scaleQuantile](https://github.com/d3/d3-scale/blob/master/README.md#scaleQuantile)\n* d3.scale.identity ↦ [d3.scaleIdentity](https://github.com/d3/d3-scale/blob/master/README.md#scaleIdentity)\n* d3.scale.ordinal ↦ [d3.scaleOrdinal](https://github.com/d3/d3-scale/blob/master/README.md#scaleOrdinal)\n* d3.time.scale ↦ [d3.scaleTime](https://github.com/d3/d3-scale/blob/master/README.md#scaleTime)\n* d3.time.scale.utc ↦ [d3.scaleUtc](https://github.com/d3/d3-scale/blob/master/README.md#scaleUtc)\n\nScales now generate ticks in the same order as the domain: if you have a descending domain, you now get descending ticks. This change affects the order of tick elements generated by [axes](#axes-d3-axis). For example:\n\n```js\nd3.scaleLinear().domain([10, 0]).ticks(5); // [10, 8, 6, 4, 2, 0]\n```\n\n[Log tick formatting](https://github.com/d3/d3-scale/blob/master/README.md#log_tickFormat) now assumes a default *count* of ten, not Infinity, if not specified. Log scales with  domains that span many powers (such as from 1e+3 to 1e+29) now return only one [tick](https://github.com/d3/d3-scale/blob/master/README.md#log_ticks) per power rather than returning *base* ticks per power. Non-linear quantitative scales are slightly more accurate.\n\nYou can now control whether an ordinal scale’s domain is implicitly extended when the scale is passed a value that is not already in its domain. By default, [*ordinal*.unknown](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_unknown) is [d3.scaleImplicit](https://github.com/d3/d3-scale/blob/master/README.md#scaleImplicit), causing unknown values to be added to the domain:\n\n```js\nvar x = d3.scaleOrdinal()\n    .domain([0, 1])\n    .range([\"red\", \"green\", \"blue\"]);\n\nx.domain(); // [0, 1]\nx(2); // \"blue\"\nx.domain(); // [0, 1, 2]\n```\n\nBy setting *ordinal*.unknown, you instead define the output value for unknown inputs. This is particularly useful for choropleth maps where you want to assign a color to missing data.\n\n```js\nvar x = d3.scaleOrdinal()\n    .domain([0, 1])\n    .range([\"red\", \"green\", \"blue\"])\n    .unknown(undefined);\n\nx.domain(); // [0, 1]\nx(2); // undefined\nx.domain(); // [0, 1]\n```\n\nThe *ordinal*.rangeBands and *ordinal*.rangeRoundBands methods have been replaced with a new subclass of ordinal scale: [band scales](https://github.com/d3/d3-scale/blob/master/README.md#band-scales). The following code in 3.x:\n\n```js\nvar x = d3.scale.ordinal()\n    .domain([\"a\", \"b\", \"c\"])\n    .rangeBands([0, width]);\n```\n\nIs equivalent to this in 4.0:\n\n```js\nvar x = d3.scaleBand()\n    .domain([\"a\", \"b\", \"c\"])\n    .range([0, width]);\n```\n\nThe new [*band*.padding](https://github.com/d3/d3-scale/blob/master/README.md#band_padding), [*band*.paddingInner](https://github.com/d3/d3-scale/blob/master/README.md#band_paddingInner) and [*band*.paddingOuter](https://github.com/d3/d3-scale/blob/master/README.md#band_paddingOuter) methods replace the optional arguments to *ordinal*.rangeBands. The new [*band*.bandwidth](https://github.com/d3/d3-scale/blob/master/README.md#band_bandwidth) and [*band*.step](https://github.com/d3/d3-scale/blob/master/README.md#band_step) methods replace *ordinal*.rangeBand. There’s also a new [*band*.align](https://github.com/d3/d3-scale/blob/master/README.md#band_align) method which you can use to control how the extra space outside the bands is distributed, say to shift columns closer to the *y*-axis.\n\nSimilarly, the *ordinal*.rangePoints and *ordinal*.rangeRoundPoints methods have been replaced with a new subclass of ordinal scale: [point scales](https://github.com/d3/d3-scale/blob/master/README.md#point-scales). The following code in 3.x:\n\n```js\nvar x = d3.scale.ordinal()\n    .domain([\"a\", \"b\", \"c\"])\n    .rangePoints([0, width]);\n```\n\nIs equivalent to this in 4.0:\n\n```js\nvar x = d3.scalePoint()\n    .domain([\"a\", \"b\", \"c\"])\n    .range([0, width]);\n```\n\nThe new [*point*.padding](https://github.com/d3/d3-scale/blob/master/README.md#point_padding) method replaces the optional *padding* argument to *ordinal*.rangePoints. Like *ordinal*.rangeBand with *ordinal*.rangePoints, the [*point*.bandwidth](https://github.com/d3/d3-scale/blob/master/README.md#point_bandwidth) method always returns zero; a new [*point*.step](https://github.com/d3/d3-scale/blob/master/README.md#point_step) method returns the interval between adjacent points.\n\nThe [ordinal scale constructor](https://github.com/d3/d3-scale/blob/master/README.md#ordinal-scales) now takes an optional *range* for a shorter alternative to [*ordinal*.range](https://github.com/d3/d3-scale/blob/master/README.md#ordinal_range). This is especially useful now that the categorical color scales have been changed to simple arrays of colors rather than specialized ordinal scale constructors:\n\n* d3.scale.category10 ↦ [d3.schemeCategory10](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory10)\n* d3.scale.category20 ↦ [d3.schemeCategory20](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20)\n* d3.scale.category20b ↦ [d3.schemeCategory20b](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20b)\n* d3.scale.category20c ↦ [d3.schemeCategory20c](https://github.com/d3/d3-scale/blob/master/README.md#schemeCategory20c)\n\nThe following code in 3.x:\n\n```js\nvar color = d3.scale.category10();\n```\n\nIs equivalent to this in 4.0:\n\n```js\nvar color = d3.scaleOrdinal(d3.schemeCategory10);\n```\n\n[Sequential scales](https://github.com/d3/d3-scale/blob/master/README.md#scaleSequential), are a new class of scales with a fixed output [interpolator](https://github.com/d3/d3-scale/blob/master/README.md#sequential_interpolator) instead of a [range](https://github.com/d3/d3-scale/blob/master/README.md#continuous_range). Typically these scales are used to implement continuous sequential or diverging color schemes. Inspired by Matplotlib’s new [perceptually-motived colormaps](https://bids.github.io/colormap/), 4.0 now features [viridis](https://github.com/d3/d3-scale/blob/master/README.md#interpolateViridis), [inferno](https://github.com/d3/d3-scale/blob/master/README.md#interpolateInferno), [magma](https://github.com/d3/d3-scale/blob/master/README.md#interpolateMagma), [plasma](https://github.com/d3/d3-scale/blob/master/README.md#interpolatePlasma) interpolators for use with sequential scales. Using [d3.quantize](https://github.com/d3/d3-interpolate/blob/master/README.md#quantize), these interpolators can also be applied to [quantile](https://github.com/d3/d3-scale/blob/master/README.md#quantile-scales), [quantize](https://github.com/d3/d3-scale/blob/master/README.md#quantize-scales) and [threshold](https://github.com/d3/d3-scale/blob/master/README.md#threshold-scales) scales.\n\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/viridis.png\" width=\"100%\" height=\"40\" alt=\"viridis\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateViridis)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/inferno.png\" width=\"100%\" height=\"40\" alt=\"inferno\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateInferno)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/magma.png\" width=\"100%\" height=\"40\" alt=\"magma\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateMagma)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/plasma.png\" width=\"100%\" height=\"40\" alt=\"plasma\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolatePlasma)\n\n4.0 also ships new Cubehelix schemes, including [Dave Green’s default](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCubehelixDefault) and a [cyclical rainbow](https://github.com/d3/d3-scale/blob/master/README.md#interpolateRainbow) inspired by [Matteo Niccoli](https://mycarta.wordpress.com/2013/02/21/perceptual-rainbow-palette-the-method/):\n\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/cubehelix.png\" width=\"100%\" height=\"40\" alt=\"cubehelix\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCubehelixDefault)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/rainbow.png\" width=\"100%\" height=\"40\" alt=\"rainbow\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateRainbow)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/warm.png\" width=\"100%\" height=\"40\" alt=\"warm\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateWarm)\n[<img src=\"https://raw.githubusercontent.com/d3/d3-scale/master/img/cool.png\" width=\"100%\" height=\"40\" alt=\"cool\">](https://github.com/d3/d3-scale/blob/master/README.md#interpolateCool)\n\nFor even more sequential and categorical color schemes, see [d3-scale-chromatic](https://github.com/d3/d3-scale-chromatic).\n\nFor an introduction to scales, see [Introducing d3-scale](https://medium.com/@mbostock/introducing-d3-scale-61980c51545f).\n\n## [Selections (d3-selection)](https://github.com/d3/d3-selection/blob/master/README.md)\n\nSelections no longer subclass Array using [prototype chain injection](http://perfectionkills.com/how-ecmascript-5-still-does-not-allow-to-subclass-an-array/#wrappers_prototype_chain_injection); they are now plain objects, improving performance. The internal fields (*selection*.\\_groups, *selection*.\\_parents) are private; please use the documented public API to manipulate selections. The new [*selection*.nodes](https://github.com/d3/d3-selection/blob/master/README.md#selection_nodes) method generates an array of all nodes in a selection.\n\nSelections are now immutable: the elements and parents in a selection never change. (The elements’ attributes and content will of course still be modified!) The [*selection*.sort](https://github.com/d3/d3-selection/blob/master/README.md#selection_sort) and [*selection*.data](https://github.com/d3/d3-selection/blob/master/README.md#selection_data) methods now return new selections rather than modifying the selection in-place. In addition, [*selection*.append](https://github.com/d3/d3-selection/blob/master/README.md#selection_append) no longer merges entering nodes into the update selection; use [*selection*.merge](https://github.com/d3/d3-selection/blob/master/README.md#selection_merge) to combine enter and update after a data join. For example, the following [general update pattern](https://bl.ocks.org/mbostock/a8a5baa4c4a470cda598) in 3.x:\n\n```js\nvar circle = svg.selectAll(\"circle\").data(data) // UPDATE\n    .style(\"fill\", \"blue\");\n\ncircle.exit().remove(); // EXIT\n\ncircle.enter().append(\"circle\") // ENTER; modifies UPDATE! 🌶\n    .style(\"fill\", \"green\");\n\ncircle // ENTER + UPDATE\n    .style(\"stroke\", \"black\");\n```\n\nWould be rewritten in 4.0 as:\n\n```js\nvar circle = svg.selectAll(\"circle\").data(data) // UPDATE\n    .style(\"fill\", \"blue\");\n\ncircle.exit().remove(); // EXIT\n\ncircle.enter().append(\"circle\") // ENTER\n    .style(\"fill\", \"green\")\n  .merge(circle) // ENTER + UPDATE\n    .style(\"stroke\", \"black\");\n```\n\nThis change is discussed further in [What Makes Software Good](https://medium.com/@mbostock/what-makes-software-good-943557f8a488).\n\nIn 3.x, the [*selection*.enter](https://github.com/d3/d3-selection/blob/master/README.md#selection_enter) and [*selection*.exit](https://github.com/d3/d3-selection/blob/master/README.md#selection_exit) methods were undefined until you called *selection*.data, resulting in a TypeError if you attempted to access them. In 4.0, now they simply return the empty selection if the selection has not been joined to data.\n\nIn 3.x, [*selection*.append](https://github.com/d3/d3-selection/blob/master/README.md#selection_append) would always append the new element as the last child of its parent. A little-known trick was to use [*selection*.insert](https://github.com/d3/d3-selection/blob/master/README.md#selection_insert) without specifying a *before* selector when entering nodes, causing the entering nodes to be inserted before the following element in the update selection. In 4.0, this is now the default behavior of *selection*.append; if you do not specify a *before* selector to *selection*.insert, the inserted element is appended as the last child. This change makes the general update pattern preserve the relative order of elements and data. For example, given the following DOM:\n\n```html\n<div>a</div>\n<div>b</div>\n<div>f</div>\n```\n\nAnd the following code:\n\n```js\nvar div = d3.select(\"body\").selectAll(\"div\")\n  .data([\"a\", \"b\", \"c\", \"d\", \"e\", \"f\"], function(d) { return d || this.textContent; });\n\ndiv.enter().append(\"div\")\n    .text(function(d) { return d; });\n```\n\nThe resulting DOM will be:\n\n```html\n<div>a</div>\n<div>b</div>\n<div>c</div>\n<div>d</div>\n<div>e</div>\n<div>f</div>\n```\n\nThus, the entering *c*, *d* and *e* are inserted before *f*, since *f* is the following element in the update selection. Although this behavior is sufficient to preserve order if the new data’s order is stable, if the data changes order, you must still use [*selection*.order](https://github.com/d3/d3-selection/blob/master/README.md#selection_order) to reorder elements.\n\nThere is now only one class of selection. 3.x implemented enter selections using a special class with different behavior for *enter*.append and *enter*.select; a consequence of this design was that enter selections in 3.x lacked [certain methods](https://github.com/d3/d3/issues/2043). In 4.0, enter selections are simply normal selections; they have the same methods and the same behavior. Placeholder [enter nodes](https://github.com/d3/d3-selection/blob/master/src/selection/enter.js) now implement [*node*.appendChild](https://developer.mozilla.org/en-US/docs/Web/API/Node/appendChild), [*node*.insertBefore](https://developer.mozilla.org/en-US/docs/Web/API/Node/insertBefore), [*node*.querySelector](https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelector), and [*node*.querySelectorAll](https://developer.mozilla.org/en-US/docs/Web/API/Element/querySelectorAll).\n\nThe [*selection*.data](https://github.com/d3/d3-selection/blob/master/README.md#selection_data) method has been changed slightly with respect to duplicate keys. In 3.x, if multiple data had the same key, the duplicate data would be ignored and not included in enter, update or exit; in 4.0 the duplicate data is always put in the enter selection. In both 3.x and 4.0, if multiple elements have the same key, the duplicate elements are put in the exit selection. Thus, 4.0’s behavior is now symmetric for enter and exit, and the general update pattern will now produce a DOM that matches the data even if there are duplicate keys.\n\nSelections have several new methods! Use [*selection*.raise](https://github.com/d3/d3-selection/blob/master/README.md#selection_raise) to move the selected elements to the front of their siblings, so that they are drawn on top; use [*selection*.lower](https://github.com/d3/d3-selection/blob/master/README.md#selection_lower) to move them to the back. Use [*selection*.dispatch](https://github.com/d3/d3-selection/blob/master/README.md#selection_dispatch) to dispatch a [custom event](https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent) to event listeners.\n\nWhen called in getter mode, [*selection*.data](https://github.com/d3/d3-selection/blob/master/README.md#selection_data) now returns the data for all elements in the selection, rather than just the data for the first group of elements. The [*selection*.call](https://github.com/d3/d3-selection/blob/master/README.md#selection_call) method no longer sets the `this` context when invoking the specified function; the *selection* is passed as the first argument to the function, so use that. The [*selection*.on](https://github.com/d3/d3-selection/blob/master/README.md#selection_on) method now accepts multiple whitespace-separated typenames, so you can add or remove multiple listeners simultaneously. For example:\n\n```js\nselection.on(\"mousedown touchstart\", function() {\n  console.log(d3.event.type);\n});\n```\n\nThe arguments passed to callback functions has changed slightly in 4.0 to be more consistent. The standard arguments are the element’s datum (*d*), the element’s index (*i*), and the element’s group (*nodes*), with *this* as the element. The slight exception to this convention is *selection*.data, which is evaluated for each group rather than each element; it is passed the group’s parent datum (*d*), the group index (*i*), and the selection’s parents (*parents*), with *this* as the group’s parent.\n\nThe new [d3.local](https://github.com/d3/d3-selection/blob/master/README.md#local-variables) provides a mechanism for defining [local variables](https://bl.ocks.org/mbostock/e1192fe405703d8321a5187350910e08): state that is bound to DOM elements, and available to any descendant element. This can be a convenient alternative to using [*selection*.each](https://github.com/d3/d3-selection/blob/master/README.md#selection_each) or storing local state in data.\n\nThe d3.ns.prefix namespace prefix map has been renamed to [d3.namespaces](https://github.com/d3/d3-selection/blob/master/README.md#namespaces), and the d3.ns.qualify method has been renamed to [d3.namespace](https://github.com/d3/d3-selection/blob/master/README.md#namespace). Several new low-level methods are now available, as well. [d3.matcher](https://github.com/d3/d3-selection/blob/master/README.md#matcher) is used internally by [*selection*.filter](https://github.com/d3/d3-selection/blob/master/README.md#selection_filter); [d3.selector](https://github.com/d3/d3-selection/blob/master/README.md#selector) is used by [*selection*.select](https://github.com/d3/d3-selection/blob/master/README.md#selection_select); [d3.selectorAll](https://github.com/d3/d3-selection/blob/master/README.md#selectorAll) is used by [*selection*.selectAll](https://github.com/d3/d3-selection/blob/master/README.md#selection_selectAll); [d3.creator](https://github.com/d3/d3-selection/blob/master/README.md#creator) is used by [*selection*.append](https://github.com/d3/d3-selection/blob/master/README.md#selection_append) and [*selection*.insert](https://github.com/d3/d3-selection/blob/master/README.md#selection_insert). The new [d3.window](https://github.com/d3/d3-selection/blob/master/README.md#window) returns the owner window for a given element, window or document. The new [d3.customEvent](https://github.com/d3/d3-selection/blob/master/README.md#customEvent) temporarily sets [d3.event](https://github.com/d3/d3-selection/blob/master/README.md#event) while invoking a function, allowing you to implement controls which dispatch custom events; this is used by [d3-drag](https://github.com/d3/d3-drag), [d3-zoom](https://github.com/d3/d3-zoom) and [d3-brush](https://github.com/d3/d3-brush).\n\nFor the sake of parsimony, the multi-value methods—where you pass an object to set multiple attributes, styles or properties simultaneously—have been extracted to [d3-selection-multi](https://github.com/d3/d3-selection-multi) and are no longer part of the default bundle. The multi-value map methods have also been renamed to plural form to reduce overload: [*selection*.attrs](https://github.com/d3/d3-selection-multi/blob/master/README.md#selection_attrs), [*selection*.styles](https://github.com/d3/d3-selection-multi/blob/master/README.md#selection_styles) and [*selection*.properties](https://github.com/d3/d3-selection-multi/blob/master/README.md#selection_properties).\n\n## [Shapes (d3-shape)](https://github.com/d3/d3-shape/blob/master/README.md)\n\nPursuant to the great namespace flattening:\n\n* d3.svg.line ↦ [d3.line](https://github.com/d3/d3-shape/blob/master/README.md#lines)\n* d3.svg.line.radial ↦ [d3.radialLine](https://github.com/d3/d3-shape/blob/master/README.md#radialLine)\n* d3.svg.area ↦ [d3.area](https://github.com/d3/d3-shape/blob/master/README.md#areas)\n* d3.svg.area.radial ↦ [d3.radialArea](https://github.com/d3/d3-shape/blob/master/README.md#radialArea)\n* d3.svg.arc ↦ [d3.arc](https://github.com/d3/d3-shape/blob/master/README.md#arcs)\n* d3.svg.symbol ↦ [d3.symbol](https://github.com/d3/d3-shape/blob/master/README.md#symbols)\n* d3.svg.symbolTypes ↦ [d3.symbolTypes](https://github.com/d3/d3-shape/blob/master/README.md#symbolTypes)\n* d3.layout.pie ↦ [d3.pie](https://github.com/d3/d3-shape/blob/master/README.md#pies)\n* d3.layout.stack ↦ [d3.stack](https://github.com/d3/d3-shape/blob/master/README.md#stacks)\n* d3.svg.diagonal ↦ REMOVED (see [d3/d3-shape#27](https://github.com/d3/d3-shape/issues/27))\n* d3.svg.diagonal.radial ↦ REMOVED\n\nShapes are no longer limited to SVG; they can now render to Canvas! Shape generators now support an optional *context*: given a [CanvasRenderingContext2D](https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D), you can render a shape as a canvas path to be filled or stroked. For example, a [canvas pie chart](https://bl.ocks.org/mbostock/8878e7fd82034f1d63cf) might use an arc generator:\n\n```js\nvar arc = d3.arc()\n    .outerRadius(radius - 10)\n    .innerRadius(0)\n    .context(context);\n```\n\nTo render an arc for a given datum *d*:\n\n```js\ncontext.beginPath();\narc(d);\ncontext.fill();\n```\n\nSee [*line*.context](https://github.com/d3/d3-shape/blob/master/README.md#line_context), [*area*.context](https://github.com/d3/d3-shape/blob/master/README.md#area_context) and [*arc*.context](https://github.com/d3/d3-shape/blob/master/README.md#arc_context) for more. Under the hood, shapes use [d3-path](#paths-d3-path) to serialize canvas path methods to SVG path data when the context is null; thus, shapes are optimized for rendering to canvas. You can also now derive lines from areas. The line shares most of the same accessors, such as [*line*.defined](https://github.com/d3/d3-shape/blob/master/README.md#line_defined) and [*line*.curve](https://github.com/d3/d3-shape/blob/master/README.md#line_curve), with the area from which it is derived. For example, to render the topline of an area, use [*area*.lineY1](https://github.com/d3/d3-shape/blob/master/README.md#area_lineY1); for the baseline, use [*area*.lineY0](https://github.com/d3/d3-shape/blob/master/README.md#area_lineY0).\n\n4.0 introduces a new curve API for specifying how line and area shapes interpolate between data points. The *line*.interpolate and *area*.interpolate methods have been replaced with [*line*.curve](https://github.com/d3/d3-shape/blob/master/README.md#line_curve) and [*area*.curve](https://github.com/d3/d3-shape/blob/master/README.md#area_curve). Curves are implemented using the [curve interface](https://github.com/d3/d3-shape/blob/master/README.md#custom-curves) rather than as a function that returns an SVG path data string; this allows curves to render to either SVG or Canvas. In addition, *line*.curve and *area*.curve now take a function which instantiates a curve for a given *context*, rather than a string. The full list of equivalents:\n\n* linear ↦ [d3.curveLinear](https://github.com/d3/d3-shape/blob/master/README.md#curveLinear)\n* linear-closed ↦ [d3.curveLinearClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveLinearClosed)\n* step ↦ [d3.curveStep](https://github.com/d3/d3-shape/blob/master/README.md#curveStep)\n* step-before ↦ [d3.curveStepBefore](https://github.com/d3/d3-shape/blob/master/README.md#curveStepBefore)\n* step-after ↦ [d3.curveStepAfter](https://github.com/d3/d3-shape/blob/master/README.md#curveStepAfter)\n* basis ↦ [d3.curveBasis](https://github.com/d3/d3-shape/blob/master/README.md#curveBasis)\n* basis-open ↦ [d3.curveBasisOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveBasisOpen)\n* basis-closed ↦ [d3.curveBasisClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveBasisClosed)\n* bundle ↦ [d3.curveBundle](https://github.com/d3/d3-shape/blob/master/README.md#curveBundle)\n* cardinal ↦ [d3.curveCardinal](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinal)\n* cardinal-open ↦ [d3.curveCardinalOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinalOpen)\n* cardinal-closed ↦ [d3.curveCardinalClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinalClosed)\n* monotone ↦ [d3.curveMonotoneX](https://github.com/d3/d3-shape/blob/master/README.md#curveMonotoneX)\n\nBut that’s not all! 4.0 now provides parameterized Catmull–Rom splines as proposed by [Yuksel *et al.*](http://www.cemyuksel.com/research/catmullrom_param/). These are available as [d3.curveCatmullRom](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRom), [d3.curveCatmullRomClosed](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRomClosed) and [d3.curveCatmullRomOpen](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRomOpen).\n\n<img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/catmullRom.png\" width=\"888\" height=\"240\" alt=\"catmullRom\">\n<img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/catmullRomOpen.png\" width=\"888\" height=\"240\" alt=\"catmullRomOpen\">\n<img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/catmullRomClosed.png\" width=\"888\" height=\"330\" alt=\"catmullRomClosed\">\n\nEach curve type can define its own named parameters, replacing *line*.tension and *area*.tension. For example, Catmull–Rom splines are parameterized using [*catmullRom*.alpha](https://github.com/d3/d3-shape/blob/master/README.md#curveCatmullRom_alpha) and defaults to 0.5, which corresponds to a centripetal spline that avoids self-intersections and overshoot. For a uniform Catmull–Rom spline instead:\n\n```js\nvar line = d3.line()\n    .curve(d3.curveCatmullRom.alpha(0));\n```\n\n4.0 fixes the interpretation of the cardinal spline *tension* parameter, which is now specified as [*cardinal*.tension](https://github.com/d3/d3-shape/blob/master/README.md#curveCardinal_tension) and defaults to zero for a uniform Catmull–Rom spline; a tension of one produces a linear curve. The first and last segments of basis and cardinal curves have also been fixed! The undocumented *interpolate*.reverse field has been removed. Curves can define different behavior for toplines and baselines by counting the sequence of [*curve*.lineStart](https://github.com/d3/d3-shape/blob/master/README.md#curve_lineStart) within [*curve*.areaStart](https://github.com/d3/d3-shape/blob/master/README.md#curve_areaStart). See the [d3.curveStep implementation](https://github.com/d3/d3-shape/blob/master/src/curve/step.js) for an example.\n\n4.0 fixes numerous bugs in the monotone curve implementation, and introduces [d3.curveMonotoneY](https://github.com/d3/d3-shape/blob/master/README.md#curveMonotoneY); this is like d3.curveMonotoneX, except it requires that the input points are monotone in *y* rather than *x*, such as for a vertically-oriented line chart. The new [d3.curveNatural](https://github.com/d3/d3-shape/blob/master/README.md#curveNatural) produces a [natural cubic spline](http://mathworld.wolfram.com/CubicSpline.html). The default [β](https://github.com/d3/d3-shape/blob/master/README.md#bundle_beta) for [d3.curveBundle](https://github.com/d3/d3-shape/blob/master/README.md#curveBundle) is now 0.85, rather than 0.7, matching the values used by [Holten](https://www.win.tue.nl/vis1/home/dholten/papers/bundles_infovis.pdf). 4.0 also has a more robust implementation of arc padding; see [*arc*.padAngle](https://github.com/d3/d3-shape/blob/master/README.md#arc_padAngle) and [*arc*.padRadius](https://github.com/d3/d3-shape/blob/master/README.md#arc_padRadius).\n\n4.0 introduces a new symbol type API. Symbol types are passed to [*symbol*.type](https://github.com/d3/d3-shape/blob/master/README.md#symbol_type) in place of strings. The equivalents are:\n\n* circle ↦ [d3.symbolCircle](https://github.com/d3/d3-shape/blob/master/README.md#symbolCircle)\n* cross ↦ [d3.symbolCross](https://github.com/d3/d3-shape/blob/master/README.md#symbolCross)\n* diamond ↦ [d3.symbolDiamond](https://github.com/d3/d3-shape/blob/master/README.md#symbolDiamond)\n* square ↦ [d3.symbolSquare](https://github.com/d3/d3-shape/blob/master/README.md#symbolSquare)\n* triangle-down ↦ REMOVED\n* triangle-up ↦ [d3.symbolTriangle](https://github.com/d3/d3-shape/blob/master/README.md#symbolTriangle)\n* ADDED ↦ [d3.symbolStar](https://github.com/d3/d3-shape/blob/master/README.md#symbolStar)\n* ADDED ↦ [d3.symbolWye](https://github.com/d3/d3-shape/blob/master/README.md#symbolWye)\n\nThe full set of symbol types is now:\n\n<a href=\"#symbolCircle\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/circle.png\" width=\"100\" height=\"100\"></a><a href=\"#symbolCross\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/cross.png\" width=\"100\" height=\"100\"></a><a href=\"#symbolDiamond\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/diamond.png\" width=\"100\" height=\"100\"></a><a href=\"#symbolSquare\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/square.png\" width=\"100\" height=\"100\"></a><a href=\"#symbolStar\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/star.png\" width=\"100\" height=\"100\"></a><a href=\"#symbolTriangle\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/triangle.png\" width=\"100\" height=\"100\"><a href=\"#symbolWye\"><img src=\"https://raw.githubusercontent.com/d3/d3-shape/master/img/wye.png\" width=\"100\" height=\"100\"></a>\n\nLastly, 4.0 overhauls the stack layout API, replacing d3.layout.stack with [d3.stack](https://github.com/d3/d3-shape/blob/master/README.md#stacks). The stack generator no longer needs an *x*-accessor. In addition, the API has been simplified: the *stack* generator now accepts tabular input, such as this array of objects:\n\n```js\nvar data = [\n  {month: new Date(2015, 0, 1), apples: 3840, bananas: 1920, cherries: 960, dates: 400},\n  {month: new Date(2015, 1, 1), apples: 1600, bananas: 1440, cherries: 960, dates: 400},\n  {month: new Date(2015, 2, 1), apples:  640, bananas:  960, cherries: 640, dates: 400},\n  {month: new Date(2015, 3, 1), apples:  320, bananas:  480, cherries: 640, dates: 400}\n];\n```\n\nTo generate the stack layout, first define a stack generator, and then apply it to the data:\n\n```js\nvar stack = d3.stack()\n    .keys([\"apples\", \"bananas\", \"cherries\", \"dates\"])\n    .order(d3.stackOrderNone)\n    .offset(d3.stackOffsetNone);\n\nvar series = stack(data);\n```\n\nThe resulting array has one element per *series*. Each series has one point per month, and each point has a lower and upper value defining the baseline and topline:\n\n```js\n[\n  [[   0, 3840], [   0, 1600], [   0,  640], [   0,  320]], // apples\n  [[3840, 5760], [1600, 3040], [ 640, 1600], [ 320,  800]], // bananas\n  [[5760, 6720], [3040, 4000], [1600, 2240], [ 800, 1440]], // cherries\n  [[6720, 7120], [4000, 4400], [2240, 2640], [1440, 1840]], // dates\n]\n```\n\nEach series in then typically passed to an [area generator](https://github.com/d3/d3-shape/blob/master/README.md#areas) to render an area chart, or used to construct rectangles for a bar chart. Stack generators no longer modify the input data, so *stack*.out has been removed.\n\nFor an introduction to shapes, see [Introducing d3-shape](https://medium.com/@mbostock/introducing-d3-shape-73f8367e6d12).\n\n## [Time Formats (d3-time-format)](https://github.com/d3/d3-time-format/blob/master/README.md)\n\nPursuant to the great namespace flattening, the format constructors have new names:\n\n* d3.time.format ↦ [d3.timeFormat](https://github.com/d3/d3-time-format/blob/master/README.md#timeFormat)\n* d3.time.format.utc ↦ [d3.utcFormat](https://github.com/d3/d3-time-format/blob/master/README.md#utcFormat)\n* d3.time.format.iso ↦ [d3.isoFormat](https://github.com/d3/d3-time-format/blob/master/README.md#isoFormat)\n\nThe *format*.parse method has also been removed in favor of separate [d3.timeParse](https://github.com/d3/d3-time-format/blob/master/README.md#timeParse), [d3.utcParse](https://github.com/d3/d3-time-format/blob/master/README.md#utcParse) and [d3.isoParse](https://github.com/d3/d3-time-format/blob/master/README.md#isoParse) parser constructors. Thus, this code in 3.x:\n\n```js\nvar parseTime = d3.time.format(\"%c\").parse;\n```\n\nCan be rewritten in 4.0 as:\n\n```js\nvar parseTime = d3.timeParse(\"%c\");\n```\n\nThe multi-scale time format d3.time.format.multi has been replaced by [d3.scaleTime](https://github.com/d3/d3-scale/blob/master/README.md#scaleTime)’s [tick format](https://github.com/d3/d3-scale/blob/master/README.md#time_tickFormat). Time formats now coerce inputs to dates, and time parsers coerce inputs to strings. The `%Z` directive now allows more flexible parsing of time zone offsets, such as `-0700`, `-07:00`, `-07`, and `Z`. The `%p` directive is now parsed correctly when the locale’s period name is longer than two characters (*e.g.*, “a.m.”).\n\nThe default U.S. English locale now uses 12-hour time and a more concise representation of the date. This aligns with local convention and is consistent with [*date*.toLocaleString](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleString) in Chrome, Firefox and Node:\n\n```js\nvar now = new Date;\nd3.timeFormat(\"%c\")(new Date); // \"6/23/2016, 2:01:33 PM\"\nd3.timeFormat(\"%x\")(new Date); // \"6/23/2016\"\nd3.timeFormat(\"%X\")(new Date); // \"2:01:38 PM\"\n```\n\nYou can now set the default locale using [d3.timeFormatDefaultLocale](https://github.com/d3/d3-time-format/blob/master/README.md#timeFormatDefaultLocale)! The locales are published as [JSON](https://github.com/d3/d3-request/blob/master/README.md#json) to [npm](https://unpkg.com/d3-time-format/locale/).\n\nThe performance of time formatting and parsing has been improved, and the UTC formatter and parser have a cleaner implementation (that avoids temporarily overriding the Date global).\n\n## [Time Intervals (d3-time)](https://github.com/d3/d3-time/blob/master/README.md)\n\nPursuant to the great namespace flattening, the local time intervals have been renamed:\n\n* ADDED ↦ [d3.timeMillisecond](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond)\n* d3.time.second ↦ [d3.timeSecond](https://github.com/d3/d3-time/blob/master/README.md#timeSecond)\n* d3.time.minute ↦ [d3.timeMinute](https://github.com/d3/d3-time/blob/master/README.md#timeMinute)\n* d3.time.hour ↦ [d3.timeHour](https://github.com/d3/d3-time/blob/master/README.md#timeHour)\n* d3.time.day ↦ [d3.timeDay](https://github.com/d3/d3-time/blob/master/README.md#timeDay)\n* d3.time.sunday ↦ [d3.timeSunday](https://github.com/d3/d3-time/blob/master/README.md#timeSunday)\n* d3.time.monday ↦ [d3.timeMonday](https://github.com/d3/d3-time/blob/master/README.md#timeMonday)\n* d3.time.tuesday ↦ [d3.timeTuesday](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday)\n* d3.time.wednesday ↦ [d3.timeWednesday](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday)\n* d3.time.thursday ↦ [d3.timeThursday](https://github.com/d3/d3-time/blob/master/README.md#timeThursday)\n* d3.time.friday ↦ [d3.timeFriday](https://github.com/d3/d3-time/blob/master/README.md#timeFriday)\n* d3.time.saturday ↦ [d3.timeSaturday](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday)\n* d3.time.week ↦ [d3.timeWeek](https://github.com/d3/d3-time/blob/master/README.md#timeWeek)\n* d3.time.month ↦ [d3.timeMonth](https://github.com/d3/d3-time/blob/master/README.md#timeMonth)\n* d3.time.year ↦ [d3.timeYear](https://github.com/d3/d3-time/blob/master/README.md#timeYear)\n\nThe UTC time intervals have likewise been renamed:\n\n* ADDED ↦ [d3.utcMillisecond](https://github.com/d3/d3-time/blob/master/README.md#utcMillisecond)\n* d3.time.second.utc ↦ [d3.utcSecond](https://github.com/d3/d3-time/blob/master/README.md#utcSecond)\n* d3.time.minute.utc ↦ [d3.utcMinute](https://github.com/d3/d3-time/blob/master/README.md#utcMinute)\n* d3.time.hour.utc ↦ [d3.utcHour](https://github.com/d3/d3-time/blob/master/README.md#utcHour)\n* d3.time.day.utc ↦ [d3.utcDay](https://github.com/d3/d3-time/blob/master/README.md#utcDay)\n* d3.time.sunday.utc ↦ [d3.utcSunday](https://github.com/d3/d3-time/blob/master/README.md#utcSunday)\n* d3.time.monday.utc ↦ [d3.utcMonday](https://github.com/d3/d3-time/blob/master/README.md#utcMonday)\n* d3.time.tuesday.utc ↦ [d3.utcTuesday](https://github.com/d3/d3-time/blob/master/README.md#utcTuesday)\n* d3.time.wednesday.utc ↦ [d3.utcWednesday](https://github.com/d3/d3-time/blob/master/README.md#utcWednesday)\n* d3.time.thursday.utc ↦ [d3.utcThursday](https://github.com/d3/d3-time/blob/master/README.md#utcThursday)\n* d3.time.friday.utc ↦ [d3.utcFriday](https://github.com/d3/d3-time/blob/master/README.md#utcFriday)\n* d3.time.saturday.utc ↦ [d3.utcSaturday](https://github.com/d3/d3-time/blob/master/README.md#utcSaturday)\n* d3.time.week.utc ↦ [d3.utcWeek](https://github.com/d3/d3-time/blob/master/README.md#utcWeek)\n* d3.time.month.utc ↦ [d3.utcMonth](https://github.com/d3/d3-time/blob/master/README.md#utcMonth)\n* d3.time.year.utc ↦ [d3.utcYear](https://github.com/d3/d3-time/blob/master/README.md#utcYear)\n\nThe local time range aliases have been renamed:\n\n* d3.time.seconds ↦ [d3.timeSeconds](https://github.com/d3/d3-time/blob/master/README.md#timeSeconds)\n* d3.time.minutes ↦ [d3.timeMinutes](https://github.com/d3/d3-time/blob/master/README.md#timeMinutes)\n* d3.time.hours ↦ [d3.timeHours](https://github.com/d3/d3-time/blob/master/README.md#timeHours)\n* d3.time.days ↦ [d3.timeDays](https://github.com/d3/d3-time/blob/master/README.md#timeDays)\n* d3.time.sundays ↦ [d3.timeSundays](https://github.com/d3/d3-time/blob/master/README.md#timeSundays)\n* d3.time.mondays ↦ [d3.timeMondays](https://github.com/d3/d3-time/blob/master/README.md#timeMondays)\n* d3.time.tuesdays ↦ [d3.timeTuesdays](https://github.com/d3/d3-time/blob/master/README.md#timeTuesdays)\n* d3.time.wednesdays ↦ [d3.timeWednesdays](https://github.com/d3/d3-time/blob/master/README.md#timeWednesdays)\n* d3.time.thursdays ↦ [d3.timeThursdays](https://github.com/d3/d3-time/blob/master/README.md#timeThursdays)\n* d3.time.fridays ↦ [d3.timeFridays](https://github.com/d3/d3-time/blob/master/README.md#timeFridays)\n* d3.time.saturdays ↦ [d3.timeSaturdays](https://github.com/d3/d3-time/blob/master/README.md#timeSaturdays)\n* d3.time.weeks ↦ [d3.timeWeeks](https://github.com/d3/d3-time/blob/master/README.md#timeWeeks)\n* d3.time.months ↦ [d3.timeMonths](https://github.com/d3/d3-time/blob/master/README.md#timeMonths)\n* d3.time.years ↦ [d3.timeYears](https://github.com/d3/d3-time/blob/master/README.md#timeYears)\n\nThe UTC time range aliases have been renamed:\n\n* d3.time.seconds.utc ↦ [d3.utcSeconds](https://github.com/d3/d3-time/blob/master/README.md#utcSeconds)\n* d3.time.minutes.utc ↦ [d3.utcMinutes](https://github.com/d3/d3-time/blob/master/README.md#utcMinutes)\n* d3.time.hours.utc ↦ [d3.utcHours](https://github.com/d3/d3-time/blob/master/README.md#utcHours)\n* d3.time.days.utc ↦ [d3.utcDays](https://github.com/d3/d3-time/blob/master/README.md#utcDays)\n* d3.time.sundays.utc ↦ [d3.utcSundays](https://github.com/d3/d3-time/blob/master/README.md#utcSundays)\n* d3.time.mondays.utc ↦ [d3.utcMondays](https://github.com/d3/d3-time/blob/master/README.md#utcMondays)\n* d3.time.tuesdays.utc ↦ [d3.utcTuesdays](https://github.com/d3/d3-time/blob/master/README.md#utcTuesdays)\n* d3.time.wednesdays.utc ↦ [d3.utcWednesdays](https://github.com/d3/d3-time/blob/master/README.md#utcWednesdays)\n* d3.time.thursdays.utc ↦ [d3.utcThursdays](https://github.com/d3/d3-time/blob/master/README.md#utcThursdays)\n* d3.time.fridays.utc ↦ [d3.utcFridays](https://github.com/d3/d3-time/blob/master/README.md#utcFridays)\n* d3.time.saturdays.utc ↦ [d3.utcSaturdays](https://github.com/d3/d3-time/blob/master/README.md#utcSaturdays)\n* d3.time.weeks.utc ↦ [d3.utcWeeks](https://github.com/d3/d3-time/blob/master/README.md#utcWeeks)\n* d3.time.months.utc ↦ [d3.utcMonths](https://github.com/d3/d3-time/blob/master/README.md#utcMonths)\n* d3.time.years.utc ↦ [d3.utcYears](https://github.com/d3/d3-time/blob/master/README.md#utcYears)\n\nThe behavior of [*interval*.range](https://github.com/d3/d3-time/blob/master/README.md#interval_range) (and the convenience aliases such as [d3.timeDays](https://github.com/d3/d3-time/blob/master/README.md#timeDays)) has been changed when *step* is greater than one. Rather than filtering the returned dates using the field number, *interval*.range now behaves like [d3.range](https://github.com/d3/d3-array/blob/master/README.md#range): it simply skips, returning every *step*th date. For example, the following code in 3.x returns only odd days of the month:\n\n```js\nd3.time.days(new Date(2016, 4, 28), new Date(2016, 5, 5), 2);\n// [Sun May 29 2016 00:00:00 GMT-0700 (PDT),\n//  Tue May 31 2016 00:00:00 GMT-0700 (PDT),\n//  Wed Jun 01 2016 00:00:00 GMT-0700 (PDT),\n//  Fri Jun 03 2016 00:00:00 GMT-0700 (PDT)]\n```\n\nNote the returned array of dates does not start on the *start* date because May 28 is even. Also note that May 31 and June 1 are one day apart, not two! The behavior of d3.timeDays in 4.0 is probably closer to what you expect:\n\n```js\nd3.timeDays(new Date(2016, 4, 28), new Date(2016, 5, 5), 2);\n// [Sat May 28 2016 00:00:00 GMT-0700 (PDT),\n//  Mon May 30 2016 00:00:00 GMT-0700 (PDT),\n//  Wed Jun 01 2016 00:00:00 GMT-0700 (PDT),\n//  Fri Jun 03 2016 00:00:00 GMT-0700 (PDT)]\n```\n\nIf you want a filtered view of a time interval (say to guarantee that two overlapping ranges are consistent, such as when generating [time scale ticks](https://github.com/d3/d3-scale/blob/master/README.md#time_ticks)), you can use the new [*interval*.every](https://github.com/d3/d3-time/blob/master/README.md#interval_every) method or its more general cousin [*interval*.filter](https://github.com/d3/d3-time/blob/master/README.md#interval_filter):\n\n```js\nd3.timeDay.every(2).range(new Date(2016, 4, 28), new Date(2016, 5, 5));\n// [Sun May 29 2016 00:00:00 GMT-0700 (PDT),\n//  Tue May 31 2016 00:00:00 GMT-0700 (PDT),\n//  Wed Jun 01 2016 00:00:00 GMT-0700 (PDT),\n//  Fri Jun 03 2016 00:00:00 GMT-0700 (PDT)]\n```\n\nTime intervals now expose an [*interval*.count](https://github.com/d3/d3-time/blob/master/README.md#interval_count) method for counting the number of interval boundaries after a *start* date and before or equal to an *end* date. This replaces d3.time.dayOfYear and related methods in 3.x. For example, this code in 3.x:\n\n```js\nvar now = new Date;\nd3.time.dayOfYear(now); // 165\n```\n\nCan be rewritten in 4.0 as:\n\n```js\nvar now = new Date;\nd3.timeDay.count(d3.timeYear(now), now); // 165\n```\n\nLikewise, in place of 3.x’s d3.time.weekOfYear, in 4.0 you would say:\n\n```js\nd3.timeWeek.count(d3.timeYear(now), now); // 24\n```\n\nThe new *interval*.count is of course more general. For example, you can use it to compute hour-of-week for a heatmap:\n\n```js\nd3.timeHour.count(d3.timeWeek(now), now); // 64\n```\n\nHere are all the equivalences from 3.x to 4.0:\n\n* d3.time.dayOfYear ↦ [d3.timeDay](https://github.com/d3/d3-time/blob/master/README.md#timeDay).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.sundayOfYear ↦ [d3.timeSunday](https://github.com/d3/d3-time/blob/master/README.md#timeSunday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.mondayOfYear ↦ [d3.timeMonday](https://github.com/d3/d3-time/blob/master/README.md#timeMonday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.tuesdayOfYear ↦ [d3.timeTuesday](https://github.com/d3/d3-time/blob/master/README.md#timeTuesday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.wednesdayOfYear ↦ [d3.timeWednesday](https://github.com/d3/d3-time/blob/master/README.md#timeWednesday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.thursdayOfYear ↦ [d3.timeThursday](https://github.com/d3/d3-time/blob/master/README.md#timeThursday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.fridayOfYear ↦ [d3.timeFriday](https://github.com/d3/d3-time/blob/master/README.md#timeFriday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.saturdayOfYear ↦ [d3.timeSaturday](https://github.com/d3/d3-time/blob/master/README.md#timeSaturday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.weekOfYear ↦ [d3.timeWeek](https://github.com/d3/d3-time/blob/master/README.md#timeWeek).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.dayOfYear.utc ↦ [d3.utcDay](https://github.com/d3/d3-time/blob/master/README.md#utcDay).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.sundayOfYear.utc ↦ [d3.utcSunday](https://github.com/d3/d3-time/blob/master/README.md#utcSunday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.mondayOfYear.utc ↦ [d3.utcMonday](https://github.com/d3/d3-time/blob/master/README.md#utcMonday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.tuesdayOfYear.utc ↦ [d3.utcTuesday](https://github.com/d3/d3-time/blob/master/README.md#utcTuesday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.wednesdayOfYear.utc ↦ [d3.utcWednesday](https://github.com/d3/d3-time/blob/master/README.md#utcWednesday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.thursdayOfYear.utc ↦ [d3.utcThursday](https://github.com/d3/d3-time/blob/master/README.md#utcThursday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.fridayOfYear.utc ↦ [d3.utcFriday](https://github.com/d3/d3-time/blob/master/README.md#utcFriday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.saturdayOfYear.utc ↦ [d3.utcSaturday](https://github.com/d3/d3-time/blob/master/README.md#utcSaturday).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n* d3.time.weekOfYear.utc ↦ [d3.utcWeek](https://github.com/d3/d3-time/blob/master/README.md#utcWeek).[count](https://github.com/d3/d3-time/blob/master/README.md#interval_count)\n\nD3 4.0 now also lets you define custom time intervals using [d3.timeInterval](https://github.com/d3/d3-time/blob/master/README.md#timeInterval). The [d3.timeYear](https://github.com/d3/d3-time/blob/master/README.md#timeYear), [d3.utcYear](https://github.com/d3/d3-time/blob/master/README.md#utcYear), [d3.timeMillisecond](https://github.com/d3/d3-time/blob/master/README.md#timeMillisecond) and [d3.utcMillisecond](https://github.com/d3/d3-time/blob/master/README.md#utcMillisecond) intervals have optimized implementations of [*interval*.every](https://github.com/d3/d3-time/blob/master/README.md#interval_every), which is necessary to generate time ticks for very large or very small domains efficiently. More generally, the performance of time intervals has been improved, and time intervals now do a better job with respect to daylight savings in various locales.\n\n## [Timers (d3-timer)](https://github.com/d3/d3-timer/blob/master/README.md)\n\nIn D3 3.x, the only way to stop a timer was for its callback to return true. For example, this timer stops after one second:\n\n```js\nd3.timer(function(elapsed) {\n  console.log(elapsed);\n  return elapsed >= 1000;\n});\n```\n\nIn 4.0, use [*timer*.stop](https://github.com/d3/d3-timer/blob/master/README.md#timer_stop) instead:\n\n```js\nvar t = d3.timer(function(elapsed) {\n  console.log(elapsed);\n  if (elapsed >= 1000) {\n    t.stop();\n  }\n});\n```\n\nThe primary benefit of *timer*.stop is that timers are not required to self-terminate: they can be stopped externally, allowing for the immediate and synchronous disposal of associated resources, and the separation of concerns. The above is equivalent to:\n\n```js\nvar t = d3.timer(function(elapsed) {\n  console.log(elapsed);\n});\n\nd3.timeout(function() {\n  t.stop();\n}, 1000);\n```\n\nThis improvement extends to [d3-transition](#transitions-d3-transition): now when a transition is interrupted, its resources are immediately freed rather than having to wait for transition to start.\n\n4.0 also introduces a new [*timer*.restart](https://github.com/d3/d3-timer/blob/master/README.md#timer_restart) method for restarting timers, for replacing the callback of a running timer, or for changing its delay or reference time. Unlike *timer*.stop followed by [d3.timer](https://github.com/d3/d3-timer/blob/master/README.md#timer), *timer*.restart maintains the invocation priority of an existing timer: it guarantees that the order of invocation of active timers remains the same. The d3.timer.flush method has been renamed to [d3.timerFlush](https://github.com/d3/d3-timer/blob/master/README.md#timerFlush).\n\nSome usage patterns in D3 3.x could cause the browser to hang when a background page returned to the foreground. For example, the following code schedules a transition every second:\n\n```js\nsetInterval(function() {\n  d3.selectAll(\"div\").transition().call(someAnimation); // BAD\n}, 1000);\n```\n\nIf such code runs in the background for hours, thousands of queued transitions will try to run simultaneously when the page is foregrounded. D3 4.0 avoids this hang by freezing time in the background: when a page is in the background, time does not advance, and so no queue of timers accumulates to run when the page returns to the foreground. Use d3.timer instead of transitions to schedule a long-running animation, or use [d3.timeout](https://github.com/d3/d3-timer/blob/master/README.md#timeout) and [d3.interval](https://github.com/d3/d3-timer/blob/master/README.md#interval) in place of setTimeout and setInterval to prevent transitions from being queued in the background:\n\n```js\nd3.interval(function() {\n  d3.selectAll(\"div\").transition().call(someAnimation); // GOOD\n}, 1000);\n```\n\nBy freezing time in the background, timers are effectively “unaware” of being backgrounded. It’s like nothing happened! 4.0 also now uses high-precision time ([performance.now](https://developer.mozilla.org/en-US/docs/Web/API/Performance/now)) where available; the current time is available as [d3.now](https://github.com/d3/d3-timer/blob/master/README.md#now).\n\n## [Transitions (d3-transition)](https://github.com/d3/d3-transition/blob/master/README.md)\n\nThe [*selection*.transition](https://github.com/d3/d3-transition/blob/master/README.md#selection_transition) method now takes an optional *transition* instance which can be used to synchronize a new transition with an existing transition. (This change is discussed further in [What Makes Software Good?](https://medium.com/@mbostock/what-makes-software-good-943557f8a488)) For example:\n\n```js\nvar t = d3.transition()\n    .duration(750)\n    .ease(d3.easeLinear);\n\nd3.selectAll(\".apple\").transition(t)\n    .style(\"fill\", \"red\");\n\nd3.selectAll(\".orange\").transition(t)\n    .style(\"fill\", \"orange\");\n```\n\nTransitions created this way inherit timing from the closest ancestor element, and thus are synchronized even when the referenced *transition* has variable timing such as a staggered delay. This method replaces the deeply magical behavior of *transition*.each in 3.x; in 4.0, [*transition*.each](https://github.com/d3/d3-transition/blob/master/README.md#transition_each) is identical to [*selection*.each](https://github.com/d3/d3-selection/blob/master/README.md#selection_each). Use the new [*transition*.on](https://github.com/d3/d3-transition/blob/master/README.md#transition_on) method to listen to transition events.\n\nThe meaning of [*transition*.delay](https://github.com/d3/d3-transition/blob/master/README.md#transition_delay) has changed for chained transitions created by [*transition*.transition](https://github.com/d3/d3-transition/blob/master/README.md#transition_transition). The specified delay is now relative to the *previous* transition in the chain, rather than the *first* transition in the chain; this makes it easier to insert interstitial pauses. For example:\n\n```js\nd3.selectAll(\".apple\")\n  .transition() // First fade to green.\n    .style(\"fill\", \"green\")\n  .transition() // Then red.\n    .style(\"fill\", \"red\")\n  .transition() // Wait one second. Then brown, and remove.\n    .delay(1000)\n    .style(\"fill\", \"brown\")\n    .remove();\n```\n\nTime is now frozen in the background; see [d3-timer](#timers-d3-timer) for more information. While it was previously the case that transitions did not run in the background, now they pick up where they left off when the page returns to the foreground. This avoids page hangs by not scheduling an unbounded number of transitions in the background. If you want to schedule an infinitely-repeating transition, use transition events, or use [d3.timeout](https://github.com/d3/d3-timer/blob/master/README.md#timeout) and [d3.interval](https://github.com/d3/d3-timer/blob/master/README.md#interval) in place of [setTimeout](https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setTimeout) and [setInterval](https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setInterval).\n\nThe [*selection*.interrupt](https://github.com/d3/d3-transition/blob/master/README.md#selection_interrupt) method now cancels all scheduled transitions on the selected elements, in addition to interrupting any active transition. When transitions are interrupted, any resources associated with the transition are now released immediately, rather than waiting until the transition starts, improving performance. (See also [*timer*.stop](https://github.com/d3/d3-timer/blob/master/README.md#timer_stop).) The new [d3.interrupt](https://github.com/d3/d3-transition/blob/master/README.md#interrupt) method is an alternative to [*selection*.interrupt](https://github.com/d3/d3-transition/blob/master/README.md#selection_interrupt) for quickly interrupting a single node.\n\nThe new [d3.active](https://github.com/d3/d3-transition/blob/master/README.md#active) method allows you to select the currently-active transition on a given *node*, if any. This is useful for modifying in-progress transitions and for scheduling infinitely-repeating transitions. For example, this transition continuously oscillates between red and blue:\n\n```js\nd3.select(\"circle\")\n  .transition()\n    .on(\"start\", function repeat() {\n        d3.active(this)\n            .style(\"fill\", \"red\")\n          .transition()\n            .style(\"fill\", \"blue\")\n          .transition()\n            .on(\"start\", repeat);\n      });\n```\n\nThe [life cycle of a transition](https://github.com/d3/d3-transition/blob/master/README.md#the-life-of-a-transition) is now more formally defined and enforced. For example, attempting to change the duration of a running transition now throws an error rather than silently failing. The [*transition*.remove](https://github.com/d3/d3-transition/blob/master/README.md#transition_remove) method has been fixed if multiple transition names are in use: the element is only removed if it has no scheduled transitions, regardless of name. The [*transition*.ease](https://github.com/d3/d3-transition/blob/master/README.md#transition_ease) method now always takes an [easing function](#easings-d3-ease), not a string. When a transition ends, the tweens are invoked one last time with *t* equal to exactly 1, regardless of the associated easing function.\n\nAs with [selections](#selections-d3-selection) in 4.0, all transition callback functions now receive the standard arguments: the element’s datum (*d*), the element’s index (*i*), and the element’s group (*nodes*), with *this* as the element. This notably affects [*transition*.attrTween](https://github.com/d3/d3-transition/blob/master/README.md#transition_attrTween) and [*transition*.styleTween](https://github.com/d3/d3-transition/blob/master/README.md#transition_styleTween), which no longer pass the *tween* function the current attribute or style value as the third argument. The *transition*.attrTween and *transition*.styleTween methods can now be called in getter modes for debugging or to share tween definitions between transitions.\n\nHomogenous transitions are now optimized! If all elements in a transition share the same tween, interpolator, or event listeners, this state is now shared across the transition rather than separately allocated for each element. 4.0 also uses an optimized default interpolator in place of [d3.interpolate](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolate) for [*transition*.attr](https://github.com/d3/d3-transition/blob/master/README.md#transition_attr) and [*transition*.style](https://github.com/d3/d3-transition/blob/master/README.md#transition_style). And transitions can now interpolate both [CSS](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformCss) and [SVG](https://github.com/d3/d3-interpolate/blob/master/README.md#interpolateTransformSvg) transforms.\n\nFor reusable components that support transitions, such as [axes](#axes-d3-axis), a new [*transition*.selection](https://github.com/d3/d3-transition/blob/master/README.md#transition_selection) method returns the [selection](#selections-d3-selection) that corresponds to a given transition. There is also a new [*transition*.merge](https://github.com/d3/d3-transition/blob/master/README.md#transition_merge) method that is equivalent to [*selection*.merge](https://github.com/d3/d3-selection/blob/master/README.md#selection_merge).\n\nFor the sake of parsimony, the multi-value map methods have been extracted to [d3-selection-multi](https://github.com/d3/d3-selection-multi) and are no longer part of the default bundle. The multi-value map methods have also been renamed to plural form to reduce overload: [*transition*.attrs](https://github.com/d3/d3-selection-multi/blob/master/README.md#transition_attrs) and [*transition*.styles](https://github.com/d3/d3-selection-multi/blob/master/README.md#transition_styles).\n\n## [Voronoi Diagrams (d3-voronoi)](https://github.com/d3/d3-voronoi/blob/master/README.md)\n\nThe d3.geom.voronoi method has been renamed to [d3.voronoi](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi), and the *voronoi*.clipExtent method has been renamed to [*voronoi*.extent](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_extent). The undocumented *polygon*.point property in 3.x, which is the element in the input *data* corresponding to the polygon, has been renamed to *polygon*.data.\n\nCalling [*voronoi*](https://github.com/d3/d3-voronoi/blob/master/README.md#_voronoi) now returns the full [Voronoi diagram](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi-diagrams), which includes topological information: each Voronoi edge exposes *edge*.left and *edge*.right specifying the sites on either side of the edge, and each Voronoi cell is defined as an array of these edges and a corresponding site. The Voronoi diagram can be used to efficiently compute both the Voronoi and Delaunay tessellations for a set of points: [*diagram*.polygons](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_polygons), [*diagram*.links](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_links), and [*diagram*.triangles](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_triangles). The new topology is also useful in conjunction with TopoJSON; see the [Voronoi topology example](https://bl.ocks.org/mbostock/cd52a201d7694eb9d890).\n\nThe [*voronoi*.polygons](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_polygons) and [*diagram*.polygons](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_polygons) now require an [extent](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_extent); there is no longer an implicit extent of ±1e6. The [*voronoi*.links](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_links), [*voronoi*.triangles](https://github.com/d3/d3-voronoi/blob/master/README.md#voronoi_triangles), [*diagram*.links](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_links) and [*diagram*.triangles](https://github.com/d3/d3-voronoi/blob/master/README.md#diagram_triangles) are now affected by the clip extent: as the Delaunay is computed as the dual of the Voronoi, two sites are only linked if the clipped cells are touching. To compute the Delaunay triangulation without respect to clipping, set the extent to null.\n\nThe Voronoi generator finally has well-defined behavior for coincident vertices: the first of a set of coincident points has a defined cell, while the subsequent duplicate points have null cells. The returned array of polygons is sparse, so by using *array*.forEach or *array*.map, you can easily skip undefined cells. The Voronoi generator also now correctly handles the case where no cell edges intersect the extent.\n\n## [Zooming (d3-zoom)](https://github.com/d3/d3-zoom/blob/master/README.md)\n\nThe zoom behavior d3.behavior.zoom has been renamed to d3.zoom. Zoom behaviors no longer store the active zoom transform (*i.e.*, the visible region; the scale and translate) internally. The zoom transform is now stored on any elements to which the zoom behavior has been applied. The zoom transform is available as *event*.transform within a zoom event or by calling [d3.zoomTransform](https://github.com/d3/d3-zoom/blob/master/README.md#zoomTransform) on a given *element*. To zoom programmatically, use [*zoom*.transform](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_transform) with a given [selection](#selections-d3-selection) or [transition](#transitions-d3-transition); see the [zoom transitions example](https://bl.ocks.org/mbostock/b783fbb2e673561d214e09c7fb5cedee). The *zoom*.event method has been removed.\n\nTo make programmatic zooming easier, there are several new convenience methods on top of *zoom*.transform: [*zoom*.translateBy](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_translateBy), [*zoom*.scaleBy](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_scaleBy) and [*zoom*.scaleTo](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_scaleTo). There is also a new API for describing [zoom transforms](https://github.com/d3/d3-zoom/blob/master/README.md#zoom-transforms). Zoom behaviors are no longer dependent on [scales](#scales-d3-scale), but you can use [*transform*.rescaleX](https://github.com/d3/d3-zoom/blob/master/README.md#transform_rescaleX), [*transform*.rescaleY](https://github.com/d3/d3-zoom/blob/master/README.md#transform_rescaleY), [*transform*.invertX](https://github.com/d3/d3-zoom/blob/master/README.md#transform_invertX) or [*transform*.invertY](https://github.com/d3/d3-zoom/blob/master/README.md#transform_invertY) to transform a scale’s domain. 3.x’s *event*.scale is replaced with *event*.transform.k, and *event*.translate is replaced with *event*.transform.x and *event*.transform.y. The *zoom*.center method has been removed in favor of programmatic zooming.\n\nThe zoom behavior finally supports simple constraints on panning! The new [*zoom*.translateExtent](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_translateExtent) lets you define the viewable extent of the world: the currently-visible extent (the extent of the viewport, as defined by [*zoom*.extent](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_extent)) is always contained within the translate extent. The *zoom*.size method has been replaced by *zoom*.extent, and the default behavior is now smarter: it defaults to the extent of the zoom behavior’s owner element, rather than being hardcoded to 960×500. (This also improves the default path chosen during smooth zoom transitions!)\n\nThe zoom behavior’s interaction has also improved. It now correctly handles concurrent wheeling and dragging, as well as concurrent touching and mousing. The zoom behavior now ignores wheel events at the limits of its scale extent, allowing you to scroll past a zoomable area. The *zoomstart* and *zoomend* events have been renamed *start* and *end*. By default, zoom behaviors now ignore right-clicks intended for the context menu; use [*zoom*.filter](https://github.com/d3/d3-zoom/blob/master/README.md#zoom_filter) to control which events are ignored. The zoom behavior also ignores emulated mouse events on iOS. The zoom behavior now consumes handled events, making it easier to combine with other interactive behaviors such as [dragging](#dragging-d3-drag).\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/LICENSE",
    "content": "Copyright 2010-2017 Mike Bostock\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n  list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n  this list of conditions and the following disclaimer in the documentation\n  and/or other materials provided with the distribution.\n\n* Neither the name of the author nor the names of contributors may be used to\n  endorse or promote products derived from this software without specific prior\n  written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/README.md",
    "content": "# D3: Data-Driven Documents\n\n<a href=\"https://d3js.org\"><img src=\"https://d3js.org/logo.svg\" align=\"left\" hspace=\"10\" vspace=\"6\"></a>\n\n**D3** (or **D3.js**) is a JavaScript library for visualizing data using web standards. D3 helps you bring data to life using SVG, Canvas and HTML. D3 combines powerful visualization and interaction techniques with a data-driven approach to DOM manipulation, giving you the full capabilities of modern browsers and the freedom to design the right visual interface for your data.\n\n## Resources\n\n* [API Reference](https://github.com/d3/d3/blob/master/API.md)\n* [Release Notes](https://github.com/d3/d3/releases)\n* [Gallery](https://github.com/d3/d3/wiki/Gallery)\n* [Examples](https://bl.ocks.org/mbostock)\n* [Wiki](https://github.com/d3/d3/wiki)\n\n## Installing\n\nIf you use npm, `npm install d3`. Otherwise, download the [latest release](https://github.com/d3/d3/releases/latest). The released bundle supports anonymous AMD, CommonJS, and vanilla environments. You can load directly from [d3js.org](https://d3js.org), [CDNJS](https://cdnjs.com/libraries/d3), or [unpkg](https://unpkg.com/d3/). For example:\n\n```html\n<script src=\"https://d3js.org/d3.v4.js\"></script>\n```\n\nFor the minified version:\n\n```html\n<script src=\"https://d3js.org/d3.v4.min.js\"></script>\n```\n\nYou can also use the standalone D3 microlibraries. For example, [d3-selection](https://github.com/d3/d3-selection):\n\n```html\n<script src=\"https://d3js.org/d3-selection.v1.js\"></script>\n```\n\nD3 is written using [ES2015 modules](http://www.2ality.com/2014/09/es6-modules-final.html). Create a [custom bundle using Rollup](https://bl.ocks.org/mbostock/bb09af4c39c79cffcde4), Webpack, or your preferred bundler. To import D3 into an ES2015 application, either import specific symbols from specific D3 modules:\n\n```js\nimport {scaleLinear} from \"d3-scale\";\n```\n\nOr import everything into a namespace (here, `d3`):\n\n```js\nimport * as d3 from \"d3\";\n```\n\nIn Node:\n\n```js\nvar d3 = require(\"d3\");\n```\n\nYou can also require individual modules and combine them into a `d3` object using [Object.assign](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign):\n\n```js\nvar d3 = Object.assign({}, require(\"d3-format\"), require(\"d3-geo\"), require(\"d3-geo-projection\"));\n```\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/d3.js",
    "content": "// https://d3js.org Version 4.9.1. Copyright 2017 Mike Bostock.\n(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n\ttypeof define === 'function' && define.amd ? define(['exports'], factory) :\n\t(factory((global.d3 = global.d3 || {})));\n}(this, (function (exports) { 'use strict';\n\nvar version = \"4.9.1\";\n\nvar ascending = function(a, b) {\n  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n};\n\nvar bisector = function(compare) {\n  if (compare.length === 1) compare = ascendingComparator(compare);\n  return {\n    left: function(a, x, lo, hi) {\n      if (lo == null) lo = 0;\n      if (hi == null) hi = a.length;\n      while (lo < hi) {\n        var mid = lo + hi >>> 1;\n        if (compare(a[mid], x) < 0) lo = mid + 1;\n        else hi = mid;\n      }\n      return lo;\n    },\n    right: function(a, x, lo, hi) {\n      if (lo == null) lo = 0;\n      if (hi == null) hi = a.length;\n      while (lo < hi) {\n        var mid = lo + hi >>> 1;\n        if (compare(a[mid], x) > 0) hi = mid;\n        else lo = mid + 1;\n      }\n      return lo;\n    }\n  };\n};\n\nfunction ascendingComparator(f) {\n  return function(d, x) {\n    return ascending(f(d), x);\n  };\n}\n\nvar ascendingBisect = bisector(ascending);\nvar bisectRight = ascendingBisect.right;\nvar bisectLeft = ascendingBisect.left;\n\nvar pairs = function(array, f) {\n  if (f == null) f = pair;\n  var i = 0, n = array.length - 1, p = array[0], pairs = new Array(n < 0 ? 0 : n);\n  while (i < n) pairs[i] = f(p, p = array[++i]);\n  return pairs;\n};\n\nfunction pair(a, b) {\n  return [a, b];\n}\n\nvar cross = function(values0, values1, reduce) {\n  var n0 = values0.length,\n      n1 = values1.length,\n      values = new Array(n0 * n1),\n      i0,\n      i1,\n      i,\n      value0;\n\n  if (reduce == null) reduce = pair;\n\n  for (i0 = i = 0; i0 < n0; ++i0) {\n    for (value0 = values0[i0], i1 = 0; i1 < n1; ++i1, ++i) {\n      values[i] = reduce(value0, values1[i1]);\n    }\n  }\n\n  return values;\n};\n\nvar descending = function(a, b) {\n  return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n};\n\nvar number = function(x) {\n  return x === null ? NaN : +x;\n};\n\nvar variance = function(values, valueof) {\n  var n = values.length,\n      m = 0,\n      i = -1,\n      mean = 0,\n      value,\n      delta,\n      sum = 0;\n\n  if (valueof == null) {\n    while (++i < n) {\n      if (!isNaN(value = number(values[i]))) {\n        delta = value - mean;\n        mean += delta / ++m;\n        sum += delta * (value - mean);\n      }\n    }\n  }\n\n  else {\n    while (++i < n) {\n      if (!isNaN(value = number(valueof(values[i], i, values)))) {\n        delta = value - mean;\n        mean += delta / ++m;\n        sum += delta * (value - mean);\n      }\n    }\n  }\n\n  if (m > 1) return sum / (m - 1);\n};\n\nvar deviation = function(array, f) {\n  var v = variance(array, f);\n  return v ? Math.sqrt(v) : v;\n};\n\nvar extent = function(values, valueof) {\n  var n = values.length,\n      i = -1,\n      value,\n      min,\n      max;\n\n  if (valueof == null) {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = values[i]) != null && value >= value) {\n        min = max = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = values[i]) != null) {\n            if (min > value) min = value;\n            if (max < value) max = value;\n          }\n        }\n      }\n    }\n  }\n\n  else {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = valueof(values[i], i, values)) != null && value >= value) {\n        min = max = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = valueof(values[i], i, values)) != null) {\n            if (min > value) min = value;\n            if (max < value) max = value;\n          }\n        }\n      }\n    }\n  }\n\n  return [min, max];\n};\n\nvar array = Array.prototype;\n\nvar slice = array.slice;\nvar map = array.map;\n\nvar constant = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar identity = function(x) {\n  return x;\n};\n\nvar sequence = function(start, stop, step) {\n  start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n  var i = -1,\n      n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n      range = new Array(n);\n\n  while (++i < n) {\n    range[i] = start + i * step;\n  }\n\n  return range;\n};\n\nvar e10 = Math.sqrt(50);\nvar e5 = Math.sqrt(10);\nvar e2 = Math.sqrt(2);\n\nvar ticks = function(start, stop, count) {\n  var reverse = stop < start,\n      i = -1,\n      n,\n      ticks,\n      step;\n\n  if (reverse) n = start, start = stop, stop = n;\n\n  if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];\n\n  if (step > 0) {\n    start = Math.ceil(start / step);\n    stop = Math.floor(stop / step);\n    ticks = new Array(n = Math.ceil(stop - start + 1));\n    while (++i < n) ticks[i] = (start + i) * step;\n  } else {\n    start = Math.floor(start * step);\n    stop = Math.ceil(stop * step);\n    ticks = new Array(n = Math.ceil(start - stop + 1));\n    while (++i < n) ticks[i] = (start - i) / step;\n  }\n\n  if (reverse) ticks.reverse();\n\n  return ticks;\n};\n\nfunction tickIncrement(start, stop, count) {\n  var step = (stop - start) / Math.max(0, count),\n      power = Math.floor(Math.log(step) / Math.LN10),\n      error = step / Math.pow(10, power);\n  return power >= 0\n      ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)\n      : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);\n}\n\nfunction tickStep(start, stop, count) {\n  var step0 = Math.abs(stop - start) / Math.max(0, count),\n      step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n      error = step0 / step1;\n  if (error >= e10) step1 *= 10;\n  else if (error >= e5) step1 *= 5;\n  else if (error >= e2) step1 *= 2;\n  return stop < start ? -step1 : step1;\n}\n\nvar sturges = function(values) {\n  return Math.ceil(Math.log(values.length) / Math.LN2) + 1;\n};\n\nvar histogram = function() {\n  var value = identity,\n      domain = extent,\n      threshold = sturges;\n\n  function histogram(data) {\n    var i,\n        n = data.length,\n        x,\n        values = new Array(n);\n\n    for (i = 0; i < n; ++i) {\n      values[i] = value(data[i], i, data);\n    }\n\n    var xz = domain(values),\n        x0 = xz[0],\n        x1 = xz[1],\n        tz = threshold(values, x0, x1);\n\n    // Convert number of thresholds into uniform thresholds.\n    if (!Array.isArray(tz)) {\n      tz = tickStep(x0, x1, tz);\n      tz = sequence(Math.ceil(x0 / tz) * tz, Math.floor(x1 / tz) * tz, tz); // exclusive\n    }\n\n    // Remove any thresholds outside the domain.\n    var m = tz.length;\n    while (tz[0] <= x0) tz.shift(), --m;\n    while (tz[m - 1] > x1) tz.pop(), --m;\n\n    var bins = new Array(m + 1),\n        bin;\n\n    // Initialize bins.\n    for (i = 0; i <= m; ++i) {\n      bin = bins[i] = [];\n      bin.x0 = i > 0 ? tz[i - 1] : x0;\n      bin.x1 = i < m ? tz[i] : x1;\n    }\n\n    // Assign data to bins by value, ignoring any outside the domain.\n    for (i = 0; i < n; ++i) {\n      x = values[i];\n      if (x0 <= x && x <= x1) {\n        bins[bisectRight(tz, x, 0, m)].push(data[i]);\n      }\n    }\n\n    return bins;\n  }\n\n  histogram.value = function(_) {\n    return arguments.length ? (value = typeof _ === \"function\" ? _ : constant(_), histogram) : value;\n  };\n\n  histogram.domain = function(_) {\n    return arguments.length ? (domain = typeof _ === \"function\" ? _ : constant([_[0], _[1]]), histogram) : domain;\n  };\n\n  histogram.thresholds = function(_) {\n    return arguments.length ? (threshold = typeof _ === \"function\" ? _ : Array.isArray(_) ? constant(slice.call(_)) : constant(_), histogram) : threshold;\n  };\n\n  return histogram;\n};\n\nvar threshold = function(values, p, valueof) {\n  if (valueof == null) valueof = number;\n  if (!(n = values.length)) return;\n  if ((p = +p) <= 0 || n < 2) return +valueof(values[0], 0, values);\n  if (p >= 1) return +valueof(values[n - 1], n - 1, values);\n  var n,\n      i = (n - 1) * p,\n      i0 = Math.floor(i),\n      value0 = +valueof(values[i0], i0, values),\n      value1 = +valueof(values[i0 + 1], i0 + 1, values);\n  return value0 + (value1 - value0) * (i - i0);\n};\n\nvar freedmanDiaconis = function(values, min, max) {\n  values = map.call(values, number).sort(ascending);\n  return Math.ceil((max - min) / (2 * (threshold(values, 0.75) - threshold(values, 0.25)) * Math.pow(values.length, -1 / 3)));\n};\n\nvar scott = function(values, min, max) {\n  return Math.ceil((max - min) / (3.5 * deviation(values) * Math.pow(values.length, -1 / 3)));\n};\n\nvar max = function(values, valueof) {\n  var n = values.length,\n      i = -1,\n      value,\n      max;\n\n  if (valueof == null) {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = values[i]) != null && value >= value) {\n        max = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = values[i]) != null && value > max) {\n            max = value;\n          }\n        }\n      }\n    }\n  }\n\n  else {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = valueof(values[i], i, values)) != null && value >= value) {\n        max = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = valueof(values[i], i, values)) != null && value > max) {\n            max = value;\n          }\n        }\n      }\n    }\n  }\n\n  return max;\n};\n\nvar mean = function(values, valueof) {\n  var n = values.length,\n      m = n,\n      i = -1,\n      value,\n      sum = 0;\n\n  if (valueof == null) {\n    while (++i < n) {\n      if (!isNaN(value = number(values[i]))) sum += value;\n      else --m;\n    }\n  }\n\n  else {\n    while (++i < n) {\n      if (!isNaN(value = number(valueof(values[i], i, values)))) sum += value;\n      else --m;\n    }\n  }\n\n  if (m) return sum / m;\n};\n\nvar median = function(values, valueof) {\n  var n = values.length,\n      i = -1,\n      value,\n      numbers = [];\n\n  if (valueof == null) {\n    while (++i < n) {\n      if (!isNaN(value = number(values[i]))) {\n        numbers.push(value);\n      }\n    }\n  }\n\n  else {\n    while (++i < n) {\n      if (!isNaN(value = number(valueof(values[i], i, values)))) {\n        numbers.push(value);\n      }\n    }\n  }\n\n  return threshold(numbers.sort(ascending), 0.5);\n};\n\nvar merge = function(arrays) {\n  var n = arrays.length,\n      m,\n      i = -1,\n      j = 0,\n      merged,\n      array;\n\n  while (++i < n) j += arrays[i].length;\n  merged = new Array(j);\n\n  while (--n >= 0) {\n    array = arrays[n];\n    m = array.length;\n    while (--m >= 0) {\n      merged[--j] = array[m];\n    }\n  }\n\n  return merged;\n};\n\nvar min = function(values, valueof) {\n  var n = values.length,\n      i = -1,\n      value,\n      min;\n\n  if (valueof == null) {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = values[i]) != null && value >= value) {\n        min = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = values[i]) != null && min > value) {\n            min = value;\n          }\n        }\n      }\n    }\n  }\n\n  else {\n    while (++i < n) { // Find the first comparable value.\n      if ((value = valueof(values[i], i, values)) != null && value >= value) {\n        min = value;\n        while (++i < n) { // Compare the remaining values.\n          if ((value = valueof(values[i], i, values)) != null && min > value) {\n            min = value;\n          }\n        }\n      }\n    }\n  }\n\n  return min;\n};\n\nvar permute = function(array, indexes) {\n  var i = indexes.length, permutes = new Array(i);\n  while (i--) permutes[i] = array[indexes[i]];\n  return permutes;\n};\n\nvar scan = function(values, compare) {\n  if (!(n = values.length)) return;\n  var n,\n      i = 0,\n      j = 0,\n      xi,\n      xj = values[j];\n\n  if (compare == null) compare = ascending;\n\n  while (++i < n) {\n    if (compare(xi = values[i], xj) < 0 || compare(xj, xj) !== 0) {\n      xj = xi, j = i;\n    }\n  }\n\n  if (compare(xj, xj) === 0) return j;\n};\n\nvar shuffle = function(array, i0, i1) {\n  var m = (i1 == null ? array.length : i1) - (i0 = i0 == null ? 0 : +i0),\n      t,\n      i;\n\n  while (m) {\n    i = Math.random() * m-- | 0;\n    t = array[m + i0];\n    array[m + i0] = array[i + i0];\n    array[i + i0] = t;\n  }\n\n  return array;\n};\n\nvar sum = function(values, valueof) {\n  var n = values.length,\n      i = -1,\n      value,\n      sum = 0;\n\n  if (valueof == null) {\n    while (++i < n) {\n      if (value = +values[i]) sum += value; // Note: zero and null are equivalent.\n    }\n  }\n\n  else {\n    while (++i < n) {\n      if (value = +valueof(values[i], i, values)) sum += value;\n    }\n  }\n\n  return sum;\n};\n\nvar transpose = function(matrix) {\n  if (!(n = matrix.length)) return [];\n  for (var i = -1, m = min(matrix, length), transpose = new Array(m); ++i < m;) {\n    for (var j = -1, n, row = transpose[i] = new Array(n); ++j < n;) {\n      row[j] = matrix[j][i];\n    }\n  }\n  return transpose;\n};\n\nfunction length(d) {\n  return d.length;\n}\n\nvar zip = function() {\n  return transpose(arguments);\n};\n\nvar slice$1 = Array.prototype.slice;\n\nvar identity$1 = function(x) {\n  return x;\n};\n\nvar top = 1;\nvar right = 2;\nvar bottom = 3;\nvar left = 4;\nvar epsilon = 1e-6;\n\nfunction translateX(x) {\n  return \"translate(\" + (x + 0.5) + \",0)\";\n}\n\nfunction translateY(y) {\n  return \"translate(0,\" + (y + 0.5) + \")\";\n}\n\nfunction center(scale) {\n  var offset = Math.max(0, scale.bandwidth() - 1) / 2; // Adjust for 0.5px offset.\n  if (scale.round()) offset = Math.round(offset);\n  return function(d) {\n    return scale(d) + offset;\n  };\n}\n\nfunction entering() {\n  return !this.__axis;\n}\n\nfunction axis(orient, scale) {\n  var tickArguments = [],\n      tickValues = null,\n      tickFormat = null,\n      tickSizeInner = 6,\n      tickSizeOuter = 6,\n      tickPadding = 3,\n      k = orient === top || orient === left ? -1 : 1,\n      x = orient === left || orient === right ? \"x\" : \"y\",\n      transform = orient === top || orient === bottom ? translateX : translateY;\n\n  function axis(context) {\n    var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,\n        format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity$1) : tickFormat,\n        spacing = Math.max(tickSizeInner, 0) + tickPadding,\n        range = scale.range(),\n        range0 = range[0] + 0.5,\n        range1 = range[range.length - 1] + 0.5,\n        position = (scale.bandwidth ? center : identity$1)(scale.copy()),\n        selection = context.selection ? context.selection() : context,\n        path = selection.selectAll(\".domain\").data([null]),\n        tick = selection.selectAll(\".tick\").data(values, scale).order(),\n        tickExit = tick.exit(),\n        tickEnter = tick.enter().append(\"g\").attr(\"class\", \"tick\"),\n        line = tick.select(\"line\"),\n        text = tick.select(\"text\");\n\n    path = path.merge(path.enter().insert(\"path\", \".tick\")\n        .attr(\"class\", \"domain\")\n        .attr(\"stroke\", \"#000\"));\n\n    tick = tick.merge(tickEnter);\n\n    line = line.merge(tickEnter.append(\"line\")\n        .attr(\"stroke\", \"#000\")\n        .attr(x + \"2\", k * tickSizeInner));\n\n    text = text.merge(tickEnter.append(\"text\")\n        .attr(\"fill\", \"#000\")\n        .attr(x, k * spacing)\n        .attr(\"dy\", orient === top ? \"0em\" : orient === bottom ? \"0.71em\" : \"0.32em\"));\n\n    if (context !== selection) {\n      path = path.transition(context);\n      tick = tick.transition(context);\n      line = line.transition(context);\n      text = text.transition(context);\n\n      tickExit = tickExit.transition(context)\n          .attr(\"opacity\", epsilon)\n          .attr(\"transform\", function(d) { return isFinite(d = position(d)) ? transform(d) : this.getAttribute(\"transform\"); });\n\n      tickEnter\n          .attr(\"opacity\", epsilon)\n          .attr(\"transform\", function(d) { var p = this.parentNode.__axis; return transform(p && isFinite(p = p(d)) ? p : position(d)); });\n    }\n\n    tickExit.remove();\n\n    path\n        .attr(\"d\", orient === left || orient == right\n            ? \"M\" + k * tickSizeOuter + \",\" + range0 + \"H0.5V\" + range1 + \"H\" + k * tickSizeOuter\n            : \"M\" + range0 + \",\" + k * tickSizeOuter + \"V0.5H\" + range1 + \"V\" + k * tickSizeOuter);\n\n    tick\n        .attr(\"opacity\", 1)\n        .attr(\"transform\", function(d) { return transform(position(d)); });\n\n    line\n        .attr(x + \"2\", k * tickSizeInner);\n\n    text\n        .attr(x, k * spacing)\n        .text(format);\n\n    selection.filter(entering)\n        .attr(\"fill\", \"none\")\n        .attr(\"font-size\", 10)\n        .attr(\"font-family\", \"sans-serif\")\n        .attr(\"text-anchor\", orient === right ? \"start\" : orient === left ? \"end\" : \"middle\");\n\n    selection\n        .each(function() { this.__axis = position; });\n  }\n\n  axis.scale = function(_) {\n    return arguments.length ? (scale = _, axis) : scale;\n  };\n\n  axis.ticks = function() {\n    return tickArguments = slice$1.call(arguments), axis;\n  };\n\n  axis.tickArguments = function(_) {\n    return arguments.length ? (tickArguments = _ == null ? [] : slice$1.call(_), axis) : tickArguments.slice();\n  };\n\n  axis.tickValues = function(_) {\n    return arguments.length ? (tickValues = _ == null ? null : slice$1.call(_), axis) : tickValues && tickValues.slice();\n  };\n\n  axis.tickFormat = function(_) {\n    return arguments.length ? (tickFormat = _, axis) : tickFormat;\n  };\n\n  axis.tickSize = function(_) {\n    return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;\n  };\n\n  axis.tickSizeInner = function(_) {\n    return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;\n  };\n\n  axis.tickSizeOuter = function(_) {\n    return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;\n  };\n\n  axis.tickPadding = function(_) {\n    return arguments.length ? (tickPadding = +_, axis) : tickPadding;\n  };\n\n  return axis;\n}\n\nfunction axisTop(scale) {\n  return axis(top, scale);\n}\n\nfunction axisRight(scale) {\n  return axis(right, scale);\n}\n\nfunction axisBottom(scale) {\n  return axis(bottom, scale);\n}\n\nfunction axisLeft(scale) {\n  return axis(left, scale);\n}\n\nvar noop = {value: function() {}};\n\nfunction dispatch() {\n  for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n    if (!(t = arguments[i] + \"\") || (t in _)) throw new Error(\"illegal type: \" + t);\n    _[t] = [];\n  }\n  return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n  this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n    return {type: t, name: name};\n  });\n}\n\nDispatch.prototype = dispatch.prototype = {\n  constructor: Dispatch,\n  on: function(typename, callback) {\n    var _ = this._,\n        T = parseTypenames(typename + \"\", _),\n        t,\n        i = -1,\n        n = T.length;\n\n    // If no callback was specified, return the callback of the given type and name.\n    if (arguments.length < 2) {\n      while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n      return;\n    }\n\n    // If a type was specified, set the callback for the given type and name.\n    // Otherwise, if a null callback was specified, remove callbacks of the given name.\n    if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n    while (++i < n) {\n      if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n      else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n    }\n\n    return this;\n  },\n  copy: function() {\n    var copy = {}, _ = this._;\n    for (var t in _) copy[t] = _[t].slice();\n    return new Dispatch(copy);\n  },\n  call: function(type, that) {\n    if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  },\n  apply: function(type, that, args) {\n    if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n    for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n  }\n};\n\nfunction get(type, name) {\n  for (var i = 0, n = type.length, c; i < n; ++i) {\n    if ((c = type[i]).name === name) {\n      return c.value;\n    }\n  }\n}\n\nfunction set(type, name, callback) {\n  for (var i = 0, n = type.length; i < n; ++i) {\n    if (type[i].name === name) {\n      type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n      break;\n    }\n  }\n  if (callback != null) type.push({name: name, value: callback});\n  return type;\n}\n\nvar xhtml = \"http://www.w3.org/1999/xhtml\";\n\nvar namespaces = {\n  svg: \"http://www.w3.org/2000/svg\",\n  xhtml: xhtml,\n  xlink: \"http://www.w3.org/1999/xlink\",\n  xml: \"http://www.w3.org/XML/1998/namespace\",\n  xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\n\nvar namespace = function(name) {\n  var prefix = name += \"\", i = prefix.indexOf(\":\");\n  if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n  return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;\n};\n\nfunction creatorInherit(name) {\n  return function() {\n    var document = this.ownerDocument,\n        uri = this.namespaceURI;\n    return uri === xhtml && document.documentElement.namespaceURI === xhtml\n        ? document.createElement(name)\n        : document.createElementNS(uri, name);\n  };\n}\n\nfunction creatorFixed(fullname) {\n  return function() {\n    return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n  };\n}\n\nvar creator = function(name) {\n  var fullname = namespace(name);\n  return (fullname.local\n      ? creatorFixed\n      : creatorInherit)(fullname);\n};\n\nvar nextId = 0;\n\nfunction local$1() {\n  return new Local;\n}\n\nfunction Local() {\n  this._ = \"@\" + (++nextId).toString(36);\n}\n\nLocal.prototype = local$1.prototype = {\n  constructor: Local,\n  get: function(node) {\n    var id = this._;\n    while (!(id in node)) if (!(node = node.parentNode)) return;\n    return node[id];\n  },\n  set: function(node, value) {\n    return node[this._] = value;\n  },\n  remove: function(node) {\n    return this._ in node && delete node[this._];\n  },\n  toString: function() {\n    return this._;\n  }\n};\n\nvar matcher = function(selector) {\n  return function() {\n    return this.matches(selector);\n  };\n};\n\nif (typeof document !== \"undefined\") {\n  var element = document.documentElement;\n  if (!element.matches) {\n    var vendorMatches = element.webkitMatchesSelector\n        || element.msMatchesSelector\n        || element.mozMatchesSelector\n        || element.oMatchesSelector;\n    matcher = function(selector) {\n      return function() {\n        return vendorMatches.call(this, selector);\n      };\n    };\n  }\n}\n\nvar matcher$1 = matcher;\n\nvar filterEvents = {};\n\nexports.event = null;\n\nif (typeof document !== \"undefined\") {\n  var element$1 = document.documentElement;\n  if (!(\"onmouseenter\" in element$1)) {\n    filterEvents = {mouseenter: \"mouseover\", mouseleave: \"mouseout\"};\n  }\n}\n\nfunction filterContextListener(listener, index, group) {\n  listener = contextListener(listener, index, group);\n  return function(event) {\n    var related = event.relatedTarget;\n    if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {\n      listener.call(this, event);\n    }\n  };\n}\n\nfunction contextListener(listener, index, group) {\n  return function(event1) {\n    var event0 = exports.event; // Events can be reentrant (e.g., focus).\n    exports.event = event1;\n    try {\n      listener.call(this, this.__data__, index, group);\n    } finally {\n      exports.event = event0;\n    }\n  };\n}\n\nfunction parseTypenames$1(typenames) {\n  return typenames.trim().split(/^|\\s+/).map(function(t) {\n    var name = \"\", i = t.indexOf(\".\");\n    if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n    return {type: t, name: name};\n  });\n}\n\nfunction onRemove(typename) {\n  return function() {\n    var on = this.__on;\n    if (!on) return;\n    for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n      if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.capture);\n      } else {\n        on[++i] = o;\n      }\n    }\n    if (++i) on.length = i;\n    else delete this.__on;\n  };\n}\n\nfunction onAdd(typename, value, capture) {\n  var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;\n  return function(d, i, group) {\n    var on = this.__on, o, listener = wrap(value, i, group);\n    if (on) for (var j = 0, m = on.length; j < m; ++j) {\n      if ((o = on[j]).type === typename.type && o.name === typename.name) {\n        this.removeEventListener(o.type, o.listener, o.capture);\n        this.addEventListener(o.type, o.listener = listener, o.capture = capture);\n        o.value = value;\n        return;\n      }\n    }\n    this.addEventListener(typename.type, listener, capture);\n    o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};\n    if (!on) this.__on = [o];\n    else on.push(o);\n  };\n}\n\nvar selection_on = function(typename, value, capture) {\n  var typenames = parseTypenames$1(typename + \"\"), i, n = typenames.length, t;\n\n  if (arguments.length < 2) {\n    var on = this.node().__on;\n    if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n      for (i = 0, o = on[j]; i < n; ++i) {\n        if ((t = typenames[i]).type === o.type && t.name === o.name) {\n          return o.value;\n        }\n      }\n    }\n    return;\n  }\n\n  on = value ? onAdd : onRemove;\n  if (capture == null) capture = false;\n  for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));\n  return this;\n};\n\nfunction customEvent(event1, listener, that, args) {\n  var event0 = exports.event;\n  event1.sourceEvent = exports.event;\n  exports.event = event1;\n  try {\n    return listener.apply(that, args);\n  } finally {\n    exports.event = event0;\n  }\n}\n\nvar sourceEvent = function() {\n  var current = exports.event, source;\n  while (source = current.sourceEvent) current = source;\n  return current;\n};\n\nvar point = function(node, event) {\n  var svg = node.ownerSVGElement || node;\n\n  if (svg.createSVGPoint) {\n    var point = svg.createSVGPoint();\n    point.x = event.clientX, point.y = event.clientY;\n    point = point.matrixTransform(node.getScreenCTM().inverse());\n    return [point.x, point.y];\n  }\n\n  var rect = node.getBoundingClientRect();\n  return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];\n};\n\nvar mouse = function(node) {\n  var event = sourceEvent();\n  if (event.changedTouches) event = event.changedTouches[0];\n  return point(node, event);\n};\n\nfunction none() {}\n\nvar selector = function(selector) {\n  return selector == null ? none : function() {\n    return this.querySelector(selector);\n  };\n};\n\nvar selection_select = function(select) {\n  if (typeof select !== \"function\") select = selector(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n};\n\nfunction empty$1() {\n  return [];\n}\n\nvar selectorAll = function(selector) {\n  return selector == null ? empty$1 : function() {\n    return this.querySelectorAll(selector);\n  };\n};\n\nvar selection_selectAll = function(select) {\n  if (typeof select !== \"function\") select = selectorAll(select);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        subgroups.push(select.call(node, node.__data__, i, group));\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, parents);\n};\n\nvar selection_filter = function(match) {\n  if (typeof match !== \"function\") match = matcher$1(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Selection(subgroups, this._parents);\n};\n\nvar sparse = function(update) {\n  return new Array(update.length);\n};\n\nvar selection_enter = function() {\n  return new Selection(this._enter || this._groups.map(sparse), this._parents);\n};\n\nfunction EnterNode(parent, datum) {\n  this.ownerDocument = parent.ownerDocument;\n  this.namespaceURI = parent.namespaceURI;\n  this._next = null;\n  this._parent = parent;\n  this.__data__ = datum;\n}\n\nEnterNode.prototype = {\n  constructor: EnterNode,\n  appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n  insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n  querySelector: function(selector) { return this._parent.querySelector(selector); },\n  querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n};\n\nvar constant$1 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar keyPrefix = \"$\"; // Protect against keys like “__proto__”.\n\nfunction bindIndex(parent, group, enter, update, exit, data) {\n  var i = 0,\n      node,\n      groupLength = group.length,\n      dataLength = data.length;\n\n  // Put any non-null nodes that fit into update.\n  // Put any null nodes into enter.\n  // Put any remaining data into enter.\n  for (; i < dataLength; ++i) {\n    if (node = group[i]) {\n      node.__data__ = data[i];\n      update[i] = node;\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Put any non-null nodes that don’t fit into exit.\n  for (; i < groupLength; ++i) {\n    if (node = group[i]) {\n      exit[i] = node;\n    }\n  }\n}\n\nfunction bindKey(parent, group, enter, update, exit, data, key) {\n  var i,\n      node,\n      nodeByKeyValue = {},\n      groupLength = group.length,\n      dataLength = data.length,\n      keyValues = new Array(groupLength),\n      keyValue;\n\n  // Compute the key for each node.\n  // If multiple nodes have the same key, the duplicates are added to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if (node = group[i]) {\n      keyValues[i] = keyValue = keyPrefix + key.call(node, node.__data__, i, group);\n      if (keyValue in nodeByKeyValue) {\n        exit[i] = node;\n      } else {\n        nodeByKeyValue[keyValue] = node;\n      }\n    }\n  }\n\n  // Compute the key for each datum.\n  // If there a node associated with this key, join and add it to update.\n  // If there is not (or the key is a duplicate), add it to enter.\n  for (i = 0; i < dataLength; ++i) {\n    keyValue = keyPrefix + key.call(parent, data[i], i, data);\n    if (node = nodeByKeyValue[keyValue]) {\n      update[i] = node;\n      node.__data__ = data[i];\n      nodeByKeyValue[keyValue] = null;\n    } else {\n      enter[i] = new EnterNode(parent, data[i]);\n    }\n  }\n\n  // Add any remaining nodes that were not bound to data to exit.\n  for (i = 0; i < groupLength; ++i) {\n    if ((node = group[i]) && (nodeByKeyValue[keyValues[i]] === node)) {\n      exit[i] = node;\n    }\n  }\n}\n\nvar selection_data = function(value, key) {\n  if (!value) {\n    data = new Array(this.size()), j = -1;\n    this.each(function(d) { data[++j] = d; });\n    return data;\n  }\n\n  var bind = key ? bindKey : bindIndex,\n      parents = this._parents,\n      groups = this._groups;\n\n  if (typeof value !== \"function\") value = constant$1(value);\n\n  for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n    var parent = parents[j],\n        group = groups[j],\n        groupLength = group.length,\n        data = value.call(parent, parent && parent.__data__, j, parents),\n        dataLength = data.length,\n        enterGroup = enter[j] = new Array(dataLength),\n        updateGroup = update[j] = new Array(dataLength),\n        exitGroup = exit[j] = new Array(groupLength);\n\n    bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n    // Now connect the enter nodes to their following update node, such that\n    // appendChild can insert the materialized enter node before this node,\n    // rather than at the end of the parent node.\n    for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n      if (previous = enterGroup[i0]) {\n        if (i0 >= i1) i1 = i0 + 1;\n        while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n        previous._next = next || null;\n      }\n    }\n  }\n\n  update = new Selection(update, parents);\n  update._enter = enter;\n  update._exit = exit;\n  return update;\n};\n\nvar selection_exit = function() {\n  return new Selection(this._exit || this._groups.map(sparse), this._parents);\n};\n\nvar selection_merge = function(selection) {\n\n  for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Selection(merges, this._parents);\n};\n\nvar selection_order = function() {\n\n  for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n    for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n      if (node = group[i]) {\n        if (next && next !== node.nextSibling) next.parentNode.insertBefore(node, next);\n        next = node;\n      }\n    }\n  }\n\n  return this;\n};\n\nvar selection_sort = function(compare) {\n  if (!compare) compare = ascending$1;\n\n  function compareNode(a, b) {\n    return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n  }\n\n  for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        sortgroup[i] = node;\n      }\n    }\n    sortgroup.sort(compareNode);\n  }\n\n  return new Selection(sortgroups, this._parents).order();\n};\n\nfunction ascending$1(a, b) {\n  return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n\nvar selection_call = function() {\n  var callback = arguments[0];\n  arguments[0] = this;\n  callback.apply(null, arguments);\n  return this;\n};\n\nvar selection_nodes = function() {\n  var nodes = new Array(this.size()), i = -1;\n  this.each(function() { nodes[++i] = this; });\n  return nodes;\n};\n\nvar selection_node = function() {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n      var node = group[i];\n      if (node) return node;\n    }\n  }\n\n  return null;\n};\n\nvar selection_size = function() {\n  var size = 0;\n  this.each(function() { ++size; });\n  return size;\n};\n\nvar selection_empty = function() {\n  return !this.node();\n};\n\nvar selection_each = function(callback) {\n\n  for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n    for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n      if (node = group[i]) callback.call(node, node.__data__, i, group);\n    }\n  }\n\n  return this;\n};\n\nfunction attrRemove(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant(name, value) {\n  return function() {\n    this.setAttribute(name, value);\n  };\n}\n\nfunction attrConstantNS(fullname, value) {\n  return function() {\n    this.setAttributeNS(fullname.space, fullname.local, value);\n  };\n}\n\nfunction attrFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttribute(name);\n    else this.setAttribute(name, v);\n  };\n}\n\nfunction attrFunctionNS(fullname, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n    else this.setAttributeNS(fullname.space, fullname.local, v);\n  };\n}\n\nvar selection_attr = function(name, value) {\n  var fullname = namespace(name);\n\n  if (arguments.length < 2) {\n    var node = this.node();\n    return fullname.local\n        ? node.getAttributeNS(fullname.space, fullname.local)\n        : node.getAttribute(fullname);\n  }\n\n  return this.each((value == null\n      ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS : attrFunction)\n      : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n};\n\nvar defaultView = function(node) {\n  return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n      || (node.document && node) // node is a Window\n      || node.defaultView; // node is a Document\n};\n\nfunction styleRemove(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant(name, value, priority) {\n  return function() {\n    this.style.setProperty(name, value, priority);\n  };\n}\n\nfunction styleFunction(name, value, priority) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) this.style.removeProperty(name);\n    else this.style.setProperty(name, v, priority);\n  };\n}\n\nvar selection_style = function(name, value, priority) {\n  return arguments.length > 1\n      ? this.each((value == null\n            ? styleRemove : typeof value === \"function\"\n            ? styleFunction\n            : styleConstant)(name, value, priority == null ? \"\" : priority))\n      : styleValue(this.node(), name);\n};\n\nfunction styleValue(node, name) {\n  return node.style.getPropertyValue(name)\n      || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);\n}\n\nfunction propertyRemove(name) {\n  return function() {\n    delete this[name];\n  };\n}\n\nfunction propertyConstant(name, value) {\n  return function() {\n    this[name] = value;\n  };\n}\n\nfunction propertyFunction(name, value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    if (v == null) delete this[name];\n    else this[name] = v;\n  };\n}\n\nvar selection_property = function(name, value) {\n  return arguments.length > 1\n      ? this.each((value == null\n          ? propertyRemove : typeof value === \"function\"\n          ? propertyFunction\n          : propertyConstant)(name, value))\n      : this.node()[name];\n};\n\nfunction classArray(string) {\n  return string.trim().split(/^|\\s+/);\n}\n\nfunction classList(node) {\n  return node.classList || new ClassList(node);\n}\n\nfunction ClassList(node) {\n  this._node = node;\n  this._names = classArray(node.getAttribute(\"class\") || \"\");\n}\n\nClassList.prototype = {\n  add: function(name) {\n    var i = this._names.indexOf(name);\n    if (i < 0) {\n      this._names.push(name);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  remove: function(name) {\n    var i = this._names.indexOf(name);\n    if (i >= 0) {\n      this._names.splice(i, 1);\n      this._node.setAttribute(\"class\", this._names.join(\" \"));\n    }\n  },\n  contains: function(name) {\n    return this._names.indexOf(name) >= 0;\n  }\n};\n\nfunction classedAdd(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.add(names[i]);\n}\n\nfunction classedRemove(node, names) {\n  var list = classList(node), i = -1, n = names.length;\n  while (++i < n) list.remove(names[i]);\n}\n\nfunction classedTrue(names) {\n  return function() {\n    classedAdd(this, names);\n  };\n}\n\nfunction classedFalse(names) {\n  return function() {\n    classedRemove(this, names);\n  };\n}\n\nfunction classedFunction(names, value) {\n  return function() {\n    (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n  };\n}\n\nvar selection_classed = function(name, value) {\n  var names = classArray(name + \"\");\n\n  if (arguments.length < 2) {\n    var list = classList(this.node()), i = -1, n = names.length;\n    while (++i < n) if (!list.contains(names[i])) return false;\n    return true;\n  }\n\n  return this.each((typeof value === \"function\"\n      ? classedFunction : value\n      ? classedTrue\n      : classedFalse)(names, value));\n};\n\nfunction textRemove() {\n  this.textContent = \"\";\n}\n\nfunction textConstant(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.textContent = v == null ? \"\" : v;\n  };\n}\n\nvar selection_text = function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? textRemove : (typeof value === \"function\"\n          ? textFunction\n          : textConstant)(value))\n      : this.node().textContent;\n};\n\nfunction htmlRemove() {\n  this.innerHTML = \"\";\n}\n\nfunction htmlConstant(value) {\n  return function() {\n    this.innerHTML = value;\n  };\n}\n\nfunction htmlFunction(value) {\n  return function() {\n    var v = value.apply(this, arguments);\n    this.innerHTML = v == null ? \"\" : v;\n  };\n}\n\nvar selection_html = function(value) {\n  return arguments.length\n      ? this.each(value == null\n          ? htmlRemove : (typeof value === \"function\"\n          ? htmlFunction\n          : htmlConstant)(value))\n      : this.node().innerHTML;\n};\n\nfunction raise() {\n  if (this.nextSibling) this.parentNode.appendChild(this);\n}\n\nvar selection_raise = function() {\n  return this.each(raise);\n};\n\nfunction lower() {\n  if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n}\n\nvar selection_lower = function() {\n  return this.each(lower);\n};\n\nvar selection_append = function(name) {\n  var create = typeof name === \"function\" ? name : creator(name);\n  return this.select(function() {\n    return this.appendChild(create.apply(this, arguments));\n  });\n};\n\nfunction constantNull() {\n  return null;\n}\n\nvar selection_insert = function(name, before) {\n  var create = typeof name === \"function\" ? name : creator(name),\n      select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n  return this.select(function() {\n    return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n  });\n};\n\nfunction remove() {\n  var parent = this.parentNode;\n  if (parent) parent.removeChild(this);\n}\n\nvar selection_remove = function() {\n  return this.each(remove);\n};\n\nvar selection_datum = function(value) {\n  return arguments.length\n      ? this.property(\"__data__\", value)\n      : this.node().__data__;\n};\n\nfunction dispatchEvent(node, type, params) {\n  var window = defaultView(node),\n      event = window.CustomEvent;\n\n  if (typeof event === \"function\") {\n    event = new event(type, params);\n  } else {\n    event = window.document.createEvent(\"Event\");\n    if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n    else event.initEvent(type, false, false);\n  }\n\n  node.dispatchEvent(event);\n}\n\nfunction dispatchConstant(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params);\n  };\n}\n\nfunction dispatchFunction(type, params) {\n  return function() {\n    return dispatchEvent(this, type, params.apply(this, arguments));\n  };\n}\n\nvar selection_dispatch = function(type, params) {\n  return this.each((typeof params === \"function\"\n      ? dispatchFunction\n      : dispatchConstant)(type, params));\n};\n\nvar root = [null];\n\nfunction Selection(groups, parents) {\n  this._groups = groups;\n  this._parents = parents;\n}\n\nfunction selection() {\n  return new Selection([[document.documentElement]], root);\n}\n\nSelection.prototype = selection.prototype = {\n  constructor: Selection,\n  select: selection_select,\n  selectAll: selection_selectAll,\n  filter: selection_filter,\n  data: selection_data,\n  enter: selection_enter,\n  exit: selection_exit,\n  merge: selection_merge,\n  order: selection_order,\n  sort: selection_sort,\n  call: selection_call,\n  nodes: selection_nodes,\n  node: selection_node,\n  size: selection_size,\n  empty: selection_empty,\n  each: selection_each,\n  attr: selection_attr,\n  style: selection_style,\n  property: selection_property,\n  classed: selection_classed,\n  text: selection_text,\n  html: selection_html,\n  raise: selection_raise,\n  lower: selection_lower,\n  append: selection_append,\n  insert: selection_insert,\n  remove: selection_remove,\n  datum: selection_datum,\n  on: selection_on,\n  dispatch: selection_dispatch\n};\n\nvar select = function(selector) {\n  return typeof selector === \"string\"\n      ? new Selection([[document.querySelector(selector)]], [document.documentElement])\n      : new Selection([[selector]], root);\n};\n\nvar selectAll = function(selector) {\n  return typeof selector === \"string\"\n      ? new Selection([document.querySelectorAll(selector)], [document.documentElement])\n      : new Selection([selector == null ? [] : selector], root);\n};\n\nvar touch = function(node, touches, identifier) {\n  if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;\n\n  for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {\n    if ((touch = touches[i]).identifier === identifier) {\n      return point(node, touch);\n    }\n  }\n\n  return null;\n};\n\nvar touches = function(node, touches) {\n  if (touches == null) touches = sourceEvent().touches;\n\n  for (var i = 0, n = touches ? touches.length : 0, points = new Array(n); i < n; ++i) {\n    points[i] = point(node, touches[i]);\n  }\n\n  return points;\n};\n\nfunction nopropagation() {\n  exports.event.stopImmediatePropagation();\n}\n\nvar noevent = function() {\n  exports.event.preventDefault();\n  exports.event.stopImmediatePropagation();\n};\n\nvar dragDisable = function(view) {\n  var root = view.document.documentElement,\n      selection$$1 = select(view).on(\"dragstart.drag\", noevent, true);\n  if (\"onselectstart\" in root) {\n    selection$$1.on(\"selectstart.drag\", noevent, true);\n  } else {\n    root.__noselect = root.style.MozUserSelect;\n    root.style.MozUserSelect = \"none\";\n  }\n};\n\nfunction yesdrag(view, noclick) {\n  var root = view.document.documentElement,\n      selection$$1 = select(view).on(\"dragstart.drag\", null);\n  if (noclick) {\n    selection$$1.on(\"click.drag\", noevent, true);\n    setTimeout(function() { selection$$1.on(\"click.drag\", null); }, 0);\n  }\n  if (\"onselectstart\" in root) {\n    selection$$1.on(\"selectstart.drag\", null);\n  } else {\n    root.style.MozUserSelect = root.__noselect;\n    delete root.__noselect;\n  }\n}\n\nvar constant$2 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nfunction DragEvent(target, type, subject, id, active, x, y, dx, dy, dispatch) {\n  this.target = target;\n  this.type = type;\n  this.subject = subject;\n  this.identifier = id;\n  this.active = active;\n  this.x = x;\n  this.y = y;\n  this.dx = dx;\n  this.dy = dy;\n  this._ = dispatch;\n}\n\nDragEvent.prototype.on = function() {\n  var value = this._.on.apply(this._, arguments);\n  return value === this._ ? this : value;\n};\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter$1() {\n  return !exports.event.button;\n}\n\nfunction defaultContainer() {\n  return this.parentNode;\n}\n\nfunction defaultSubject(d) {\n  return d == null ? {x: exports.event.x, y: exports.event.y} : d;\n}\n\nvar drag = function() {\n  var filter = defaultFilter$1,\n      container = defaultContainer,\n      subject = defaultSubject,\n      gestures = {},\n      listeners = dispatch(\"start\", \"drag\", \"end\"),\n      active = 0,\n      mousedownx,\n      mousedowny,\n      mousemoving,\n      touchending,\n      clickDistance2 = 0;\n\n  function drag(selection$$1) {\n    selection$$1\n        .on(\"mousedown.drag\", mousedowned)\n        .on(\"touchstart.drag\", touchstarted)\n        .on(\"touchmove.drag\", touchmoved)\n        .on(\"touchend.drag touchcancel.drag\", touchended)\n        .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n  }\n\n  function mousedowned() {\n    if (touchending || !filter.apply(this, arguments)) return;\n    var gesture = beforestart(\"mouse\", container.apply(this, arguments), mouse, this, arguments);\n    if (!gesture) return;\n    select(exports.event.view).on(\"mousemove.drag\", mousemoved, true).on(\"mouseup.drag\", mouseupped, true);\n    dragDisable(exports.event.view);\n    nopropagation();\n    mousemoving = false;\n    mousedownx = exports.event.clientX;\n    mousedowny = exports.event.clientY;\n    gesture(\"start\");\n  }\n\n  function mousemoved() {\n    noevent();\n    if (!mousemoving) {\n      var dx = exports.event.clientX - mousedownx, dy = exports.event.clientY - mousedowny;\n      mousemoving = dx * dx + dy * dy > clickDistance2;\n    }\n    gestures.mouse(\"drag\");\n  }\n\n  function mouseupped() {\n    select(exports.event.view).on(\"mousemove.drag mouseup.drag\", null);\n    yesdrag(exports.event.view, mousemoving);\n    noevent();\n    gestures.mouse(\"end\");\n  }\n\n  function touchstarted() {\n    if (!filter.apply(this, arguments)) return;\n    var touches$$1 = exports.event.changedTouches,\n        c = container.apply(this, arguments),\n        n = touches$$1.length, i, gesture;\n\n    for (i = 0; i < n; ++i) {\n      if (gesture = beforestart(touches$$1[i].identifier, c, touch, this, arguments)) {\n        nopropagation();\n        gesture(\"start\");\n      }\n    }\n  }\n\n  function touchmoved() {\n    var touches$$1 = exports.event.changedTouches,\n        n = touches$$1.length, i, gesture;\n\n    for (i = 0; i < n; ++i) {\n      if (gesture = gestures[touches$$1[i].identifier]) {\n        noevent();\n        gesture(\"drag\");\n      }\n    }\n  }\n\n  function touchended() {\n    var touches$$1 = exports.event.changedTouches,\n        n = touches$$1.length, i, gesture;\n\n    if (touchending) clearTimeout(touchending);\n    touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n    for (i = 0; i < n; ++i) {\n      if (gesture = gestures[touches$$1[i].identifier]) {\n        nopropagation();\n        gesture(\"end\");\n      }\n    }\n  }\n\n  function beforestart(id, container, point, that, args) {\n    var p = point(container, id), s, dx, dy,\n        sublisteners = listeners.copy();\n\n    if (!customEvent(new DragEvent(drag, \"beforestart\", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {\n      if ((exports.event.subject = s = subject.apply(that, args)) == null) return false;\n      dx = s.x - p[0] || 0;\n      dy = s.y - p[1] || 0;\n      return true;\n    })) return;\n\n    return function gesture(type) {\n      var p0 = p, n;\n      switch (type) {\n        case \"start\": gestures[id] = gesture, n = active++; break;\n        case \"end\": delete gestures[id], --active; // nobreak\n        case \"drag\": p = point(container, id), n = active; break;\n      }\n      customEvent(new DragEvent(drag, type, s, id, n, p[0] + dx, p[1] + dy, p[0] - p0[0], p[1] - p0[1], sublisteners), sublisteners.apply, sublisteners, [type, that, args]);\n    };\n  }\n\n  drag.filter = function(_) {\n    return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$2(!!_), drag) : filter;\n  };\n\n  drag.container = function(_) {\n    return arguments.length ? (container = typeof _ === \"function\" ? _ : constant$2(_), drag) : container;\n  };\n\n  drag.subject = function(_) {\n    return arguments.length ? (subject = typeof _ === \"function\" ? _ : constant$2(_), drag) : subject;\n  };\n\n  drag.on = function() {\n    var value = listeners.on.apply(listeners, arguments);\n    return value === listeners ? drag : value;\n  };\n\n  drag.clickDistance = function(_) {\n    return arguments.length ? (clickDistance2 = (_ = +_) * _, drag) : Math.sqrt(clickDistance2);\n  };\n\n  return drag;\n};\n\nvar define = function(constructor, factory, prototype) {\n  constructor.prototype = factory.prototype = prototype;\n  prototype.constructor = constructor;\n};\n\nfunction extend(parent, definition) {\n  var prototype = Object.create(parent.prototype);\n  for (var key in definition) prototype[key] = definition[key];\n  return prototype;\n}\n\nfunction Color() {}\n\nvar darker = 0.7;\nvar brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\";\nvar reN = \"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\";\nvar reP = \"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\";\nvar reHex3 = /^#([0-9a-f]{3})$/;\nvar reHex6 = /^#([0-9a-f]{6})$/;\nvar reRgbInteger = new RegExp(\"^rgb\\\\(\" + [reI, reI, reI] + \"\\\\)$\");\nvar reRgbPercent = new RegExp(\"^rgb\\\\(\" + [reP, reP, reP] + \"\\\\)$\");\nvar reRgbaInteger = new RegExp(\"^rgba\\\\(\" + [reI, reI, reI, reN] + \"\\\\)$\");\nvar reRgbaPercent = new RegExp(\"^rgba\\\\(\" + [reP, reP, reP, reN] + \"\\\\)$\");\nvar reHslPercent = new RegExp(\"^hsl\\\\(\" + [reN, reP, reP] + \"\\\\)$\");\nvar reHslaPercent = new RegExp(\"^hsla\\\\(\" + [reN, reP, reP, reN] + \"\\\\)$\");\n\nvar named = {\n  aliceblue: 0xf0f8ff,\n  antiquewhite: 0xfaebd7,\n  aqua: 0x00ffff,\n  aquamarine: 0x7fffd4,\n  azure: 0xf0ffff,\n  beige: 0xf5f5dc,\n  bisque: 0xffe4c4,\n  black: 0x000000,\n  blanchedalmond: 0xffebcd,\n  blue: 0x0000ff,\n  blueviolet: 0x8a2be2,\n  brown: 0xa52a2a,\n  burlywood: 0xdeb887,\n  cadetblue: 0x5f9ea0,\n  chartreuse: 0x7fff00,\n  chocolate: 0xd2691e,\n  coral: 0xff7f50,\n  cornflowerblue: 0x6495ed,\n  cornsilk: 0xfff8dc,\n  crimson: 0xdc143c,\n  cyan: 0x00ffff,\n  darkblue: 0x00008b,\n  darkcyan: 0x008b8b,\n  darkgoldenrod: 0xb8860b,\n  darkgray: 0xa9a9a9,\n  darkgreen: 0x006400,\n  darkgrey: 0xa9a9a9,\n  darkkhaki: 0xbdb76b,\n  darkmagenta: 0x8b008b,\n  darkolivegreen: 0x556b2f,\n  darkorange: 0xff8c00,\n  darkorchid: 0x9932cc,\n  darkred: 0x8b0000,\n  darksalmon: 0xe9967a,\n  darkseagreen: 0x8fbc8f,\n  darkslateblue: 0x483d8b,\n  darkslategray: 0x2f4f4f,\n  darkslategrey: 0x2f4f4f,\n  darkturquoise: 0x00ced1,\n  darkviolet: 0x9400d3,\n  deeppink: 0xff1493,\n  deepskyblue: 0x00bfff,\n  dimgray: 0x696969,\n  dimgrey: 0x696969,\n  dodgerblue: 0x1e90ff,\n  firebrick: 0xb22222,\n  floralwhite: 0xfffaf0,\n  forestgreen: 0x228b22,\n  fuchsia: 0xff00ff,\n  gainsboro: 0xdcdcdc,\n  ghostwhite: 0xf8f8ff,\n  gold: 0xffd700,\n  goldenrod: 0xdaa520,\n  gray: 0x808080,\n  green: 0x008000,\n  greenyellow: 0xadff2f,\n  grey: 0x808080,\n  honeydew: 0xf0fff0,\n  hotpink: 0xff69b4,\n  indianred: 0xcd5c5c,\n  indigo: 0x4b0082,\n  ivory: 0xfffff0,\n  khaki: 0xf0e68c,\n  lavender: 0xe6e6fa,\n  lavenderblush: 0xfff0f5,\n  lawngreen: 0x7cfc00,\n  lemonchiffon: 0xfffacd,\n  lightblue: 0xadd8e6,\n  lightcoral: 0xf08080,\n  lightcyan: 0xe0ffff,\n  lightgoldenrodyellow: 0xfafad2,\n  lightgray: 0xd3d3d3,\n  lightgreen: 0x90ee90,\n  lightgrey: 0xd3d3d3,\n  lightpink: 0xffb6c1,\n  lightsalmon: 0xffa07a,\n  lightseagreen: 0x20b2aa,\n  lightskyblue: 0x87cefa,\n  lightslategray: 0x778899,\n  lightslategrey: 0x778899,\n  lightsteelblue: 0xb0c4de,\n  lightyellow: 0xffffe0,\n  lime: 0x00ff00,\n  limegreen: 0x32cd32,\n  linen: 0xfaf0e6,\n  magenta: 0xff00ff,\n  maroon: 0x800000,\n  mediumaquamarine: 0x66cdaa,\n  mediumblue: 0x0000cd,\n  mediumorchid: 0xba55d3,\n  mediumpurple: 0x9370db,\n  mediumseagreen: 0x3cb371,\n  mediumslateblue: 0x7b68ee,\n  mediumspringgreen: 0x00fa9a,\n  mediumturquoise: 0x48d1cc,\n  mediumvioletred: 0xc71585,\n  midnightblue: 0x191970,\n  mintcream: 0xf5fffa,\n  mistyrose: 0xffe4e1,\n  moccasin: 0xffe4b5,\n  navajowhite: 0xffdead,\n  navy: 0x000080,\n  oldlace: 0xfdf5e6,\n  olive: 0x808000,\n  olivedrab: 0x6b8e23,\n  orange: 0xffa500,\n  orangered: 0xff4500,\n  orchid: 0xda70d6,\n  palegoldenrod: 0xeee8aa,\n  palegreen: 0x98fb98,\n  paleturquoise: 0xafeeee,\n  palevioletred: 0xdb7093,\n  papayawhip: 0xffefd5,\n  peachpuff: 0xffdab9,\n  peru: 0xcd853f,\n  pink: 0xffc0cb,\n  plum: 0xdda0dd,\n  powderblue: 0xb0e0e6,\n  purple: 0x800080,\n  rebeccapurple: 0x663399,\n  red: 0xff0000,\n  rosybrown: 0xbc8f8f,\n  royalblue: 0x4169e1,\n  saddlebrown: 0x8b4513,\n  salmon: 0xfa8072,\n  sandybrown: 0xf4a460,\n  seagreen: 0x2e8b57,\n  seashell: 0xfff5ee,\n  sienna: 0xa0522d,\n  silver: 0xc0c0c0,\n  skyblue: 0x87ceeb,\n  slateblue: 0x6a5acd,\n  slategray: 0x708090,\n  slategrey: 0x708090,\n  snow: 0xfffafa,\n  springgreen: 0x00ff7f,\n  steelblue: 0x4682b4,\n  tan: 0xd2b48c,\n  teal: 0x008080,\n  thistle: 0xd8bfd8,\n  tomato: 0xff6347,\n  turquoise: 0x40e0d0,\n  violet: 0xee82ee,\n  wheat: 0xf5deb3,\n  white: 0xffffff,\n  whitesmoke: 0xf5f5f5,\n  yellow: 0xffff00,\n  yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n  displayable: function() {\n    return this.rgb().displayable();\n  },\n  toString: function() {\n    return this.rgb() + \"\";\n  }\n});\n\nfunction color(format) {\n  var m;\n  format = (format + \"\").trim().toLowerCase();\n  return (m = reHex3.exec(format)) ? (m = parseInt(m[1], 16), new Rgb((m >> 8 & 0xf) | (m >> 4 & 0x0f0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1)) // #f00\n      : (m = reHex6.exec(format)) ? rgbn(parseInt(m[1], 16)) // #ff0000\n      : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n      : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n      : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n      : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n      : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n      : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n      : named.hasOwnProperty(format) ? rgbn(named[format])\n      : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n      : null;\n}\n\nfunction rgbn(n) {\n  return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n  if (a <= 0) r = g = b = NaN;\n  return new Rgb(r, g, b, a);\n}\n\nfunction rgbConvert(o) {\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Rgb;\n  o = o.rgb();\n  return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nfunction rgb(r, g, b, opacity) {\n  return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nfunction Rgb(r, g, b, opacity) {\n  this.r = +r;\n  this.g = +g;\n  this.b = +b;\n  this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n  brighter: function(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  darker: function(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n  },\n  rgb: function() {\n    return this;\n  },\n  displayable: function() {\n    return (0 <= this.r && this.r <= 255)\n        && (0 <= this.g && this.g <= 255)\n        && (0 <= this.b && this.b <= 255)\n        && (0 <= this.opacity && this.opacity <= 1);\n  },\n  toString: function() {\n    var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n    return (a === 1 ? \"rgb(\" : \"rgba(\")\n        + Math.max(0, Math.min(255, Math.round(this.r) || 0)) + \", \"\n        + Math.max(0, Math.min(255, Math.round(this.g) || 0)) + \", \"\n        + Math.max(0, Math.min(255, Math.round(this.b) || 0))\n        + (a === 1 ? \")\" : \", \" + a + \")\");\n  }\n}));\n\nfunction hsla(h, s, l, a) {\n  if (a <= 0) h = s = l = NaN;\n  else if (l <= 0 || l >= 1) h = s = NaN;\n  else if (s <= 0) h = NaN;\n  return new Hsl(h, s, l, a);\n}\n\nfunction hslConvert(o) {\n  if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n  if (!(o instanceof Color)) o = color(o);\n  if (!o) return new Hsl;\n  if (o instanceof Hsl) return o;\n  o = o.rgb();\n  var r = o.r / 255,\n      g = o.g / 255,\n      b = o.b / 255,\n      min = Math.min(r, g, b),\n      max = Math.max(r, g, b),\n      h = NaN,\n      s = max - min,\n      l = (max + min) / 2;\n  if (s) {\n    if (r === max) h = (g - b) / s + (g < b) * 6;\n    else if (g === max) h = (b - r) / s + 2;\n    else h = (r - g) / s + 4;\n    s /= l < 0.5 ? max + min : 2 - max - min;\n    h *= 60;\n  } else {\n    s = l > 0 && l < 1 ? 0 : h;\n  }\n  return new Hsl(h, s, l, o.opacity);\n}\n\nfunction hsl(h, s, l, opacity) {\n  return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n  this.h = +h;\n  this.s = +s;\n  this.l = +l;\n  this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n  brighter: function(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  darker: function(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Hsl(this.h, this.s, this.l * k, this.opacity);\n  },\n  rgb: function() {\n    var h = this.h % 360 + (this.h < 0) * 360,\n        s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n        l = this.l,\n        m2 = l + (l < 0.5 ? l : 1 - l) * s,\n        m1 = 2 * l - m2;\n    return new Rgb(\n      hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n      hsl2rgb(h, m1, m2),\n      hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n      this.opacity\n    );\n  },\n  displayable: function() {\n    return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n        && (0 <= this.l && this.l <= 1)\n        && (0 <= this.opacity && this.opacity <= 1);\n  }\n}));\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n  return (h < 60 ? m1 + (m2 - m1) * h / 60\n      : h < 180 ? m2\n      : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n      : m1) * 255;\n}\n\nvar deg2rad = Math.PI / 180;\nvar rad2deg = 180 / Math.PI;\n\nvar Kn = 18;\nvar Xn = 0.950470;\nvar Yn = 1;\nvar Zn = 1.088830;\nvar t0 = 4 / 29;\nvar t1 = 6 / 29;\nvar t2 = 3 * t1 * t1;\nvar t3 = t1 * t1 * t1;\n\nfunction labConvert(o) {\n  if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);\n  if (o instanceof Hcl) {\n    var h = o.h * deg2rad;\n    return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);\n  }\n  if (!(o instanceof Rgb)) o = rgbConvert(o);\n  var b = rgb2xyz(o.r),\n      a = rgb2xyz(o.g),\n      l = rgb2xyz(o.b),\n      x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n      y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n      z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n  return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);\n}\n\nfunction lab(l, a, b, opacity) {\n  return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);\n}\n\nfunction Lab(l, a, b, opacity) {\n  this.l = +l;\n  this.a = +a;\n  this.b = +b;\n  this.opacity = +opacity;\n}\n\ndefine(Lab, lab, extend(Color, {\n  brighter: function(k) {\n    return new Lab(this.l + Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n  },\n  darker: function(k) {\n    return new Lab(this.l - Kn * (k == null ? 1 : k), this.a, this.b, this.opacity);\n  },\n  rgb: function() {\n    var y = (this.l + 16) / 116,\n        x = isNaN(this.a) ? y : y + this.a / 500,\n        z = isNaN(this.b) ? y : y - this.b / 200;\n    y = Yn * lab2xyz(y);\n    x = Xn * lab2xyz(x);\n    z = Zn * lab2xyz(z);\n    return new Rgb(\n      xyz2rgb( 3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n      xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n      xyz2rgb( 0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n      this.opacity\n    );\n  }\n}));\n\nfunction xyz2lab(t) {\n  return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\n\nfunction lab2xyz(t) {\n  return t > t1 ? t * t * t : t2 * (t - t0);\n}\n\nfunction xyz2rgb(x) {\n  return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\n\nfunction rgb2xyz(x) {\n  return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\n\nfunction hclConvert(o) {\n  if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);\n  if (!(o instanceof Lab)) o = labConvert(o);\n  var h = Math.atan2(o.b, o.a) * rad2deg;\n  return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);\n}\n\nfunction hcl(h, c, l, opacity) {\n  return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hcl(h, c, l, opacity) {\n  this.h = +h;\n  this.c = +c;\n  this.l = +l;\n  this.opacity = +opacity;\n}\n\ndefine(Hcl, hcl, extend(Color, {\n  brighter: function(k) {\n    return new Hcl(this.h, this.c, this.l + Kn * (k == null ? 1 : k), this.opacity);\n  },\n  darker: function(k) {\n    return new Hcl(this.h, this.c, this.l - Kn * (k == null ? 1 : k), this.opacity);\n  },\n  rgb: function() {\n    return labConvert(this).rgb();\n  }\n}));\n\nvar A = -0.14861;\nvar B = +1.78277;\nvar C = -0.29227;\nvar D = -0.90649;\nvar E = +1.97294;\nvar ED = E * D;\nvar EB = E * B;\nvar BC_DA = B * C - D * A;\n\nfunction cubehelixConvert(o) {\n  if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);\n  if (!(o instanceof Rgb)) o = rgbConvert(o);\n  var r = o.r / 255,\n      g = o.g / 255,\n      b = o.b / 255,\n      l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),\n      bl = b - l,\n      k = (E * (g - l) - C * bl) / D,\n      s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1\n      h = s ? Math.atan2(k, bl) * rad2deg - 120 : NaN;\n  return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);\n}\n\nfunction cubehelix(h, s, l, opacity) {\n  return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Cubehelix(h, s, l, opacity) {\n  this.h = +h;\n  this.s = +s;\n  this.l = +l;\n  this.opacity = +opacity;\n}\n\ndefine(Cubehelix, cubehelix, extend(Color, {\n  brighter: function(k) {\n    k = k == null ? brighter : Math.pow(brighter, k);\n    return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n  },\n  darker: function(k) {\n    k = k == null ? darker : Math.pow(darker, k);\n    return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n  },\n  rgb: function() {\n    var h = isNaN(this.h) ? 0 : (this.h + 120) * deg2rad,\n        l = +this.l,\n        a = isNaN(this.s) ? 0 : this.s * l * (1 - l),\n        cosh = Math.cos(h),\n        sinh = Math.sin(h);\n    return new Rgb(\n      255 * (l + a * (A * cosh + B * sinh)),\n      255 * (l + a * (C * cosh + D * sinh)),\n      255 * (l + a * (E * cosh)),\n      this.opacity\n    );\n  }\n}));\n\nfunction basis(t1, v0, v1, v2, v3) {\n  var t2 = t1 * t1, t3 = t2 * t1;\n  return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n      + (4 - 6 * t2 + 3 * t3) * v1\n      + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n      + t3 * v3) / 6;\n}\n\nvar basis$1 = function(values) {\n  var n = values.length - 1;\n  return function(t) {\n    var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n        v1 = values[i],\n        v2 = values[i + 1],\n        v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n        v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n    return basis((t - i / n) * n, v0, v1, v2, v3);\n  };\n};\n\nvar basisClosed = function(values) {\n  var n = values.length;\n  return function(t) {\n    var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n        v0 = values[(i + n - 1) % n],\n        v1 = values[i % n],\n        v2 = values[(i + 1) % n],\n        v3 = values[(i + 2) % n];\n    return basis((t - i / n) * n, v0, v1, v2, v3);\n  };\n};\n\nvar constant$3 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nfunction linear(a, d) {\n  return function(t) {\n    return a + t * d;\n  };\n}\n\nfunction exponential(a, b, y) {\n  return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n    return Math.pow(a + t * b, y);\n  };\n}\n\nfunction hue(a, b) {\n  var d = b - a;\n  return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant$3(isNaN(a) ? b : a);\n}\n\nfunction gamma(y) {\n  return (y = +y) === 1 ? nogamma : function(a, b) {\n    return b - a ? exponential(a, b, y) : constant$3(isNaN(a) ? b : a);\n  };\n}\n\nfunction nogamma(a, b) {\n  var d = b - a;\n  return d ? linear(a, d) : constant$3(isNaN(a) ? b : a);\n}\n\nvar interpolateRgb = ((function rgbGamma(y) {\n  var color$$1 = gamma(y);\n\n  function rgb$$1(start, end) {\n    var r = color$$1((start = rgb(start)).r, (end = rgb(end)).r),\n        g = color$$1(start.g, end.g),\n        b = color$$1(start.b, end.b),\n        opacity = nogamma(start.opacity, end.opacity);\n    return function(t) {\n      start.r = r(t);\n      start.g = g(t);\n      start.b = b(t);\n      start.opacity = opacity(t);\n      return start + \"\";\n    };\n  }\n\n  rgb$$1.gamma = rgbGamma;\n\n  return rgb$$1;\n}))(1);\n\nfunction rgbSpline(spline) {\n  return function(colors) {\n    var n = colors.length,\n        r = new Array(n),\n        g = new Array(n),\n        b = new Array(n),\n        i, color$$1;\n    for (i = 0; i < n; ++i) {\n      color$$1 = rgb(colors[i]);\n      r[i] = color$$1.r || 0;\n      g[i] = color$$1.g || 0;\n      b[i] = color$$1.b || 0;\n    }\n    r = spline(r);\n    g = spline(g);\n    b = spline(b);\n    color$$1.opacity = 1;\n    return function(t) {\n      color$$1.r = r(t);\n      color$$1.g = g(t);\n      color$$1.b = b(t);\n      return color$$1 + \"\";\n    };\n  };\n}\n\nvar rgbBasis = rgbSpline(basis$1);\nvar rgbBasisClosed = rgbSpline(basisClosed);\n\nvar array$1 = function(a, b) {\n  var nb = b ? b.length : 0,\n      na = a ? Math.min(nb, a.length) : 0,\n      x = new Array(nb),\n      c = new Array(nb),\n      i;\n\n  for (i = 0; i < na; ++i) x[i] = interpolateValue(a[i], b[i]);\n  for (; i < nb; ++i) c[i] = b[i];\n\n  return function(t) {\n    for (i = 0; i < na; ++i) c[i] = x[i](t);\n    return c;\n  };\n};\n\nvar date = function(a, b) {\n  var d = new Date;\n  return a = +a, b -= a, function(t) {\n    return d.setTime(a + b * t), d;\n  };\n};\n\nvar reinterpolate = function(a, b) {\n  return a = +a, b -= a, function(t) {\n    return a + b * t;\n  };\n};\n\nvar object = function(a, b) {\n  var i = {},\n      c = {},\n      k;\n\n  if (a === null || typeof a !== \"object\") a = {};\n  if (b === null || typeof b !== \"object\") b = {};\n\n  for (k in b) {\n    if (k in a) {\n      i[k] = interpolateValue(a[k], b[k]);\n    } else {\n      c[k] = b[k];\n    }\n  }\n\n  return function(t) {\n    for (k in i) c[k] = i[k](t);\n    return c;\n  };\n};\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g;\nvar reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n  return function() {\n    return b;\n  };\n}\n\nfunction one(b) {\n  return function(t) {\n    return b(t) + \"\";\n  };\n}\n\nvar interpolateString = function(a, b) {\n  var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n      am, // current match in a\n      bm, // current match in b\n      bs, // string preceding current number in b, if any\n      i = -1, // index in s\n      s = [], // string constants and placeholders\n      q = []; // number interpolators\n\n  // Coerce inputs to strings.\n  a = a + \"\", b = b + \"\";\n\n  // Interpolate pairs of numbers in a & b.\n  while ((am = reA.exec(a))\n      && (bm = reB.exec(b))) {\n    if ((bs = bm.index) > bi) { // a string precedes the next number in b\n      bs = b.slice(bi, bs);\n      if (s[i]) s[i] += bs; // coalesce with previous string\n      else s[++i] = bs;\n    }\n    if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n      if (s[i]) s[i] += bm; // coalesce with previous string\n      else s[++i] = bm;\n    } else { // interpolate non-matching numbers\n      s[++i] = null;\n      q.push({i: i, x: reinterpolate(am, bm)});\n    }\n    bi = reB.lastIndex;\n  }\n\n  // Add remains of b.\n  if (bi < b.length) {\n    bs = b.slice(bi);\n    if (s[i]) s[i] += bs; // coalesce with previous string\n    else s[++i] = bs;\n  }\n\n  // Special optimization for only a single match.\n  // Otherwise, interpolate each of the numbers and rejoin the string.\n  return s.length < 2 ? (q[0]\n      ? one(q[0].x)\n      : zero(b))\n      : (b = q.length, function(t) {\n          for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n          return s.join(\"\");\n        });\n};\n\nvar interpolateValue = function(a, b) {\n  var t = typeof b, c;\n  return b == null || t === \"boolean\" ? constant$3(b)\n      : (t === \"number\" ? reinterpolate\n      : t === \"string\" ? ((c = color(b)) ? (b = c, interpolateRgb) : interpolateString)\n      : b instanceof color ? interpolateRgb\n      : b instanceof Date ? date\n      : Array.isArray(b) ? array$1\n      : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n      : reinterpolate)(a, b);\n};\n\nvar interpolateRound = function(a, b) {\n  return a = +a, b -= a, function(t) {\n    return Math.round(a + b * t);\n  };\n};\n\nvar degrees = 180 / Math.PI;\n\nvar identity$2 = {\n  translateX: 0,\n  translateY: 0,\n  rotate: 0,\n  skewX: 0,\n  scaleX: 1,\n  scaleY: 1\n};\n\nvar decompose = function(a, b, c, d, e, f) {\n  var scaleX, scaleY, skewX;\n  if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n  if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n  if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n  if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n  return {\n    translateX: e,\n    translateY: f,\n    rotate: Math.atan2(b, a) * degrees,\n    skewX: Math.atan(skewX) * degrees,\n    scaleX: scaleX,\n    scaleY: scaleY\n  };\n};\n\nvar cssNode;\nvar cssRoot;\nvar cssView;\nvar svgNode;\n\nfunction parseCss(value) {\n  if (value === \"none\") return identity$2;\n  if (!cssNode) cssNode = document.createElement(\"DIV\"), cssRoot = document.documentElement, cssView = document.defaultView;\n  cssNode.style.transform = value;\n  value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue(\"transform\");\n  cssRoot.removeChild(cssNode);\n  value = value.slice(7, -1).split(\",\");\n  return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);\n}\n\nfunction parseSvg(value) {\n  if (value == null) return identity$2;\n  if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n  svgNode.setAttribute(\"transform\", value);\n  if (!(value = svgNode.transform.baseVal.consolidate())) return identity$2;\n  value = value.matrix;\n  return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n}\n\nfunction interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n  function pop(s) {\n    return s.length ? s.pop() + \" \" : \"\";\n  }\n\n  function translate(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n      q.push({i: i - 4, x: reinterpolate(xa, xb)}, {i: i - 2, x: reinterpolate(ya, yb)});\n    } else if (xb || yb) {\n      s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n    }\n  }\n\n  function rotate(a, b, s, q) {\n    if (a !== b) {\n      if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n      q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: reinterpolate(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"rotate(\" + b + degParen);\n    }\n  }\n\n  function skewX(a, b, s, q) {\n    if (a !== b) {\n      q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: reinterpolate(a, b)});\n    } else if (b) {\n      s.push(pop(s) + \"skewX(\" + b + degParen);\n    }\n  }\n\n  function scale(xa, ya, xb, yb, s, q) {\n    if (xa !== xb || ya !== yb) {\n      var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n      q.push({i: i - 4, x: reinterpolate(xa, xb)}, {i: i - 2, x: reinterpolate(ya, yb)});\n    } else if (xb !== 1 || yb !== 1) {\n      s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n    }\n  }\n\n  return function(a, b) {\n    var s = [], // string constants and placeholders\n        q = []; // number interpolators\n    a = parse(a), b = parse(b);\n    translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n    rotate(a.rotate, b.rotate, s, q);\n    skewX(a.skewX, b.skewX, s, q);\n    scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n    a = b = null; // gc\n    return function(t) {\n      var i = -1, n = q.length, o;\n      while (++i < n) s[(o = q[i]).i] = o.x(t);\n      return s.join(\"\");\n    };\n  };\n}\n\nvar interpolateTransformCss = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\nvar interpolateTransformSvg = interpolateTransform(parseSvg, \", \", \")\", \")\");\n\nvar rho = Math.SQRT2;\nvar rho2 = 2;\nvar rho4 = 4;\nvar epsilon2 = 1e-12;\n\nfunction cosh(x) {\n  return ((x = Math.exp(x)) + 1 / x) / 2;\n}\n\nfunction sinh(x) {\n  return ((x = Math.exp(x)) - 1 / x) / 2;\n}\n\nfunction tanh(x) {\n  return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n}\n\n// p0 = [ux0, uy0, w0]\n// p1 = [ux1, uy1, w1]\nvar interpolateZoom = function(p0, p1) {\n  var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],\n      ux1 = p1[0], uy1 = p1[1], w1 = p1[2],\n      dx = ux1 - ux0,\n      dy = uy1 - uy0,\n      d2 = dx * dx + dy * dy,\n      i,\n      S;\n\n  // Special case for u0 ≅ u1.\n  if (d2 < epsilon2) {\n    S = Math.log(w1 / w0) / rho;\n    i = function(t) {\n      return [\n        ux0 + t * dx,\n        uy0 + t * dy,\n        w0 * Math.exp(rho * t * S)\n      ];\n    };\n  }\n\n  // General case.\n  else {\n    var d1 = Math.sqrt(d2),\n        b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),\n        b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),\n        r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),\n        r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n    S = (r1 - r0) / rho;\n    i = function(t) {\n      var s = t * S,\n          coshr0 = cosh(r0),\n          u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));\n      return [\n        ux0 + u * dx,\n        uy0 + u * dy,\n        w0 * coshr0 / cosh(rho * s + r0)\n      ];\n    };\n  }\n\n  i.duration = S * 1000;\n\n  return i;\n};\n\nfunction hsl$1(hue$$1) {\n  return function(start, end) {\n    var h = hue$$1((start = hsl(start)).h, (end = hsl(end)).h),\n        s = nogamma(start.s, end.s),\n        l = nogamma(start.l, end.l),\n        opacity = nogamma(start.opacity, end.opacity);\n    return function(t) {\n      start.h = h(t);\n      start.s = s(t);\n      start.l = l(t);\n      start.opacity = opacity(t);\n      return start + \"\";\n    };\n  }\n}\n\nvar hsl$2 = hsl$1(hue);\nvar hslLong = hsl$1(nogamma);\n\nfunction lab$1(start, end) {\n  var l = nogamma((start = lab(start)).l, (end = lab(end)).l),\n      a = nogamma(start.a, end.a),\n      b = nogamma(start.b, end.b),\n      opacity = nogamma(start.opacity, end.opacity);\n  return function(t) {\n    start.l = l(t);\n    start.a = a(t);\n    start.b = b(t);\n    start.opacity = opacity(t);\n    return start + \"\";\n  };\n}\n\nfunction hcl$1(hue$$1) {\n  return function(start, end) {\n    var h = hue$$1((start = hcl(start)).h, (end = hcl(end)).h),\n        c = nogamma(start.c, end.c),\n        l = nogamma(start.l, end.l),\n        opacity = nogamma(start.opacity, end.opacity);\n    return function(t) {\n      start.h = h(t);\n      start.c = c(t);\n      start.l = l(t);\n      start.opacity = opacity(t);\n      return start + \"\";\n    };\n  }\n}\n\nvar hcl$2 = hcl$1(hue);\nvar hclLong = hcl$1(nogamma);\n\nfunction cubehelix$1(hue$$1) {\n  return (function cubehelixGamma(y) {\n    y = +y;\n\n    function cubehelix$$1(start, end) {\n      var h = hue$$1((start = cubehelix(start)).h, (end = cubehelix(end)).h),\n          s = nogamma(start.s, end.s),\n          l = nogamma(start.l, end.l),\n          opacity = nogamma(start.opacity, end.opacity);\n      return function(t) {\n        start.h = h(t);\n        start.s = s(t);\n        start.l = l(Math.pow(t, y));\n        start.opacity = opacity(t);\n        return start + \"\";\n      };\n    }\n\n    cubehelix$$1.gamma = cubehelixGamma;\n\n    return cubehelix$$1;\n  })(1);\n}\n\nvar cubehelix$2 = cubehelix$1(hue);\nvar cubehelixLong = cubehelix$1(nogamma);\n\nvar quantize = function(interpolator, n) {\n  var samples = new Array(n);\n  for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));\n  return samples;\n};\n\nvar frame = 0;\nvar timeout = 0;\nvar interval = 0;\nvar pokeDelay = 1000;\nvar taskHead;\nvar taskTail;\nvar clockLast = 0;\nvar clockNow = 0;\nvar clockSkew = 0;\nvar clock = typeof performance === \"object\" && performance.now ? performance : Date;\nvar setFrame = typeof requestAnimationFrame === \"function\" ? requestAnimationFrame : function(f) { setTimeout(f, 17); };\n\nfunction now() {\n  return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n  clockNow = 0;\n}\n\nfunction Timer() {\n  this._call =\n  this._time =\n  this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n  constructor: Timer,\n  restart: function(callback, delay, time) {\n    if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n    time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n    if (!this._next && taskTail !== this) {\n      if (taskTail) taskTail._next = this;\n      else taskHead = this;\n      taskTail = this;\n    }\n    this._call = callback;\n    this._time = time;\n    sleep();\n  },\n  stop: function() {\n    if (this._call) {\n      this._call = null;\n      this._time = Infinity;\n      sleep();\n    }\n  }\n};\n\nfunction timer(callback, delay, time) {\n  var t = new Timer;\n  t.restart(callback, delay, time);\n  return t;\n}\n\nfunction timerFlush() {\n  now(); // Get the current time, if not already set.\n  ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n  var t = taskHead, e;\n  while (t) {\n    if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n    t = t._next;\n  }\n  --frame;\n}\n\nfunction wake() {\n  clockNow = (clockLast = clock.now()) + clockSkew;\n  frame = timeout = 0;\n  try {\n    timerFlush();\n  } finally {\n    frame = 0;\n    nap();\n    clockNow = 0;\n  }\n}\n\nfunction poke() {\n  var now = clock.now(), delay = now - clockLast;\n  if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n  var t0, t1 = taskHead, t2, time = Infinity;\n  while (t1) {\n    if (t1._call) {\n      if (time > t1._time) time = t1._time;\n      t0 = t1, t1 = t1._next;\n    } else {\n      t2 = t1._next, t1._next = null;\n      t1 = t0 ? t0._next = t2 : taskHead = t2;\n    }\n  }\n  taskTail = t0;\n  sleep(time);\n}\n\nfunction sleep(time) {\n  if (frame) return; // Soonest alarm already set, or will be.\n  if (timeout) timeout = clearTimeout(timeout);\n  var delay = time - clockNow;\n  if (delay > 24) {\n    if (time < Infinity) timeout = setTimeout(wake, delay);\n    if (interval) interval = clearInterval(interval);\n  } else {\n    if (!interval) clockLast = clockNow, interval = setInterval(poke, pokeDelay);\n    frame = 1, setFrame(wake);\n  }\n}\n\nvar timeout$1 = function(callback, delay, time) {\n  var t = new Timer;\n  delay = delay == null ? 0 : +delay;\n  t.restart(function(elapsed) {\n    t.stop();\n    callback(elapsed + delay);\n  }, delay, time);\n  return t;\n};\n\nvar interval$1 = function(callback, delay, time) {\n  var t = new Timer, total = delay;\n  if (delay == null) return t.restart(callback, delay, time), t;\n  delay = +delay, time = time == null ? now() : +time;\n  t.restart(function tick(elapsed) {\n    elapsed += total;\n    t.restart(tick, total += delay, time);\n    callback(elapsed);\n  }, delay, time);\n  return t;\n};\n\nvar emptyOn = dispatch(\"start\", \"end\", \"interrupt\");\nvar emptyTween = [];\n\nvar CREATED = 0;\nvar SCHEDULED = 1;\nvar STARTING = 2;\nvar STARTED = 3;\nvar RUNNING = 4;\nvar ENDING = 5;\nvar ENDED = 6;\n\nvar schedule = function(node, name, id, index, group, timing) {\n  var schedules = node.__transition;\n  if (!schedules) node.__transition = {};\n  else if (id in schedules) return;\n  create(node, id, {\n    name: name,\n    index: index, // For context during callback.\n    group: group, // For context during callback.\n    on: emptyOn,\n    tween: emptyTween,\n    time: timing.time,\n    delay: timing.delay,\n    duration: timing.duration,\n    ease: timing.ease,\n    timer: null,\n    state: CREATED\n  });\n};\n\nfunction init(node, id) {\n  var schedule = node.__transition;\n  if (!schedule || !(schedule = schedule[id]) || schedule.state > CREATED) throw new Error(\"too late\");\n  return schedule;\n}\n\nfunction set$1(node, id) {\n  var schedule = node.__transition;\n  if (!schedule || !(schedule = schedule[id]) || schedule.state > STARTING) throw new Error(\"too late\");\n  return schedule;\n}\n\nfunction get$1(node, id) {\n  var schedule = node.__transition;\n  if (!schedule || !(schedule = schedule[id])) throw new Error(\"too late\");\n  return schedule;\n}\n\nfunction create(node, id, self) {\n  var schedules = node.__transition,\n      tween;\n\n  // Initialize the self timer when the transition is created.\n  // Note the actual delay is not known until the first callback!\n  schedules[id] = self;\n  self.timer = timer(schedule, 0, self.time);\n\n  function schedule(elapsed) {\n    self.state = SCHEDULED;\n    self.timer.restart(start, self.delay, self.time);\n\n    // If the elapsed delay is less than our first sleep, start immediately.\n    if (self.delay <= elapsed) start(elapsed - self.delay);\n  }\n\n  function start(elapsed) {\n    var i, j, n, o;\n\n    // If the state is not SCHEDULED, then we previously errored on start.\n    if (self.state !== SCHEDULED) return stop();\n\n    for (i in schedules) {\n      o = schedules[i];\n      if (o.name !== self.name) continue;\n\n      // While this element already has a starting transition during this frame,\n      // defer starting an interrupting transition until that transition has a\n      // chance to tick (and possibly end); see d3/d3-transition#54!\n      if (o.state === STARTED) return timeout$1(start);\n\n      // Interrupt the active transition, if any.\n      // Dispatch the interrupt event.\n      if (o.state === RUNNING) {\n        o.state = ENDED;\n        o.timer.stop();\n        o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n        delete schedules[i];\n      }\n\n      // Cancel any pre-empted transitions. No interrupt event is dispatched\n      // because the cancelled transitions never started. Note that this also\n      // removes this transition from the pending list!\n      else if (+i < id) {\n        o.state = ENDED;\n        o.timer.stop();\n        delete schedules[i];\n      }\n    }\n\n    // Defer the first tick to end of the current frame; see d3/d3#1576.\n    // Note the transition may be canceled after start and before the first tick!\n    // Note this must be scheduled before the start event; see d3/d3-transition#16!\n    // Assuming this is successful, subsequent callbacks go straight to tick.\n    timeout$1(function() {\n      if (self.state === STARTED) {\n        self.state = RUNNING;\n        self.timer.restart(tick, self.delay, self.time);\n        tick(elapsed);\n      }\n    });\n\n    // Dispatch the start event.\n    // Note this must be done before the tween are initialized.\n    self.state = STARTING;\n    self.on.call(\"start\", node, node.__data__, self.index, self.group);\n    if (self.state !== STARTING) return; // interrupted\n    self.state = STARTED;\n\n    // Initialize the tween, deleting null tween.\n    tween = new Array(n = self.tween.length);\n    for (i = 0, j = -1; i < n; ++i) {\n      if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n        tween[++j] = o;\n      }\n    }\n    tween.length = j + 1;\n  }\n\n  function tick(elapsed) {\n    var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),\n        i = -1,\n        n = tween.length;\n\n    while (++i < n) {\n      tween[i].call(null, t);\n    }\n\n    // Dispatch the end event.\n    if (self.state === ENDING) {\n      self.on.call(\"end\", node, node.__data__, self.index, self.group);\n      stop();\n    }\n  }\n\n  function stop() {\n    self.state = ENDED;\n    self.timer.stop();\n    delete schedules[id];\n    for (var i in schedules) return; // eslint-disable-line no-unused-vars\n    delete node.__transition;\n  }\n}\n\nvar interrupt = function(node, name) {\n  var schedules = node.__transition,\n      schedule,\n      active,\n      empty = true,\n      i;\n\n  if (!schedules) return;\n\n  name = name == null ? null : name + \"\";\n\n  for (i in schedules) {\n    if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n    active = schedule.state > STARTING && schedule.state < ENDING;\n    schedule.state = ENDED;\n    schedule.timer.stop();\n    if (active) schedule.on.call(\"interrupt\", node, node.__data__, schedule.index, schedule.group);\n    delete schedules[i];\n  }\n\n  if (empty) delete node.__transition;\n};\n\nvar selection_interrupt = function(name) {\n  return this.each(function() {\n    interrupt(this, name);\n  });\n};\n\nfunction tweenRemove(id, name) {\n  var tween0, tween1;\n  return function() {\n    var schedule = set$1(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = tween0 = tween;\n      for (var i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1 = tween1.slice();\n          tween1.splice(i, 1);\n          break;\n        }\n      }\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nfunction tweenFunction(id, name, value) {\n  var tween0, tween1;\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    var schedule = set$1(this, id),\n        tween = schedule.tween;\n\n    // If this node shared tween with the previous node,\n    // just assign the updated shared tween and we’re done!\n    // Otherwise, copy-on-write.\n    if (tween !== tween0) {\n      tween1 = (tween0 = tween).slice();\n      for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n        if (tween1[i].name === name) {\n          tween1[i] = t;\n          break;\n        }\n      }\n      if (i === n) tween1.push(t);\n    }\n\n    schedule.tween = tween1;\n  };\n}\n\nvar transition_tween = function(name, value) {\n  var id = this._id;\n\n  name += \"\";\n\n  if (arguments.length < 2) {\n    var tween = get$1(this.node(), id).tween;\n    for (var i = 0, n = tween.length, t; i < n; ++i) {\n      if ((t = tween[i]).name === name) {\n        return t.value;\n      }\n    }\n    return null;\n  }\n\n  return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n};\n\nfunction tweenValue(transition, name, value) {\n  var id = transition._id;\n\n  transition.each(function() {\n    var schedule = set$1(this, id);\n    (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n  });\n\n  return function(node) {\n    return get$1(node, id).value[name];\n  };\n}\n\nvar interpolate$$1 = function(a, b) {\n  var c;\n  return (typeof b === \"number\" ? reinterpolate\n      : b instanceof color ? interpolateRgb\n      : (c = color(b)) ? (b = c, interpolateRgb)\n      : interpolateString)(a, b);\n};\n\nfunction attrRemove$1(name) {\n  return function() {\n    this.removeAttribute(name);\n  };\n}\n\nfunction attrRemoveNS$1(fullname) {\n  return function() {\n    this.removeAttributeNS(fullname.space, fullname.local);\n  };\n}\n\nfunction attrConstant$1(name, interpolate$$1, value1) {\n  var value00,\n      interpolate0;\n  return function() {\n    var value0 = this.getAttribute(name);\n    return value0 === value1 ? null\n        : value0 === value00 ? interpolate0\n        : interpolate0 = interpolate$$1(value00 = value0, value1);\n  };\n}\n\nfunction attrConstantNS$1(fullname, interpolate$$1, value1) {\n  var value00,\n      interpolate0;\n  return function() {\n    var value0 = this.getAttributeNS(fullname.space, fullname.local);\n    return value0 === value1 ? null\n        : value0 === value00 ? interpolate0\n        : interpolate0 = interpolate$$1(value00 = value0, value1);\n  };\n}\n\nfunction attrFunction$1(name, interpolate$$1, value) {\n  var value00,\n      value10,\n      interpolate0;\n  return function() {\n    var value0, value1 = value(this);\n    if (value1 == null) return void this.removeAttribute(name);\n    value0 = this.getAttribute(name);\n    return value0 === value1 ? null\n        : value0 === value00 && value1 === value10 ? interpolate0\n        : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);\n  };\n}\n\nfunction attrFunctionNS$1(fullname, interpolate$$1, value) {\n  var value00,\n      value10,\n      interpolate0;\n  return function() {\n    var value0, value1 = value(this);\n    if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n    value0 = this.getAttributeNS(fullname.space, fullname.local);\n    return value0 === value1 ? null\n        : value0 === value00 && value1 === value10 ? interpolate0\n        : interpolate0 = interpolate$$1(value00 = value0, value10 = value1);\n  };\n}\n\nvar transition_attr = function(name, value) {\n  var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransformSvg : interpolate$$1;\n  return this.attrTween(name, typeof value === \"function\"\n      ? (fullname.local ? attrFunctionNS$1 : attrFunction$1)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n      : value == null ? (fullname.local ? attrRemoveNS$1 : attrRemove$1)(fullname)\n      : (fullname.local ? attrConstantNS$1 : attrConstant$1)(fullname, i, value + \"\"));\n};\n\nfunction attrTweenNS(fullname, value) {\n  function tween() {\n    var node = this, i = value.apply(node, arguments);\n    return i && function(t) {\n      node.setAttributeNS(fullname.space, fullname.local, i(t));\n    };\n  }\n  tween._value = value;\n  return tween;\n}\n\nfunction attrTween(name, value) {\n  function tween() {\n    var node = this, i = value.apply(node, arguments);\n    return i && function(t) {\n      node.setAttribute(name, i(t));\n    };\n  }\n  tween._value = value;\n  return tween;\n}\n\nvar transition_attrTween = function(name, value) {\n  var key = \"attr.\" + name;\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  var fullname = namespace(name);\n  return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n};\n\nfunction delayFunction(id, value) {\n  return function() {\n    init(this, id).delay = +value.apply(this, arguments);\n  };\n}\n\nfunction delayConstant(id, value) {\n  return value = +value, function() {\n    init(this, id).delay = value;\n  };\n}\n\nvar transition_delay = function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? delayFunction\n          : delayConstant)(id, value))\n      : get$1(this.node(), id).delay;\n};\n\nfunction durationFunction(id, value) {\n  return function() {\n    set$1(this, id).duration = +value.apply(this, arguments);\n  };\n}\n\nfunction durationConstant(id, value) {\n  return value = +value, function() {\n    set$1(this, id).duration = value;\n  };\n}\n\nvar transition_duration = function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each((typeof value === \"function\"\n          ? durationFunction\n          : durationConstant)(id, value))\n      : get$1(this.node(), id).duration;\n};\n\nfunction easeConstant(id, value) {\n  if (typeof value !== \"function\") throw new Error;\n  return function() {\n    set$1(this, id).ease = value;\n  };\n}\n\nvar transition_ease = function(value) {\n  var id = this._id;\n\n  return arguments.length\n      ? this.each(easeConstant(id, value))\n      : get$1(this.node(), id).ease;\n};\n\nvar transition_filter = function(match) {\n  if (typeof match !== \"function\") match = matcher$1(match);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n      if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n        subgroup.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, this._name, this._id);\n};\n\nvar transition_merge = function(transition) {\n  if (transition._id !== this._id) throw new Error;\n\n  for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n    for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n      if (node = group0[i] || group1[i]) {\n        merge[i] = node;\n      }\n    }\n  }\n\n  for (; j < m0; ++j) {\n    merges[j] = groups0[j];\n  }\n\n  return new Transition(merges, this._parents, this._name, this._id);\n};\n\nfunction start(name) {\n  return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n    var i = t.indexOf(\".\");\n    if (i >= 0) t = t.slice(0, i);\n    return !t || t === \"start\";\n  });\n}\n\nfunction onFunction(id, name, listener) {\n  var on0, on1, sit = start(name) ? init : set$1;\n  return function() {\n    var schedule = sit(this, id),\n        on = schedule.on;\n\n    // If this node shared a dispatch with the previous node,\n    // just assign the updated shared dispatch and we’re done!\n    // Otherwise, copy-on-write.\n    if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n    schedule.on = on1;\n  };\n}\n\nvar transition_on = function(name, listener) {\n  var id = this._id;\n\n  return arguments.length < 2\n      ? get$1(this.node(), id).on.on(name)\n      : this.each(onFunction(id, name, listener));\n};\n\nfunction removeFunction(id) {\n  return function() {\n    var parent = this.parentNode;\n    for (var i in this.__transition) if (+i !== id) return;\n    if (parent) parent.removeChild(this);\n  };\n}\n\nvar transition_remove = function() {\n  return this.on(\"end.remove\", removeFunction(this._id));\n};\n\nvar transition_select = function(select$$1) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select$$1 !== \"function\") select$$1 = selector(select$$1);\n\n  for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n      if ((node = group[i]) && (subnode = select$$1.call(node, node.__data__, i, group))) {\n        if (\"__data__\" in node) subnode.__data__ = node.__data__;\n        subgroup[i] = subnode;\n        schedule(subgroup[i], name, id, i, subgroup, get$1(node, id));\n      }\n    }\n  }\n\n  return new Transition(subgroups, this._parents, name, id);\n};\n\nvar transition_selectAll = function(select$$1) {\n  var name = this._name,\n      id = this._id;\n\n  if (typeof select$$1 !== \"function\") select$$1 = selectorAll(select$$1);\n\n  for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        for (var children = select$$1.call(node, node.__data__, i, group), child, inherit = get$1(node, id), k = 0, l = children.length; k < l; ++k) {\n          if (child = children[k]) {\n            schedule(child, name, id, k, children, inherit);\n          }\n        }\n        subgroups.push(children);\n        parents.push(node);\n      }\n    }\n  }\n\n  return new Transition(subgroups, parents, name, id);\n};\n\nvar Selection$1 = selection.prototype.constructor;\n\nvar transition_selection = function() {\n  return new Selection$1(this._groups, this._parents);\n};\n\nfunction styleRemove$1(name, interpolate$$2) {\n  var value00,\n      value10,\n      interpolate0;\n  return function() {\n    var value0 = styleValue(this, name),\n        value1 = (this.style.removeProperty(name), styleValue(this, name));\n    return value0 === value1 ? null\n        : value0 === value00 && value1 === value10 ? interpolate0\n        : interpolate0 = interpolate$$2(value00 = value0, value10 = value1);\n  };\n}\n\nfunction styleRemoveEnd(name) {\n  return function() {\n    this.style.removeProperty(name);\n  };\n}\n\nfunction styleConstant$1(name, interpolate$$2, value1) {\n  var value00,\n      interpolate0;\n  return function() {\n    var value0 = styleValue(this, name);\n    return value0 === value1 ? null\n        : value0 === value00 ? interpolate0\n        : interpolate0 = interpolate$$2(value00 = value0, value1);\n  };\n}\n\nfunction styleFunction$1(name, interpolate$$2, value) {\n  var value00,\n      value10,\n      interpolate0;\n  return function() {\n    var value0 = styleValue(this, name),\n        value1 = value(this);\n    if (value1 == null) value1 = (this.style.removeProperty(name), styleValue(this, name));\n    return value0 === value1 ? null\n        : value0 === value00 && value1 === value10 ? interpolate0\n        : interpolate0 = interpolate$$2(value00 = value0, value10 = value1);\n  };\n}\n\nvar transition_style = function(name, value, priority) {\n  var i = (name += \"\") === \"transform\" ? interpolateTransformCss : interpolate$$1;\n  return value == null ? this\n          .styleTween(name, styleRemove$1(name, i))\n          .on(\"end.style.\" + name, styleRemoveEnd(name))\n      : this.styleTween(name, typeof value === \"function\"\n          ? styleFunction$1(name, i, tweenValue(this, \"style.\" + name, value))\n          : styleConstant$1(name, i, value + \"\"), priority);\n};\n\nfunction styleTween(name, value, priority) {\n  function tween() {\n    var node = this, i = value.apply(node, arguments);\n    return i && function(t) {\n      node.style.setProperty(name, i(t), priority);\n    };\n  }\n  tween._value = value;\n  return tween;\n}\n\nvar transition_styleTween = function(name, value, priority) {\n  var key = \"style.\" + (name += \"\");\n  if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n  if (value == null) return this.tween(key, null);\n  if (typeof value !== \"function\") throw new Error;\n  return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n};\n\nfunction textConstant$1(value) {\n  return function() {\n    this.textContent = value;\n  };\n}\n\nfunction textFunction$1(value) {\n  return function() {\n    var value1 = value(this);\n    this.textContent = value1 == null ? \"\" : value1;\n  };\n}\n\nvar transition_text = function(value) {\n  return this.tween(\"text\", typeof value === \"function\"\n      ? textFunction$1(tweenValue(this, \"text\", value))\n      : textConstant$1(value == null ? \"\" : value + \"\"));\n};\n\nvar transition_transition = function() {\n  var name = this._name,\n      id0 = this._id,\n      id1 = newId();\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        var inherit = get$1(node, id0);\n        schedule(node, name, id1, i, group, {\n          time: inherit.time + inherit.delay + inherit.duration,\n          delay: 0,\n          duration: inherit.duration,\n          ease: inherit.ease\n        });\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id1);\n};\n\nvar id = 0;\n\nfunction Transition(groups, parents, name, id) {\n  this._groups = groups;\n  this._parents = parents;\n  this._name = name;\n  this._id = id;\n}\n\nfunction transition(name) {\n  return selection().transition(name);\n}\n\nfunction newId() {\n  return ++id;\n}\n\nvar selection_prototype = selection.prototype;\n\nTransition.prototype = transition.prototype = {\n  constructor: Transition,\n  select: transition_select,\n  selectAll: transition_selectAll,\n  filter: transition_filter,\n  merge: transition_merge,\n  selection: transition_selection,\n  transition: transition_transition,\n  call: selection_prototype.call,\n  nodes: selection_prototype.nodes,\n  node: selection_prototype.node,\n  size: selection_prototype.size,\n  empty: selection_prototype.empty,\n  each: selection_prototype.each,\n  on: transition_on,\n  attr: transition_attr,\n  attrTween: transition_attrTween,\n  style: transition_style,\n  styleTween: transition_styleTween,\n  text: transition_text,\n  remove: transition_remove,\n  tween: transition_tween,\n  delay: transition_delay,\n  duration: transition_duration,\n  ease: transition_ease\n};\n\nfunction linear$1(t) {\n  return +t;\n}\n\nfunction quadIn(t) {\n  return t * t;\n}\n\nfunction quadOut(t) {\n  return t * (2 - t);\n}\n\nfunction quadInOut(t) {\n  return ((t *= 2) <= 1 ? t * t : --t * (2 - t) + 1) / 2;\n}\n\nfunction cubicIn(t) {\n  return t * t * t;\n}\n\nfunction cubicOut(t) {\n  return --t * t * t + 1;\n}\n\nfunction cubicInOut(t) {\n  return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n\nvar exponent = 3;\n\nvar polyIn = (function custom(e) {\n  e = +e;\n\n  function polyIn(t) {\n    return Math.pow(t, e);\n  }\n\n  polyIn.exponent = custom;\n\n  return polyIn;\n})(exponent);\n\nvar polyOut = (function custom(e) {\n  e = +e;\n\n  function polyOut(t) {\n    return 1 - Math.pow(1 - t, e);\n  }\n\n  polyOut.exponent = custom;\n\n  return polyOut;\n})(exponent);\n\nvar polyInOut = (function custom(e) {\n  e = +e;\n\n  function polyInOut(t) {\n    return ((t *= 2) <= 1 ? Math.pow(t, e) : 2 - Math.pow(2 - t, e)) / 2;\n  }\n\n  polyInOut.exponent = custom;\n\n  return polyInOut;\n})(exponent);\n\nvar pi = Math.PI;\nvar halfPi = pi / 2;\n\nfunction sinIn(t) {\n  return 1 - Math.cos(t * halfPi);\n}\n\nfunction sinOut(t) {\n  return Math.sin(t * halfPi);\n}\n\nfunction sinInOut(t) {\n  return (1 - Math.cos(pi * t)) / 2;\n}\n\nfunction expIn(t) {\n  return Math.pow(2, 10 * t - 10);\n}\n\nfunction expOut(t) {\n  return 1 - Math.pow(2, -10 * t);\n}\n\nfunction expInOut(t) {\n  return ((t *= 2) <= 1 ? Math.pow(2, 10 * t - 10) : 2 - Math.pow(2, 10 - 10 * t)) / 2;\n}\n\nfunction circleIn(t) {\n  return 1 - Math.sqrt(1 - t * t);\n}\n\nfunction circleOut(t) {\n  return Math.sqrt(1 - --t * t);\n}\n\nfunction circleInOut(t) {\n  return ((t *= 2) <= 1 ? 1 - Math.sqrt(1 - t * t) : Math.sqrt(1 - (t -= 2) * t) + 1) / 2;\n}\n\nvar b1 = 4 / 11;\nvar b2 = 6 / 11;\nvar b3 = 8 / 11;\nvar b4 = 3 / 4;\nvar b5 = 9 / 11;\nvar b6 = 10 / 11;\nvar b7 = 15 / 16;\nvar b8 = 21 / 22;\nvar b9 = 63 / 64;\nvar b0 = 1 / b1 / b1;\n\nfunction bounceIn(t) {\n  return 1 - bounceOut(1 - t);\n}\n\nfunction bounceOut(t) {\n  return (t = +t) < b1 ? b0 * t * t : t < b3 ? b0 * (t -= b2) * t + b4 : t < b6 ? b0 * (t -= b5) * t + b7 : b0 * (t -= b8) * t + b9;\n}\n\nfunction bounceInOut(t) {\n  return ((t *= 2) <= 1 ? 1 - bounceOut(1 - t) : bounceOut(t - 1) + 1) / 2;\n}\n\nvar overshoot = 1.70158;\n\nvar backIn = (function custom(s) {\n  s = +s;\n\n  function backIn(t) {\n    return t * t * ((s + 1) * t - s);\n  }\n\n  backIn.overshoot = custom;\n\n  return backIn;\n})(overshoot);\n\nvar backOut = (function custom(s) {\n  s = +s;\n\n  function backOut(t) {\n    return --t * t * ((s + 1) * t + s) + 1;\n  }\n\n  backOut.overshoot = custom;\n\n  return backOut;\n})(overshoot);\n\nvar backInOut = (function custom(s) {\n  s = +s;\n\n  function backInOut(t) {\n    return ((t *= 2) < 1 ? t * t * ((s + 1) * t - s) : (t -= 2) * t * ((s + 1) * t + s) + 2) / 2;\n  }\n\n  backInOut.overshoot = custom;\n\n  return backInOut;\n})(overshoot);\n\nvar tau = 2 * Math.PI;\nvar amplitude = 1;\nvar period = 0.3;\n\nvar elasticIn = (function custom(a, p) {\n  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n  function elasticIn(t) {\n    return a * Math.pow(2, 10 * --t) * Math.sin((s - t) / p);\n  }\n\n  elasticIn.amplitude = function(a) { return custom(a, p * tau); };\n  elasticIn.period = function(p) { return custom(a, p); };\n\n  return elasticIn;\n})(amplitude, period);\n\nvar elasticOut = (function custom(a, p) {\n  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n  function elasticOut(t) {\n    return 1 - a * Math.pow(2, -10 * (t = +t)) * Math.sin((t + s) / p);\n  }\n\n  elasticOut.amplitude = function(a) { return custom(a, p * tau); };\n  elasticOut.period = function(p) { return custom(a, p); };\n\n  return elasticOut;\n})(amplitude, period);\n\nvar elasticInOut = (function custom(a, p) {\n  var s = Math.asin(1 / (a = Math.max(1, a))) * (p /= tau);\n\n  function elasticInOut(t) {\n    return ((t = t * 2 - 1) < 0\n        ? a * Math.pow(2, 10 * t) * Math.sin((s - t) / p)\n        : 2 - a * Math.pow(2, -10 * t) * Math.sin((s + t) / p)) / 2;\n  }\n\n  elasticInOut.amplitude = function(a) { return custom(a, p * tau); };\n  elasticInOut.period = function(p) { return custom(a, p); };\n\n  return elasticInOut;\n})(amplitude, period);\n\nvar defaultTiming = {\n  time: null, // Set on use.\n  delay: 0,\n  duration: 250,\n  ease: cubicInOut\n};\n\nfunction inherit(node, id) {\n  var timing;\n  while (!(timing = node.__transition) || !(timing = timing[id])) {\n    if (!(node = node.parentNode)) {\n      return defaultTiming.time = now(), defaultTiming;\n    }\n  }\n  return timing;\n}\n\nvar selection_transition = function(name) {\n  var id,\n      timing;\n\n  if (name instanceof Transition) {\n    id = name._id, name = name._name;\n  } else {\n    id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n  }\n\n  for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n    for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n      if (node = group[i]) {\n        schedule(node, name, id, i, group, timing || inherit(node, id));\n      }\n    }\n  }\n\n  return new Transition(groups, this._parents, name, id);\n};\n\nselection.prototype.interrupt = selection_interrupt;\nselection.prototype.transition = selection_transition;\n\nvar root$1 = [null];\n\nvar active = function(node, name) {\n  var schedules = node.__transition,\n      schedule,\n      i;\n\n  if (schedules) {\n    name = name == null ? null : name + \"\";\n    for (i in schedules) {\n      if ((schedule = schedules[i]).state > SCHEDULED && schedule.name === name) {\n        return new Transition([[node]], root$1, name, +i);\n      }\n    }\n  }\n\n  return null;\n};\n\nvar constant$4 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar BrushEvent = function(target, type, selection) {\n  this.target = target;\n  this.type = type;\n  this.selection = selection;\n};\n\nfunction nopropagation$1() {\n  exports.event.stopImmediatePropagation();\n}\n\nvar noevent$1 = function() {\n  exports.event.preventDefault();\n  exports.event.stopImmediatePropagation();\n};\n\nvar MODE_DRAG = {name: \"drag\"};\nvar MODE_SPACE = {name: \"space\"};\nvar MODE_HANDLE = {name: \"handle\"};\nvar MODE_CENTER = {name: \"center\"};\n\nvar X = {\n  name: \"x\",\n  handles: [\"e\", \"w\"].map(type),\n  input: function(x, e) { return x && [[x[0], e[0][1]], [x[1], e[1][1]]]; },\n  output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }\n};\n\nvar Y = {\n  name: \"y\",\n  handles: [\"n\", \"s\"].map(type),\n  input: function(y, e) { return y && [[e[0][0], y[0]], [e[1][0], y[1]]]; },\n  output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }\n};\n\nvar XY = {\n  name: \"xy\",\n  handles: [\"n\", \"e\", \"s\", \"w\", \"nw\", \"ne\", \"se\", \"sw\"].map(type),\n  input: function(xy) { return xy; },\n  output: function(xy) { return xy; }\n};\n\nvar cursors = {\n  overlay: \"crosshair\",\n  selection: \"move\",\n  n: \"ns-resize\",\n  e: \"ew-resize\",\n  s: \"ns-resize\",\n  w: \"ew-resize\",\n  nw: \"nwse-resize\",\n  ne: \"nesw-resize\",\n  se: \"nwse-resize\",\n  sw: \"nesw-resize\"\n};\n\nvar flipX = {\n  e: \"w\",\n  w: \"e\",\n  nw: \"ne\",\n  ne: \"nw\",\n  se: \"sw\",\n  sw: \"se\"\n};\n\nvar flipY = {\n  n: \"s\",\n  s: \"n\",\n  nw: \"sw\",\n  ne: \"se\",\n  se: \"ne\",\n  sw: \"nw\"\n};\n\nvar signsX = {\n  overlay: +1,\n  selection: +1,\n  n: null,\n  e: +1,\n  s: null,\n  w: -1,\n  nw: -1,\n  ne: +1,\n  se: +1,\n  sw: -1\n};\n\nvar signsY = {\n  overlay: +1,\n  selection: +1,\n  n: -1,\n  e: null,\n  s: +1,\n  w: null,\n  nw: -1,\n  ne: -1,\n  se: +1,\n  sw: +1\n};\n\nfunction type(t) {\n  return {type: t};\n}\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter() {\n  return !exports.event.button;\n}\n\nfunction defaultExtent() {\n  var svg = this.ownerSVGElement || this;\n  return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];\n}\n\n// Like d3.local, but with the name “__brush” rather than auto-generated.\nfunction local$$1(node) {\n  while (!node.__brush) if (!(node = node.parentNode)) return;\n  return node.__brush;\n}\n\nfunction empty(extent) {\n  return extent[0][0] === extent[1][0]\n      || extent[0][1] === extent[1][1];\n}\n\nfunction brushSelection(node) {\n  var state = node.__brush;\n  return state ? state.dim.output(state.selection) : null;\n}\n\nfunction brushX() {\n  return brush$1(X);\n}\n\nfunction brushY() {\n  return brush$1(Y);\n}\n\nvar brush = function() {\n  return brush$1(XY);\n};\n\nfunction brush$1(dim) {\n  var extent = defaultExtent,\n      filter = defaultFilter,\n      listeners = dispatch(brush, \"start\", \"brush\", \"end\"),\n      handleSize = 6,\n      touchending;\n\n  function brush(group) {\n    var overlay = group\n        .property(\"__brush\", initialize)\n      .selectAll(\".overlay\")\n      .data([type(\"overlay\")]);\n\n    overlay.enter().append(\"rect\")\n        .attr(\"class\", \"overlay\")\n        .attr(\"pointer-events\", \"all\")\n        .attr(\"cursor\", cursors.overlay)\n      .merge(overlay)\n        .each(function() {\n          var extent = local$$1(this).extent;\n          select(this)\n              .attr(\"x\", extent[0][0])\n              .attr(\"y\", extent[0][1])\n              .attr(\"width\", extent[1][0] - extent[0][0])\n              .attr(\"height\", extent[1][1] - extent[0][1]);\n        });\n\n    group.selectAll(\".selection\")\n      .data([type(\"selection\")])\n      .enter().append(\"rect\")\n        .attr(\"class\", \"selection\")\n        .attr(\"cursor\", cursors.selection)\n        .attr(\"fill\", \"#777\")\n        .attr(\"fill-opacity\", 0.3)\n        .attr(\"stroke\", \"#fff\")\n        .attr(\"shape-rendering\", \"crispEdges\");\n\n    var handle = group.selectAll(\".handle\")\n      .data(dim.handles, function(d) { return d.type; });\n\n    handle.exit().remove();\n\n    handle.enter().append(\"rect\")\n        .attr(\"class\", function(d) { return \"handle handle--\" + d.type; })\n        .attr(\"cursor\", function(d) { return cursors[d.type]; });\n\n    group\n        .each(redraw)\n        .attr(\"fill\", \"none\")\n        .attr(\"pointer-events\", \"all\")\n        .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n        .on(\"mousedown.brush touchstart.brush\", started);\n  }\n\n  brush.move = function(group, selection$$1) {\n    if (group.selection) {\n      group\n          .on(\"start.brush\", function() { emitter(this, arguments).beforestart().start(); })\n          .on(\"interrupt.brush end.brush\", function() { emitter(this, arguments).end(); })\n          .tween(\"brush\", function() {\n            var that = this,\n                state = that.__brush,\n                emit = emitter(that, arguments),\n                selection0 = state.selection,\n                selection1 = dim.input(typeof selection$$1 === \"function\" ? selection$$1.apply(this, arguments) : selection$$1, state.extent),\n                i = interpolateValue(selection0, selection1);\n\n            function tween(t) {\n              state.selection = t === 1 && empty(selection1) ? null : i(t);\n              redraw.call(that);\n              emit.brush();\n            }\n\n            return selection0 && selection1 ? tween : tween(1);\n          });\n    } else {\n      group\n          .each(function() {\n            var that = this,\n                args = arguments,\n                state = that.__brush,\n                selection1 = dim.input(typeof selection$$1 === \"function\" ? selection$$1.apply(that, args) : selection$$1, state.extent),\n                emit = emitter(that, args).beforestart();\n\n            interrupt(that);\n            state.selection = selection1 == null || empty(selection1) ? null : selection1;\n            redraw.call(that);\n            emit.start().brush().end();\n          });\n    }\n  };\n\n  function redraw() {\n    var group = select(this),\n        selection$$1 = local$$1(this).selection;\n\n    if (selection$$1) {\n      group.selectAll(\".selection\")\n          .style(\"display\", null)\n          .attr(\"x\", selection$$1[0][0])\n          .attr(\"y\", selection$$1[0][1])\n          .attr(\"width\", selection$$1[1][0] - selection$$1[0][0])\n          .attr(\"height\", selection$$1[1][1] - selection$$1[0][1]);\n\n      group.selectAll(\".handle\")\n          .style(\"display\", null)\n          .attr(\"x\", function(d) { return d.type[d.type.length - 1] === \"e\" ? selection$$1[1][0] - handleSize / 2 : selection$$1[0][0] - handleSize / 2; })\n          .attr(\"y\", function(d) { return d.type[0] === \"s\" ? selection$$1[1][1] - handleSize / 2 : selection$$1[0][1] - handleSize / 2; })\n          .attr(\"width\", function(d) { return d.type === \"n\" || d.type === \"s\" ? selection$$1[1][0] - selection$$1[0][0] + handleSize : handleSize; })\n          .attr(\"height\", function(d) { return d.type === \"e\" || d.type === \"w\" ? selection$$1[1][1] - selection$$1[0][1] + handleSize : handleSize; });\n    }\n\n    else {\n      group.selectAll(\".selection,.handle\")\n          .style(\"display\", \"none\")\n          .attr(\"x\", null)\n          .attr(\"y\", null)\n          .attr(\"width\", null)\n          .attr(\"height\", null);\n    }\n  }\n\n  function emitter(that, args) {\n    return that.__brush.emitter || new Emitter(that, args);\n  }\n\n  function Emitter(that, args) {\n    this.that = that;\n    this.args = args;\n    this.state = that.__brush;\n    this.active = 0;\n  }\n\n  Emitter.prototype = {\n    beforestart: function() {\n      if (++this.active === 1) this.state.emitter = this, this.starting = true;\n      return this;\n    },\n    start: function() {\n      if (this.starting) this.starting = false, this.emit(\"start\");\n      return this;\n    },\n    brush: function() {\n      this.emit(\"brush\");\n      return this;\n    },\n    end: function() {\n      if (--this.active === 0) delete this.state.emitter, this.emit(\"end\");\n      return this;\n    },\n    emit: function(type) {\n      customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);\n    }\n  };\n\n  function started() {\n    if (exports.event.touches) { if (exports.event.changedTouches.length < exports.event.touches.length) return noevent$1(); }\n    else if (touchending) return;\n    if (!filter.apply(this, arguments)) return;\n\n    var that = this,\n        type = exports.event.target.__data__.type,\n        mode = (exports.event.metaKey ? type = \"overlay\" : type) === \"selection\" ? MODE_DRAG : (exports.event.altKey ? MODE_CENTER : MODE_HANDLE),\n        signX = dim === Y ? null : signsX[type],\n        signY = dim === X ? null : signsY[type],\n        state = local$$1(that),\n        extent = state.extent,\n        selection$$1 = state.selection,\n        W = extent[0][0], w0, w1,\n        N = extent[0][1], n0, n1,\n        E = extent[1][0], e0, e1,\n        S = extent[1][1], s0, s1,\n        dx,\n        dy,\n        moving,\n        shifting = signX && signY && exports.event.shiftKey,\n        lockX,\n        lockY,\n        point0 = mouse(that),\n        point = point0,\n        emit = emitter(that, arguments).beforestart();\n\n    if (type === \"overlay\") {\n      state.selection = selection$$1 = [\n        [w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],\n        [e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]\n      ];\n    } else {\n      w0 = selection$$1[0][0];\n      n0 = selection$$1[0][1];\n      e0 = selection$$1[1][0];\n      s0 = selection$$1[1][1];\n    }\n\n    w1 = w0;\n    n1 = n0;\n    e1 = e0;\n    s1 = s0;\n\n    var group = select(that)\n        .attr(\"pointer-events\", \"none\");\n\n    var overlay = group.selectAll(\".overlay\")\n        .attr(\"cursor\", cursors[type]);\n\n    if (exports.event.touches) {\n      group\n          .on(\"touchmove.brush\", moved, true)\n          .on(\"touchend.brush touchcancel.brush\", ended, true);\n    } else {\n      var view = select(exports.event.view)\n          .on(\"keydown.brush\", keydowned, true)\n          .on(\"keyup.brush\", keyupped, true)\n          .on(\"mousemove.brush\", moved, true)\n          .on(\"mouseup.brush\", ended, true);\n\n      dragDisable(exports.event.view);\n    }\n\n    nopropagation$1();\n    interrupt(that);\n    redraw.call(that);\n    emit.start();\n\n    function moved() {\n      var point1 = mouse(that);\n      if (shifting && !lockX && !lockY) {\n        if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;\n        else lockX = true;\n      }\n      point = point1;\n      moving = true;\n      noevent$1();\n      move();\n    }\n\n    function move() {\n      var t;\n\n      dx = point[0] - point0[0];\n      dy = point[1] - point0[1];\n\n      switch (mode) {\n        case MODE_SPACE:\n        case MODE_DRAG: {\n          if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;\n          if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;\n          break;\n        }\n        case MODE_HANDLE: {\n          if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;\n          else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;\n          if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;\n          else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;\n          break;\n        }\n        case MODE_CENTER: {\n          if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));\n          if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));\n          break;\n        }\n      }\n\n      if (e1 < w1) {\n        signX *= -1;\n        t = w0, w0 = e0, e0 = t;\n        t = w1, w1 = e1, e1 = t;\n        if (type in flipX) overlay.attr(\"cursor\", cursors[type = flipX[type]]);\n      }\n\n      if (s1 < n1) {\n        signY *= -1;\n        t = n0, n0 = s0, s0 = t;\n        t = n1, n1 = s1, s1 = t;\n        if (type in flipY) overlay.attr(\"cursor\", cursors[type = flipY[type]]);\n      }\n\n      if (state.selection) selection$$1 = state.selection; // May be set by brush.move!\n      if (lockX) w1 = selection$$1[0][0], e1 = selection$$1[1][0];\n      if (lockY) n1 = selection$$1[0][1], s1 = selection$$1[1][1];\n\n      if (selection$$1[0][0] !== w1\n          || selection$$1[0][1] !== n1\n          || selection$$1[1][0] !== e1\n          || selection$$1[1][1] !== s1) {\n        state.selection = [[w1, n1], [e1, s1]];\n        redraw.call(that);\n        emit.brush();\n      }\n    }\n\n    function ended() {\n      nopropagation$1();\n      if (exports.event.touches) {\n        if (exports.event.touches.length) return;\n        if (touchending) clearTimeout(touchending);\n        touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n        group.on(\"touchmove.brush touchend.brush touchcancel.brush\", null);\n      } else {\n        yesdrag(exports.event.view, moving);\n        view.on(\"keydown.brush keyup.brush mousemove.brush mouseup.brush\", null);\n      }\n      group.attr(\"pointer-events\", \"all\");\n      overlay.attr(\"cursor\", cursors.overlay);\n      if (state.selection) selection$$1 = state.selection; // May be set by brush.move (on start)!\n      if (empty(selection$$1)) state.selection = null, redraw.call(that);\n      emit.end();\n    }\n\n    function keydowned() {\n      switch (exports.event.keyCode) {\n        case 16: { // SHIFT\n          shifting = signX && signY;\n          break;\n        }\n        case 18: { // ALT\n          if (mode === MODE_HANDLE) {\n            if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n            if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n            mode = MODE_CENTER;\n            move();\n          }\n          break;\n        }\n        case 32: { // SPACE; takes priority over ALT\n          if (mode === MODE_HANDLE || mode === MODE_CENTER) {\n            if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;\n            if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;\n            mode = MODE_SPACE;\n            overlay.attr(\"cursor\", cursors.selection);\n            move();\n          }\n          break;\n        }\n        default: return;\n      }\n      noevent$1();\n    }\n\n    function keyupped() {\n      switch (exports.event.keyCode) {\n        case 16: { // SHIFT\n          if (shifting) {\n            lockX = lockY = shifting = false;\n            move();\n          }\n          break;\n        }\n        case 18: { // ALT\n          if (mode === MODE_CENTER) {\n            if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n            if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n            mode = MODE_HANDLE;\n            move();\n          }\n          break;\n        }\n        case 32: { // SPACE\n          if (mode === MODE_SPACE) {\n            if (exports.event.altKey) {\n              if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n              if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n              mode = MODE_CENTER;\n            } else {\n              if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n              if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n              mode = MODE_HANDLE;\n            }\n            overlay.attr(\"cursor\", cursors[type]);\n            move();\n          }\n          break;\n        }\n        default: return;\n      }\n      noevent$1();\n    }\n  }\n\n  function initialize() {\n    var state = this.__brush || {selection: null};\n    state.extent = extent.apply(this, arguments);\n    state.dim = dim;\n    return state;\n  }\n\n  brush.extent = function(_) {\n    return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$4([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), brush) : extent;\n  };\n\n  brush.filter = function(_) {\n    return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$4(!!_), brush) : filter;\n  };\n\n  brush.handleSize = function(_) {\n    return arguments.length ? (handleSize = +_, brush) : handleSize;\n  };\n\n  brush.on = function() {\n    var value = listeners.on.apply(listeners, arguments);\n    return value === listeners ? brush : value;\n  };\n\n  return brush;\n}\n\nvar cos = Math.cos;\nvar sin = Math.sin;\nvar pi$1 = Math.PI;\nvar halfPi$1 = pi$1 / 2;\nvar tau$1 = pi$1 * 2;\nvar max$1 = Math.max;\n\nfunction compareValue(compare) {\n  return function(a, b) {\n    return compare(\n      a.source.value + a.target.value,\n      b.source.value + b.target.value\n    );\n  };\n}\n\nvar chord = function() {\n  var padAngle = 0,\n      sortGroups = null,\n      sortSubgroups = null,\n      sortChords = null;\n\n  function chord(matrix) {\n    var n = matrix.length,\n        groupSums = [],\n        groupIndex = sequence(n),\n        subgroupIndex = [],\n        chords = [],\n        groups = chords.groups = new Array(n),\n        subgroups = new Array(n * n),\n        k,\n        x,\n        x0,\n        dx,\n        i,\n        j;\n\n    // Compute the sum.\n    k = 0, i = -1; while (++i < n) {\n      x = 0, j = -1; while (++j < n) {\n        x += matrix[i][j];\n      }\n      groupSums.push(x);\n      subgroupIndex.push(sequence(n));\n      k += x;\n    }\n\n    // Sort groups…\n    if (sortGroups) groupIndex.sort(function(a, b) {\n      return sortGroups(groupSums[a], groupSums[b]);\n    });\n\n    // Sort subgroups…\n    if (sortSubgroups) subgroupIndex.forEach(function(d, i) {\n      d.sort(function(a, b) {\n        return sortSubgroups(matrix[i][a], matrix[i][b]);\n      });\n    });\n\n    // Convert the sum to scaling factor for [0, 2pi].\n    // TODO Allow start and end angle to be specified?\n    // TODO Allow padding to be specified as percentage?\n    k = max$1(0, tau$1 - padAngle * n) / k;\n    dx = k ? padAngle : tau$1 / n;\n\n    // Compute the start and end angle for each group and subgroup.\n    // Note: Opera has a bug reordering object literal properties!\n    x = 0, i = -1; while (++i < n) {\n      x0 = x, j = -1; while (++j < n) {\n        var di = groupIndex[i],\n            dj = subgroupIndex[di][j],\n            v = matrix[di][dj],\n            a0 = x,\n            a1 = x += v * k;\n        subgroups[dj * n + di] = {\n          index: di,\n          subindex: dj,\n          startAngle: a0,\n          endAngle: a1,\n          value: v\n        };\n      }\n      groups[di] = {\n        index: di,\n        startAngle: x0,\n        endAngle: x,\n        value: groupSums[di]\n      };\n      x += dx;\n    }\n\n    // Generate chords for each (non-empty) subgroup-subgroup link.\n    i = -1; while (++i < n) {\n      j = i - 1; while (++j < n) {\n        var source = subgroups[j * n + i],\n            target = subgroups[i * n + j];\n        if (source.value || target.value) {\n          chords.push(source.value < target.value\n              ? {source: target, target: source}\n              : {source: source, target: target});\n        }\n      }\n    }\n\n    return sortChords ? chords.sort(sortChords) : chords;\n  }\n\n  chord.padAngle = function(_) {\n    return arguments.length ? (padAngle = max$1(0, _), chord) : padAngle;\n  };\n\n  chord.sortGroups = function(_) {\n    return arguments.length ? (sortGroups = _, chord) : sortGroups;\n  };\n\n  chord.sortSubgroups = function(_) {\n    return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;\n  };\n\n  chord.sortChords = function(_) {\n    return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;\n  };\n\n  return chord;\n};\n\nvar slice$2 = Array.prototype.slice;\n\nvar constant$5 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar pi$2 = Math.PI;\nvar tau$2 = 2 * pi$2;\nvar epsilon$1 = 1e-6;\nvar tauEpsilon = tau$2 - epsilon$1;\n\nfunction Path() {\n  this._x0 = this._y0 = // start of current subpath\n  this._x1 = this._y1 = null; // end of current subpath\n  this._ = \"\";\n}\n\nfunction path() {\n  return new Path;\n}\n\nPath.prototype = path.prototype = {\n  constructor: Path,\n  moveTo: function(x, y) {\n    this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y);\n  },\n  closePath: function() {\n    if (this._x1 !== null) {\n      this._x1 = this._x0, this._y1 = this._y0;\n      this._ += \"Z\";\n    }\n  },\n  lineTo: function(x, y) {\n    this._ += \"L\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n  },\n  quadraticCurveTo: function(x1, y1, x, y) {\n    this._ += \"Q\" + (+x1) + \",\" + (+y1) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n  },\n  bezierCurveTo: function(x1, y1, x2, y2, x, y) {\n    this._ += \"C\" + (+x1) + \",\" + (+y1) + \",\" + (+x2) + \",\" + (+y2) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n  },\n  arcTo: function(x1, y1, x2, y2, r) {\n    x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n    var x0 = this._x1,\n        y0 = this._y1,\n        x21 = x2 - x1,\n        y21 = y2 - y1,\n        x01 = x0 - x1,\n        y01 = y0 - y1,\n        l01_2 = x01 * x01 + y01 * y01;\n\n    // Is the radius negative? Error.\n    if (r < 0) throw new Error(\"negative radius: \" + r);\n\n    // Is this path empty? Move to (x1,y1).\n    if (this._x1 === null) {\n      this._ += \"M\" + (this._x1 = x1) + \",\" + (this._y1 = y1);\n    }\n\n    // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.\n    else if (!(l01_2 > epsilon$1)) {}\n\n    // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?\n    // Equivalently, is (x1,y1) coincident with (x2,y2)?\n    // Or, is the radius zero? Line to (x1,y1).\n    else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon$1) || !r) {\n      this._ += \"L\" + (this._x1 = x1) + \",\" + (this._y1 = y1);\n    }\n\n    // Otherwise, draw an arc!\n    else {\n      var x20 = x2 - x0,\n          y20 = y2 - y0,\n          l21_2 = x21 * x21 + y21 * y21,\n          l20_2 = x20 * x20 + y20 * y20,\n          l21 = Math.sqrt(l21_2),\n          l01 = Math.sqrt(l01_2),\n          l = r * Math.tan((pi$2 - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),\n          t01 = l / l01,\n          t21 = l / l21;\n\n      // If the start tangent is not coincident with (x0,y0), line to.\n      if (Math.abs(t01 - 1) > epsilon$1) {\n        this._ += \"L\" + (x1 + t01 * x01) + \",\" + (y1 + t01 * y01);\n      }\n\n      this._ += \"A\" + r + \",\" + r + \",0,0,\" + (+(y01 * x20 > x01 * y20)) + \",\" + (this._x1 = x1 + t21 * x21) + \",\" + (this._y1 = y1 + t21 * y21);\n    }\n  },\n  arc: function(x, y, r, a0, a1, ccw) {\n    x = +x, y = +y, r = +r;\n    var dx = r * Math.cos(a0),\n        dy = r * Math.sin(a0),\n        x0 = x + dx,\n        y0 = y + dy,\n        cw = 1 ^ ccw,\n        da = ccw ? a0 - a1 : a1 - a0;\n\n    // Is the radius negative? Error.\n    if (r < 0) throw new Error(\"negative radius: \" + r);\n\n    // Is this path empty? Move to (x0,y0).\n    if (this._x1 === null) {\n      this._ += \"M\" + x0 + \",\" + y0;\n    }\n\n    // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).\n    else if (Math.abs(this._x1 - x0) > epsilon$1 || Math.abs(this._y1 - y0) > epsilon$1) {\n      this._ += \"L\" + x0 + \",\" + y0;\n    }\n\n    // Is this arc empty? We’re done.\n    if (!r) return;\n\n    // Does the angle go the wrong way? Flip the direction.\n    if (da < 0) da = da % tau$2 + tau$2;\n\n    // Is this a complete circle? Draw two arcs to complete the circle.\n    if (da > tauEpsilon) {\n      this._ += \"A\" + r + \",\" + r + \",0,1,\" + cw + \",\" + (x - dx) + \",\" + (y - dy) + \"A\" + r + \",\" + r + \",0,1,\" + cw + \",\" + (this._x1 = x0) + \",\" + (this._y1 = y0);\n    }\n\n    // Is this arc non-empty? Draw an arc!\n    else if (da > epsilon$1) {\n      this._ += \"A\" + r + \",\" + r + \",0,\" + (+(da >= pi$2)) + \",\" + cw + \",\" + (this._x1 = x + r * Math.cos(a1)) + \",\" + (this._y1 = y + r * Math.sin(a1));\n    }\n  },\n  rect: function(x, y, w, h) {\n    this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y) + \"h\" + (+w) + \"v\" + (+h) + \"h\" + (-w) + \"Z\";\n  },\n  toString: function() {\n    return this._;\n  }\n};\n\nfunction defaultSource(d) {\n  return d.source;\n}\n\nfunction defaultTarget(d) {\n  return d.target;\n}\n\nfunction defaultRadius(d) {\n  return d.radius;\n}\n\nfunction defaultStartAngle(d) {\n  return d.startAngle;\n}\n\nfunction defaultEndAngle(d) {\n  return d.endAngle;\n}\n\nvar ribbon = function() {\n  var source = defaultSource,\n      target = defaultTarget,\n      radius = defaultRadius,\n      startAngle = defaultStartAngle,\n      endAngle = defaultEndAngle,\n      context = null;\n\n  function ribbon() {\n    var buffer,\n        argv = slice$2.call(arguments),\n        s = source.apply(this, argv),\n        t = target.apply(this, argv),\n        sr = +radius.apply(this, (argv[0] = s, argv)),\n        sa0 = startAngle.apply(this, argv) - halfPi$1,\n        sa1 = endAngle.apply(this, argv) - halfPi$1,\n        sx0 = sr * cos(sa0),\n        sy0 = sr * sin(sa0),\n        tr = +radius.apply(this, (argv[0] = t, argv)),\n        ta0 = startAngle.apply(this, argv) - halfPi$1,\n        ta1 = endAngle.apply(this, argv) - halfPi$1;\n\n    if (!context) context = buffer = path();\n\n    context.moveTo(sx0, sy0);\n    context.arc(0, 0, sr, sa0, sa1);\n    if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?\n      context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));\n      context.arc(0, 0, tr, ta0, ta1);\n    }\n    context.quadraticCurveTo(0, 0, sx0, sy0);\n    context.closePath();\n\n    if (buffer) return context = null, buffer + \"\" || null;\n  }\n\n  ribbon.radius = function(_) {\n    return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$5(+_), ribbon) : radius;\n  };\n\n  ribbon.startAngle = function(_) {\n    return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$5(+_), ribbon) : startAngle;\n  };\n\n  ribbon.endAngle = function(_) {\n    return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$5(+_), ribbon) : endAngle;\n  };\n\n  ribbon.source = function(_) {\n    return arguments.length ? (source = _, ribbon) : source;\n  };\n\n  ribbon.target = function(_) {\n    return arguments.length ? (target = _, ribbon) : target;\n  };\n\n  ribbon.context = function(_) {\n    return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;\n  };\n\n  return ribbon;\n};\n\nvar prefix = \"$\";\n\nfunction Map() {}\n\nMap.prototype = map$1.prototype = {\n  constructor: Map,\n  has: function(key) {\n    return (prefix + key) in this;\n  },\n  get: function(key) {\n    return this[prefix + key];\n  },\n  set: function(key, value) {\n    this[prefix + key] = value;\n    return this;\n  },\n  remove: function(key) {\n    var property = prefix + key;\n    return property in this && delete this[property];\n  },\n  clear: function() {\n    for (var property in this) if (property[0] === prefix) delete this[property];\n  },\n  keys: function() {\n    var keys = [];\n    for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));\n    return keys;\n  },\n  values: function() {\n    var values = [];\n    for (var property in this) if (property[0] === prefix) values.push(this[property]);\n    return values;\n  },\n  entries: function() {\n    var entries = [];\n    for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});\n    return entries;\n  },\n  size: function() {\n    var size = 0;\n    for (var property in this) if (property[0] === prefix) ++size;\n    return size;\n  },\n  empty: function() {\n    for (var property in this) if (property[0] === prefix) return false;\n    return true;\n  },\n  each: function(f) {\n    for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);\n  }\n};\n\nfunction map$1(object, f) {\n  var map = new Map;\n\n  // Copy constructor.\n  if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });\n\n  // Index array by numeric index or specified key function.\n  else if (Array.isArray(object)) {\n    var i = -1,\n        n = object.length,\n        o;\n\n    if (f == null) while (++i < n) map.set(i, object[i]);\n    else while (++i < n) map.set(f(o = object[i], i, object), o);\n  }\n\n  // Convert object to map.\n  else if (object) for (var key in object) map.set(key, object[key]);\n\n  return map;\n}\n\nvar nest = function() {\n  var keys = [],\n      sortKeys = [],\n      sortValues,\n      rollup,\n      nest;\n\n  function apply(array, depth, createResult, setResult) {\n    if (depth >= keys.length) return rollup != null\n        ? rollup(array) : (sortValues != null\n        ? array.sort(sortValues)\n        : array);\n\n    var i = -1,\n        n = array.length,\n        key = keys[depth++],\n        keyValue,\n        value,\n        valuesByKey = map$1(),\n        values,\n        result = createResult();\n\n    while (++i < n) {\n      if (values = valuesByKey.get(keyValue = key(value = array[i]) + \"\")) {\n        values.push(value);\n      } else {\n        valuesByKey.set(keyValue, [value]);\n      }\n    }\n\n    valuesByKey.each(function(values, key) {\n      setResult(result, key, apply(values, depth, createResult, setResult));\n    });\n\n    return result;\n  }\n\n  function entries(map, depth) {\n    if (++depth > keys.length) return map;\n    var array, sortKey = sortKeys[depth - 1];\n    if (rollup != null && depth >= keys.length) array = map.entries();\n    else array = [], map.each(function(v, k) { array.push({key: k, values: entries(v, depth)}); });\n    return sortKey != null ? array.sort(function(a, b) { return sortKey(a.key, b.key); }) : array;\n  }\n\n  return nest = {\n    object: function(array) { return apply(array, 0, createObject, setObject); },\n    map: function(array) { return apply(array, 0, createMap, setMap); },\n    entries: function(array) { return entries(apply(array, 0, createMap, setMap), 0); },\n    key: function(d) { keys.push(d); return nest; },\n    sortKeys: function(order) { sortKeys[keys.length - 1] = order; return nest; },\n    sortValues: function(order) { sortValues = order; return nest; },\n    rollup: function(f) { rollup = f; return nest; }\n  };\n};\n\nfunction createObject() {\n  return {};\n}\n\nfunction setObject(object, key, value) {\n  object[key] = value;\n}\n\nfunction createMap() {\n  return map$1();\n}\n\nfunction setMap(map, key, value) {\n  map.set(key, value);\n}\n\nfunction Set() {}\n\nvar proto = map$1.prototype;\n\nSet.prototype = set$2.prototype = {\n  constructor: Set,\n  has: proto.has,\n  add: function(value) {\n    value += \"\";\n    this[prefix + value] = value;\n    return this;\n  },\n  remove: proto.remove,\n  clear: proto.clear,\n  values: proto.keys,\n  size: proto.size,\n  empty: proto.empty,\n  each: proto.each\n};\n\nfunction set$2(object, f) {\n  var set = new Set;\n\n  // Copy constructor.\n  if (object instanceof Set) object.each(function(value) { set.add(value); });\n\n  // Otherwise, assume it’s an array.\n  else if (object) {\n    var i = -1, n = object.length;\n    if (f == null) while (++i < n) set.add(object[i]);\n    else while (++i < n) set.add(f(object[i], i, object));\n  }\n\n  return set;\n}\n\nvar keys = function(map) {\n  var keys = [];\n  for (var key in map) keys.push(key);\n  return keys;\n};\n\nvar values = function(map) {\n  var values = [];\n  for (var key in map) values.push(map[key]);\n  return values;\n};\n\nvar entries = function(map) {\n  var entries = [];\n  for (var key in map) entries.push({key: key, value: map[key]});\n  return entries;\n};\n\nfunction objectConverter(columns) {\n  return new Function(\"d\", \"return {\" + columns.map(function(name, i) {\n    return JSON.stringify(name) + \": d[\" + i + \"]\";\n  }).join(\",\") + \"}\");\n}\n\nfunction customConverter(columns, f) {\n  var object = objectConverter(columns);\n  return function(row, i) {\n    return f(object(row), i, columns);\n  };\n}\n\n// Compute unique columns in order of discovery.\nfunction inferColumns(rows) {\n  var columnSet = Object.create(null),\n      columns = [];\n\n  rows.forEach(function(row) {\n    for (var column in row) {\n      if (!(column in columnSet)) {\n        columns.push(columnSet[column] = column);\n      }\n    }\n  });\n\n  return columns;\n}\n\nvar dsv = function(delimiter) {\n  var reFormat = new RegExp(\"[\\\"\" + delimiter + \"\\n\\r]\"),\n      delimiterCode = delimiter.charCodeAt(0);\n\n  function parse(text, f) {\n    var convert, columns, rows = parseRows(text, function(row, i) {\n      if (convert) return convert(row, i - 1);\n      columns = row, convert = f ? customConverter(row, f) : objectConverter(row);\n    });\n    rows.columns = columns;\n    return rows;\n  }\n\n  function parseRows(text, f) {\n    var EOL = {}, // sentinel value for end-of-line\n        EOF = {}, // sentinel value for end-of-file\n        rows = [], // output rows\n        N = text.length,\n        I = 0, // current character index\n        n = 0, // the current line number\n        t, // the current token\n        eol; // is the current token followed by EOL?\n\n    function token() {\n      if (I >= N) return EOF; // special case: end of file\n      if (eol) return eol = false, EOL; // special case: end of line\n\n      // special case: quotes\n      var j = I, c;\n      if (text.charCodeAt(j) === 34) {\n        var i = j;\n        while (i++ < N) {\n          if (text.charCodeAt(i) === 34) {\n            if (text.charCodeAt(i + 1) !== 34) break;\n            ++i;\n          }\n        }\n        I = i + 2;\n        c = text.charCodeAt(i + 1);\n        if (c === 13) {\n          eol = true;\n          if (text.charCodeAt(i + 2) === 10) ++I;\n        } else if (c === 10) {\n          eol = true;\n        }\n        return text.slice(j + 1, i).replace(/\"\"/g, \"\\\"\");\n      }\n\n      // common case: find next delimiter or newline\n      while (I < N) {\n        var k = 1;\n        c = text.charCodeAt(I++);\n        if (c === 10) eol = true; // \\n\n        else if (c === 13) { eol = true; if (text.charCodeAt(I) === 10) ++I, ++k; } // \\r|\\r\\n\n        else if (c !== delimiterCode) continue;\n        return text.slice(j, I - k);\n      }\n\n      // special case: last token before EOF\n      return text.slice(j);\n    }\n\n    while ((t = token()) !== EOF) {\n      var a = [];\n      while (t !== EOL && t !== EOF) {\n        a.push(t);\n        t = token();\n      }\n      if (f && (a = f(a, n++)) == null) continue;\n      rows.push(a);\n    }\n\n    return rows;\n  }\n\n  function format(rows, columns) {\n    if (columns == null) columns = inferColumns(rows);\n    return [columns.map(formatValue).join(delimiter)].concat(rows.map(function(row) {\n      return columns.map(function(column) {\n        return formatValue(row[column]);\n      }).join(delimiter);\n    })).join(\"\\n\");\n  }\n\n  function formatRows(rows) {\n    return rows.map(formatRow).join(\"\\n\");\n  }\n\n  function formatRow(row) {\n    return row.map(formatValue).join(delimiter);\n  }\n\n  function formatValue(text) {\n    return text == null ? \"\"\n        : reFormat.test(text += \"\") ? \"\\\"\" + text.replace(/\\\"/g, \"\\\"\\\"\") + \"\\\"\"\n        : text;\n  }\n\n  return {\n    parse: parse,\n    parseRows: parseRows,\n    format: format,\n    formatRows: formatRows\n  };\n};\n\nvar csv = dsv(\",\");\n\nvar csvParse = csv.parse;\nvar csvParseRows = csv.parseRows;\nvar csvFormat = csv.format;\nvar csvFormatRows = csv.formatRows;\n\nvar tsv = dsv(\"\\t\");\n\nvar tsvParse = tsv.parse;\nvar tsvParseRows = tsv.parseRows;\nvar tsvFormat = tsv.format;\nvar tsvFormatRows = tsv.formatRows;\n\nvar center$1 = function(x, y) {\n  var nodes;\n\n  if (x == null) x = 0;\n  if (y == null) y = 0;\n\n  function force() {\n    var i,\n        n = nodes.length,\n        node,\n        sx = 0,\n        sy = 0;\n\n    for (i = 0; i < n; ++i) {\n      node = nodes[i], sx += node.x, sy += node.y;\n    }\n\n    for (sx = sx / n - x, sy = sy / n - y, i = 0; i < n; ++i) {\n      node = nodes[i], node.x -= sx, node.y -= sy;\n    }\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n  };\n\n  force.x = function(_) {\n    return arguments.length ? (x = +_, force) : x;\n  };\n\n  force.y = function(_) {\n    return arguments.length ? (y = +_, force) : y;\n  };\n\n  return force;\n};\n\nvar constant$6 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar jiggle = function() {\n  return (Math.random() - 0.5) * 1e-6;\n};\n\nvar tree_add = function(d) {\n  var x = +this._x.call(null, d),\n      y = +this._y.call(null, d);\n  return add(this.cover(x, y), x, y, d);\n};\n\nfunction add(tree, x, y, d) {\n  if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n  var parent,\n      node = tree._root,\n      leaf = {data: d},\n      x0 = tree._x0,\n      y0 = tree._y0,\n      x1 = tree._x1,\n      y1 = tree._y1,\n      xm,\n      ym,\n      xp,\n      yp,\n      right,\n      bottom,\n      i,\n      j;\n\n  // If the tree is empty, initialize the root as a leaf.\n  if (!node) return tree._root = leaf, tree;\n\n  // Find the existing leaf for the new point, or add it.\n  while (node.length) {\n    if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n    if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n    if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n  }\n\n  // Is the new point is exactly coincident with the existing point?\n  xp = +tree._x.call(null, node.data);\n  yp = +tree._y.call(null, node.data);\n  if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n  // Otherwise, split the leaf node until the old and new point are separated.\n  do {\n    parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n    if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n    if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n  } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n  return parent[j] = node, parent[i] = leaf, tree;\n}\n\nfunction addAll(data) {\n  var d, i, n = data.length,\n      x,\n      y,\n      xz = new Array(n),\n      yz = new Array(n),\n      x0 = Infinity,\n      y0 = Infinity,\n      x1 = -Infinity,\n      y1 = -Infinity;\n\n  // Compute the points and their extent.\n  for (i = 0; i < n; ++i) {\n    if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n    xz[i] = x;\n    yz[i] = y;\n    if (x < x0) x0 = x;\n    if (x > x1) x1 = x;\n    if (y < y0) y0 = y;\n    if (y > y1) y1 = y;\n  }\n\n  // If there were no (valid) points, inherit the existing extent.\n  if (x1 < x0) x0 = this._x0, x1 = this._x1;\n  if (y1 < y0) y0 = this._y0, y1 = this._y1;\n\n  // Expand the tree to cover the new points.\n  this.cover(x0, y0).cover(x1, y1);\n\n  // Add the new points.\n  for (i = 0; i < n; ++i) {\n    add(this, xz[i], yz[i], data[i]);\n  }\n\n  return this;\n}\n\nvar tree_cover = function(x, y) {\n  if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n  var x0 = this._x0,\n      y0 = this._y0,\n      x1 = this._x1,\n      y1 = this._y1;\n\n  // If the quadtree has no extent, initialize them.\n  // Integer extent are necessary so that if we later double the extent,\n  // the existing quadrant boundaries don’t change due to floating point error!\n  if (isNaN(x0)) {\n    x1 = (x0 = Math.floor(x)) + 1;\n    y1 = (y0 = Math.floor(y)) + 1;\n  }\n\n  // Otherwise, double repeatedly to cover.\n  else if (x0 > x || x > x1 || y0 > y || y > y1) {\n    var z = x1 - x0,\n        node = this._root,\n        parent,\n        i;\n\n    switch (i = (y < (y0 + y1) / 2) << 1 | (x < (x0 + x1) / 2)) {\n      case 0: {\n        do parent = new Array(4), parent[i] = node, node = parent;\n        while (z *= 2, x1 = x0 + z, y1 = y0 + z, x > x1 || y > y1);\n        break;\n      }\n      case 1: {\n        do parent = new Array(4), parent[i] = node, node = parent;\n        while (z *= 2, x0 = x1 - z, y1 = y0 + z, x0 > x || y > y1);\n        break;\n      }\n      case 2: {\n        do parent = new Array(4), parent[i] = node, node = parent;\n        while (z *= 2, x1 = x0 + z, y0 = y1 - z, x > x1 || y0 > y);\n        break;\n      }\n      case 3: {\n        do parent = new Array(4), parent[i] = node, node = parent;\n        while (z *= 2, x0 = x1 - z, y0 = y1 - z, x0 > x || y0 > y);\n        break;\n      }\n    }\n\n    if (this._root && this._root.length) this._root = node;\n  }\n\n  // If the quadtree covers the point already, just return.\n  else return this;\n\n  this._x0 = x0;\n  this._y0 = y0;\n  this._x1 = x1;\n  this._y1 = y1;\n  return this;\n};\n\nvar tree_data = function() {\n  var data = [];\n  this.visit(function(node) {\n    if (!node.length) do data.push(node.data); while (node = node.next)\n  });\n  return data;\n};\n\nvar tree_extent = function(_) {\n  return arguments.length\n      ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n      : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n};\n\nvar Quad = function(node, x0, y0, x1, y1) {\n  this.node = node;\n  this.x0 = x0;\n  this.y0 = y0;\n  this.x1 = x1;\n  this.y1 = y1;\n};\n\nvar tree_find = function(x, y, radius) {\n  var data,\n      x0 = this._x0,\n      y0 = this._y0,\n      x1,\n      y1,\n      x2,\n      y2,\n      x3 = this._x1,\n      y3 = this._y1,\n      quads = [],\n      node = this._root,\n      q,\n      i;\n\n  if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n  if (radius == null) radius = Infinity;\n  else {\n    x0 = x - radius, y0 = y - radius;\n    x3 = x + radius, y3 = y + radius;\n    radius *= radius;\n  }\n\n  while (q = quads.pop()) {\n\n    // Stop searching if this quadrant can’t contain a closer node.\n    if (!(node = q.node)\n        || (x1 = q.x0) > x3\n        || (y1 = q.y0) > y3\n        || (x2 = q.x1) < x0\n        || (y2 = q.y1) < y0) continue;\n\n    // Bisect the current quadrant.\n    if (node.length) {\n      var xm = (x1 + x2) / 2,\n          ym = (y1 + y2) / 2;\n\n      quads.push(\n        new Quad(node[3], xm, ym, x2, y2),\n        new Quad(node[2], x1, ym, xm, y2),\n        new Quad(node[1], xm, y1, x2, ym),\n        new Quad(node[0], x1, y1, xm, ym)\n      );\n\n      // Visit the closest quadrant first.\n      if (i = (y >= ym) << 1 | (x >= xm)) {\n        q = quads[quads.length - 1];\n        quads[quads.length - 1] = quads[quads.length - 1 - i];\n        quads[quads.length - 1 - i] = q;\n      }\n    }\n\n    // Visit this point. (Visiting coincident points isn’t necessary!)\n    else {\n      var dx = x - +this._x.call(null, node.data),\n          dy = y - +this._y.call(null, node.data),\n          d2 = dx * dx + dy * dy;\n      if (d2 < radius) {\n        var d = Math.sqrt(radius = d2);\n        x0 = x - d, y0 = y - d;\n        x3 = x + d, y3 = y + d;\n        data = node.data;\n      }\n    }\n  }\n\n  return data;\n};\n\nvar tree_remove = function(d) {\n  if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n  var parent,\n      node = this._root,\n      retainer,\n      previous,\n      next,\n      x0 = this._x0,\n      y0 = this._y0,\n      x1 = this._x1,\n      y1 = this._y1,\n      x,\n      y,\n      xm,\n      ym,\n      right,\n      bottom,\n      i,\n      j;\n\n  // If the tree is empty, initialize the root as a leaf.\n  if (!node) return this;\n\n  // Find the leaf node for the point.\n  // While descending, also retain the deepest parent with a non-removed sibling.\n  if (node.length) while (true) {\n    if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n    if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n    if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n    if (!node.length) break;\n    if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n  }\n\n  // Find the point to remove.\n  while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n  if (next = node.next) delete node.next;\n\n  // If there are multiple coincident points, remove just the point.\n  if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n  // If this is the root point, remove it.\n  if (!parent) return this._root = next, this;\n\n  // Remove this leaf.\n  next ? parent[i] = next : delete parent[i];\n\n  // If the parent now contains exactly one leaf, collapse superfluous parents.\n  if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n      && node === (parent[3] || parent[2] || parent[1] || parent[0])\n      && !node.length) {\n    if (retainer) retainer[j] = node;\n    else this._root = node;\n  }\n\n  return this;\n};\n\nfunction removeAll(data) {\n  for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n  return this;\n}\n\nvar tree_root = function() {\n  return this._root;\n};\n\nvar tree_size = function() {\n  var size = 0;\n  this.visit(function(node) {\n    if (!node.length) do ++size; while (node = node.next)\n  });\n  return size;\n};\n\nvar tree_visit = function(callback) {\n  var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n  if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n  while (q = quads.pop()) {\n    if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n      var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n      if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n      if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n      if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n      if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n    }\n  }\n  return this;\n};\n\nvar tree_visitAfter = function(callback) {\n  var quads = [], next = [], q;\n  if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n  while (q = quads.pop()) {\n    var node = q.node;\n    if (node.length) {\n      var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n      if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n      if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n      if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n      if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n    }\n    next.push(q);\n  }\n  while (q = next.pop()) {\n    callback(q.node, q.x0, q.y0, q.x1, q.y1);\n  }\n  return this;\n};\n\nfunction defaultX(d) {\n  return d[0];\n}\n\nvar tree_x = function(_) {\n  return arguments.length ? (this._x = _, this) : this._x;\n};\n\nfunction defaultY(d) {\n  return d[1];\n}\n\nvar tree_y = function(_) {\n  return arguments.length ? (this._y = _, this) : this._y;\n};\n\nfunction quadtree(nodes, x, y) {\n  var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n  return nodes == null ? tree : tree.addAll(nodes);\n}\n\nfunction Quadtree(x, y, x0, y0, x1, y1) {\n  this._x = x;\n  this._y = y;\n  this._x0 = x0;\n  this._y0 = y0;\n  this._x1 = x1;\n  this._y1 = y1;\n  this._root = undefined;\n}\n\nfunction leaf_copy(leaf) {\n  var copy = {data: leaf.data}, next = copy;\n  while (leaf = leaf.next) next = next.next = {data: leaf.data};\n  return copy;\n}\n\nvar treeProto = quadtree.prototype = Quadtree.prototype;\n\ntreeProto.copy = function() {\n  var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n      node = this._root,\n      nodes,\n      child;\n\n  if (!node) return copy;\n\n  if (!node.length) return copy._root = leaf_copy(node), copy;\n\n  nodes = [{source: node, target: copy._root = new Array(4)}];\n  while (node = nodes.pop()) {\n    for (var i = 0; i < 4; ++i) {\n      if (child = node.source[i]) {\n        if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n        else node.target[i] = leaf_copy(child);\n      }\n    }\n  }\n\n  return copy;\n};\n\ntreeProto.add = tree_add;\ntreeProto.addAll = addAll;\ntreeProto.cover = tree_cover;\ntreeProto.data = tree_data;\ntreeProto.extent = tree_extent;\ntreeProto.find = tree_find;\ntreeProto.remove = tree_remove;\ntreeProto.removeAll = removeAll;\ntreeProto.root = tree_root;\ntreeProto.size = tree_size;\ntreeProto.visit = tree_visit;\ntreeProto.visitAfter = tree_visitAfter;\ntreeProto.x = tree_x;\ntreeProto.y = tree_y;\n\nfunction x(d) {\n  return d.x + d.vx;\n}\n\nfunction y(d) {\n  return d.y + d.vy;\n}\n\nvar collide = function(radius) {\n  var nodes,\n      radii,\n      strength = 1,\n      iterations = 1;\n\n  if (typeof radius !== \"function\") radius = constant$6(radius == null ? 1 : +radius);\n\n  function force() {\n    var i, n = nodes.length,\n        tree,\n        node,\n        xi,\n        yi,\n        ri,\n        ri2;\n\n    for (var k = 0; k < iterations; ++k) {\n      tree = quadtree(nodes, x, y).visitAfter(prepare);\n      for (i = 0; i < n; ++i) {\n        node = nodes[i];\n        ri = radii[node.index], ri2 = ri * ri;\n        xi = node.x + node.vx;\n        yi = node.y + node.vy;\n        tree.visit(apply);\n      }\n    }\n\n    function apply(quad, x0, y0, x1, y1) {\n      var data = quad.data, rj = quad.r, r = ri + rj;\n      if (data) {\n        if (data.index > node.index) {\n          var x = xi - data.x - data.vx,\n              y = yi - data.y - data.vy,\n              l = x * x + y * y;\n          if (l < r * r) {\n            if (x === 0) x = jiggle(), l += x * x;\n            if (y === 0) y = jiggle(), l += y * y;\n            l = (r - (l = Math.sqrt(l))) / l * strength;\n            node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n            node.vy += (y *= l) * r;\n            data.vx -= x * (r = 1 - r);\n            data.vy -= y * r;\n          }\n        }\n        return;\n      }\n      return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n    }\n  }\n\n  function prepare(quad) {\n    if (quad.data) return quad.r = radii[quad.data.index];\n    for (var i = quad.r = 0; i < 4; ++i) {\n      if (quad[i] && quad[i].r > quad.r) {\n        quad.r = quad[i].r;\n      }\n    }\n  }\n\n  function initialize() {\n    if (!nodes) return;\n    var i, n = nodes.length, node;\n    radii = new Array(n);\n    for (i = 0; i < n; ++i) node = nodes[i], radii[node.index] = +radius(node, i, nodes);\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n    initialize();\n  };\n\n  force.iterations = function(_) {\n    return arguments.length ? (iterations = +_, force) : iterations;\n  };\n\n  force.strength = function(_) {\n    return arguments.length ? (strength = +_, force) : strength;\n  };\n\n  force.radius = function(_) {\n    return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : radius;\n  };\n\n  return force;\n};\n\nfunction index(d) {\n  return d.index;\n}\n\nfunction find(nodeById, nodeId) {\n  var node = nodeById.get(nodeId);\n  if (!node) throw new Error(\"missing: \" + nodeId);\n  return node;\n}\n\nvar link = function(links) {\n  var id = index,\n      strength = defaultStrength,\n      strengths,\n      distance = constant$6(30),\n      distances,\n      nodes,\n      count,\n      bias,\n      iterations = 1;\n\n  if (links == null) links = [];\n\n  function defaultStrength(link) {\n    return 1 / Math.min(count[link.source.index], count[link.target.index]);\n  }\n\n  function force(alpha) {\n    for (var k = 0, n = links.length; k < iterations; ++k) {\n      for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n        link = links[i], source = link.source, target = link.target;\n        x = target.x + target.vx - source.x - source.vx || jiggle();\n        y = target.y + target.vy - source.y - source.vy || jiggle();\n        l = Math.sqrt(x * x + y * y);\n        l = (l - distances[i]) / l * alpha * strengths[i];\n        x *= l, y *= l;\n        target.vx -= x * (b = bias[i]);\n        target.vy -= y * b;\n        source.vx += x * (b = 1 - b);\n        source.vy += y * b;\n      }\n    }\n  }\n\n  function initialize() {\n    if (!nodes) return;\n\n    var i,\n        n = nodes.length,\n        m = links.length,\n        nodeById = map$1(nodes, id),\n        link;\n\n    for (i = 0, count = new Array(n); i < m; ++i) {\n      link = links[i], link.index = i;\n      if (typeof link.source !== \"object\") link.source = find(nodeById, link.source);\n      if (typeof link.target !== \"object\") link.target = find(nodeById, link.target);\n      count[link.source.index] = (count[link.source.index] || 0) + 1;\n      count[link.target.index] = (count[link.target.index] || 0) + 1;\n    }\n\n    for (i = 0, bias = new Array(m); i < m; ++i) {\n      link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n    }\n\n    strengths = new Array(m), initializeStrength();\n    distances = new Array(m), initializeDistance();\n  }\n\n  function initializeStrength() {\n    if (!nodes) return;\n\n    for (var i = 0, n = links.length; i < n; ++i) {\n      strengths[i] = +strength(links[i], i, links);\n    }\n  }\n\n  function initializeDistance() {\n    if (!nodes) return;\n\n    for (var i = 0, n = links.length; i < n; ++i) {\n      distances[i] = +distance(links[i], i, links);\n    }\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n    initialize();\n  };\n\n  force.links = function(_) {\n    return arguments.length ? (links = _, initialize(), force) : links;\n  };\n\n  force.id = function(_) {\n    return arguments.length ? (id = _, force) : id;\n  };\n\n  force.iterations = function(_) {\n    return arguments.length ? (iterations = +_, force) : iterations;\n  };\n\n  force.strength = function(_) {\n    return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initializeStrength(), force) : strength;\n  };\n\n  force.distance = function(_) {\n    return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant$6(+_), initializeDistance(), force) : distance;\n  };\n\n  return force;\n};\n\nfunction x$1(d) {\n  return d.x;\n}\n\nfunction y$1(d) {\n  return d.y;\n}\n\nvar initialRadius = 10;\nvar initialAngle = Math.PI * (3 - Math.sqrt(5));\n\nvar simulation = function(nodes) {\n  var simulation,\n      alpha = 1,\n      alphaMin = 0.001,\n      alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n      alphaTarget = 0,\n      velocityDecay = 0.6,\n      forces = map$1(),\n      stepper = timer(step),\n      event = dispatch(\"tick\", \"end\");\n\n  if (nodes == null) nodes = [];\n\n  function step() {\n    tick();\n    event.call(\"tick\", simulation);\n    if (alpha < alphaMin) {\n      stepper.stop();\n      event.call(\"end\", simulation);\n    }\n  }\n\n  function tick() {\n    var i, n = nodes.length, node;\n\n    alpha += (alphaTarget - alpha) * alphaDecay;\n\n    forces.each(function(force) {\n      force(alpha);\n    });\n\n    for (i = 0; i < n; ++i) {\n      node = nodes[i];\n      if (node.fx == null) node.x += node.vx *= velocityDecay;\n      else node.x = node.fx, node.vx = 0;\n      if (node.fy == null) node.y += node.vy *= velocityDecay;\n      else node.y = node.fy, node.vy = 0;\n    }\n  }\n\n  function initializeNodes() {\n    for (var i = 0, n = nodes.length, node; i < n; ++i) {\n      node = nodes[i], node.index = i;\n      if (isNaN(node.x) || isNaN(node.y)) {\n        var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;\n        node.x = radius * Math.cos(angle);\n        node.y = radius * Math.sin(angle);\n      }\n      if (isNaN(node.vx) || isNaN(node.vy)) {\n        node.vx = node.vy = 0;\n      }\n    }\n  }\n\n  function initializeForce(force) {\n    if (force.initialize) force.initialize(nodes);\n    return force;\n  }\n\n  initializeNodes();\n\n  return simulation = {\n    tick: tick,\n\n    restart: function() {\n      return stepper.restart(step), simulation;\n    },\n\n    stop: function() {\n      return stepper.stop(), simulation;\n    },\n\n    nodes: function(_) {\n      return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;\n    },\n\n    alpha: function(_) {\n      return arguments.length ? (alpha = +_, simulation) : alpha;\n    },\n\n    alphaMin: function(_) {\n      return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n    },\n\n    alphaDecay: function(_) {\n      return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n    },\n\n    alphaTarget: function(_) {\n      return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n    },\n\n    velocityDecay: function(_) {\n      return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n    },\n\n    force: function(name, _) {\n      return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n    },\n\n    find: function(x, y, radius) {\n      var i = 0,\n          n = nodes.length,\n          dx,\n          dy,\n          d2,\n          node,\n          closest;\n\n      if (radius == null) radius = Infinity;\n      else radius *= radius;\n\n      for (i = 0; i < n; ++i) {\n        node = nodes[i];\n        dx = x - node.x;\n        dy = y - node.y;\n        d2 = dx * dx + dy * dy;\n        if (d2 < radius) closest = node, radius = d2;\n      }\n\n      return closest;\n    },\n\n    on: function(name, _) {\n      return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n    }\n  };\n};\n\nvar manyBody = function() {\n  var nodes,\n      node,\n      alpha,\n      strength = constant$6(-30),\n      strengths,\n      distanceMin2 = 1,\n      distanceMax2 = Infinity,\n      theta2 = 0.81;\n\n  function force(_) {\n    var i, n = nodes.length, tree = quadtree(nodes, x$1, y$1).visitAfter(accumulate);\n    for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n  }\n\n  function initialize() {\n    if (!nodes) return;\n    var i, n = nodes.length, node;\n    strengths = new Array(n);\n    for (i = 0; i < n; ++i) node = nodes[i], strengths[node.index] = +strength(node, i, nodes);\n  }\n\n  function accumulate(quad) {\n    var strength = 0, q, c, x$$1, y$$1, i;\n\n    // For internal nodes, accumulate forces from child quadrants.\n    if (quad.length) {\n      for (x$$1 = y$$1 = i = 0; i < 4; ++i) {\n        if ((q = quad[i]) && (c = q.value)) {\n          strength += c, x$$1 += c * q.x, y$$1 += c * q.y;\n        }\n      }\n      quad.x = x$$1 / strength;\n      quad.y = y$$1 / strength;\n    }\n\n    // For leaf nodes, accumulate forces from coincident quadrants.\n    else {\n      q = quad;\n      q.x = q.data.x;\n      q.y = q.data.y;\n      do strength += strengths[q.data.index];\n      while (q = q.next);\n    }\n\n    quad.value = strength;\n  }\n\n  function apply(quad, x1, _, x2) {\n    if (!quad.value) return true;\n\n    var x$$1 = quad.x - node.x,\n        y$$1 = quad.y - node.y,\n        w = x2 - x1,\n        l = x$$1 * x$$1 + y$$1 * y$$1;\n\n    // Apply the Barnes-Hut approximation if possible.\n    // Limit forces for very close nodes; randomize direction if coincident.\n    if (w * w / theta2 < l) {\n      if (l < distanceMax2) {\n        if (x$$1 === 0) x$$1 = jiggle(), l += x$$1 * x$$1;\n        if (y$$1 === 0) y$$1 = jiggle(), l += y$$1 * y$$1;\n        if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n        node.vx += x$$1 * quad.value * alpha / l;\n        node.vy += y$$1 * quad.value * alpha / l;\n      }\n      return true;\n    }\n\n    // Otherwise, process points directly.\n    else if (quad.length || l >= distanceMax2) return;\n\n    // Limit forces for very close nodes; randomize direction if coincident.\n    if (quad.data !== node || quad.next) {\n      if (x$$1 === 0) x$$1 = jiggle(), l += x$$1 * x$$1;\n      if (y$$1 === 0) y$$1 = jiggle(), l += y$$1 * y$$1;\n      if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n    }\n\n    do if (quad.data !== node) {\n      w = strengths[quad.data.index] * alpha / l;\n      node.vx += x$$1 * w;\n      node.vy += y$$1 * w;\n    } while (quad = quad.next);\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n    initialize();\n  };\n\n  force.strength = function(_) {\n    return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n  };\n\n  force.distanceMin = function(_) {\n    return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n  };\n\n  force.distanceMax = function(_) {\n    return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n  };\n\n  force.theta = function(_) {\n    return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n  };\n\n  return force;\n};\n\nvar x$2 = function(x) {\n  var strength = constant$6(0.1),\n      nodes,\n      strengths,\n      xz;\n\n  if (typeof x !== \"function\") x = constant$6(x == null ? 0 : +x);\n\n  function force(alpha) {\n    for (var i = 0, n = nodes.length, node; i < n; ++i) {\n      node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n    }\n  }\n\n  function initialize() {\n    if (!nodes) return;\n    var i, n = nodes.length;\n    strengths = new Array(n);\n    xz = new Array(n);\n    for (i = 0; i < n; ++i) {\n      strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n    }\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n    initialize();\n  };\n\n  force.strength = function(_) {\n    return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n  };\n\n  force.x = function(_) {\n    return arguments.length ? (x = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : x;\n  };\n\n  return force;\n};\n\nvar y$2 = function(y) {\n  var strength = constant$6(0.1),\n      nodes,\n      strengths,\n      yz;\n\n  if (typeof y !== \"function\") y = constant$6(y == null ? 0 : +y);\n\n  function force(alpha) {\n    for (var i = 0, n = nodes.length, node; i < n; ++i) {\n      node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n    }\n  }\n\n  function initialize() {\n    if (!nodes) return;\n    var i, n = nodes.length;\n    strengths = new Array(n);\n    yz = new Array(n);\n    for (i = 0; i < n; ++i) {\n      strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n    }\n  }\n\n  force.initialize = function(_) {\n    nodes = _;\n    initialize();\n  };\n\n  force.strength = function(_) {\n    return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : strength;\n  };\n\n  force.y = function(_) {\n    return arguments.length ? (y = typeof _ === \"function\" ? _ : constant$6(+_), initialize(), force) : y;\n  };\n\n  return force;\n};\n\n// Computes the decimal coefficient and exponent of the specified number x with\n// significant digits p, where x is positive and p is in [1, 21] or undefined.\n// For example, formatDecimal(1.23) returns [\"123\", 0].\nvar formatDecimal = function(x, p) {\n  if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n  var i, coefficient = x.slice(0, i);\n\n  // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n  // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n  return [\n    coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n    +x.slice(i + 1)\n  ];\n};\n\nvar exponent$1 = function(x) {\n  return x = formatDecimal(Math.abs(x)), x ? x[1] : NaN;\n};\n\nvar formatGroup = function(grouping, thousands) {\n  return function(value, width) {\n    var i = value.length,\n        t = [],\n        j = 0,\n        g = grouping[0],\n        length = 0;\n\n    while (i > 0 && g > 0) {\n      if (length + g + 1 > width) g = Math.max(1, width - length);\n      t.push(value.substring(i -= g, i + g));\n      if ((length += g + 1) > width) break;\n      g = grouping[j = (j + 1) % grouping.length];\n    }\n\n    return t.reverse().join(thousands);\n  };\n};\n\nvar formatNumerals = function(numerals) {\n  return function(value) {\n    return value.replace(/[0-9]/g, function(i) {\n      return numerals[+i];\n    });\n  };\n};\n\nvar formatDefault = function(x, p) {\n  x = x.toPrecision(p);\n\n  out: for (var n = x.length, i = 1, i0 = -1, i1; i < n; ++i) {\n    switch (x[i]) {\n      case \".\": i0 = i1 = i; break;\n      case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n      case \"e\": break out;\n      default: if (i0 > 0) i0 = 0; break;\n    }\n  }\n\n  return i0 > 0 ? x.slice(0, i0) + x.slice(i1 + 1) : x;\n};\n\nvar prefixExponent;\n\nvar formatPrefixAuto = function(x, p) {\n  var d = formatDecimal(x, p);\n  if (!d) return x + \"\";\n  var coefficient = d[0],\n      exponent = d[1],\n      i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n      n = coefficient.length;\n  return i === n ? coefficient\n      : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n      : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n      : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimal(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n};\n\nvar formatRounded = function(x, p) {\n  var d = formatDecimal(x, p);\n  if (!d) return x + \"\";\n  var coefficient = d[0],\n      exponent = d[1];\n  return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n      : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n      : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n};\n\nvar formatTypes = {\n  \"\": formatDefault,\n  \"%\": function(x, p) { return (x * 100).toFixed(p); },\n  \"b\": function(x) { return Math.round(x).toString(2); },\n  \"c\": function(x) { return x + \"\"; },\n  \"d\": function(x) { return Math.round(x).toString(10); },\n  \"e\": function(x, p) { return x.toExponential(p); },\n  \"f\": function(x, p) { return x.toFixed(p); },\n  \"g\": function(x, p) { return x.toPrecision(p); },\n  \"o\": function(x) { return Math.round(x).toString(8); },\n  \"p\": function(x, p) { return formatRounded(x * 100, p); },\n  \"r\": formatRounded,\n  \"s\": formatPrefixAuto,\n  \"X\": function(x) { return Math.round(x).toString(16).toUpperCase(); },\n  \"x\": function(x) { return Math.round(x).toString(16); }\n};\n\n// [[fill]align][sign][symbol][0][width][,][.precision][type]\nvar re = /^(?:(.)?([<>=^]))?([+\\-\\( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?([a-z%])?$/i;\n\nfunction formatSpecifier(specifier) {\n  return new FormatSpecifier(specifier);\n}\n\nformatSpecifier.prototype = FormatSpecifier.prototype; // instanceof\n\nfunction FormatSpecifier(specifier) {\n  if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n\n  var match,\n      fill = match[1] || \" \",\n      align = match[2] || \">\",\n      sign = match[3] || \"-\",\n      symbol = match[4] || \"\",\n      zero = !!match[5],\n      width = match[6] && +match[6],\n      comma = !!match[7],\n      precision = match[8] && +match[8].slice(1),\n      type = match[9] || \"\";\n\n  // The \"n\" type is an alias for \",g\".\n  if (type === \"n\") comma = true, type = \"g\";\n\n  // Map invalid types to the default format.\n  else if (!formatTypes[type]) type = \"\";\n\n  // If zero fill is specified, padding goes after sign and before digits.\n  if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n  this.fill = fill;\n  this.align = align;\n  this.sign = sign;\n  this.symbol = symbol;\n  this.zero = zero;\n  this.width = width;\n  this.comma = comma;\n  this.precision = precision;\n  this.type = type;\n}\n\nFormatSpecifier.prototype.toString = function() {\n  return this.fill\n      + this.align\n      + this.sign\n      + this.symbol\n      + (this.zero ? \"0\" : \"\")\n      + (this.width == null ? \"\" : Math.max(1, this.width | 0))\n      + (this.comma ? \",\" : \"\")\n      + (this.precision == null ? \"\" : \".\" + Math.max(0, this.precision | 0))\n      + this.type;\n};\n\nvar identity$3 = function(x) {\n  return x;\n};\n\nvar prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"\\xB5\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\nvar formatLocale = function(locale) {\n  var group = locale.grouping && locale.thousands ? formatGroup(locale.grouping, locale.thousands) : identity$3,\n      currency = locale.currency,\n      decimal = locale.decimal,\n      numerals = locale.numerals ? formatNumerals(locale.numerals) : identity$3,\n      percent = locale.percent || \"%\";\n\n  function newFormat(specifier) {\n    specifier = formatSpecifier(specifier);\n\n    var fill = specifier.fill,\n        align = specifier.align,\n        sign = specifier.sign,\n        symbol = specifier.symbol,\n        zero = specifier.zero,\n        width = specifier.width,\n        comma = specifier.comma,\n        precision = specifier.precision,\n        type = specifier.type;\n\n    // Compute the prefix and suffix.\n    // For SI-prefix, the suffix is lazily computed.\n    var prefix = symbol === \"$\" ? currency[0] : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n        suffix = symbol === \"$\" ? currency[1] : /[%p]/.test(type) ? percent : \"\";\n\n    // What format function should we use?\n    // Is this an integer type?\n    // Can this type generate exponential notation?\n    var formatType = formatTypes[type],\n        maybeSuffix = !type || /[defgprs%]/.test(type);\n\n    // Set the default precision if not specified,\n    // or clamp the specified precision to the supported range.\n    // For significant precision, it must be in [1, 21].\n    // For fixed precision, it must be in [0, 20].\n    precision = precision == null ? (type ? 6 : 12)\n        : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n        : Math.max(0, Math.min(20, precision));\n\n    function format(value) {\n      var valuePrefix = prefix,\n          valueSuffix = suffix,\n          i, n, c;\n\n      if (type === \"c\") {\n        valueSuffix = formatType(value) + valueSuffix;\n        value = \"\";\n      } else {\n        value = +value;\n\n        // Perform the initial formatting.\n        var valueNegative = value < 0;\n        value = formatType(Math.abs(value), precision);\n\n        // If a negative value rounds to zero during formatting, treat as positive.\n        if (valueNegative && +value === 0) valueNegative = false;\n\n        // Compute the prefix and suffix.\n        valuePrefix = (valueNegative ? (sign === \"(\" ? sign : \"-\") : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n        valueSuffix = valueSuffix + (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n        // Break the formatted value into the integer “value” part that can be\n        // grouped, and fractional or exponential “suffix” part that is not.\n        if (maybeSuffix) {\n          i = -1, n = value.length;\n          while (++i < n) {\n            if (c = value.charCodeAt(i), 48 > c || c > 57) {\n              valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n              value = value.slice(0, i);\n              break;\n            }\n          }\n        }\n      }\n\n      // If the fill character is not \"0\", grouping is applied before padding.\n      if (comma && !zero) value = group(value, Infinity);\n\n      // Compute the padding.\n      var length = valuePrefix.length + value.length + valueSuffix.length,\n          padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n      // If the fill character is \"0\", grouping is applied after padding.\n      if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n      // Reconstruct the final output based on the desired alignment.\n      switch (align) {\n        case \"<\": value = valuePrefix + value + valueSuffix + padding; break;\n        case \"=\": value = valuePrefix + padding + value + valueSuffix; break;\n        case \"^\": value = padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length); break;\n        default: value = padding + valuePrefix + value + valueSuffix; break;\n      }\n\n      return numerals(value);\n    }\n\n    format.toString = function() {\n      return specifier + \"\";\n    };\n\n    return format;\n  }\n\n  function formatPrefix(specifier, value) {\n    var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n        e = Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3,\n        k = Math.pow(10, -e),\n        prefix = prefixes[8 + e / 3];\n    return function(value) {\n      return f(k * value) + prefix;\n    };\n  }\n\n  return {\n    format: newFormat,\n    formatPrefix: formatPrefix\n  };\n};\n\nvar locale$1;\n\n\n\ndefaultLocale({\n  decimal: \".\",\n  thousands: \",\",\n  grouping: [3],\n  currency: [\"$\", \"\"]\n});\n\nfunction defaultLocale(definition) {\n  locale$1 = formatLocale(definition);\n  exports.format = locale$1.format;\n  exports.formatPrefix = locale$1.formatPrefix;\n  return locale$1;\n}\n\nvar precisionFixed = function(step) {\n  return Math.max(0, -exponent$1(Math.abs(step)));\n};\n\nvar precisionPrefix = function(step, value) {\n  return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent$1(value) / 3))) * 3 - exponent$1(Math.abs(step)));\n};\n\nvar precisionRound = function(step, max) {\n  step = Math.abs(step), max = Math.abs(max) - step;\n  return Math.max(0, exponent$1(max) - exponent$1(step)) + 1;\n};\n\n// Adds floating point numbers with twice the normal precision.\n// Reference: J. R. Shewchuk, Adaptive Precision Floating-Point Arithmetic and\n// Fast Robust Geometric Predicates, Discrete & Computational Geometry 18(3)\n// 305–363 (1997).\n// Code adapted from GeographicLib by Charles F. F. Karney,\n// http://geographiclib.sourceforge.net/\n\nvar adder = function() {\n  return new Adder;\n};\n\nfunction Adder() {\n  this.reset();\n}\n\nAdder.prototype = {\n  constructor: Adder,\n  reset: function() {\n    this.s = // rounded value\n    this.t = 0; // exact error\n  },\n  add: function(y) {\n    add$1(temp, y, this.t);\n    add$1(this, temp.s, this.s);\n    if (this.s) this.t += temp.t;\n    else this.s = temp.t;\n  },\n  valueOf: function() {\n    return this.s;\n  }\n};\n\nvar temp = new Adder;\n\nfunction add$1(adder, a, b) {\n  var x = adder.s = a + b,\n      bv = x - a,\n      av = x - bv;\n  adder.t = (a - av) + (b - bv);\n}\n\nvar epsilon$2 = 1e-6;\nvar epsilon2$1 = 1e-12;\nvar pi$3 = Math.PI;\nvar halfPi$2 = pi$3 / 2;\nvar quarterPi = pi$3 / 4;\nvar tau$3 = pi$3 * 2;\n\nvar degrees$1 = 180 / pi$3;\nvar radians = pi$3 / 180;\n\nvar abs = Math.abs;\nvar atan = Math.atan;\nvar atan2 = Math.atan2;\nvar cos$1 = Math.cos;\nvar ceil = Math.ceil;\nvar exp = Math.exp;\n\nvar log = Math.log;\nvar pow = Math.pow;\nvar sin$1 = Math.sin;\nvar sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\nvar sqrt = Math.sqrt;\nvar tan = Math.tan;\n\nfunction acos(x) {\n  return x > 1 ? 0 : x < -1 ? pi$3 : Math.acos(x);\n}\n\nfunction asin(x) {\n  return x > 1 ? halfPi$2 : x < -1 ? -halfPi$2 : Math.asin(x);\n}\n\nfunction haversin(x) {\n  return (x = sin$1(x / 2)) * x;\n}\n\nfunction noop$1() {}\n\nfunction streamGeometry(geometry, stream) {\n  if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n    streamGeometryType[geometry.type](geometry, stream);\n  }\n}\n\nvar streamObjectType = {\n  Feature: function(object, stream) {\n    streamGeometry(object.geometry, stream);\n  },\n  FeatureCollection: function(object, stream) {\n    var features = object.features, i = -1, n = features.length;\n    while (++i < n) streamGeometry(features[i].geometry, stream);\n  }\n};\n\nvar streamGeometryType = {\n  Sphere: function(object, stream) {\n    stream.sphere();\n  },\n  Point: function(object, stream) {\n    object = object.coordinates;\n    stream.point(object[0], object[1], object[2]);\n  },\n  MultiPoint: function(object, stream) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n  },\n  LineString: function(object, stream) {\n    streamLine(object.coordinates, stream, 0);\n  },\n  MultiLineString: function(object, stream) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) streamLine(coordinates[i], stream, 0);\n  },\n  Polygon: function(object, stream) {\n    streamPolygon(object.coordinates, stream);\n  },\n  MultiPolygon: function(object, stream) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) streamPolygon(coordinates[i], stream);\n  },\n  GeometryCollection: function(object, stream) {\n    var geometries = object.geometries, i = -1, n = geometries.length;\n    while (++i < n) streamGeometry(geometries[i], stream);\n  }\n};\n\nfunction streamLine(coordinates, stream, closed) {\n  var i = -1, n = coordinates.length - closed, coordinate;\n  stream.lineStart();\n  while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n  stream.lineEnd();\n}\n\nfunction streamPolygon(coordinates, stream) {\n  var i = -1, n = coordinates.length;\n  stream.polygonStart();\n  while (++i < n) streamLine(coordinates[i], stream, 1);\n  stream.polygonEnd();\n}\n\nvar geoStream = function(object, stream) {\n  if (object && streamObjectType.hasOwnProperty(object.type)) {\n    streamObjectType[object.type](object, stream);\n  } else {\n    streamGeometry(object, stream);\n  }\n};\n\nvar areaRingSum = adder();\n\nvar areaSum = adder();\nvar lambda00;\nvar phi00;\nvar lambda0;\nvar cosPhi0;\nvar sinPhi0;\n\nvar areaStream = {\n  point: noop$1,\n  lineStart: noop$1,\n  lineEnd: noop$1,\n  polygonStart: function() {\n    areaRingSum.reset();\n    areaStream.lineStart = areaRingStart;\n    areaStream.lineEnd = areaRingEnd;\n  },\n  polygonEnd: function() {\n    var areaRing = +areaRingSum;\n    areaSum.add(areaRing < 0 ? tau$3 + areaRing : areaRing);\n    this.lineStart = this.lineEnd = this.point = noop$1;\n  },\n  sphere: function() {\n    areaSum.add(tau$3);\n  }\n};\n\nfunction areaRingStart() {\n  areaStream.point = areaPointFirst;\n}\n\nfunction areaRingEnd() {\n  areaPoint(lambda00, phi00);\n}\n\nfunction areaPointFirst(lambda, phi) {\n  areaStream.point = areaPoint;\n  lambda00 = lambda, phi00 = phi;\n  lambda *= radians, phi *= radians;\n  lambda0 = lambda, cosPhi0 = cos$1(phi = phi / 2 + quarterPi), sinPhi0 = sin$1(phi);\n}\n\nfunction areaPoint(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  phi = phi / 2 + quarterPi; // half the angular distance from south pole\n\n  // Spherical excess E for a spherical triangle with vertices: south pole,\n  // previous point, current point.  Uses a formula derived from Cagnoli’s\n  // theorem.  See Todhunter, Spherical Trig. (1871), Sec. 103, Eq. (2).\n  var dLambda = lambda - lambda0,\n      sdLambda = dLambda >= 0 ? 1 : -1,\n      adLambda = sdLambda * dLambda,\n      cosPhi = cos$1(phi),\n      sinPhi = sin$1(phi),\n      k = sinPhi0 * sinPhi,\n      u = cosPhi0 * cosPhi + k * cos$1(adLambda),\n      v = k * sdLambda * sin$1(adLambda);\n  areaRingSum.add(atan2(v, u));\n\n  // Advance the previous points.\n  lambda0 = lambda, cosPhi0 = cosPhi, sinPhi0 = sinPhi;\n}\n\nvar area = function(object) {\n  areaSum.reset();\n  geoStream(object, areaStream);\n  return areaSum * 2;\n};\n\nfunction spherical(cartesian) {\n  return [atan2(cartesian[1], cartesian[0]), asin(cartesian[2])];\n}\n\nfunction cartesian(spherical) {\n  var lambda = spherical[0], phi = spherical[1], cosPhi = cos$1(phi);\n  return [cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi)];\n}\n\nfunction cartesianDot(a, b) {\n  return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n\nfunction cartesianCross(a, b) {\n  return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n}\n\n// TODO return a\nfunction cartesianAddInPlace(a, b) {\n  a[0] += b[0], a[1] += b[1], a[2] += b[2];\n}\n\nfunction cartesianScale(vector, k) {\n  return [vector[0] * k, vector[1] * k, vector[2] * k];\n}\n\n// TODO return d\nfunction cartesianNormalizeInPlace(d) {\n  var l = sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n  d[0] /= l, d[1] /= l, d[2] /= l;\n}\n\nvar lambda0$1;\nvar phi0;\nvar lambda1;\nvar phi1;\nvar lambda2;\nvar lambda00$1;\nvar phi00$1;\nvar p0;\nvar deltaSum = adder();\nvar ranges;\nvar range;\n\nvar boundsStream = {\n  point: boundsPoint,\n  lineStart: boundsLineStart,\n  lineEnd: boundsLineEnd,\n  polygonStart: function() {\n    boundsStream.point = boundsRingPoint;\n    boundsStream.lineStart = boundsRingStart;\n    boundsStream.lineEnd = boundsRingEnd;\n    deltaSum.reset();\n    areaStream.polygonStart();\n  },\n  polygonEnd: function() {\n    areaStream.polygonEnd();\n    boundsStream.point = boundsPoint;\n    boundsStream.lineStart = boundsLineStart;\n    boundsStream.lineEnd = boundsLineEnd;\n    if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);\n    else if (deltaSum > epsilon$2) phi1 = 90;\n    else if (deltaSum < -epsilon$2) phi0 = -90;\n    range[0] = lambda0$1, range[1] = lambda1;\n  }\n};\n\nfunction boundsPoint(lambda, phi) {\n  ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);\n  if (phi < phi0) phi0 = phi;\n  if (phi > phi1) phi1 = phi;\n}\n\nfunction linePoint(lambda, phi) {\n  var p = cartesian([lambda * radians, phi * radians]);\n  if (p0) {\n    var normal = cartesianCross(p0, p),\n        equatorial = [normal[1], -normal[0], 0],\n        inflection = cartesianCross(equatorial, normal);\n    cartesianNormalizeInPlace(inflection);\n    inflection = spherical(inflection);\n    var delta = lambda - lambda2,\n        sign$$1 = delta > 0 ? 1 : -1,\n        lambdai = inflection[0] * degrees$1 * sign$$1,\n        phii,\n        antimeridian = abs(delta) > 180;\n    if (antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {\n      phii = inflection[1] * degrees$1;\n      if (phii > phi1) phi1 = phii;\n    } else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign$$1 * lambda2 < lambdai && lambdai < sign$$1 * lambda)) {\n      phii = -inflection[1] * degrees$1;\n      if (phii < phi0) phi0 = phii;\n    } else {\n      if (phi < phi0) phi0 = phi;\n      if (phi > phi1) phi1 = phi;\n    }\n    if (antimeridian) {\n      if (lambda < lambda2) {\n        if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n      } else {\n        if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n      }\n    } else {\n      if (lambda1 >= lambda0$1) {\n        if (lambda < lambda0$1) lambda0$1 = lambda;\n        if (lambda > lambda1) lambda1 = lambda;\n      } else {\n        if (lambda > lambda2) {\n          if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;\n        } else {\n          if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;\n        }\n      }\n    }\n  } else {\n    ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);\n  }\n  if (phi < phi0) phi0 = phi;\n  if (phi > phi1) phi1 = phi;\n  p0 = p, lambda2 = lambda;\n}\n\nfunction boundsLineStart() {\n  boundsStream.point = linePoint;\n}\n\nfunction boundsLineEnd() {\n  range[0] = lambda0$1, range[1] = lambda1;\n  boundsStream.point = boundsPoint;\n  p0 = null;\n}\n\nfunction boundsRingPoint(lambda, phi) {\n  if (p0) {\n    var delta = lambda - lambda2;\n    deltaSum.add(abs(delta) > 180 ? delta + (delta > 0 ? 360 : -360) : delta);\n  } else {\n    lambda00$1 = lambda, phi00$1 = phi;\n  }\n  areaStream.point(lambda, phi);\n  linePoint(lambda, phi);\n}\n\nfunction boundsRingStart() {\n  areaStream.lineStart();\n}\n\nfunction boundsRingEnd() {\n  boundsRingPoint(lambda00$1, phi00$1);\n  areaStream.lineEnd();\n  if (abs(deltaSum) > epsilon$2) lambda0$1 = -(lambda1 = 180);\n  range[0] = lambda0$1, range[1] = lambda1;\n  p0 = null;\n}\n\n// Finds the left-right distance between two longitudes.\n// This is almost the same as (lambda1 - lambda0 + 360°) % 360°, except that we want\n// the distance between ±180° to be 360°.\nfunction angle(lambda0, lambda1) {\n  return (lambda1 -= lambda0) < 0 ? lambda1 + 360 : lambda1;\n}\n\nfunction rangeCompare(a, b) {\n  return a[0] - b[0];\n}\n\nfunction rangeContains(range, x) {\n  return range[0] <= range[1] ? range[0] <= x && x <= range[1] : x < range[0] || range[1] < x;\n}\n\nvar bounds = function(feature) {\n  var i, n, a, b, merged, deltaMax, delta;\n\n  phi1 = lambda1 = -(lambda0$1 = phi0 = Infinity);\n  ranges = [];\n  geoStream(feature, boundsStream);\n\n  // First, sort ranges by their minimum longitudes.\n  if (n = ranges.length) {\n    ranges.sort(rangeCompare);\n\n    // Then, merge any ranges that overlap.\n    for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {\n      b = ranges[i];\n      if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {\n        if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];\n        if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];\n      } else {\n        merged.push(a = b);\n      }\n    }\n\n    // Finally, find the largest gap between the merged ranges.\n    // The final bounding box will be the inverse of this gap.\n    for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {\n      b = merged[i];\n      if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];\n    }\n  }\n\n  ranges = range = null;\n\n  return lambda0$1 === Infinity || phi0 === Infinity\n      ? [[NaN, NaN], [NaN, NaN]]\n      : [[lambda0$1, phi0], [lambda1, phi1]];\n};\n\nvar W0;\nvar W1;\nvar X0;\nvar Y0;\nvar Z0;\nvar X1;\nvar Y1;\nvar Z1;\nvar X2;\nvar Y2;\nvar Z2;\nvar lambda00$2;\nvar phi00$2;\nvar x0;\nvar y0;\nvar z0; // previous point\n\nvar centroidStream = {\n  sphere: noop$1,\n  point: centroidPoint,\n  lineStart: centroidLineStart,\n  lineEnd: centroidLineEnd,\n  polygonStart: function() {\n    centroidStream.lineStart = centroidRingStart;\n    centroidStream.lineEnd = centroidRingEnd;\n  },\n  polygonEnd: function() {\n    centroidStream.lineStart = centroidLineStart;\n    centroidStream.lineEnd = centroidLineEnd;\n  }\n};\n\n// Arithmetic mean of Cartesian vectors.\nfunction centroidPoint(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  var cosPhi = cos$1(phi);\n  centroidPointCartesian(cosPhi * cos$1(lambda), cosPhi * sin$1(lambda), sin$1(phi));\n}\n\nfunction centroidPointCartesian(x, y, z) {\n  ++W0;\n  X0 += (x - X0) / W0;\n  Y0 += (y - Y0) / W0;\n  Z0 += (z - Z0) / W0;\n}\n\nfunction centroidLineStart() {\n  centroidStream.point = centroidLinePointFirst;\n}\n\nfunction centroidLinePointFirst(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  var cosPhi = cos$1(phi);\n  x0 = cosPhi * cos$1(lambda);\n  y0 = cosPhi * sin$1(lambda);\n  z0 = sin$1(phi);\n  centroidStream.point = centroidLinePoint;\n  centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLinePoint(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  var cosPhi = cos$1(phi),\n      x = cosPhi * cos$1(lambda),\n      y = cosPhi * sin$1(lambda),\n      z = sin$1(phi),\n      w = atan2(sqrt((w = y0 * z - z0 * y) * w + (w = z0 * x - x0 * z) * w + (w = x0 * y - y0 * x) * w), x0 * x + y0 * y + z0 * z);\n  W1 += w;\n  X1 += w * (x0 + (x0 = x));\n  Y1 += w * (y0 + (y0 = y));\n  Z1 += w * (z0 + (z0 = z));\n  centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidLineEnd() {\n  centroidStream.point = centroidPoint;\n}\n\n// See J. E. Brock, The Inertia Tensor for a Spherical Triangle,\n// J. Applied Mechanics 42, 239 (1975).\nfunction centroidRingStart() {\n  centroidStream.point = centroidRingPointFirst;\n}\n\nfunction centroidRingEnd() {\n  centroidRingPoint(lambda00$2, phi00$2);\n  centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingPointFirst(lambda, phi) {\n  lambda00$2 = lambda, phi00$2 = phi;\n  lambda *= radians, phi *= radians;\n  centroidStream.point = centroidRingPoint;\n  var cosPhi = cos$1(phi);\n  x0 = cosPhi * cos$1(lambda);\n  y0 = cosPhi * sin$1(lambda);\n  z0 = sin$1(phi);\n  centroidPointCartesian(x0, y0, z0);\n}\n\nfunction centroidRingPoint(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  var cosPhi = cos$1(phi),\n      x = cosPhi * cos$1(lambda),\n      y = cosPhi * sin$1(lambda),\n      z = sin$1(phi),\n      cx = y0 * z - z0 * y,\n      cy = z0 * x - x0 * z,\n      cz = x0 * y - y0 * x,\n      m = sqrt(cx * cx + cy * cy + cz * cz),\n      w = asin(m), // line weight = angle\n      v = m && -w / m; // area weight multiplier\n  X2 += v * cx;\n  Y2 += v * cy;\n  Z2 += v * cz;\n  W1 += w;\n  X1 += w * (x0 + (x0 = x));\n  Y1 += w * (y0 + (y0 = y));\n  Z1 += w * (z0 + (z0 = z));\n  centroidPointCartesian(x0, y0, z0);\n}\n\nvar centroid = function(object) {\n  W0 = W1 =\n  X0 = Y0 = Z0 =\n  X1 = Y1 = Z1 =\n  X2 = Y2 = Z2 = 0;\n  geoStream(object, centroidStream);\n\n  var x = X2,\n      y = Y2,\n      z = Z2,\n      m = x * x + y * y + z * z;\n\n  // If the area-weighted ccentroid is undefined, fall back to length-weighted ccentroid.\n  if (m < epsilon2$1) {\n    x = X1, y = Y1, z = Z1;\n    // If the feature has zero length, fall back to arithmetic mean of point vectors.\n    if (W1 < epsilon$2) x = X0, y = Y0, z = Z0;\n    m = x * x + y * y + z * z;\n    // If the feature still has an undefined ccentroid, then return.\n    if (m < epsilon2$1) return [NaN, NaN];\n  }\n\n  return [atan2(y, x) * degrees$1, asin(z / sqrt(m)) * degrees$1];\n};\n\nvar constant$7 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar compose = function(a, b) {\n\n  function compose(x, y) {\n    return x = a(x, y), b(x[0], x[1]);\n  }\n\n  if (a.invert && b.invert) compose.invert = function(x, y) {\n    return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n  };\n\n  return compose;\n};\n\nfunction rotationIdentity(lambda, phi) {\n  return [lambda > pi$3 ? lambda - tau$3 : lambda < -pi$3 ? lambda + tau$3 : lambda, phi];\n}\n\nrotationIdentity.invert = rotationIdentity;\n\nfunction rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n  return (deltaLambda %= tau$3) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n    : rotationLambda(deltaLambda))\n    : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n    : rotationIdentity);\n}\n\nfunction forwardRotationLambda(deltaLambda) {\n  return function(lambda, phi) {\n    return lambda += deltaLambda, [lambda > pi$3 ? lambda - tau$3 : lambda < -pi$3 ? lambda + tau$3 : lambda, phi];\n  };\n}\n\nfunction rotationLambda(deltaLambda) {\n  var rotation = forwardRotationLambda(deltaLambda);\n  rotation.invert = forwardRotationLambda(-deltaLambda);\n  return rotation;\n}\n\nfunction rotationPhiGamma(deltaPhi, deltaGamma) {\n  var cosDeltaPhi = cos$1(deltaPhi),\n      sinDeltaPhi = sin$1(deltaPhi),\n      cosDeltaGamma = cos$1(deltaGamma),\n      sinDeltaGamma = sin$1(deltaGamma);\n\n  function rotation(lambda, phi) {\n    var cosPhi = cos$1(phi),\n        x = cos$1(lambda) * cosPhi,\n        y = sin$1(lambda) * cosPhi,\n        z = sin$1(phi),\n        k = z * cosDeltaPhi + x * sinDeltaPhi;\n    return [\n      atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n      asin(k * cosDeltaGamma + y * sinDeltaGamma)\n    ];\n  }\n\n  rotation.invert = function(lambda, phi) {\n    var cosPhi = cos$1(phi),\n        x = cos$1(lambda) * cosPhi,\n        y = sin$1(lambda) * cosPhi,\n        z = sin$1(phi),\n        k = z * cosDeltaGamma - y * sinDeltaGamma;\n    return [\n      atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n      asin(k * cosDeltaPhi - x * sinDeltaPhi)\n    ];\n  };\n\n  return rotation;\n}\n\nvar rotation = function(rotate) {\n  rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n  function forward(coordinates) {\n    coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n    return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n  }\n\n  forward.invert = function(coordinates) {\n    coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n    return coordinates[0] *= degrees$1, coordinates[1] *= degrees$1, coordinates;\n  };\n\n  return forward;\n};\n\n// Generates a circle centered at [0°, 0°], with a given radius and precision.\nfunction circleStream(stream, radius, delta, direction, t0, t1) {\n  if (!delta) return;\n  var cosRadius = cos$1(radius),\n      sinRadius = sin$1(radius),\n      step = direction * delta;\n  if (t0 == null) {\n    t0 = radius + direction * tau$3;\n    t1 = radius - step / 2;\n  } else {\n    t0 = circleRadius(cosRadius, t0);\n    t1 = circleRadius(cosRadius, t1);\n    if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau$3;\n  }\n  for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n    point = spherical([cosRadius, -sinRadius * cos$1(t), -sinRadius * sin$1(t)]);\n    stream.point(point[0], point[1]);\n  }\n}\n\n// Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\nfunction circleRadius(cosRadius, point) {\n  point = cartesian(point), point[0] -= cosRadius;\n  cartesianNormalizeInPlace(point);\n  var radius = acos(-point[1]);\n  return ((-point[2] < 0 ? -radius : radius) + tau$3 - epsilon$2) % tau$3;\n}\n\nvar circle = function() {\n  var center = constant$7([0, 0]),\n      radius = constant$7(90),\n      precision = constant$7(6),\n      ring,\n      rotate,\n      stream = {point: point};\n\n  function point(x, y) {\n    ring.push(x = rotate(x, y));\n    x[0] *= degrees$1, x[1] *= degrees$1;\n  }\n\n  function circle() {\n    var c = center.apply(this, arguments),\n        r = radius.apply(this, arguments) * radians,\n        p = precision.apply(this, arguments) * radians;\n    ring = [];\n    rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n    circleStream(stream, r, p, 1);\n    c = {type: \"Polygon\", coordinates: [ring]};\n    ring = rotate = null;\n    return c;\n  }\n\n  circle.center = function(_) {\n    return arguments.length ? (center = typeof _ === \"function\" ? _ : constant$7([+_[0], +_[1]]), circle) : center;\n  };\n\n  circle.radius = function(_) {\n    return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant$7(+_), circle) : radius;\n  };\n\n  circle.precision = function(_) {\n    return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant$7(+_), circle) : precision;\n  };\n\n  return circle;\n};\n\nvar clipBuffer = function() {\n  var lines = [],\n      line;\n  return {\n    point: function(x, y) {\n      line.push([x, y]);\n    },\n    lineStart: function() {\n      lines.push(line = []);\n    },\n    lineEnd: noop$1,\n    rejoin: function() {\n      if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n    },\n    result: function() {\n      var result = lines;\n      lines = [];\n      line = null;\n      return result;\n    }\n  };\n};\n\nvar clipLine = function(a, b, x0, y0, x1, y1) {\n  var ax = a[0],\n      ay = a[1],\n      bx = b[0],\n      by = b[1],\n      t0 = 0,\n      t1 = 1,\n      dx = bx - ax,\n      dy = by - ay,\n      r;\n\n  r = x0 - ax;\n  if (!dx && r > 0) return;\n  r /= dx;\n  if (dx < 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  } else if (dx > 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  }\n\n  r = x1 - ax;\n  if (!dx && r < 0) return;\n  r /= dx;\n  if (dx < 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  } else if (dx > 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  }\n\n  r = y0 - ay;\n  if (!dy && r > 0) return;\n  r /= dy;\n  if (dy < 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  } else if (dy > 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  }\n\n  r = y1 - ay;\n  if (!dy && r < 0) return;\n  r /= dy;\n  if (dy < 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  } else if (dy > 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  }\n\n  if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n  if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n  return true;\n};\n\nvar pointEqual = function(a, b) {\n  return abs(a[0] - b[0]) < epsilon$2 && abs(a[1] - b[1]) < epsilon$2;\n};\n\nfunction Intersection(point, points, other, entry) {\n  this.x = point;\n  this.z = points;\n  this.o = other; // another intersection\n  this.e = entry; // is an entry?\n  this.v = false; // visited\n  this.n = this.p = null; // next & previous\n}\n\n// A generalized polygon clipping algorithm: given a polygon that has been cut\n// into its visible line segments, and rejoins the segments by interpolating\n// along the clip edge.\nvar clipPolygon = function(segments, compareIntersection, startInside, interpolate, stream) {\n  var subject = [],\n      clip = [],\n      i,\n      n;\n\n  segments.forEach(function(segment) {\n    if ((n = segment.length - 1) <= 0) return;\n    var n, p0 = segment[0], p1 = segment[n], x;\n\n    // If the first and last points of a segment are coincident, then treat as a\n    // closed ring. TODO if all rings are closed, then the winding order of the\n    // exterior ring should be checked.\n    if (pointEqual(p0, p1)) {\n      stream.lineStart();\n      for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n      stream.lineEnd();\n      return;\n    }\n\n    subject.push(x = new Intersection(p0, segment, null, true));\n    clip.push(x.o = new Intersection(p0, null, x, false));\n    subject.push(x = new Intersection(p1, segment, null, false));\n    clip.push(x.o = new Intersection(p1, null, x, true));\n  });\n\n  if (!subject.length) return;\n\n  clip.sort(compareIntersection);\n  link$1(subject);\n  link$1(clip);\n\n  for (i = 0, n = clip.length; i < n; ++i) {\n    clip[i].e = startInside = !startInside;\n  }\n\n  var start = subject[0],\n      points,\n      point;\n\n  while (1) {\n    // Find first unvisited intersection.\n    var current = start,\n        isSubject = true;\n    while (current.v) if ((current = current.n) === start) return;\n    points = current.z;\n    stream.lineStart();\n    do {\n      current.v = current.o.v = true;\n      if (current.e) {\n        if (isSubject) {\n          for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n        } else {\n          interpolate(current.x, current.n.x, 1, stream);\n        }\n        current = current.n;\n      } else {\n        if (isSubject) {\n          points = current.p.z;\n          for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n        } else {\n          interpolate(current.x, current.p.x, -1, stream);\n        }\n        current = current.p;\n      }\n      current = current.o;\n      points = current.z;\n      isSubject = !isSubject;\n    } while (!current.v);\n    stream.lineEnd();\n  }\n};\n\nfunction link$1(array) {\n  if (!(n = array.length)) return;\n  var n,\n      i = 0,\n      a = array[0],\n      b;\n  while (++i < n) {\n    a.n = b = array[i];\n    b.p = a;\n    a = b;\n  }\n  a.n = b = array[0];\n  b.p = a;\n}\n\nvar clipMax = 1e9;\nvar clipMin = -clipMax;\n\n// TODO Use d3-polygon’s polygonContains here for the ring check?\n// TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\nfunction clipExtent(x0, y0, x1, y1) {\n\n  function visible(x, y) {\n    return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n  }\n\n  function interpolate(from, to, direction, stream) {\n    var a = 0, a1 = 0;\n    if (from == null\n        || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n        || comparePoint(from, to) < 0 ^ direction > 0) {\n      do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n      while ((a = (a + direction + 4) % 4) !== a1);\n    } else {\n      stream.point(to[0], to[1]);\n    }\n  }\n\n  function corner(p, direction) {\n    return abs(p[0] - x0) < epsilon$2 ? direction > 0 ? 0 : 3\n        : abs(p[0] - x1) < epsilon$2 ? direction > 0 ? 2 : 1\n        : abs(p[1] - y0) < epsilon$2 ? direction > 0 ? 1 : 0\n        : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n  }\n\n  function compareIntersection(a, b) {\n    return comparePoint(a.x, b.x);\n  }\n\n  function comparePoint(a, b) {\n    var ca = corner(a, 1),\n        cb = corner(b, 1);\n    return ca !== cb ? ca - cb\n        : ca === 0 ? b[1] - a[1]\n        : ca === 1 ? a[0] - b[0]\n        : ca === 2 ? a[1] - b[1]\n        : b[0] - a[0];\n  }\n\n  return function(stream) {\n    var activeStream = stream,\n        bufferStream = clipBuffer(),\n        segments,\n        polygon,\n        ring,\n        x__, y__, v__, // first point\n        x_, y_, v_, // previous point\n        first,\n        clean;\n\n    var clipStream = {\n      point: point,\n      lineStart: lineStart,\n      lineEnd: lineEnd,\n      polygonStart: polygonStart,\n      polygonEnd: polygonEnd\n    };\n\n    function point(x, y) {\n      if (visible(x, y)) activeStream.point(x, y);\n    }\n\n    function polygonInside() {\n      var winding = 0;\n\n      for (var i = 0, n = polygon.length; i < n; ++i) {\n        for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n          a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n          if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n          else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n        }\n      }\n\n      return winding;\n    }\n\n    // Buffer geometry within a polygon and then clip it en masse.\n    function polygonStart() {\n      activeStream = bufferStream, segments = [], polygon = [], clean = true;\n    }\n\n    function polygonEnd() {\n      var startInside = polygonInside(),\n          cleanInside = clean && startInside,\n          visible = (segments = merge(segments)).length;\n      if (cleanInside || visible) {\n        stream.polygonStart();\n        if (cleanInside) {\n          stream.lineStart();\n          interpolate(null, null, 1, stream);\n          stream.lineEnd();\n        }\n        if (visible) {\n          clipPolygon(segments, compareIntersection, startInside, interpolate, stream);\n        }\n        stream.polygonEnd();\n      }\n      activeStream = stream, segments = polygon = ring = null;\n    }\n\n    function lineStart() {\n      clipStream.point = linePoint;\n      if (polygon) polygon.push(ring = []);\n      first = true;\n      v_ = false;\n      x_ = y_ = NaN;\n    }\n\n    // TODO rather than special-case polygons, simply handle them separately.\n    // Ideally, coincident intersection points should be jittered to avoid\n    // clipping issues.\n    function lineEnd() {\n      if (segments) {\n        linePoint(x__, y__);\n        if (v__ && v_) bufferStream.rejoin();\n        segments.push(bufferStream.result());\n      }\n      clipStream.point = point;\n      if (v_) activeStream.lineEnd();\n    }\n\n    function linePoint(x, y) {\n      var v = visible(x, y);\n      if (polygon) ring.push([x, y]);\n      if (first) {\n        x__ = x, y__ = y, v__ = v;\n        first = false;\n        if (v) {\n          activeStream.lineStart();\n          activeStream.point(x, y);\n        }\n      } else {\n        if (v && v_) activeStream.point(x, y);\n        else {\n          var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n              b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n          if (clipLine(a, b, x0, y0, x1, y1)) {\n            if (!v_) {\n              activeStream.lineStart();\n              activeStream.point(a[0], a[1]);\n            }\n            activeStream.point(b[0], b[1]);\n            if (!v) activeStream.lineEnd();\n            clean = false;\n          } else if (v) {\n            activeStream.lineStart();\n            activeStream.point(x, y);\n            clean = false;\n          }\n        }\n      }\n      x_ = x, y_ = y, v_ = v;\n    }\n\n    return clipStream;\n  };\n}\n\nvar extent$1 = function() {\n  var x0 = 0,\n      y0 = 0,\n      x1 = 960,\n      y1 = 500,\n      cache,\n      cacheStream,\n      clip;\n\n  return clip = {\n    stream: function(stream) {\n      return cache && cacheStream === stream ? cache : cache = clipExtent(x0, y0, x1, y1)(cacheStream = stream);\n    },\n    extent: function(_) {\n      return arguments.length ? (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1], cache = cacheStream = null, clip) : [[x0, y0], [x1, y1]];\n    }\n  };\n};\n\nvar sum$1 = adder();\n\nvar polygonContains = function(polygon, point) {\n  var lambda = point[0],\n      phi = point[1],\n      normal = [sin$1(lambda), -cos$1(lambda), 0],\n      angle = 0,\n      winding = 0;\n\n  sum$1.reset();\n\n  for (var i = 0, n = polygon.length; i < n; ++i) {\n    if (!(m = (ring = polygon[i]).length)) continue;\n    var ring,\n        m,\n        point0 = ring[m - 1],\n        lambda0 = point0[0],\n        phi0 = point0[1] / 2 + quarterPi,\n        sinPhi0 = sin$1(phi0),\n        cosPhi0 = cos$1(phi0);\n\n    for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n      var point1 = ring[j],\n          lambda1 = point1[0],\n          phi1 = point1[1] / 2 + quarterPi,\n          sinPhi1 = sin$1(phi1),\n          cosPhi1 = cos$1(phi1),\n          delta = lambda1 - lambda0,\n          sign$$1 = delta >= 0 ? 1 : -1,\n          absDelta = sign$$1 * delta,\n          antimeridian = absDelta > pi$3,\n          k = sinPhi0 * sinPhi1;\n\n      sum$1.add(atan2(k * sign$$1 * sin$1(absDelta), cosPhi0 * cosPhi1 + k * cos$1(absDelta)));\n      angle += antimeridian ? delta + sign$$1 * tau$3 : delta;\n\n      // Are the longitudes either side of the point’s meridian (lambda),\n      // and are the latitudes smaller than the parallel (phi)?\n      if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n        var arc = cartesianCross(cartesian(point0), cartesian(point1));\n        cartesianNormalizeInPlace(arc);\n        var intersection = cartesianCross(normal, arc);\n        cartesianNormalizeInPlace(intersection);\n        var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin(intersection[2]);\n        if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n          winding += antimeridian ^ delta >= 0 ? 1 : -1;\n        }\n      }\n    }\n  }\n\n  // First, determine whether the South pole is inside or outside:\n  //\n  // It is inside if:\n  // * the polygon winds around it in a clockwise direction.\n  // * the polygon does not (cumulatively) wind around it, but has a negative\n  //   (counter-clockwise) area.\n  //\n  // Second, count the (signed) number of times a segment crosses a lambda\n  // from the point to the South pole.  If it is zero, then the point is the\n  // same side as the South pole.\n\n  return (angle < -epsilon$2 || angle < epsilon$2 && sum$1 < -epsilon$2) ^ (winding & 1);\n};\n\nvar lengthSum = adder();\nvar lambda0$2;\nvar sinPhi0$1;\nvar cosPhi0$1;\n\nvar lengthStream = {\n  sphere: noop$1,\n  point: noop$1,\n  lineStart: lengthLineStart,\n  lineEnd: noop$1,\n  polygonStart: noop$1,\n  polygonEnd: noop$1\n};\n\nfunction lengthLineStart() {\n  lengthStream.point = lengthPointFirst;\n  lengthStream.lineEnd = lengthLineEnd;\n}\n\nfunction lengthLineEnd() {\n  lengthStream.point = lengthStream.lineEnd = noop$1;\n}\n\nfunction lengthPointFirst(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  lambda0$2 = lambda, sinPhi0$1 = sin$1(phi), cosPhi0$1 = cos$1(phi);\n  lengthStream.point = lengthPoint;\n}\n\nfunction lengthPoint(lambda, phi) {\n  lambda *= radians, phi *= radians;\n  var sinPhi = sin$1(phi),\n      cosPhi = cos$1(phi),\n      delta = abs(lambda - lambda0$2),\n      cosDelta = cos$1(delta),\n      sinDelta = sin$1(delta),\n      x = cosPhi * sinDelta,\n      y = cosPhi0$1 * sinPhi - sinPhi0$1 * cosPhi * cosDelta,\n      z = sinPhi0$1 * sinPhi + cosPhi0$1 * cosPhi * cosDelta;\n  lengthSum.add(atan2(sqrt(x * x + y * y), z));\n  lambda0$2 = lambda, sinPhi0$1 = sinPhi, cosPhi0$1 = cosPhi;\n}\n\nvar length$1 = function(object) {\n  lengthSum.reset();\n  geoStream(object, lengthStream);\n  return +lengthSum;\n};\n\nvar coordinates = [null, null];\nvar object$1 = {type: \"LineString\", coordinates: coordinates};\n\nvar distance = function(a, b) {\n  coordinates[0] = a;\n  coordinates[1] = b;\n  return length$1(object$1);\n};\n\nvar containsObjectType = {\n  Feature: function(object, point) {\n    return containsGeometry(object.geometry, point);\n  },\n  FeatureCollection: function(object, point) {\n    var features = object.features, i = -1, n = features.length;\n    while (++i < n) if (containsGeometry(features[i].geometry, point)) return true;\n    return false;\n  }\n};\n\nvar containsGeometryType = {\n  Sphere: function() {\n    return true;\n  },\n  Point: function(object, point) {\n    return containsPoint(object.coordinates, point);\n  },\n  MultiPoint: function(object, point) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) if (containsPoint(coordinates[i], point)) return true;\n    return false;\n  },\n  LineString: function(object, point) {\n    return containsLine(object.coordinates, point);\n  },\n  MultiLineString: function(object, point) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) if (containsLine(coordinates[i], point)) return true;\n    return false;\n  },\n  Polygon: function(object, point) {\n    return containsPolygon(object.coordinates, point);\n  },\n  MultiPolygon: function(object, point) {\n    var coordinates = object.coordinates, i = -1, n = coordinates.length;\n    while (++i < n) if (containsPolygon(coordinates[i], point)) return true;\n    return false;\n  },\n  GeometryCollection: function(object, point) {\n    var geometries = object.geometries, i = -1, n = geometries.length;\n    while (++i < n) if (containsGeometry(geometries[i], point)) return true;\n    return false;\n  }\n};\n\nfunction containsGeometry(geometry, point) {\n  return geometry && containsGeometryType.hasOwnProperty(geometry.type)\n      ? containsGeometryType[geometry.type](geometry, point)\n      : false;\n}\n\nfunction containsPoint(coordinates, point) {\n  return distance(coordinates, point) === 0;\n}\n\nfunction containsLine(coordinates, point) {\n  var ab = distance(coordinates[0], coordinates[1]),\n      ao = distance(coordinates[0], point),\n      ob = distance(point, coordinates[1]);\n  return ao + ob <= ab + epsilon$2;\n}\n\nfunction containsPolygon(coordinates, point) {\n  return !!polygonContains(coordinates.map(ringRadians), pointRadians(point));\n}\n\nfunction ringRadians(ring) {\n  return ring = ring.map(pointRadians), ring.pop(), ring;\n}\n\nfunction pointRadians(point) {\n  return [point[0] * radians, point[1] * radians];\n}\n\nvar contains = function(object, point) {\n  return (object && containsObjectType.hasOwnProperty(object.type)\n      ? containsObjectType[object.type]\n      : containsGeometry)(object, point);\n};\n\nfunction graticuleX(y0, y1, dy) {\n  var y = sequence(y0, y1 - epsilon$2, dy).concat(y1);\n  return function(x) { return y.map(function(y) { return [x, y]; }); };\n}\n\nfunction graticuleY(x0, x1, dx) {\n  var x = sequence(x0, x1 - epsilon$2, dx).concat(x1);\n  return function(y) { return x.map(function(x) { return [x, y]; }); };\n}\n\nfunction graticule() {\n  var x1, x0, X1, X0,\n      y1, y0, Y1, Y0,\n      dx = 10, dy = dx, DX = 90, DY = 360,\n      x, y, X, Y,\n      precision = 2.5;\n\n  function graticule() {\n    return {type: \"MultiLineString\", coordinates: lines()};\n  }\n\n  function lines() {\n    return sequence(ceil(X0 / DX) * DX, X1, DX).map(X)\n        .concat(sequence(ceil(Y0 / DY) * DY, Y1, DY).map(Y))\n        .concat(sequence(ceil(x0 / dx) * dx, x1, dx).filter(function(x) { return abs(x % DX) > epsilon$2; }).map(x))\n        .concat(sequence(ceil(y0 / dy) * dy, y1, dy).filter(function(y) { return abs(y % DY) > epsilon$2; }).map(y));\n  }\n\n  graticule.lines = function() {\n    return lines().map(function(coordinates) { return {type: \"LineString\", coordinates: coordinates}; });\n  };\n\n  graticule.outline = function() {\n    return {\n      type: \"Polygon\",\n      coordinates: [\n        X(X0).concat(\n        Y(Y1).slice(1),\n        X(X1).reverse().slice(1),\n        Y(Y0).reverse().slice(1))\n      ]\n    };\n  };\n\n  graticule.extent = function(_) {\n    if (!arguments.length) return graticule.extentMinor();\n    return graticule.extentMajor(_).extentMinor(_);\n  };\n\n  graticule.extentMajor = function(_) {\n    if (!arguments.length) return [[X0, Y0], [X1, Y1]];\n    X0 = +_[0][0], X1 = +_[1][0];\n    Y0 = +_[0][1], Y1 = +_[1][1];\n    if (X0 > X1) _ = X0, X0 = X1, X1 = _;\n    if (Y0 > Y1) _ = Y0, Y0 = Y1, Y1 = _;\n    return graticule.precision(precision);\n  };\n\n  graticule.extentMinor = function(_) {\n    if (!arguments.length) return [[x0, y0], [x1, y1]];\n    x0 = +_[0][0], x1 = +_[1][0];\n    y0 = +_[0][1], y1 = +_[1][1];\n    if (x0 > x1) _ = x0, x0 = x1, x1 = _;\n    if (y0 > y1) _ = y0, y0 = y1, y1 = _;\n    return graticule.precision(precision);\n  };\n\n  graticule.step = function(_) {\n    if (!arguments.length) return graticule.stepMinor();\n    return graticule.stepMajor(_).stepMinor(_);\n  };\n\n  graticule.stepMajor = function(_) {\n    if (!arguments.length) return [DX, DY];\n    DX = +_[0], DY = +_[1];\n    return graticule;\n  };\n\n  graticule.stepMinor = function(_) {\n    if (!arguments.length) return [dx, dy];\n    dx = +_[0], dy = +_[1];\n    return graticule;\n  };\n\n  graticule.precision = function(_) {\n    if (!arguments.length) return precision;\n    precision = +_;\n    x = graticuleX(y0, y1, 90);\n    y = graticuleY(x0, x1, precision);\n    X = graticuleX(Y0, Y1, 90);\n    Y = graticuleY(X0, X1, precision);\n    return graticule;\n  };\n\n  return graticule\n      .extentMajor([[-180, -90 + epsilon$2], [180, 90 - epsilon$2]])\n      .extentMinor([[-180, -80 - epsilon$2], [180, 80 + epsilon$2]]);\n}\n\nfunction graticule10() {\n  return graticule()();\n}\n\nvar interpolate$1 = function(a, b) {\n  var x0 = a[0] * radians,\n      y0 = a[1] * radians,\n      x1 = b[0] * radians,\n      y1 = b[1] * radians,\n      cy0 = cos$1(y0),\n      sy0 = sin$1(y0),\n      cy1 = cos$1(y1),\n      sy1 = sin$1(y1),\n      kx0 = cy0 * cos$1(x0),\n      ky0 = cy0 * sin$1(x0),\n      kx1 = cy1 * cos$1(x1),\n      ky1 = cy1 * sin$1(x1),\n      d = 2 * asin(sqrt(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),\n      k = sin$1(d);\n\n  var interpolate = d ? function(t) {\n    var B = sin$1(t *= d) / k,\n        A = sin$1(d - t) / k,\n        x = A * kx0 + B * kx1,\n        y = A * ky0 + B * ky1,\n        z = A * sy0 + B * sy1;\n    return [\n      atan2(y, x) * degrees$1,\n      atan2(z, sqrt(x * x + y * y)) * degrees$1\n    ];\n  } : function() {\n    return [x0 * degrees$1, y0 * degrees$1];\n  };\n\n  interpolate.distance = d;\n\n  return interpolate;\n};\n\nvar identity$4 = function(x) {\n  return x;\n};\n\nvar areaSum$1 = adder();\nvar areaRingSum$1 = adder();\nvar x00;\nvar y00;\nvar x0$1;\nvar y0$1;\n\nvar areaStream$1 = {\n  point: noop$1,\n  lineStart: noop$1,\n  lineEnd: noop$1,\n  polygonStart: function() {\n    areaStream$1.lineStart = areaRingStart$1;\n    areaStream$1.lineEnd = areaRingEnd$1;\n  },\n  polygonEnd: function() {\n    areaStream$1.lineStart = areaStream$1.lineEnd = areaStream$1.point = noop$1;\n    areaSum$1.add(abs(areaRingSum$1));\n    areaRingSum$1.reset();\n  },\n  result: function() {\n    var area = areaSum$1 / 2;\n    areaSum$1.reset();\n    return area;\n  }\n};\n\nfunction areaRingStart$1() {\n  areaStream$1.point = areaPointFirst$1;\n}\n\nfunction areaPointFirst$1(x, y) {\n  areaStream$1.point = areaPoint$1;\n  x00 = x0$1 = x, y00 = y0$1 = y;\n}\n\nfunction areaPoint$1(x, y) {\n  areaRingSum$1.add(y0$1 * x - x0$1 * y);\n  x0$1 = x, y0$1 = y;\n}\n\nfunction areaRingEnd$1() {\n  areaPoint$1(x00, y00);\n}\n\nvar x0$2 = Infinity;\nvar y0$2 = x0$2;\nvar x1 = -x0$2;\nvar y1 = x1;\n\nvar boundsStream$1 = {\n  point: boundsPoint$1,\n  lineStart: noop$1,\n  lineEnd: noop$1,\n  polygonStart: noop$1,\n  polygonEnd: noop$1,\n  result: function() {\n    var bounds = [[x0$2, y0$2], [x1, y1]];\n    x1 = y1 = -(y0$2 = x0$2 = Infinity);\n    return bounds;\n  }\n};\n\nfunction boundsPoint$1(x, y) {\n  if (x < x0$2) x0$2 = x;\n  if (x > x1) x1 = x;\n  if (y < y0$2) y0$2 = y;\n  if (y > y1) y1 = y;\n}\n\n// TODO Enforce positive area for exterior, negative area for interior?\n\nvar X0$1 = 0;\nvar Y0$1 = 0;\nvar Z0$1 = 0;\nvar X1$1 = 0;\nvar Y1$1 = 0;\nvar Z1$1 = 0;\nvar X2$1 = 0;\nvar Y2$1 = 0;\nvar Z2$1 = 0;\nvar x00$1;\nvar y00$1;\nvar x0$3;\nvar y0$3;\n\nvar centroidStream$1 = {\n  point: centroidPoint$1,\n  lineStart: centroidLineStart$1,\n  lineEnd: centroidLineEnd$1,\n  polygonStart: function() {\n    centroidStream$1.lineStart = centroidRingStart$1;\n    centroidStream$1.lineEnd = centroidRingEnd$1;\n  },\n  polygonEnd: function() {\n    centroidStream$1.point = centroidPoint$1;\n    centroidStream$1.lineStart = centroidLineStart$1;\n    centroidStream$1.lineEnd = centroidLineEnd$1;\n  },\n  result: function() {\n    var centroid = Z2$1 ? [X2$1 / Z2$1, Y2$1 / Z2$1]\n        : Z1$1 ? [X1$1 / Z1$1, Y1$1 / Z1$1]\n        : Z0$1 ? [X0$1 / Z0$1, Y0$1 / Z0$1]\n        : [NaN, NaN];\n    X0$1 = Y0$1 = Z0$1 =\n    X1$1 = Y1$1 = Z1$1 =\n    X2$1 = Y2$1 = Z2$1 = 0;\n    return centroid;\n  }\n};\n\nfunction centroidPoint$1(x, y) {\n  X0$1 += x;\n  Y0$1 += y;\n  ++Z0$1;\n}\n\nfunction centroidLineStart$1() {\n  centroidStream$1.point = centroidPointFirstLine;\n}\n\nfunction centroidPointFirstLine(x, y) {\n  centroidStream$1.point = centroidPointLine;\n  centroidPoint$1(x0$3 = x, y0$3 = y);\n}\n\nfunction centroidPointLine(x, y) {\n  var dx = x - x0$3, dy = y - y0$3, z = sqrt(dx * dx + dy * dy);\n  X1$1 += z * (x0$3 + x) / 2;\n  Y1$1 += z * (y0$3 + y) / 2;\n  Z1$1 += z;\n  centroidPoint$1(x0$3 = x, y0$3 = y);\n}\n\nfunction centroidLineEnd$1() {\n  centroidStream$1.point = centroidPoint$1;\n}\n\nfunction centroidRingStart$1() {\n  centroidStream$1.point = centroidPointFirstRing;\n}\n\nfunction centroidRingEnd$1() {\n  centroidPointRing(x00$1, y00$1);\n}\n\nfunction centroidPointFirstRing(x, y) {\n  centroidStream$1.point = centroidPointRing;\n  centroidPoint$1(x00$1 = x0$3 = x, y00$1 = y0$3 = y);\n}\n\nfunction centroidPointRing(x, y) {\n  var dx = x - x0$3,\n      dy = y - y0$3,\n      z = sqrt(dx * dx + dy * dy);\n\n  X1$1 += z * (x0$3 + x) / 2;\n  Y1$1 += z * (y0$3 + y) / 2;\n  Z1$1 += z;\n\n  z = y0$3 * x - x0$3 * y;\n  X2$1 += z * (x0$3 + x);\n  Y2$1 += z * (y0$3 + y);\n  Z2$1 += z * 3;\n  centroidPoint$1(x0$3 = x, y0$3 = y);\n}\n\nfunction PathContext(context) {\n  this._context = context;\n}\n\nPathContext.prototype = {\n  _radius: 4.5,\n  pointRadius: function(_) {\n    return this._radius = _, this;\n  },\n  polygonStart: function() {\n    this._line = 0;\n  },\n  polygonEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line === 0) this._context.closePath();\n    this._point = NaN;\n  },\n  point: function(x, y) {\n    switch (this._point) {\n      case 0: {\n        this._context.moveTo(x, y);\n        this._point = 1;\n        break;\n      }\n      case 1: {\n        this._context.lineTo(x, y);\n        break;\n      }\n      default: {\n        this._context.moveTo(x + this._radius, y);\n        this._context.arc(x, y, this._radius, 0, tau$3);\n        break;\n      }\n    }\n  },\n  result: noop$1\n};\n\nvar lengthSum$1 = adder();\nvar lengthRing;\nvar x00$2;\nvar y00$2;\nvar x0$4;\nvar y0$4;\n\nvar lengthStream$1 = {\n  point: noop$1,\n  lineStart: function() {\n    lengthStream$1.point = lengthPointFirst$1;\n  },\n  lineEnd: function() {\n    if (lengthRing) lengthPoint$1(x00$2, y00$2);\n    lengthStream$1.point = noop$1;\n  },\n  polygonStart: function() {\n    lengthRing = true;\n  },\n  polygonEnd: function() {\n    lengthRing = null;\n  },\n  result: function() {\n    var length = +lengthSum$1;\n    lengthSum$1.reset();\n    return length;\n  }\n};\n\nfunction lengthPointFirst$1(x, y) {\n  lengthStream$1.point = lengthPoint$1;\n  x00$2 = x0$4 = x, y00$2 = y0$4 = y;\n}\n\nfunction lengthPoint$1(x, y) {\n  x0$4 -= x, y0$4 -= y;\n  lengthSum$1.add(sqrt(x0$4 * x0$4 + y0$4 * y0$4));\n  x0$4 = x, y0$4 = y;\n}\n\nfunction PathString() {\n  this._string = [];\n}\n\nPathString.prototype = {\n  _radius: 4.5,\n  _circle: circle$1(4.5),\n  pointRadius: function(_) {\n    if ((_ = +_) !== this._radius) this._radius = _, this._circle = null;\n    return this;\n  },\n  polygonStart: function() {\n    this._line = 0;\n  },\n  polygonEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line === 0) this._string.push(\"Z\");\n    this._point = NaN;\n  },\n  point: function(x, y) {\n    switch (this._point) {\n      case 0: {\n        this._string.push(\"M\", x, \",\", y);\n        this._point = 1;\n        break;\n      }\n      case 1: {\n        this._string.push(\"L\", x, \",\", y);\n        break;\n      }\n      default: {\n        if (this._circle == null) this._circle = circle$1(this._radius);\n        this._string.push(\"M\", x, \",\", y, this._circle);\n        break;\n      }\n    }\n  },\n  result: function() {\n    if (this._string.length) {\n      var result = this._string.join(\"\");\n      this._string = [];\n      return result;\n    } else {\n      return null;\n    }\n  }\n};\n\nfunction circle$1(radius) {\n  return \"m0,\" + radius\n      + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + -2 * radius\n      + \"a\" + radius + \",\" + radius + \" 0 1,1 0,\" + 2 * radius\n      + \"z\";\n}\n\nvar index$1 = function(projection, context) {\n  var pointRadius = 4.5,\n      projectionStream,\n      contextStream;\n\n  function path(object) {\n    if (object) {\n      if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n      geoStream(object, projectionStream(contextStream));\n    }\n    return contextStream.result();\n  }\n\n  path.area = function(object) {\n    geoStream(object, projectionStream(areaStream$1));\n    return areaStream$1.result();\n  };\n\n  path.measure = function(object) {\n    geoStream(object, projectionStream(lengthStream$1));\n    return lengthStream$1.result();\n  };\n\n  path.bounds = function(object) {\n    geoStream(object, projectionStream(boundsStream$1));\n    return boundsStream$1.result();\n  };\n\n  path.centroid = function(object) {\n    geoStream(object, projectionStream(centroidStream$1));\n    return centroidStream$1.result();\n  };\n\n  path.projection = function(_) {\n    return arguments.length ? (projectionStream = _ == null ? (projection = null, identity$4) : (projection = _).stream, path) : projection;\n  };\n\n  path.context = function(_) {\n    if (!arguments.length) return context;\n    contextStream = _ == null ? (context = null, new PathString) : new PathContext(context = _);\n    if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n    return path;\n  };\n\n  path.pointRadius = function(_) {\n    if (!arguments.length) return pointRadius;\n    pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n    return path;\n  };\n\n  return path.projection(projection).context(context);\n};\n\nvar clip = function(pointVisible, clipLine, interpolate, start) {\n  return function(rotate, sink) {\n    var line = clipLine(sink),\n        rotatedStart = rotate.invert(start[0], start[1]),\n        ringBuffer = clipBuffer(),\n        ringSink = clipLine(ringBuffer),\n        polygonStarted = false,\n        polygon,\n        segments,\n        ring;\n\n    var clip = {\n      point: point,\n      lineStart: lineStart,\n      lineEnd: lineEnd,\n      polygonStart: function() {\n        clip.point = pointRing;\n        clip.lineStart = ringStart;\n        clip.lineEnd = ringEnd;\n        segments = [];\n        polygon = [];\n      },\n      polygonEnd: function() {\n        clip.point = point;\n        clip.lineStart = lineStart;\n        clip.lineEnd = lineEnd;\n        segments = merge(segments);\n        var startInside = polygonContains(polygon, rotatedStart);\n        if (segments.length) {\n          if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n          clipPolygon(segments, compareIntersection, startInside, interpolate, sink);\n        } else if (startInside) {\n          if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n          sink.lineStart();\n          interpolate(null, null, 1, sink);\n          sink.lineEnd();\n        }\n        if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n        segments = polygon = null;\n      },\n      sphere: function() {\n        sink.polygonStart();\n        sink.lineStart();\n        interpolate(null, null, 1, sink);\n        sink.lineEnd();\n        sink.polygonEnd();\n      }\n    };\n\n    function point(lambda, phi) {\n      var point = rotate(lambda, phi);\n      if (pointVisible(lambda = point[0], phi = point[1])) sink.point(lambda, phi);\n    }\n\n    function pointLine(lambda, phi) {\n      var point = rotate(lambda, phi);\n      line.point(point[0], point[1]);\n    }\n\n    function lineStart() {\n      clip.point = pointLine;\n      line.lineStart();\n    }\n\n    function lineEnd() {\n      clip.point = point;\n      line.lineEnd();\n    }\n\n    function pointRing(lambda, phi) {\n      ring.push([lambda, phi]);\n      var point = rotate(lambda, phi);\n      ringSink.point(point[0], point[1]);\n    }\n\n    function ringStart() {\n      ringSink.lineStart();\n      ring = [];\n    }\n\n    function ringEnd() {\n      pointRing(ring[0][0], ring[0][1]);\n      ringSink.lineEnd();\n\n      var clean = ringSink.clean(),\n          ringSegments = ringBuffer.result(),\n          i, n = ringSegments.length, m,\n          segment,\n          point;\n\n      ring.pop();\n      polygon.push(ring);\n      ring = null;\n\n      if (!n) return;\n\n      // No intersections.\n      if (clean & 1) {\n        segment = ringSegments[0];\n        if ((m = segment.length - 1) > 0) {\n          if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n          sink.lineStart();\n          for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n          sink.lineEnd();\n        }\n        return;\n      }\n\n      // Rejoin connected segments.\n      // TODO reuse ringBuffer.rejoin()?\n      if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n      segments.push(ringSegments.filter(validSegment));\n    }\n\n    return clip;\n  };\n};\n\nfunction validSegment(segment) {\n  return segment.length > 1;\n}\n\n// Intersections are sorted along the clip edge. For both antimeridian cutting\n// and circle clipping, the same comparison is used.\nfunction compareIntersection(a, b) {\n  return ((a = a.x)[0] < 0 ? a[1] - halfPi$2 - epsilon$2 : halfPi$2 - a[1])\n       - ((b = b.x)[0] < 0 ? b[1] - halfPi$2 - epsilon$2 : halfPi$2 - b[1]);\n}\n\nvar clipAntimeridian = clip(\n  function() { return true; },\n  clipAntimeridianLine,\n  clipAntimeridianInterpolate,\n  [-pi$3, -halfPi$2]\n);\n\n// Takes a line and cuts into visible segments. Return values: 0 - there were\n// intersections or the line was empty; 1 - no intersections; 2 - there were\n// intersections, and the first and last segments should be rejoined.\nfunction clipAntimeridianLine(stream) {\n  var lambda0 = NaN,\n      phi0 = NaN,\n      sign0 = NaN,\n      clean; // no intersections\n\n  return {\n    lineStart: function() {\n      stream.lineStart();\n      clean = 1;\n    },\n    point: function(lambda1, phi1) {\n      var sign1 = lambda1 > 0 ? pi$3 : -pi$3,\n          delta = abs(lambda1 - lambda0);\n      if (abs(delta - pi$3) < epsilon$2) { // line crosses a pole\n        stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi$2 : -halfPi$2);\n        stream.point(sign0, phi0);\n        stream.lineEnd();\n        stream.lineStart();\n        stream.point(sign1, phi0);\n        stream.point(lambda1, phi0);\n        clean = 0;\n      } else if (sign0 !== sign1 && delta >= pi$3) { // line crosses antimeridian\n        if (abs(lambda0 - sign0) < epsilon$2) lambda0 -= sign0 * epsilon$2; // handle degeneracies\n        if (abs(lambda1 - sign1) < epsilon$2) lambda1 -= sign1 * epsilon$2;\n        phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n        stream.point(sign0, phi0);\n        stream.lineEnd();\n        stream.lineStart();\n        stream.point(sign1, phi0);\n        clean = 0;\n      }\n      stream.point(lambda0 = lambda1, phi0 = phi1);\n      sign0 = sign1;\n    },\n    lineEnd: function() {\n      stream.lineEnd();\n      lambda0 = phi0 = NaN;\n    },\n    clean: function() {\n      return 2 - clean; // if intersections, rejoin first and last segments\n    }\n  };\n}\n\nfunction clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n  var cosPhi0,\n      cosPhi1,\n      sinLambda0Lambda1 = sin$1(lambda0 - lambda1);\n  return abs(sinLambda0Lambda1) > epsilon$2\n      ? atan((sin$1(phi0) * (cosPhi1 = cos$1(phi1)) * sin$1(lambda1)\n          - sin$1(phi1) * (cosPhi0 = cos$1(phi0)) * sin$1(lambda0))\n          / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n      : (phi0 + phi1) / 2;\n}\n\nfunction clipAntimeridianInterpolate(from, to, direction, stream) {\n  var phi;\n  if (from == null) {\n    phi = direction * halfPi$2;\n    stream.point(-pi$3, phi);\n    stream.point(0, phi);\n    stream.point(pi$3, phi);\n    stream.point(pi$3, 0);\n    stream.point(pi$3, -phi);\n    stream.point(0, -phi);\n    stream.point(-pi$3, -phi);\n    stream.point(-pi$3, 0);\n    stream.point(-pi$3, phi);\n  } else if (abs(from[0] - to[0]) > epsilon$2) {\n    var lambda = from[0] < to[0] ? pi$3 : -pi$3;\n    phi = direction * lambda / 2;\n    stream.point(-lambda, phi);\n    stream.point(0, phi);\n    stream.point(lambda, phi);\n  } else {\n    stream.point(to[0], to[1]);\n  }\n}\n\nvar clipCircle = function(radius, delta) {\n  var cr = cos$1(radius),\n      smallRadius = cr > 0,\n      notHemisphere = abs(cr) > epsilon$2; // TODO optimise for this common case\n\n  function interpolate(from, to, direction, stream) {\n    circleStream(stream, radius, delta, direction, from, to);\n  }\n\n  function visible(lambda, phi) {\n    return cos$1(lambda) * cos$1(phi) > cr;\n  }\n\n  // Takes a line and cuts into visible segments. Return values used for polygon\n  // clipping: 0 - there were intersections or the line was empty; 1 - no\n  // intersections 2 - there were intersections, and the first and last segments\n  // should be rejoined.\n  function clipLine(stream) {\n    var point0, // previous point\n        c0, // code for previous point\n        v0, // visibility of previous point\n        v00, // visibility of first point\n        clean; // no intersections\n    return {\n      lineStart: function() {\n        v00 = v0 = false;\n        clean = 1;\n      },\n      point: function(lambda, phi) {\n        var point1 = [lambda, phi],\n            point2,\n            v = visible(lambda, phi),\n            c = smallRadius\n              ? v ? 0 : code(lambda, phi)\n              : v ? code(lambda + (lambda < 0 ? pi$3 : -pi$3), phi) : 0;\n        if (!point0 && (v00 = v0 = v)) stream.lineStart();\n        // Handle degeneracies.\n        // TODO ignore if not clipping polygons.\n        if (v !== v0) {\n          point2 = intersect(point0, point1);\n          if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2)) {\n            point1[0] += epsilon$2;\n            point1[1] += epsilon$2;\n            v = visible(point1[0], point1[1]);\n          }\n        }\n        if (v !== v0) {\n          clean = 0;\n          if (v) {\n            // outside going in\n            stream.lineStart();\n            point2 = intersect(point1, point0);\n            stream.point(point2[0], point2[1]);\n          } else {\n            // inside going out\n            point2 = intersect(point0, point1);\n            stream.point(point2[0], point2[1]);\n            stream.lineEnd();\n          }\n          point0 = point2;\n        } else if (notHemisphere && point0 && smallRadius ^ v) {\n          var t;\n          // If the codes for two points are different, or are both zero,\n          // and there this segment intersects with the small circle.\n          if (!(c & c0) && (t = intersect(point1, point0, true))) {\n            clean = 0;\n            if (smallRadius) {\n              stream.lineStart();\n              stream.point(t[0][0], t[0][1]);\n              stream.point(t[1][0], t[1][1]);\n              stream.lineEnd();\n            } else {\n              stream.point(t[1][0], t[1][1]);\n              stream.lineEnd();\n              stream.lineStart();\n              stream.point(t[0][0], t[0][1]);\n            }\n          }\n        }\n        if (v && (!point0 || !pointEqual(point0, point1))) {\n          stream.point(point1[0], point1[1]);\n        }\n        point0 = point1, v0 = v, c0 = c;\n      },\n      lineEnd: function() {\n        if (v0) stream.lineEnd();\n        point0 = null;\n      },\n      // Rejoin first and last segments if there were intersections and the first\n      // and last points were visible.\n      clean: function() {\n        return clean | ((v00 && v0) << 1);\n      }\n    };\n  }\n\n  // Intersects the great circle between a and b with the clip circle.\n  function intersect(a, b, two) {\n    var pa = cartesian(a),\n        pb = cartesian(b);\n\n    // We have two planes, n1.p = d1 and n2.p = d2.\n    // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n    var n1 = [1, 0, 0], // normal\n        n2 = cartesianCross(pa, pb),\n        n2n2 = cartesianDot(n2, n2),\n        n1n2 = n2[0], // cartesianDot(n1, n2),\n        determinant = n2n2 - n1n2 * n1n2;\n\n    // Two polar points.\n    if (!determinant) return !two && a;\n\n    var c1 =  cr * n2n2 / determinant,\n        c2 = -cr * n1n2 / determinant,\n        n1xn2 = cartesianCross(n1, n2),\n        A = cartesianScale(n1, c1),\n        B = cartesianScale(n2, c2);\n    cartesianAddInPlace(A, B);\n\n    // Solve |p(t)|^2 = 1.\n    var u = n1xn2,\n        w = cartesianDot(A, u),\n        uu = cartesianDot(u, u),\n        t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n    if (t2 < 0) return;\n\n    var t = sqrt(t2),\n        q = cartesianScale(u, (-w - t) / uu);\n    cartesianAddInPlace(q, A);\n    q = spherical(q);\n\n    if (!two) return q;\n\n    // Two intersection points.\n    var lambda0 = a[0],\n        lambda1 = b[0],\n        phi0 = a[1],\n        phi1 = b[1],\n        z;\n\n    if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n    var delta = lambda1 - lambda0,\n        polar = abs(delta - pi$3) < epsilon$2,\n        meridian = polar || delta < epsilon$2;\n\n    if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n    // Check that the first point is between a and b.\n    if (meridian\n        ? polar\n          ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon$2 ? phi0 : phi1)\n          : phi0 <= q[1] && q[1] <= phi1\n        : delta > pi$3 ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n      var q1 = cartesianScale(u, (-w + t) / uu);\n      cartesianAddInPlace(q1, A);\n      return [q, spherical(q1)];\n    }\n  }\n\n  // Generates a 4-bit vector representing the location of a point relative to\n  // the small circle's bounding box.\n  function code(lambda, phi) {\n    var r = smallRadius ? radius : pi$3 - radius,\n        code = 0;\n    if (lambda < -r) code |= 1; // left\n    else if (lambda > r) code |= 2; // right\n    if (phi < -r) code |= 4; // below\n    else if (phi > r) code |= 8; // above\n    return code;\n  }\n\n  return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi$3, radius - pi$3]);\n};\n\nvar transform = function(methods) {\n  return {\n    stream: transformer(methods)\n  };\n};\n\nfunction transformer(methods) {\n  return function(stream) {\n    var s = new TransformStream;\n    for (var key in methods) s[key] = methods[key];\n    s.stream = stream;\n    return s;\n  };\n}\n\nfunction TransformStream() {}\n\nTransformStream.prototype = {\n  constructor: TransformStream,\n  point: function(x, y) { this.stream.point(x, y); },\n  sphere: function() { this.stream.sphere(); },\n  lineStart: function() { this.stream.lineStart(); },\n  lineEnd: function() { this.stream.lineEnd(); },\n  polygonStart: function() { this.stream.polygonStart(); },\n  polygonEnd: function() { this.stream.polygonEnd(); }\n};\n\nfunction fitExtent(projection, extent, object) {\n  var w = extent[1][0] - extent[0][0],\n      h = extent[1][1] - extent[0][1],\n      clip = projection.clipExtent && projection.clipExtent();\n\n  projection\n      .scale(150)\n      .translate([0, 0]);\n\n  if (clip != null) projection.clipExtent(null);\n\n  geoStream(object, projection.stream(boundsStream$1));\n\n  var b = boundsStream$1.result(),\n      k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),\n      x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,\n      y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;\n\n  if (clip != null) projection.clipExtent(clip);\n\n  return projection\n      .scale(k * 150)\n      .translate([x, y]);\n}\n\nfunction fitSize(projection, size, object) {\n  return fitExtent(projection, [[0, 0], size], object);\n}\n\nvar maxDepth = 16;\nvar cosMinDistance = cos$1(30 * radians); // cos(minimum angular distance)\n\nvar resample = function(project, delta2) {\n  return +delta2 ? resample$1(project, delta2) : resampleNone(project);\n};\n\nfunction resampleNone(project) {\n  return transformer({\n    point: function(x, y) {\n      x = project(x, y);\n      this.stream.point(x[0], x[1]);\n    }\n  });\n}\n\nfunction resample$1(project, delta2) {\n\n  function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n    var dx = x1 - x0,\n        dy = y1 - y0,\n        d2 = dx * dx + dy * dy;\n    if (d2 > 4 * delta2 && depth--) {\n      var a = a0 + a1,\n          b = b0 + b1,\n          c = c0 + c1,\n          m = sqrt(a * a + b * b + c * c),\n          phi2 = asin(c /= m),\n          lambda2 = abs(abs(c) - 1) < epsilon$2 || abs(lambda0 - lambda1) < epsilon$2 ? (lambda0 + lambda1) / 2 : atan2(b, a),\n          p = project(lambda2, phi2),\n          x2 = p[0],\n          y2 = p[1],\n          dx2 = x2 - x0,\n          dy2 = y2 - y0,\n          dz = dy * dx2 - dx * dy2;\n      if (dz * dz / d2 > delta2 // perpendicular projected distance\n          || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n          || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n        resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n        stream.point(x2, y2);\n        resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n      }\n    }\n  }\n  return function(stream) {\n    var lambda00, x00, y00, a00, b00, c00, // first point\n        lambda0, x0, y0, a0, b0, c0; // previous point\n\n    var resampleStream = {\n      point: point,\n      lineStart: lineStart,\n      lineEnd: lineEnd,\n      polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n      polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n    };\n\n    function point(x, y) {\n      x = project(x, y);\n      stream.point(x[0], x[1]);\n    }\n\n    function lineStart() {\n      x0 = NaN;\n      resampleStream.point = linePoint;\n      stream.lineStart();\n    }\n\n    function linePoint(lambda, phi) {\n      var c = cartesian([lambda, phi]), p = project(lambda, phi);\n      resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n      stream.point(x0, y0);\n    }\n\n    function lineEnd() {\n      resampleStream.point = point;\n      stream.lineEnd();\n    }\n\n    function ringStart() {\n      lineStart();\n      resampleStream.point = ringPoint;\n      resampleStream.lineEnd = ringEnd;\n    }\n\n    function ringPoint(lambda, phi) {\n      linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n      resampleStream.point = linePoint;\n    }\n\n    function ringEnd() {\n      resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n      resampleStream.lineEnd = lineEnd;\n      lineEnd();\n    }\n\n    return resampleStream;\n  };\n}\n\nvar transformRadians = transformer({\n  point: function(x, y) {\n    this.stream.point(x * radians, y * radians);\n  }\n});\n\nfunction projection(project) {\n  return projectionMutator(function() { return project; })();\n}\n\nfunction projectionMutator(projectAt) {\n  var project,\n      k = 150, // scale\n      x = 480, y = 250, // translate\n      dx, dy, lambda = 0, phi = 0, // center\n      deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, projectRotate, // rotate\n      theta = null, preclip = clipAntimeridian, // clip angle\n      x0 = null, y0, x1, y1, postclip = identity$4, // clip extent\n      delta2 = 0.5, projectResample = resample(projectTransform, delta2), // precision\n      cache,\n      cacheStream;\n\n  function projection(point) {\n    point = projectRotate(point[0] * radians, point[1] * radians);\n    return [point[0] * k + dx, dy - point[1] * k];\n  }\n\n  function invert(point) {\n    point = projectRotate.invert((point[0] - dx) / k, (dy - point[1]) / k);\n    return point && [point[0] * degrees$1, point[1] * degrees$1];\n  }\n\n  function projectTransform(x, y) {\n    return x = project(x, y), [x[0] * k + dx, dy - x[1] * k];\n  }\n\n  projection.stream = function(stream) {\n    return cache && cacheStream === stream ? cache : cache = transformRadians(preclip(rotate, projectResample(postclip(cacheStream = stream))));\n  };\n\n  projection.clipAngle = function(_) {\n    return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians, 6 * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees$1;\n  };\n\n  projection.clipExtent = function(_) {\n    return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$4) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n  };\n\n  projection.scale = function(_) {\n    return arguments.length ? (k = +_, recenter()) : k;\n  };\n\n  projection.translate = function(_) {\n    return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n  };\n\n  projection.center = function(_) {\n    return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees$1, phi * degrees$1];\n  };\n\n  projection.rotate = function(_) {\n    return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees$1, deltaPhi * degrees$1, deltaGamma * degrees$1];\n  };\n\n  projection.precision = function(_) {\n    return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt(delta2);\n  };\n\n  projection.fitExtent = function(extent, object) {\n    return fitExtent(projection, extent, object);\n  };\n\n  projection.fitSize = function(size, object) {\n    return fitSize(projection, size, object);\n  };\n\n  function recenter() {\n    projectRotate = compose(rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma), project);\n    var center = project(lambda, phi);\n    dx = x - center[0] * k;\n    dy = y + center[1] * k;\n    return reset();\n  }\n\n  function reset() {\n    cache = cacheStream = null;\n    return projection;\n  }\n\n  return function() {\n    project = projectAt.apply(this, arguments);\n    projection.invert = project.invert && invert;\n    return recenter();\n  };\n}\n\nfunction conicProjection(projectAt) {\n  var phi0 = 0,\n      phi1 = pi$3 / 3,\n      m = projectionMutator(projectAt),\n      p = m(phi0, phi1);\n\n  p.parallels = function(_) {\n    return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees$1, phi1 * degrees$1];\n  };\n\n  return p;\n}\n\nfunction cylindricalEqualAreaRaw(phi0) {\n  var cosPhi0 = cos$1(phi0);\n\n  function forward(lambda, phi) {\n    return [lambda * cosPhi0, sin$1(phi) / cosPhi0];\n  }\n\n  forward.invert = function(x, y) {\n    return [x / cosPhi0, asin(y * cosPhi0)];\n  };\n\n  return forward;\n}\n\nfunction conicEqualAreaRaw(y0, y1) {\n  var sy0 = sin$1(y0), n = (sy0 + sin$1(y1)) / 2;\n\n  // Are the parallels symmetrical around the Equator?\n  if (abs(n) < epsilon$2) return cylindricalEqualAreaRaw(y0);\n\n  var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt(c) / n;\n\n  function project(x, y) {\n    var r = sqrt(c - 2 * n * sin$1(y)) / n;\n    return [r * sin$1(x *= n), r0 - r * cos$1(x)];\n  }\n\n  project.invert = function(x, y) {\n    var r0y = r0 - y;\n    return [atan2(x, abs(r0y)) / n * sign(r0y), asin((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n  };\n\n  return project;\n}\n\nvar conicEqualArea = function() {\n  return conicProjection(conicEqualAreaRaw)\n      .scale(155.424)\n      .center([0, 33.6442]);\n};\n\nvar albers = function() {\n  return conicEqualArea()\n      .parallels([29.5, 45.5])\n      .scale(1070)\n      .translate([480, 250])\n      .rotate([96, 0])\n      .center([-0.6, 38.7]);\n};\n\n// The projections must have mutually exclusive clip regions on the sphere,\n// as this will avoid emitting interleaving lines and polygons.\nfunction multiplex(streams) {\n  var n = streams.length;\n  return {\n    point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n    sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n    lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n    lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n    polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n    polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n  };\n}\n\n// A composite projection for the United States, configured by default for\n// 960×500. The projection also works quite well at 960×600 if you change the\n// scale to 1285 and adjust the translate accordingly. The set of standard\n// parallels for each region comes from USGS, which is published here:\n// http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\nvar albersUsa = function() {\n  var cache,\n      cacheStream,\n      lower48 = albers(), lower48Point,\n      alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n      hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n      point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n  function albersUsa(coordinates) {\n    var x = coordinates[0], y = coordinates[1];\n    return point = null,\n        (lower48Point.point(x, y), point)\n        || (alaskaPoint.point(x, y), point)\n        || (hawaiiPoint.point(x, y), point);\n  }\n\n  albersUsa.invert = function(coordinates) {\n    var k = lower48.scale(),\n        t = lower48.translate(),\n        x = (coordinates[0] - t[0]) / k,\n        y = (coordinates[1] - t[1]) / k;\n    return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n        : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n        : lower48).invert(coordinates);\n  };\n\n  albersUsa.stream = function(stream) {\n    return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n  };\n\n  albersUsa.precision = function(_) {\n    if (!arguments.length) return lower48.precision();\n    lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n    return reset();\n  };\n\n  albersUsa.scale = function(_) {\n    if (!arguments.length) return lower48.scale();\n    lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n    return albersUsa.translate(lower48.translate());\n  };\n\n  albersUsa.translate = function(_) {\n    if (!arguments.length) return lower48.translate();\n    var k = lower48.scale(), x = +_[0], y = +_[1];\n\n    lower48Point = lower48\n        .translate(_)\n        .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n        .stream(pointStream);\n\n    alaskaPoint = alaska\n        .translate([x - 0.307 * k, y + 0.201 * k])\n        .clipExtent([[x - 0.425 * k + epsilon$2, y + 0.120 * k + epsilon$2], [x - 0.214 * k - epsilon$2, y + 0.234 * k - epsilon$2]])\n        .stream(pointStream);\n\n    hawaiiPoint = hawaii\n        .translate([x - 0.205 * k, y + 0.212 * k])\n        .clipExtent([[x - 0.214 * k + epsilon$2, y + 0.166 * k + epsilon$2], [x - 0.115 * k - epsilon$2, y + 0.234 * k - epsilon$2]])\n        .stream(pointStream);\n\n    return reset();\n  };\n\n  albersUsa.fitExtent = function(extent, object) {\n    return fitExtent(albersUsa, extent, object);\n  };\n\n  albersUsa.fitSize = function(size, object) {\n    return fitSize(albersUsa, size, object);\n  };\n\n  function reset() {\n    cache = cacheStream = null;\n    return albersUsa;\n  }\n\n  return albersUsa.scale(1070);\n};\n\nfunction azimuthalRaw(scale) {\n  return function(x, y) {\n    var cx = cos$1(x),\n        cy = cos$1(y),\n        k = scale(cx * cy);\n    return [\n      k * cy * sin$1(x),\n      k * sin$1(y)\n    ];\n  }\n}\n\nfunction azimuthalInvert(angle) {\n  return function(x, y) {\n    var z = sqrt(x * x + y * y),\n        c = angle(z),\n        sc = sin$1(c),\n        cc = cos$1(c);\n    return [\n      atan2(x * sc, z * cc),\n      asin(z && y * sc / z)\n    ];\n  }\n}\n\nvar azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n  return sqrt(2 / (1 + cxcy));\n});\n\nazimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n  return 2 * asin(z / 2);\n});\n\nvar azimuthalEqualArea = function() {\n  return projection(azimuthalEqualAreaRaw)\n      .scale(124.75)\n      .clipAngle(180 - 1e-3);\n};\n\nvar azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n  return (c = acos(c)) && c / sin$1(c);\n});\n\nazimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n  return z;\n});\n\nvar azimuthalEquidistant = function() {\n  return projection(azimuthalEquidistantRaw)\n      .scale(79.4188)\n      .clipAngle(180 - 1e-3);\n};\n\nfunction mercatorRaw(lambda, phi) {\n  return [lambda, log(tan((halfPi$2 + phi) / 2))];\n}\n\nmercatorRaw.invert = function(x, y) {\n  return [x, 2 * atan(exp(y)) - halfPi$2];\n};\n\nvar mercator = function() {\n  return mercatorProjection(mercatorRaw)\n      .scale(961 / tau$3);\n};\n\nfunction mercatorProjection(project) {\n  var m = projection(project),\n      center = m.center,\n      scale = m.scale,\n      translate = m.translate,\n      clipExtent = m.clipExtent,\n      x0 = null, y0, x1, y1; // clip extent\n\n  m.scale = function(_) {\n    return arguments.length ? (scale(_), reclip()) : scale();\n  };\n\n  m.translate = function(_) {\n    return arguments.length ? (translate(_), reclip()) : translate();\n  };\n\n  m.center = function(_) {\n    return arguments.length ? (center(_), reclip()) : center();\n  };\n\n  m.clipExtent = function(_) {\n    return arguments.length ? ((_ == null ? x0 = y0 = x1 = y1 = null : (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1])), reclip()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n  };\n\n  function reclip() {\n    var k = pi$3 * scale(),\n        t = m(rotation(m.rotate()).invert([0, 0]));\n    return clipExtent(x0 == null\n        ? [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]] : project === mercatorRaw\n        ? [[Math.max(t[0] - k, x0), y0], [Math.min(t[0] + k, x1), y1]]\n        : [[x0, Math.max(t[1] - k, y0)], [x1, Math.min(t[1] + k, y1)]]);\n  }\n\n  return reclip();\n}\n\nfunction tany(y) {\n  return tan((halfPi$2 + y) / 2);\n}\n\nfunction conicConformalRaw(y0, y1) {\n  var cy0 = cos$1(y0),\n      n = y0 === y1 ? sin$1(y0) : log(cy0 / cos$1(y1)) / log(tany(y1) / tany(y0)),\n      f = cy0 * pow(tany(y0), n) / n;\n\n  if (!n) return mercatorRaw;\n\n  function project(x, y) {\n    if (f > 0) { if (y < -halfPi$2 + epsilon$2) y = -halfPi$2 + epsilon$2; }\n    else { if (y > halfPi$2 - epsilon$2) y = halfPi$2 - epsilon$2; }\n    var r = f / pow(tany(y), n);\n    return [r * sin$1(n * x), f - r * cos$1(n * x)];\n  }\n\n  project.invert = function(x, y) {\n    var fy = f - y, r = sign(n) * sqrt(x * x + fy * fy);\n    return [atan2(x, abs(fy)) / n * sign(fy), 2 * atan(pow(f / r, 1 / n)) - halfPi$2];\n  };\n\n  return project;\n}\n\nvar conicConformal = function() {\n  return conicProjection(conicConformalRaw)\n      .scale(109.5)\n      .parallels([30, 30]);\n};\n\nfunction equirectangularRaw(lambda, phi) {\n  return [lambda, phi];\n}\n\nequirectangularRaw.invert = equirectangularRaw;\n\nvar equirectangular = function() {\n  return projection(equirectangularRaw)\n      .scale(152.63);\n};\n\nfunction conicEquidistantRaw(y0, y1) {\n  var cy0 = cos$1(y0),\n      n = y0 === y1 ? sin$1(y0) : (cy0 - cos$1(y1)) / (y1 - y0),\n      g = cy0 / n + y0;\n\n  if (abs(n) < epsilon$2) return equirectangularRaw;\n\n  function project(x, y) {\n    var gy = g - y, nx = n * x;\n    return [gy * sin$1(nx), g - gy * cos$1(nx)];\n  }\n\n  project.invert = function(x, y) {\n    var gy = g - y;\n    return [atan2(x, abs(gy)) / n * sign(gy), g - sign(n) * sqrt(x * x + gy * gy)];\n  };\n\n  return project;\n}\n\nvar conicEquidistant = function() {\n  return conicProjection(conicEquidistantRaw)\n      .scale(131.154)\n      .center([0, 13.9389]);\n};\n\nfunction gnomonicRaw(x, y) {\n  var cy = cos$1(y), k = cos$1(x) * cy;\n  return [cy * sin$1(x) / k, sin$1(y) / k];\n}\n\ngnomonicRaw.invert = azimuthalInvert(atan);\n\nvar gnomonic = function() {\n  return projection(gnomonicRaw)\n      .scale(144.049)\n      .clipAngle(60);\n};\n\nfunction scaleTranslate(kx, ky, tx, ty) {\n  return kx === 1 && ky === 1 && tx === 0 && ty === 0 ? identity$4 : transformer({\n    point: function(x, y) {\n      this.stream.point(x * kx + tx, y * ky + ty);\n    }\n  });\n}\n\nvar identity$5 = function() {\n  var k = 1, tx = 0, ty = 0, sx = 1, sy = 1, transform = identity$4, // scale, translate and reflect\n      x0 = null, y0, x1, y1, clip = identity$4, // clip extent\n      cache,\n      cacheStream,\n      projection;\n\n  function reset() {\n    cache = cacheStream = null;\n    return projection;\n  }\n\n  return projection = {\n    stream: function(stream) {\n      return cache && cacheStream === stream ? cache : cache = transform(clip(cacheStream = stream));\n    },\n    clipExtent: function(_) {\n      return arguments.length ? (clip = _ == null ? (x0 = y0 = x1 = y1 = null, identity$4) : clipExtent(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n    },\n    scale: function(_) {\n      return arguments.length ? (transform = scaleTranslate((k = +_) * sx, k * sy, tx, ty), reset()) : k;\n    },\n    translate: function(_) {\n      return arguments.length ? (transform = scaleTranslate(k * sx, k * sy, tx = +_[0], ty = +_[1]), reset()) : [tx, ty];\n    },\n    reflectX: function(_) {\n      return arguments.length ? (transform = scaleTranslate(k * (sx = _ ? -1 : 1), k * sy, tx, ty), reset()) : sx < 0;\n    },\n    reflectY: function(_) {\n      return arguments.length ? (transform = scaleTranslate(k * sx, k * (sy = _ ? -1 : 1), tx, ty), reset()) : sy < 0;\n    },\n    fitExtent: function(extent, object) {\n      return fitExtent(projection, extent, object);\n    },\n    fitSize: function(size, object) {\n      return fitSize(projection, size, object);\n    }\n  };\n};\n\nfunction orthographicRaw(x, y) {\n  return [cos$1(y) * sin$1(x), sin$1(y)];\n}\n\northographicRaw.invert = azimuthalInvert(asin);\n\nvar orthographic = function() {\n  return projection(orthographicRaw)\n      .scale(249.5)\n      .clipAngle(90 + epsilon$2);\n};\n\nfunction stereographicRaw(x, y) {\n  var cy = cos$1(y), k = 1 + cos$1(x) * cy;\n  return [cy * sin$1(x) / k, sin$1(y) / k];\n}\n\nstereographicRaw.invert = azimuthalInvert(function(z) {\n  return 2 * atan(z);\n});\n\nvar stereographic = function() {\n  return projection(stereographicRaw)\n      .scale(250)\n      .clipAngle(142);\n};\n\nfunction transverseMercatorRaw(lambda, phi) {\n  return [log(tan((halfPi$2 + phi) / 2)), -lambda];\n}\n\ntransverseMercatorRaw.invert = function(x, y) {\n  return [-y, 2 * atan(exp(x)) - halfPi$2];\n};\n\nvar transverseMercator = function() {\n  var m = mercatorProjection(transverseMercatorRaw),\n      center = m.center,\n      rotate = m.rotate;\n\n  m.center = function(_) {\n    return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n  };\n\n  m.rotate = function(_) {\n    return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n  };\n\n  return rotate([0, 0, 90])\n      .scale(159.155);\n};\n\nfunction defaultSeparation(a, b) {\n  return a.parent === b.parent ? 1 : 2;\n}\n\nfunction meanX(children) {\n  return children.reduce(meanXReduce, 0) / children.length;\n}\n\nfunction meanXReduce(x, c) {\n  return x + c.x;\n}\n\nfunction maxY(children) {\n  return 1 + children.reduce(maxYReduce, 0);\n}\n\nfunction maxYReduce(y, c) {\n  return Math.max(y, c.y);\n}\n\nfunction leafLeft(node) {\n  var children;\n  while (children = node.children) node = children[0];\n  return node;\n}\n\nfunction leafRight(node) {\n  var children;\n  while (children = node.children) node = children[children.length - 1];\n  return node;\n}\n\nvar cluster = function() {\n  var separation = defaultSeparation,\n      dx = 1,\n      dy = 1,\n      nodeSize = false;\n\n  function cluster(root) {\n    var previousNode,\n        x = 0;\n\n    // First walk, computing the initial x & y values.\n    root.eachAfter(function(node) {\n      var children = node.children;\n      if (children) {\n        node.x = meanX(children);\n        node.y = maxY(children);\n      } else {\n        node.x = previousNode ? x += separation(node, previousNode) : 0;\n        node.y = 0;\n        previousNode = node;\n      }\n    });\n\n    var left = leafLeft(root),\n        right = leafRight(root),\n        x0 = left.x - separation(left, right) / 2,\n        x1 = right.x + separation(right, left) / 2;\n\n    // Second walk, normalizing x & y to the desired size.\n    return root.eachAfter(nodeSize ? function(node) {\n      node.x = (node.x - root.x) * dx;\n      node.y = (root.y - node.y) * dy;\n    } : function(node) {\n      node.x = (node.x - x0) / (x1 - x0) * dx;\n      node.y = (1 - (root.y ? node.y / root.y : 1)) * dy;\n    });\n  }\n\n  cluster.separation = function(x) {\n    return arguments.length ? (separation = x, cluster) : separation;\n  };\n\n  cluster.size = function(x) {\n    return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? null : [dx, dy]);\n  };\n\n  cluster.nodeSize = function(x) {\n    return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], cluster) : (nodeSize ? [dx, dy] : null);\n  };\n\n  return cluster;\n};\n\nfunction count(node) {\n  var sum = 0,\n      children = node.children,\n      i = children && children.length;\n  if (!i) sum = 1;\n  else while (--i >= 0) sum += children[i].value;\n  node.value = sum;\n}\n\nvar node_count = function() {\n  return this.eachAfter(count);\n};\n\nvar node_each = function(callback) {\n  var node = this, current, next = [node], children, i, n;\n  do {\n    current = next.reverse(), next = [];\n    while (node = current.pop()) {\n      callback(node), children = node.children;\n      if (children) for (i = 0, n = children.length; i < n; ++i) {\n        next.push(children[i]);\n      }\n    }\n  } while (next.length);\n  return this;\n};\n\nvar node_eachBefore = function(callback) {\n  var node = this, nodes = [node], children, i;\n  while (node = nodes.pop()) {\n    callback(node), children = node.children;\n    if (children) for (i = children.length - 1; i >= 0; --i) {\n      nodes.push(children[i]);\n    }\n  }\n  return this;\n};\n\nvar node_eachAfter = function(callback) {\n  var node = this, nodes = [node], next = [], children, i, n;\n  while (node = nodes.pop()) {\n    next.push(node), children = node.children;\n    if (children) for (i = 0, n = children.length; i < n; ++i) {\n      nodes.push(children[i]);\n    }\n  }\n  while (node = next.pop()) {\n    callback(node);\n  }\n  return this;\n};\n\nvar node_sum = function(value) {\n  return this.eachAfter(function(node) {\n    var sum = +value(node.data) || 0,\n        children = node.children,\n        i = children && children.length;\n    while (--i >= 0) sum += children[i].value;\n    node.value = sum;\n  });\n};\n\nvar node_sort = function(compare) {\n  return this.eachBefore(function(node) {\n    if (node.children) {\n      node.children.sort(compare);\n    }\n  });\n};\n\nvar node_path = function(end) {\n  var start = this,\n      ancestor = leastCommonAncestor(start, end),\n      nodes = [start];\n  while (start !== ancestor) {\n    start = start.parent;\n    nodes.push(start);\n  }\n  var k = nodes.length;\n  while (end !== ancestor) {\n    nodes.splice(k, 0, end);\n    end = end.parent;\n  }\n  return nodes;\n};\n\nfunction leastCommonAncestor(a, b) {\n  if (a === b) return a;\n  var aNodes = a.ancestors(),\n      bNodes = b.ancestors(),\n      c = null;\n  a = aNodes.pop();\n  b = bNodes.pop();\n  while (a === b) {\n    c = a;\n    a = aNodes.pop();\n    b = bNodes.pop();\n  }\n  return c;\n}\n\nvar node_ancestors = function() {\n  var node = this, nodes = [node];\n  while (node = node.parent) {\n    nodes.push(node);\n  }\n  return nodes;\n};\n\nvar node_descendants = function() {\n  var nodes = [];\n  this.each(function(node) {\n    nodes.push(node);\n  });\n  return nodes;\n};\n\nvar node_leaves = function() {\n  var leaves = [];\n  this.eachBefore(function(node) {\n    if (!node.children) {\n      leaves.push(node);\n    }\n  });\n  return leaves;\n};\n\nvar node_links = function() {\n  var root = this, links = [];\n  root.each(function(node) {\n    if (node !== root) { // Don’t include the root’s parent, if any.\n      links.push({source: node.parent, target: node});\n    }\n  });\n  return links;\n};\n\nfunction hierarchy(data, children) {\n  var root = new Node(data),\n      valued = +data.value && (root.value = data.value),\n      node,\n      nodes = [root],\n      child,\n      childs,\n      i,\n      n;\n\n  if (children == null) children = defaultChildren;\n\n  while (node = nodes.pop()) {\n    if (valued) node.value = +node.data.value;\n    if ((childs = children(node.data)) && (n = childs.length)) {\n      node.children = new Array(n);\n      for (i = n - 1; i >= 0; --i) {\n        nodes.push(child = node.children[i] = new Node(childs[i]));\n        child.parent = node;\n        child.depth = node.depth + 1;\n      }\n    }\n  }\n\n  return root.eachBefore(computeHeight);\n}\n\nfunction node_copy() {\n  return hierarchy(this).eachBefore(copyData);\n}\n\nfunction defaultChildren(d) {\n  return d.children;\n}\n\nfunction copyData(node) {\n  node.data = node.data.data;\n}\n\nfunction computeHeight(node) {\n  var height = 0;\n  do node.height = height;\n  while ((node = node.parent) && (node.height < ++height));\n}\n\nfunction Node(data) {\n  this.data = data;\n  this.depth =\n  this.height = 0;\n  this.parent = null;\n}\n\nNode.prototype = hierarchy.prototype = {\n  constructor: Node,\n  count: node_count,\n  each: node_each,\n  eachAfter: node_eachAfter,\n  eachBefore: node_eachBefore,\n  sum: node_sum,\n  sort: node_sort,\n  path: node_path,\n  ancestors: node_ancestors,\n  descendants: node_descendants,\n  leaves: node_leaves,\n  links: node_links,\n  copy: node_copy\n};\n\nfunction Node$2(value) {\n  this._ = value;\n  this.next = null;\n}\n\nvar shuffle$1 = function(array) {\n  var i,\n      n = (array = array.slice()).length,\n      head = null,\n      node = head;\n\n  while (n) {\n    var next = new Node$2(array[n - 1]);\n    if (node) node = node.next = next;\n    else node = head = next;\n    array[i] = array[--n];\n  }\n\n  return {\n    head: head,\n    tail: node\n  };\n};\n\nvar enclose = function(circles) {\n  return encloseN(shuffle$1(circles), []);\n};\n\nfunction encloses(a, b) {\n  var dx = b.x - a.x,\n      dy = b.y - a.y,\n      dr = a.r - b.r;\n  return dr * dr + 1e-6 > dx * dx + dy * dy;\n}\n\n// Returns the smallest circle that contains circles L and intersects circles B.\nfunction encloseN(L, B) {\n  var circle,\n      l0 = null,\n      l1 = L.head,\n      l2,\n      p1;\n\n  switch (B.length) {\n    case 1: circle = enclose1(B[0]); break;\n    case 2: circle = enclose2(B[0], B[1]); break;\n    case 3: circle = enclose3(B[0], B[1], B[2]); break;\n  }\n\n  while (l1) {\n    p1 = l1._, l2 = l1.next;\n    if (!circle || !encloses(circle, p1)) {\n\n      // Temporarily truncate L before l1.\n      if (l0) L.tail = l0, l0.next = null;\n      else L.head = L.tail = null;\n\n      B.push(p1);\n      circle = encloseN(L, B); // Note: reorders L!\n      B.pop();\n\n      // Move l1 to the front of L and reconnect the truncated list L.\n      if (L.head) l1.next = L.head, L.head = l1;\n      else l1.next = null, L.head = L.tail = l1;\n      l0 = L.tail, l0.next = l2;\n\n    } else {\n      l0 = l1;\n    }\n    l1 = l2;\n  }\n\n  L.tail = l0;\n  return circle;\n}\n\nfunction enclose1(a) {\n  return {\n    x: a.x,\n    y: a.y,\n    r: a.r\n  };\n}\n\nfunction enclose2(a, b) {\n  var x1 = a.x, y1 = a.y, r1 = a.r,\n      x2 = b.x, y2 = b.y, r2 = b.r,\n      x21 = x2 - x1, y21 = y2 - y1, r21 = r2 - r1,\n      l = Math.sqrt(x21 * x21 + y21 * y21);\n  return {\n    x: (x1 + x2 + x21 / l * r21) / 2,\n    y: (y1 + y2 + y21 / l * r21) / 2,\n    r: (l + r1 + r2) / 2\n  };\n}\n\nfunction enclose3(a, b, c) {\n  var x1 = a.x, y1 = a.y, r1 = a.r,\n      x2 = b.x, y2 = b.y, r2 = b.r,\n      x3 = c.x, y3 = c.y, r3 = c.r,\n      a2 = 2 * (x1 - x2),\n      b2 = 2 * (y1 - y2),\n      c2 = 2 * (r2 - r1),\n      d2 = x1 * x1 + y1 * y1 - r1 * r1 - x2 * x2 - y2 * y2 + r2 * r2,\n      a3 = 2 * (x1 - x3),\n      b3 = 2 * (y1 - y3),\n      c3 = 2 * (r3 - r1),\n      d3 = x1 * x1 + y1 * y1 - r1 * r1 - x3 * x3 - y3 * y3 + r3 * r3,\n      ab = a3 * b2 - a2 * b3,\n      xa = (b2 * d3 - b3 * d2) / ab - x1,\n      xb = (b3 * c2 - b2 * c3) / ab,\n      ya = (a3 * d2 - a2 * d3) / ab - y1,\n      yb = (a2 * c3 - a3 * c2) / ab,\n      A = xb * xb + yb * yb - 1,\n      B = 2 * (xa * xb + ya * yb + r1),\n      C = xa * xa + ya * ya - r1 * r1,\n      r = (-B - Math.sqrt(B * B - 4 * A * C)) / (2 * A);\n  return {\n    x: xa + xb * r + x1,\n    y: ya + yb * r + y1,\n    r: r\n  };\n}\n\nfunction place(a, b, c) {\n  var ax = a.x,\n      ay = a.y,\n      da = b.r + c.r,\n      db = a.r + c.r,\n      dx = b.x - ax,\n      dy = b.y - ay,\n      dc = dx * dx + dy * dy;\n  if (dc) {\n    var x = 0.5 + ((db *= db) - (da *= da)) / (2 * dc),\n        y = Math.sqrt(Math.max(0, 2 * da * (db + dc) - (db -= dc) * db - da * da)) / (2 * dc);\n    c.x = ax + x * dx + y * dy;\n    c.y = ay + x * dy - y * dx;\n  } else {\n    c.x = ax + db;\n    c.y = ay;\n  }\n}\n\nfunction intersects(a, b) {\n  var dx = b.x - a.x,\n      dy = b.y - a.y,\n      dr = a.r + b.r;\n  return dr * dr - 1e-6 > dx * dx + dy * dy;\n}\n\nfunction distance2(node, x, y) {\n  var a = node._,\n      b = node.next._,\n      ab = a.r + b.r,\n      dx = (a.x * b.r + b.x * a.r) / ab - x,\n      dy = (a.y * b.r + b.y * a.r) / ab - y;\n  return dx * dx + dy * dy;\n}\n\nfunction Node$1(circle) {\n  this._ = circle;\n  this.next = null;\n  this.previous = null;\n}\n\nfunction packEnclose(circles) {\n  if (!(n = circles.length)) return 0;\n\n  var a, b, c, n;\n\n  // Place the first circle.\n  a = circles[0], a.x = 0, a.y = 0;\n  if (!(n > 1)) return a.r;\n\n  // Place the second circle.\n  b = circles[1], a.x = -b.r, b.x = a.r, b.y = 0;\n  if (!(n > 2)) return a.r + b.r;\n\n  // Place the third circle.\n  place(b, a, c = circles[2]);\n\n  // Initialize the weighted centroid.\n  var aa = a.r * a.r,\n      ba = b.r * b.r,\n      ca = c.r * c.r,\n      oa = aa + ba + ca,\n      ox = aa * a.x + ba * b.x + ca * c.x,\n      oy = aa * a.y + ba * b.y + ca * c.y,\n      cx, cy, i, j, k, sj, sk;\n\n  // Initialize the front-chain using the first three circles a, b and c.\n  a = new Node$1(a), b = new Node$1(b), c = new Node$1(c);\n  a.next = c.previous = b;\n  b.next = a.previous = c;\n  c.next = b.previous = a;\n\n  // Attempt to place each remaining circle…\n  pack: for (i = 3; i < n; ++i) {\n    place(a._, b._, c = circles[i]), c = new Node$1(c);\n\n    // Find the closest intersecting circle on the front-chain, if any.\n    // “Closeness” is determined by linear distance along the front-chain.\n    // “Ahead” or “behind” is likewise determined by linear distance.\n    j = b.next, k = a.previous, sj = b._.r, sk = a._.r;\n    do {\n      if (sj <= sk) {\n        if (intersects(j._, c._)) {\n          b = j, a.next = b, b.previous = a, --i;\n          continue pack;\n        }\n        sj += j._.r, j = j.next;\n      } else {\n        if (intersects(k._, c._)) {\n          a = k, a.next = b, b.previous = a, --i;\n          continue pack;\n        }\n        sk += k._.r, k = k.previous;\n      }\n    } while (j !== k.next);\n\n    // Success! Insert the new circle c between a and b.\n    c.previous = a, c.next = b, a.next = b.previous = b = c;\n\n    // Update the weighted centroid.\n    oa += ca = c._.r * c._.r;\n    ox += ca * c._.x;\n    oy += ca * c._.y;\n\n    // Compute the new closest circle pair to the centroid.\n    aa = distance2(a, cx = ox / oa, cy = oy / oa);\n    while ((c = c.next) !== b) {\n      if ((ca = distance2(c, cx, cy)) < aa) {\n        a = c, aa = ca;\n      }\n    }\n    b = a.next;\n  }\n\n  // Compute the enclosing circle of the front chain.\n  a = [b._], c = b; while ((c = c.next) !== b) a.push(c._); c = enclose(a);\n\n  // Translate the circles to put the enclosing circle around the origin.\n  for (i = 0; i < n; ++i) a = circles[i], a.x -= c.x, a.y -= c.y;\n\n  return c.r;\n}\n\nvar siblings = function(circles) {\n  packEnclose(circles);\n  return circles;\n};\n\nfunction optional(f) {\n  return f == null ? null : required(f);\n}\n\nfunction required(f) {\n  if (typeof f !== \"function\") throw new Error;\n  return f;\n}\n\nfunction constantZero() {\n  return 0;\n}\n\nvar constant$8 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nfunction defaultRadius$1(d) {\n  return Math.sqrt(d.value);\n}\n\nvar index$2 = function() {\n  var radius = null,\n      dx = 1,\n      dy = 1,\n      padding = constantZero;\n\n  function pack(root) {\n    root.x = dx / 2, root.y = dy / 2;\n    if (radius) {\n      root.eachBefore(radiusLeaf(radius))\n          .eachAfter(packChildren(padding, 0.5))\n          .eachBefore(translateChild(1));\n    } else {\n      root.eachBefore(radiusLeaf(defaultRadius$1))\n          .eachAfter(packChildren(constantZero, 1))\n          .eachAfter(packChildren(padding, root.r / Math.min(dx, dy)))\n          .eachBefore(translateChild(Math.min(dx, dy) / (2 * root.r)));\n    }\n    return root;\n  }\n\n  pack.radius = function(x) {\n    return arguments.length ? (radius = optional(x), pack) : radius;\n  };\n\n  pack.size = function(x) {\n    return arguments.length ? (dx = +x[0], dy = +x[1], pack) : [dx, dy];\n  };\n\n  pack.padding = function(x) {\n    return arguments.length ? (padding = typeof x === \"function\" ? x : constant$8(+x), pack) : padding;\n  };\n\n  return pack;\n};\n\nfunction radiusLeaf(radius) {\n  return function(node) {\n    if (!node.children) {\n      node.r = Math.max(0, +radius(node) || 0);\n    }\n  };\n}\n\nfunction packChildren(padding, k) {\n  return function(node) {\n    if (children = node.children) {\n      var children,\n          i,\n          n = children.length,\n          r = padding(node) * k || 0,\n          e;\n\n      if (r) for (i = 0; i < n; ++i) children[i].r += r;\n      e = packEnclose(children);\n      if (r) for (i = 0; i < n; ++i) children[i].r -= r;\n      node.r = e + r;\n    }\n  };\n}\n\nfunction translateChild(k) {\n  return function(node) {\n    var parent = node.parent;\n    node.r *= k;\n    if (parent) {\n      node.x = parent.x + k * node.x;\n      node.y = parent.y + k * node.y;\n    }\n  };\n}\n\nvar roundNode = function(node) {\n  node.x0 = Math.round(node.x0);\n  node.y0 = Math.round(node.y0);\n  node.x1 = Math.round(node.x1);\n  node.y1 = Math.round(node.y1);\n};\n\nvar treemapDice = function(parent, x0, y0, x1, y1) {\n  var nodes = parent.children,\n      node,\n      i = -1,\n      n = nodes.length,\n      k = parent.value && (x1 - x0) / parent.value;\n\n  while (++i < n) {\n    node = nodes[i], node.y0 = y0, node.y1 = y1;\n    node.x0 = x0, node.x1 = x0 += node.value * k;\n  }\n};\n\nvar partition = function() {\n  var dx = 1,\n      dy = 1,\n      padding = 0,\n      round = false;\n\n  function partition(root) {\n    var n = root.height + 1;\n    root.x0 =\n    root.y0 = padding;\n    root.x1 = dx;\n    root.y1 = dy / n;\n    root.eachBefore(positionNode(dy, n));\n    if (round) root.eachBefore(roundNode);\n    return root;\n  }\n\n  function positionNode(dy, n) {\n    return function(node) {\n      if (node.children) {\n        treemapDice(node, node.x0, dy * (node.depth + 1) / n, node.x1, dy * (node.depth + 2) / n);\n      }\n      var x0 = node.x0,\n          y0 = node.y0,\n          x1 = node.x1 - padding,\n          y1 = node.y1 - padding;\n      if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n      if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n      node.x0 = x0;\n      node.y0 = y0;\n      node.x1 = x1;\n      node.y1 = y1;\n    };\n  }\n\n  partition.round = function(x) {\n    return arguments.length ? (round = !!x, partition) : round;\n  };\n\n  partition.size = function(x) {\n    return arguments.length ? (dx = +x[0], dy = +x[1], partition) : [dx, dy];\n  };\n\n  partition.padding = function(x) {\n    return arguments.length ? (padding = +x, partition) : padding;\n  };\n\n  return partition;\n};\n\nvar keyPrefix$1 = \"$\";\nvar preroot = {depth: -1};\nvar ambiguous = {};\n\nfunction defaultId(d) {\n  return d.id;\n}\n\nfunction defaultParentId(d) {\n  return d.parentId;\n}\n\nvar stratify = function() {\n  var id = defaultId,\n      parentId = defaultParentId;\n\n  function stratify(data) {\n    var d,\n        i,\n        n = data.length,\n        root,\n        parent,\n        node,\n        nodes = new Array(n),\n        nodeId,\n        nodeKey,\n        nodeByKey = {};\n\n    for (i = 0; i < n; ++i) {\n      d = data[i], node = nodes[i] = new Node(d);\n      if ((nodeId = id(d, i, data)) != null && (nodeId += \"\")) {\n        nodeKey = keyPrefix$1 + (node.id = nodeId);\n        nodeByKey[nodeKey] = nodeKey in nodeByKey ? ambiguous : node;\n      }\n    }\n\n    for (i = 0; i < n; ++i) {\n      node = nodes[i], nodeId = parentId(data[i], i, data);\n      if (nodeId == null || !(nodeId += \"\")) {\n        if (root) throw new Error(\"multiple roots\");\n        root = node;\n      } else {\n        parent = nodeByKey[keyPrefix$1 + nodeId];\n        if (!parent) throw new Error(\"missing: \" + nodeId);\n        if (parent === ambiguous) throw new Error(\"ambiguous: \" + nodeId);\n        if (parent.children) parent.children.push(node);\n        else parent.children = [node];\n        node.parent = parent;\n      }\n    }\n\n    if (!root) throw new Error(\"no root\");\n    root.parent = preroot;\n    root.eachBefore(function(node) { node.depth = node.parent.depth + 1; --n; }).eachBefore(computeHeight);\n    root.parent = null;\n    if (n > 0) throw new Error(\"cycle\");\n\n    return root;\n  }\n\n  stratify.id = function(x) {\n    return arguments.length ? (id = required(x), stratify) : id;\n  };\n\n  stratify.parentId = function(x) {\n    return arguments.length ? (parentId = required(x), stratify) : parentId;\n  };\n\n  return stratify;\n};\n\nfunction defaultSeparation$1(a, b) {\n  return a.parent === b.parent ? 1 : 2;\n}\n\n// function radialSeparation(a, b) {\n//   return (a.parent === b.parent ? 1 : 2) / a.depth;\n// }\n\n// This function is used to traverse the left contour of a subtree (or\n// subforest). It returns the successor of v on this contour. This successor is\n// either given by the leftmost child of v or by the thread of v. The function\n// returns null if and only if v is on the highest level of its subtree.\nfunction nextLeft(v) {\n  var children = v.children;\n  return children ? children[0] : v.t;\n}\n\n// This function works analogously to nextLeft.\nfunction nextRight(v) {\n  var children = v.children;\n  return children ? children[children.length - 1] : v.t;\n}\n\n// Shifts the current subtree rooted at w+. This is done by increasing\n// prelim(w+) and mod(w+) by shift.\nfunction moveSubtree(wm, wp, shift) {\n  var change = shift / (wp.i - wm.i);\n  wp.c -= change;\n  wp.s += shift;\n  wm.c += change;\n  wp.z += shift;\n  wp.m += shift;\n}\n\n// All other shifts, applied to the smaller subtrees between w- and w+, are\n// performed by this function. To prepare the shifts, we have to adjust\n// change(w+), shift(w+), and change(w-).\nfunction executeShifts(v) {\n  var shift = 0,\n      change = 0,\n      children = v.children,\n      i = children.length,\n      w;\n  while (--i >= 0) {\n    w = children[i];\n    w.z += shift;\n    w.m += shift;\n    shift += w.s + (change += w.c);\n  }\n}\n\n// If vi-’s ancestor is a sibling of v, returns vi-’s ancestor. Otherwise,\n// returns the specified (default) ancestor.\nfunction nextAncestor(vim, v, ancestor) {\n  return vim.a.parent === v.parent ? vim.a : ancestor;\n}\n\nfunction TreeNode(node, i) {\n  this._ = node;\n  this.parent = null;\n  this.children = null;\n  this.A = null; // default ancestor\n  this.a = this; // ancestor\n  this.z = 0; // prelim\n  this.m = 0; // mod\n  this.c = 0; // change\n  this.s = 0; // shift\n  this.t = null; // thread\n  this.i = i; // number\n}\n\nTreeNode.prototype = Object.create(Node.prototype);\n\nfunction treeRoot(root) {\n  var tree = new TreeNode(root, 0),\n      node,\n      nodes = [tree],\n      child,\n      children,\n      i,\n      n;\n\n  while (node = nodes.pop()) {\n    if (children = node._.children) {\n      node.children = new Array(n = children.length);\n      for (i = n - 1; i >= 0; --i) {\n        nodes.push(child = node.children[i] = new TreeNode(children[i], i));\n        child.parent = node;\n      }\n    }\n  }\n\n  (tree.parent = new TreeNode(null, 0)).children = [tree];\n  return tree;\n}\n\n// Node-link tree diagram using the Reingold-Tilford \"tidy\" algorithm\nvar tree = function() {\n  var separation = defaultSeparation$1,\n      dx = 1,\n      dy = 1,\n      nodeSize = null;\n\n  function tree(root) {\n    var t = treeRoot(root);\n\n    // Compute the layout using Buchheim et al.’s algorithm.\n    t.eachAfter(firstWalk), t.parent.m = -t.z;\n    t.eachBefore(secondWalk);\n\n    // If a fixed node size is specified, scale x and y.\n    if (nodeSize) root.eachBefore(sizeNode);\n\n    // If a fixed tree size is specified, scale x and y based on the extent.\n    // Compute the left-most, right-most, and depth-most nodes for extents.\n    else {\n      var left = root,\n          right = root,\n          bottom = root;\n      root.eachBefore(function(node) {\n        if (node.x < left.x) left = node;\n        if (node.x > right.x) right = node;\n        if (node.depth > bottom.depth) bottom = node;\n      });\n      var s = left === right ? 1 : separation(left, right) / 2,\n          tx = s - left.x,\n          kx = dx / (right.x + s + tx),\n          ky = dy / (bottom.depth || 1);\n      root.eachBefore(function(node) {\n        node.x = (node.x + tx) * kx;\n        node.y = node.depth * ky;\n      });\n    }\n\n    return root;\n  }\n\n  // Computes a preliminary x-coordinate for v. Before that, FIRST WALK is\n  // applied recursively to the children of v, as well as the function\n  // APPORTION. After spacing out the children by calling EXECUTE SHIFTS, the\n  // node v is placed to the midpoint of its outermost children.\n  function firstWalk(v) {\n    var children = v.children,\n        siblings = v.parent.children,\n        w = v.i ? siblings[v.i - 1] : null;\n    if (children) {\n      executeShifts(v);\n      var midpoint = (children[0].z + children[children.length - 1].z) / 2;\n      if (w) {\n        v.z = w.z + separation(v._, w._);\n        v.m = v.z - midpoint;\n      } else {\n        v.z = midpoint;\n      }\n    } else if (w) {\n      v.z = w.z + separation(v._, w._);\n    }\n    v.parent.A = apportion(v, w, v.parent.A || siblings[0]);\n  }\n\n  // Computes all real x-coordinates by summing up the modifiers recursively.\n  function secondWalk(v) {\n    v._.x = v.z + v.parent.m;\n    v.m += v.parent.m;\n  }\n\n  // The core of the algorithm. Here, a new subtree is combined with the\n  // previous subtrees. Threads are used to traverse the inside and outside\n  // contours of the left and right subtree up to the highest common level. The\n  // vertices used for the traversals are vi+, vi-, vo-, and vo+, where the\n  // superscript o means outside and i means inside, the subscript - means left\n  // subtree and + means right subtree. For summing up the modifiers along the\n  // contour, we use respective variables si+, si-, so-, and so+. Whenever two\n  // nodes of the inside contours conflict, we compute the left one of the\n  // greatest uncommon ancestors using the function ANCESTOR and call MOVE\n  // SUBTREE to shift the subtree and prepare the shifts of smaller subtrees.\n  // Finally, we add a new thread (if necessary).\n  function apportion(v, w, ancestor) {\n    if (w) {\n      var vip = v,\n          vop = v,\n          vim = w,\n          vom = vip.parent.children[0],\n          sip = vip.m,\n          sop = vop.m,\n          sim = vim.m,\n          som = vom.m,\n          shift;\n      while (vim = nextRight(vim), vip = nextLeft(vip), vim && vip) {\n        vom = nextLeft(vom);\n        vop = nextRight(vop);\n        vop.a = v;\n        shift = vim.z + sim - vip.z - sip + separation(vim._, vip._);\n        if (shift > 0) {\n          moveSubtree(nextAncestor(vim, v, ancestor), v, shift);\n          sip += shift;\n          sop += shift;\n        }\n        sim += vim.m;\n        sip += vip.m;\n        som += vom.m;\n        sop += vop.m;\n      }\n      if (vim && !nextRight(vop)) {\n        vop.t = vim;\n        vop.m += sim - sop;\n      }\n      if (vip && !nextLeft(vom)) {\n        vom.t = vip;\n        vom.m += sip - som;\n        ancestor = v;\n      }\n    }\n    return ancestor;\n  }\n\n  function sizeNode(node) {\n    node.x *= dx;\n    node.y = node.depth * dy;\n  }\n\n  tree.separation = function(x) {\n    return arguments.length ? (separation = x, tree) : separation;\n  };\n\n  tree.size = function(x) {\n    return arguments.length ? (nodeSize = false, dx = +x[0], dy = +x[1], tree) : (nodeSize ? null : [dx, dy]);\n  };\n\n  tree.nodeSize = function(x) {\n    return arguments.length ? (nodeSize = true, dx = +x[0], dy = +x[1], tree) : (nodeSize ? [dx, dy] : null);\n  };\n\n  return tree;\n};\n\nvar treemapSlice = function(parent, x0, y0, x1, y1) {\n  var nodes = parent.children,\n      node,\n      i = -1,\n      n = nodes.length,\n      k = parent.value && (y1 - y0) / parent.value;\n\n  while (++i < n) {\n    node = nodes[i], node.x0 = x0, node.x1 = x1;\n    node.y0 = y0, node.y1 = y0 += node.value * k;\n  }\n};\n\nvar phi = (1 + Math.sqrt(5)) / 2;\n\nfunction squarifyRatio(ratio, parent, x0, y0, x1, y1) {\n  var rows = [],\n      nodes = parent.children,\n      row,\n      nodeValue,\n      i0 = 0,\n      i1 = 0,\n      n = nodes.length,\n      dx, dy,\n      value = parent.value,\n      sumValue,\n      minValue,\n      maxValue,\n      newRatio,\n      minRatio,\n      alpha,\n      beta;\n\n  while (i0 < n) {\n    dx = x1 - x0, dy = y1 - y0;\n\n    // Find the next non-empty node.\n    do sumValue = nodes[i1++].value; while (!sumValue && i1 < n);\n    minValue = maxValue = sumValue;\n    alpha = Math.max(dy / dx, dx / dy) / (value * ratio);\n    beta = sumValue * sumValue * alpha;\n    minRatio = Math.max(maxValue / beta, beta / minValue);\n\n    // Keep adding nodes while the aspect ratio maintains or improves.\n    for (; i1 < n; ++i1) {\n      sumValue += nodeValue = nodes[i1].value;\n      if (nodeValue < minValue) minValue = nodeValue;\n      if (nodeValue > maxValue) maxValue = nodeValue;\n      beta = sumValue * sumValue * alpha;\n      newRatio = Math.max(maxValue / beta, beta / minValue);\n      if (newRatio > minRatio) { sumValue -= nodeValue; break; }\n      minRatio = newRatio;\n    }\n\n    // Position and record the row orientation.\n    rows.push(row = {value: sumValue, dice: dx < dy, children: nodes.slice(i0, i1)});\n    if (row.dice) treemapDice(row, x0, y0, x1, value ? y0 += dy * sumValue / value : y1);\n    else treemapSlice(row, x0, y0, value ? x0 += dx * sumValue / value : x1, y1);\n    value -= sumValue, i0 = i1;\n  }\n\n  return rows;\n}\n\nvar squarify = ((function custom(ratio) {\n\n  function squarify(parent, x0, y0, x1, y1) {\n    squarifyRatio(ratio, parent, x0, y0, x1, y1);\n  }\n\n  squarify.ratio = function(x) {\n    return custom((x = +x) > 1 ? x : 1);\n  };\n\n  return squarify;\n}))(phi);\n\nvar index$3 = function() {\n  var tile = squarify,\n      round = false,\n      dx = 1,\n      dy = 1,\n      paddingStack = [0],\n      paddingInner = constantZero,\n      paddingTop = constantZero,\n      paddingRight = constantZero,\n      paddingBottom = constantZero,\n      paddingLeft = constantZero;\n\n  function treemap(root) {\n    root.x0 =\n    root.y0 = 0;\n    root.x1 = dx;\n    root.y1 = dy;\n    root.eachBefore(positionNode);\n    paddingStack = [0];\n    if (round) root.eachBefore(roundNode);\n    return root;\n  }\n\n  function positionNode(node) {\n    var p = paddingStack[node.depth],\n        x0 = node.x0 + p,\n        y0 = node.y0 + p,\n        x1 = node.x1 - p,\n        y1 = node.y1 - p;\n    if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n    if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n    node.x0 = x0;\n    node.y0 = y0;\n    node.x1 = x1;\n    node.y1 = y1;\n    if (node.children) {\n      p = paddingStack[node.depth + 1] = paddingInner(node) / 2;\n      x0 += paddingLeft(node) - p;\n      y0 += paddingTop(node) - p;\n      x1 -= paddingRight(node) - p;\n      y1 -= paddingBottom(node) - p;\n      if (x1 < x0) x0 = x1 = (x0 + x1) / 2;\n      if (y1 < y0) y0 = y1 = (y0 + y1) / 2;\n      tile(node, x0, y0, x1, y1);\n    }\n  }\n\n  treemap.round = function(x) {\n    return arguments.length ? (round = !!x, treemap) : round;\n  };\n\n  treemap.size = function(x) {\n    return arguments.length ? (dx = +x[0], dy = +x[1], treemap) : [dx, dy];\n  };\n\n  treemap.tile = function(x) {\n    return arguments.length ? (tile = required(x), treemap) : tile;\n  };\n\n  treemap.padding = function(x) {\n    return arguments.length ? treemap.paddingInner(x).paddingOuter(x) : treemap.paddingInner();\n  };\n\n  treemap.paddingInner = function(x) {\n    return arguments.length ? (paddingInner = typeof x === \"function\" ? x : constant$8(+x), treemap) : paddingInner;\n  };\n\n  treemap.paddingOuter = function(x) {\n    return arguments.length ? treemap.paddingTop(x).paddingRight(x).paddingBottom(x).paddingLeft(x) : treemap.paddingTop();\n  };\n\n  treemap.paddingTop = function(x) {\n    return arguments.length ? (paddingTop = typeof x === \"function\" ? x : constant$8(+x), treemap) : paddingTop;\n  };\n\n  treemap.paddingRight = function(x) {\n    return arguments.length ? (paddingRight = typeof x === \"function\" ? x : constant$8(+x), treemap) : paddingRight;\n  };\n\n  treemap.paddingBottom = function(x) {\n    return arguments.length ? (paddingBottom = typeof x === \"function\" ? x : constant$8(+x), treemap) : paddingBottom;\n  };\n\n  treemap.paddingLeft = function(x) {\n    return arguments.length ? (paddingLeft = typeof x === \"function\" ? x : constant$8(+x), treemap) : paddingLeft;\n  };\n\n  return treemap;\n};\n\nvar binary = function(parent, x0, y0, x1, y1) {\n  var nodes = parent.children,\n      i, n = nodes.length,\n      sum, sums = new Array(n + 1);\n\n  for (sums[0] = sum = i = 0; i < n; ++i) {\n    sums[i + 1] = sum += nodes[i].value;\n  }\n\n  partition(0, n, parent.value, x0, y0, x1, y1);\n\n  function partition(i, j, value, x0, y0, x1, y1) {\n    if (i >= j - 1) {\n      var node = nodes[i];\n      node.x0 = x0, node.y0 = y0;\n      node.x1 = x1, node.y1 = y1;\n      return;\n    }\n\n    var valueOffset = sums[i],\n        valueTarget = (value / 2) + valueOffset,\n        k = i + 1,\n        hi = j - 1;\n\n    while (k < hi) {\n      var mid = k + hi >>> 1;\n      if (sums[mid] < valueTarget) k = mid + 1;\n      else hi = mid;\n    }\n\n    if ((valueTarget - sums[k - 1]) < (sums[k] - valueTarget) && i + 1 < k) --k;\n\n    var valueLeft = sums[k] - valueOffset,\n        valueRight = value - valueLeft;\n\n    if ((x1 - x0) > (y1 - y0)) {\n      var xk = (x0 * valueRight + x1 * valueLeft) / value;\n      partition(i, k, valueLeft, x0, y0, xk, y1);\n      partition(k, j, valueRight, xk, y0, x1, y1);\n    } else {\n      var yk = (y0 * valueRight + y1 * valueLeft) / value;\n      partition(i, k, valueLeft, x0, y0, x1, yk);\n      partition(k, j, valueRight, x0, yk, x1, y1);\n    }\n  }\n};\n\nvar sliceDice = function(parent, x0, y0, x1, y1) {\n  (parent.depth & 1 ? treemapSlice : treemapDice)(parent, x0, y0, x1, y1);\n};\n\nvar resquarify = ((function custom(ratio) {\n\n  function resquarify(parent, x0, y0, x1, y1) {\n    if ((rows = parent._squarify) && (rows.ratio === ratio)) {\n      var rows,\n          row,\n          nodes,\n          i,\n          j = -1,\n          n,\n          m = rows.length,\n          value = parent.value;\n\n      while (++j < m) {\n        row = rows[j], nodes = row.children;\n        for (i = row.value = 0, n = nodes.length; i < n; ++i) row.value += nodes[i].value;\n        if (row.dice) treemapDice(row, x0, y0, x1, y0 += (y1 - y0) * row.value / value);\n        else treemapSlice(row, x0, y0, x0 += (x1 - x0) * row.value / value, y1);\n        value -= row.value;\n      }\n    } else {\n      parent._squarify = rows = squarifyRatio(ratio, parent, x0, y0, x1, y1);\n      rows.ratio = ratio;\n    }\n  }\n\n  resquarify.ratio = function(x) {\n    return custom((x = +x) > 1 ? x : 1);\n  };\n\n  return resquarify;\n}))(phi);\n\nvar area$1 = function(polygon) {\n  var i = -1,\n      n = polygon.length,\n      a,\n      b = polygon[n - 1],\n      area = 0;\n\n  while (++i < n) {\n    a = b;\n    b = polygon[i];\n    area += a[1] * b[0] - a[0] * b[1];\n  }\n\n  return area / 2;\n};\n\nvar centroid$1 = function(polygon) {\n  var i = -1,\n      n = polygon.length,\n      x = 0,\n      y = 0,\n      a,\n      b = polygon[n - 1],\n      c,\n      k = 0;\n\n  while (++i < n) {\n    a = b;\n    b = polygon[i];\n    k += c = a[0] * b[1] - b[0] * a[1];\n    x += (a[0] + b[0]) * c;\n    y += (a[1] + b[1]) * c;\n  }\n\n  return k *= 3, [x / k, y / k];\n};\n\n// Returns the 2D cross product of AB and AC vectors, i.e., the z-component of\n// the 3D cross product in a quadrant I Cartesian coordinate system (+x is\n// right, +y is up). Returns a positive value if ABC is counter-clockwise,\n// negative if clockwise, and zero if the points are collinear.\nvar cross$1 = function(a, b, c) {\n  return (b[0] - a[0]) * (c[1] - a[1]) - (b[1] - a[1]) * (c[0] - a[0]);\n};\n\nfunction lexicographicOrder(a, b) {\n  return a[0] - b[0] || a[1] - b[1];\n}\n\n// Computes the upper convex hull per the monotone chain algorithm.\n// Assumes points.length >= 3, is sorted by x, unique in y.\n// Returns an array of indices into points in left-to-right order.\nfunction computeUpperHullIndexes(points) {\n  var n = points.length,\n      indexes = [0, 1],\n      size = 2;\n\n  for (var i = 2; i < n; ++i) {\n    while (size > 1 && cross$1(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;\n    indexes[size++] = i;\n  }\n\n  return indexes.slice(0, size); // remove popped points\n}\n\nvar hull = function(points) {\n  if ((n = points.length) < 3) return null;\n\n  var i,\n      n,\n      sortedPoints = new Array(n),\n      flippedPoints = new Array(n);\n\n  for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];\n  sortedPoints.sort(lexicographicOrder);\n  for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];\n\n  var upperIndexes = computeUpperHullIndexes(sortedPoints),\n      lowerIndexes = computeUpperHullIndexes(flippedPoints);\n\n  // Construct the hull polygon, removing possible duplicate endpoints.\n  var skipLeft = lowerIndexes[0] === upperIndexes[0],\n      skipRight = lowerIndexes[lowerIndexes.length - 1] === upperIndexes[upperIndexes.length - 1],\n      hull = [];\n\n  // Add upper hull in right-to-l order.\n  // Then add lower hull in left-to-right order.\n  for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);\n  for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);\n\n  return hull;\n};\n\nvar contains$1 = function(polygon, point) {\n  var n = polygon.length,\n      p = polygon[n - 1],\n      x = point[0], y = point[1],\n      x0 = p[0], y0 = p[1],\n      x1, y1,\n      inside = false;\n\n  for (var i = 0; i < n; ++i) {\n    p = polygon[i], x1 = p[0], y1 = p[1];\n    if (((y1 > y) !== (y0 > y)) && (x < (x0 - x1) * (y - y1) / (y0 - y1) + x1)) inside = !inside;\n    x0 = x1, y0 = y1;\n  }\n\n  return inside;\n};\n\nvar length$2 = function(polygon) {\n  var i = -1,\n      n = polygon.length,\n      b = polygon[n - 1],\n      xa,\n      ya,\n      xb = b[0],\n      yb = b[1],\n      perimeter = 0;\n\n  while (++i < n) {\n    xa = xb;\n    ya = yb;\n    b = polygon[i];\n    xb = b[0];\n    yb = b[1];\n    xa -= xb;\n    ya -= yb;\n    perimeter += Math.sqrt(xa * xa + ya * ya);\n  }\n\n  return perimeter;\n};\n\nvar slice$3 = [].slice;\n\nvar noabort = {};\n\nfunction Queue(size) {\n  this._size = size;\n  this._call =\n  this._error = null;\n  this._tasks = [];\n  this._data = [];\n  this._waiting =\n  this._active =\n  this._ended =\n  this._start = 0; // inside a synchronous task callback?\n}\n\nQueue.prototype = queue.prototype = {\n  constructor: Queue,\n  defer: function(callback) {\n    if (typeof callback !== \"function\") throw new Error(\"invalid callback\");\n    if (this._call) throw new Error(\"defer after await\");\n    if (this._error != null) return this;\n    var t = slice$3.call(arguments, 1);\n    t.push(callback);\n    ++this._waiting, this._tasks.push(t);\n    poke$1(this);\n    return this;\n  },\n  abort: function() {\n    if (this._error == null) abort(this, new Error(\"abort\"));\n    return this;\n  },\n  await: function(callback) {\n    if (typeof callback !== \"function\") throw new Error(\"invalid callback\");\n    if (this._call) throw new Error(\"multiple await\");\n    this._call = function(error, results) { callback.apply(null, [error].concat(results)); };\n    maybeNotify(this);\n    return this;\n  },\n  awaitAll: function(callback) {\n    if (typeof callback !== \"function\") throw new Error(\"invalid callback\");\n    if (this._call) throw new Error(\"multiple await\");\n    this._call = callback;\n    maybeNotify(this);\n    return this;\n  }\n};\n\nfunction poke$1(q) {\n  if (!q._start) {\n    try { start$1(q); } // let the current task complete\n    catch (e) {\n      if (q._tasks[q._ended + q._active - 1]) abort(q, e); // task errored synchronously\n      else if (!q._data) throw e; // await callback errored synchronously\n    }\n  }\n}\n\nfunction start$1(q) {\n  while (q._start = q._waiting && q._active < q._size) {\n    var i = q._ended + q._active,\n        t = q._tasks[i],\n        j = t.length - 1,\n        c = t[j];\n    t[j] = end(q, i);\n    --q._waiting, ++q._active;\n    t = c.apply(null, t);\n    if (!q._tasks[i]) continue; // task finished synchronously\n    q._tasks[i] = t || noabort;\n  }\n}\n\nfunction end(q, i) {\n  return function(e, r) {\n    if (!q._tasks[i]) return; // ignore multiple callbacks\n    --q._active, ++q._ended;\n    q._tasks[i] = null;\n    if (q._error != null) return; // ignore secondary errors\n    if (e != null) {\n      abort(q, e);\n    } else {\n      q._data[i] = r;\n      if (q._waiting) poke$1(q);\n      else maybeNotify(q);\n    }\n  };\n}\n\nfunction abort(q, e) {\n  var i = q._tasks.length, t;\n  q._error = e; // ignore active callbacks\n  q._data = undefined; // allow gc\n  q._waiting = NaN; // prevent starting\n\n  while (--i >= 0) {\n    if (t = q._tasks[i]) {\n      q._tasks[i] = null;\n      if (t.abort) {\n        try { t.abort(); }\n        catch (e) { /* ignore */ }\n      }\n    }\n  }\n\n  q._active = NaN; // allow notification\n  maybeNotify(q);\n}\n\nfunction maybeNotify(q) {\n  if (!q._active && q._call) {\n    var d = q._data;\n    q._data = undefined; // allow gc\n    q._call(q._error, d);\n  }\n}\n\nfunction queue(concurrency) {\n  if (concurrency == null) concurrency = Infinity;\n  else if (!((concurrency = +concurrency) >= 1)) throw new Error(\"invalid concurrency\");\n  return new Queue(concurrency);\n}\n\nvar defaultSource$1 = function() {\n  return Math.random();\n};\n\nvar uniform = ((function sourceRandomUniform(source) {\n  function randomUniform(min, max) {\n    min = min == null ? 0 : +min;\n    max = max == null ? 1 : +max;\n    if (arguments.length === 1) max = min, min = 0;\n    else max -= min;\n    return function() {\n      return source() * max + min;\n    };\n  }\n\n  randomUniform.source = sourceRandomUniform;\n\n  return randomUniform;\n}))(defaultSource$1);\n\nvar normal = ((function sourceRandomNormal(source) {\n  function randomNormal(mu, sigma) {\n    var x, r;\n    mu = mu == null ? 0 : +mu;\n    sigma = sigma == null ? 1 : +sigma;\n    return function() {\n      var y;\n\n      // If available, use the second previously-generated uniform random.\n      if (x != null) y = x, x = null;\n\n      // Otherwise, generate a new x and y.\n      else do {\n        x = source() * 2 - 1;\n        y = source() * 2 - 1;\n        r = x * x + y * y;\n      } while (!r || r > 1);\n\n      return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);\n    };\n  }\n\n  randomNormal.source = sourceRandomNormal;\n\n  return randomNormal;\n}))(defaultSource$1);\n\nvar logNormal = ((function sourceRandomLogNormal(source) {\n  function randomLogNormal() {\n    var randomNormal = normal.source(source).apply(this, arguments);\n    return function() {\n      return Math.exp(randomNormal());\n    };\n  }\n\n  randomLogNormal.source = sourceRandomLogNormal;\n\n  return randomLogNormal;\n}))(defaultSource$1);\n\nvar irwinHall = ((function sourceRandomIrwinHall(source) {\n  function randomIrwinHall(n) {\n    return function() {\n      for (var sum = 0, i = 0; i < n; ++i) sum += source();\n      return sum;\n    };\n  }\n\n  randomIrwinHall.source = sourceRandomIrwinHall;\n\n  return randomIrwinHall;\n}))(defaultSource$1);\n\nvar bates = ((function sourceRandomBates(source) {\n  function randomBates(n) {\n    var randomIrwinHall = irwinHall.source(source)(n);\n    return function() {\n      return randomIrwinHall() / n;\n    };\n  }\n\n  randomBates.source = sourceRandomBates;\n\n  return randomBates;\n}))(defaultSource$1);\n\nvar exponential$1 = ((function sourceRandomExponential(source) {\n  function randomExponential(lambda) {\n    return function() {\n      return -Math.log(1 - source()) / lambda;\n    };\n  }\n\n  randomExponential.source = sourceRandomExponential;\n\n  return randomExponential;\n}))(defaultSource$1);\n\nvar request = function(url, callback) {\n  var request,\n      event = dispatch(\"beforesend\", \"progress\", \"load\", \"error\"),\n      mimeType,\n      headers = map$1(),\n      xhr = new XMLHttpRequest,\n      user = null,\n      password = null,\n      response,\n      responseType,\n      timeout = 0;\n\n  // If IE does not support CORS, use XDomainRequest.\n  if (typeof XDomainRequest !== \"undefined\"\n      && !(\"withCredentials\" in xhr)\n      && /^(http(s)?:)?\\/\\//.test(url)) xhr = new XDomainRequest;\n\n  \"onload\" in xhr\n      ? xhr.onload = xhr.onerror = xhr.ontimeout = respond\n      : xhr.onreadystatechange = function(o) { xhr.readyState > 3 && respond(o); };\n\n  function respond(o) {\n    var status = xhr.status, result;\n    if (!status && hasResponse(xhr)\n        || status >= 200 && status < 300\n        || status === 304) {\n      if (response) {\n        try {\n          result = response.call(request, xhr);\n        } catch (e) {\n          event.call(\"error\", request, e);\n          return;\n        }\n      } else {\n        result = xhr;\n      }\n      event.call(\"load\", request, result);\n    } else {\n      event.call(\"error\", request, o);\n    }\n  }\n\n  xhr.onprogress = function(e) {\n    event.call(\"progress\", request, e);\n  };\n\n  request = {\n    header: function(name, value) {\n      name = (name + \"\").toLowerCase();\n      if (arguments.length < 2) return headers.get(name);\n      if (value == null) headers.remove(name);\n      else headers.set(name, value + \"\");\n      return request;\n    },\n\n    // If mimeType is non-null and no Accept header is set, a default is used.\n    mimeType: function(value) {\n      if (!arguments.length) return mimeType;\n      mimeType = value == null ? null : value + \"\";\n      return request;\n    },\n\n    // Specifies what type the response value should take;\n    // for instance, arraybuffer, blob, document, or text.\n    responseType: function(value) {\n      if (!arguments.length) return responseType;\n      responseType = value;\n      return request;\n    },\n\n    timeout: function(value) {\n      if (!arguments.length) return timeout;\n      timeout = +value;\n      return request;\n    },\n\n    user: function(value) {\n      return arguments.length < 1 ? user : (user = value == null ? null : value + \"\", request);\n    },\n\n    password: function(value) {\n      return arguments.length < 1 ? password : (password = value == null ? null : value + \"\", request);\n    },\n\n    // Specify how to convert the response content to a specific type;\n    // changes the callback value on \"load\" events.\n    response: function(value) {\n      response = value;\n      return request;\n    },\n\n    // Alias for send(\"GET\", …).\n    get: function(data, callback) {\n      return request.send(\"GET\", data, callback);\n    },\n\n    // Alias for send(\"POST\", …).\n    post: function(data, callback) {\n      return request.send(\"POST\", data, callback);\n    },\n\n    // If callback is non-null, it will be used for error and load events.\n    send: function(method, data, callback) {\n      xhr.open(method, url, true, user, password);\n      if (mimeType != null && !headers.has(\"accept\")) headers.set(\"accept\", mimeType + \",*/*\");\n      if (xhr.setRequestHeader) headers.each(function(value, name) { xhr.setRequestHeader(name, value); });\n      if (mimeType != null && xhr.overrideMimeType) xhr.overrideMimeType(mimeType);\n      if (responseType != null) xhr.responseType = responseType;\n      if (timeout > 0) xhr.timeout = timeout;\n      if (callback == null && typeof data === \"function\") callback = data, data = null;\n      if (callback != null && callback.length === 1) callback = fixCallback(callback);\n      if (callback != null) request.on(\"error\", callback).on(\"load\", function(xhr) { callback(null, xhr); });\n      event.call(\"beforesend\", request, xhr);\n      xhr.send(data == null ? null : data);\n      return request;\n    },\n\n    abort: function() {\n      xhr.abort();\n      return request;\n    },\n\n    on: function() {\n      var value = event.on.apply(event, arguments);\n      return value === event ? request : value;\n    }\n  };\n\n  if (callback != null) {\n    if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n    return request.get(callback);\n  }\n\n  return request;\n};\n\nfunction fixCallback(callback) {\n  return function(error, xhr) {\n    callback(error == null ? xhr : null);\n  };\n}\n\nfunction hasResponse(xhr) {\n  var type = xhr.responseType;\n  return type && type !== \"text\"\n      ? xhr.response // null on error\n      : xhr.responseText; // \"\" on error\n}\n\nvar type$1 = function(defaultMimeType, response) {\n  return function(url, callback) {\n    var r = request(url).mimeType(defaultMimeType).response(response);\n    if (callback != null) {\n      if (typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n      return r.get(callback);\n    }\n    return r;\n  };\n};\n\nvar html = type$1(\"text/html\", function(xhr) {\n  return document.createRange().createContextualFragment(xhr.responseText);\n});\n\nvar json = type$1(\"application/json\", function(xhr) {\n  return JSON.parse(xhr.responseText);\n});\n\nvar text = type$1(\"text/plain\", function(xhr) {\n  return xhr.responseText;\n});\n\nvar xml = type$1(\"application/xml\", function(xhr) {\n  var xml = xhr.responseXML;\n  if (!xml) throw new Error(\"parse error\");\n  return xml;\n});\n\nvar dsv$1 = function(defaultMimeType, parse) {\n  return function(url, row, callback) {\n    if (arguments.length < 3) callback = row, row = null;\n    var r = request(url).mimeType(defaultMimeType);\n    r.row = function(_) { return arguments.length ? r.response(responseOf(parse, row = _)) : row; };\n    r.row(row);\n    return callback ? r.get(callback) : r;\n  };\n};\n\nfunction responseOf(parse, row) {\n  return function(request$$1) {\n    return parse(request$$1.responseText, row);\n  };\n}\n\nvar csv$1 = dsv$1(\"text/csv\", csvParse);\n\nvar tsv$1 = dsv$1(\"text/tab-separated-values\", tsvParse);\n\nvar array$2 = Array.prototype;\n\nvar map$3 = array$2.map;\nvar slice$4 = array$2.slice;\n\nvar implicit = {name: \"implicit\"};\n\nfunction ordinal(range) {\n  var index = map$1(),\n      domain = [],\n      unknown = implicit;\n\n  range = range == null ? [] : slice$4.call(range);\n\n  function scale(d) {\n    var key = d + \"\", i = index.get(key);\n    if (!i) {\n      if (unknown !== implicit) return unknown;\n      index.set(key, i = domain.push(d));\n    }\n    return range[(i - 1) % range.length];\n  }\n\n  scale.domain = function(_) {\n    if (!arguments.length) return domain.slice();\n    domain = [], index = map$1();\n    var i = -1, n = _.length, d, key;\n    while (++i < n) if (!index.has(key = (d = _[i]) + \"\")) index.set(key, domain.push(d));\n    return scale;\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (range = slice$4.call(_), scale) : range.slice();\n  };\n\n  scale.unknown = function(_) {\n    return arguments.length ? (unknown = _, scale) : unknown;\n  };\n\n  scale.copy = function() {\n    return ordinal()\n        .domain(domain)\n        .range(range)\n        .unknown(unknown);\n  };\n\n  return scale;\n}\n\nfunction band() {\n  var scale = ordinal().unknown(undefined),\n      domain = scale.domain,\n      ordinalRange = scale.range,\n      range$$1 = [0, 1],\n      step,\n      bandwidth,\n      round = false,\n      paddingInner = 0,\n      paddingOuter = 0,\n      align = 0.5;\n\n  delete scale.unknown;\n\n  function rescale() {\n    var n = domain().length,\n        reverse = range$$1[1] < range$$1[0],\n        start = range$$1[reverse - 0],\n        stop = range$$1[1 - reverse];\n    step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);\n    if (round) step = Math.floor(step);\n    start += (stop - start - step * (n - paddingInner)) * align;\n    bandwidth = step * (1 - paddingInner);\n    if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);\n    var values = sequence(n).map(function(i) { return start + step * i; });\n    return ordinalRange(reverse ? values.reverse() : values);\n  }\n\n  scale.domain = function(_) {\n    return arguments.length ? (domain(_), rescale()) : domain();\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (range$$1 = [+_[0], +_[1]], rescale()) : range$$1.slice();\n  };\n\n  scale.rangeRound = function(_) {\n    return range$$1 = [+_[0], +_[1]], round = true, rescale();\n  };\n\n  scale.bandwidth = function() {\n    return bandwidth;\n  };\n\n  scale.step = function() {\n    return step;\n  };\n\n  scale.round = function(_) {\n    return arguments.length ? (round = !!_, rescale()) : round;\n  };\n\n  scale.padding = function(_) {\n    return arguments.length ? (paddingInner = paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n  };\n\n  scale.paddingInner = function(_) {\n    return arguments.length ? (paddingInner = Math.max(0, Math.min(1, _)), rescale()) : paddingInner;\n  };\n\n  scale.paddingOuter = function(_) {\n    return arguments.length ? (paddingOuter = Math.max(0, Math.min(1, _)), rescale()) : paddingOuter;\n  };\n\n  scale.align = function(_) {\n    return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;\n  };\n\n  scale.copy = function() {\n    return band()\n        .domain(domain())\n        .range(range$$1)\n        .round(round)\n        .paddingInner(paddingInner)\n        .paddingOuter(paddingOuter)\n        .align(align);\n  };\n\n  return rescale();\n}\n\nfunction pointish(scale) {\n  var copy = scale.copy;\n\n  scale.padding = scale.paddingOuter;\n  delete scale.paddingInner;\n  delete scale.paddingOuter;\n\n  scale.copy = function() {\n    return pointish(copy());\n  };\n\n  return scale;\n}\n\nfunction point$1() {\n  return pointish(band().paddingInner(1));\n}\n\nvar constant$9 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nvar number$1 = function(x) {\n  return +x;\n};\n\nvar unit = [0, 1];\n\nfunction deinterpolateLinear(a, b) {\n  return (b -= (a = +a))\n      ? function(x) { return (x - a) / b; }\n      : constant$9(b);\n}\n\nfunction deinterpolateClamp(deinterpolate) {\n  return function(a, b) {\n    var d = deinterpolate(a = +a, b = +b);\n    return function(x) { return x <= a ? 0 : x >= b ? 1 : d(x); };\n  };\n}\n\nfunction reinterpolateClamp(reinterpolate) {\n  return function(a, b) {\n    var r = reinterpolate(a = +a, b = +b);\n    return function(t) { return t <= 0 ? a : t >= 1 ? b : r(t); };\n  };\n}\n\nfunction bimap(domain, range$$1, deinterpolate, reinterpolate) {\n  var d0 = domain[0], d1 = domain[1], r0 = range$$1[0], r1 = range$$1[1];\n  if (d1 < d0) d0 = deinterpolate(d1, d0), r0 = reinterpolate(r1, r0);\n  else d0 = deinterpolate(d0, d1), r0 = reinterpolate(r0, r1);\n  return function(x) { return r0(d0(x)); };\n}\n\nfunction polymap(domain, range$$1, deinterpolate, reinterpolate) {\n  var j = Math.min(domain.length, range$$1.length) - 1,\n      d = new Array(j),\n      r = new Array(j),\n      i = -1;\n\n  // Reverse descending domains.\n  if (domain[j] < domain[0]) {\n    domain = domain.slice().reverse();\n    range$$1 = range$$1.slice().reverse();\n  }\n\n  while (++i < j) {\n    d[i] = deinterpolate(domain[i], domain[i + 1]);\n    r[i] = reinterpolate(range$$1[i], range$$1[i + 1]);\n  }\n\n  return function(x) {\n    var i = bisectRight(domain, x, 1, j) - 1;\n    return r[i](d[i](x));\n  };\n}\n\nfunction copy(source, target) {\n  return target\n      .domain(source.domain())\n      .range(source.range())\n      .interpolate(source.interpolate())\n      .clamp(source.clamp());\n}\n\n// deinterpolate(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].\n// reinterpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding domain value x in [a,b].\nfunction continuous(deinterpolate, reinterpolate) {\n  var domain = unit,\n      range$$1 = unit,\n      interpolate$$1 = interpolateValue,\n      clamp = false,\n      piecewise,\n      output,\n      input;\n\n  function rescale() {\n    piecewise = Math.min(domain.length, range$$1.length) > 2 ? polymap : bimap;\n    output = input = null;\n    return scale;\n  }\n\n  function scale(x) {\n    return (output || (output = piecewise(domain, range$$1, clamp ? deinterpolateClamp(deinterpolate) : deinterpolate, interpolate$$1)))(+x);\n  }\n\n  scale.invert = function(y) {\n    return (input || (input = piecewise(range$$1, domain, deinterpolateLinear, clamp ? reinterpolateClamp(reinterpolate) : reinterpolate)))(+y);\n  };\n\n  scale.domain = function(_) {\n    return arguments.length ? (domain = map$3.call(_, number$1), rescale()) : domain.slice();\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (range$$1 = slice$4.call(_), rescale()) : range$$1.slice();\n  };\n\n  scale.rangeRound = function(_) {\n    return range$$1 = slice$4.call(_), interpolate$$1 = interpolateRound, rescale();\n  };\n\n  scale.clamp = function(_) {\n    return arguments.length ? (clamp = !!_, rescale()) : clamp;\n  };\n\n  scale.interpolate = function(_) {\n    return arguments.length ? (interpolate$$1 = _, rescale()) : interpolate$$1;\n  };\n\n  return rescale();\n}\n\nvar tickFormat = function(domain, count, specifier) {\n  var start = domain[0],\n      stop = domain[domain.length - 1],\n      step = tickStep(start, stop, count == null ? 10 : count),\n      precision;\n  specifier = formatSpecifier(specifier == null ? \",f\" : specifier);\n  switch (specifier.type) {\n    case \"s\": {\n      var value = Math.max(Math.abs(start), Math.abs(stop));\n      if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;\n      return exports.formatPrefix(specifier, value);\n    }\n    case \"\":\n    case \"e\":\n    case \"g\":\n    case \"p\":\n    case \"r\": {\n      if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === \"e\");\n      break;\n    }\n    case \"f\":\n    case \"%\": {\n      if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === \"%\") * 2;\n      break;\n    }\n  }\n  return exports.format(specifier);\n};\n\nfunction linearish(scale) {\n  var domain = scale.domain;\n\n  scale.ticks = function(count) {\n    var d = domain();\n    return ticks(d[0], d[d.length - 1], count == null ? 10 : count);\n  };\n\n  scale.tickFormat = function(count, specifier) {\n    return tickFormat(domain(), count, specifier);\n  };\n\n  scale.nice = function(count) {\n    if (count == null) count = 10;\n\n    var d = domain(),\n        i0 = 0,\n        i1 = d.length - 1,\n        start = d[i0],\n        stop = d[i1],\n        step;\n\n    if (stop < start) {\n      step = start, start = stop, stop = step;\n      step = i0, i0 = i1, i1 = step;\n    }\n\n    step = tickIncrement(start, stop, count);\n\n    if (step > 0) {\n      start = Math.floor(start / step) * step;\n      stop = Math.ceil(stop / step) * step;\n      step = tickIncrement(start, stop, count);\n    } else if (step < 0) {\n      start = Math.ceil(start * step) / step;\n      stop = Math.floor(stop * step) / step;\n      step = tickIncrement(start, stop, count);\n    }\n\n    if (step > 0) {\n      d[i0] = Math.floor(start / step) * step;\n      d[i1] = Math.ceil(stop / step) * step;\n      domain(d);\n    } else if (step < 0) {\n      d[i0] = Math.ceil(start * step) / step;\n      d[i1] = Math.floor(stop * step) / step;\n      domain(d);\n    }\n\n    return scale;\n  };\n\n  return scale;\n}\n\nfunction linear$2() {\n  var scale = continuous(deinterpolateLinear, reinterpolate);\n\n  scale.copy = function() {\n    return copy(scale, linear$2());\n  };\n\n  return linearish(scale);\n}\n\nfunction identity$6() {\n  var domain = [0, 1];\n\n  function scale(x) {\n    return +x;\n  }\n\n  scale.invert = scale;\n\n  scale.domain = scale.range = function(_) {\n    return arguments.length ? (domain = map$3.call(_, number$1), scale) : domain.slice();\n  };\n\n  scale.copy = function() {\n    return identity$6().domain(domain);\n  };\n\n  return linearish(scale);\n}\n\nvar nice = function(domain, interval) {\n  domain = domain.slice();\n\n  var i0 = 0,\n      i1 = domain.length - 1,\n      x0 = domain[i0],\n      x1 = domain[i1],\n      t;\n\n  if (x1 < x0) {\n    t = i0, i0 = i1, i1 = t;\n    t = x0, x0 = x1, x1 = t;\n  }\n\n  domain[i0] = interval.floor(x0);\n  domain[i1] = interval.ceil(x1);\n  return domain;\n};\n\nfunction deinterpolate(a, b) {\n  return (b = Math.log(b / a))\n      ? function(x) { return Math.log(x / a) / b; }\n      : constant$9(b);\n}\n\nfunction reinterpolate$1(a, b) {\n  return a < 0\n      ? function(t) { return -Math.pow(-b, t) * Math.pow(-a, 1 - t); }\n      : function(t) { return Math.pow(b, t) * Math.pow(a, 1 - t); };\n}\n\nfunction pow10(x) {\n  return isFinite(x) ? +(\"1e\" + x) : x < 0 ? 0 : x;\n}\n\nfunction powp(base) {\n  return base === 10 ? pow10\n      : base === Math.E ? Math.exp\n      : function(x) { return Math.pow(base, x); };\n}\n\nfunction logp(base) {\n  return base === Math.E ? Math.log\n      : base === 10 && Math.log10\n      || base === 2 && Math.log2\n      || (base = Math.log(base), function(x) { return Math.log(x) / base; });\n}\n\nfunction reflect(f) {\n  return function(x) {\n    return -f(-x);\n  };\n}\n\nfunction log$1() {\n  var scale = continuous(deinterpolate, reinterpolate$1).domain([1, 10]),\n      domain = scale.domain,\n      base = 10,\n      logs = logp(10),\n      pows = powp(10);\n\n  function rescale() {\n    logs = logp(base), pows = powp(base);\n    if (domain()[0] < 0) logs = reflect(logs), pows = reflect(pows);\n    return scale;\n  }\n\n  scale.base = function(_) {\n    return arguments.length ? (base = +_, rescale()) : base;\n  };\n\n  scale.domain = function(_) {\n    return arguments.length ? (domain(_), rescale()) : domain();\n  };\n\n  scale.ticks = function(count) {\n    var d = domain(),\n        u = d[0],\n        v = d[d.length - 1],\n        r;\n\n    if (r = v < u) i = u, u = v, v = i;\n\n    var i = logs(u),\n        j = logs(v),\n        p,\n        k,\n        t,\n        n = count == null ? 10 : +count,\n        z = [];\n\n    if (!(base % 1) && j - i < n) {\n      i = Math.round(i) - 1, j = Math.round(j) + 1;\n      if (u > 0) for (; i < j; ++i) {\n        for (k = 1, p = pows(i); k < base; ++k) {\n          t = p * k;\n          if (t < u) continue;\n          if (t > v) break;\n          z.push(t);\n        }\n      } else for (; i < j; ++i) {\n        for (k = base - 1, p = pows(i); k >= 1; --k) {\n          t = p * k;\n          if (t < u) continue;\n          if (t > v) break;\n          z.push(t);\n        }\n      }\n    } else {\n      z = ticks(i, j, Math.min(j - i, n)).map(pows);\n    }\n\n    return r ? z.reverse() : z;\n  };\n\n  scale.tickFormat = function(count, specifier) {\n    if (specifier == null) specifier = base === 10 ? \".0e\" : \",\";\n    if (typeof specifier !== \"function\") specifier = exports.format(specifier);\n    if (count === Infinity) return specifier;\n    if (count == null) count = 10;\n    var k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?\n    return function(d) {\n      var i = d / pows(Math.round(logs(d)));\n      if (i * base < base - 0.5) i *= base;\n      return i <= k ? specifier(d) : \"\";\n    };\n  };\n\n  scale.nice = function() {\n    return domain(nice(domain(), {\n      floor: function(x) { return pows(Math.floor(logs(x))); },\n      ceil: function(x) { return pows(Math.ceil(logs(x))); }\n    }));\n  };\n\n  scale.copy = function() {\n    return copy(scale, log$1().base(base));\n  };\n\n  return scale;\n}\n\nfunction raise$1(x, exponent) {\n  return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);\n}\n\nfunction pow$1() {\n  var exponent = 1,\n      scale = continuous(deinterpolate, reinterpolate),\n      domain = scale.domain;\n\n  function deinterpolate(a, b) {\n    return (b = raise$1(b, exponent) - (a = raise$1(a, exponent)))\n        ? function(x) { return (raise$1(x, exponent) - a) / b; }\n        : constant$9(b);\n  }\n\n  function reinterpolate(a, b) {\n    b = raise$1(b, exponent) - (a = raise$1(a, exponent));\n    return function(t) { return raise$1(a + b * t, 1 / exponent); };\n  }\n\n  scale.exponent = function(_) {\n    return arguments.length ? (exponent = +_, domain(domain())) : exponent;\n  };\n\n  scale.copy = function() {\n    return copy(scale, pow$1().exponent(exponent));\n  };\n\n  return linearish(scale);\n}\n\nfunction sqrt$1() {\n  return pow$1().exponent(0.5);\n}\n\nfunction quantile$$1() {\n  var domain = [],\n      range$$1 = [],\n      thresholds = [];\n\n  function rescale() {\n    var i = 0, n = Math.max(1, range$$1.length);\n    thresholds = new Array(n - 1);\n    while (++i < n) thresholds[i - 1] = threshold(domain, i / n);\n    return scale;\n  }\n\n  function scale(x) {\n    if (!isNaN(x = +x)) return range$$1[bisectRight(thresholds, x)];\n  }\n\n  scale.invertExtent = function(y) {\n    var i = range$$1.indexOf(y);\n    return i < 0 ? [NaN, NaN] : [\n      i > 0 ? thresholds[i - 1] : domain[0],\n      i < thresholds.length ? thresholds[i] : domain[domain.length - 1]\n    ];\n  };\n\n  scale.domain = function(_) {\n    if (!arguments.length) return domain.slice();\n    domain = [];\n    for (var i = 0, n = _.length, d; i < n; ++i) if (d = _[i], d != null && !isNaN(d = +d)) domain.push(d);\n    domain.sort(ascending);\n    return rescale();\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (range$$1 = slice$4.call(_), rescale()) : range$$1.slice();\n  };\n\n  scale.quantiles = function() {\n    return thresholds.slice();\n  };\n\n  scale.copy = function() {\n    return quantile$$1()\n        .domain(domain)\n        .range(range$$1);\n  };\n\n  return scale;\n}\n\nfunction quantize$1() {\n  var x0 = 0,\n      x1 = 1,\n      n = 1,\n      domain = [0.5],\n      range$$1 = [0, 1];\n\n  function scale(x) {\n    if (x <= x) return range$$1[bisectRight(domain, x, 0, n)];\n  }\n\n  function rescale() {\n    var i = -1;\n    domain = new Array(n);\n    while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);\n    return scale;\n  }\n\n  scale.domain = function(_) {\n    return arguments.length ? (x0 = +_[0], x1 = +_[1], rescale()) : [x0, x1];\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (n = (range$$1 = slice$4.call(_)).length - 1, rescale()) : range$$1.slice();\n  };\n\n  scale.invertExtent = function(y) {\n    var i = range$$1.indexOf(y);\n    return i < 0 ? [NaN, NaN]\n        : i < 1 ? [x0, domain[0]]\n        : i >= n ? [domain[n - 1], x1]\n        : [domain[i - 1], domain[i]];\n  };\n\n  scale.copy = function() {\n    return quantize$1()\n        .domain([x0, x1])\n        .range(range$$1);\n  };\n\n  return linearish(scale);\n}\n\nfunction threshold$1() {\n  var domain = [0.5],\n      range$$1 = [0, 1],\n      n = 1;\n\n  function scale(x) {\n    if (x <= x) return range$$1[bisectRight(domain, x, 0, n)];\n  }\n\n  scale.domain = function(_) {\n    return arguments.length ? (domain = slice$4.call(_), n = Math.min(domain.length, range$$1.length - 1), scale) : domain.slice();\n  };\n\n  scale.range = function(_) {\n    return arguments.length ? (range$$1 = slice$4.call(_), n = Math.min(domain.length, range$$1.length - 1), scale) : range$$1.slice();\n  };\n\n  scale.invertExtent = function(y) {\n    var i = range$$1.indexOf(y);\n    return [domain[i - 1], domain[i]];\n  };\n\n  scale.copy = function() {\n    return threshold$1()\n        .domain(domain)\n        .range(range$$1);\n  };\n\n  return scale;\n}\n\nvar t0$1 = new Date;\nvar t1$1 = new Date;\n\nfunction newInterval(floori, offseti, count, field) {\n\n  function interval(date) {\n    return floori(date = new Date(+date)), date;\n  }\n\n  interval.floor = interval;\n\n  interval.ceil = function(date) {\n    return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n  };\n\n  interval.round = function(date) {\n    var d0 = interval(date),\n        d1 = interval.ceil(date);\n    return date - d0 < d1 - date ? d0 : d1;\n  };\n\n  interval.offset = function(date, step) {\n    return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n  };\n\n  interval.range = function(start, stop, step) {\n    var range = [];\n    start = interval.ceil(start);\n    step = step == null ? 1 : Math.floor(step);\n    if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n    do range.push(new Date(+start)); while (offseti(start, step), floori(start), start < stop)\n    return range;\n  };\n\n  interval.filter = function(test) {\n    return newInterval(function(date) {\n      if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);\n    }, function(date, step) {\n      if (date >= date) while (--step >= 0) while (offseti(date, 1), !test(date)) {} // eslint-disable-line no-empty\n    });\n  };\n\n  if (count) {\n    interval.count = function(start, end) {\n      t0$1.setTime(+start), t1$1.setTime(+end);\n      floori(t0$1), floori(t1$1);\n      return Math.floor(count(t0$1, t1$1));\n    };\n\n    interval.every = function(step) {\n      step = Math.floor(step);\n      return !isFinite(step) || !(step > 0) ? null\n          : !(step > 1) ? interval\n          : interval.filter(field\n              ? function(d) { return field(d) % step === 0; }\n              : function(d) { return interval.count(0, d) % step === 0; });\n    };\n  }\n\n  return interval;\n}\n\nvar millisecond = newInterval(function() {\n  // noop\n}, function(date, step) {\n  date.setTime(+date + step);\n}, function(start, end) {\n  return end - start;\n});\n\n// An optimized implementation for this simple case.\nmillisecond.every = function(k) {\n  k = Math.floor(k);\n  if (!isFinite(k) || !(k > 0)) return null;\n  if (!(k > 1)) return millisecond;\n  return newInterval(function(date) {\n    date.setTime(Math.floor(date / k) * k);\n  }, function(date, step) {\n    date.setTime(+date + step * k);\n  }, function(start, end) {\n    return (end - start) / k;\n  });\n};\n\nvar milliseconds = millisecond.range;\n\nvar durationSecond$1 = 1e3;\nvar durationMinute$1 = 6e4;\nvar durationHour$1 = 36e5;\nvar durationDay$1 = 864e5;\nvar durationWeek$1 = 6048e5;\n\nvar second = newInterval(function(date) {\n  date.setTime(Math.floor(date / durationSecond$1) * durationSecond$1);\n}, function(date, step) {\n  date.setTime(+date + step * durationSecond$1);\n}, function(start, end) {\n  return (end - start) / durationSecond$1;\n}, function(date) {\n  return date.getUTCSeconds();\n});\n\nvar seconds = second.range;\n\nvar minute = newInterval(function(date) {\n  date.setTime(Math.floor(date / durationMinute$1) * durationMinute$1);\n}, function(date, step) {\n  date.setTime(+date + step * durationMinute$1);\n}, function(start, end) {\n  return (end - start) / durationMinute$1;\n}, function(date) {\n  return date.getMinutes();\n});\n\nvar minutes = minute.range;\n\nvar hour = newInterval(function(date) {\n  var offset = date.getTimezoneOffset() * durationMinute$1 % durationHour$1;\n  if (offset < 0) offset += durationHour$1;\n  date.setTime(Math.floor((+date - offset) / durationHour$1) * durationHour$1 + offset);\n}, function(date, step) {\n  date.setTime(+date + step * durationHour$1);\n}, function(start, end) {\n  return (end - start) / durationHour$1;\n}, function(date) {\n  return date.getHours();\n});\n\nvar hours = hour.range;\n\nvar day = newInterval(function(date) {\n  date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setDate(date.getDate() + step);\n}, function(start, end) {\n  return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute$1) / durationDay$1;\n}, function(date) {\n  return date.getDate() - 1;\n});\n\nvar days = day.range;\n\nfunction weekday(i) {\n  return newInterval(function(date) {\n    date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n    date.setHours(0, 0, 0, 0);\n  }, function(date, step) {\n    date.setDate(date.getDate() + step * 7);\n  }, function(start, end) {\n    return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute$1) / durationWeek$1;\n  });\n}\n\nvar sunday = weekday(0);\nvar monday = weekday(1);\nvar tuesday = weekday(2);\nvar wednesday = weekday(3);\nvar thursday = weekday(4);\nvar friday = weekday(5);\nvar saturday = weekday(6);\n\nvar sundays = sunday.range;\nvar mondays = monday.range;\nvar tuesdays = tuesday.range;\nvar wednesdays = wednesday.range;\nvar thursdays = thursday.range;\nvar fridays = friday.range;\nvar saturdays = saturday.range;\n\nvar month = newInterval(function(date) {\n  date.setDate(1);\n  date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setMonth(date.getMonth() + step);\n}, function(start, end) {\n  return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n}, function(date) {\n  return date.getMonth();\n});\n\nvar months = month.range;\n\nvar year = newInterval(function(date) {\n  date.setMonth(0, 1);\n  date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setFullYear(date.getFullYear() + step);\n}, function(start, end) {\n  return end.getFullYear() - start.getFullYear();\n}, function(date) {\n  return date.getFullYear();\n});\n\n// An optimized implementation for this simple case.\nyear.every = function(k) {\n  return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n    date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n    date.setMonth(0, 1);\n    date.setHours(0, 0, 0, 0);\n  }, function(date, step) {\n    date.setFullYear(date.getFullYear() + step * k);\n  });\n};\n\nvar years = year.range;\n\nvar utcMinute = newInterval(function(date) {\n  date.setUTCSeconds(0, 0);\n}, function(date, step) {\n  date.setTime(+date + step * durationMinute$1);\n}, function(start, end) {\n  return (end - start) / durationMinute$1;\n}, function(date) {\n  return date.getUTCMinutes();\n});\n\nvar utcMinutes = utcMinute.range;\n\nvar utcHour = newInterval(function(date) {\n  date.setUTCMinutes(0, 0, 0);\n}, function(date, step) {\n  date.setTime(+date + step * durationHour$1);\n}, function(start, end) {\n  return (end - start) / durationHour$1;\n}, function(date) {\n  return date.getUTCHours();\n});\n\nvar utcHours = utcHour.range;\n\nvar utcDay = newInterval(function(date) {\n  date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setUTCDate(date.getUTCDate() + step);\n}, function(start, end) {\n  return (end - start) / durationDay$1;\n}, function(date) {\n  return date.getUTCDate() - 1;\n});\n\nvar utcDays = utcDay.range;\n\nfunction utcWeekday(i) {\n  return newInterval(function(date) {\n    date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n    date.setUTCHours(0, 0, 0, 0);\n  }, function(date, step) {\n    date.setUTCDate(date.getUTCDate() + step * 7);\n  }, function(start, end) {\n    return (end - start) / durationWeek$1;\n  });\n}\n\nvar utcSunday = utcWeekday(0);\nvar utcMonday = utcWeekday(1);\nvar utcTuesday = utcWeekday(2);\nvar utcWednesday = utcWeekday(3);\nvar utcThursday = utcWeekday(4);\nvar utcFriday = utcWeekday(5);\nvar utcSaturday = utcWeekday(6);\n\nvar utcSundays = utcSunday.range;\nvar utcMondays = utcMonday.range;\nvar utcTuesdays = utcTuesday.range;\nvar utcWednesdays = utcWednesday.range;\nvar utcThursdays = utcThursday.range;\nvar utcFridays = utcFriday.range;\nvar utcSaturdays = utcSaturday.range;\n\nvar utcMonth = newInterval(function(date) {\n  date.setUTCDate(1);\n  date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setUTCMonth(date.getUTCMonth() + step);\n}, function(start, end) {\n  return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n}, function(date) {\n  return date.getUTCMonth();\n});\n\nvar utcMonths = utcMonth.range;\n\nvar utcYear = newInterval(function(date) {\n  date.setUTCMonth(0, 1);\n  date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n  date.setUTCFullYear(date.getUTCFullYear() + step);\n}, function(start, end) {\n  return end.getUTCFullYear() - start.getUTCFullYear();\n}, function(date) {\n  return date.getUTCFullYear();\n});\n\n// An optimized implementation for this simple case.\nutcYear.every = function(k) {\n  return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : newInterval(function(date) {\n    date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n    date.setUTCMonth(0, 1);\n    date.setUTCHours(0, 0, 0, 0);\n  }, function(date, step) {\n    date.setUTCFullYear(date.getUTCFullYear() + step * k);\n  });\n};\n\nvar utcYears = utcYear.range;\n\nfunction localDate(d) {\n  if (0 <= d.y && d.y < 100) {\n    var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n    date.setFullYear(d.y);\n    return date;\n  }\n  return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n}\n\nfunction utcDate(d) {\n  if (0 <= d.y && d.y < 100) {\n    var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n    date.setUTCFullYear(d.y);\n    return date;\n  }\n  return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n}\n\nfunction newYear(y) {\n  return {y: y, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0};\n}\n\nfunction formatLocale$1(locale) {\n  var locale_dateTime = locale.dateTime,\n      locale_date = locale.date,\n      locale_time = locale.time,\n      locale_periods = locale.periods,\n      locale_weekdays = locale.days,\n      locale_shortWeekdays = locale.shortDays,\n      locale_months = locale.months,\n      locale_shortMonths = locale.shortMonths;\n\n  var periodRe = formatRe(locale_periods),\n      periodLookup = formatLookup(locale_periods),\n      weekdayRe = formatRe(locale_weekdays),\n      weekdayLookup = formatLookup(locale_weekdays),\n      shortWeekdayRe = formatRe(locale_shortWeekdays),\n      shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n      monthRe = formatRe(locale_months),\n      monthLookup = formatLookup(locale_months),\n      shortMonthRe = formatRe(locale_shortMonths),\n      shortMonthLookup = formatLookup(locale_shortMonths);\n\n  var formats = {\n    \"a\": formatShortWeekday,\n    \"A\": formatWeekday,\n    \"b\": formatShortMonth,\n    \"B\": formatMonth,\n    \"c\": null,\n    \"d\": formatDayOfMonth,\n    \"e\": formatDayOfMonth,\n    \"H\": formatHour24,\n    \"I\": formatHour12,\n    \"j\": formatDayOfYear,\n    \"L\": formatMilliseconds,\n    \"m\": formatMonthNumber,\n    \"M\": formatMinutes,\n    \"p\": formatPeriod,\n    \"S\": formatSeconds,\n    \"U\": formatWeekNumberSunday,\n    \"w\": formatWeekdayNumber,\n    \"W\": formatWeekNumberMonday,\n    \"x\": null,\n    \"X\": null,\n    \"y\": formatYear,\n    \"Y\": formatFullYear,\n    \"Z\": formatZone,\n    \"%\": formatLiteralPercent\n  };\n\n  var utcFormats = {\n    \"a\": formatUTCShortWeekday,\n    \"A\": formatUTCWeekday,\n    \"b\": formatUTCShortMonth,\n    \"B\": formatUTCMonth,\n    \"c\": null,\n    \"d\": formatUTCDayOfMonth,\n    \"e\": formatUTCDayOfMonth,\n    \"H\": formatUTCHour24,\n    \"I\": formatUTCHour12,\n    \"j\": formatUTCDayOfYear,\n    \"L\": formatUTCMilliseconds,\n    \"m\": formatUTCMonthNumber,\n    \"M\": formatUTCMinutes,\n    \"p\": formatUTCPeriod,\n    \"S\": formatUTCSeconds,\n    \"U\": formatUTCWeekNumberSunday,\n    \"w\": formatUTCWeekdayNumber,\n    \"W\": formatUTCWeekNumberMonday,\n    \"x\": null,\n    \"X\": null,\n    \"y\": formatUTCYear,\n    \"Y\": formatUTCFullYear,\n    \"Z\": formatUTCZone,\n    \"%\": formatLiteralPercent\n  };\n\n  var parses = {\n    \"a\": parseShortWeekday,\n    \"A\": parseWeekday,\n    \"b\": parseShortMonth,\n    \"B\": parseMonth,\n    \"c\": parseLocaleDateTime,\n    \"d\": parseDayOfMonth,\n    \"e\": parseDayOfMonth,\n    \"H\": parseHour24,\n    \"I\": parseHour24,\n    \"j\": parseDayOfYear,\n    \"L\": parseMilliseconds,\n    \"m\": parseMonthNumber,\n    \"M\": parseMinutes,\n    \"p\": parsePeriod,\n    \"S\": parseSeconds,\n    \"U\": parseWeekNumberSunday,\n    \"w\": parseWeekdayNumber,\n    \"W\": parseWeekNumberMonday,\n    \"x\": parseLocaleDate,\n    \"X\": parseLocaleTime,\n    \"y\": parseYear,\n    \"Y\": parseFullYear,\n    \"Z\": parseZone,\n    \"%\": parseLiteralPercent\n  };\n\n  // These recursive directive definitions must be deferred.\n  formats.x = newFormat(locale_date, formats);\n  formats.X = newFormat(locale_time, formats);\n  formats.c = newFormat(locale_dateTime, formats);\n  utcFormats.x = newFormat(locale_date, utcFormats);\n  utcFormats.X = newFormat(locale_time, utcFormats);\n  utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n  function newFormat(specifier, formats) {\n    return function(date) {\n      var string = [],\n          i = -1,\n          j = 0,\n          n = specifier.length,\n          c,\n          pad,\n          format;\n\n      if (!(date instanceof Date)) date = new Date(+date);\n\n      while (++i < n) {\n        if (specifier.charCodeAt(i) === 37) {\n          string.push(specifier.slice(j, i));\n          if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n          else pad = c === \"e\" ? \" \" : \"0\";\n          if (format = formats[c]) c = format(date, pad);\n          string.push(c);\n          j = i + 1;\n        }\n      }\n\n      string.push(specifier.slice(j, i));\n      return string.join(\"\");\n    };\n  }\n\n  function newParse(specifier, newDate) {\n    return function(string) {\n      var d = newYear(1900),\n          i = parseSpecifier(d, specifier, string += \"\", 0);\n      if (i != string.length) return null;\n\n      // The am-pm flag is 0 for AM, and 1 for PM.\n      if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n      // Convert day-of-week and week-of-year to day-of-year.\n      if (\"W\" in d || \"U\" in d) {\n        if (!(\"w\" in d)) d.w = \"W\" in d ? 1 : 0;\n        var day$$1 = \"Z\" in d ? utcDate(newYear(d.y)).getUTCDay() : newDate(newYear(d.y)).getDay();\n        d.m = 0;\n        d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day$$1 + 5) % 7 : d.w + d.U * 7 - (day$$1 + 6) % 7;\n      }\n\n      // If a time zone is specified, all fields are interpreted as UTC and then\n      // offset according to the specified time zone.\n      if (\"Z\" in d) {\n        d.H += d.Z / 100 | 0;\n        d.M += d.Z % 100;\n        return utcDate(d);\n      }\n\n      // Otherwise, all fields are in local time.\n      return newDate(d);\n    };\n  }\n\n  function parseSpecifier(d, specifier, string, j) {\n    var i = 0,\n        n = specifier.length,\n        m = string.length,\n        c,\n        parse;\n\n    while (i < n) {\n      if (j >= m) return -1;\n      c = specifier.charCodeAt(i++);\n      if (c === 37) {\n        c = specifier.charAt(i++);\n        parse = parses[c in pads ? specifier.charAt(i++) : c];\n        if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n      } else if (c != string.charCodeAt(j++)) {\n        return -1;\n      }\n    }\n\n    return j;\n  }\n\n  function parsePeriod(d, string, i) {\n    var n = periodRe.exec(string.slice(i));\n    return n ? (d.p = periodLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n  }\n\n  function parseShortWeekday(d, string, i) {\n    var n = shortWeekdayRe.exec(string.slice(i));\n    return n ? (d.w = shortWeekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n  }\n\n  function parseWeekday(d, string, i) {\n    var n = weekdayRe.exec(string.slice(i));\n    return n ? (d.w = weekdayLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n  }\n\n  function parseShortMonth(d, string, i) {\n    var n = shortMonthRe.exec(string.slice(i));\n    return n ? (d.m = shortMonthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n  }\n\n  function parseMonth(d, string, i) {\n    var n = monthRe.exec(string.slice(i));\n    return n ? (d.m = monthLookup[n[0].toLowerCase()], i + n[0].length) : -1;\n  }\n\n  function parseLocaleDateTime(d, string, i) {\n    return parseSpecifier(d, locale_dateTime, string, i);\n  }\n\n  function parseLocaleDate(d, string, i) {\n    return parseSpecifier(d, locale_date, string, i);\n  }\n\n  function parseLocaleTime(d, string, i) {\n    return parseSpecifier(d, locale_time, string, i);\n  }\n\n  function formatShortWeekday(d) {\n    return locale_shortWeekdays[d.getDay()];\n  }\n\n  function formatWeekday(d) {\n    return locale_weekdays[d.getDay()];\n  }\n\n  function formatShortMonth(d) {\n    return locale_shortMonths[d.getMonth()];\n  }\n\n  function formatMonth(d) {\n    return locale_months[d.getMonth()];\n  }\n\n  function formatPeriod(d) {\n    return locale_periods[+(d.getHours() >= 12)];\n  }\n\n  function formatUTCShortWeekday(d) {\n    return locale_shortWeekdays[d.getUTCDay()];\n  }\n\n  function formatUTCWeekday(d) {\n    return locale_weekdays[d.getUTCDay()];\n  }\n\n  function formatUTCShortMonth(d) {\n    return locale_shortMonths[d.getUTCMonth()];\n  }\n\n  function formatUTCMonth(d) {\n    return locale_months[d.getUTCMonth()];\n  }\n\n  function formatUTCPeriod(d) {\n    return locale_periods[+(d.getUTCHours() >= 12)];\n  }\n\n  return {\n    format: function(specifier) {\n      var f = newFormat(specifier += \"\", formats);\n      f.toString = function() { return specifier; };\n      return f;\n    },\n    parse: function(specifier) {\n      var p = newParse(specifier += \"\", localDate);\n      p.toString = function() { return specifier; };\n      return p;\n    },\n    utcFormat: function(specifier) {\n      var f = newFormat(specifier += \"\", utcFormats);\n      f.toString = function() { return specifier; };\n      return f;\n    },\n    utcParse: function(specifier) {\n      var p = newParse(specifier, utcDate);\n      p.toString = function() { return specifier; };\n      return p;\n    }\n  };\n}\n\nvar pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"};\nvar numberRe = /^\\s*\\d+/;\nvar percentRe = /^%/;\nvar requoteRe = /[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g;\n\nfunction pad(value, fill, width) {\n  var sign = value < 0 ? \"-\" : \"\",\n      string = (sign ? -value : value) + \"\",\n      length = string.length;\n  return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n}\n\nfunction requote(s) {\n  return s.replace(requoteRe, \"\\\\$&\");\n}\n\nfunction formatRe(names) {\n  return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n}\n\nfunction formatLookup(names) {\n  var map = {}, i = -1, n = names.length;\n  while (++i < n) map[names[i].toLowerCase()] = i;\n  return map;\n}\n\nfunction parseWeekdayNumber(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 1));\n  return n ? (d.w = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberSunday(d, string, i) {\n  var n = numberRe.exec(string.slice(i));\n  return n ? (d.U = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberMonday(d, string, i) {\n  var n = numberRe.exec(string.slice(i));\n  return n ? (d.W = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseFullYear(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 4));\n  return n ? (d.y = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseYear(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n}\n\nfunction parseZone(d, string, i) {\n  var n = /^(Z)|([+-]\\d\\d)(?:\\:?(\\d\\d))?/.exec(string.slice(i, i + 6));\n  return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n}\n\nfunction parseMonthNumber(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n}\n\nfunction parseDayOfMonth(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseDayOfYear(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 3));\n  return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseHour24(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.H = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMinutes(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.M = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseSeconds(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 2));\n  return n ? (d.S = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMilliseconds(d, string, i) {\n  var n = numberRe.exec(string.slice(i, i + 3));\n  return n ? (d.L = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseLiteralPercent(d, string, i) {\n  var n = percentRe.exec(string.slice(i, i + 1));\n  return n ? i + n[0].length : -1;\n}\n\nfunction formatDayOfMonth(d, p) {\n  return pad(d.getDate(), p, 2);\n}\n\nfunction formatHour24(d, p) {\n  return pad(d.getHours(), p, 2);\n}\n\nfunction formatHour12(d, p) {\n  return pad(d.getHours() % 12 || 12, p, 2);\n}\n\nfunction formatDayOfYear(d, p) {\n  return pad(1 + day.count(year(d), d), p, 3);\n}\n\nfunction formatMilliseconds(d, p) {\n  return pad(d.getMilliseconds(), p, 3);\n}\n\nfunction formatMonthNumber(d, p) {\n  return pad(d.getMonth() + 1, p, 2);\n}\n\nfunction formatMinutes(d, p) {\n  return pad(d.getMinutes(), p, 2);\n}\n\nfunction formatSeconds(d, p) {\n  return pad(d.getSeconds(), p, 2);\n}\n\nfunction formatWeekNumberSunday(d, p) {\n  return pad(sunday.count(year(d), d), p, 2);\n}\n\nfunction formatWeekdayNumber(d) {\n  return d.getDay();\n}\n\nfunction formatWeekNumberMonday(d, p) {\n  return pad(monday.count(year(d), d), p, 2);\n}\n\nfunction formatYear(d, p) {\n  return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatFullYear(d, p) {\n  return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatZone(d) {\n  var z = d.getTimezoneOffset();\n  return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n      + pad(z / 60 | 0, \"0\", 2)\n      + pad(z % 60, \"0\", 2);\n}\n\nfunction formatUTCDayOfMonth(d, p) {\n  return pad(d.getUTCDate(), p, 2);\n}\n\nfunction formatUTCHour24(d, p) {\n  return pad(d.getUTCHours(), p, 2);\n}\n\nfunction formatUTCHour12(d, p) {\n  return pad(d.getUTCHours() % 12 || 12, p, 2);\n}\n\nfunction formatUTCDayOfYear(d, p) {\n  return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n}\n\nfunction formatUTCMilliseconds(d, p) {\n  return pad(d.getUTCMilliseconds(), p, 3);\n}\n\nfunction formatUTCMonthNumber(d, p) {\n  return pad(d.getUTCMonth() + 1, p, 2);\n}\n\nfunction formatUTCMinutes(d, p) {\n  return pad(d.getUTCMinutes(), p, 2);\n}\n\nfunction formatUTCSeconds(d, p) {\n  return pad(d.getUTCSeconds(), p, 2);\n}\n\nfunction formatUTCWeekNumberSunday(d, p) {\n  return pad(utcSunday.count(utcYear(d), d), p, 2);\n}\n\nfunction formatUTCWeekdayNumber(d) {\n  return d.getUTCDay();\n}\n\nfunction formatUTCWeekNumberMonday(d, p) {\n  return pad(utcMonday.count(utcYear(d), d), p, 2);\n}\n\nfunction formatUTCYear(d, p) {\n  return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCFullYear(d, p) {\n  return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCZone() {\n  return \"+0000\";\n}\n\nfunction formatLiteralPercent() {\n  return \"%\";\n}\n\nvar locale$2;\n\n\n\n\n\ndefaultLocale$1({\n  dateTime: \"%x, %X\",\n  date: \"%-m/%-d/%Y\",\n  time: \"%-I:%M:%S %p\",\n  periods: [\"AM\", \"PM\"],\n  days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n  shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n  months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n  shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n});\n\nfunction defaultLocale$1(definition) {\n  locale$2 = formatLocale$1(definition);\n  exports.timeFormat = locale$2.format;\n  exports.timeParse = locale$2.parse;\n  exports.utcFormat = locale$2.utcFormat;\n  exports.utcParse = locale$2.utcParse;\n  return locale$2;\n}\n\nvar isoSpecifier = \"%Y-%m-%dT%H:%M:%S.%LZ\";\n\nfunction formatIsoNative(date) {\n  return date.toISOString();\n}\n\nvar formatIso = Date.prototype.toISOString\n    ? formatIsoNative\n    : exports.utcFormat(isoSpecifier);\n\nfunction parseIsoNative(string) {\n  var date = new Date(string);\n  return isNaN(date) ? null : date;\n}\n\nvar parseIso = +new Date(\"2000-01-01T00:00:00.000Z\")\n    ? parseIsoNative\n    : exports.utcParse(isoSpecifier);\n\nvar durationSecond = 1000;\nvar durationMinute = durationSecond * 60;\nvar durationHour = durationMinute * 60;\nvar durationDay = durationHour * 24;\nvar durationWeek = durationDay * 7;\nvar durationMonth = durationDay * 30;\nvar durationYear = durationDay * 365;\n\nfunction date$1(t) {\n  return new Date(t);\n}\n\nfunction number$2(t) {\n  return t instanceof Date ? +t : +new Date(+t);\n}\n\nfunction calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format) {\n  var scale = continuous(deinterpolateLinear, reinterpolate),\n      invert = scale.invert,\n      domain = scale.domain;\n\n  var formatMillisecond = format(\".%L\"),\n      formatSecond = format(\":%S\"),\n      formatMinute = format(\"%I:%M\"),\n      formatHour = format(\"%I %p\"),\n      formatDay = format(\"%a %d\"),\n      formatWeek = format(\"%b %d\"),\n      formatMonth = format(\"%B\"),\n      formatYear = format(\"%Y\");\n\n  var tickIntervals = [\n    [second$$1,  1,      durationSecond],\n    [second$$1,  5,  5 * durationSecond],\n    [second$$1, 15, 15 * durationSecond],\n    [second$$1, 30, 30 * durationSecond],\n    [minute$$1,  1,      durationMinute],\n    [minute$$1,  5,  5 * durationMinute],\n    [minute$$1, 15, 15 * durationMinute],\n    [minute$$1, 30, 30 * durationMinute],\n    [  hour$$1,  1,      durationHour  ],\n    [  hour$$1,  3,  3 * durationHour  ],\n    [  hour$$1,  6,  6 * durationHour  ],\n    [  hour$$1, 12, 12 * durationHour  ],\n    [   day$$1,  1,      durationDay   ],\n    [   day$$1,  2,  2 * durationDay   ],\n    [  week,  1,      durationWeek  ],\n    [ month$$1,  1,      durationMonth ],\n    [ month$$1,  3,  3 * durationMonth ],\n    [  year$$1,  1,      durationYear  ]\n  ];\n\n  function tickFormat(date) {\n    return (second$$1(date) < date ? formatMillisecond\n        : minute$$1(date) < date ? formatSecond\n        : hour$$1(date) < date ? formatMinute\n        : day$$1(date) < date ? formatHour\n        : month$$1(date) < date ? (week(date) < date ? formatDay : formatWeek)\n        : year$$1(date) < date ? formatMonth\n        : formatYear)(date);\n  }\n\n  function tickInterval(interval, start, stop, step) {\n    if (interval == null) interval = 10;\n\n    // If a desired tick count is specified, pick a reasonable tick interval\n    // based on the extent of the domain and a rough estimate of tick size.\n    // Otherwise, assume interval is already a time interval and use it.\n    if (typeof interval === \"number\") {\n      var target = Math.abs(stop - start) / interval,\n          i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);\n      if (i === tickIntervals.length) {\n        step = tickStep(start / durationYear, stop / durationYear, interval);\n        interval = year$$1;\n      } else if (i) {\n        i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n        step = i[1];\n        interval = i[0];\n      } else {\n        step = tickStep(start, stop, interval);\n        interval = millisecond$$1;\n      }\n    }\n\n    return step == null ? interval : interval.every(step);\n  }\n\n  scale.invert = function(y) {\n    return new Date(invert(y));\n  };\n\n  scale.domain = function(_) {\n    return arguments.length ? domain(map$3.call(_, number$2)) : domain().map(date$1);\n  };\n\n  scale.ticks = function(interval, step) {\n    var d = domain(),\n        t0 = d[0],\n        t1 = d[d.length - 1],\n        r = t1 < t0,\n        t;\n    if (r) t = t0, t0 = t1, t1 = t;\n    t = tickInterval(interval, t0, t1, step);\n    t = t ? t.range(t0, t1 + 1) : []; // inclusive stop\n    return r ? t.reverse() : t;\n  };\n\n  scale.tickFormat = function(count, specifier) {\n    return specifier == null ? tickFormat : format(specifier);\n  };\n\n  scale.nice = function(interval, step) {\n    var d = domain();\n    return (interval = tickInterval(interval, d[0], d[d.length - 1], step))\n        ? domain(nice(d, interval))\n        : scale;\n  };\n\n  scale.copy = function() {\n    return copy(scale, calendar(year$$1, month$$1, week, day$$1, hour$$1, minute$$1, second$$1, millisecond$$1, format));\n  };\n\n  return scale;\n}\n\nvar time = function() {\n  return calendar(year, month, sunday, day, hour, minute, second, millisecond, exports.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]);\n};\n\nvar utcTime = function() {\n  return calendar(utcYear, utcMonth, utcSunday, utcDay, utcHour, utcMinute, second, millisecond, exports.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]);\n};\n\nvar colors = function(s) {\n  return s.match(/.{6}/g).map(function(x) {\n    return \"#\" + x;\n  });\n};\n\nvar category10 = colors(\"1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf\");\n\nvar category20b = colors(\"393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6\");\n\nvar category20c = colors(\"3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9\");\n\nvar category20 = colors(\"1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5\");\n\nvar cubehelix$3 = cubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));\n\nvar warm = cubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\nvar cool = cubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\nvar rainbow = cubehelix();\n\nvar rainbow$1 = function(t) {\n  if (t < 0 || t > 1) t -= Math.floor(t);\n  var ts = Math.abs(t - 0.5);\n  rainbow.h = 360 * t - 100;\n  rainbow.s = 1.5 - 1.5 * ts;\n  rainbow.l = 0.8 - 0.9 * ts;\n  return rainbow + \"\";\n};\n\nfunction ramp(range) {\n  var n = range.length;\n  return function(t) {\n    return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];\n  };\n}\n\nvar viridis = ramp(colors(\"44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725\"));\n\nvar magma = ramp(colors(\"00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf\"));\n\nvar inferno = ramp(colors(\"00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4\"));\n\nvar plasma = ramp(colors(\"0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921\"));\n\nfunction sequential(interpolator) {\n  var x0 = 0,\n      x1 = 1,\n      clamp = false;\n\n  function scale(x) {\n    var t = (x - x0) / (x1 - x0);\n    return interpolator(clamp ? Math.max(0, Math.min(1, t)) : t);\n  }\n\n  scale.domain = function(_) {\n    return arguments.length ? (x0 = +_[0], x1 = +_[1], scale) : [x0, x1];\n  };\n\n  scale.clamp = function(_) {\n    return arguments.length ? (clamp = !!_, scale) : clamp;\n  };\n\n  scale.interpolator = function(_) {\n    return arguments.length ? (interpolator = _, scale) : interpolator;\n  };\n\n  scale.copy = function() {\n    return sequential(interpolator).domain([x0, x1]).clamp(clamp);\n  };\n\n  return linearish(scale);\n}\n\nvar constant$10 = function(x) {\n  return function constant() {\n    return x;\n  };\n};\n\nvar abs$1 = Math.abs;\nvar atan2$1 = Math.atan2;\nvar cos$2 = Math.cos;\nvar max$2 = Math.max;\nvar min$1 = Math.min;\nvar sin$2 = Math.sin;\nvar sqrt$2 = Math.sqrt;\n\nvar epsilon$3 = 1e-12;\nvar pi$4 = Math.PI;\nvar halfPi$3 = pi$4 / 2;\nvar tau$4 = 2 * pi$4;\n\nfunction acos$1(x) {\n  return x > 1 ? 0 : x < -1 ? pi$4 : Math.acos(x);\n}\n\nfunction asin$1(x) {\n  return x >= 1 ? halfPi$3 : x <= -1 ? -halfPi$3 : Math.asin(x);\n}\n\nfunction arcInnerRadius(d) {\n  return d.innerRadius;\n}\n\nfunction arcOuterRadius(d) {\n  return d.outerRadius;\n}\n\nfunction arcStartAngle(d) {\n  return d.startAngle;\n}\n\nfunction arcEndAngle(d) {\n  return d.endAngle;\n}\n\nfunction arcPadAngle(d) {\n  return d && d.padAngle; // Note: optional!\n}\n\nfunction intersect(x0, y0, x1, y1, x2, y2, x3, y3) {\n  var x10 = x1 - x0, y10 = y1 - y0,\n      x32 = x3 - x2, y32 = y3 - y2,\n      t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / (y32 * x10 - x32 * y10);\n  return [x0 + t * x10, y0 + t * y10];\n}\n\n// Compute perpendicular offset line of length rc.\n// http://mathworld.wolfram.com/Circle-LineIntersection.html\nfunction cornerTangents(x0, y0, x1, y1, r1, rc, cw) {\n  var x01 = x0 - x1,\n      y01 = y0 - y1,\n      lo = (cw ? rc : -rc) / sqrt$2(x01 * x01 + y01 * y01),\n      ox = lo * y01,\n      oy = -lo * x01,\n      x11 = x0 + ox,\n      y11 = y0 + oy,\n      x10 = x1 + ox,\n      y10 = y1 + oy,\n      x00 = (x11 + x10) / 2,\n      y00 = (y11 + y10) / 2,\n      dx = x10 - x11,\n      dy = y10 - y11,\n      d2 = dx * dx + dy * dy,\n      r = r1 - rc,\n      D = x11 * y10 - x10 * y11,\n      d = (dy < 0 ? -1 : 1) * sqrt$2(max$2(0, r * r * d2 - D * D)),\n      cx0 = (D * dy - dx * d) / d2,\n      cy0 = (-D * dx - dy * d) / d2,\n      cx1 = (D * dy + dx * d) / d2,\n      cy1 = (-D * dx + dy * d) / d2,\n      dx0 = cx0 - x00,\n      dy0 = cy0 - y00,\n      dx1 = cx1 - x00,\n      dy1 = cy1 - y00;\n\n  // Pick the closer of the two intersection points.\n  // TODO Is there a faster way to determine which intersection to use?\n  if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n\n  return {\n    cx: cx0,\n    cy: cy0,\n    x01: -ox,\n    y01: -oy,\n    x11: cx0 * (r1 / r - 1),\n    y11: cy0 * (r1 / r - 1)\n  };\n}\n\nvar arc = function() {\n  var innerRadius = arcInnerRadius,\n      outerRadius = arcOuterRadius,\n      cornerRadius = constant$10(0),\n      padRadius = null,\n      startAngle = arcStartAngle,\n      endAngle = arcEndAngle,\n      padAngle = arcPadAngle,\n      context = null;\n\n  function arc() {\n    var buffer,\n        r,\n        r0 = +innerRadius.apply(this, arguments),\n        r1 = +outerRadius.apply(this, arguments),\n        a0 = startAngle.apply(this, arguments) - halfPi$3,\n        a1 = endAngle.apply(this, arguments) - halfPi$3,\n        da = abs$1(a1 - a0),\n        cw = a1 > a0;\n\n    if (!context) context = buffer = path();\n\n    // Ensure that the outer radius is always larger than the inner radius.\n    if (r1 < r0) r = r1, r1 = r0, r0 = r;\n\n    // Is it a point?\n    if (!(r1 > epsilon$3)) context.moveTo(0, 0);\n\n    // Or is it a circle or annulus?\n    else if (da > tau$4 - epsilon$3) {\n      context.moveTo(r1 * cos$2(a0), r1 * sin$2(a0));\n      context.arc(0, 0, r1, a0, a1, !cw);\n      if (r0 > epsilon$3) {\n        context.moveTo(r0 * cos$2(a1), r0 * sin$2(a1));\n        context.arc(0, 0, r0, a1, a0, cw);\n      }\n    }\n\n    // Or is it a circular or annular sector?\n    else {\n      var a01 = a0,\n          a11 = a1,\n          a00 = a0,\n          a10 = a1,\n          da0 = da,\n          da1 = da,\n          ap = padAngle.apply(this, arguments) / 2,\n          rp = (ap > epsilon$3) && (padRadius ? +padRadius.apply(this, arguments) : sqrt$2(r0 * r0 + r1 * r1)),\n          rc = min$1(abs$1(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),\n          rc0 = rc,\n          rc1 = rc,\n          t0,\n          t1;\n\n      // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.\n      if (rp > epsilon$3) {\n        var p0 = asin$1(rp / r0 * sin$2(ap)),\n            p1 = asin$1(rp / r1 * sin$2(ap));\n        if ((da0 -= p0 * 2) > epsilon$3) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;\n        else da0 = 0, a00 = a10 = (a0 + a1) / 2;\n        if ((da1 -= p1 * 2) > epsilon$3) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;\n        else da1 = 0, a01 = a11 = (a0 + a1) / 2;\n      }\n\n      var x01 = r1 * cos$2(a01),\n          y01 = r1 * sin$2(a01),\n          x10 = r0 * cos$2(a10),\n          y10 = r0 * sin$2(a10);\n\n      // Apply rounded corners?\n      if (rc > epsilon$3) {\n        var x11 = r1 * cos$2(a11),\n            y11 = r1 * sin$2(a11),\n            x00 = r0 * cos$2(a00),\n            y00 = r0 * sin$2(a00);\n\n        // Restrict the corner radius according to the sector angle.\n        if (da < pi$4) {\n          var oc = da0 > epsilon$3 ? intersect(x01, y01, x00, y00, x11, y11, x10, y10) : [x10, y10],\n              ax = x01 - oc[0],\n              ay = y01 - oc[1],\n              bx = x11 - oc[0],\n              by = y11 - oc[1],\n              kc = 1 / sin$2(acos$1((ax * bx + ay * by) / (sqrt$2(ax * ax + ay * ay) * sqrt$2(bx * bx + by * by))) / 2),\n              lc = sqrt$2(oc[0] * oc[0] + oc[1] * oc[1]);\n          rc0 = min$1(rc, (r0 - lc) / (kc - 1));\n          rc1 = min$1(rc, (r1 - lc) / (kc + 1));\n        }\n      }\n\n      // Is the sector collapsed to a line?\n      if (!(da1 > epsilon$3)) context.moveTo(x01, y01);\n\n      // Does the sector’s outer ring have rounded corners?\n      else if (rc1 > epsilon$3) {\n        t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);\n        t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);\n\n        context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n        // Have the corners merged?\n        if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, atan2$1(t0.y01, t0.x01), atan2$1(t1.y01, t1.x01), !cw);\n\n        // Otherwise, draw the two corners and the ring.\n        else {\n          context.arc(t0.cx, t0.cy, rc1, atan2$1(t0.y01, t0.x01), atan2$1(t0.y11, t0.x11), !cw);\n          context.arc(0, 0, r1, atan2$1(t0.cy + t0.y11, t0.cx + t0.x11), atan2$1(t1.cy + t1.y11, t1.cx + t1.x11), !cw);\n          context.arc(t1.cx, t1.cy, rc1, atan2$1(t1.y11, t1.x11), atan2$1(t1.y01, t1.x01), !cw);\n        }\n      }\n\n      // Or is the outer ring just a circular arc?\n      else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);\n\n      // Is there no inner ring, and it’s a circular sector?\n      // Or perhaps it’s an annular sector collapsed due to padding?\n      if (!(r0 > epsilon$3) || !(da0 > epsilon$3)) context.lineTo(x10, y10);\n\n      // Does the sector’s inner ring (or point) have rounded corners?\n      else if (rc0 > epsilon$3) {\n        t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);\n        t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);\n\n        context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n        // Have the corners merged?\n        if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, atan2$1(t0.y01, t0.x01), atan2$1(t1.y01, t1.x01), !cw);\n\n        // Otherwise, draw the two corners and the ring.\n        else {\n          context.arc(t0.cx, t0.cy, rc0, atan2$1(t0.y01, t0.x01), atan2$1(t0.y11, t0.x11), !cw);\n          context.arc(0, 0, r0, atan2$1(t0.cy + t0.y11, t0.cx + t0.x11), atan2$1(t1.cy + t1.y11, t1.cx + t1.x11), cw);\n          context.arc(t1.cx, t1.cy, rc0, atan2$1(t1.y11, t1.x11), atan2$1(t1.y01, t1.x01), !cw);\n        }\n      }\n\n      // Or is the inner ring just a circular arc?\n      else context.arc(0, 0, r0, a10, a00, cw);\n    }\n\n    context.closePath();\n\n    if (buffer) return context = null, buffer + \"\" || null;\n  }\n\n  arc.centroid = function() {\n    var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,\n        a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi$4 / 2;\n    return [cos$2(a) * r, sin$2(a) * r];\n  };\n\n  arc.innerRadius = function(_) {\n    return arguments.length ? (innerRadius = typeof _ === \"function\" ? _ : constant$10(+_), arc) : innerRadius;\n  };\n\n  arc.outerRadius = function(_) {\n    return arguments.length ? (outerRadius = typeof _ === \"function\" ? _ : constant$10(+_), arc) : outerRadius;\n  };\n\n  arc.cornerRadius = function(_) {\n    return arguments.length ? (cornerRadius = typeof _ === \"function\" ? _ : constant$10(+_), arc) : cornerRadius;\n  };\n\n  arc.padRadius = function(_) {\n    return arguments.length ? (padRadius = _ == null ? null : typeof _ === \"function\" ? _ : constant$10(+_), arc) : padRadius;\n  };\n\n  arc.startAngle = function(_) {\n    return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$10(+_), arc) : startAngle;\n  };\n\n  arc.endAngle = function(_) {\n    return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$10(+_), arc) : endAngle;\n  };\n\n  arc.padAngle = function(_) {\n    return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$10(+_), arc) : padAngle;\n  };\n\n  arc.context = function(_) {\n    return arguments.length ? ((context = _ == null ? null : _), arc) : context;\n  };\n\n  return arc;\n};\n\nfunction Linear(context) {\n  this._context = context;\n}\n\nLinear.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; // proceed\n      default: this._context.lineTo(x, y); break;\n    }\n  }\n};\n\nvar curveLinear = function(context) {\n  return new Linear(context);\n};\n\nfunction x$3(p) {\n  return p[0];\n}\n\nfunction y$3(p) {\n  return p[1];\n}\n\nvar line = function() {\n  var x$$1 = x$3,\n      y$$1 = y$3,\n      defined = constant$10(true),\n      context = null,\n      curve = curveLinear,\n      output = null;\n\n  function line(data) {\n    var i,\n        n = data.length,\n        d,\n        defined0 = false,\n        buffer;\n\n    if (context == null) output = curve(buffer = path());\n\n    for (i = 0; i <= n; ++i) {\n      if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n        if (defined0 = !defined0) output.lineStart();\n        else output.lineEnd();\n      }\n      if (defined0) output.point(+x$$1(d, i, data), +y$$1(d, i, data));\n    }\n\n    if (buffer) return output = null, buffer + \"\" || null;\n  }\n\n  line.x = function(_) {\n    return arguments.length ? (x$$1 = typeof _ === \"function\" ? _ : constant$10(+_), line) : x$$1;\n  };\n\n  line.y = function(_) {\n    return arguments.length ? (y$$1 = typeof _ === \"function\" ? _ : constant$10(+_), line) : y$$1;\n  };\n\n  line.defined = function(_) {\n    return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$10(!!_), line) : defined;\n  };\n\n  line.curve = function(_) {\n    return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;\n  };\n\n  line.context = function(_) {\n    return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;\n  };\n\n  return line;\n};\n\nvar area$2 = function() {\n  var x0 = x$3,\n      x1 = null,\n      y0 = constant$10(0),\n      y1 = y$3,\n      defined = constant$10(true),\n      context = null,\n      curve = curveLinear,\n      output = null;\n\n  function area(data) {\n    var i,\n        j,\n        k,\n        n = data.length,\n        d,\n        defined0 = false,\n        buffer,\n        x0z = new Array(n),\n        y0z = new Array(n);\n\n    if (context == null) output = curve(buffer = path());\n\n    for (i = 0; i <= n; ++i) {\n      if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n        if (defined0 = !defined0) {\n          j = i;\n          output.areaStart();\n          output.lineStart();\n        } else {\n          output.lineEnd();\n          output.lineStart();\n          for (k = i - 1; k >= j; --k) {\n            output.point(x0z[k], y0z[k]);\n          }\n          output.lineEnd();\n          output.areaEnd();\n        }\n      }\n      if (defined0) {\n        x0z[i] = +x0(d, i, data), y0z[i] = +y0(d, i, data);\n        output.point(x1 ? +x1(d, i, data) : x0z[i], y1 ? +y1(d, i, data) : y0z[i]);\n      }\n    }\n\n    if (buffer) return output = null, buffer + \"\" || null;\n  }\n\n  function arealine() {\n    return line().defined(defined).curve(curve).context(context);\n  }\n\n  area.x = function(_) {\n    return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$10(+_), x1 = null, area) : x0;\n  };\n\n  area.x0 = function(_) {\n    return arguments.length ? (x0 = typeof _ === \"function\" ? _ : constant$10(+_), area) : x0;\n  };\n\n  area.x1 = function(_) {\n    return arguments.length ? (x1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$10(+_), area) : x1;\n  };\n\n  area.y = function(_) {\n    return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$10(+_), y1 = null, area) : y0;\n  };\n\n  area.y0 = function(_) {\n    return arguments.length ? (y0 = typeof _ === \"function\" ? _ : constant$10(+_), area) : y0;\n  };\n\n  area.y1 = function(_) {\n    return arguments.length ? (y1 = _ == null ? null : typeof _ === \"function\" ? _ : constant$10(+_), area) : y1;\n  };\n\n  area.lineX0 =\n  area.lineY0 = function() {\n    return arealine().x(x0).y(y0);\n  };\n\n  area.lineY1 = function() {\n    return arealine().x(x0).y(y1);\n  };\n\n  area.lineX1 = function() {\n    return arealine().x(x1).y(y0);\n  };\n\n  area.defined = function(_) {\n    return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant$10(!!_), area) : defined;\n  };\n\n  area.curve = function(_) {\n    return arguments.length ? (curve = _, context != null && (output = curve(context)), area) : curve;\n  };\n\n  area.context = function(_) {\n    return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), area) : context;\n  };\n\n  return area;\n};\n\nvar descending$1 = function(a, b) {\n  return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n};\n\nvar identity$7 = function(d) {\n  return d;\n};\n\nvar pie = function() {\n  var value = identity$7,\n      sortValues = descending$1,\n      sort = null,\n      startAngle = constant$10(0),\n      endAngle = constant$10(tau$4),\n      padAngle = constant$10(0);\n\n  function pie(data) {\n    var i,\n        n = data.length,\n        j,\n        k,\n        sum = 0,\n        index = new Array(n),\n        arcs = new Array(n),\n        a0 = +startAngle.apply(this, arguments),\n        da = Math.min(tau$4, Math.max(-tau$4, endAngle.apply(this, arguments) - a0)),\n        a1,\n        p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),\n        pa = p * (da < 0 ? -1 : 1),\n        v;\n\n    for (i = 0; i < n; ++i) {\n      if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {\n        sum += v;\n      }\n    }\n\n    // Optionally sort the arcs by previously-computed values or by data.\n    if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });\n    else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });\n\n    // Compute the arcs! They are stored in the original data's order.\n    for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {\n      j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {\n        data: data[j],\n        index: i,\n        value: v,\n        startAngle: a0,\n        endAngle: a1,\n        padAngle: p\n      };\n    }\n\n    return arcs;\n  }\n\n  pie.value = function(_) {\n    return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$10(+_), pie) : value;\n  };\n\n  pie.sortValues = function(_) {\n    return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;\n  };\n\n  pie.sort = function(_) {\n    return arguments.length ? (sort = _, sortValues = null, pie) : sort;\n  };\n\n  pie.startAngle = function(_) {\n    return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant$10(+_), pie) : startAngle;\n  };\n\n  pie.endAngle = function(_) {\n    return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant$10(+_), pie) : endAngle;\n  };\n\n  pie.padAngle = function(_) {\n    return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant$10(+_), pie) : padAngle;\n  };\n\n  return pie;\n};\n\nvar curveRadialLinear = curveRadial(curveLinear);\n\nfunction Radial(curve) {\n  this._curve = curve;\n}\n\nRadial.prototype = {\n  areaStart: function() {\n    this._curve.areaStart();\n  },\n  areaEnd: function() {\n    this._curve.areaEnd();\n  },\n  lineStart: function() {\n    this._curve.lineStart();\n  },\n  lineEnd: function() {\n    this._curve.lineEnd();\n  },\n  point: function(a, r) {\n    this._curve.point(r * Math.sin(a), r * -Math.cos(a));\n  }\n};\n\nfunction curveRadial(curve) {\n\n  function radial(context) {\n    return new Radial(curve(context));\n  }\n\n  radial._curve = curve;\n\n  return radial;\n}\n\nfunction radialLine(l) {\n  var c = l.curve;\n\n  l.angle = l.x, delete l.x;\n  l.radius = l.y, delete l.y;\n\n  l.curve = function(_) {\n    return arguments.length ? c(curveRadial(_)) : c()._curve;\n  };\n\n  return l;\n}\n\nvar radialLine$1 = function() {\n  return radialLine(line().curve(curveRadialLinear));\n};\n\nvar radialArea = function() {\n  var a = area$2().curve(curveRadialLinear),\n      c = a.curve,\n      x0 = a.lineX0,\n      x1 = a.lineX1,\n      y0 = a.lineY0,\n      y1 = a.lineY1;\n\n  a.angle = a.x, delete a.x;\n  a.startAngle = a.x0, delete a.x0;\n  a.endAngle = a.x1, delete a.x1;\n  a.radius = a.y, delete a.y;\n  a.innerRadius = a.y0, delete a.y0;\n  a.outerRadius = a.y1, delete a.y1;\n  a.lineStartAngle = function() { return radialLine(x0()); }, delete a.lineX0;\n  a.lineEndAngle = function() { return radialLine(x1()); }, delete a.lineX1;\n  a.lineInnerRadius = function() { return radialLine(y0()); }, delete a.lineY0;\n  a.lineOuterRadius = function() { return radialLine(y1()); }, delete a.lineY1;\n\n  a.curve = function(_) {\n    return arguments.length ? c(curveRadial(_)) : c()._curve;\n  };\n\n  return a;\n};\n\nvar slice$5 = Array.prototype.slice;\n\nvar radialPoint = function(x, y) {\n  return [(y = +y) * Math.cos(x -= Math.PI / 2), y * Math.sin(x)];\n};\n\nfunction linkSource(d) {\n  return d.source;\n}\n\nfunction linkTarget(d) {\n  return d.target;\n}\n\nfunction link$2(curve) {\n  var source = linkSource,\n      target = linkTarget,\n      x$$1 = x$3,\n      y$$1 = y$3,\n      context = null;\n\n  function link() {\n    var buffer, argv = slice$5.call(arguments), s = source.apply(this, argv), t = target.apply(this, argv);\n    if (!context) context = buffer = path();\n    curve(context, +x$$1.apply(this, (argv[0] = s, argv)), +y$$1.apply(this, argv), +x$$1.apply(this, (argv[0] = t, argv)), +y$$1.apply(this, argv));\n    if (buffer) return context = null, buffer + \"\" || null;\n  }\n\n  link.source = function(_) {\n    return arguments.length ? (source = _, link) : source;\n  };\n\n  link.target = function(_) {\n    return arguments.length ? (target = _, link) : target;\n  };\n\n  link.x = function(_) {\n    return arguments.length ? (x$$1 = typeof _ === \"function\" ? _ : constant$10(+_), link) : x$$1;\n  };\n\n  link.y = function(_) {\n    return arguments.length ? (y$$1 = typeof _ === \"function\" ? _ : constant$10(+_), link) : y$$1;\n  };\n\n  link.context = function(_) {\n    return arguments.length ? ((context = _ == null ? null : _), link) : context;\n  };\n\n  return link;\n}\n\nfunction curveHorizontal(context, x0, y0, x1, y1) {\n  context.moveTo(x0, y0);\n  context.bezierCurveTo(x0 = (x0 + x1) / 2, y0, x0, y1, x1, y1);\n}\n\nfunction curveVertical(context, x0, y0, x1, y1) {\n  context.moveTo(x0, y0);\n  context.bezierCurveTo(x0, y0 = (y0 + y1) / 2, x1, y0, x1, y1);\n}\n\nfunction curveRadial$1(context, x0, y0, x1, y1) {\n  var p0 = radialPoint(x0, y0),\n      p1 = radialPoint(x0, y0 = (y0 + y1) / 2),\n      p2 = radialPoint(x1, y0),\n      p3 = radialPoint(x1, y1);\n  context.moveTo(p0[0], p0[1]);\n  context.bezierCurveTo(p1[0], p1[1], p2[0], p2[1], p3[0], p3[1]);\n}\n\nfunction linkHorizontal() {\n  return link$2(curveHorizontal);\n}\n\nfunction linkVertical() {\n  return link$2(curveVertical);\n}\n\nfunction linkRadial() {\n  var l = link$2(curveRadial$1);\n  l.angle = l.x, delete l.x;\n  l.radius = l.y, delete l.y;\n  return l;\n}\n\nvar circle$2 = {\n  draw: function(context, size) {\n    var r = Math.sqrt(size / pi$4);\n    context.moveTo(r, 0);\n    context.arc(0, 0, r, 0, tau$4);\n  }\n};\n\nvar cross$2 = {\n  draw: function(context, size) {\n    var r = Math.sqrt(size / 5) / 2;\n    context.moveTo(-3 * r, -r);\n    context.lineTo(-r, -r);\n    context.lineTo(-r, -3 * r);\n    context.lineTo(r, -3 * r);\n    context.lineTo(r, -r);\n    context.lineTo(3 * r, -r);\n    context.lineTo(3 * r, r);\n    context.lineTo(r, r);\n    context.lineTo(r, 3 * r);\n    context.lineTo(-r, 3 * r);\n    context.lineTo(-r, r);\n    context.lineTo(-3 * r, r);\n    context.closePath();\n  }\n};\n\nvar tan30 = Math.sqrt(1 / 3);\nvar tan30_2 = tan30 * 2;\n\nvar diamond = {\n  draw: function(context, size) {\n    var y = Math.sqrt(size / tan30_2),\n        x = y * tan30;\n    context.moveTo(0, -y);\n    context.lineTo(x, 0);\n    context.lineTo(0, y);\n    context.lineTo(-x, 0);\n    context.closePath();\n  }\n};\n\nvar ka = 0.89081309152928522810;\nvar kr = Math.sin(pi$4 / 10) / Math.sin(7 * pi$4 / 10);\nvar kx = Math.sin(tau$4 / 10) * kr;\nvar ky = -Math.cos(tau$4 / 10) * kr;\n\nvar star = {\n  draw: function(context, size) {\n    var r = Math.sqrt(size * ka),\n        x = kx * r,\n        y = ky * r;\n    context.moveTo(0, -r);\n    context.lineTo(x, y);\n    for (var i = 1; i < 5; ++i) {\n      var a = tau$4 * i / 5,\n          c = Math.cos(a),\n          s = Math.sin(a);\n      context.lineTo(s * r, -c * r);\n      context.lineTo(c * x - s * y, s * x + c * y);\n    }\n    context.closePath();\n  }\n};\n\nvar square = {\n  draw: function(context, size) {\n    var w = Math.sqrt(size),\n        x = -w / 2;\n    context.rect(x, x, w, w);\n  }\n};\n\nvar sqrt3 = Math.sqrt(3);\n\nvar triangle = {\n  draw: function(context, size) {\n    var y = -Math.sqrt(size / (sqrt3 * 3));\n    context.moveTo(0, y * 2);\n    context.lineTo(-sqrt3 * y, -y);\n    context.lineTo(sqrt3 * y, -y);\n    context.closePath();\n  }\n};\n\nvar c = -0.5;\nvar s = Math.sqrt(3) / 2;\nvar k = 1 / Math.sqrt(12);\nvar a = (k / 2 + 1) * 3;\n\nvar wye = {\n  draw: function(context, size) {\n    var r = Math.sqrt(size / a),\n        x0 = r / 2,\n        y0 = r * k,\n        x1 = x0,\n        y1 = r * k + r,\n        x2 = -x1,\n        y2 = y1;\n    context.moveTo(x0, y0);\n    context.lineTo(x1, y1);\n    context.lineTo(x2, y2);\n    context.lineTo(c * x0 - s * y0, s * x0 + c * y0);\n    context.lineTo(c * x1 - s * y1, s * x1 + c * y1);\n    context.lineTo(c * x2 - s * y2, s * x2 + c * y2);\n    context.lineTo(c * x0 + s * y0, c * y0 - s * x0);\n    context.lineTo(c * x1 + s * y1, c * y1 - s * x1);\n    context.lineTo(c * x2 + s * y2, c * y2 - s * x2);\n    context.closePath();\n  }\n};\n\nvar symbols = [\n  circle$2,\n  cross$2,\n  diamond,\n  square,\n  star,\n  triangle,\n  wye\n];\n\nvar symbol = function() {\n  var type = constant$10(circle$2),\n      size = constant$10(64),\n      context = null;\n\n  function symbol() {\n    var buffer;\n    if (!context) context = buffer = path();\n    type.apply(this, arguments).draw(context, +size.apply(this, arguments));\n    if (buffer) return context = null, buffer + \"\" || null;\n  }\n\n  symbol.type = function(_) {\n    return arguments.length ? (type = typeof _ === \"function\" ? _ : constant$10(_), symbol) : type;\n  };\n\n  symbol.size = function(_) {\n    return arguments.length ? (size = typeof _ === \"function\" ? _ : constant$10(+_), symbol) : size;\n  };\n\n  symbol.context = function(_) {\n    return arguments.length ? (context = _ == null ? null : _, symbol) : context;\n  };\n\n  return symbol;\n};\n\nvar noop$2 = function() {};\n\nfunction point$2(that, x, y) {\n  that._context.bezierCurveTo(\n    (2 * that._x0 + that._x1) / 3,\n    (2 * that._y0 + that._y1) / 3,\n    (that._x0 + 2 * that._x1) / 3,\n    (that._y0 + 2 * that._y1) / 3,\n    (that._x0 + 4 * that._x1 + x) / 6,\n    (that._y0 + 4 * that._y1 + y) / 6\n  );\n}\n\nfunction Basis(context) {\n  this._context = context;\n}\n\nBasis.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 =\n    this._y0 = this._y1 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 3: point$2(this, this._x1, this._y1); // proceed\n      case 2: this._context.lineTo(this._x1, this._y1); break;\n    }\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // proceed\n      default: point$2(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = x;\n    this._y0 = this._y1, this._y1 = y;\n  }\n};\n\nvar basis$2 = function(context) {\n  return new Basis(context);\n};\n\nfunction BasisClosed(context) {\n  this._context = context;\n}\n\nBasisClosed.prototype = {\n  areaStart: noop$2,\n  areaEnd: noop$2,\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =\n    this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 1: {\n        this._context.moveTo(this._x2, this._y2);\n        this._context.closePath();\n        break;\n      }\n      case 2: {\n        this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);\n        this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);\n        this._context.closePath();\n        break;\n      }\n      case 3: {\n        this.point(this._x2, this._y2);\n        this.point(this._x3, this._y3);\n        this.point(this._x4, this._y4);\n        break;\n      }\n    }\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._x2 = x, this._y2 = y; break;\n      case 1: this._point = 2; this._x3 = x, this._y3 = y; break;\n      case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;\n      default: point$2(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = x;\n    this._y0 = this._y1, this._y1 = y;\n  }\n};\n\nvar basisClosed$1 = function(context) {\n  return new BasisClosed(context);\n};\n\nfunction BasisOpen(context) {\n  this._context = context;\n}\n\nBasisOpen.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 =\n    this._y0 = this._y1 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;\n      case 3: this._point = 4; // proceed\n      default: point$2(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = x;\n    this._y0 = this._y1, this._y1 = y;\n  }\n};\n\nvar basisOpen = function(context) {\n  return new BasisOpen(context);\n};\n\nfunction Bundle(context, beta) {\n  this._basis = new Basis(context);\n  this._beta = beta;\n}\n\nBundle.prototype = {\n  lineStart: function() {\n    this._x = [];\n    this._y = [];\n    this._basis.lineStart();\n  },\n  lineEnd: function() {\n    var x = this._x,\n        y = this._y,\n        j = x.length - 1;\n\n    if (j > 0) {\n      var x0 = x[0],\n          y0 = y[0],\n          dx = x[j] - x0,\n          dy = y[j] - y0,\n          i = -1,\n          t;\n\n      while (++i <= j) {\n        t = i / j;\n        this._basis.point(\n          this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),\n          this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)\n        );\n      }\n    }\n\n    this._x = this._y = null;\n    this._basis.lineEnd();\n  },\n  point: function(x, y) {\n    this._x.push(+x);\n    this._y.push(+y);\n  }\n};\n\nvar bundle = ((function custom(beta) {\n\n  function bundle(context) {\n    return beta === 1 ? new Basis(context) : new Bundle(context, beta);\n  }\n\n  bundle.beta = function(beta) {\n    return custom(+beta);\n  };\n\n  return bundle;\n}))(0.85);\n\nfunction point$3(that, x, y) {\n  that._context.bezierCurveTo(\n    that._x1 + that._k * (that._x2 - that._x0),\n    that._y1 + that._k * (that._y2 - that._y0),\n    that._x2 + that._k * (that._x1 - x),\n    that._y2 + that._k * (that._y1 - y),\n    that._x2,\n    that._y2\n  );\n}\n\nfunction Cardinal(context, tension) {\n  this._context = context;\n  this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 =\n    this._y0 = this._y1 = this._y2 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 2: this._context.lineTo(this._x2, this._y2); break;\n      case 3: point$3(this, this._x1, this._y1); break;\n    }\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n      case 2: this._point = 3; // proceed\n      default: point$3(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar cardinal = ((function custom(tension) {\n\n  function cardinal(context) {\n    return new Cardinal(context, tension);\n  }\n\n  cardinal.tension = function(tension) {\n    return custom(+tension);\n  };\n\n  return cardinal;\n}))(0);\n\nfunction CardinalClosed(context, tension) {\n  this._context = context;\n  this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n  areaStart: noop$2,\n  areaEnd: noop$2,\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n    this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 1: {\n        this._context.moveTo(this._x3, this._y3);\n        this._context.closePath();\n        break;\n      }\n      case 2: {\n        this._context.lineTo(this._x3, this._y3);\n        this._context.closePath();\n        break;\n      }\n      case 3: {\n        this.point(this._x3, this._y3);\n        this.point(this._x4, this._y4);\n        this.point(this._x5, this._y5);\n        break;\n      }\n    }\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n      case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n      case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n      default: point$3(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar cardinalClosed = ((function custom(tension) {\n\n  function cardinal(context) {\n    return new CardinalClosed(context, tension);\n  }\n\n  cardinal.tension = function(tension) {\n    return custom(+tension);\n  };\n\n  return cardinal;\n}))(0);\n\nfunction CardinalOpen(context, tension) {\n  this._context = context;\n  this._k = (1 - tension) / 6;\n}\n\nCardinalOpen.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 =\n    this._y0 = this._y1 = this._y2 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n      case 3: this._point = 4; // proceed\n      default: point$3(this, x, y); break;\n    }\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar cardinalOpen = ((function custom(tension) {\n\n  function cardinal(context) {\n    return new CardinalOpen(context, tension);\n  }\n\n  cardinal.tension = function(tension) {\n    return custom(+tension);\n  };\n\n  return cardinal;\n}))(0);\n\nfunction point$4(that, x, y) {\n  var x1 = that._x1,\n      y1 = that._y1,\n      x2 = that._x2,\n      y2 = that._y2;\n\n  if (that._l01_a > epsilon$3) {\n    var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,\n        n = 3 * that._l01_a * (that._l01_a + that._l12_a);\n    x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;\n    y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;\n  }\n\n  if (that._l23_a > epsilon$3) {\n    var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,\n        m = 3 * that._l23_a * (that._l23_a + that._l12_a);\n    x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;\n    y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;\n  }\n\n  that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);\n}\n\nfunction CatmullRom(context, alpha) {\n  this._context = context;\n  this._alpha = alpha;\n}\n\nCatmullRom.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 =\n    this._y0 = this._y1 = this._y2 = NaN;\n    this._l01_a = this._l12_a = this._l23_a =\n    this._l01_2a = this._l12_2a = this._l23_2a =\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 2: this._context.lineTo(this._x2, this._y2); break;\n      case 3: this.point(this._x2, this._y2); break;\n    }\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n\n    if (this._point) {\n      var x23 = this._x2 - x,\n          y23 = this._y2 - y;\n      this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n    }\n\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; // proceed\n      default: point$4(this, x, y); break;\n    }\n\n    this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n    this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar catmullRom = ((function custom(alpha) {\n\n  function catmullRom(context) {\n    return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);\n  }\n\n  catmullRom.alpha = function(alpha) {\n    return custom(+alpha);\n  };\n\n  return catmullRom;\n}))(0.5);\n\nfunction CatmullRomClosed(context, alpha) {\n  this._context = context;\n  this._alpha = alpha;\n}\n\nCatmullRomClosed.prototype = {\n  areaStart: noop$2,\n  areaEnd: noop$2,\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n    this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n    this._l01_a = this._l12_a = this._l23_a =\n    this._l01_2a = this._l12_2a = this._l23_2a =\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 1: {\n        this._context.moveTo(this._x3, this._y3);\n        this._context.closePath();\n        break;\n      }\n      case 2: {\n        this._context.lineTo(this._x3, this._y3);\n        this._context.closePath();\n        break;\n      }\n      case 3: {\n        this.point(this._x3, this._y3);\n        this.point(this._x4, this._y4);\n        this.point(this._x5, this._y5);\n        break;\n      }\n    }\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n\n    if (this._point) {\n      var x23 = this._x2 - x,\n          y23 = this._y2 - y;\n      this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n    }\n\n    switch (this._point) {\n      case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n      case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n      case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n      default: point$4(this, x, y); break;\n    }\n\n    this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n    this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar catmullRomClosed = ((function custom(alpha) {\n\n  function catmullRom(context) {\n    return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);\n  }\n\n  catmullRom.alpha = function(alpha) {\n    return custom(+alpha);\n  };\n\n  return catmullRom;\n}))(0.5);\n\nfunction CatmullRomOpen(context, alpha) {\n  this._context = context;\n  this._alpha = alpha;\n}\n\nCatmullRomOpen.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 = this._x2 =\n    this._y0 = this._y1 = this._y2 = NaN;\n    this._l01_a = this._l12_a = this._l23_a =\n    this._l01_2a = this._l12_2a = this._l23_2a =\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n\n    if (this._point) {\n      var x23 = this._x2 - x,\n          y23 = this._y2 - y;\n      this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n    }\n\n    switch (this._point) {\n      case 0: this._point = 1; break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n      case 3: this._point = 4; // proceed\n      default: point$4(this, x, y); break;\n    }\n\n    this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n    this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n    this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n    this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n  }\n};\n\nvar catmullRomOpen = ((function custom(alpha) {\n\n  function catmullRom(context) {\n    return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);\n  }\n\n  catmullRom.alpha = function(alpha) {\n    return custom(+alpha);\n  };\n\n  return catmullRom;\n}))(0.5);\n\nfunction LinearClosed(context) {\n  this._context = context;\n}\n\nLinearClosed.prototype = {\n  areaStart: noop$2,\n  areaEnd: noop$2,\n  lineStart: function() {\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (this._point) this._context.closePath();\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    if (this._point) this._context.lineTo(x, y);\n    else this._point = 1, this._context.moveTo(x, y);\n  }\n};\n\nvar linearClosed = function(context) {\n  return new LinearClosed(context);\n};\n\nfunction sign$1(x) {\n  return x < 0 ? -1 : 1;\n}\n\n// Calculate the slopes of the tangents (Hermite-type interpolation) based on\n// the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n// Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n// NOV(II), P. 443, 1990.\nfunction slope3(that, x2, y2) {\n  var h0 = that._x1 - that._x0,\n      h1 = x2 - that._x1,\n      s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),\n      s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),\n      p = (s0 * h1 + s1 * h0) / (h0 + h1);\n  return (sign$1(s0) + sign$1(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;\n}\n\n// Calculate a one-sided slope.\nfunction slope2(that, t) {\n  var h = that._x1 - that._x0;\n  return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;\n}\n\n// According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n// \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n// with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\nfunction point$5(that, t0, t1) {\n  var x0 = that._x0,\n      y0 = that._y0,\n      x1 = that._x1,\n      y1 = that._y1,\n      dx = (x1 - x0) / 3;\n  that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);\n}\n\nfunction MonotoneX(context) {\n  this._context = context;\n}\n\nMonotoneX.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x0 = this._x1 =\n    this._y0 = this._y1 =\n    this._t0 = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    switch (this._point) {\n      case 2: this._context.lineTo(this._x1, this._y1); break;\n      case 3: point$5(this, this._t0, slope2(this, this._t0)); break;\n    }\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    var t1 = NaN;\n\n    x = +x, y = +y;\n    if (x === this._x1 && y === this._y1) return; // Ignore coincident points.\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; break;\n      case 2: this._point = 3; point$5(this, slope2(this, t1 = slope3(this, x, y)), t1); break;\n      default: point$5(this, this._t0, t1 = slope3(this, x, y)); break;\n    }\n\n    this._x0 = this._x1, this._x1 = x;\n    this._y0 = this._y1, this._y1 = y;\n    this._t0 = t1;\n  }\n};\n\nfunction MonotoneY(context) {\n  this._context = new ReflectContext(context);\n}\n\n(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {\n  MonotoneX.prototype.point.call(this, y, x);\n};\n\nfunction ReflectContext(context) {\n  this._context = context;\n}\n\nReflectContext.prototype = {\n  moveTo: function(x, y) { this._context.moveTo(y, x); },\n  closePath: function() { this._context.closePath(); },\n  lineTo: function(x, y) { this._context.lineTo(y, x); },\n  bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }\n};\n\nfunction monotoneX(context) {\n  return new MonotoneX(context);\n}\n\nfunction monotoneY(context) {\n  return new MonotoneY(context);\n}\n\nfunction Natural(context) {\n  this._context = context;\n}\n\nNatural.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x = [];\n    this._y = [];\n  },\n  lineEnd: function() {\n    var x = this._x,\n        y = this._y,\n        n = x.length;\n\n    if (n) {\n      this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);\n      if (n === 2) {\n        this._context.lineTo(x[1], y[1]);\n      } else {\n        var px = controlPoints(x),\n            py = controlPoints(y);\n        for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {\n          this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);\n        }\n      }\n    }\n\n    if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();\n    this._line = 1 - this._line;\n    this._x = this._y = null;\n  },\n  point: function(x, y) {\n    this._x.push(+x);\n    this._y.push(+y);\n  }\n};\n\n// See https://www.particleincell.com/2012/bezier-splines/ for derivation.\nfunction controlPoints(x) {\n  var i,\n      n = x.length - 1,\n      m,\n      a = new Array(n),\n      b = new Array(n),\n      r = new Array(n);\n  a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];\n  for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];\n  a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];\n  for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];\n  a[n - 1] = r[n - 1] / b[n - 1];\n  for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];\n  b[n - 1] = (x[n] + a[n - 1]) / 2;\n  for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];\n  return [a, b];\n}\n\nvar natural = function(context) {\n  return new Natural(context);\n};\n\nfunction Step(context, t) {\n  this._context = context;\n  this._t = t;\n}\n\nStep.prototype = {\n  areaStart: function() {\n    this._line = 0;\n  },\n  areaEnd: function() {\n    this._line = NaN;\n  },\n  lineStart: function() {\n    this._x = this._y = NaN;\n    this._point = 0;\n  },\n  lineEnd: function() {\n    if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);\n    if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n    if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;\n  },\n  point: function(x, y) {\n    x = +x, y = +y;\n    switch (this._point) {\n      case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n      case 1: this._point = 2; // proceed\n      default: {\n        if (this._t <= 0) {\n          this._context.lineTo(this._x, y);\n          this._context.lineTo(x, y);\n        } else {\n          var x1 = this._x * (1 - this._t) + x * this._t;\n          this._context.lineTo(x1, this._y);\n          this._context.lineTo(x1, y);\n        }\n        break;\n      }\n    }\n    this._x = x, this._y = y;\n  }\n};\n\nvar step = function(context) {\n  return new Step(context, 0.5);\n};\n\nfunction stepBefore(context) {\n  return new Step(context, 0);\n}\n\nfunction stepAfter(context) {\n  return new Step(context, 1);\n}\n\nvar none$1 = function(series, order) {\n  if (!((n = series.length) > 1)) return;\n  for (var i = 1, j, s0, s1 = series[order[0]], n, m = s1.length; i < n; ++i) {\n    s0 = s1, s1 = series[order[i]];\n    for (j = 0; j < m; ++j) {\n      s1[j][1] += s1[j][0] = isNaN(s0[j][1]) ? s0[j][0] : s0[j][1];\n    }\n  }\n};\n\nvar none$2 = function(series) {\n  var n = series.length, o = new Array(n);\n  while (--n >= 0) o[n] = n;\n  return o;\n};\n\nfunction stackValue(d, key) {\n  return d[key];\n}\n\nvar stack = function() {\n  var keys = constant$10([]),\n      order = none$2,\n      offset = none$1,\n      value = stackValue;\n\n  function stack(data) {\n    var kz = keys.apply(this, arguments),\n        i,\n        m = data.length,\n        n = kz.length,\n        sz = new Array(n),\n        oz;\n\n    for (i = 0; i < n; ++i) {\n      for (var ki = kz[i], si = sz[i] = new Array(m), j = 0, sij; j < m; ++j) {\n        si[j] = sij = [0, +value(data[j], ki, j, data)];\n        sij.data = data[j];\n      }\n      si.key = ki;\n    }\n\n    for (i = 0, oz = order(sz); i < n; ++i) {\n      sz[oz[i]].index = i;\n    }\n\n    offset(sz, oz);\n    return sz;\n  }\n\n  stack.keys = function(_) {\n    return arguments.length ? (keys = typeof _ === \"function\" ? _ : constant$10(slice$5.call(_)), stack) : keys;\n  };\n\n  stack.value = function(_) {\n    return arguments.length ? (value = typeof _ === \"function\" ? _ : constant$10(+_), stack) : value;\n  };\n\n  stack.order = function(_) {\n    return arguments.length ? (order = _ == null ? none$2 : typeof _ === \"function\" ? _ : constant$10(slice$5.call(_)), stack) : order;\n  };\n\n  stack.offset = function(_) {\n    return arguments.length ? (offset = _ == null ? none$1 : _, stack) : offset;\n  };\n\n  return stack;\n};\n\nvar expand = function(series, order) {\n  if (!((n = series.length) > 0)) return;\n  for (var i, n, j = 0, m = series[0].length, y; j < m; ++j) {\n    for (y = i = 0; i < n; ++i) y += series[i][j][1] || 0;\n    if (y) for (i = 0; i < n; ++i) series[i][j][1] /= y;\n  }\n  none$1(series, order);\n};\n\nvar diverging = function(series, order) {\n  if (!((n = series.length) > 1)) return;\n  for (var i, j = 0, d, dy, yp, yn, n, m = series[order[0]].length; j < m; ++j) {\n    for (yp = yn = 0, i = 0; i < n; ++i) {\n      if ((dy = (d = series[order[i]][j])[1] - d[0]) >= 0) {\n        d[0] = yp, d[1] = yp += dy;\n      } else if (dy < 0) {\n        d[1] = yn, d[0] = yn += dy;\n      } else {\n        d[0] = yp;\n      }\n    }\n  }\n};\n\nvar silhouette = function(series, order) {\n  if (!((n = series.length) > 0)) return;\n  for (var j = 0, s0 = series[order[0]], n, m = s0.length; j < m; ++j) {\n    for (var i = 0, y = 0; i < n; ++i) y += series[i][j][1] || 0;\n    s0[j][1] += s0[j][0] = -y / 2;\n  }\n  none$1(series, order);\n};\n\nvar wiggle = function(series, order) {\n  if (!((n = series.length) > 0) || !((m = (s0 = series[order[0]]).length) > 0)) return;\n  for (var y = 0, j = 1, s0, m, n; j < m; ++j) {\n    for (var i = 0, s1 = 0, s2 = 0; i < n; ++i) {\n      var si = series[order[i]],\n          sij0 = si[j][1] || 0,\n          sij1 = si[j - 1][1] || 0,\n          s3 = (sij0 - sij1) / 2;\n      for (var k = 0; k < i; ++k) {\n        var sk = series[order[k]],\n            skj0 = sk[j][1] || 0,\n            skj1 = sk[j - 1][1] || 0;\n        s3 += skj0 - skj1;\n      }\n      s1 += sij0, s2 += s3 * sij0;\n    }\n    s0[j - 1][1] += s0[j - 1][0] = y;\n    if (s1) y -= s2 / s1;\n  }\n  s0[j - 1][1] += s0[j - 1][0] = y;\n  none$1(series, order);\n};\n\nvar ascending$2 = function(series) {\n  var sums = series.map(sum$2);\n  return none$2(series).sort(function(a, b) { return sums[a] - sums[b]; });\n};\n\nfunction sum$2(series) {\n  var s = 0, i = -1, n = series.length, v;\n  while (++i < n) if (v = +series[i][1]) s += v;\n  return s;\n}\n\nvar descending$2 = function(series) {\n  return ascending$2(series).reverse();\n};\n\nvar insideOut = function(series) {\n  var n = series.length,\n      i,\n      j,\n      sums = series.map(sum$2),\n      order = none$2(series).sort(function(a, b) { return sums[b] - sums[a]; }),\n      top = 0,\n      bottom = 0,\n      tops = [],\n      bottoms = [];\n\n  for (i = 0; i < n; ++i) {\n    j = order[i];\n    if (top < bottom) {\n      top += sums[j];\n      tops.push(j);\n    } else {\n      bottom += sums[j];\n      bottoms.push(j);\n    }\n  }\n\n  return bottoms.reverse().concat(tops);\n};\n\nvar reverse = function(series) {\n  return none$2(series).reverse();\n};\n\nvar constant$11 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nfunction x$4(d) {\n  return d[0];\n}\n\nfunction y$4(d) {\n  return d[1];\n}\n\nfunction RedBlackTree() {\n  this._ = null; // root node\n}\n\nfunction RedBlackNode(node) {\n  node.U = // parent node\n  node.C = // color - true for red, false for black\n  node.L = // left node\n  node.R = // right node\n  node.P = // previous node\n  node.N = null; // next node\n}\n\nRedBlackTree.prototype = {\n  constructor: RedBlackTree,\n\n  insert: function(after, node) {\n    var parent, grandpa, uncle;\n\n    if (after) {\n      node.P = after;\n      node.N = after.N;\n      if (after.N) after.N.P = node;\n      after.N = node;\n      if (after.R) {\n        after = after.R;\n        while (after.L) after = after.L;\n        after.L = node;\n      } else {\n        after.R = node;\n      }\n      parent = after;\n    } else if (this._) {\n      after = RedBlackFirst(this._);\n      node.P = null;\n      node.N = after;\n      after.P = after.L = node;\n      parent = after;\n    } else {\n      node.P = node.N = null;\n      this._ = node;\n      parent = null;\n    }\n    node.L = node.R = null;\n    node.U = parent;\n    node.C = true;\n\n    after = node;\n    while (parent && parent.C) {\n      grandpa = parent.U;\n      if (parent === grandpa.L) {\n        uncle = grandpa.R;\n        if (uncle && uncle.C) {\n          parent.C = uncle.C = false;\n          grandpa.C = true;\n          after = grandpa;\n        } else {\n          if (after === parent.R) {\n            RedBlackRotateLeft(this, parent);\n            after = parent;\n            parent = after.U;\n          }\n          parent.C = false;\n          grandpa.C = true;\n          RedBlackRotateRight(this, grandpa);\n        }\n      } else {\n        uncle = grandpa.L;\n        if (uncle && uncle.C) {\n          parent.C = uncle.C = false;\n          grandpa.C = true;\n          after = grandpa;\n        } else {\n          if (after === parent.L) {\n            RedBlackRotateRight(this, parent);\n            after = parent;\n            parent = after.U;\n          }\n          parent.C = false;\n          grandpa.C = true;\n          RedBlackRotateLeft(this, grandpa);\n        }\n      }\n      parent = after.U;\n    }\n    this._.C = false;\n  },\n\n  remove: function(node) {\n    if (node.N) node.N.P = node.P;\n    if (node.P) node.P.N = node.N;\n    node.N = node.P = null;\n\n    var parent = node.U,\n        sibling,\n        left = node.L,\n        right = node.R,\n        next,\n        red;\n\n    if (!left) next = right;\n    else if (!right) next = left;\n    else next = RedBlackFirst(right);\n\n    if (parent) {\n      if (parent.L === node) parent.L = next;\n      else parent.R = next;\n    } else {\n      this._ = next;\n    }\n\n    if (left && right) {\n      red = next.C;\n      next.C = node.C;\n      next.L = left;\n      left.U = next;\n      if (next !== right) {\n        parent = next.U;\n        next.U = node.U;\n        node = next.R;\n        parent.L = node;\n        next.R = right;\n        right.U = next;\n      } else {\n        next.U = parent;\n        parent = next;\n        node = next.R;\n      }\n    } else {\n      red = node.C;\n      node = next;\n    }\n\n    if (node) node.U = parent;\n    if (red) return;\n    if (node && node.C) { node.C = false; return; }\n\n    do {\n      if (node === this._) break;\n      if (node === parent.L) {\n        sibling = parent.R;\n        if (sibling.C) {\n          sibling.C = false;\n          parent.C = true;\n          RedBlackRotateLeft(this, parent);\n          sibling = parent.R;\n        }\n        if ((sibling.L && sibling.L.C)\n            || (sibling.R && sibling.R.C)) {\n          if (!sibling.R || !sibling.R.C) {\n            sibling.L.C = false;\n            sibling.C = true;\n            RedBlackRotateRight(this, sibling);\n            sibling = parent.R;\n          }\n          sibling.C = parent.C;\n          parent.C = sibling.R.C = false;\n          RedBlackRotateLeft(this, parent);\n          node = this._;\n          break;\n        }\n      } else {\n        sibling = parent.L;\n        if (sibling.C) {\n          sibling.C = false;\n          parent.C = true;\n          RedBlackRotateRight(this, parent);\n          sibling = parent.L;\n        }\n        if ((sibling.L && sibling.L.C)\n          || (sibling.R && sibling.R.C)) {\n          if (!sibling.L || !sibling.L.C) {\n            sibling.R.C = false;\n            sibling.C = true;\n            RedBlackRotateLeft(this, sibling);\n            sibling = parent.L;\n          }\n          sibling.C = parent.C;\n          parent.C = sibling.L.C = false;\n          RedBlackRotateRight(this, parent);\n          node = this._;\n          break;\n        }\n      }\n      sibling.C = true;\n      node = parent;\n      parent = parent.U;\n    } while (!node.C);\n\n    if (node) node.C = false;\n  }\n};\n\nfunction RedBlackRotateLeft(tree, node) {\n  var p = node,\n      q = node.R,\n      parent = p.U;\n\n  if (parent) {\n    if (parent.L === p) parent.L = q;\n    else parent.R = q;\n  } else {\n    tree._ = q;\n  }\n\n  q.U = parent;\n  p.U = q;\n  p.R = q.L;\n  if (p.R) p.R.U = p;\n  q.L = p;\n}\n\nfunction RedBlackRotateRight(tree, node) {\n  var p = node,\n      q = node.L,\n      parent = p.U;\n\n  if (parent) {\n    if (parent.L === p) parent.L = q;\n    else parent.R = q;\n  } else {\n    tree._ = q;\n  }\n\n  q.U = parent;\n  p.U = q;\n  p.L = q.R;\n  if (p.L) p.L.U = p;\n  q.R = p;\n}\n\nfunction RedBlackFirst(node) {\n  while (node.L) node = node.L;\n  return node;\n}\n\nfunction createEdge(left, right, v0, v1) {\n  var edge = [null, null],\n      index = edges.push(edge) - 1;\n  edge.left = left;\n  edge.right = right;\n  if (v0) setEdgeEnd(edge, left, right, v0);\n  if (v1) setEdgeEnd(edge, right, left, v1);\n  cells[left.index].halfedges.push(index);\n  cells[right.index].halfedges.push(index);\n  return edge;\n}\n\nfunction createBorderEdge(left, v0, v1) {\n  var edge = [v0, v1];\n  edge.left = left;\n  return edge;\n}\n\nfunction setEdgeEnd(edge, left, right, vertex) {\n  if (!edge[0] && !edge[1]) {\n    edge[0] = vertex;\n    edge.left = left;\n    edge.right = right;\n  } else if (edge.left === right) {\n    edge[1] = vertex;\n  } else {\n    edge[0] = vertex;\n  }\n}\n\n// Liang–Barsky line clipping.\nfunction clipEdge(edge, x0, y0, x1, y1) {\n  var a = edge[0],\n      b = edge[1],\n      ax = a[0],\n      ay = a[1],\n      bx = b[0],\n      by = b[1],\n      t0 = 0,\n      t1 = 1,\n      dx = bx - ax,\n      dy = by - ay,\n      r;\n\n  r = x0 - ax;\n  if (!dx && r > 0) return;\n  r /= dx;\n  if (dx < 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  } else if (dx > 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  }\n\n  r = x1 - ax;\n  if (!dx && r < 0) return;\n  r /= dx;\n  if (dx < 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  } else if (dx > 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  }\n\n  r = y0 - ay;\n  if (!dy && r > 0) return;\n  r /= dy;\n  if (dy < 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  } else if (dy > 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  }\n\n  r = y1 - ay;\n  if (!dy && r < 0) return;\n  r /= dy;\n  if (dy < 0) {\n    if (r > t1) return;\n    if (r > t0) t0 = r;\n  } else if (dy > 0) {\n    if (r < t0) return;\n    if (r < t1) t1 = r;\n  }\n\n  if (!(t0 > 0) && !(t1 < 1)) return true; // TODO Better check?\n\n  if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];\n  if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];\n  return true;\n}\n\nfunction connectEdge(edge, x0, y0, x1, y1) {\n  var v1 = edge[1];\n  if (v1) return true;\n\n  var v0 = edge[0],\n      left = edge.left,\n      right = edge.right,\n      lx = left[0],\n      ly = left[1],\n      rx = right[0],\n      ry = right[1],\n      fx = (lx + rx) / 2,\n      fy = (ly + ry) / 2,\n      fm,\n      fb;\n\n  if (ry === ly) {\n    if (fx < x0 || fx >= x1) return;\n    if (lx > rx) {\n      if (!v0) v0 = [fx, y0];\n      else if (v0[1] >= y1) return;\n      v1 = [fx, y1];\n    } else {\n      if (!v0) v0 = [fx, y1];\n      else if (v0[1] < y0) return;\n      v1 = [fx, y0];\n    }\n  } else {\n    fm = (lx - rx) / (ry - ly);\n    fb = fy - fm * fx;\n    if (fm < -1 || fm > 1) {\n      if (lx > rx) {\n        if (!v0) v0 = [(y0 - fb) / fm, y0];\n        else if (v0[1] >= y1) return;\n        v1 = [(y1 - fb) / fm, y1];\n      } else {\n        if (!v0) v0 = [(y1 - fb) / fm, y1];\n        else if (v0[1] < y0) return;\n        v1 = [(y0 - fb) / fm, y0];\n      }\n    } else {\n      if (ly < ry) {\n        if (!v0) v0 = [x0, fm * x0 + fb];\n        else if (v0[0] >= x1) return;\n        v1 = [x1, fm * x1 + fb];\n      } else {\n        if (!v0) v0 = [x1, fm * x1 + fb];\n        else if (v0[0] < x0) return;\n        v1 = [x0, fm * x0 + fb];\n      }\n    }\n  }\n\n  edge[0] = v0;\n  edge[1] = v1;\n  return true;\n}\n\nfunction clipEdges(x0, y0, x1, y1) {\n  var i = edges.length,\n      edge;\n\n  while (i--) {\n    if (!connectEdge(edge = edges[i], x0, y0, x1, y1)\n        || !clipEdge(edge, x0, y0, x1, y1)\n        || !(Math.abs(edge[0][0] - edge[1][0]) > epsilon$4\n            || Math.abs(edge[0][1] - edge[1][1]) > epsilon$4)) {\n      delete edges[i];\n    }\n  }\n}\n\nfunction createCell(site) {\n  return cells[site.index] = {\n    site: site,\n    halfedges: []\n  };\n}\n\nfunction cellHalfedgeAngle(cell, edge) {\n  var site = cell.site,\n      va = edge.left,\n      vb = edge.right;\n  if (site === vb) vb = va, va = site;\n  if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);\n  if (site === va) va = edge[1], vb = edge[0];\n  else va = edge[0], vb = edge[1];\n  return Math.atan2(va[0] - vb[0], vb[1] - va[1]);\n}\n\nfunction cellHalfedgeStart(cell, edge) {\n  return edge[+(edge.left !== cell.site)];\n}\n\nfunction cellHalfedgeEnd(cell, edge) {\n  return edge[+(edge.left === cell.site)];\n}\n\nfunction sortCellHalfedges() {\n  for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {\n    if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {\n      var index = new Array(m),\n          array = new Array(m);\n      for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);\n      index.sort(function(i, j) { return array[j] - array[i]; });\n      for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];\n      for (j = 0; j < m; ++j) halfedges[j] = array[j];\n    }\n  }\n}\n\nfunction clipCells(x0, y0, x1, y1) {\n  var nCells = cells.length,\n      iCell,\n      cell,\n      site,\n      iHalfedge,\n      halfedges,\n      nHalfedges,\n      start,\n      startX,\n      startY,\n      end,\n      endX,\n      endY,\n      cover = true;\n\n  for (iCell = 0; iCell < nCells; ++iCell) {\n    if (cell = cells[iCell]) {\n      site = cell.site;\n      halfedges = cell.halfedges;\n      iHalfedge = halfedges.length;\n\n      // Remove any dangling clipped edges.\n      while (iHalfedge--) {\n        if (!edges[halfedges[iHalfedge]]) {\n          halfedges.splice(iHalfedge, 1);\n        }\n      }\n\n      // Insert any border edges as necessary.\n      iHalfedge = 0, nHalfedges = halfedges.length;\n      while (iHalfedge < nHalfedges) {\n        end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];\n        start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];\n        if (Math.abs(endX - startX) > epsilon$4 || Math.abs(endY - startY) > epsilon$4) {\n          halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,\n              Math.abs(endX - x0) < epsilon$4 && y1 - endY > epsilon$4 ? [x0, Math.abs(startX - x0) < epsilon$4 ? startY : y1]\n              : Math.abs(endY - y1) < epsilon$4 && x1 - endX > epsilon$4 ? [Math.abs(startY - y1) < epsilon$4 ? startX : x1, y1]\n              : Math.abs(endX - x1) < epsilon$4 && endY - y0 > epsilon$4 ? [x1, Math.abs(startX - x1) < epsilon$4 ? startY : y0]\n              : Math.abs(endY - y0) < epsilon$4 && endX - x0 > epsilon$4 ? [Math.abs(startY - y0) < epsilon$4 ? startX : x0, y0]\n              : null)) - 1);\n          ++nHalfedges;\n        }\n      }\n\n      if (nHalfedges) cover = false;\n    }\n  }\n\n  // If there weren’t any edges, have the closest site cover the extent.\n  // It doesn’t matter which corner of the extent we measure!\n  if (cover) {\n    var dx, dy, d2, dc = Infinity;\n\n    for (iCell = 0, cover = null; iCell < nCells; ++iCell) {\n      if (cell = cells[iCell]) {\n        site = cell.site;\n        dx = site[0] - x0;\n        dy = site[1] - y0;\n        d2 = dx * dx + dy * dy;\n        if (d2 < dc) dc = d2, cover = cell;\n      }\n    }\n\n    if (cover) {\n      var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];\n      cover.halfedges.push(\n        edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,\n        edges.push(createBorderEdge(site, v01, v11)) - 1,\n        edges.push(createBorderEdge(site, v11, v10)) - 1,\n        edges.push(createBorderEdge(site, v10, v00)) - 1\n      );\n    }\n  }\n\n  // Lastly delete any cells with no edges; these were entirely clipped.\n  for (iCell = 0; iCell < nCells; ++iCell) {\n    if (cell = cells[iCell]) {\n      if (!cell.halfedges.length) {\n        delete cells[iCell];\n      }\n    }\n  }\n}\n\nvar circlePool = [];\n\nvar firstCircle;\n\nfunction Circle() {\n  RedBlackNode(this);\n  this.x =\n  this.y =\n  this.arc =\n  this.site =\n  this.cy = null;\n}\n\nfunction attachCircle(arc) {\n  var lArc = arc.P,\n      rArc = arc.N;\n\n  if (!lArc || !rArc) return;\n\n  var lSite = lArc.site,\n      cSite = arc.site,\n      rSite = rArc.site;\n\n  if (lSite === rSite) return;\n\n  var bx = cSite[0],\n      by = cSite[1],\n      ax = lSite[0] - bx,\n      ay = lSite[1] - by,\n      cx = rSite[0] - bx,\n      cy = rSite[1] - by;\n\n  var d = 2 * (ax * cy - ay * cx);\n  if (d >= -epsilon2$2) return;\n\n  var ha = ax * ax + ay * ay,\n      hc = cx * cx + cy * cy,\n      x = (cy * ha - ay * hc) / d,\n      y = (ax * hc - cx * ha) / d;\n\n  var circle = circlePool.pop() || new Circle;\n  circle.arc = arc;\n  circle.site = cSite;\n  circle.x = x + bx;\n  circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom\n\n  arc.circle = circle;\n\n  var before = null,\n      node = circles._;\n\n  while (node) {\n    if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {\n      if (node.L) node = node.L;\n      else { before = node.P; break; }\n    } else {\n      if (node.R) node = node.R;\n      else { before = node; break; }\n    }\n  }\n\n  circles.insert(before, circle);\n  if (!before) firstCircle = circle;\n}\n\nfunction detachCircle(arc) {\n  var circle = arc.circle;\n  if (circle) {\n    if (!circle.P) firstCircle = circle.N;\n    circles.remove(circle);\n    circlePool.push(circle);\n    RedBlackNode(circle);\n    arc.circle = null;\n  }\n}\n\nvar beachPool = [];\n\nfunction Beach() {\n  RedBlackNode(this);\n  this.edge =\n  this.site =\n  this.circle = null;\n}\n\nfunction createBeach(site) {\n  var beach = beachPool.pop() || new Beach;\n  beach.site = site;\n  return beach;\n}\n\nfunction detachBeach(beach) {\n  detachCircle(beach);\n  beaches.remove(beach);\n  beachPool.push(beach);\n  RedBlackNode(beach);\n}\n\nfunction removeBeach(beach) {\n  var circle = beach.circle,\n      x = circle.x,\n      y = circle.cy,\n      vertex = [x, y],\n      previous = beach.P,\n      next = beach.N,\n      disappearing = [beach];\n\n  detachBeach(beach);\n\n  var lArc = previous;\n  while (lArc.circle\n      && Math.abs(x - lArc.circle.x) < epsilon$4\n      && Math.abs(y - lArc.circle.cy) < epsilon$4) {\n    previous = lArc.P;\n    disappearing.unshift(lArc);\n    detachBeach(lArc);\n    lArc = previous;\n  }\n\n  disappearing.unshift(lArc);\n  detachCircle(lArc);\n\n  var rArc = next;\n  while (rArc.circle\n      && Math.abs(x - rArc.circle.x) < epsilon$4\n      && Math.abs(y - rArc.circle.cy) < epsilon$4) {\n    next = rArc.N;\n    disappearing.push(rArc);\n    detachBeach(rArc);\n    rArc = next;\n  }\n\n  disappearing.push(rArc);\n  detachCircle(rArc);\n\n  var nArcs = disappearing.length,\n      iArc;\n  for (iArc = 1; iArc < nArcs; ++iArc) {\n    rArc = disappearing[iArc];\n    lArc = disappearing[iArc - 1];\n    setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);\n  }\n\n  lArc = disappearing[0];\n  rArc = disappearing[nArcs - 1];\n  rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);\n\n  attachCircle(lArc);\n  attachCircle(rArc);\n}\n\nfunction addBeach(site) {\n  var x = site[0],\n      directrix = site[1],\n      lArc,\n      rArc,\n      dxl,\n      dxr,\n      node = beaches._;\n\n  while (node) {\n    dxl = leftBreakPoint(node, directrix) - x;\n    if (dxl > epsilon$4) node = node.L; else {\n      dxr = x - rightBreakPoint(node, directrix);\n      if (dxr > epsilon$4) {\n        if (!node.R) {\n          lArc = node;\n          break;\n        }\n        node = node.R;\n      } else {\n        if (dxl > -epsilon$4) {\n          lArc = node.P;\n          rArc = node;\n        } else if (dxr > -epsilon$4) {\n          lArc = node;\n          rArc = node.N;\n        } else {\n          lArc = rArc = node;\n        }\n        break;\n      }\n    }\n  }\n\n  createCell(site);\n  var newArc = createBeach(site);\n  beaches.insert(lArc, newArc);\n\n  if (!lArc && !rArc) return;\n\n  if (lArc === rArc) {\n    detachCircle(lArc);\n    rArc = createBeach(lArc.site);\n    beaches.insert(newArc, rArc);\n    newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);\n    attachCircle(lArc);\n    attachCircle(rArc);\n    return;\n  }\n\n  if (!rArc) { // && lArc\n    newArc.edge = createEdge(lArc.site, newArc.site);\n    return;\n  }\n\n  // else lArc !== rArc\n  detachCircle(lArc);\n  detachCircle(rArc);\n\n  var lSite = lArc.site,\n      ax = lSite[0],\n      ay = lSite[1],\n      bx = site[0] - ax,\n      by = site[1] - ay,\n      rSite = rArc.site,\n      cx = rSite[0] - ax,\n      cy = rSite[1] - ay,\n      d = 2 * (bx * cy - by * cx),\n      hb = bx * bx + by * by,\n      hc = cx * cx + cy * cy,\n      vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];\n\n  setEdgeEnd(rArc.edge, lSite, rSite, vertex);\n  newArc.edge = createEdge(lSite, site, null, vertex);\n  rArc.edge = createEdge(site, rSite, null, vertex);\n  attachCircle(lArc);\n  attachCircle(rArc);\n}\n\nfunction leftBreakPoint(arc, directrix) {\n  var site = arc.site,\n      rfocx = site[0],\n      rfocy = site[1],\n      pby2 = rfocy - directrix;\n\n  if (!pby2) return rfocx;\n\n  var lArc = arc.P;\n  if (!lArc) return -Infinity;\n\n  site = lArc.site;\n  var lfocx = site[0],\n      lfocy = site[1],\n      plby2 = lfocy - directrix;\n\n  if (!plby2) return lfocx;\n\n  var hl = lfocx - rfocx,\n      aby2 = 1 / pby2 - 1 / plby2,\n      b = hl / plby2;\n\n  if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;\n\n  return (rfocx + lfocx) / 2;\n}\n\nfunction rightBreakPoint(arc, directrix) {\n  var rArc = arc.N;\n  if (rArc) return leftBreakPoint(rArc, directrix);\n  var site = arc.site;\n  return site[1] === directrix ? site[0] : Infinity;\n}\n\nvar epsilon$4 = 1e-6;\nvar epsilon2$2 = 1e-12;\nvar beaches;\nvar cells;\nvar circles;\nvar edges;\n\nfunction triangleArea(a, b, c) {\n  return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);\n}\n\nfunction lexicographic(a, b) {\n  return b[1] - a[1]\n      || b[0] - a[0];\n}\n\nfunction Diagram(sites, extent) {\n  var site = sites.sort(lexicographic).pop(),\n      x,\n      y,\n      circle;\n\n  edges = [];\n  cells = new Array(sites.length);\n  beaches = new RedBlackTree;\n  circles = new RedBlackTree;\n\n  while (true) {\n    circle = firstCircle;\n    if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {\n      if (site[0] !== x || site[1] !== y) {\n        addBeach(site);\n        x = site[0], y = site[1];\n      }\n      site = sites.pop();\n    } else if (circle) {\n      removeBeach(circle.arc);\n    } else {\n      break;\n    }\n  }\n\n  sortCellHalfedges();\n\n  if (extent) {\n    var x0 = +extent[0][0],\n        y0 = +extent[0][1],\n        x1 = +extent[1][0],\n        y1 = +extent[1][1];\n    clipEdges(x0, y0, x1, y1);\n    clipCells(x0, y0, x1, y1);\n  }\n\n  this.edges = edges;\n  this.cells = cells;\n\n  beaches =\n  circles =\n  edges =\n  cells = null;\n}\n\nDiagram.prototype = {\n  constructor: Diagram,\n\n  polygons: function() {\n    var edges = this.edges;\n\n    return this.cells.map(function(cell) {\n      var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });\n      polygon.data = cell.site.data;\n      return polygon;\n    });\n  },\n\n  triangles: function() {\n    var triangles = [],\n        edges = this.edges;\n\n    this.cells.forEach(function(cell, i) {\n      if (!(m = (halfedges = cell.halfedges).length)) return;\n      var site = cell.site,\n          halfedges,\n          j = -1,\n          m,\n          s0,\n          e1 = edges[halfedges[m - 1]],\n          s1 = e1.left === site ? e1.right : e1.left;\n\n      while (++j < m) {\n        s0 = s1;\n        e1 = edges[halfedges[j]];\n        s1 = e1.left === site ? e1.right : e1.left;\n        if (s0 && s1 && i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {\n          triangles.push([site.data, s0.data, s1.data]);\n        }\n      }\n    });\n\n    return triangles;\n  },\n\n  links: function() {\n    return this.edges.filter(function(edge) {\n      return edge.right;\n    }).map(function(edge) {\n      return {\n        source: edge.left.data,\n        target: edge.right.data\n      };\n    });\n  },\n\n  find: function(x, y, radius) {\n    var that = this, i0, i1 = that._found || 0, n = that.cells.length, cell;\n\n    // Use the previously-found cell, or start with an arbitrary one.\n    while (!(cell = that.cells[i1])) if (++i1 >= n) return null;\n    var dx = x - cell.site[0], dy = y - cell.site[1], d2 = dx * dx + dy * dy;\n\n    // Traverse the half-edges to find a closer cell, if any.\n    do {\n      cell = that.cells[i0 = i1], i1 = null;\n      cell.halfedges.forEach(function(e) {\n        var edge = that.edges[e], v = edge.left;\n        if ((v === cell.site || !v) && !(v = edge.right)) return;\n        var vx = x - v[0], vy = y - v[1], v2 = vx * vx + vy * vy;\n        if (v2 < d2) d2 = v2, i1 = v.index;\n      });\n    } while (i1 !== null);\n\n    that._found = i0;\n\n    return radius == null || d2 <= radius * radius ? cell.site : null;\n  }\n};\n\nvar voronoi = function() {\n  var x$$1 = x$4,\n      y$$1 = y$4,\n      extent = null;\n\n  function voronoi(data) {\n    return new Diagram(data.map(function(d, i) {\n      var s = [Math.round(x$$1(d, i, data) / epsilon$4) * epsilon$4, Math.round(y$$1(d, i, data) / epsilon$4) * epsilon$4];\n      s.index = i;\n      s.data = d;\n      return s;\n    }), extent);\n  }\n\n  voronoi.polygons = function(data) {\n    return voronoi(data).polygons();\n  };\n\n  voronoi.links = function(data) {\n    return voronoi(data).links();\n  };\n\n  voronoi.triangles = function(data) {\n    return voronoi(data).triangles();\n  };\n\n  voronoi.x = function(_) {\n    return arguments.length ? (x$$1 = typeof _ === \"function\" ? _ : constant$11(+_), voronoi) : x$$1;\n  };\n\n  voronoi.y = function(_) {\n    return arguments.length ? (y$$1 = typeof _ === \"function\" ? _ : constant$11(+_), voronoi) : y$$1;\n  };\n\n  voronoi.extent = function(_) {\n    return arguments.length ? (extent = _ == null ? null : [[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]], voronoi) : extent && [[extent[0][0], extent[0][1]], [extent[1][0], extent[1][1]]];\n  };\n\n  voronoi.size = function(_) {\n    return arguments.length ? (extent = _ == null ? null : [[0, 0], [+_[0], +_[1]]], voronoi) : extent && [extent[1][0] - extent[0][0], extent[1][1] - extent[0][1]];\n  };\n\n  return voronoi;\n};\n\nvar constant$12 = function(x) {\n  return function() {\n    return x;\n  };\n};\n\nfunction ZoomEvent(target, type, transform) {\n  this.target = target;\n  this.type = type;\n  this.transform = transform;\n}\n\nfunction Transform(k, x, y) {\n  this.k = k;\n  this.x = x;\n  this.y = y;\n}\n\nTransform.prototype = {\n  constructor: Transform,\n  scale: function(k) {\n    return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n  },\n  translate: function(x, y) {\n    return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n  },\n  apply: function(point) {\n    return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n  },\n  applyX: function(x) {\n    return x * this.k + this.x;\n  },\n  applyY: function(y) {\n    return y * this.k + this.y;\n  },\n  invert: function(location) {\n    return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n  },\n  invertX: function(x) {\n    return (x - this.x) / this.k;\n  },\n  invertY: function(y) {\n    return (y - this.y) / this.k;\n  },\n  rescaleX: function(x) {\n    return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n  },\n  rescaleY: function(y) {\n    return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n  },\n  toString: function() {\n    return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n  }\n};\n\nvar identity$8 = new Transform(1, 0, 0);\n\ntransform$1.prototype = Transform.prototype;\n\nfunction transform$1(node) {\n  return node.__zoom || identity$8;\n}\n\nfunction nopropagation$2() {\n  exports.event.stopImmediatePropagation();\n}\n\nvar noevent$2 = function() {\n  exports.event.preventDefault();\n  exports.event.stopImmediatePropagation();\n};\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter$2() {\n  return !exports.event.button;\n}\n\nfunction defaultExtent$1() {\n  var e = this, w, h;\n  if (e instanceof SVGElement) {\n    e = e.ownerSVGElement || e;\n    w = e.width.baseVal.value;\n    h = e.height.baseVal.value;\n  } else {\n    w = e.clientWidth;\n    h = e.clientHeight;\n  }\n  return [[0, 0], [w, h]];\n}\n\nfunction defaultTransform() {\n  return this.__zoom || identity$8;\n}\n\nvar zoom = function() {\n  var filter = defaultFilter$2,\n      extent = defaultExtent$1,\n      k0 = 0,\n      k1 = Infinity,\n      x0 = -k1,\n      x1 = k1,\n      y0 = x0,\n      y1 = x1,\n      duration = 250,\n      interpolate$$1 = interpolateZoom,\n      gestures = [],\n      listeners = dispatch(\"start\", \"zoom\", \"end\"),\n      touchstarting,\n      touchending,\n      touchDelay = 500,\n      wheelDelay = 150,\n      clickDistance2 = 0;\n\n  function zoom(selection$$1) {\n    selection$$1\n        .on(\"wheel.zoom\", wheeled)\n        .on(\"mousedown.zoom\", mousedowned)\n        .on(\"dblclick.zoom\", dblclicked)\n        .on(\"touchstart.zoom\", touchstarted)\n        .on(\"touchmove.zoom\", touchmoved)\n        .on(\"touchend.zoom touchcancel.zoom\", touchended)\n        .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\")\n        .property(\"__zoom\", defaultTransform);\n  }\n\n  zoom.transform = function(collection, transform) {\n    var selection$$1 = collection.selection ? collection.selection() : collection;\n    selection$$1.property(\"__zoom\", defaultTransform);\n    if (collection !== selection$$1) {\n      schedule(collection, transform);\n    } else {\n      selection$$1.interrupt().each(function() {\n        gesture(this, arguments)\n            .start()\n            .zoom(null, typeof transform === \"function\" ? transform.apply(this, arguments) : transform)\n            .end();\n      });\n    }\n  };\n\n  zoom.scaleBy = function(selection$$1, k) {\n    zoom.scaleTo(selection$$1, function() {\n      var k0 = this.__zoom.k,\n          k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n      return k0 * k1;\n    });\n  };\n\n  zoom.scaleTo = function(selection$$1, k) {\n    zoom.transform(selection$$1, function() {\n      var e = extent.apply(this, arguments),\n          t0 = this.__zoom,\n          p0 = centroid(e),\n          p1 = t0.invert(p0),\n          k1 = typeof k === \"function\" ? k.apply(this, arguments) : k;\n      return constrain(translate(scale(t0, k1), p0, p1), e);\n    });\n  };\n\n  zoom.translateBy = function(selection$$1, x, y) {\n    zoom.transform(selection$$1, function() {\n      return constrain(this.__zoom.translate(\n        typeof x === \"function\" ? x.apply(this, arguments) : x,\n        typeof y === \"function\" ? y.apply(this, arguments) : y\n      ), extent.apply(this, arguments));\n    });\n  };\n\n  function scale(transform, k) {\n    k = Math.max(k0, Math.min(k1, k));\n    return k === transform.k ? transform : new Transform(k, transform.x, transform.y);\n  }\n\n  function translate(transform, p0, p1) {\n    var x = p0[0] - p1[0] * transform.k, y = p0[1] - p1[1] * transform.k;\n    return x === transform.x && y === transform.y ? transform : new Transform(transform.k, x, y);\n  }\n\n  function constrain(transform, extent) {\n    var dx0 = transform.invertX(extent[0][0]) - x0,\n        dx1 = transform.invertX(extent[1][0]) - x1,\n        dy0 = transform.invertY(extent[0][1]) - y0,\n        dy1 = transform.invertY(extent[1][1]) - y1;\n    return transform.translate(\n      dx1 > dx0 ? (dx0 + dx1) / 2 : Math.min(0, dx0) || Math.max(0, dx1),\n      dy1 > dy0 ? (dy0 + dy1) / 2 : Math.min(0, dy0) || Math.max(0, dy1)\n    );\n  }\n\n  function centroid(extent) {\n    return [(+extent[0][0] + +extent[1][0]) / 2, (+extent[0][1] + +extent[1][1]) / 2];\n  }\n\n  function schedule(transition$$1, transform, center) {\n    transition$$1\n        .on(\"start.zoom\", function() { gesture(this, arguments).start(); })\n        .on(\"interrupt.zoom end.zoom\", function() { gesture(this, arguments).end(); })\n        .tween(\"zoom\", function() {\n          var that = this,\n              args = arguments,\n              g = gesture(that, args),\n              e = extent.apply(that, args),\n              p = center || centroid(e),\n              w = Math.max(e[1][0] - e[0][0], e[1][1] - e[0][1]),\n              a = that.__zoom,\n              b = typeof transform === \"function\" ? transform.apply(that, args) : transform,\n              i = interpolate$$1(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));\n          return function(t) {\n            if (t === 1) t = b; // Avoid rounding error on end.\n            else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }\n            g.zoom(null, t);\n          };\n        });\n  }\n\n  function gesture(that, args) {\n    for (var i = 0, n = gestures.length, g; i < n; ++i) {\n      if ((g = gestures[i]).that === that) {\n        return g;\n      }\n    }\n    return new Gesture(that, args);\n  }\n\n  function Gesture(that, args) {\n    this.that = that;\n    this.args = args;\n    this.index = -1;\n    this.active = 0;\n    this.extent = extent.apply(that, args);\n  }\n\n  Gesture.prototype = {\n    start: function() {\n      if (++this.active === 1) {\n        this.index = gestures.push(this) - 1;\n        this.emit(\"start\");\n      }\n      return this;\n    },\n    zoom: function(key, transform) {\n      if (this.mouse && key !== \"mouse\") this.mouse[1] = transform.invert(this.mouse[0]);\n      if (this.touch0 && key !== \"touch\") this.touch0[1] = transform.invert(this.touch0[0]);\n      if (this.touch1 && key !== \"touch\") this.touch1[1] = transform.invert(this.touch1[0]);\n      this.that.__zoom = transform;\n      this.emit(\"zoom\");\n      return this;\n    },\n    end: function() {\n      if (--this.active === 0) {\n        gestures.splice(this.index, 1);\n        this.index = -1;\n        this.emit(\"end\");\n      }\n      return this;\n    },\n    emit: function(type) {\n      customEvent(new ZoomEvent(zoom, type, this.that.__zoom), listeners.apply, listeners, [type, this.that, this.args]);\n    }\n  };\n\n  function wheeled() {\n    if (!filter.apply(this, arguments)) return;\n    var g = gesture(this, arguments),\n        t = this.__zoom,\n        k = Math.max(k0, Math.min(k1, t.k * Math.pow(2, -exports.event.deltaY * (exports.event.deltaMode ? 120 : 1) / 500))),\n        p = mouse(this);\n\n    // If the mouse is in the same location as before, reuse it.\n    // If there were recent wheel events, reset the wheel idle timeout.\n    if (g.wheel) {\n      if (g.mouse[0][0] !== p[0] || g.mouse[0][1] !== p[1]) {\n        g.mouse[1] = t.invert(g.mouse[0] = p);\n      }\n      clearTimeout(g.wheel);\n    }\n\n    // If this wheel event won’t trigger a transform change, ignore it.\n    else if (t.k === k) return;\n\n    // Otherwise, capture the mouse point and location at the start.\n    else {\n      g.mouse = [p, t.invert(p)];\n      interrupt(this);\n      g.start();\n    }\n\n    noevent$2();\n    g.wheel = setTimeout(wheelidled, wheelDelay);\n    g.zoom(\"mouse\", constrain(translate(scale(t, k), g.mouse[0], g.mouse[1]), g.extent));\n\n    function wheelidled() {\n      g.wheel = null;\n      g.end();\n    }\n  }\n\n  function mousedowned() {\n    if (touchending || !filter.apply(this, arguments)) return;\n    var g = gesture(this, arguments),\n        v = select(exports.event.view).on(\"mousemove.zoom\", mousemoved, true).on(\"mouseup.zoom\", mouseupped, true),\n        p = mouse(this),\n        x0 = exports.event.clientX,\n        y0 = exports.event.clientY;\n\n    dragDisable(exports.event.view);\n    nopropagation$2();\n    g.mouse = [p, this.__zoom.invert(p)];\n    interrupt(this);\n    g.start();\n\n    function mousemoved() {\n      noevent$2();\n      if (!g.moved) {\n        var dx = exports.event.clientX - x0, dy = exports.event.clientY - y0;\n        g.moved = dx * dx + dy * dy > clickDistance2;\n      }\n      g.zoom(\"mouse\", constrain(translate(g.that.__zoom, g.mouse[0] = mouse(g.that), g.mouse[1]), g.extent));\n    }\n\n    function mouseupped() {\n      v.on(\"mousemove.zoom mouseup.zoom\", null);\n      yesdrag(exports.event.view, g.moved);\n      noevent$2();\n      g.end();\n    }\n  }\n\n  function dblclicked() {\n    if (!filter.apply(this, arguments)) return;\n    var t0 = this.__zoom,\n        p0 = mouse(this),\n        p1 = t0.invert(p0),\n        k1 = t0.k * (exports.event.shiftKey ? 0.5 : 2),\n        t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments));\n\n    noevent$2();\n    if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);\n    else select(this).call(zoom.transform, t1);\n  }\n\n  function touchstarted() {\n    if (!filter.apply(this, arguments)) return;\n    var g = gesture(this, arguments),\n        touches$$1 = exports.event.changedTouches,\n        started,\n        n = touches$$1.length, i, t, p;\n\n    nopropagation$2();\n    for (i = 0; i < n; ++i) {\n      t = touches$$1[i], p = touch(this, touches$$1, t.identifier);\n      p = [p, this.__zoom.invert(p), t.identifier];\n      if (!g.touch0) g.touch0 = p, started = true;\n      else if (!g.touch1) g.touch1 = p;\n    }\n\n    // If this is a dbltap, reroute to the (optional) dblclick.zoom handler.\n    if (touchstarting) {\n      touchstarting = clearTimeout(touchstarting);\n      if (!g.touch1) {\n        g.end();\n        p = select(this).on(\"dblclick.zoom\");\n        if (p) p.apply(this, arguments);\n        return;\n      }\n    }\n\n    if (started) {\n      touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);\n      interrupt(this);\n      g.start();\n    }\n  }\n\n  function touchmoved() {\n    var g = gesture(this, arguments),\n        touches$$1 = exports.event.changedTouches,\n        n = touches$$1.length, i, t, p, l;\n\n    noevent$2();\n    if (touchstarting) touchstarting = clearTimeout(touchstarting);\n    for (i = 0; i < n; ++i) {\n      t = touches$$1[i], p = touch(this, touches$$1, t.identifier);\n      if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;\n      else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;\n    }\n    t = g.that.__zoom;\n    if (g.touch1) {\n      var p0 = g.touch0[0], l0 = g.touch0[1],\n          p1 = g.touch1[0], l1 = g.touch1[1],\n          dp = (dp = p1[0] - p0[0]) * dp + (dp = p1[1] - p0[1]) * dp,\n          dl = (dl = l1[0] - l0[0]) * dl + (dl = l1[1] - l0[1]) * dl;\n      t = scale(t, Math.sqrt(dp / dl));\n      p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];\n      l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];\n    }\n    else if (g.touch0) p = g.touch0[0], l = g.touch0[1];\n    else return;\n    g.zoom(\"touch\", constrain(translate(t, p, l), g.extent));\n  }\n\n  function touchended() {\n    var g = gesture(this, arguments),\n        touches$$1 = exports.event.changedTouches,\n        n = touches$$1.length, i, t;\n\n    nopropagation$2();\n    if (touchending) clearTimeout(touchending);\n    touchending = setTimeout(function() { touchending = null; }, touchDelay);\n    for (i = 0; i < n; ++i) {\n      t = touches$$1[i];\n      if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;\n      else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;\n    }\n    if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;\n    if (g.touch0) g.touch0[1] = this.__zoom.invert(g.touch0[0]);\n    else g.end();\n  }\n\n  zoom.filter = function(_) {\n    return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant$12(!!_), zoom) : filter;\n  };\n\n  zoom.extent = function(_) {\n    return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant$12([[+_[0][0], +_[0][1]], [+_[1][0], +_[1][1]]]), zoom) : extent;\n  };\n\n  zoom.scaleExtent = function(_) {\n    return arguments.length ? (k0 = +_[0], k1 = +_[1], zoom) : [k0, k1];\n  };\n\n  zoom.translateExtent = function(_) {\n    return arguments.length ? (x0 = +_[0][0], x1 = +_[1][0], y0 = +_[0][1], y1 = +_[1][1], zoom) : [[x0, y0], [x1, y1]];\n  };\n\n  zoom.duration = function(_) {\n    return arguments.length ? (duration = +_, zoom) : duration;\n  };\n\n  zoom.interpolate = function(_) {\n    return arguments.length ? (interpolate$$1 = _, zoom) : interpolate$$1;\n  };\n\n  zoom.on = function() {\n    var value = listeners.on.apply(listeners, arguments);\n    return value === listeners ? zoom : value;\n  };\n\n  zoom.clickDistance = function(_) {\n    return arguments.length ? (clickDistance2 = (_ = +_) * _, zoom) : Math.sqrt(clickDistance2);\n  };\n    \n  return zoom;\n};\n\nexports.version = version;\nexports.bisect = bisectRight;\nexports.bisectRight = bisectRight;\nexports.bisectLeft = bisectLeft;\nexports.ascending = ascending;\nexports.bisector = bisector;\nexports.cross = cross;\nexports.descending = descending;\nexports.deviation = deviation;\nexports.extent = extent;\nexports.histogram = histogram;\nexports.thresholdFreedmanDiaconis = freedmanDiaconis;\nexports.thresholdScott = scott;\nexports.thresholdSturges = sturges;\nexports.max = max;\nexports.mean = mean;\nexports.median = median;\nexports.merge = merge;\nexports.min = min;\nexports.pairs = pairs;\nexports.permute = permute;\nexports.quantile = threshold;\nexports.range = sequence;\nexports.scan = scan;\nexports.shuffle = shuffle;\nexports.sum = sum;\nexports.ticks = ticks;\nexports.tickIncrement = tickIncrement;\nexports.tickStep = tickStep;\nexports.transpose = transpose;\nexports.variance = variance;\nexports.zip = zip;\nexports.axisTop = axisTop;\nexports.axisRight = axisRight;\nexports.axisBottom = axisBottom;\nexports.axisLeft = axisLeft;\nexports.brush = brush;\nexports.brushX = brushX;\nexports.brushY = brushY;\nexports.brushSelection = brushSelection;\nexports.chord = chord;\nexports.ribbon = ribbon;\nexports.nest = nest;\nexports.set = set$2;\nexports.map = map$1;\nexports.keys = keys;\nexports.values = values;\nexports.entries = entries;\nexports.color = color;\nexports.rgb = rgb;\nexports.hsl = hsl;\nexports.lab = lab;\nexports.hcl = hcl;\nexports.cubehelix = cubehelix;\nexports.dispatch = dispatch;\nexports.drag = drag;\nexports.dragDisable = dragDisable;\nexports.dragEnable = yesdrag;\nexports.dsvFormat = dsv;\nexports.csvParse = csvParse;\nexports.csvParseRows = csvParseRows;\nexports.csvFormat = csvFormat;\nexports.csvFormatRows = csvFormatRows;\nexports.tsvParse = tsvParse;\nexports.tsvParseRows = tsvParseRows;\nexports.tsvFormat = tsvFormat;\nexports.tsvFormatRows = tsvFormatRows;\nexports.easeLinear = linear$1;\nexports.easeQuad = quadInOut;\nexports.easeQuadIn = quadIn;\nexports.easeQuadOut = quadOut;\nexports.easeQuadInOut = quadInOut;\nexports.easeCubic = cubicInOut;\nexports.easeCubicIn = cubicIn;\nexports.easeCubicOut = cubicOut;\nexports.easeCubicInOut = cubicInOut;\nexports.easePoly = polyInOut;\nexports.easePolyIn = polyIn;\nexports.easePolyOut = polyOut;\nexports.easePolyInOut = polyInOut;\nexports.easeSin = sinInOut;\nexports.easeSinIn = sinIn;\nexports.easeSinOut = sinOut;\nexports.easeSinInOut = sinInOut;\nexports.easeExp = expInOut;\nexports.easeExpIn = expIn;\nexports.easeExpOut = expOut;\nexports.easeExpInOut = expInOut;\nexports.easeCircle = circleInOut;\nexports.easeCircleIn = circleIn;\nexports.easeCircleOut = circleOut;\nexports.easeCircleInOut = circleInOut;\nexports.easeBounce = bounceOut;\nexports.easeBounceIn = bounceIn;\nexports.easeBounceOut = bounceOut;\nexports.easeBounceInOut = bounceInOut;\nexports.easeBack = backInOut;\nexports.easeBackIn = backIn;\nexports.easeBackOut = backOut;\nexports.easeBackInOut = backInOut;\nexports.easeElastic = elasticOut;\nexports.easeElasticIn = elasticIn;\nexports.easeElasticOut = elasticOut;\nexports.easeElasticInOut = elasticInOut;\nexports.forceCenter = center$1;\nexports.forceCollide = collide;\nexports.forceLink = link;\nexports.forceManyBody = manyBody;\nexports.forceSimulation = simulation;\nexports.forceX = x$2;\nexports.forceY = y$2;\nexports.formatDefaultLocale = defaultLocale;\nexports.formatLocale = formatLocale;\nexports.formatSpecifier = formatSpecifier;\nexports.precisionFixed = precisionFixed;\nexports.precisionPrefix = precisionPrefix;\nexports.precisionRound = precisionRound;\nexports.geoArea = area;\nexports.geoBounds = bounds;\nexports.geoCentroid = centroid;\nexports.geoCircle = circle;\nexports.geoClipExtent = extent$1;\nexports.geoContains = contains;\nexports.geoDistance = distance;\nexports.geoGraticule = graticule;\nexports.geoGraticule10 = graticule10;\nexports.geoInterpolate = interpolate$1;\nexports.geoLength = length$1;\nexports.geoPath = index$1;\nexports.geoAlbers = albers;\nexports.geoAlbersUsa = albersUsa;\nexports.geoAzimuthalEqualArea = azimuthalEqualArea;\nexports.geoAzimuthalEqualAreaRaw = azimuthalEqualAreaRaw;\nexports.geoAzimuthalEquidistant = azimuthalEquidistant;\nexports.geoAzimuthalEquidistantRaw = azimuthalEquidistantRaw;\nexports.geoConicConformal = conicConformal;\nexports.geoConicConformalRaw = conicConformalRaw;\nexports.geoConicEqualArea = conicEqualArea;\nexports.geoConicEqualAreaRaw = conicEqualAreaRaw;\nexports.geoConicEquidistant = conicEquidistant;\nexports.geoConicEquidistantRaw = conicEquidistantRaw;\nexports.geoEquirectangular = equirectangular;\nexports.geoEquirectangularRaw = equirectangularRaw;\nexports.geoGnomonic = gnomonic;\nexports.geoGnomonicRaw = gnomonicRaw;\nexports.geoIdentity = identity$5;\nexports.geoProjection = projection;\nexports.geoProjectionMutator = projectionMutator;\nexports.geoMercator = mercator;\nexports.geoMercatorRaw = mercatorRaw;\nexports.geoOrthographic = orthographic;\nexports.geoOrthographicRaw = orthographicRaw;\nexports.geoStereographic = stereographic;\nexports.geoStereographicRaw = stereographicRaw;\nexports.geoTransverseMercator = transverseMercator;\nexports.geoTransverseMercatorRaw = transverseMercatorRaw;\nexports.geoRotation = rotation;\nexports.geoStream = geoStream;\nexports.geoTransform = transform;\nexports.cluster = cluster;\nexports.hierarchy = hierarchy;\nexports.pack = index$2;\nexports.packSiblings = siblings;\nexports.packEnclose = enclose;\nexports.partition = partition;\nexports.stratify = stratify;\nexports.tree = tree;\nexports.treemap = index$3;\nexports.treemapBinary = binary;\nexports.treemapDice = treemapDice;\nexports.treemapSlice = treemapSlice;\nexports.treemapSliceDice = sliceDice;\nexports.treemapSquarify = squarify;\nexports.treemapResquarify = resquarify;\nexports.interpolate = interpolateValue;\nexports.interpolateArray = array$1;\nexports.interpolateBasis = basis$1;\nexports.interpolateBasisClosed = basisClosed;\nexports.interpolateDate = date;\nexports.interpolateNumber = reinterpolate;\nexports.interpolateObject = object;\nexports.interpolateRound = interpolateRound;\nexports.interpolateString = interpolateString;\nexports.interpolateTransformCss = interpolateTransformCss;\nexports.interpolateTransformSvg = interpolateTransformSvg;\nexports.interpolateZoom = interpolateZoom;\nexports.interpolateRgb = interpolateRgb;\nexports.interpolateRgbBasis = rgbBasis;\nexports.interpolateRgbBasisClosed = rgbBasisClosed;\nexports.interpolateHsl = hsl$2;\nexports.interpolateHslLong = hslLong;\nexports.interpolateLab = lab$1;\nexports.interpolateHcl = hcl$2;\nexports.interpolateHclLong = hclLong;\nexports.interpolateCubehelix = cubehelix$2;\nexports.interpolateCubehelixLong = cubehelixLong;\nexports.quantize = quantize;\nexports.path = path;\nexports.polygonArea = area$1;\nexports.polygonCentroid = centroid$1;\nexports.polygonHull = hull;\nexports.polygonContains = contains$1;\nexports.polygonLength = length$2;\nexports.quadtree = quadtree;\nexports.queue = queue;\nexports.randomUniform = uniform;\nexports.randomNormal = normal;\nexports.randomLogNormal = logNormal;\nexports.randomBates = bates;\nexports.randomIrwinHall = irwinHall;\nexports.randomExponential = exponential$1;\nexports.request = request;\nexports.html = html;\nexports.json = json;\nexports.text = text;\nexports.xml = xml;\nexports.csv = csv$1;\nexports.tsv = tsv$1;\nexports.scaleBand = band;\nexports.scalePoint = point$1;\nexports.scaleIdentity = identity$6;\nexports.scaleLinear = linear$2;\nexports.scaleLog = log$1;\nexports.scaleOrdinal = ordinal;\nexports.scaleImplicit = implicit;\nexports.scalePow = pow$1;\nexports.scaleSqrt = sqrt$1;\nexports.scaleQuantile = quantile$$1;\nexports.scaleQuantize = quantize$1;\nexports.scaleThreshold = threshold$1;\nexports.scaleTime = time;\nexports.scaleUtc = utcTime;\nexports.schemeCategory10 = category10;\nexports.schemeCategory20b = category20b;\nexports.schemeCategory20c = category20c;\nexports.schemeCategory20 = category20;\nexports.interpolateCubehelixDefault = cubehelix$3;\nexports.interpolateRainbow = rainbow$1;\nexports.interpolateWarm = warm;\nexports.interpolateCool = cool;\nexports.interpolateViridis = viridis;\nexports.interpolateMagma = magma;\nexports.interpolateInferno = inferno;\nexports.interpolatePlasma = plasma;\nexports.scaleSequential = sequential;\nexports.creator = creator;\nexports.local = local$1;\nexports.matcher = matcher$1;\nexports.mouse = mouse;\nexports.namespace = namespace;\nexports.namespaces = namespaces;\nexports.select = select;\nexports.selectAll = selectAll;\nexports.selection = selection;\nexports.selector = selector;\nexports.selectorAll = selectorAll;\nexports.style = styleValue;\nexports.touch = touch;\nexports.touches = touches;\nexports.window = defaultView;\nexports.customEvent = customEvent;\nexports.arc = arc;\nexports.area = area$2;\nexports.line = line;\nexports.pie = pie;\nexports.radialArea = radialArea;\nexports.radialLine = radialLine$1;\nexports.linkHorizontal = linkHorizontal;\nexports.linkVertical = linkVertical;\nexports.linkRadial = linkRadial;\nexports.symbol = symbol;\nexports.symbols = symbols;\nexports.symbolCircle = circle$2;\nexports.symbolCross = cross$2;\nexports.symbolDiamond = diamond;\nexports.symbolSquare = square;\nexports.symbolStar = star;\nexports.symbolTriangle = triangle;\nexports.symbolWye = wye;\nexports.curveBasisClosed = basisClosed$1;\nexports.curveBasisOpen = basisOpen;\nexports.curveBasis = basis$2;\nexports.curveBundle = bundle;\nexports.curveCardinalClosed = cardinalClosed;\nexports.curveCardinalOpen = cardinalOpen;\nexports.curveCardinal = cardinal;\nexports.curveCatmullRomClosed = catmullRomClosed;\nexports.curveCatmullRomOpen = catmullRomOpen;\nexports.curveCatmullRom = catmullRom;\nexports.curveLinearClosed = linearClosed;\nexports.curveLinear = curveLinear;\nexports.curveMonotoneX = monotoneX;\nexports.curveMonotoneY = monotoneY;\nexports.curveNatural = natural;\nexports.curveStep = step;\nexports.curveStepAfter = stepAfter;\nexports.curveStepBefore = stepBefore;\nexports.stack = stack;\nexports.stackOffsetExpand = expand;\nexports.stackOffsetDiverging = diverging;\nexports.stackOffsetNone = none$1;\nexports.stackOffsetSilhouette = silhouette;\nexports.stackOffsetWiggle = wiggle;\nexports.stackOrderAscending = ascending$2;\nexports.stackOrderDescending = descending$2;\nexports.stackOrderInsideOut = insideOut;\nexports.stackOrderNone = none$2;\nexports.stackOrderReverse = reverse;\nexports.timeInterval = newInterval;\nexports.timeMillisecond = millisecond;\nexports.timeMilliseconds = milliseconds;\nexports.utcMillisecond = millisecond;\nexports.utcMilliseconds = milliseconds;\nexports.timeSecond = second;\nexports.timeSeconds = seconds;\nexports.utcSecond = second;\nexports.utcSeconds = seconds;\nexports.timeMinute = minute;\nexports.timeMinutes = minutes;\nexports.timeHour = hour;\nexports.timeHours = hours;\nexports.timeDay = day;\nexports.timeDays = days;\nexports.timeWeek = sunday;\nexports.timeWeeks = sundays;\nexports.timeSunday = sunday;\nexports.timeSundays = sundays;\nexports.timeMonday = monday;\nexports.timeMondays = mondays;\nexports.timeTuesday = tuesday;\nexports.timeTuesdays = tuesdays;\nexports.timeWednesday = wednesday;\nexports.timeWednesdays = wednesdays;\nexports.timeThursday = thursday;\nexports.timeThursdays = thursdays;\nexports.timeFriday = friday;\nexports.timeFridays = fridays;\nexports.timeSaturday = saturday;\nexports.timeSaturdays = saturdays;\nexports.timeMonth = month;\nexports.timeMonths = months;\nexports.timeYear = year;\nexports.timeYears = years;\nexports.utcMinute = utcMinute;\nexports.utcMinutes = utcMinutes;\nexports.utcHour = utcHour;\nexports.utcHours = utcHours;\nexports.utcDay = utcDay;\nexports.utcDays = utcDays;\nexports.utcWeek = utcSunday;\nexports.utcWeeks = utcSundays;\nexports.utcSunday = utcSunday;\nexports.utcSundays = utcSundays;\nexports.utcMonday = utcMonday;\nexports.utcMondays = utcMondays;\nexports.utcTuesday = utcTuesday;\nexports.utcTuesdays = utcTuesdays;\nexports.utcWednesday = utcWednesday;\nexports.utcWednesdays = utcWednesdays;\nexports.utcThursday = utcThursday;\nexports.utcThursdays = utcThursdays;\nexports.utcFriday = utcFriday;\nexports.utcFridays = utcFridays;\nexports.utcSaturday = utcSaturday;\nexports.utcSaturdays = utcSaturdays;\nexports.utcMonth = utcMonth;\nexports.utcMonths = utcMonths;\nexports.utcYear = utcYear;\nexports.utcYears = utcYears;\nexports.timeFormatDefaultLocale = defaultLocale$1;\nexports.timeFormatLocale = formatLocale$1;\nexports.isoFormat = formatIso;\nexports.isoParse = parseIso;\nexports.now = now;\nexports.timer = timer;\nexports.timerFlush = timerFlush;\nexports.timeout = timeout$1;\nexports.interval = interval$1;\nexports.transition = transition;\nexports.active = active;\nexports.interrupt = interrupt;\nexports.voronoi = voronoi;\nexports.zoom = zoom;\nexports.zoomTransform = transform$1;\nexports.zoomIdentity = identity$8;\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\n})));\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/d3/d3.min-v4.js",
    "content": "// https://d3js.org Version 4.9.1. Copyright 2017 Mike Bostock.\n(function(t,n){\"object\"==typeof exports&&\"undefined\"!=typeof module?n(exports):\"function\"==typeof define&&define.amd?define([\"exports\"],n):n(t.d3=t.d3||{})})(this,function(t){\"use strict\";function n(t){return function(n,e){return js(t(n),e)}}function e(t,n){return[t,n]}function r(t,n,e){var r=(n-t)/Math.max(0,e),i=Math.floor(Math.log(r)/Math.LN10),o=r/Math.pow(10,i);return i>=0?(o>=sf?10:o>=ff?5:o>=lf?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(o>=sf?10:o>=ff?5:o>=lf?2:1)}function i(t,n,e){var r=Math.abs(n-t)/Math.max(0,e),i=Math.pow(10,Math.floor(Math.log(r)/Math.LN10)),o=r/i;return o>=sf?i*=10:o>=ff?i*=5:o>=lf&&(i*=2),n<t?-i:i}function o(t){return t.length}function u(t){return\"translate(\"+(t+.5)+\",0)\"}function a(t){return\"translate(0,\"+(t+.5)+\")\"}function c(t){var n=Math.max(0,t.bandwidth()-1)/2;return t.round()&&(n=Math.round(n)),function(e){return t(e)+n}}function s(){return!this.__axis}function f(t,n){function e(e){var u=null==i?n.ticks?n.ticks.apply(n,r):n.domain():i,a=null==o?n.tickFormat?n.tickFormat.apply(n,r):Cf:o,_=Math.max(f,0)+h,y=n.range(),g=y[0]+.5,m=y[y.length-1]+.5,x=(n.bandwidth?c:Cf)(n.copy()),b=e.selection?e.selection():e,w=b.selectAll(\".domain\").data([null]),M=b.selectAll(\".tick\").data(u,n).order(),T=M.exit(),k=M.enter().append(\"g\").attr(\"class\",\"tick\"),N=M.select(\"line\"),S=M.select(\"text\");w=w.merge(w.enter().insert(\"path\",\".tick\").attr(\"class\",\"domain\").attr(\"stroke\",\"#000\")),M=M.merge(k),N=N.merge(k.append(\"line\").attr(\"stroke\",\"#000\").attr(d+\"2\",p*f)),S=S.merge(k.append(\"text\").attr(\"fill\",\"#000\").attr(d,p*_).attr(\"dy\",t===zf?\"0em\":t===Lf?\"0.71em\":\"0.32em\")),e!==b&&(w=w.transition(e),M=M.transition(e),N=N.transition(e),S=S.transition(e),T=T.transition(e).attr(\"opacity\",qf).attr(\"transform\",function(t){return isFinite(t=x(t))?v(t):this.getAttribute(\"transform\")}),k.attr(\"opacity\",qf).attr(\"transform\",function(t){var n=this.parentNode.__axis;return v(n&&isFinite(n=n(t))?n:x(t))})),T.remove(),w.attr(\"d\",t===Rf||t==Pf?\"M\"+p*l+\",\"+g+\"H0.5V\"+m+\"H\"+p*l:\"M\"+g+\",\"+p*l+\"V0.5H\"+m+\"V\"+p*l),M.attr(\"opacity\",1).attr(\"transform\",function(t){return v(x(t))}),N.attr(d+\"2\",p*f),S.attr(d,p*_).text(a),b.filter(s).attr(\"fill\",\"none\").attr(\"font-size\",10).attr(\"font-family\",\"sans-serif\").attr(\"text-anchor\",t===Pf?\"start\":t===Rf?\"end\":\"middle\"),b.each(function(){this.__axis=x})}var r=[],i=null,o=null,f=6,l=6,h=3,p=t===zf||t===Rf?-1:1,d=t===Rf||t===Pf?\"x\":\"y\",v=t===zf||t===Lf?u:a;return e.scale=function(t){return arguments.length?(n=t,e):n},e.ticks=function(){return r=Af.call(arguments),e},e.tickArguments=function(t){return arguments.length?(r=null==t?[]:Af.call(t),e):r.slice()},e.tickValues=function(t){return arguments.length?(i=null==t?null:Af.call(t),e):i&&i.slice()},e.tickFormat=function(t){return arguments.length?(o=t,e):o},e.tickSize=function(t){return arguments.length?(f=l=+t,e):f},e.tickSizeInner=function(t){return arguments.length?(f=+t,e):f},e.tickSizeOuter=function(t){return arguments.length?(l=+t,e):l},e.tickPadding=function(t){return arguments.length?(h=+t,e):h},e}function l(t){return f(zf,t)}function h(t){return f(Pf,t)}function p(t){return f(Lf,t)}function d(t){return f(Rf,t)}function v(){for(var t,n=0,e=arguments.length,r={};n<e;++n){if(!(t=arguments[n]+\"\")||t in r)throw new Error(\"illegal type: \"+t);r[t]=[]}return new _(r)}function _(t){this._=t}function y(t,n){return t.trim().split(/^|\\s+/).map(function(t){var e=\"\",r=t.indexOf(\".\");if(r>=0&&(e=t.slice(r+1),t=t.slice(0,r)),t&&!n.hasOwnProperty(t))throw new Error(\"unknown type: \"+t);return{type:t,name:e}})}function g(t,n){for(var e,r=0,i=t.length;r<i;++r)if((e=t[r]).name===n)return e.value}function m(t,n,e){for(var r=0,i=t.length;r<i;++r)if(t[r].name===n){t[r]=Uf,t=t.slice(0,r).concat(t.slice(r+1));break}return null!=e&&t.push({name:n,value:e}),t}function x(t){return function(){var n=this.ownerDocument,e=this.namespaceURI;return e===Df&&n.documentElement.namespaceURI===Df?n.createElement(t):n.createElementNS(e,t)}}function b(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}function w(){return new M}function M(){this._=\"@\"+(++Yf).toString(36)}function T(t,n,e){return t=k(t,n,e),function(n){var e=n.relatedTarget;e&&(e===this||8&e.compareDocumentPosition(this))||t.call(this,n)}}function k(n,e,r){return function(i){var o=t.event;t.event=i;try{n.call(this,this.__data__,e,r)}finally{t.event=o}}}function N(t){return t.trim().split(/^|\\s+/).map(function(t){var n=\"\",e=t.indexOf(\".\");return e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),{type:t,name:n}})}function S(t){return function(){var n=this.__on;if(n){for(var e,r=0,i=-1,o=n.length;r<o;++r)e=n[r],t.type&&e.type!==t.type||e.name!==t.name?n[++i]=e:this.removeEventListener(e.type,e.listener,e.capture);++i?n.length=i:delete this.__on}}}function E(t,n,e){var r=$f.hasOwnProperty(t.type)?T:k;return function(i,o,u){var a,c=this.__on,s=r(n,o,u);if(c)for(var f=0,l=c.length;f<l;++f)if((a=c[f]).type===t.type&&a.name===t.name)return this.removeEventListener(a.type,a.listener,a.capture),this.addEventListener(a.type,a.listener=s,a.capture=e),void(a.value=n);this.addEventListener(t.type,s,e),a={type:t.type,name:t.name,value:n,listener:s,capture:e},c?c.push(a):this.__on=[a]}}function A(n,e,r,i){var o=t.event;n.sourceEvent=t.event,t.event=n;try{return e.apply(r,i)}finally{t.event=o}}function C(){}function z(){return[]}function P(t,n){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=n}function L(t,n,e,r,i,o){for(var u,a=0,c=n.length,s=o.length;a<s;++a)(u=n[a])?(u.__data__=o[a],r[a]=u):e[a]=new P(t,o[a]);for(;a<c;++a)(u=n[a])&&(i[a]=u)}function R(t,n,e,r,i,o,u){var a,c,s,f={},l=n.length,h=o.length,p=new Array(l);for(a=0;a<l;++a)(c=n[a])&&(p[a]=s=ol+u.call(c,c.__data__,a,n),s in f?i[a]=c:f[s]=c);for(a=0;a<h;++a)s=ol+u.call(t,o[a],a,o),(c=f[s])?(r[a]=c,c.__data__=o[a],f[s]=null):e[a]=new P(t,o[a]);for(a=0;a<l;++a)(c=n[a])&&f[p[a]]===c&&(i[a]=c)}function q(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function U(t){return function(){this.removeAttribute(t)}}function D(t){return function(){this.removeAttributeNS(t.space,t.local)}}function O(t,n){return function(){this.setAttribute(t,n)}}function F(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}function I(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttribute(t):this.setAttribute(t,e)}}function Y(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,e)}}function B(t){return function(){this.style.removeProperty(t)}}function H(t,n,e){return function(){this.style.setProperty(t,n,e)}}function j(t,n,e){return function(){var r=n.apply(this,arguments);null==r?this.style.removeProperty(t):this.style.setProperty(t,r,e)}}function X(t,n){return t.style.getPropertyValue(n)||gl(t).getComputedStyle(t,null).getPropertyValue(n)}function $(t){return function(){delete this[t]}}function V(t,n){return function(){this[t]=n}}function W(t,n){return function(){var e=n.apply(this,arguments);null==e?delete this[t]:this[t]=e}}function Z(t){return t.trim().split(/^|\\s+/)}function G(t){return t.classList||new J(t)}function J(t){this._node=t,this._names=Z(t.getAttribute(\"class\")||\"\")}function Q(t,n){for(var e=G(t),r=-1,i=n.length;++r<i;)e.add(n[r])}function K(t,n){for(var e=G(t),r=-1,i=n.length;++r<i;)e.remove(n[r])}function tt(t){return function(){Q(this,t)}}function nt(t){return function(){K(this,t)}}function et(t,n){return function(){(n.apply(this,arguments)?Q:K)(this,t)}}function rt(){this.textContent=\"\"}function it(t){return function(){this.textContent=t}}function ot(t){return function(){var n=t.apply(this,arguments);this.textContent=null==n?\"\":n}}function ut(){this.innerHTML=\"\"}function at(t){return function(){this.innerHTML=t}}function ct(t){return function(){var n=t.apply(this,arguments);this.innerHTML=null==n?\"\":n}}function st(){this.nextSibling&&this.parentNode.appendChild(this)}function ft(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function lt(){return null}function ht(){var t=this.parentNode;t&&t.removeChild(this)}function pt(t,n,e){var r=gl(t),i=r.CustomEvent;\"function\"==typeof i?i=new i(n,e):(i=r.document.createEvent(\"Event\"),e?(i.initEvent(n,e.bubbles,e.cancelable),i.detail=e.detail):i.initEvent(n,!1,!1)),t.dispatchEvent(i)}function dt(t,n){return function(){return pt(this,t,n)}}function vt(t,n){return function(){return pt(this,t,n.apply(this,arguments))}}function _t(t,n){this._groups=t,this._parents=n}function yt(){return new _t([[document.documentElement]],zl)}function gt(){t.event.stopImmediatePropagation()}function mt(t,n){var e=t.document.documentElement,r=Pl(t).on(\"dragstart.drag\",null);n&&(r.on(\"click.drag\",Ul,!0),setTimeout(function(){r.on(\"click.drag\",null)},0)),\"onselectstart\"in e?r.on(\"selectstart.drag\",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}function xt(t,n,e,r,i,o,u,a,c,s){this.target=t,this.type=n,this.subject=e,this.identifier=r,this.active=i,this.x=o,this.y=u,this.dx=a,this.dy=c,this._=s}function bt(){return!t.event.button}function wt(){return this.parentNode}function Mt(n){return null==n?{x:t.event.x,y:t.event.y}:n}function Tt(t,n){var e=Object.create(t.prototype);for(var r in n)e[r]=n[r];return e}function kt(){}function Nt(t){var n;return t=(t+\"\").trim().toLowerCase(),(n=jl.exec(t))?(n=parseInt(n[1],16),new zt(n>>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1)):(n=Xl.exec(t))?St(parseInt(n[1],16)):(n=$l.exec(t))?new zt(n[1],n[2],n[3],1):(n=Vl.exec(t))?new zt(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=Wl.exec(t))?Et(n[1],n[2],n[3],n[4]):(n=Zl.exec(t))?Et(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=Gl.exec(t))?Pt(n[1],n[2]/100,n[3]/100,1):(n=Jl.exec(t))?Pt(n[1],n[2]/100,n[3]/100,n[4]):Ql.hasOwnProperty(t)?St(Ql[t]):\"transparent\"===t?new zt(NaN,NaN,NaN,0):null}function St(t){return new zt(t>>16&255,t>>8&255,255&t,1)}function Et(t,n,e,r){return r<=0&&(t=n=e=NaN),new zt(t,n,e,r)}function At(t){return t instanceof kt||(t=Nt(t)),t?(t=t.rgb(),new zt(t.r,t.g,t.b,t.opacity)):new zt}function Ct(t,n,e,r){return 1===arguments.length?At(t):new zt(t,n,e,null==r?1:r)}function zt(t,n,e,r){this.r=+t,this.g=+n,this.b=+e,this.opacity=+r}function Pt(t,n,e,r){return r<=0?t=n=e=NaN:e<=0||e>=1?t=n=NaN:n<=0&&(t=NaN),new qt(t,n,e,r)}function Lt(t){if(t instanceof qt)return new qt(t.h,t.s,t.l,t.opacity);if(t instanceof kt||(t=Nt(t)),!t)return new qt;if(t instanceof qt)return t;t=t.rgb();var n=t.r/255,e=t.g/255,r=t.b/255,i=Math.min(n,e,r),o=Math.max(n,e,r),u=NaN,a=o-i,c=(o+i)/2;return a?(u=n===o?(e-r)/a+6*(e<r):e===o?(r-n)/a+2:(n-e)/a+4,a/=c<.5?o+i:2-o-i,u*=60):a=c>0&&c<1?0:u,new qt(u,a,c,t.opacity)}function Rt(t,n,e,r){return 1===arguments.length?Lt(t):new qt(t,n,e,null==r?1:r)}function qt(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Ut(t,n,e){return 255*(t<60?n+(e-n)*t/60:t<180?e:t<240?n+(e-n)*(240-t)/60:n)}function Dt(t){if(t instanceof Ft)return new Ft(t.l,t.a,t.b,t.opacity);if(t instanceof $t){var n=t.h*Kl;return new Ft(t.l,Math.cos(n)*t.c,Math.sin(n)*t.c,t.opacity)}t instanceof zt||(t=At(t));var e=Ht(t.r),r=Ht(t.g),i=Ht(t.b),o=It((.4124564*e+.3575761*r+.1804375*i)/nh),u=It((.2126729*e+.7151522*r+.072175*i)/eh);return new Ft(116*u-16,500*(o-u),200*(u-It((.0193339*e+.119192*r+.9503041*i)/rh)),t.opacity)}function Ot(t,n,e,r){return 1===arguments.length?Dt(t):new Ft(t,n,e,null==r?1:r)}function Ft(t,n,e,r){this.l=+t,this.a=+n,this.b=+e,this.opacity=+r}function It(t){return t>ah?Math.pow(t,1/3):t/uh+ih}function Yt(t){return t>oh?t*t*t:uh*(t-ih)}function Bt(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Ht(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function jt(t){if(t instanceof $t)return new $t(t.h,t.c,t.l,t.opacity);t instanceof Ft||(t=Dt(t));var n=Math.atan2(t.b,t.a)*th;return new $t(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function Xt(t,n,e,r){return 1===arguments.length?jt(t):new $t(t,n,e,null==r?1:r)}function $t(t,n,e,r){this.h=+t,this.c=+n,this.l=+e,this.opacity=+r}function Vt(t){if(t instanceof Zt)return new Zt(t.h,t.s,t.l,t.opacity);t instanceof zt||(t=At(t));var n=t.r/255,e=t.g/255,r=t.b/255,i=(vh*r+ph*n-dh*e)/(vh+ph-dh),o=r-i,u=(hh*(e-i)-fh*o)/lh,a=Math.sqrt(u*u+o*o)/(hh*i*(1-i)),c=a?Math.atan2(u,o)*th-120:NaN;return new Zt(c<0?c+360:c,a,i,t.opacity)}function Wt(t,n,e,r){return 1===arguments.length?Vt(t):new Zt(t,n,e,null==r?1:r)}function Zt(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Gt(t,n,e,r,i){var o=t*t,u=o*t;return((1-3*t+3*o-u)*n+(4-6*o+3*u)*e+(1+3*t+3*o-3*u)*r+u*i)/6}function Jt(t,n){return function(e){return t+e*n}}function Qt(t,n,e){return t=Math.pow(t,e),n=Math.pow(n,e)-t,e=1/e,function(r){return Math.pow(t+r*n,e)}}function Kt(t,n){var e=n-t;return e?Jt(t,e>180||e<-180?e-360*Math.round(e/360):e):Th(isNaN(t)?n:t)}function tn(t){return 1==(t=+t)?nn:function(n,e){return e-n?Qt(n,e,t):Th(isNaN(n)?e:n)}}function nn(t,n){var e=n-t;return e?Jt(t,e):Th(isNaN(t)?n:t)}function en(t){return function(n){var e,r,i=n.length,o=new Array(i),u=new Array(i),a=new Array(i);for(e=0;e<i;++e)r=Ct(n[e]),o[e]=r.r||0,u[e]=r.g||0,a[e]=r.b||0;return o=t(o),u=t(u),a=t(a),r.opacity=1,function(t){return r.r=o(t),r.g=u(t),r.b=a(t),r+\"\"}}}function rn(t){return function(){return t}}function on(t){return function(n){return t(n)+\"\"}}function un(t){return\"none\"===t?Oh:(_h||(_h=document.createElement(\"DIV\"),yh=document.documentElement,gh=document.defaultView),_h.style.transform=t,t=gh.getComputedStyle(yh.appendChild(_h),null).getPropertyValue(\"transform\"),yh.removeChild(_h),t=t.slice(7,-1).split(\",\"),Fh(+t[0],+t[1],+t[2],+t[3],+t[4],+t[5]))}function an(t){return null==t?Oh:(mh||(mh=document.createElementNS(\"http://www.w3.org/2000/svg\",\"g\")),mh.setAttribute(\"transform\",t),(t=mh.transform.baseVal.consolidate())?(t=t.matrix,Fh(t.a,t.b,t.c,t.d,t.e,t.f)):Oh)}function cn(t,n,e,r){function i(t){return t.length?t.pop()+\" \":\"\"}function o(t,r,i,o,u,a){if(t!==i||r!==o){var c=u.push(\"translate(\",null,n,null,e);a.push({i:c-4,x:Ch(t,i)},{i:c-2,x:Ch(r,o)})}else(i||o)&&u.push(\"translate(\"+i+n+o+e)}function u(t,n,e,o){t!==n?(t-n>180?n+=360:n-t>180&&(t+=360),o.push({i:e.push(i(e)+\"rotate(\",null,r)-2,x:Ch(t,n)})):n&&e.push(i(e)+\"rotate(\"+n+r)}function a(t,n,e,o){t!==n?o.push({i:e.push(i(e)+\"skewX(\",null,r)-2,x:Ch(t,n)}):n&&e.push(i(e)+\"skewX(\"+n+r)}function c(t,n,e,r,o,u){if(t!==e||n!==r){var a=o.push(i(o)+\"scale(\",null,\",\",null,\")\");u.push({i:a-4,x:Ch(t,e)},{i:a-2,x:Ch(n,r)})}else 1===e&&1===r||o.push(i(o)+\"scale(\"+e+\",\"+r+\")\")}return function(n,e){var r=[],i=[];return n=t(n),e=t(e),o(n.translateX,n.translateY,e.translateX,e.translateY,r,i),u(n.rotate,e.rotate,r,i),a(n.skewX,e.skewX,r,i),c(n.scaleX,n.scaleY,e.scaleX,e.scaleY,r,i),n=e=null,function(t){for(var n,e=-1,o=i.length;++e<o;)r[(n=i[e]).i]=n.x(t);return r.join(\"\")}}}function sn(t){return((t=Math.exp(t))+1/t)/2}function fn(t){return((t=Math.exp(t))-1/t)/2}function ln(t){return((t=Math.exp(2*t))-1)/(t+1)}function hn(t){return function(n,e){var r=t((n=Rt(n)).h,(e=Rt(e)).h),i=nn(n.s,e.s),o=nn(n.l,e.l),u=nn(n.opacity,e.opacity);return function(t){return n.h=r(t),n.s=i(t),n.l=o(t),n.opacity=u(t),n+\"\"}}}function pn(t,n){var e=nn((t=Ot(t)).l,(n=Ot(n)).l),r=nn(t.a,n.a),i=nn(t.b,n.b),o=nn(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=r(n),t.b=i(n),t.opacity=o(n),t+\"\"}}function dn(t){return function(n,e){var r=t((n=Xt(n)).h,(e=Xt(e)).h),i=nn(n.c,e.c),o=nn(n.l,e.l),u=nn(n.opacity,e.opacity);return function(t){return n.h=r(t),n.c=i(t),n.l=o(t),n.opacity=u(t),n+\"\"}}}function vn(t){return function n(e){function r(n,r){var i=t((n=Wt(n)).h,(r=Wt(r)).h),o=nn(n.s,r.s),u=nn(n.l,r.l),a=nn(n.opacity,r.opacity);return function(t){return n.h=i(t),n.s=o(t),n.l=u(Math.pow(t,e)),n.opacity=a(t),n+\"\"}}return e=+e,r.gamma=n,r}(1)}function _n(){return ep||(op(yn),ep=ip.now()+rp)}function yn(){ep=0}function gn(){this._call=this._time=this._next=null}function mn(t,n,e){var r=new gn;return r.restart(t,n,e),r}function xn(){_n(),++Jh;for(var t,n=xh;n;)(t=ep-n._time)>=0&&n._call.call(null,t),n=n._next;--Jh}function bn(){ep=(np=ip.now())+rp,Jh=Qh=0;try{xn()}finally{Jh=0,Mn(),ep=0}}function wn(){var t=ip.now(),n=t-np;n>tp&&(rp-=n,np=t)}function Mn(){for(var t,n,e=xh,r=1/0;e;)e._call?(r>e._time&&(r=e._time),t=e,e=e._next):(n=e._next,e._next=null,e=t?t._next=n:xh=n);bh=t,Tn(r)}function Tn(t){if(!Jh){Qh&&(Qh=clearTimeout(Qh));var n=t-ep;n>24?(t<1/0&&(Qh=setTimeout(bn,n)),Kh&&(Kh=clearInterval(Kh))):(Kh||(np=ep,Kh=setInterval(wn,tp)),Jh=1,op(bn))}}function kn(t,n){var e=t.__transition;if(!e||!(e=e[n])||e.state>fp)throw new Error(\"too late\");return e}function Nn(t,n){var e=t.__transition;if(!e||!(e=e[n])||e.state>hp)throw new Error(\"too late\");return e}function Sn(t,n){var e=t.__transition;if(!e||!(e=e[n]))throw new Error(\"too late\");return e}function En(t,n,e){function r(t){e.state=lp,e.timer.restart(i,e.delay,e.time),e.delay<=t&&i(t-e.delay)}function i(r){var s,f,l,h;if(e.state!==lp)return u();for(s in c)if(h=c[s],h.name===e.name){if(h.state===pp)return up(i);h.state===dp?(h.state=_p,h.timer.stop(),h.on.call(\"interrupt\",t,t.__data__,h.index,h.group),delete c[s]):+s<n&&(h.state=_p,h.timer.stop(),delete c[s])}if(up(function(){e.state===pp&&(e.state=dp,e.timer.restart(o,e.delay,e.time),o(r))}),e.state=hp,e.on.call(\"start\",t,t.__data__,e.index,e.group),e.state===hp){for(e.state=pp,a=new Array(l=e.tween.length),s=0,f=-1;s<l;++s)(h=e.tween[s].value.call(t,t.__data__,e.index,e.group))&&(a[++f]=h);a.length=f+1}}function o(n){for(var r=n<e.duration?e.ease.call(null,n/e.duration):(e.timer.restart(u),e.state=vp,1),i=-1,o=a.length;++i<o;)a[i].call(null,r);e.state===vp&&(e.on.call(\"end\",t,t.__data__,e.index,e.group),u())}function u(){e.state=_p,e.timer.stop(),delete c[n];for(var r in c)return;delete t.__transition}var a,c=t.__transition;c[n]=e,e.timer=mn(r,0,e.time)}function An(t,n){var e,r;return function(){var i=Nn(this,t),o=i.tween;if(o!==e){r=e=o;for(var u=0,a=r.length;u<a;++u)if(r[u].name===n){r=r.slice(),r.splice(u,1);break}}i.tween=r}}function Cn(t,n,e){var r,i;if(\"function\"!=typeof e)throw new Error;return function(){var o=Nn(this,t),u=o.tween;if(u!==r){i=(r=u).slice();for(var a={name:n,value:e},c=0,s=i.length;c<s;++c)if(i[c].name===n){i[c]=a;break}c===s&&i.push(a)}o.tween=i}}function zn(t,n,e){var r=t._id;return t.each(function(){var t=Nn(this,r);(t.value||(t.value={}))[n]=e.apply(this,arguments)}),function(t){return Sn(t,r).value[n]}}function Pn(t){return function(){this.removeAttribute(t)}}function Ln(t){return function(){this.removeAttributeNS(t.space,t.local)}}function Rn(t,n,e){var r,i;return function(){var o=this.getAttribute(t);return o===e?null:o===r?i:i=n(r=o,e)}}function qn(t,n,e){var r,i;return function(){var o=this.getAttributeNS(t.space,t.local);return o===e?null:o===r?i:i=n(r=o,e)}}function Un(t,n,e){var r,i,o;return function(){var u,a=e(this);return null==a?void this.removeAttribute(t):(u=this.getAttribute(t),u===a?null:u===r&&a===i?o:o=n(r=u,i=a))}}function Dn(t,n,e){var r,i,o;return function(){var u,a=e(this);return null==a?void this.removeAttributeNS(t.space,t.local):(u=this.getAttributeNS(t.space,t.local),u===a?null:u===r&&a===i?o:o=n(r=u,i=a))}}function On(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttributeNS(t.space,t.local,r(n))}}return e._value=n,e}function Fn(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttribute(t,r(n))}}return e._value=n,e}function In(t,n){return function(){kn(this,t).delay=+n.apply(this,arguments)}}function Yn(t,n){return n=+n,function(){kn(this,t).delay=n}}function Bn(t,n){return function(){Nn(this,t).duration=+n.apply(this,arguments)}}function Hn(t,n){return n=+n,function(){Nn(this,t).duration=n}}function jn(t,n){if(\"function\"!=typeof n)throw new Error;return function(){Nn(this,t).ease=n}}function Xn(t){return(t+\"\").trim().split(/^|\\s+/).every(function(t){var n=t.indexOf(\".\");return n>=0&&(t=t.slice(0,n)),!t||\"start\"===t})}function $n(t,n,e){var r,i,o=Xn(n)?kn:Nn;return function(){var u=o(this,t),a=u.on;a!==r&&(i=(r=a).copy()).on(n,e),u.on=i}}function Vn(t){return function(){var n=this.parentNode;for(var e in this.__transition)if(+e!==t)return;n&&n.removeChild(this)}}function Wn(t,n){var e,r,i;return function(){var o=X(this,t),u=(this.style.removeProperty(t),X(this,t));return o===u?null:o===e&&u===r?i:i=n(e=o,r=u)}}function Zn(t){return function(){this.style.removeProperty(t)}}function Gn(t,n,e){var r,i;return function(){var o=X(this,t);return o===e?null:o===r?i:i=n(r=o,e)}}function Jn(t,n,e){var r,i,o;return function(){var u=X(this,t),a=e(this);return null==a&&(this.style.removeProperty(t),a=X(this,t)),u===a?null:u===r&&a===i?o:o=n(r=u,i=a)}}function Qn(t,n,e){function r(){var r=this,i=n.apply(r,arguments);return i&&function(n){r.style.setProperty(t,i(n),e)}}return r._value=n,r}function Kn(t){return function(){this.textContent=t}}function te(t){return function(){var n=t(this);this.textContent=null==n?\"\":n}}function ne(t,n,e,r){this._groups=t,this._parents=n,this._name=e,this._id=r}function ee(t){return yt().transition(t)}function re(){return++Fp}function ie(t){return+t}function oe(t){return t*t}function ue(t){return t*(2-t)}function ae(t){return((t*=2)<=1?t*t:--t*(2-t)+1)/2}function ce(t){return t*t*t}function se(t){return--t*t*t+1}function fe(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}function le(t){return 1-Math.cos(t*Xp)}function he(t){return Math.sin(t*Xp)}function pe(t){return(1-Math.cos(jp*t))/2}function de(t){return Math.pow(2,10*t-10)}function ve(t){return 1-Math.pow(2,-10*t)}function _e(t){return((t*=2)<=1?Math.pow(2,10*t-10):2-Math.pow(2,10-10*t))/2}function ye(t){return 1-Math.sqrt(1-t*t)}function ge(t){return Math.sqrt(1- --t*t)}function me(t){return((t*=2)<=1?1-Math.sqrt(1-t*t):Math.sqrt(1-(t-=2)*t)+1)/2}function xe(t){return 1-be(1-t)}function be(t){return(t=+t)<$p?nd*t*t:t<Wp?nd*(t-=Vp)*t+Zp:t<Jp?nd*(t-=Gp)*t+Qp:nd*(t-=Kp)*t+td}function we(t){return((t*=2)<=1?1-be(1-t):be(t-1)+1)/2}function Me(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return sd.time=_n(),sd;return e}function Te(){t.event.stopImmediatePropagation()}function ke(t){return{type:t}}function Ne(){return!t.event.button}function Se(){var t=this.ownerSVGElement||this;return[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]}function Ee(t){for(;!t.__brush;)if(!(t=t.parentNode))return;return t.__brush}function Ae(t){return t[0][0]===t[1][0]||t[0][1]===t[1][1]}function Ce(t){var n=t.__brush;return n?n.dim.output(n.selection):null}function ze(){return Le(xd)}function Pe(){return Le(bd)}function Le(n){function e(t){var e=t.property(\"__brush\",a).selectAll(\".overlay\").data([ke(\"overlay\")]);e.enter().append(\"rect\").attr(\"class\",\"overlay\").attr(\"pointer-events\",\"all\").attr(\"cursor\",Md.overlay).merge(e).each(function(){var t=Ee(this).extent;Pl(this).attr(\"x\",t[0][0]).attr(\"y\",t[0][1]).attr(\"width\",t[1][0]-t[0][0]).attr(\"height\",t[1][1]-t[0][1])}),t.selectAll(\".selection\").data([ke(\"selection\")]).enter().append(\"rect\").attr(\"class\",\"selection\").attr(\"cursor\",Md.selection).attr(\"fill\",\"#777\").attr(\"fill-opacity\",.3).attr(\"stroke\",\"#fff\").attr(\"shape-rendering\",\"crispEdges\");var i=t.selectAll(\".handle\").data(n.handles,function(t){return t.type});i.exit().remove(),i.enter().append(\"rect\").attr(\"class\",function(t){return\"handle handle--\"+t.type}).attr(\"cursor\",function(t){return Md[t.type]}),t.each(r).attr(\"fill\",\"none\").attr(\"pointer-events\",\"all\").style(\"-webkit-tap-highlight-color\",\"rgba(0,0,0,0)\").on(\"mousedown.brush touchstart.brush\",u)}function r(){var t=Pl(this),n=Ee(this).selection;n?(t.selectAll(\".selection\").style(\"display\",null).attr(\"x\",n[0][0]).attr(\"y\",n[0][1]).attr(\"width\",n[1][0]-n[0][0]).attr(\"height\",n[1][1]-n[0][1]),t.selectAll(\".handle\").style(\"display\",null).attr(\"x\",function(t){return\"e\"===t.type[t.type.length-1]?n[1][0]-h/2:n[0][0]-h/2}).attr(\"y\",function(t){return\"s\"===t.type[0]?n[1][1]-h/2:n[0][1]-h/2}).attr(\"width\",function(t){return\"n\"===t.type||\"s\"===t.type?n[1][0]-n[0][0]+h:h}).attr(\"height\",function(t){return\"e\"===t.type||\"w\"===t.type?n[1][1]-n[0][1]+h:h})):t.selectAll(\".selection,.handle\").style(\"display\",\"none\").attr(\"x\",null).attr(\"y\",null).attr(\"width\",null).attr(\"height\",null)}function i(t,n){return t.__brush.emitter||new o(t,n)}function o(t,n){this.that=t,this.args=n,this.state=t.__brush,this.active=0}function u(){function e(){var t=Gf(T);!U||w||M||(Math.abs(t[0]-O[0])>Math.abs(t[1]-O[1])?M=!0:w=!0),O=t,b=!0,vd(),o()}function o(){var t;switch(m=O[0]-D[0],x=O[1]-D[1],N){case yd:case _d:S&&(m=Math.max(P-l,Math.min(R-v,m)),h=l+m,_=v+m),E&&(x=Math.max(L-p,Math.min(q-y,x)),d=p+x,g=y+x);break;case gd:S<0?(m=Math.max(P-l,Math.min(R-l,m)),h=l+m,_=v):S>0&&(m=Math.max(P-v,Math.min(R-v,m)),h=l,_=v+m),E<0?(x=Math.max(L-p,Math.min(q-p,x)),d=p+x,g=y):E>0&&(x=Math.max(L-y,Math.min(q-y,x)),d=p,g=y+x);break;case md:S&&(h=Math.max(P,Math.min(R,l-m*S)),_=Math.max(P,Math.min(R,v+m*S))),E&&(d=Math.max(L,Math.min(q,p-x*E)),g=Math.max(L,Math.min(q,y+x*E)))}_<h&&(S*=-1,t=l,l=v,v=t,t=h,h=_,_=t,k in Td&&Y.attr(\"cursor\",Md[k=Td[k]])),g<d&&(E*=-1,t=p,p=y,y=t,t=d,d=g,g=t,k in kd&&Y.attr(\"cursor\",Md[k=kd[k]])),A.selection&&(z=A.selection),w&&(h=z[0][0],_=z[1][0]),M&&(d=z[0][1],g=z[1][1]),z[0][0]===h&&z[0][1]===d&&z[1][0]===_&&z[1][1]===g||(A.selection=[[h,d],[_,g]],r.call(T),F.brush())}function u(){if(Te(),t.event.touches){if(t.event.touches.length)return;c&&clearTimeout(c),c=setTimeout(function(){c=null},500),I.on(\"touchmove.brush touchend.brush touchcancel.brush\",null)}else mt(t.event.view,b),B.on(\"keydown.brush keyup.brush mousemove.brush mouseup.brush\",null);I.attr(\"pointer-events\",\"all\"),Y.attr(\"cursor\",Md.overlay),A.selection&&(z=A.selection),Ae(z)&&(A.selection=null,r.call(T)),F.end()}function a(){switch(t.event.keyCode){case 16:U=S&&E;break;case 18:N===gd&&(S&&(v=_-m*S,l=h+m*S),E&&(y=g-x*E,p=d+x*E),N=md,o());break;case 32:N!==gd&&N!==md||(S<0?v=_-m:S>0&&(l=h-m),E<0?y=g-x:E>0&&(p=d-x),N=yd,Y.attr(\"cursor\",Md.selection),o());break;default:return}vd()}function s(){switch(t.event.keyCode){case 16:U&&(w=M=U=!1,o());break;case 18:N===md&&(S<0?v=_:S>0&&(l=h),E<0?y=g:E>0&&(p=d),N=gd,o());break;case 32:N===yd&&(t.event.altKey?(S&&(v=_-m*S,l=h+m*S),E&&(y=g-x*E,p=d+x*E),N=md):(S<0?v=_:S>0&&(l=h),E<0?y=g:E>0&&(p=d),N=gd),Y.attr(\"cursor\",Md[k]),o());break;default:return}vd()}if(t.event.touches){if(t.event.changedTouches.length<t.event.touches.length)return vd()}else if(c)return;if(f.apply(this,arguments)){var l,h,p,d,v,_,y,g,m,x,b,w,M,T=this,k=t.event.target.__data__.type,N=\"selection\"===(t.event.metaKey?k=\"overlay\":k)?_d:t.event.altKey?md:gd,S=n===bd?null:Nd[k],E=n===xd?null:Sd[k],A=Ee(T),C=A.extent,z=A.selection,P=C[0][0],L=C[0][1],R=C[1][0],q=C[1][1],U=S&&E&&t.event.shiftKey,D=Gf(T),O=D,F=i(T,arguments).beforestart();\"overlay\"===k?A.selection=z=[[l=n===bd?P:D[0],p=n===xd?L:D[1]],[v=n===bd?R:l,y=n===xd?q:p]]:(l=z[0][0],p=z[0][1],v=z[1][0],y=z[1][1]),h=l,d=p,_=v,g=y;var I=Pl(T).attr(\"pointer-events\",\"none\"),Y=I.selectAll(\".overlay\").attr(\"cursor\",Md[k]);if(t.event.touches)I.on(\"touchmove.brush\",e,!0).on(\"touchend.brush touchcancel.brush\",u,!0);else{var B=Pl(t.event.view).on(\"keydown.brush\",a,!0).on(\"keyup.brush\",s,!0).on(\"mousemove.brush\",e,!0).on(\"mouseup.brush\",u,!0);Dl(t.event.view)}Te(),gp(T),r.call(T),F.start()}}function a(){var t=this.__brush||{selection:null};return t.extent=s.apply(this,arguments),t.dim=n,t}var c,s=Se,f=Ne,l=v(e,\"start\",\"brush\",\"end\"),h=6;return e.move=function(t,e){t.selection?t.on(\"start.brush\",function(){i(this,arguments).beforestart().start()}).on(\"interrupt.brush end.brush\",function(){i(this,arguments).end()}).tween(\"brush\",function(){function t(t){u.selection=1===t&&Ae(s)?null:f(t),r.call(o),a.brush()}var o=this,u=o.__brush,a=i(o,arguments),c=u.selection,s=n.input(\"function\"==typeof e?e.apply(this,arguments):e,u.extent),f=qh(c,s);return c&&s?t:t(1)}):t.each(function(){var t=this,o=arguments,u=t.__brush,a=n.input(\"function\"==typeof e?e.apply(t,o):e,u.extent),c=i(t,o).beforestart();gp(t),u.selection=null==a||Ae(a)?null:a,r.call(t),c.start().brush().end()})},o.prototype={beforestart:function(){return 1==++this.active&&(this.state.emitter=this,this.starting=!0),this},start:function(){return this.starting&&(this.starting=!1,this.emit(\"start\")),this},brush:function(){return this.emit(\"brush\"),this},end:function(){return 0==--this.active&&(delete this.state.emitter,this.emit(\"end\")),this},emit:function(t){A(new dd(e,t,n.output(this.state.selection)),l.apply,l,[t,this.that,this.args])}},e.extent=function(t){return arguments.length?(s=\"function\"==typeof t?t:pd([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),e):s},e.filter=function(t){return arguments.length?(f=\"function\"==typeof t?t:pd(!!t),e):f},e.handleSize=function(t){return arguments.length?(h=+t,e):h},e.on=function(){var t=l.on.apply(l,arguments);return t===l?e:t},e}function Re(t){return function(n,e){return t(n.source.value+n.target.value,e.source.value+e.target.value)}}function qe(){this._x0=this._y0=this._x1=this._y1=null,this._=\"\"}function Ue(){return new qe}function De(t){return t.source}function Oe(t){return t.target}function Fe(t){return t.radius}function Ie(t){return t.startAngle}function Ye(t){return t.endAngle}function Be(){}function He(t,n){var e=new Be;if(t instanceof Be)t.each(function(t,n){e.set(n,t)});else if(Array.isArray(t)){var r,i=-1,o=t.length;if(null==n)for(;++i<o;)e.set(i,t[i]);else for(;++i<o;)e.set(n(r=t[i],i,t),r)}else if(t)for(var u in t)e.set(u,t[u]);return e}function je(){return{}}function Xe(t,n,e){t[n]=e}function $e(){return He()}function Ve(t,n,e){t.set(n,e)}function We(){}function Ze(t,n){var e=new We;if(t instanceof We)t.each(function(t){e.add(t)});else if(t){var r=-1,i=t.length;if(null==n)for(;++r<i;)e.add(t[r]);else for(;++r<i;)e.add(n(t[r],r,t))}return e}function Ge(t){return new Function(\"d\",\"return {\"+t.map(function(t,n){return JSON.stringify(t)+\": d[\"+n+\"]\"}).join(\",\")+\"}\")}function Je(t,n){var e=Ge(t);return function(r,i){return n(e(r),i,t)}}function Qe(t){var n=Object.create(null),e=[];return t.forEach(function(t){for(var r in t)r in n||e.push(n[r]=r)}),e}function Ke(t,n,e,r){if(isNaN(n)||isNaN(e))return t;var i,o,u,a,c,s,f,l,h,p=t._root,d={data:r},v=t._x0,_=t._y0,y=t._x1,g=t._y1;if(!p)return t._root=d,t;for(;p.length;)if((s=n>=(o=(v+y)/2))?v=o:y=o,(f=e>=(u=(_+g)/2))?_=u:g=u,i=p,!(p=p[l=f<<1|s]))return i[l]=d,t;if(a=+t._x.call(null,p.data),c=+t._y.call(null,p.data),n===a&&e===c)return d.next=p,i?i[l]=d:t._root=d,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(s=n>=(o=(v+y)/2))?v=o:y=o,(f=e>=(u=(_+g)/2))?_=u:g=u}while((l=f<<1|s)==(h=(c>=u)<<1|a>=o));return i[h]=p,i[l]=d,t}function tr(t){var n,e,r,i,o=t.length,u=new Array(o),a=new Array(o),c=1/0,s=1/0,f=-1/0,l=-1/0;for(e=0;e<o;++e)isNaN(r=+this._x.call(null,n=t[e]))||isNaN(i=+this._y.call(null,n))||(u[e]=r,a[e]=i,r<c&&(c=r),r>f&&(f=r),i<s&&(s=i),i>l&&(l=i));for(f<c&&(c=this._x0,f=this._x1),l<s&&(s=this._y0,l=this._y1),this.cover(c,s).cover(f,l),e=0;e<o;++e)Ke(this,u[e],a[e],t[e]);return this}function nr(t){for(var n=0,e=t.length;n<e;++n)this.remove(t[n]);return this}function er(t){return t[0]}function rr(t){return t[1]}function ir(t,n,e){var r=new or(null==n?er:n,null==e?rr:e,NaN,NaN,NaN,NaN);return null==t?r:r.addAll(t)}function or(t,n,e,r,i,o){this._x=t,this._y=n,this._x0=e,this._y0=r,this._x1=i,this._y1=o,this._root=void 0}function ur(t){for(var n={data:t.data},e=n;t=t.next;)e=e.next={data:t.data};return n}function ar(t){return t.x+t.vx}function cr(t){return t.y+t.vy}function sr(t){return t.index}function fr(t,n){var e=t.get(n);if(!e)throw new Error(\"missing: \"+n);return e}function lr(t){return t.x}function hr(t){return t.y}function pr(t){return new dr(t)}function dr(t){if(!(n=Ov.exec(t)))throw new Error(\"invalid format: \"+t);var n,e=n[1]||\" \",r=n[2]||\">\",i=n[3]||\"-\",o=n[4]||\"\",u=!!n[5],a=n[6]&&+n[6],c=!!n[7],s=n[8]&&+n[8].slice(1),f=n[9]||\"\";\"n\"===f?(c=!0,f=\"g\"):Dv[f]||(f=\"\"),(u||\"0\"===e&&\"=\"===r)&&(u=!0,e=\"0\",r=\"=\"),this.fill=e,this.align=r,\nthis.sign=i,this.symbol=o,this.zero=u,this.width=a,this.comma=c,this.precision=s,this.type=f}function vr(n){return Fv=Bv(n),t.format=Fv.format,t.formatPrefix=Fv.formatPrefix,Fv}function _r(){this.reset()}function yr(t,n,e){var r=t.s=n+e,i=r-n,o=r-i;t.t=n-o+(e-i)}function gr(t){return t>1?0:t<-1?N_:Math.acos(t)}function mr(t){return t>1?S_:t<-1?-S_:Math.asin(t)}function xr(t){return(t=I_(t/2))*t}function br(){}function wr(t,n){t&&X_.hasOwnProperty(t.type)&&X_[t.type](t,n)}function Mr(t,n,e){var r,i=-1,o=t.length-e;for(n.lineStart();++i<o;)r=t[i],n.point(r[0],r[1],r[2]);n.lineEnd()}function Tr(t,n){var e=-1,r=t.length;for(n.polygonStart();++e<r;)Mr(t[e],n,1);n.polygonEnd()}function kr(){Z_.point=Sr}function Nr(){Er(Vv,Wv)}function Sr(t,n){Z_.point=Er,Vv=t,Wv=n,t*=z_,n*=z_,Zv=t,Gv=q_(n=n/2+E_),Jv=I_(n)}function Er(t,n){t*=z_,n*=z_,n=n/2+E_;var e=t-Zv,r=e>=0?1:-1,i=r*e,o=q_(n),u=I_(n),a=Jv*u,c=Gv*o+a*q_(i),s=a*r*I_(i);V_.add(R_(s,c)),Zv=t,Gv=o,Jv=u}function Ar(t){return[R_(t[1],t[0]),mr(t[2])]}function Cr(t){var n=t[0],e=t[1],r=q_(e);return[r*q_(n),r*I_(n),I_(e)]}function zr(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function Pr(t,n){return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function Lr(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function Rr(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function qr(t){var n=B_(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}function Ur(t,n){u_.push(a_=[Qv=t,t_=t]),n<Kv&&(Kv=n),n>n_&&(n_=n)}function Dr(t,n){var e=Cr([t*z_,n*z_]);if(o_){var r=Pr(o_,e),i=[r[1],-r[0],0],o=Pr(i,r);qr(o),o=Ar(o);var u,a=t-e_,c=a>0?1:-1,s=o[0]*C_*c,f=P_(a)>180;f^(c*e_<s&&s<c*t)?(u=o[1]*C_)>n_&&(n_=u):(s=(s+360)%360-180,f^(c*e_<s&&s<c*t)?(u=-o[1]*C_)<Kv&&(Kv=u):(n<Kv&&(Kv=n),n>n_&&(n_=n))),f?t<e_?Hr(Qv,t)>Hr(Qv,t_)&&(t_=t):Hr(t,t_)>Hr(Qv,t_)&&(Qv=t):t_>=Qv?(t<Qv&&(Qv=t),t>t_&&(t_=t)):t>e_?Hr(Qv,t)>Hr(Qv,t_)&&(t_=t):Hr(t,t_)>Hr(Qv,t_)&&(Qv=t)}else u_.push(a_=[Qv=t,t_=t]);n<Kv&&(Kv=n),n>n_&&(n_=n),o_=e,e_=t}function Or(){Q_.point=Dr}function Fr(){a_[0]=Qv,a_[1]=t_,Q_.point=Ur,o_=null}function Ir(t,n){if(o_){var e=t-e_;J_.add(P_(e)>180?e+(e>0?360:-360):e)}else r_=t,i_=n;Z_.point(t,n),Dr(t,n)}function Yr(){Z_.lineStart()}function Br(){Ir(r_,i_),Z_.lineEnd(),P_(J_)>k_&&(Qv=-(t_=180)),a_[0]=Qv,a_[1]=t_,o_=null}function Hr(t,n){return(n-=t)<0?n+360:n}function jr(t,n){return t[0]-n[0]}function Xr(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}function $r(t,n){t*=z_,n*=z_;var e=q_(n);Vr(e*q_(t),e*I_(t),I_(n))}function Vr(t,n,e){++c_,f_+=(t-f_)/c_,l_+=(n-l_)/c_,h_+=(e-h_)/c_}function Wr(){ty.point=Zr}function Zr(t,n){t*=z_,n*=z_;var e=q_(n);b_=e*q_(t),w_=e*I_(t),M_=I_(n),ty.point=Gr,Vr(b_,w_,M_)}function Gr(t,n){t*=z_,n*=z_;var e=q_(n),r=e*q_(t),i=e*I_(t),o=I_(n),u=R_(B_((u=w_*o-M_*i)*u+(u=M_*r-b_*o)*u+(u=b_*i-w_*r)*u),b_*r+w_*i+M_*o);s_+=u,p_+=u*(b_+(b_=r)),d_+=u*(w_+(w_=i)),v_+=u*(M_+(M_=o)),Vr(b_,w_,M_)}function Jr(){ty.point=$r}function Qr(){ty.point=ti}function Kr(){ni(m_,x_),ty.point=$r}function ti(t,n){m_=t,x_=n,t*=z_,n*=z_,ty.point=ni;var e=q_(n);b_=e*q_(t),w_=e*I_(t),M_=I_(n),Vr(b_,w_,M_)}function ni(t,n){t*=z_,n*=z_;var e=q_(n),r=e*q_(t),i=e*I_(t),o=I_(n),u=w_*o-M_*i,a=M_*r-b_*o,c=b_*i-w_*r,s=B_(u*u+a*a+c*c),f=mr(s),l=s&&-f/s;__+=l*u,y_+=l*a,g_+=l*c,s_+=f,p_+=f*(b_+(b_=r)),d_+=f*(w_+(w_=i)),v_+=f*(M_+(M_=o)),Vr(b_,w_,M_)}function ei(t,n){return[t>N_?t-A_:t<-N_?t+A_:t,n]}function ri(t,n,e){return(t%=A_)?n||e?ry(oi(t),ui(n,e)):oi(t):n||e?ui(n,e):ei}function ii(t){return function(n,e){return n+=t,[n>N_?n-A_:n<-N_?n+A_:n,e]}}function oi(t){var n=ii(t);return n.invert=ii(-t),n}function ui(t,n){function e(t,n){var e=q_(n),a=q_(t)*e,c=I_(t)*e,s=I_(n),f=s*r+a*i;return[R_(c*o-f*u,a*r-s*i),mr(f*o+c*u)]}var r=q_(t),i=I_(t),o=q_(n),u=I_(n);return e.invert=function(t,n){var e=q_(n),a=q_(t)*e,c=I_(t)*e,s=I_(n),f=s*o-c*u;return[R_(c*o+s*u,a*r+f*i),mr(f*r-a*i)]},e}function ai(t,n,e,r,i,o){if(e){var u=q_(n),a=I_(n),c=r*e;null==i?(i=n+r*A_,o=n-c/2):(i=ci(u,i),o=ci(u,o),(r>0?i<o:i>o)&&(i+=r*A_));for(var s,f=i;r>0?f>o:f<o;f-=c)s=Ar([u,-a*q_(f),-a*I_(f)]),t.point(s[0],s[1])}}function ci(t,n){n=Cr(n),n[0]-=t,qr(n);var e=gr(-n[1]);return((-n[2]<0?-e:e)+A_-k_)%A_}function si(t,n,e,r){this.x=t,this.z=n,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function fi(t){if(n=t.length){for(var n,e,r=0,i=t[0];++r<n;)i.n=e=t[r],e.p=i,i=e;i.n=e=t[0],e.p=i}}function li(t,n,e,r){function i(i,o){return t<=i&&i<=e&&n<=o&&o<=r}function o(i,o,a,s){var f=0,l=0;if(null==i||(f=u(i,a))!==(l=u(o,a))||c(i,o)<0^a>0)do{s.point(0===f||3===f?t:e,f>1?r:n)}while((f=(f+a+4)%4)!==l);else s.point(o[0],o[1])}function u(r,i){return P_(r[0]-t)<k_?i>0?0:3:P_(r[0]-e)<k_?i>0?2:1:P_(r[1]-n)<k_?i>0?1:0:i>0?3:2}function a(t,n){return c(t.x,n.x)}function c(t,n){var e=u(t,1),r=u(n,1);return e!==r?e-r:0===e?n[1]-t[1]:1===e?t[0]-n[0]:2===e?t[1]-n[1]:n[0]-t[0]}return function(u){function c(t,n){i(t,n)&&N.point(t,n)}function s(){for(var n=0,e=0,i=_.length;e<i;++e)for(var o,u,a=_[e],c=1,s=a.length,f=a[0],l=f[0],h=f[1];c<s;++c)o=l,u=h,f=a[c],l=f[0],h=f[1],u<=r?h>r&&(l-o)*(r-u)>(h-u)*(t-o)&&++n:h<=r&&(l-o)*(r-u)<(h-u)*(t-o)&&--n;return n}function f(){N=S,v=[],_=[],k=!0}function l(){var t=s(),n=k&&t,e=(v=bf(v)).length;(n||e)&&(u.polygonStart(),n&&(u.lineStart(),o(null,null,1,u),u.lineEnd()),e&&xy(v,a,t,o,u),u.polygonEnd()),N=u,v=_=y=null}function h(){E.point=d,_&&_.push(y=[]),T=!0,M=!1,b=w=NaN}function p(){v&&(d(g,m),x&&M&&S.rejoin(),v.push(S.result())),E.point=c,M&&N.lineEnd()}function d(o,u){var a=i(o,u);if(_&&y.push([o,u]),T)g=o,m=u,x=a,T=!1,a&&(N.lineStart(),N.point(o,u));else if(a&&M)N.point(o,u);else{var c=[b=Math.max(wy,Math.min(by,b)),w=Math.max(wy,Math.min(by,w))],s=[o=Math.max(wy,Math.min(by,o)),u=Math.max(wy,Math.min(by,u))];gy(c,s,t,n,e,r)?(M||(N.lineStart(),N.point(c[0],c[1])),N.point(s[0],s[1]),a||N.lineEnd(),k=!1):a&&(N.lineStart(),N.point(o,u),k=!1)}b=o,w=u,M=a}var v,_,y,g,m,x,b,w,M,T,k,N=u,S=yy(),E={point:c,lineStart:h,lineEnd:p,polygonStart:f,polygonEnd:l};return E}}function hi(){Sy.point=di,Sy.lineEnd=pi}function pi(){Sy.point=Sy.lineEnd=br}function di(t,n){t*=z_,n*=z_,iy=t,oy=I_(n),uy=q_(n),Sy.point=vi}function vi(t,n){t*=z_,n*=z_;var e=I_(n),r=q_(n),i=P_(t-iy),o=q_(i),u=I_(i),a=r*u,c=uy*e-oy*r*o,s=oy*e+uy*r*o;Ny.add(R_(B_(a*a+c*c),s)),iy=t,oy=e,uy=r}function _i(t,n){return!(!t||!Ly.hasOwnProperty(t.type))&&Ly[t.type](t,n)}function yi(t,n){return 0===zy(t,n)}function gi(t,n){var e=zy(t[0],t[1]);return zy(t[0],n)+zy(n,t[1])<=e+k_}function mi(t,n){return!!ky(t.map(xi),bi(n))}function xi(t){return t=t.map(bi),t.pop(),t}function bi(t){return[t[0]*z_,t[1]*z_]}function wi(t,n,e){var r=cf(t,n-k_,e).concat(n);return function(t){return r.map(function(n){return[t,n]})}}function Mi(t,n,e){var r=cf(t,n-k_,e).concat(n);return function(t){return r.map(function(n){return[n,t]})}}function Ti(){function t(){return{type:\"MultiLineString\",coordinates:n()}}function n(){return cf(U_(o/_)*_,i,_).map(h).concat(cf(U_(s/y)*y,c,y).map(p)).concat(cf(U_(r/d)*d,e,d).filter(function(t){return P_(t%_)>k_}).map(f)).concat(cf(U_(a/v)*v,u,v).filter(function(t){return P_(t%y)>k_}).map(l))}var e,r,i,o,u,a,c,s,f,l,h,p,d=10,v=d,_=90,y=360,g=2.5;return t.lines=function(){return n().map(function(t){return{type:\"LineString\",coordinates:t}})},t.outline=function(){return{type:\"Polygon\",coordinates:[h(o).concat(p(c).slice(1),h(i).reverse().slice(1),p(s).reverse().slice(1))]}},t.extent=function(n){return arguments.length?t.extentMajor(n).extentMinor(n):t.extentMinor()},t.extentMajor=function(n){return arguments.length?(o=+n[0][0],i=+n[1][0],s=+n[0][1],c=+n[1][1],o>i&&(n=o,o=i,i=n),s>c&&(n=s,s=c,c=n),t.precision(g)):[[o,s],[i,c]]},t.extentMinor=function(n){return arguments.length?(r=+n[0][0],e=+n[1][0],a=+n[0][1],u=+n[1][1],r>e&&(n=r,r=e,e=n),a>u&&(n=a,a=u,u=n),t.precision(g)):[[r,a],[e,u]]},t.step=function(n){return arguments.length?t.stepMajor(n).stepMinor(n):t.stepMinor()},t.stepMajor=function(n){return arguments.length?(_=+n[0],y=+n[1],t):[_,y]},t.stepMinor=function(n){return arguments.length?(d=+n[0],v=+n[1],t):[d,v]},t.precision=function(n){return arguments.length?(g=+n,f=wi(a,u,90),l=Mi(r,e,g),h=wi(s,c,90),p=Mi(o,i,g),t):g},t.extentMajor([[-180,-90+k_],[180,90-k_]]).extentMinor([[-180,-80-k_],[180,80+k_]])}function ki(){return Ti()()}function Ni(){Fy.point=Si}function Si(t,n){Fy.point=Ei,ay=sy=t,cy=fy=n}function Ei(t,n){Oy.add(fy*t-sy*n),sy=t,fy=n}function Ai(){Ei(ay,cy)}function Ci(t,n){t<Iy&&(Iy=t),t>By&&(By=t),n<Yy&&(Yy=n),n>Hy&&(Hy=n)}function zi(t,n){Xy+=t,$y+=n,++Vy}function Pi(){tg.point=Li}function Li(t,n){tg.point=Ri,zi(py=t,dy=n)}function Ri(t,n){var e=t-py,r=n-dy,i=B_(e*e+r*r);Wy+=i*(py+t)/2,Zy+=i*(dy+n)/2,Gy+=i,zi(py=t,dy=n)}function qi(){tg.point=zi}function Ui(){tg.point=Oi}function Di(){Fi(ly,hy)}function Oi(t,n){tg.point=Fi,zi(ly=py=t,hy=dy=n)}function Fi(t,n){var e=t-py,r=n-dy,i=B_(e*e+r*r);Wy+=i*(py+t)/2,Zy+=i*(dy+n)/2,Gy+=i,i=dy*t-py*n,Jy+=i*(py+t),Qy+=i*(dy+n),Ky+=3*i,zi(py=t,dy=n)}function Ii(t){this._context=t}function Yi(t,n){ag.point=Bi,eg=ig=t,rg=og=n}function Bi(t,n){ig-=t,og-=n,ug.add(B_(ig*ig+og*og)),ig=t,og=n}function Hi(){this._string=[]}function ji(t){return\"m0,\"+t+\"a\"+t+\",\"+t+\" 0 1,1 0,\"+-2*t+\"a\"+t+\",\"+t+\" 0 1,1 0,\"+2*t+\"z\"}function Xi(t){return t.length>1}function $i(t,n){return((t=t.x)[0]<0?t[1]-S_-k_:S_-t[1])-((n=n.x)[0]<0?n[1]-S_-k_:S_-n[1])}function Vi(t){var n,e=NaN,r=NaN,i=NaN;return{lineStart:function(){t.lineStart(),n=1},point:function(o,u){var a=o>0?N_:-N_,c=P_(o-e);P_(c-N_)<k_?(t.point(e,r=(r+u)/2>0?S_:-S_),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(a,r),t.point(o,r),n=0):i!==a&&c>=N_&&(P_(e-i)<k_&&(e-=i*k_),P_(o-a)<k_&&(o-=a*k_),r=Wi(e,r,o,u),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(a,r),n=0),t.point(e=o,r=u),i=a},lineEnd:function(){t.lineEnd(),e=r=NaN},clean:function(){return 2-n}}}function Wi(t,n,e,r){var i,o,u=I_(t-e);return P_(u)>k_?L_((I_(n)*(o=q_(r))*I_(e)-I_(r)*(i=q_(n))*I_(t))/(i*o*u)):(n+r)/2}function Zi(t,n,e,r){var i;if(null==t)i=e*S_,r.point(-N_,i),r.point(0,i),r.point(N_,i),r.point(N_,0),r.point(N_,-i),r.point(0,-i),r.point(-N_,-i),r.point(-N_,0),r.point(-N_,i);else if(P_(t[0]-n[0])>k_){var o=t[0]<n[0]?N_:-N_;i=e*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(n[0],n[1])}function Gi(t){return function(n){var e=new Ji;for(var r in t)e[r]=t[r];return e.stream=n,e}}function Ji(){}function Qi(t,n,e){var r=n[1][0]-n[0][0],i=n[1][1]-n[0][1],o=t.clipExtent&&t.clipExtent();t.scale(150).translate([0,0]),null!=o&&t.clipExtent(null),$_(e,t.stream(jy));var u=jy.result(),a=Math.min(r/(u[1][0]-u[0][0]),i/(u[1][1]-u[0][1])),c=+n[0][0]+(r-a*(u[1][0]+u[0][0]))/2,s=+n[0][1]+(i-a*(u[1][1]+u[0][1]))/2;return null!=o&&t.clipExtent(o),t.scale(150*a).translate([c,s])}function Ki(t,n,e){return Qi(t,[[0,0],n],e)}function to(t){return Gi({point:function(n,e){n=t(n,e),this.stream.point(n[0],n[1])}})}function no(t,n){function e(r,i,o,u,a,c,s,f,l,h,p,d,v,_){var y=s-r,g=f-i,m=y*y+g*g;if(m>4*n&&v--){var x=u+h,b=a+p,w=c+d,M=B_(x*x+b*b+w*w),T=mr(w/=M),k=P_(P_(w)-1)<k_||P_(o-l)<k_?(o+l)/2:R_(b,x),N=t(k,T),S=N[0],E=N[1],A=S-r,C=E-i,z=g*A-y*C;(z*z/m>n||P_((y*A+g*C)/m-.5)>.3||u*h+a*p+c*d<dg)&&(e(r,i,o,u,a,c,S,E,k,x/=M,b/=M,w,v,_),_.point(S,E),e(S,E,k,x,b,w,s,f,l,h,p,d,v,_))}}return function(n){function r(e,r){e=t(e,r),n.point(e[0],e[1])}function i(){y=NaN,w.point=o,n.lineStart()}function o(r,i){var o=Cr([r,i]),u=t(r,i);e(y,g,_,m,x,b,y=u[0],g=u[1],_=r,m=o[0],x=o[1],b=o[2],pg,n),n.point(y,g)}function u(){w.point=r,n.lineEnd()}function a(){i(),w.point=c,w.lineEnd=s}function c(t,n){o(f=t,n),l=y,h=g,p=m,d=x,v=b,w.point=o}function s(){e(y,g,_,m,x,b,l,h,f,p,d,v,pg,n),w.lineEnd=u,u()}var f,l,h,p,d,v,_,y,g,m,x,b,w={point:r,lineStart:i,lineEnd:u,polygonStart:function(){n.polygonStart(),w.lineStart=a},polygonEnd:function(){n.polygonEnd(),w.lineStart=i}};return w}}function eo(t){return ro(function(){return t})()}function ro(t){function n(t){return t=f(t[0]*z_,t[1]*z_),[t[0]*_+a,c-t[1]*_]}function e(t){return(t=f.invert((t[0]-a)/_,(c-t[1])/_))&&[t[0]*C_,t[1]*C_]}function r(t,n){return t=u(t,n),[t[0]*_+a,c-t[1]*_]}function i(){f=ry(s=ri(b,w,M),u);var t=u(m,x);return a=y-t[0]*_,c=g+t[1]*_,o()}function o(){return d=v=null,n}var u,a,c,s,f,l,h,p,d,v,_=150,y=480,g=250,m=0,x=0,b=0,w=0,M=0,T=null,k=fg,N=null,S=Uy,E=.5,A=vg(r,E);return n.stream=function(t){return d&&v===t?d:d=_g(k(s,A(S(v=t))))},n.clipAngle=function(t){return arguments.length?(k=+t?lg(T=t*z_,6*z_):(T=null,fg),o()):T*C_},n.clipExtent=function(t){return arguments.length?(S=null==t?(N=l=h=p=null,Uy):li(N=+t[0][0],l=+t[0][1],h=+t[1][0],p=+t[1][1]),o()):null==N?null:[[N,l],[h,p]]},n.scale=function(t){return arguments.length?(_=+t,i()):_},n.translate=function(t){return arguments.length?(y=+t[0],g=+t[1],i()):[y,g]},n.center=function(t){return arguments.length?(m=t[0]%360*z_,x=t[1]%360*z_,i()):[m*C_,x*C_]},n.rotate=function(t){return arguments.length?(b=t[0]%360*z_,w=t[1]%360*z_,M=t.length>2?t[2]%360*z_:0,i()):[b*C_,w*C_,M*C_]},n.precision=function(t){return arguments.length?(A=vg(r,E=t*t),o()):B_(E)},n.fitExtent=function(t,e){return Qi(n,t,e)},n.fitSize=function(t,e){return Ki(n,t,e)},function(){return u=t.apply(this,arguments),n.invert=u.invert&&e,i()}}function io(t){var n=0,e=N_/3,r=ro(t),i=r(n,e);return i.parallels=function(t){return arguments.length?r(n=t[0]*z_,e=t[1]*z_):[n*C_,e*C_]},i}function oo(t){function n(t,n){return[t*e,I_(n)/e]}var e=q_(t);return n.invert=function(t,n){return[t/e,mr(n*e)]},n}function uo(t,n){function e(t,n){var e=B_(o-2*i*I_(n))/i;return[e*I_(t*=i),u-e*q_(t)]}var r=I_(t),i=(r+I_(n))/2;if(P_(i)<k_)return oo(t);var o=1+r*(2*i-r),u=B_(o)/i;return e.invert=function(t,n){var e=u-n;return[R_(t,P_(e))/i*Y_(e),mr((o-(t*t+e*e)*i*i)/(2*i))]},e}function ao(t){var n=t.length;return{point:function(e,r){for(var i=-1;++i<n;)t[i].point(e,r)},sphere:function(){for(var e=-1;++e<n;)t[e].sphere()},lineStart:function(){for(var e=-1;++e<n;)t[e].lineStart()},lineEnd:function(){for(var e=-1;++e<n;)t[e].lineEnd()},polygonStart:function(){for(var e=-1;++e<n;)t[e].polygonStart()},polygonEnd:function(){for(var e=-1;++e<n;)t[e].polygonEnd()}}}function co(t){return function(n,e){var r=q_(n),i=q_(e),o=t(r*i);return[o*i*I_(n),o*I_(e)]}}function so(t){return function(n,e){var r=B_(n*n+e*e),i=t(r),o=I_(i),u=q_(i);return[R_(n*o,r*u),mr(r&&e*o/r)]}}function fo(t,n){return[t,O_(H_((S_+n)/2))]}function lo(t){function n(){var n=N_*a(),u=o(vy(o.rotate()).invert([0,0]));return s(null==f?[[u[0]-n,u[1]-n],[u[0]+n,u[1]+n]]:t===fo?[[Math.max(u[0]-n,f),e],[Math.min(u[0]+n,r),i]]:[[f,Math.max(u[1]-n,e)],[r,Math.min(u[1]+n,i)]])}var e,r,i,o=eo(t),u=o.center,a=o.scale,c=o.translate,s=o.clipExtent,f=null;return o.scale=function(t){return arguments.length?(a(t),n()):a()},o.translate=function(t){return arguments.length?(c(t),n()):c()},o.center=function(t){return arguments.length?(u(t),n()):u()},o.clipExtent=function(t){return arguments.length?(null==t?f=e=r=i=null:(f=+t[0][0],e=+t[0][1],r=+t[1][0],i=+t[1][1]),n()):null==f?null:[[f,e],[r,i]]},n()}function ho(t){return H_((S_+t)/2)}function po(t,n){function e(t,n){o>0?n<-S_+k_&&(n=-S_+k_):n>S_-k_&&(n=S_-k_);var e=o/F_(ho(n),i);return[e*I_(i*t),o-e*q_(i*t)]}var r=q_(t),i=t===n?I_(t):O_(r/q_(n))/O_(ho(n)/ho(t)),o=r*F_(ho(t),i)/i;return i?(e.invert=function(t,n){var e=o-n,r=Y_(i)*B_(t*t+e*e);return[R_(t,P_(e))/i*Y_(e),2*L_(F_(o/r,1/i))-S_]},e):fo}function vo(t,n){return[t,n]}function _o(t,n){function e(t,n){var e=o-n,r=i*t;return[e*I_(r),o-e*q_(r)]}var r=q_(t),i=t===n?I_(t):(r-q_(n))/(n-t),o=r/i+t;return P_(i)<k_?vo:(e.invert=function(t,n){var e=o-n;return[R_(t,P_(e))/i*Y_(e),o-Y_(i)*B_(t*t+e*e)]},e)}function yo(t,n){var e=q_(n),r=q_(t)*e;return[e*I_(t)/r,I_(n)/r]}function go(t,n,e,r){return 1===t&&1===n&&0===e&&0===r?Uy:Gi({point:function(i,o){this.stream.point(i*t+e,o*n+r)}})}function mo(t,n){return[q_(n)*I_(t),I_(n)]}function xo(t,n){var e=q_(n),r=1+q_(t)*e;return[e*I_(t)/r,I_(n)/r]}function bo(t,n){return[O_(H_((S_+n)/2)),-t]}function wo(t,n){return t.parent===n.parent?1:2}function Mo(t){return t.reduce(To,0)/t.length}function To(t,n){return t+n.x}function ko(t){return 1+t.reduce(No,0)}function No(t,n){return Math.max(t,n.y)}function So(t){for(var n;n=t.children;)t=n[0];return t}function Eo(t){for(var n;n=t.children;)t=n[n.length-1];return t}function Ao(t){var n=0,e=t.children,r=e&&e.length;if(r)for(;--r>=0;)n+=e[r].value;else n=1;t.value=n}function Co(t,n){if(t===n)return t;var e=t.ancestors(),r=n.ancestors(),i=null;for(t=e.pop(),n=r.pop();t===n;)i=t,t=e.pop(),n=r.pop();return i}function zo(t,n){var e,r,i,o,u,a=new Uo(t),c=+t.value&&(a.value=t.value),s=[a];for(null==n&&(n=Lo);e=s.pop();)if(c&&(e.value=+e.data.value),(i=n(e.data))&&(u=i.length))for(e.children=new Array(u),o=u-1;o>=0;--o)s.push(r=e.children[o]=new Uo(i[o])),r.parent=e,r.depth=e.depth+1;return a.eachBefore(qo)}function Po(){return zo(this).eachBefore(Ro)}function Lo(t){return t.children}function Ro(t){t.data=t.data.data}function qo(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function Uo(t){this.data=t,this.depth=this.height=0,this.parent=null}function Do(t){this._=t,this.next=null}function Oo(t,n){var e=n.x-t.x,r=n.y-t.y,i=t.r-n.r;return i*i+1e-6>e*e+r*r}function Fo(t,n){var e,r,i,o=null,u=t.head;switch(n.length){case 1:e=Io(n[0]);break;case 2:e=Yo(n[0],n[1]);break;case 3:e=Bo(n[0],n[1],n[2])}for(;u;)i=u._,r=u.next,e&&Oo(e,i)?o=u:(o?(t.tail=o,o.next=null):t.head=t.tail=null,n.push(i),e=Fo(t,n),n.pop(),t.head?(u.next=t.head,t.head=u):(u.next=null,t.head=t.tail=u),o=t.tail,o.next=r),u=r;return t.tail=o,e}function Io(t){return{x:t.x,y:t.y,r:t.r}}function Yo(t,n){var e=t.x,r=t.y,i=t.r,o=n.x,u=n.y,a=n.r,c=o-e,s=u-r,f=a-i,l=Math.sqrt(c*c+s*s);return{x:(e+o+c/l*f)/2,y:(r+u+s/l*f)/2,r:(l+i+a)/2}}function Bo(t,n,e){var r=t.x,i=t.y,o=t.r,u=n.x,a=n.y,c=n.r,s=e.x,f=e.y,l=e.r,h=2*(r-u),p=2*(i-a),d=2*(c-o),v=r*r+i*i-o*o-u*u-a*a+c*c,_=2*(r-s),y=2*(i-f),g=2*(l-o),m=r*r+i*i-o*o-s*s-f*f+l*l,x=_*p-h*y,b=(p*m-y*v)/x-r,w=(y*d-p*g)/x,M=(_*v-h*m)/x-i,T=(h*g-_*d)/x,k=w*w+T*T-1,N=2*(b*w+M*T+o),S=b*b+M*M-o*o,E=(-N-Math.sqrt(N*N-4*k*S))/(2*k);return{x:b+w*E+r,y:M+T*E+i,r:E}}function Ho(t,n,e){var r=t.x,i=t.y,o=n.r+e.r,u=t.r+e.r,a=n.x-r,c=n.y-i,s=a*a+c*c;if(s){var f=.5+((u*=u)-(o*=o))/(2*s),l=Math.sqrt(Math.max(0,2*o*(u+s)-(u-=s)*u-o*o))/(2*s);e.x=r+f*a+l*c,e.y=i+f*c-l*a}else e.x=r+u,e.y=i}function jo(t,n){var e=n.x-t.x,r=n.y-t.y,i=t.r+n.r;return i*i-1e-6>e*e+r*r}function Xo(t,n,e){var r=t._,i=t.next._,o=r.r+i.r,u=(r.x*i.r+i.x*r.r)/o-n,a=(r.y*i.r+i.y*r.r)/o-e;return u*u+a*a}function $o(t){this._=t,this.next=null,this.previous=null}function Vo(t){if(!(i=t.length))return 0;var n,e,r,i;if(n=t[0],n.x=0,n.y=0,!(i>1))return n.r;if(e=t[1],n.x=-e.r,e.x=n.r,e.y=0,!(i>2))return n.r+e.r;Ho(e,n,r=t[2]);var o,u,a,c,s,f,l,h=n.r*n.r,p=e.r*e.r,d=r.r*r.r,v=h+p+d,_=h*n.x+p*e.x+d*r.x,y=h*n.y+p*e.y+d*r.y;n=new $o(n),e=new $o(e),r=new $o(r),n.next=r.previous=e,e.next=n.previous=r,r.next=e.previous=n;t:for(a=3;a<i;++a){Ho(n._,e._,r=t[a]),r=new $o(r),c=e.next,s=n.previous,f=e._.r,l=n._.r;do{if(f<=l){if(jo(c._,r._)){e=c,n.next=e,e.previous=n,--a;continue t}f+=c._.r,c=c.next}else{if(jo(s._,r._)){n=s,n.next=e,e.previous=n,--a;continue t}l+=s._.r,s=s.previous}}while(c!==s.next);for(r.previous=n,r.next=e,n.next=e.previous=e=r,v+=d=r._.r*r._.r,_+=d*r._.x,y+=d*r._.y,h=Xo(n,o=_/v,u=y/v);(r=r.next)!==e;)(d=Xo(r,o,u))<h&&(n=r,h=d);e=n.next}for(n=[e._],r=e;(r=r.next)!==e;)n.push(r._);for(r=$g(n),a=0;a<i;++a)n=t[a],n.x-=r.x,n.y-=r.y;return r.r}function Wo(t){return null==t?null:Zo(t)}function Zo(t){if(\"function\"!=typeof t)throw new Error;return t}function Go(){return 0}function Jo(t){return Math.sqrt(t.value)}function Qo(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function Ko(t,n){return function(e){if(r=e.children){var r,i,o,u=r.length,a=t(e)*n||0;if(a)for(i=0;i<u;++i)r[i].r+=a;if(o=Vo(r),a)for(i=0;i<u;++i)r[i].r-=a;e.r=o+a}}}function tu(t){return function(n){var e=n.parent;n.r*=t,e&&(n.x=e.x+t*n.x,n.y=e.y+t*n.y)}}function nu(t){return t.id}function eu(t){return t.parentId}function ru(t,n){return t.parent===n.parent?1:2}function iu(t){var n=t.children;return n?n[0]:t.t}function ou(t){var n=t.children;return n?n[n.length-1]:t.t}function uu(t,n,e){var r=e/(n.i-t.i);n.c-=r,n.s+=e,t.c+=r,n.z+=e,n.m+=e}function au(t){for(var n,e=0,r=0,i=t.children,o=i.length;--o>=0;)n=i[o],n.z+=e,n.m+=e,e+=n.s+(r+=n.c)}function cu(t,n,e){return t.a.parent===n.parent?t.a:e}function su(t,n){this._=t,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=n}function fu(t){for(var n,e,r,i,o,u=new su(t,0),a=[u];n=a.pop();)if(r=n._.children)for(n.children=new Array(o=r.length),i=o-1;i>=0;--i)a.push(e=n.children[i]=new su(r[i],i)),e.parent=n;return(u.parent=new su(null,0)).children=[u],u}function lu(t,n,e,r,i,o){for(var u,a,c,s,f,l,h,p,d,v,_,y=[],g=n.children,m=0,x=0,b=g.length,w=n.value;m<b;){c=i-e,s=o-r;do{f=g[x++].value}while(!f&&x<b);for(l=h=f,v=Math.max(s/c,c/s)/(w*t),_=f*f*v,d=Math.max(h/_,_/l);x<b;++x){if(f+=a=g[x].value,a<l&&(l=a),a>h&&(h=a),_=f*f*v,(p=Math.max(h/_,_/l))>d){f-=a;break}d=p}y.push(u={value:f,dice:c<s,children:g.slice(m,x)}),u.dice?Jg(u,e,r,i,w?r+=s*f/w:o):im(u,e,r,w?e+=c*f/w:i,o),w-=f,m=x}return y}function hu(t,n){return t[0]-n[0]||t[1]-n[1]}function pu(t){for(var n=t.length,e=[0,1],r=2,i=2;i<n;++i){for(;r>1&&pm(t[e[r-2]],t[e[r-1]],t[i])<=0;)--r;e[r++]=i}return e.slice(0,r)}function du(t){this._size=t,this._call=this._error=null,this._tasks=[],this._data=[],this._waiting=this._active=this._ended=this._start=0}function vu(t){if(!t._start)try{_u(t)}catch(n){if(t._tasks[t._ended+t._active-1])gu(t,n);else if(!t._data)throw n}}function _u(t){for(;t._start=t._waiting&&t._active<t._size;){var n=t._ended+t._active,e=t._tasks[n],r=e.length-1,i=e[r];e[r]=yu(t,n),--t._waiting,++t._active,e=i.apply(null,e),t._tasks[n]&&(t._tasks[n]=e||gm)}}function yu(t,n){return function(e,r){t._tasks[n]&&(--t._active,++t._ended,t._tasks[n]=null,null==t._error&&(null!=e?gu(t,e):(t._data[n]=r,t._waiting?vu(t):mu(t))))}}function gu(t,n){var e,r=t._tasks.length;for(t._error=n,t._data=void 0,t._waiting=NaN;--r>=0;)if((e=t._tasks[r])&&(t._tasks[r]=null,e.abort))try{e.abort()}catch(n){}t._active=NaN,mu(t)}function mu(t){if(!t._active&&t._call){var n=t._data;t._data=void 0,t._call(t._error,n)}}function xu(t){if(null==t)t=1/0;else if(!((t=+t)>=1))throw new Error(\"invalid concurrency\");return new du(t)}function bu(t){return function(n,e){t(null==n?e:null)}}function wu(t){var n=t.responseType;return n&&\"text\"!==n?t.response:t.responseText}function Mu(t,n){return function(e){return t(e.responseText,n)}}function Tu(t){function n(n){var o=n+\"\",u=e.get(o);if(!u){if(i!==Om)return i;e.set(o,u=r.push(n))}return t[(u-1)%t.length]}var e=He(),r=[],i=Om;return t=null==t?[]:Dm.call(t),n.domain=function(t){if(!arguments.length)return r.slice();r=[],e=He();for(var i,o,u=-1,a=t.length;++u<a;)e.has(o=(i=t[u])+\"\")||e.set(o,r.push(i));return n},n.range=function(e){return arguments.length?(t=Dm.call(e),n):t.slice()},n.unknown=function(t){return arguments.length?(i=t,n):i},n.copy=function(){return Tu().domain(r).range(t).unknown(i)},n}function ku(){function t(){var t=i().length,r=u[1]<u[0],l=u[r-0],h=u[1-r];n=(h-l)/Math.max(1,t-c+2*s),a&&(n=Math.floor(n)),l+=(h-l-n*(t-c))*f,e=n*(1-c),a&&(l=Math.round(l),e=Math.round(e));var p=cf(t).map(function(t){return l+n*t});return o(r?p.reverse():p)}var n,e,r=Tu().unknown(void 0),i=r.domain,o=r.range,u=[0,1],a=!1,c=0,s=0,f=.5;return delete r.unknown,r.domain=function(n){return arguments.length?(i(n),t()):i()},r.range=function(n){return arguments.length?(u=[+n[0],+n[1]],t()):u.slice()},r.rangeRound=function(n){return u=[+n[0],+n[1]],a=!0,t()},r.bandwidth=function(){return e},r.step=function(){return n},r.round=function(n){return arguments.length?(a=!!n,t()):a},r.padding=function(n){return arguments.length?(c=s=Math.max(0,Math.min(1,n)),t()):c},r.paddingInner=function(n){return arguments.length?(c=Math.max(0,Math.min(1,n)),t()):c},r.paddingOuter=function(n){return arguments.length?(s=Math.max(0,Math.min(1,n)),t()):s},r.align=function(n){return arguments.length?(f=Math.max(0,Math.min(1,n)),t()):f},r.copy=function(){return ku().domain(i()).range(u).round(a).paddingInner(c).paddingOuter(s).align(f)},t()}function Nu(t){var n=t.copy;return t.padding=t.paddingOuter,delete t.paddingInner,delete t.paddingOuter,t.copy=function(){return Nu(n())},t}function Su(){return Nu(ku().paddingInner(1))}function Eu(t,n){return(n-=t=+t)?function(e){return(e-t)/n}:Fm(n)}function Au(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=n?0:t>=e?1:r(t)}}}function Cu(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=0?n:t>=1?e:r(t)}}}function zu(t,n,e,r){var i=t[0],o=t[1],u=n[0],a=n[1];return o<i?(i=e(o,i),u=r(a,u)):(i=e(i,o),u=r(u,a)),function(t){return u(i(t))}}function Pu(t,n,e,r){var i=Math.min(t.length,n.length)-1,o=new Array(i),u=new Array(i),a=-1;for(t[i]<t[0]&&(t=t.slice().reverse(),n=n.slice().reverse());++a<i;)o[a]=e(t[a],t[a+1]),u[a]=r(n[a],n[a+1]);return function(n){var e=Vs(t,n,1,i)-1;return u[e](o[e](n))}}function Lu(t,n){return n.domain(t.domain()).range(t.range()).interpolate(t.interpolate()).clamp(t.clamp())}function Ru(t,n){function e(){return i=Math.min(a.length,c.length)>2?Pu:zu,o=u=null,r}function r(n){return(o||(o=i(a,c,f?Au(t):t,s)))(+n)}var i,o,u,a=Ym,c=Ym,s=qh,f=!1;return r.invert=function(t){return(u||(u=i(c,a,Eu,f?Cu(n):n)))(+t)},r.domain=function(t){return arguments.length?(a=Um.call(t,Im),e()):a.slice()},r.range=function(t){return arguments.length?(c=Dm.call(t),e()):c.slice()},r.rangeRound=function(t){return c=Dm.call(t),s=Uh,e()},r.clamp=function(t){return arguments.length?(f=!!t,e()):f},r.interpolate=function(t){return arguments.length?(s=t,e()):s},e()}function qu(t){var n=t.domain;return t.ticks=function(t){var e=n();return hf(e[0],e[e.length-1],null==t?10:t)},t.tickFormat=function(t,e){return Bm(n(),t,e)},t.nice=function(e){null==e&&(e=10);var i,o=n(),u=0,a=o.length-1,c=o[u],s=o[a];return s<c&&(i=c,c=s,s=i,i=u,u=a,a=i),i=r(c,s,e),i>0?(c=Math.floor(c/i)*i,s=Math.ceil(s/i)*i,i=r(c,s,e)):i<0&&(c=Math.ceil(c*i)/i,s=Math.floor(s*i)/i,i=r(c,s,e)),i>0?(o[u]=Math.floor(c/i)*i,o[a]=Math.ceil(s/i)*i,n(o)):i<0&&(o[u]=Math.ceil(c*i)/i,o[a]=Math.floor(s*i)/i,n(o)),t},t}function Uu(){var t=Ru(Eu,Ch);return t.copy=function(){return Lu(t,Uu())},qu(t)}function Du(){function t(t){return+t}var n=[0,1];return t.invert=t,t.domain=t.range=function(e){return arguments.length?(n=Um.call(e,Im),t):n.slice()},t.copy=function(){return Du().domain(n)},qu(t)}function Ou(t,n){return(n=Math.log(n/t))?function(e){return Math.log(e/t)/n}:Fm(n)}function Fu(t,n){return t<0?function(e){return-Math.pow(-n,e)*Math.pow(-t,1-e)}:function(e){return Math.pow(n,e)*Math.pow(t,1-e)}}function Iu(t){return isFinite(t)?+(\"1e\"+t):t<0?0:t}function Yu(t){return 10===t?Iu:t===Math.E?Math.exp:function(n){return Math.pow(t,n)}}function Bu(t){return t===Math.E?Math.log:10===t&&Math.log10||2===t&&Math.log2||(t=Math.log(t),function(n){return Math.log(n)/t})}function Hu(t){return function(n){return-t(-n)}}function ju(){function n(){return o=Bu(i),u=Yu(i),r()[0]<0&&(o=Hu(o),u=Hu(u)),e}var e=Ru(Ou,Fu).domain([1,10]),r=e.domain,i=10,o=Bu(10),u=Yu(10);return e.base=function(t){return arguments.length?(i=+t,n()):i},e.domain=function(t){return arguments.length?(r(t),n()):r()},e.ticks=function(t){var n,e=r(),a=e[0],c=e[e.length-1];(n=c<a)&&(h=a,a=c,c=h);var s,f,l,h=o(a),p=o(c),d=null==t?10:+t,v=[];if(!(i%1)&&p-h<d){if(h=Math.round(h)-1,p=Math.round(p)+1,a>0){for(;h<p;++h)for(f=1,s=u(h);f<i;++f)if(!((l=s*f)<a)){if(l>c)break;v.push(l)}}else for(;h<p;++h)for(f=i-1,s=u(h);f>=1;--f)if(!((l=s*f)<a)){if(l>c)break;v.push(l)}}else v=hf(h,p,Math.min(p-h,d)).map(u);return n?v.reverse():v},e.tickFormat=function(n,r){if(null==r&&(r=10===i?\".0e\":\",\"),\"function\"!=typeof r&&(r=t.format(r)),n===1/0)return r;null==n&&(n=10);var a=Math.max(1,i*n/e.ticks().length);return function(t){var n=t/u(Math.round(o(t)));return n*i<i-.5&&(n*=i),n<=a?r(t):\"\"}},e.nice=function(){return r(Hm(r(),{floor:function(t){return u(Math.floor(o(t)))},ceil:function(t){return u(Math.ceil(o(t)))}}))},e.copy=function(){return Lu(e,ju().base(i))},e}function Xu(t,n){return t<0?-Math.pow(-t,n):Math.pow(t,n)}function $u(){function t(t,n){return(n=Xu(n,e)-(t=Xu(t,e)))?function(r){return(Xu(r,e)-t)/n}:Fm(n)}function n(t,n){return n=Xu(n,e)-(t=Xu(t,e)),function(r){return Xu(t+n*r,1/e)}}var e=1,r=Ru(t,n),i=r.domain;return r.exponent=function(t){return arguments.length?(e=+t,i(i())):e},r.copy=function(){return Lu(r,$u().exponent(e))},qu(r)}function Vu(){return $u().exponent(.5)}function Wu(){function t(){var t=0,o=Math.max(1,r.length);for(i=new Array(o-1);++t<o;)i[t-1]=vf(e,t/o);return n}function n(t){if(!isNaN(t=+t))return r[Vs(i,t)]}var e=[],r=[],i=[];return n.invertExtent=function(t){var n=r.indexOf(t);return n<0?[NaN,NaN]:[n>0?i[n-1]:e[0],n<i.length?i[n]:e[e.length-1]]},n.domain=function(n){if(!arguments.length)return e.slice();e=[];for(var r,i=0,o=n.length;i<o;++i)null==(r=n[i])||isNaN(r=+r)||e.push(r);return e.sort(js),t()},n.range=function(n){return arguments.length?(r=Dm.call(n),t()):r.slice()},n.quantiles=function(){return i.slice()},n.copy=function(){return Wu().domain(e).range(r)},n}function Zu(){function t(t){if(t<=t)return u[Vs(o,t,0,i)]}function n(){var n=-1;for(o=new Array(i);++n<i;)o[n]=((n+1)*r-(n-i)*e)/(i+1);return t}var e=0,r=1,i=1,o=[.5],u=[0,1];return t.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],n()):[e,r]},t.range=function(t){return arguments.length?(i=(u=Dm.call(t)).length-1,n()):u.slice()},t.invertExtent=function(t){var n=u.indexOf(t);return n<0?[NaN,NaN]:n<1?[e,o[0]]:n>=i?[o[i-1],r]:[o[n-1],o[n]]},t.copy=function(){return Zu().domain([e,r]).range(u)},qu(t)}function Gu(){function t(t){if(t<=t)return e[Vs(n,t,0,r)]}var n=[.5],e=[0,1],r=1;return t.domain=function(i){return arguments.length?(n=Dm.call(i),r=Math.min(n.length,e.length-1),t):n.slice()},t.range=function(i){return arguments.length?(e=Dm.call(i),r=Math.min(n.length,e.length-1),t):e.slice()},t.invertExtent=function(t){var r=e.indexOf(t);return[n[r-1],n[r]]},t.copy=function(){return Gu().domain(n).range(e)},t}function Ju(t,n,e,r){function i(n){return t(n=new Date(+n)),n}return i.floor=i,i.ceil=function(e){return t(e=new Date(e-1)),n(e,1),t(e),e},i.round=function(t){var n=i(t),e=i.ceil(t);return t-n<e-t?n:e},i.offset=function(t,e){return n(t=new Date(+t),null==e?1:Math.floor(e)),t},i.range=function(e,r,o){var u=[];if(e=i.ceil(e),o=null==o?1:Math.floor(o),!(e<r&&o>0))return u;do{u.push(new Date(+e))}while(n(e,o),t(e),e<r);return u},i.filter=function(e){return Ju(function(n){if(n>=n)for(;t(n),!e(n);)n.setTime(n-1)},function(t,r){if(t>=t)for(;--r>=0;)for(;n(t,1),!e(t););})},e&&(i.count=function(n,r){return jm.setTime(+n),Xm.setTime(+r),t(jm),t(Xm),Math.floor(e(jm,Xm))},i.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?i.filter(r?function(n){return r(n)%t==0}:function(n){return i.count(0,n)%t==0}):i:null}),i}function Qu(t){return Ju(function(n){n.setDate(n.getDate()-(n.getDay()+7-t)%7),n.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+7*n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Wm)/Zm})}function Ku(t){return Ju(function(n){n.setUTCDate(n.getUTCDate()-(n.getUTCDay()+7-t)%7),n.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+7*n)},function(t,n){return(n-t)/Zm})}function ta(t){if(0<=t.y&&t.y<100){var n=new Date(-1,t.m,t.d,t.H,t.M,t.S,t.L);return n.setFullYear(t.y),n}return new Date(t.y,t.m,t.d,t.H,t.M,t.S,t.L)}function na(t){if(0<=t.y&&t.y<100){var n=new Date(Date.UTC(-1,t.m,t.d,t.H,t.M,t.S,t.L));return n.setUTCFullYear(t.y),n}return new Date(Date.UTC(t.y,t.m,t.d,t.H,t.M,t.S,t.L))}function ea(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function ra(t){function n(t,n){return function(e){var r,i,o,u=[],a=-1,c=0,s=t.length;for(e instanceof Date||(e=new Date(+e));++a<s;)37===t.charCodeAt(a)&&(u.push(t.slice(c,a)),null!=(i=Vx[r=t.charAt(++a)])?r=t.charAt(++a):i=\"e\"===r?\" \":\"0\",(o=n[r])&&(r=o(e,i)),\nu.push(r),c=a+1);return u.push(t.slice(c,a)),u.join(\"\")}}function e(t,n){return function(e){var i=ea(1900);if(r(i,t,e+=\"\",0)!=e.length)return null;if(\"p\"in i&&(i.H=i.H%12+12*i.p),\"W\"in i||\"U\"in i){\"w\"in i||(i.w=\"W\"in i?1:0);var o=\"Z\"in i?na(ea(i.y)).getUTCDay():n(ea(i.y)).getDay();i.m=0,i.d=\"W\"in i?(i.w+6)%7+7*i.W-(o+5)%7:i.w+7*i.U-(o+6)%7}return\"Z\"in i?(i.H+=i.Z/100|0,i.M+=i.Z%100,na(i)):n(i)}}function r(t,n,e,r){for(var i,o,u=0,a=n.length,c=e.length;u<a;){if(r>=c)return-1;if(37===(i=n.charCodeAt(u++))){if(i=n.charAt(u++),!(o=B[i in Vx?n.charAt(u++):i])||(r=o(t,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}function i(t,n,e){var r=C.exec(n.slice(e));return r?(t.p=z[r[0].toLowerCase()],e+r[0].length):-1}function o(t,n,e){var r=R.exec(n.slice(e));return r?(t.w=q[r[0].toLowerCase()],e+r[0].length):-1}function u(t,n,e){var r=P.exec(n.slice(e));return r?(t.w=L[r[0].toLowerCase()],e+r[0].length):-1}function a(t,n,e){var r=O.exec(n.slice(e));return r?(t.m=F[r[0].toLowerCase()],e+r[0].length):-1}function c(t,n,e){var r=U.exec(n.slice(e));return r?(t.m=D[r[0].toLowerCase()],e+r[0].length):-1}function s(t,n,e){return r(t,w,n,e)}function f(t,n,e){return r(t,M,n,e)}function l(t,n,e){return r(t,T,n,e)}function h(t){return S[t.getDay()]}function p(t){return N[t.getDay()]}function d(t){return A[t.getMonth()]}function v(t){return E[t.getMonth()]}function _(t){return k[+(t.getHours()>=12)]}function y(t){return S[t.getUTCDay()]}function g(t){return N[t.getUTCDay()]}function m(t){return A[t.getUTCMonth()]}function x(t){return E[t.getUTCMonth()]}function b(t){return k[+(t.getUTCHours()>=12)]}var w=t.dateTime,M=t.date,T=t.time,k=t.periods,N=t.days,S=t.shortDays,E=t.months,A=t.shortMonths,C=ua(k),z=aa(k),P=ua(N),L=aa(N),R=ua(S),q=aa(S),U=ua(E),D=aa(E),O=ua(A),F=aa(A),I={a:h,A:p,b:d,B:v,c:null,d:wa,e:wa,H:Ma,I:Ta,j:ka,L:Na,m:Sa,M:Ea,p:_,S:Aa,U:Ca,w:za,W:Pa,x:null,X:null,y:La,Y:Ra,Z:qa,\"%\":Ga},Y={a:y,A:g,b:m,B:x,c:null,d:Ua,e:Ua,H:Da,I:Oa,j:Fa,L:Ia,m:Ya,M:Ba,p:b,S:Ha,U:ja,w:Xa,W:$a,x:null,X:null,y:Va,Y:Wa,Z:Za,\"%\":Ga},B={a:o,A:u,b:a,B:c,c:s,d:va,e:va,H:ya,I:ya,j:_a,L:xa,m:da,M:ga,p:i,S:ma,U:sa,w:ca,W:fa,x:f,X:l,y:ha,Y:la,Z:pa,\"%\":ba};return I.x=n(M,I),I.X=n(T,I),I.c=n(w,I),Y.x=n(M,Y),Y.X=n(T,Y),Y.c=n(w,Y),{format:function(t){var e=n(t+=\"\",I);return e.toString=function(){return t},e},parse:function(t){var n=e(t+=\"\",ta);return n.toString=function(){return t},n},utcFormat:function(t){var e=n(t+=\"\",Y);return e.toString=function(){return t},e},utcParse:function(t){var n=e(t,na);return n.toString=function(){return t},n}}}function ia(t,n,e){var r=t<0?\"-\":\"\",i=(r?-t:t)+\"\",o=i.length;return r+(o<e?new Array(e-o+1).join(n)+i:i)}function oa(t){return t.replace(Gx,\"\\\\$&\")}function ua(t){return new RegExp(\"^(?:\"+t.map(oa).join(\"|\")+\")\",\"i\")}function aa(t){for(var n={},e=-1,r=t.length;++e<r;)n[t[e].toLowerCase()]=e;return n}function ca(t,n,e){var r=Wx.exec(n.slice(e,e+1));return r?(t.w=+r[0],e+r[0].length):-1}function sa(t,n,e){var r=Wx.exec(n.slice(e));return r?(t.U=+r[0],e+r[0].length):-1}function fa(t,n,e){var r=Wx.exec(n.slice(e));return r?(t.W=+r[0],e+r[0].length):-1}function la(t,n,e){var r=Wx.exec(n.slice(e,e+4));return r?(t.y=+r[0],e+r[0].length):-1}function ha(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.y=+r[0]+(+r[0]>68?1900:2e3),e+r[0].length):-1}function pa(t,n,e){var r=/^(Z)|([+-]\\d\\d)(?:\\:?(\\d\\d))?/.exec(n.slice(e,e+6));return r?(t.Z=r[1]?0:-(r[2]+(r[3]||\"00\")),e+r[0].length):-1}function da(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.m=r[0]-1,e+r[0].length):-1}function va(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.d=+r[0],e+r[0].length):-1}function _a(t,n,e){var r=Wx.exec(n.slice(e,e+3));return r?(t.m=0,t.d=+r[0],e+r[0].length):-1}function ya(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.H=+r[0],e+r[0].length):-1}function ga(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.M=+r[0],e+r[0].length):-1}function ma(t,n,e){var r=Wx.exec(n.slice(e,e+2));return r?(t.S=+r[0],e+r[0].length):-1}function xa(t,n,e){var r=Wx.exec(n.slice(e,e+3));return r?(t.L=+r[0],e+r[0].length):-1}function ba(t,n,e){var r=Zx.exec(n.slice(e,e+1));return r?e+r[0].length:-1}function wa(t,n){return ia(t.getDate(),n,2)}function Ma(t,n){return ia(t.getHours(),n,2)}function Ta(t,n){return ia(t.getHours()%12||12,n,2)}function ka(t,n){return ia(1+ex.count(xx(t),t),n,3)}function Na(t,n){return ia(t.getMilliseconds(),n,3)}function Sa(t,n){return ia(t.getMonth()+1,n,2)}function Ea(t,n){return ia(t.getMinutes(),n,2)}function Aa(t,n){return ia(t.getSeconds(),n,2)}function Ca(t,n){return ia(ix.count(xx(t),t),n,2)}function za(t){return t.getDay()}function Pa(t,n){return ia(ox.count(xx(t),t),n,2)}function La(t,n){return ia(t.getFullYear()%100,n,2)}function Ra(t,n){return ia(t.getFullYear()%1e4,n,4)}function qa(t){var n=t.getTimezoneOffset();return(n>0?\"-\":(n*=-1,\"+\"))+ia(n/60|0,\"0\",2)+ia(n%60,\"0\",2)}function Ua(t,n){return ia(t.getUTCDate(),n,2)}function Da(t,n){return ia(t.getUTCHours(),n,2)}function Oa(t,n){return ia(t.getUTCHours()%12||12,n,2)}function Fa(t,n){return ia(1+Nx.count(jx(t),t),n,3)}function Ia(t,n){return ia(t.getUTCMilliseconds(),n,3)}function Ya(t,n){return ia(t.getUTCMonth()+1,n,2)}function Ba(t,n){return ia(t.getUTCMinutes(),n,2)}function Ha(t,n){return ia(t.getUTCSeconds(),n,2)}function ja(t,n){return ia(Ex.count(jx(t),t),n,2)}function Xa(t){return t.getUTCDay()}function $a(t,n){return ia(Ax.count(jx(t),t),n,2)}function Va(t,n){return ia(t.getUTCFullYear()%100,n,2)}function Wa(t,n){return ia(t.getUTCFullYear()%1e4,n,4)}function Za(){return\"+0000\"}function Ga(){return\"%\"}function Ja(n){return Xx=ra(n),t.timeFormat=Xx.format,t.timeParse=Xx.parse,t.utcFormat=Xx.utcFormat,t.utcParse=Xx.utcParse,Xx}function Qa(t){return t.toISOString()}function Ka(t){var n=new Date(t);return isNaN(n)?null:n}function tc(t){return new Date(t)}function nc(t){return t instanceof Date?+t:+new Date(+t)}function ec(t,n,e,r,o,u,a,c,s){function f(i){return(a(i)<i?v:u(i)<i?_:o(i)<i?y:r(i)<i?g:n(i)<i?e(i)<i?m:x:t(i)<i?b:w)(i)}function l(n,e,r,o){if(null==n&&(n=10),\"number\"==typeof n){var u=Math.abs(r-e)/n,a=Xs(function(t){return t[2]}).right(M,u);a===M.length?(o=i(e/ob,r/ob,n),n=t):a?(a=M[u/M[a-1][2]<M[a][2]/u?a-1:a],o=a[1],n=a[0]):(o=i(e,r,n),n=c)}return null==o?n:n.every(o)}var h=Ru(Eu,Ch),p=h.invert,d=h.domain,v=s(\".%L\"),_=s(\":%S\"),y=s(\"%I:%M\"),g=s(\"%I %p\"),m=s(\"%a %d\"),x=s(\"%b %d\"),b=s(\"%B\"),w=s(\"%Y\"),M=[[a,1,Kx],[a,5,5*Kx],[a,15,15*Kx],[a,30,30*Kx],[u,1,tb],[u,5,5*tb],[u,15,15*tb],[u,30,30*tb],[o,1,nb],[o,3,3*nb],[o,6,6*nb],[o,12,12*nb],[r,1,eb],[r,2,2*eb],[e,1,rb],[n,1,ib],[n,3,3*ib],[t,1,ob]];return h.invert=function(t){return new Date(p(t))},h.domain=function(t){return arguments.length?d(Um.call(t,nc)):d().map(tc)},h.ticks=function(t,n){var e,r=d(),i=r[0],o=r[r.length-1],u=o<i;return u&&(e=i,i=o,o=e),e=l(t,i,o,n),e=e?e.range(i,o+1):[],u?e.reverse():e},h.tickFormat=function(t,n){return null==n?f:s(n)},h.nice=function(t,n){var e=d();return(t=l(t,e[0],e[e.length-1],n))?d(Hm(e,t)):h},h.copy=function(){return Lu(h,ec(t,n,e,r,o,u,a,c,s))},h}function rc(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}}function ic(t){function n(n){var o=(n-e)/(r-e);return t(i?Math.max(0,Math.min(1,o)):o)}var e=0,r=1,i=!1;return n.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],n):[e,r]},n.clamp=function(t){return arguments.length?(i=!!t,n):i},n.interpolator=function(e){return arguments.length?(t=e,n):t},n.copy=function(){return ic(t).domain([e,r]).clamp(i)},qu(n)}function oc(t){return t>1?0:t<-1?zb:Math.acos(t)}function uc(t){return t>=1?Pb:t<=-1?-Pb:Math.asin(t)}function ac(t){return t.innerRadius}function cc(t){return t.outerRadius}function sc(t){return t.startAngle}function fc(t){return t.endAngle}function lc(t){return t&&t.padAngle}function hc(t,n,e,r,i,o,u,a){var c=e-t,s=r-n,f=u-i,l=a-o,h=(f*(n-o)-l*(t-i))/(l*c-f*s);return[t+h*c,n+h*s]}function pc(t,n,e,r,i,o,u){var a=t-e,c=n-r,s=(u?o:-o)/Ab(a*a+c*c),f=s*c,l=-s*a,h=t+f,p=n+l,d=e+f,v=r+l,_=(h+d)/2,y=(p+v)/2,g=d-h,m=v-p,x=g*g+m*m,b=i-o,w=h*v-d*p,M=(m<0?-1:1)*Ab(Nb(0,b*b*x-w*w)),T=(w*m-g*M)/x,k=(-w*g-m*M)/x,N=(w*m+g*M)/x,S=(-w*g+m*M)/x,E=T-_,A=k-y,C=N-_,z=S-y;return E*E+A*A>C*C+z*z&&(T=N,k=S),{cx:T,cy:k,x01:-f,y01:-l,x11:T*(i/b-1),y11:k*(i/b-1)}}function dc(t){this._context=t}function vc(t){return t[0]}function _c(t){return t[1]}function yc(t){this._curve=t}function gc(t){function n(n){return new yc(t(n))}return n._curve=t,n}function mc(t){var n=t.curve;return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t.curve=function(t){return arguments.length?n(gc(t)):n()._curve},t}function xc(t){return t.source}function bc(t){return t.target}function wc(t){function n(){var n,a=jb.call(arguments),c=e.apply(this,a),s=r.apply(this,a);if(u||(u=n=Ue()),t(u,+i.apply(this,(a[0]=c,a)),+o.apply(this,a),+i.apply(this,(a[0]=s,a)),+o.apply(this,a)),n)return u=null,n+\"\"||null}var e=xc,r=bc,i=vc,o=_c,u=null;return n.source=function(t){return arguments.length?(e=t,n):e},n.target=function(t){return arguments.length?(r=t,n):r},n.x=function(t){return arguments.length?(i=\"function\"==typeof t?t:wb(+t),n):i},n.y=function(t){return arguments.length?(o=\"function\"==typeof t?t:wb(+t),n):o},n.context=function(t){return arguments.length?(u=null==t?null:t,n):u},n}function Mc(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n=(n+r)/2,e,n,i,r,i)}function Tc(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n,e=(e+i)/2,r,e,r,i)}function kc(t,n,e,r,i){var o=Xb(n,e),u=Xb(n,e=(e+i)/2),a=Xb(r,e),c=Xb(r,i);t.moveTo(o[0],o[1]),t.bezierCurveTo(u[0],u[1],a[0],a[1],c[0],c[1])}function Nc(){return wc(Mc)}function Sc(){return wc(Tc)}function Ec(){var t=wc(kc);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t}function Ac(t,n,e){t._context.bezierCurveTo((2*t._x0+t._x1)/3,(2*t._y0+t._y1)/3,(t._x0+2*t._x1)/3,(t._y0+2*t._y1)/3,(t._x0+4*t._x1+n)/6,(t._y0+4*t._y1+e)/6)}function Cc(t){this._context=t}function zc(t){this._context=t}function Pc(t){this._context=t}function Lc(t,n){this._basis=new Cc(t),this._beta=n}function Rc(t,n,e){t._context.bezierCurveTo(t._x1+t._k*(t._x2-t._x0),t._y1+t._k*(t._y2-t._y0),t._x2+t._k*(t._x1-n),t._y2+t._k*(t._y1-e),t._x2,t._y2)}function qc(t,n){this._context=t,this._k=(1-n)/6}function Uc(t,n){this._context=t,this._k=(1-n)/6}function Dc(t,n){this._context=t,this._k=(1-n)/6}function Oc(t,n,e){var r=t._x1,i=t._y1,o=t._x2,u=t._y2;if(t._l01_a>Cb){var a=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,c=3*t._l01_a*(t._l01_a+t._l12_a);r=(r*a-t._x0*t._l12_2a+t._x2*t._l01_2a)/c,i=(i*a-t._y0*t._l12_2a+t._y2*t._l01_2a)/c}if(t._l23_a>Cb){var s=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,f=3*t._l23_a*(t._l23_a+t._l12_a);o=(o*s+t._x1*t._l23_2a-n*t._l12_2a)/f,u=(u*s+t._y1*t._l23_2a-e*t._l12_2a)/f}t._context.bezierCurveTo(r,i,o,u,t._x2,t._y2)}function Fc(t,n){this._context=t,this._alpha=n}function Ic(t,n){this._context=t,this._alpha=n}function Yc(t,n){this._context=t,this._alpha=n}function Bc(t){this._context=t}function Hc(t){return t<0?-1:1}function jc(t,n,e){var r=t._x1-t._x0,i=n-t._x1,o=(t._y1-t._y0)/(r||i<0&&-0),u=(e-t._y1)/(i||r<0&&-0),a=(o*i+u*r)/(r+i);return(Hc(o)+Hc(u))*Math.min(Math.abs(o),Math.abs(u),.5*Math.abs(a))||0}function Xc(t,n){var e=t._x1-t._x0;return e?(3*(t._y1-t._y0)/e-n)/2:n}function $c(t,n,e){var r=t._x0,i=t._y0,o=t._x1,u=t._y1,a=(o-r)/3;t._context.bezierCurveTo(r+a,i+a*n,o-a,u-a*e,o,u)}function Vc(t){this._context=t}function Wc(t){this._context=new Zc(t)}function Zc(t){this._context=t}function Gc(t){return new Vc(t)}function Jc(t){return new Wc(t)}function Qc(t){this._context=t}function Kc(t){var n,e,r=t.length-1,i=new Array(r),o=new Array(r),u=new Array(r);for(i[0]=0,o[0]=2,u[0]=t[0]+2*t[1],n=1;n<r-1;++n)i[n]=1,o[n]=4,u[n]=4*t[n]+2*t[n+1];for(i[r-1]=2,o[r-1]=7,u[r-1]=8*t[r-1]+t[r],n=1;n<r;++n)e=i[n]/o[n-1],o[n]-=e,u[n]-=e*u[n-1];for(i[r-1]=u[r-1]/o[r-1],n=r-2;n>=0;--n)i[n]=(u[n]-i[n+1])/o[n];for(o[r-1]=(t[r]+i[r-1])/2,n=0;n<r-1;++n)o[n]=2*t[n+1]-i[n+1];return[i,o]}function ts(t,n){this._context=t,this._t=n}function ns(t){return new ts(t,0)}function es(t){return new ts(t,1)}function rs(t,n){return t[n]}function is(t){for(var n,e=0,r=-1,i=t.length;++r<i;)(n=+t[r][1])&&(e+=n);return e}function os(t){return t[0]}function us(t){return t[1]}function as(){this._=null}function cs(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function ss(t,n){var e=n,r=n.R,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function fs(t,n){var e=n,r=n.L,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function ls(t){for(;t.L;)t=t.L;return t}function hs(t,n,e,r){var i=[null,null],o=Yw.push(i)-1;return i.left=t,i.right=n,e&&ds(i,t,n,e),r&&ds(i,n,t,r),Fw[t.index].halfedges.push(o),Fw[n.index].halfedges.push(o),i}function ps(t,n,e){var r=[n,e];return r.left=t,r}function ds(t,n,e,r){t[0]||t[1]?t.left===e?t[1]=r:t[0]=r:(t[0]=r,t.left=n,t.right=e)}function vs(t,n,e,r,i){var o,u=t[0],a=t[1],c=u[0],s=u[1],f=a[0],l=a[1],h=0,p=1,d=f-c,v=l-s;if(o=n-c,d||!(o>0)){if(o/=d,d<0){if(o<h)return;o<p&&(p=o)}else if(d>0){if(o>p)return;o>h&&(h=o)}if(o=r-c,d||!(o<0)){if(o/=d,d<0){if(o>p)return;o>h&&(h=o)}else if(d>0){if(o<h)return;o<p&&(p=o)}if(o=e-s,v||!(o>0)){if(o/=v,v<0){if(o<h)return;o<p&&(p=o)}else if(v>0){if(o>p)return;o>h&&(h=o)}if(o=i-s,v||!(o<0)){if(o/=v,v<0){if(o>p)return;o>h&&(h=o)}else if(v>0){if(o<h)return;o<p&&(p=o)}return!(h>0||p<1)||(h>0&&(t[0]=[c+h*d,s+h*v]),p<1&&(t[1]=[c+p*d,s+p*v]),!0)}}}}}function _s(t,n,e,r,i){var o=t[1];if(o)return!0;var u,a,c=t[0],s=t.left,f=t.right,l=s[0],h=s[1],p=f[0],d=f[1],v=(l+p)/2,_=(h+d)/2;if(d===h){if(v<n||v>=r)return;if(l>p){if(c){if(c[1]>=i)return}else c=[v,e];o=[v,i]}else{if(c){if(c[1]<e)return}else c=[v,i];o=[v,e]}}else if(u=(l-p)/(d-h),a=_-u*v,u<-1||u>1)if(l>p){if(c){if(c[1]>=i)return}else c=[(e-a)/u,e];o=[(i-a)/u,i]}else{if(c){if(c[1]<e)return}else c=[(i-a)/u,i];o=[(e-a)/u,e]}else if(h<d){if(c){if(c[0]>=r)return}else c=[n,u*n+a];o=[r,u*r+a]}else{if(c){if(c[0]<n)return}else c=[r,u*r+a];o=[n,u*n+a]}return t[0]=c,t[1]=o,!0}function ys(t,n,e,r){for(var i,o=Yw.length;o--;)_s(i=Yw[o],t,n,e,r)&&vs(i,t,n,e,r)&&(Math.abs(i[0][0]-i[1][0])>jw||Math.abs(i[0][1]-i[1][1])>jw)||delete Yw[o]}function gs(t){return Fw[t.index]={site:t,halfedges:[]}}function ms(t,n){var e=t.site,r=n.left,i=n.right;return e===i&&(i=r,r=e),i?Math.atan2(i[1]-r[1],i[0]-r[0]):(e===r?(r=n[1],i=n[0]):(r=n[0],i=n[1]),Math.atan2(r[0]-i[0],i[1]-r[1]))}function xs(t,n){return n[+(n.left!==t.site)]}function bs(t,n){return n[+(n.left===t.site)]}function ws(){for(var t,n,e,r,i=0,o=Fw.length;i<o;++i)if((t=Fw[i])&&(r=(n=t.halfedges).length)){var u=new Array(r),a=new Array(r);for(e=0;e<r;++e)u[e]=e,a[e]=ms(t,Yw[n[e]]);for(u.sort(function(t,n){return a[n]-a[t]}),e=0;e<r;++e)a[e]=n[u[e]];for(e=0;e<r;++e)n[e]=a[e]}}function Ms(t,n,e,r){var i,o,u,a,c,s,f,l,h,p,d,v,_=Fw.length,y=!0;for(i=0;i<_;++i)if(o=Fw[i]){for(u=o.site,c=o.halfedges,a=c.length;a--;)Yw[c[a]]||c.splice(a,1);for(a=0,s=c.length;a<s;)p=bs(o,Yw[c[a]]),d=p[0],v=p[1],f=xs(o,Yw[c[++a%s]]),l=f[0],h=f[1],(Math.abs(d-l)>jw||Math.abs(v-h)>jw)&&(c.splice(a,0,Yw.push(ps(u,p,Math.abs(d-t)<jw&&r-v>jw?[t,Math.abs(l-t)<jw?h:r]:Math.abs(v-r)<jw&&e-d>jw?[Math.abs(h-r)<jw?l:e,r]:Math.abs(d-e)<jw&&v-n>jw?[e,Math.abs(l-e)<jw?h:n]:Math.abs(v-n)<jw&&d-t>jw?[Math.abs(h-n)<jw?l:t,n]:null))-1),++s);s&&(y=!1)}if(y){var g,m,x,b=1/0;for(i=0,y=null;i<_;++i)(o=Fw[i])&&(u=o.site,g=u[0]-t,m=u[1]-n,(x=g*g+m*m)<b&&(b=x,y=o));if(y){var w=[t,n],M=[t,r],T=[e,r],k=[e,n];y.halfedges.push(Yw.push(ps(u=y.site,w,M))-1,Yw.push(ps(u,M,T))-1,Yw.push(ps(u,T,k))-1,Yw.push(ps(u,k,w))-1)}}for(i=0;i<_;++i)(o=Fw[i])&&(o.halfedges.length||delete Fw[i])}function Ts(){cs(this),this.x=this.y=this.arc=this.site=this.cy=null}function ks(t){var n=t.P,e=t.N;if(n&&e){var r=n.site,i=t.site,o=e.site;if(r!==o){var u=i[0],a=i[1],c=r[0]-u,s=r[1]-a,f=o[0]-u,l=o[1]-a,h=2*(c*l-s*f);if(!(h>=-Xw)){var p=c*c+s*s,d=f*f+l*l,v=(l*p-s*d)/h,_=(c*d-f*p)/h,y=Bw.pop()||new Ts;y.arc=t,y.site=i,y.x=v+u,y.y=(y.cy=_+a)+Math.sqrt(v*v+_*_),t.circle=y;for(var g=null,m=Iw._;m;)if(y.y<m.y||y.y===m.y&&y.x<=m.x){if(!m.L){g=m.P;break}m=m.L}else{if(!m.R){g=m;break}m=m.R}Iw.insert(g,y),g||(Dw=y)}}}}function Ns(t){var n=t.circle;n&&(n.P||(Dw=n.N),Iw.remove(n),Bw.push(n),cs(n),t.circle=null)}function Ss(){cs(this),this.edge=this.site=this.circle=null}function Es(t){var n=Hw.pop()||new Ss;return n.site=t,n}function As(t){Ns(t),Ow.remove(t),Hw.push(t),cs(t)}function Cs(t){var n=t.circle,e=n.x,r=n.cy,i=[e,r],o=t.P,u=t.N,a=[t];As(t);for(var c=o;c.circle&&Math.abs(e-c.circle.x)<jw&&Math.abs(r-c.circle.cy)<jw;)o=c.P,a.unshift(c),As(c),c=o;a.unshift(c),Ns(c);for(var s=u;s.circle&&Math.abs(e-s.circle.x)<jw&&Math.abs(r-s.circle.cy)<jw;)u=s.N,a.push(s),As(s),s=u;a.push(s),Ns(s);var f,l=a.length;for(f=1;f<l;++f)s=a[f],c=a[f-1],ds(s.edge,c.site,s.site,i);c=a[0],s=a[l-1],s.edge=hs(c.site,s.site,null,i),ks(c),ks(s)}function zs(t){for(var n,e,r,i,o=t[0],u=t[1],a=Ow._;a;)if((r=Ps(a,u)-o)>jw)a=a.L;else{if(!((i=o-Ls(a,u))>jw)){r>-jw?(n=a.P,e=a):i>-jw?(n=a,e=a.N):n=e=a;break}if(!a.R){n=a;break}a=a.R}gs(t);var c=Es(t);if(Ow.insert(n,c),n||e){if(n===e)return Ns(n),e=Es(n.site),Ow.insert(c,e),c.edge=e.edge=hs(n.site,c.site),ks(n),void ks(e);if(!e)return void(c.edge=hs(n.site,c.site));Ns(n),Ns(e);var s=n.site,f=s[0],l=s[1],h=t[0]-f,p=t[1]-l,d=e.site,v=d[0]-f,_=d[1]-l,y=2*(h*_-p*v),g=h*h+p*p,m=v*v+_*_,x=[(_*g-p*m)/y+f,(h*m-v*g)/y+l];ds(e.edge,s,d,x),c.edge=hs(s,t,null,x),e.edge=hs(t,d,null,x),ks(n),ks(e)}}function Ps(t,n){var e=t.site,r=e[0],i=e[1],o=i-n;if(!o)return r;var u=t.P;if(!u)return-1/0;e=u.site;var a=e[0],c=e[1],s=c-n;if(!s)return a;var f=a-r,l=1/o-1/s,h=f/s;return l?(-h+Math.sqrt(h*h-2*l*(f*f/(-2*s)-c+s/2+i-o/2)))/l+r:(r+a)/2}function Ls(t,n){var e=t.N;if(e)return Ps(e,n);var r=t.site;return r[1]===n?r[0]:1/0}function Rs(t,n,e){return(t[0]-e[0])*(n[1]-t[1])-(t[0]-n[0])*(e[1]-t[1])}function qs(t,n){return n[1]-t[1]||n[0]-t[0]}function Us(t,n){var e,r,i,o=t.sort(qs).pop();for(Yw=[],Fw=new Array(t.length),Ow=new as,Iw=new as;;)if(i=Dw,o&&(!i||o[1]<i.y||o[1]===i.y&&o[0]<i.x))o[0]===e&&o[1]===r||(zs(o),e=o[0],r=o[1]),o=t.pop();else{if(!i)break;Cs(i.arc)}if(ws(),n){var u=+n[0][0],a=+n[0][1],c=+n[1][0],s=+n[1][1];ys(u,a,c,s),Ms(u,a,c,s)}this.edges=Yw,this.cells=Fw,Ow=Iw=Yw=Fw=null}function Ds(t,n,e){this.target=t,this.type=n,this.transform=e}function Os(t,n,e){this.k=t,this.x=n,this.y=e}function Fs(t){return t.__zoom||Ww}function Is(){t.event.stopImmediatePropagation()}function Ys(){return!t.event.button}function Bs(){var t,n,e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e,t=e.width.baseVal.value,n=e.height.baseVal.value):(t=e.clientWidth,n=e.clientHeight),[[0,0],[t,n]]}function Hs(){return this.__zoom||Ww}var js=function(t,n){return t<n?-1:t>n?1:t>=n?0:NaN},Xs=function(t){return 1===t.length&&(t=n(t)),{left:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)<0?r=o+1:i=o}return r},right:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)>0?i=o:r=o+1}return r}}},$s=Xs(js),Vs=$s.right,Ws=$s.left,Zs=function(t,n){null==n&&(n=e);for(var r=0,i=t.length-1,o=t[0],u=new Array(i<0?0:i);r<i;)u[r]=n(o,o=t[++r]);return u},Gs=function(t,n,r){var i,o,u,a,c=t.length,s=n.length,f=new Array(c*s);for(null==r&&(r=e),i=u=0;i<c;++i)for(a=t[i],o=0;o<s;++o,++u)f[u]=r(a,n[o]);return f},Js=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},Qs=function(t){return null===t?NaN:+t},Ks=function(t,n){var e,r,i=t.length,o=0,u=-1,a=0,c=0;if(null==n)for(;++u<i;)isNaN(e=Qs(t[u]))||(r=e-a,a+=r/++o,c+=r*(e-a));else for(;++u<i;)isNaN(e=Qs(n(t[u],u,t)))||(r=e-a,a+=r/++o,c+=r*(e-a));if(o>1)return c/(o-1)},tf=function(t,n){var e=Ks(t,n);return e?Math.sqrt(e):e},nf=function(t,n){var e,r,i,o=t.length,u=-1;if(null==n){for(;++u<o;)if(null!=(e=t[u])&&e>=e)for(r=i=e;++u<o;)null!=(e=t[u])&&(r>e&&(r=e),i<e&&(i=e))}else for(;++u<o;)if(null!=(e=n(t[u],u,t))&&e>=e)for(r=i=e;++u<o;)null!=(e=n(t[u],u,t))&&(r>e&&(r=e),i<e&&(i=e));return[r,i]},ef=Array.prototype,rf=ef.slice,of=ef.map,uf=function(t){return function(){return t}},af=function(t){return t},cf=function(t,n,e){t=+t,n=+n,e=(i=arguments.length)<2?(n=t,t=0,1):i<3?1:+e;for(var r=-1,i=0|Math.max(0,Math.ceil((n-t)/e)),o=new Array(i);++r<i;)o[r]=t+r*e;return o},sf=Math.sqrt(50),ff=Math.sqrt(10),lf=Math.sqrt(2),hf=function(t,n,e){var i,o,u,a=n<t,c=-1;if(a&&(i=t,t=n,n=i),0===(u=r(t,n,e))||!isFinite(u))return[];if(u>0)for(t=Math.ceil(t/u),n=Math.floor(n/u),o=new Array(i=Math.ceil(n-t+1));++c<i;)o[c]=(t+c)*u;else for(t=Math.floor(t*u),n=Math.ceil(n*u),o=new Array(i=Math.ceil(t-n+1));++c<i;)o[c]=(t-c)/u;return a&&o.reverse(),o},pf=function(t){return Math.ceil(Math.log(t.length)/Math.LN2)+1},df=function(){function t(t){var o,u,a=t.length,c=new Array(a);for(o=0;o<a;++o)c[o]=n(t[o],o,t);var s=e(c),f=s[0],l=s[1],h=r(c,f,l);Array.isArray(h)||(h=i(f,l,h),h=cf(Math.ceil(f/h)*h,Math.floor(l/h)*h,h));for(var p=h.length;h[0]<=f;)h.shift(),--p;for(;h[p-1]>l;)h.pop(),--p;var d,v=new Array(p+1);for(o=0;o<=p;++o)d=v[o]=[],d.x0=o>0?h[o-1]:f,d.x1=o<p?h[o]:l;for(o=0;o<a;++o)u=c[o],f<=u&&u<=l&&v[Vs(h,u,0,p)].push(t[o]);return v}var n=af,e=nf,r=pf;return t.value=function(e){return arguments.length?(n=\"function\"==typeof e?e:uf(e),t):n},t.domain=function(n){return arguments.length?(e=\"function\"==typeof n?n:uf([n[0],n[1]]),t):e},t.thresholds=function(n){return arguments.length?(r=\"function\"==typeof n?n:uf(Array.isArray(n)?rf.call(n):n),t):r},t},vf=function(t,n,e){if(null==e&&(e=Qs),r=t.length){if((n=+n)<=0||r<2)return+e(t[0],0,t);if(n>=1)return+e(t[r-1],r-1,t);var r,i=(r-1)*n,o=Math.floor(i),u=+e(t[o],o,t);return u+(+e(t[o+1],o+1,t)-u)*(i-o)}},_f=function(t,n,e){return t=of.call(t,Qs).sort(js),Math.ceil((e-n)/(2*(vf(t,.75)-vf(t,.25))*Math.pow(t.length,-1/3)))},yf=function(t,n,e){return Math.ceil((e-n)/(3.5*tf(t)*Math.pow(t.length,-1/3)))},gf=function(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&e>r&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&e>r&&(r=e);return r},mf=function(t,n){var e,r=t.length,i=r,o=-1,u=0;if(null==n)for(;++o<r;)isNaN(e=Qs(t[o]))?--i:u+=e;else for(;++o<r;)isNaN(e=Qs(n(t[o],o,t)))?--i:u+=e;if(i)return u/i},xf=function(t,n){var e,r=t.length,i=-1,o=[];if(null==n)for(;++i<r;)isNaN(e=Qs(t[i]))||o.push(e);else for(;++i<r;)isNaN(e=Qs(n(t[i],i,t)))||o.push(e);return vf(o.sort(js),.5)},bf=function(t){for(var n,e,r,i=t.length,o=-1,u=0;++o<i;)u+=t[o].length;for(e=new Array(u);--i>=0;)for(r=t[i],n=r.length;--n>=0;)e[--u]=r[n];return e},wf=function(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&r>e&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&r>e&&(r=e);return r},Mf=function(t,n){for(var e=n.length,r=new Array(e);e--;)r[e]=t[n[e]];return r},Tf=function(t,n){if(e=t.length){var e,r,i=0,o=0,u=t[o];for(null==n&&(n=js);++i<e;)(n(r=t[i],u)<0||0!==n(u,u))&&(u=r,o=i);return 0===n(u,u)?o:void 0}},kf=function(t,n,e){for(var r,i,o=(null==e?t.length:e)-(n=null==n?0:+n);o;)i=Math.random()*o--|0,r=t[o+n],t[o+n]=t[i+n],t[i+n]=r;return t},Nf=function(t,n){var e,r=t.length,i=-1,o=0;if(null==n)for(;++i<r;)(e=+t[i])&&(o+=e);else for(;++i<r;)(e=+n(t[i],i,t))&&(o+=e);return o},Sf=function(t){if(!(i=t.length))return[];for(var n=-1,e=wf(t,o),r=new Array(e);++n<e;)for(var i,u=-1,a=r[n]=new Array(i);++u<i;)a[u]=t[u][n];return r},Ef=function(){return Sf(arguments)},Af=Array.prototype.slice,Cf=function(t){return t},zf=1,Pf=2,Lf=3,Rf=4,qf=1e-6,Uf={value:function(){}};_.prototype=v.prototype={constructor:_,on:function(t,n){var e,r=this._,i=y(t+\"\",r),o=-1,u=i.length;{if(!(arguments.length<2)){if(null!=n&&\"function\"!=typeof n)throw new Error(\"invalid callback: \"+n);for(;++o<u;)if(e=(t=i[o]).type)r[e]=m(r[e],t.name,n);else if(null==n)for(e in r)r[e]=m(r[e],t.name,null);return this}for(;++o<u;)if((e=(t=i[o]).type)&&(e=g(r[e],t.name)))return e}},copy:function(){var t={},n=this._;for(var e in n)t[e]=n[e].slice();return new _(t)},call:function(t,n){if((e=arguments.length-2)>0)for(var e,r,i=new Array(e),o=0;o<e;++o)i[o]=arguments[o+2];if(!this._.hasOwnProperty(t))throw new Error(\"unknown type: \"+t);for(r=this._[t],o=0,e=r.length;o<e;++o)r[o].value.apply(n,i)},apply:function(t,n,e){if(!this._.hasOwnProperty(t))throw new Error(\"unknown type: \"+t);for(var r=this._[t],i=0,o=r.length;i<o;++i)r[i].value.apply(n,e)}};var Df=\"http://www.w3.org/1999/xhtml\",Of={svg:\"http://www.w3.org/2000/svg\",xhtml:Df,xlink:\"http://www.w3.org/1999/xlink\",xml:\"http://www.w3.org/XML/1998/namespace\",xmlns:\"http://www.w3.org/2000/xmlns/\"},Ff=function(t){var n=t+=\"\",e=n.indexOf(\":\");return e>=0&&\"xmlns\"!==(n=t.slice(0,e))&&(t=t.slice(e+1)),Of.hasOwnProperty(n)?{space:Of[n],local:t}:t},If=function(t){var n=Ff(t);return(n.local?b:x)(n)},Yf=0;M.prototype=w.prototype={constructor:M,get:function(t){for(var n=this._;!(n in t);)if(!(t=t.parentNode))return;return t[n]},set:function(t,n){return t[this._]=n},remove:function(t){return this._ in t&&delete t[this._]},toString:function(){return this._}};var Bf=function(t){return function(){return this.matches(t)}};if(\"undefined\"!=typeof document){var Hf=document.documentElement;if(!Hf.matches){var jf=Hf.webkitMatchesSelector||Hf.msMatchesSelector||Hf.mozMatchesSelector||Hf.oMatchesSelector;Bf=function(t){return function(){return jf.call(this,t)}}}}var Xf=Bf,$f={};if(t.event=null,\"undefined\"!=typeof document){\"onmouseenter\"in document.documentElement||($f={mouseenter:\"mouseover\",mouseleave:\"mouseout\"})}var Vf=function(t,n,e){var r,i,o=N(t+\"\"),u=o.length;{if(!(arguments.length<2)){for(a=n?E:S,null==e&&(e=!1),r=0;r<u;++r)this.each(a(o[r],n,e));return this}var a=this.node().__on;if(a)for(var c,s=0,f=a.length;s<f;++s)for(r=0,c=a[s];r<u;++r)if((i=o[r]).type===c.type&&i.name===c.name)return c.value}},Wf=function(){for(var n,e=t.event;n=e.sourceEvent;)e=n;return e},Zf=function(t,n){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var r=e.createSVGPoint();return r.x=n.clientX,r.y=n.clientY,r=r.matrixTransform(t.getScreenCTM().inverse()),[r.x,r.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]},Gf=function(t){var n=Wf();return n.changedTouches&&(n=n.changedTouches[0]),Zf(t,n)},Jf=function(t){return null==t?C:function(){return this.querySelector(t)}},Qf=function(t){\"function\"!=typeof t&&(t=Jf(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u,a=n[i],c=a.length,s=r[i]=new Array(c),f=0;f<c;++f)(o=a[f])&&(u=t.call(o,o.__data__,f,a))&&(\"__data__\"in o&&(u.__data__=o.__data__),s[f]=u);return new _t(r,this._parents)},Kf=function(t){return null==t?z:function(){return this.querySelectorAll(t)}},tl=function(t){\"function\"!=typeof t&&(t=Kf(t));for(var n=this._groups,e=n.length,r=[],i=[],o=0;o<e;++o)for(var u,a=n[o],c=a.length,s=0;s<c;++s)(u=a[s])&&(r.push(t.call(u,u.__data__,s,a)),i.push(u));return new _t(r,i)},nl=function(t){\"function\"!=typeof t&&(t=Xf(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u=n[i],a=u.length,c=r[i]=[],s=0;s<a;++s)(o=u[s])&&t.call(o,o.__data__,s,u)&&c.push(o);return new _t(r,this._parents)},el=function(t){return new Array(t.length)},rl=function(){return new _t(this._enter||this._groups.map(el),this._parents)};P.prototype={constructor:P,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,n){return this._parent.insertBefore(t,n)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}};var il=function(t){return function(){return t}},ol=\"$\",ul=function(t,n){if(!t)return p=new Array(this.size()),s=-1,this.each(function(t){p[++s]=t}),p;var e=n?R:L,r=this._parents,i=this._groups;\"function\"!=typeof t&&(t=il(t));for(var o=i.length,u=new Array(o),a=new Array(o),c=new Array(o),s=0;s<o;++s){var f=r[s],l=i[s],h=l.length,p=t.call(f,f&&f.__data__,s,r),d=p.length,v=a[s]=new Array(d),_=u[s]=new Array(d);e(f,l,v,_,c[s]=new Array(h),p,n);for(var y,g,m=0,x=0;m<d;++m)if(y=v[m]){for(m>=x&&(x=m+1);!(g=_[x])&&++x<d;);y._next=g||null}}return u=new _t(u,r),u._enter=a,u._exit=c,u},al=function(){return new _t(this._exit||this._groups.map(el),this._parents)},cl=function(t){for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),u=new Array(r),a=0;a<o;++a)for(var c,s=n[a],f=e[a],l=s.length,h=u[a]=new Array(l),p=0;p<l;++p)(c=s[p]||f[p])&&(h[p]=c);for(;a<r;++a)u[a]=n[a];return new _t(u,this._parents)},sl=function(){for(var t=this._groups,n=-1,e=t.length;++n<e;)for(var r,i=t[n],o=i.length-1,u=i[o];--o>=0;)(r=i[o])&&(u&&u!==r.nextSibling&&u.parentNode.insertBefore(r,u),u=r);return this},fl=function(t){function n(n,e){return n&&e?t(n.__data__,e.__data__):!n-!e}t||(t=q);for(var e=this._groups,r=e.length,i=new Array(r),o=0;o<r;++o){for(var u,a=e[o],c=a.length,s=i[o]=new Array(c),f=0;f<c;++f)(u=a[f])&&(s[f]=u);s.sort(n)}return new _t(i,this._parents).order()},ll=function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},hl=function(){var t=new Array(this.size()),n=-1;return this.each(function(){t[++n]=this}),t},pl=function(){for(var t=this._groups,n=0,e=t.length;n<e;++n)for(var r=t[n],i=0,o=r.length;i<o;++i){var u=r[i];if(u)return u}return null},dl=function(){var t=0;return this.each(function(){++t}),t},vl=function(){return!this.node()},_l=function(t){for(var n=this._groups,e=0,r=n.length;e<r;++e)for(var i,o=n[e],u=0,a=o.length;u<a;++u)(i=o[u])&&t.call(i,i.__data__,u,o);return this},yl=function(t,n){var e=Ff(t);if(arguments.length<2){var r=this.node();return e.local?r.getAttributeNS(e.space,e.local):r.getAttribute(e)}return this.each((null==n?e.local?D:U:\"function\"==typeof n?e.local?Y:I:e.local?F:O)(e,n))},gl=function(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView},ml=function(t,n,e){return arguments.length>1?this.each((null==n?B:\"function\"==typeof n?j:H)(t,n,null==e?\"\":e)):X(this.node(),t)},xl=function(t,n){return arguments.length>1?this.each((null==n?$:\"function\"==typeof n?W:V)(t,n)):this.node()[t]};J.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute(\"class\",this._names.join(\" \")))},remove:function(t){var n=this._names.indexOf(t);n>=0&&(this._names.splice(n,1),this._node.setAttribute(\"class\",this._names.join(\" \")))},contains:function(t){return this._names.indexOf(t)>=0}};var bl=function(t,n){var e=Z(t+\"\");if(arguments.length<2){for(var r=G(this.node()),i=-1,o=e.length;++i<o;)if(!r.contains(e[i]))return!1;return!0}return this.each((\"function\"==typeof n?et:n?tt:nt)(e,n))},wl=function(t){return arguments.length?this.each(null==t?rt:(\"function\"==typeof t?ot:it)(t)):this.node().textContent},Ml=function(t){return arguments.length?this.each(null==t?ut:(\"function\"==typeof t?ct:at)(t)):this.node().innerHTML},Tl=function(){return this.each(st)},kl=function(){return this.each(ft)},Nl=function(t){var n=\"function\"==typeof t?t:If(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})},Sl=function(t,n){var e=\"function\"==typeof t?t:If(t),r=null==n?lt:\"function\"==typeof n?n:Jf(n);return this.select(function(){return this.insertBefore(e.apply(this,arguments),r.apply(this,arguments)||null)})},El=function(){return this.each(ht)},Al=function(t){return arguments.length?this.property(\"__data__\",t):this.node().__data__},Cl=function(t,n){return this.each((\"function\"==typeof n?vt:dt)(t,n))},zl=[null];_t.prototype=yt.prototype={constructor:_t,select:Qf,selectAll:tl,filter:nl,data:ul,enter:rl,exit:al,merge:cl,order:sl,sort:fl,call:ll,nodes:hl,node:pl,size:dl,empty:vl,each:_l,attr:yl,style:ml,property:xl,classed:bl,text:wl,html:Ml,raise:Tl,lower:kl,append:Nl,insert:Sl,remove:El,datum:Al,on:Vf,dispatch:Cl};var Pl=function(t){return\"string\"==typeof t?new _t([[document.querySelector(t)]],[document.documentElement]):new _t([[t]],zl)},Ll=function(t){return\"string\"==typeof t?new _t([document.querySelectorAll(t)],[document.documentElement]):new _t([null==t?[]:t],zl)\n},Rl=function(t,n,e){arguments.length<3&&(e=n,n=Wf().changedTouches);for(var r,i=0,o=n?n.length:0;i<o;++i)if((r=n[i]).identifier===e)return Zf(t,r);return null},ql=function(t,n){null==n&&(n=Wf().touches);for(var e=0,r=n?n.length:0,i=new Array(r);e<r;++e)i[e]=Zf(t,n[e]);return i},Ul=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()},Dl=function(t){var n=t.document.documentElement,e=Pl(t).on(\"dragstart.drag\",Ul,!0);\"onselectstart\"in n?e.on(\"selectstart.drag\",Ul,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect=\"none\")},Ol=function(t){return function(){return t}};xt.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};var Fl=function(){function n(t){t.on(\"mousedown.drag\",e).on(\"touchstart.drag\",o).on(\"touchmove.drag\",u).on(\"touchend.drag touchcancel.drag\",a).style(\"-webkit-tap-highlight-color\",\"rgba(0,0,0,0)\")}function e(){if(!h&&p.apply(this,arguments)){var n=c(\"mouse\",d.apply(this,arguments),Gf,this,arguments);n&&(Pl(t.event.view).on(\"mousemove.drag\",r,!0).on(\"mouseup.drag\",i,!0),Dl(t.event.view),gt(),l=!1,s=t.event.clientX,f=t.event.clientY,n(\"start\"))}}function r(){if(Ul(),!l){var n=t.event.clientX-s,e=t.event.clientY-f;l=n*n+e*e>x}y.mouse(\"drag\")}function i(){Pl(t.event.view).on(\"mousemove.drag mouseup.drag\",null),mt(t.event.view,l),Ul(),y.mouse(\"end\")}function o(){if(p.apply(this,arguments)){var n,e,r=t.event.changedTouches,i=d.apply(this,arguments),o=r.length;for(n=0;n<o;++n)(e=c(r[n].identifier,i,Rl,this,arguments))&&(gt(),e(\"start\"))}}function u(){var n,e,r=t.event.changedTouches,i=r.length;for(n=0;n<i;++n)(e=y[r[n].identifier])&&(Ul(),e(\"drag\"))}function a(){var n,e,r=t.event.changedTouches,i=r.length;for(h&&clearTimeout(h),h=setTimeout(function(){h=null},500),n=0;n<i;++n)(e=y[r[n].identifier])&&(gt(),e(\"end\"))}function c(e,r,i,o,u){var a,c,s,f=i(r,e),l=g.copy();if(A(new xt(n,\"beforestart\",a,e,m,f[0],f[1],0,0,l),function(){return null!=(t.event.subject=a=_.apply(o,u))&&(c=a.x-f[0]||0,s=a.y-f[1]||0,!0)}))return function t(h){var p,d=f;switch(h){case\"start\":y[e]=t,p=m++;break;case\"end\":delete y[e],--m;case\"drag\":f=i(r,e),p=m}A(new xt(n,h,a,e,p,f[0]+c,f[1]+s,f[0]-d[0],f[1]-d[1],l),l.apply,l,[h,o,u])}}var s,f,l,h,p=bt,d=wt,_=Mt,y={},g=v(\"start\",\"drag\",\"end\"),m=0,x=0;return n.filter=function(t){return arguments.length?(p=\"function\"==typeof t?t:Ol(!!t),n):p},n.container=function(t){return arguments.length?(d=\"function\"==typeof t?t:Ol(t),n):d},n.subject=function(t){return arguments.length?(_=\"function\"==typeof t?t:Ol(t),n):_},n.on=function(){var t=g.on.apply(g,arguments);return t===g?n:t},n.clickDistance=function(t){return arguments.length?(x=(t=+t)*t,n):Math.sqrt(x)},n},Il=function(t,n,e){t.prototype=n.prototype=e,e.constructor=t},Yl=\"\\\\s*([+-]?\\\\d+)\\\\s*\",Bl=\"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",Hl=\"\\\\s*([+-]?\\\\d*\\\\.?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",jl=/^#([0-9a-f]{3})$/,Xl=/^#([0-9a-f]{6})$/,$l=new RegExp(\"^rgb\\\\(\"+[Yl,Yl,Yl]+\"\\\\)$\"),Vl=new RegExp(\"^rgb\\\\(\"+[Hl,Hl,Hl]+\"\\\\)$\"),Wl=new RegExp(\"^rgba\\\\(\"+[Yl,Yl,Yl,Bl]+\"\\\\)$\"),Zl=new RegExp(\"^rgba\\\\(\"+[Hl,Hl,Hl,Bl]+\"\\\\)$\"),Gl=new RegExp(\"^hsl\\\\(\"+[Bl,Hl,Hl]+\"\\\\)$\"),Jl=new RegExp(\"^hsla\\\\(\"+[Bl,Hl,Hl,Bl]+\"\\\\)$\"),Ql={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Il(kt,Nt,{displayable:function(){return this.rgb().displayable()},toString:function(){return this.rgb()+\"\"}}),Il(zt,Ct,Tt(kt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new zt(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new zt(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return 0<=this.r&&this.r<=255&&0<=this.g&&this.g<=255&&0<=this.b&&this.b<=255&&0<=this.opacity&&this.opacity<=1},toString:function(){var t=this.opacity;return t=isNaN(t)?1:Math.max(0,Math.min(1,t)),(1===t?\"rgb(\":\"rgba(\")+Math.max(0,Math.min(255,Math.round(this.r)||0))+\", \"+Math.max(0,Math.min(255,Math.round(this.g)||0))+\", \"+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?\")\":\", \"+t+\")\")}})),Il(qt,Rt,Tt(kt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new qt(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new qt(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),n=isNaN(t)||isNaN(this.s)?0:this.s,e=this.l,r=e+(e<.5?e:1-e)*n,i=2*e-r;return new zt(Ut(t>=240?t-240:t+120,i,r),Ut(t,i,r),Ut(t<120?t+240:t-120,i,r),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1}}));var Kl=Math.PI/180,th=180/Math.PI,nh=.95047,eh=1,rh=1.08883,ih=4/29,oh=6/29,uh=3*oh*oh,ah=oh*oh*oh;Il(Ft,Ot,Tt(kt,{brighter:function(t){return new Ft(this.l+18*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new Ft(this.l-18*(null==t?1:t),this.a,this.b,this.opacity)},rgb:function(){var t=(this.l+16)/116,n=isNaN(this.a)?t:t+this.a/500,e=isNaN(this.b)?t:t-this.b/200;return t=eh*Yt(t),n=nh*Yt(n),e=rh*Yt(e),new zt(Bt(3.2404542*n-1.5371385*t-.4985314*e),Bt(-.969266*n+1.8760108*t+.041556*e),Bt(.0556434*n-.2040259*t+1.0572252*e),this.opacity)}})),Il($t,Xt,Tt(kt,{brighter:function(t){return new $t(this.h,this.c,this.l+18*(null==t?1:t),this.opacity)},darker:function(t){return new $t(this.h,this.c,this.l-18*(null==t?1:t),this.opacity)},rgb:function(){return Dt(this).rgb()}}));var ch=-.14861,sh=1.78277,fh=-.29227,lh=-.90649,hh=1.97294,ph=hh*lh,dh=hh*sh,vh=sh*fh-lh*ch;Il(Zt,Wt,Tt(kt,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new Zt(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new Zt(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=isNaN(this.h)?0:(this.h+120)*Kl,n=+this.l,e=isNaN(this.s)?0:this.s*n*(1-n),r=Math.cos(t),i=Math.sin(t);return new zt(255*(n+e*(ch*r+sh*i)),255*(n+e*(fh*r+lh*i)),255*(n+e*(hh*r)),this.opacity)}}));var _h,yh,gh,mh,xh,bh,wh=function(t){var n=t.length-1;return function(e){var r=e<=0?e=0:e>=1?(e=1,n-1):Math.floor(e*n),i=t[r],o=t[r+1],u=r>0?t[r-1]:2*i-o,a=r<n-1?t[r+2]:2*o-i;return Gt((e-r/n)*n,u,i,o,a)}},Mh=function(t){var n=t.length;return function(e){var r=Math.floor(((e%=1)<0?++e:e)*n),i=t[(r+n-1)%n],o=t[r%n],u=t[(r+1)%n],a=t[(r+2)%n];return Gt((e-r/n)*n,i,o,u,a)}},Th=function(t){return function(){return t}},kh=function t(n){function e(t,n){var e=r((t=Ct(t)).r,(n=Ct(n)).r),i=r(t.g,n.g),o=r(t.b,n.b),u=nn(t.opacity,n.opacity);return function(n){return t.r=e(n),t.g=i(n),t.b=o(n),t.opacity=u(n),t+\"\"}}var r=tn(n);return e.gamma=t,e}(1),Nh=en(wh),Sh=en(Mh),Eh=function(t,n){var e,r=n?n.length:0,i=t?Math.min(r,t.length):0,o=new Array(r),u=new Array(r);for(e=0;e<i;++e)o[e]=qh(t[e],n[e]);for(;e<r;++e)u[e]=n[e];return function(t){for(e=0;e<i;++e)u[e]=o[e](t);return u}},Ah=function(t,n){var e=new Date;return t=+t,n-=t,function(r){return e.setTime(t+n*r),e}},Ch=function(t,n){return t=+t,n-=t,function(e){return t+n*e}},zh=function(t,n){var e,r={},i={};null!==t&&\"object\"==typeof t||(t={}),null!==n&&\"object\"==typeof n||(n={});for(e in n)e in t?r[e]=qh(t[e],n[e]):i[e]=n[e];return function(t){for(e in r)i[e]=r[e](t);return i}},Ph=/[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,Lh=new RegExp(Ph.source,\"g\"),Rh=function(t,n){var e,r,i,o=Ph.lastIndex=Lh.lastIndex=0,u=-1,a=[],c=[];for(t+=\"\",n+=\"\";(e=Ph.exec(t))&&(r=Lh.exec(n));)(i=r.index)>o&&(i=n.slice(o,i),a[u]?a[u]+=i:a[++u]=i),(e=e[0])===(r=r[0])?a[u]?a[u]+=r:a[++u]=r:(a[++u]=null,c.push({i:u,x:Ch(e,r)})),o=Lh.lastIndex;return o<n.length&&(i=n.slice(o),a[u]?a[u]+=i:a[++u]=i),a.length<2?c[0]?on(c[0].x):rn(n):(n=c.length,function(t){for(var e,r=0;r<n;++r)a[(e=c[r]).i]=e.x(t);return a.join(\"\")})},qh=function(t,n){var e,r=typeof n;return null==n||\"boolean\"===r?Th(n):(\"number\"===r?Ch:\"string\"===r?(e=Nt(n))?(n=e,kh):Rh:n instanceof Nt?kh:n instanceof Date?Ah:Array.isArray(n)?Eh:\"function\"!=typeof n.valueOf&&\"function\"!=typeof n.toString||isNaN(n)?zh:Ch)(t,n)},Uh=function(t,n){return t=+t,n-=t,function(e){return Math.round(t+n*e)}},Dh=180/Math.PI,Oh={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1},Fh=function(t,n,e,r,i,o){var u,a,c;return(u=Math.sqrt(t*t+n*n))&&(t/=u,n/=u),(c=t*e+n*r)&&(e-=t*c,r-=n*c),(a=Math.sqrt(e*e+r*r))&&(e/=a,r/=a,c/=a),t*r<n*e&&(t=-t,n=-n,c=-c,u=-u),{translateX:i,translateY:o,rotate:Math.atan2(n,t)*Dh,skewX:Math.atan(c)*Dh,scaleX:u,scaleY:a}},Ih=cn(un,\"px, \",\"px)\",\"deg)\"),Yh=cn(an,\", \",\")\",\")\"),Bh=Math.SQRT2,Hh=function(t,n){var e,r,i=t[0],o=t[1],u=t[2],a=n[0],c=n[1],s=n[2],f=a-i,l=c-o,h=f*f+l*l;if(h<1e-12)r=Math.log(s/u)/Bh,e=function(t){return[i+t*f,o+t*l,u*Math.exp(Bh*t*r)]};else{var p=Math.sqrt(h),d=(s*s-u*u+4*h)/(2*u*2*p),v=(s*s-u*u-4*h)/(2*s*2*p),_=Math.log(Math.sqrt(d*d+1)-d),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-_)/Bh,e=function(t){var n=t*r,e=sn(_),a=u/(2*p)*(e*ln(Bh*n+_)-fn(_));return[i+a*f,o+a*l,u*e/sn(Bh*n+_)]}}return e.duration=1e3*r,e},jh=hn(Kt),Xh=hn(nn),$h=dn(Kt),Vh=dn(nn),Wh=vn(Kt),Zh=vn(nn),Gh=function(t,n){for(var e=new Array(n),r=0;r<n;++r)e[r]=t(r/(n-1));return e},Jh=0,Qh=0,Kh=0,tp=1e3,np=0,ep=0,rp=0,ip=\"object\"==typeof performance&&performance.now?performance:Date,op=\"function\"==typeof requestAnimationFrame?requestAnimationFrame:function(t){setTimeout(t,17)};gn.prototype=mn.prototype={constructor:gn,restart:function(t,n,e){if(\"function\"!=typeof t)throw new TypeError(\"callback is not a function\");e=(null==e?_n():+e)+(null==n?0:+n),this._next||bh===this||(bh?bh._next=this:xh=this,bh=this),this._call=t,this._time=e,Tn()},stop:function(){this._call&&(this._call=null,this._time=1/0,Tn())}};var up=function(t,n,e){var r=new gn;return n=null==n?0:+n,r.restart(function(e){r.stop(),t(e+n)},n,e),r},ap=function(t,n,e){var r=new gn,i=n;return null==n?(r.restart(t,n,e),r):(n=+n,e=null==e?_n():+e,r.restart(function o(u){u+=i,r.restart(o,i+=n,e),t(u)},n,e),r)},cp=v(\"start\",\"end\",\"interrupt\"),sp=[],fp=0,lp=1,hp=2,pp=3,dp=4,vp=5,_p=6,yp=function(t,n,e,r,i,o){var u=t.__transition;if(u){if(e in u)return}else t.__transition={};En(t,e,{name:n,index:r,group:i,on:cp,tween:sp,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:fp})},gp=function(t,n){var e,r,i,o=t.__transition,u=!0;if(o){n=null==n?null:n+\"\";for(i in o)(e=o[i]).name===n?(r=e.state>hp&&e.state<vp,e.state=_p,e.timer.stop(),r&&e.on.call(\"interrupt\",t,t.__data__,e.index,e.group),delete o[i]):u=!1;u&&delete t.__transition}},mp=function(t){return this.each(function(){gp(this,t)})},xp=function(t,n){var e=this._id;if(t+=\"\",arguments.length<2){for(var r,i=Sn(this.node(),e).tween,o=0,u=i.length;o<u;++o)if((r=i[o]).name===t)return r.value;return null}return this.each((null==n?An:Cn)(e,t,n))},bp=function(t,n){var e;return(\"number\"==typeof n?Ch:n instanceof Nt?kh:(e=Nt(n))?(n=e,kh):Rh)(t,n)},wp=function(t,n){var e=Ff(t),r=\"transform\"===e?Yh:bp;return this.attrTween(t,\"function\"==typeof n?(e.local?Dn:Un)(e,r,zn(this,\"attr.\"+t,n)):null==n?(e.local?Ln:Pn)(e):(e.local?qn:Rn)(e,r,n+\"\"))},Mp=function(t,n){var e=\"attr.\"+t;if(arguments.length<2)return(e=this.tween(e))&&e._value;if(null==n)return this.tween(e,null);if(\"function\"!=typeof n)throw new Error;var r=Ff(t);return this.tween(e,(r.local?On:Fn)(r,n))},Tp=function(t){var n=this._id;return arguments.length?this.each((\"function\"==typeof t?In:Yn)(n,t)):Sn(this.node(),n).delay},kp=function(t){var n=this._id;return arguments.length?this.each((\"function\"==typeof t?Bn:Hn)(n,t)):Sn(this.node(),n).duration},Np=function(t){var n=this._id;return arguments.length?this.each(jn(n,t)):Sn(this.node(),n).ease},Sp=function(t){\"function\"!=typeof t&&(t=Xf(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,u=n[i],a=u.length,c=r[i]=[],s=0;s<a;++s)(o=u[s])&&t.call(o,o.__data__,s,u)&&c.push(o);return new ne(r,this._parents,this._name,this._id)},Ep=function(t){if(t._id!==this._id)throw new Error;for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),u=new Array(r),a=0;a<o;++a)for(var c,s=n[a],f=e[a],l=s.length,h=u[a]=new Array(l),p=0;p<l;++p)(c=s[p]||f[p])&&(h[p]=c);for(;a<r;++a)u[a]=n[a];return new ne(u,this._parents,this._name,this._id)},Ap=function(t,n){var e=this._id;return arguments.length<2?Sn(this.node(),e).on.on(t):this.each($n(e,t,n))},Cp=function(){return this.on(\"end.remove\",Vn(this._id))},zp=function(t){var n=this._name,e=this._id;\"function\"!=typeof t&&(t=Jf(t));for(var r=this._groups,i=r.length,o=new Array(i),u=0;u<i;++u)for(var a,c,s=r[u],f=s.length,l=o[u]=new Array(f),h=0;h<f;++h)(a=s[h])&&(c=t.call(a,a.__data__,h,s))&&(\"__data__\"in a&&(c.__data__=a.__data__),l[h]=c,yp(l[h],n,e,h,l,Sn(a,e)));return new ne(o,this._parents,n,e)},Pp=function(t){var n=this._name,e=this._id;\"function\"!=typeof t&&(t=Kf(t));for(var r=this._groups,i=r.length,o=[],u=[],a=0;a<i;++a)for(var c,s=r[a],f=s.length,l=0;l<f;++l)if(c=s[l]){for(var h,p=t.call(c,c.__data__,l,s),d=Sn(c,e),v=0,_=p.length;v<_;++v)(h=p[v])&&yp(h,n,e,v,p,d);o.push(p),u.push(c)}return new ne(o,u,n,e)},Lp=yt.prototype.constructor,Rp=function(){return new Lp(this._groups,this._parents)},qp=function(t,n,e){var r=\"transform\"==(t+=\"\")?Ih:bp;return null==n?this.styleTween(t,Wn(t,r)).on(\"end.style.\"+t,Zn(t)):this.styleTween(t,\"function\"==typeof n?Jn(t,r,zn(this,\"style.\"+t,n)):Gn(t,r,n+\"\"),e)},Up=function(t,n,e){var r=\"style.\"+(t+=\"\");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==n)return this.tween(r,null);if(\"function\"!=typeof n)throw new Error;return this.tween(r,Qn(t,n,null==e?\"\":e))},Dp=function(t){return this.tween(\"text\",\"function\"==typeof t?te(zn(this,\"text\",t)):Kn(null==t?\"\":t+\"\"))},Op=function(){for(var t=this._name,n=this._id,e=re(),r=this._groups,i=r.length,o=0;o<i;++o)for(var u,a=r[o],c=a.length,s=0;s<c;++s)if(u=a[s]){var f=Sn(u,n);yp(u,t,e,s,a,{time:f.time+f.delay+f.duration,delay:0,duration:f.duration,ease:f.ease})}return new ne(r,this._parents,t,e)},Fp=0,Ip=yt.prototype;ne.prototype=ee.prototype={constructor:ne,select:zp,selectAll:Pp,filter:Sp,merge:Ep,selection:Rp,transition:Op,call:Ip.call,nodes:Ip.nodes,node:Ip.node,size:Ip.size,empty:Ip.empty,each:Ip.each,on:Ap,attr:wp,attrTween:Mp,style:qp,styleTween:Up,text:Dp,remove:Cp,tween:xp,delay:Tp,duration:kp,ease:Np};var Yp=function t(n){function e(t){return Math.pow(t,n)}return n=+n,e.exponent=t,e}(3),Bp=function t(n){function e(t){return 1-Math.pow(1-t,n)}return n=+n,e.exponent=t,e}(3),Hp=function t(n){function e(t){return((t*=2)<=1?Math.pow(t,n):2-Math.pow(2-t,n))/2}return n=+n,e.exponent=t,e}(3),jp=Math.PI,Xp=jp/2,$p=4/11,Vp=6/11,Wp=8/11,Zp=.75,Gp=9/11,Jp=10/11,Qp=.9375,Kp=21/22,td=63/64,nd=1/$p/$p,ed=function t(n){function e(t){return t*t*((n+1)*t-n)}return n=+n,e.overshoot=t,e}(1.70158),rd=function t(n){function e(t){return--t*t*((n+1)*t+n)+1}return n=+n,e.overshoot=t,e}(1.70158),id=function t(n){function e(t){return((t*=2)<1?t*t*((n+1)*t-n):(t-=2)*t*((n+1)*t+n)+2)/2}return n=+n,e.overshoot=t,e}(1.70158),od=2*Math.PI,ud=function t(n,e){function r(t){return n*Math.pow(2,10*--t)*Math.sin((i-t)/e)}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=od);return r.amplitude=function(n){return t(n,e*od)},r.period=function(e){return t(n,e)},r}(1,.3),ad=function t(n,e){function r(t){return 1-n*Math.pow(2,-10*(t=+t))*Math.sin((t+i)/e)}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=od);return r.amplitude=function(n){return t(n,e*od)},r.period=function(e){return t(n,e)},r}(1,.3),cd=function t(n,e){function r(t){return((t=2*t-1)<0?n*Math.pow(2,10*t)*Math.sin((i-t)/e):2-n*Math.pow(2,-10*t)*Math.sin((i+t)/e))/2}var i=Math.asin(1/(n=Math.max(1,n)))*(e/=od);return r.amplitude=function(n){return t(n,e*od)},r.period=function(e){return t(n,e)},r}(1,.3),sd={time:null,delay:0,duration:250,ease:fe},fd=function(t){var n,e;t instanceof ne?(n=t._id,t=t._name):(n=re(),(e=sd).time=_n(),t=null==t?null:t+\"\");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var u,a=r[o],c=a.length,s=0;s<c;++s)(u=a[s])&&yp(u,t,n,s,a,e||Me(u,n));return new ne(r,this._parents,t,n)};yt.prototype.interrupt=mp,yt.prototype.transition=fd;var ld=[null],hd=function(t,n){var e,r,i=t.__transition;if(i){n=null==n?null:n+\"\";for(r in i)if((e=i[r]).state>lp&&e.name===n)return new ne([[t]],ld,n,+r)}return null},pd=function(t){return function(){return t}},dd=function(t,n,e){this.target=t,this.type=n,this.selection=e},vd=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()},_d={name:\"drag\"},yd={name:\"space\"},gd={name:\"handle\"},md={name:\"center\"},xd={name:\"x\",handles:[\"e\",\"w\"].map(ke),input:function(t,n){return t&&[[t[0],n[0][1]],[t[1],n[1][1]]]},output:function(t){return t&&[t[0][0],t[1][0]]}},bd={name:\"y\",handles:[\"n\",\"s\"].map(ke),input:function(t,n){return t&&[[n[0][0],t[0]],[n[1][0],t[1]]]},output:function(t){return t&&[t[0][1],t[1][1]]}},wd={name:\"xy\",handles:[\"n\",\"e\",\"s\",\"w\",\"nw\",\"ne\",\"se\",\"sw\"].map(ke),input:function(t){return t},output:function(t){return t}},Md={overlay:\"crosshair\",selection:\"move\",n:\"ns-resize\",e:\"ew-resize\",s:\"ns-resize\",w:\"ew-resize\",nw:\"nwse-resize\",ne:\"nesw-resize\",se:\"nwse-resize\",sw:\"nesw-resize\"},Td={e:\"w\",w:\"e\",nw:\"ne\",ne:\"nw\",se:\"sw\",sw:\"se\"},kd={n:\"s\",s:\"n\",nw:\"sw\",ne:\"se\",se:\"ne\",sw:\"nw\"},Nd={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},Sd={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1},Ed=function(){return Le(wd)},Ad=Math.cos,Cd=Math.sin,zd=Math.PI,Pd=zd/2,Ld=2*zd,Rd=Math.max,qd=function(){function t(t){var o,u,a,c,s,f,l=t.length,h=[],p=cf(l),d=[],v=[],_=v.groups=new Array(l),y=new Array(l*l);for(o=0,s=-1;++s<l;){for(u=0,f=-1;++f<l;)u+=t[s][f];h.push(u),d.push(cf(l)),o+=u}for(e&&p.sort(function(t,n){return e(h[t],h[n])}),r&&d.forEach(function(n,e){n.sort(function(n,i){return r(t[e][n],t[e][i])})}),o=Rd(0,Ld-n*l)/o,c=o?n:Ld/l,u=0,s=-1;++s<l;){for(a=u,f=-1;++f<l;){var g=p[s],m=d[g][f],x=t[g][m],b=u,w=u+=x*o;y[m*l+g]={index:g,subindex:m,startAngle:b,endAngle:w,value:x}}_[g]={index:g,startAngle:a,endAngle:u,value:h[g]},u+=c}for(s=-1;++s<l;)for(f=s-1;++f<l;){var M=y[f*l+s],T=y[s*l+f];(M.value||T.value)&&v.push(M.value<T.value?{source:T,target:M}:{source:M,target:T})}return i?v.sort(i):v}var n=0,e=null,r=null,i=null;return t.padAngle=function(e){return arguments.length?(n=Rd(0,e),t):n},t.sortGroups=function(n){return arguments.length?(e=n,t):e},t.sortSubgroups=function(n){return arguments.length?(r=n,t):r},t.sortChords=function(n){return arguments.length?(null==n?i=null:(i=Re(n))._=n,t):i&&i._},t},Ud=Array.prototype.slice,Dd=function(t){return function(){return t}},Od=Math.PI,Fd=2*Od,Id=Fd-1e-6;qe.prototype=Ue.prototype={constructor:qe,moveTo:function(t,n){this._+=\"M\"+(this._x0=this._x1=+t)+\",\"+(this._y0=this._y1=+n)},closePath:function(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+=\"Z\")},lineTo:function(t,n){this._+=\"L\"+(this._x1=+t)+\",\"+(this._y1=+n)},quadraticCurveTo:function(t,n,e,r){this._+=\"Q\"+ +t+\",\"+ +n+\",\"+(this._x1=+e)+\",\"+(this._y1=+r)},bezierCurveTo:function(t,n,e,r,i,o){this._+=\"C\"+ +t+\",\"+ +n+\",\"+ +e+\",\"+ +r+\",\"+(this._x1=+i)+\",\"+(this._y1=+o)},arcTo:function(t,n,e,r,i){t=+t,n=+n,e=+e,r=+r,i=+i;var o=this._x1,u=this._y1,a=e-t,c=r-n,s=o-t,f=u-n,l=s*s+f*f;if(i<0)throw new Error(\"negative radius: \"+i);if(null===this._x1)this._+=\"M\"+(this._x1=t)+\",\"+(this._y1=n);else if(l>1e-6)if(Math.abs(f*a-c*s)>1e-6&&i){var h=e-o,p=r-u,d=a*a+c*c,v=h*h+p*p,_=Math.sqrt(d),y=Math.sqrt(l),g=i*Math.tan((Od-Math.acos((d+l-v)/(2*_*y)))/2),m=g/y,x=g/_;Math.abs(m-1)>1e-6&&(this._+=\"L\"+(t+m*s)+\",\"+(n+m*f)),this._+=\"A\"+i+\",\"+i+\",0,0,\"+ +(f*h>s*p)+\",\"+(this._x1=t+x*a)+\",\"+(this._y1=n+x*c)}else this._+=\"L\"+(this._x1=t)+\",\"+(this._y1=n);else;},arc:function(t,n,e,r,i,o){t=+t,n=+n,e=+e;var u=e*Math.cos(r),a=e*Math.sin(r),c=t+u,s=n+a,f=1^o,l=o?r-i:i-r;if(e<0)throw new Error(\"negative radius: \"+e);null===this._x1?this._+=\"M\"+c+\",\"+s:(Math.abs(this._x1-c)>1e-6||Math.abs(this._y1-s)>1e-6)&&(this._+=\"L\"+c+\",\"+s),e&&(l<0&&(l=l%Fd+Fd),l>Id?this._+=\"A\"+e+\",\"+e+\",0,1,\"+f+\",\"+(t-u)+\",\"+(n-a)+\"A\"+e+\",\"+e+\",0,1,\"+f+\",\"+(this._x1=c)+\",\"+(this._y1=s):l>1e-6&&(this._+=\"A\"+e+\",\"+e+\",0,\"+ +(l>=Od)+\",\"+f+\",\"+(this._x1=t+e*Math.cos(i))+\",\"+(this._y1=n+e*Math.sin(i))))},rect:function(t,n,e,r){this._+=\"M\"+(this._x0=this._x1=+t)+\",\"+(this._y0=this._y1=+n)+\"h\"+ +e+\"v\"+ +r+\"h\"+-e+\"Z\"},toString:function(){return this._}};var Yd=function(){function t(){var t,a=Ud.call(arguments),c=n.apply(this,a),s=e.apply(this,a),f=+r.apply(this,(a[0]=c,a)),l=i.apply(this,a)-Pd,h=o.apply(this,a)-Pd,p=f*Ad(l),d=f*Cd(l),v=+r.apply(this,(a[0]=s,a)),_=i.apply(this,a)-Pd,y=o.apply(this,a)-Pd;if(u||(u=t=Ue()),u.moveTo(p,d),u.arc(0,0,f,l,h),l===_&&h===y||(u.quadraticCurveTo(0,0,v*Ad(_),v*Cd(_)),u.arc(0,0,v,_,y)),u.quadraticCurveTo(0,0,p,d),u.closePath(),t)return u=null,t+\"\"||null}var n=De,e=Oe,r=Fe,i=Ie,o=Ye,u=null;return t.radius=function(n){return arguments.length?(r=\"function\"==typeof n?n:Dd(+n),t):r},t.startAngle=function(n){return arguments.length?(i=\"function\"==typeof n?n:Dd(+n),t):i},t.endAngle=function(n){return arguments.length?(o=\"function\"==typeof n?n:Dd(+n),t):o},t.source=function(e){return arguments.length?(n=e,t):n},t.target=function(n){return arguments.length?(e=n,t):e},t.context=function(n){return arguments.length?(u=null==n?null:n,t):u},t};Be.prototype=He.prototype={constructor:Be,has:function(t){return\"$\"+t in this},get:function(t){return this[\"$\"+t]},set:function(t,n){return this[\"$\"+t]=n,this},remove:function(t){var n=\"$\"+t;return n in this&&delete this[n]},clear:function(){for(var t in this)\"$\"===t[0]&&delete this[t]},keys:function(){var t=[];for(var n in this)\"$\"===n[0]&&t.push(n.slice(1));return t},values:function(){var t=[];for(var n in this)\"$\"===n[0]&&t.push(this[n]);return t},entries:function(){var t=[];for(var n in this)\"$\"===n[0]&&t.push({key:n.slice(1),value:this[n]});return t},size:function(){var t=0;for(var n in this)\"$\"===n[0]&&++t;return t},empty:function(){for(var t in this)if(\"$\"===t[0])return!1;return!0},each:function(t){for(var n in this)\"$\"===n[0]&&t(this[n],n.slice(1),this)}};var Bd=function(){function t(n,i,u,a){if(i>=o.length)return null!=r?r(n):null!=e?n.sort(e):n;for(var c,s,f,l=-1,h=n.length,p=o[i++],d=He(),v=u();++l<h;)(f=d.get(c=p(s=n[l])+\"\"))?f.push(s):d.set(c,[s]);return d.each(function(n,e){a(v,e,t(n,i,u,a))}),v}function n(t,e){if(++e>o.length)return t;var i,a=u[e-1];return null!=r&&e>=o.length?i=t.entries():(i=[],t.each(function(t,r){i.push({key:r,values:n(t,e)})})),null!=a?i.sort(function(t,n){return a(t.key,n.key)}):i}var e,r,i,o=[],u=[];return i={object:function(n){return t(n,0,je,Xe)},map:function(n){return t(n,0,$e,Ve)},entries:function(e){return n(t(e,0,$e,Ve),0)},key:function(t){return o.push(t),i},sortKeys:function(t){return u[o.length-1]=t,i},sortValues:function(t){return e=t,i},rollup:function(t){return r=t,i}}},Hd=He.prototype;We.prototype=Ze.prototype={constructor:We,has:Hd.has,add:function(t){return t+=\"\",this[\"$\"+t]=t,this},remove:Hd.remove,clear:Hd.clear,values:Hd.keys,size:Hd.size,empty:Hd.empty,each:Hd.each};var jd=function(t){var n=[];for(var e in t)n.push(e);return n},Xd=function(t){var n=[];for(var e in t)n.push(t[e]);return n},$d=function(t){var n=[];for(var e in t)n.push({key:e,value:t[e]});return n},Vd=function(t){function n(t,n){var r,i,o=e(t,function(t,e){if(r)return r(t,e-1);i=t,r=n?Je(t,n):Ge(t)});return o.columns=i,o}function e(t,n){function e(){if(f>=s)return u;if(i)return i=!1,o;var n,e=f;if(34===t.charCodeAt(e)){for(var r=e;r++<s;)if(34===t.charCodeAt(r)){if(34!==t.charCodeAt(r+1))break;++r}return f=r+2,n=t.charCodeAt(r+1),13===n?(i=!0,10===t.charCodeAt(r+2)&&++f):10===n&&(i=!0),t.slice(e+1,r).replace(/\"\"/g,'\"')}for(;f<s;){var a=1;if(10===(n=t.charCodeAt(f++)))i=!0;else if(13===n)i=!0,10===t.charCodeAt(f)&&(++f,++a);else if(n!==c)continue;return t.slice(e,f-a)}return t.slice(e)}for(var r,i,o={},u={},a=[],s=t.length,f=0,l=0;(r=e())!==u;){for(var h=[];r!==o&&r!==u;)h.push(r),r=e();n&&null==(h=n(h,l++))||a.push(h)}return a}function r(n,e){return null==e&&(e=Qe(n)),[e.map(u).join(t)].concat(n.map(function(n){return e.map(function(t){return u(n[t])}).join(t)})).join(\"\\n\")}function i(t){return t.map(o).join(\"\\n\")}function o(n){return n.map(u).join(t)}function u(t){return null==t?\"\":a.test(t+=\"\")?'\"'+t.replace(/\\\"/g,'\"\"')+'\"':t}var a=new RegExp('[\"'+t+\"\\n\\r]\"),c=t.charCodeAt(0);return{parse:n,parseRows:e,format:r,formatRows:i}},Wd=Vd(\",\"),Zd=Wd.parse,Gd=Wd.parseRows,Jd=Wd.format,Qd=Wd.formatRows,Kd=Vd(\"\\t\"),tv=Kd.parse,nv=Kd.parseRows,ev=Kd.format,rv=Kd.formatRows,iv=function(t,n){function e(){var e,i,o=r.length,u=0,a=0;for(e=0;e<o;++e)i=r[e],u+=i.x,a+=i.y;for(u=u/o-t,a=a/o-n,e=0;e<o;++e)i=r[e],i.x-=u,i.y-=a}var r;return null==t&&(t=0),null==n&&(n=0),e.initialize=function(t){r=t},e.x=function(n){return arguments.length?(t=+n,e):t},e.y=function(t){return arguments.length?(n=+t,e):n},e},ov=function(t){return function(){return t}},uv=function(){return 1e-6*(Math.random()-.5)},av=function(t){var n=+this._x.call(null,t),e=+this._y.call(null,t);return Ke(this.cover(n,e),n,e,t)},cv=function(t,n){if(isNaN(t=+t)||isNaN(n=+n))return this;var e=this._x0,r=this._y0,i=this._x1,o=this._y1;if(isNaN(e))i=(e=Math.floor(t))+1,o=(r=Math.floor(n))+1;else{if(!(e>t||t>i||r>n||n>o))return this;var u,a,c=i-e,s=this._root;switch(a=(n<(r+o)/2)<<1|t<(e+i)/2){case 0:do{u=new Array(4),u[a]=s,s=u}while(c*=2,i=e+c,o=r+c,t>i||n>o);break;case 1:do{u=new Array(4),u[a]=s,s=u}while(c*=2,e=i-c,o=r+c,e>t||n>o);break;case 2:do{u=new Array(4),u[a]=s,s=u}while(c*=2,i=e+c,r=o-c,t>i||r>n);break;case 3:do{u=new Array(4),u[a]=s,s=u}while(c*=2,e=i-c,r=o-c,e>t||r>n)}this._root&&this._root.length&&(this._root=s)}return this._x0=e,this._y0=r,this._x1=i,this._y1=o,this},sv=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t},fv=function(t){return arguments.length?this.cover(+t[0][0],+t[0][1]).cover(+t[1][0],+t[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]},lv=function(t,n,e,r,i){this.node=t,this.x0=n,this.y0=e,this.x1=r,this.y1=i},hv=function(t,n,e){var r,i,o,u,a,c,s,f=this._x0,l=this._y0,h=this._x1,p=this._y1,d=[],v=this._root;for(v&&d.push(new lv(v,f,l,h,p)),null==e?e=1/0:(f=t-e,l=n-e,h=t+e,p=n+e,e*=e);c=d.pop();)if(!(!(v=c.node)||(i=c.x0)>h||(o=c.y0)>p||(u=c.x1)<f||(a=c.y1)<l))if(v.length){var _=(i+u)/2,y=(o+a)/2;d.push(new lv(v[3],_,y,u,a),new lv(v[2],i,y,_,a),new lv(v[1],_,o,u,y),new lv(v[0],i,o,_,y)),(s=(n>=y)<<1|t>=_)&&(c=d[d.length-1],d[d.length-1]=d[d.length-1-s],d[d.length-1-s]=c)}else{var g=t-+this._x.call(null,v.data),m=n-+this._y.call(null,v.data),x=g*g+m*m;if(x<e){var b=Math.sqrt(e=x);f=t-b,l=n-b,h=t+b,p=n+b,r=v.data}}return r},pv=function(t){if(isNaN(o=+this._x.call(null,t))||isNaN(u=+this._y.call(null,t)))return this;var n,e,r,i,o,u,a,c,s,f,l,h,p=this._root,d=this._x0,v=this._y0,_=this._x1,y=this._y1;if(!p)return this;if(p.length)for(;;){if((s=o>=(a=(d+_)/2))?d=a:_=a,(f=u>=(c=(v+y)/2))?v=c:y=c,n=p,!(p=p[l=f<<1|s]))return this;if(!p.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(e=n,h=l)}for(;p.data!==t;)if(r=p,!(p=p.next))return this;return(i=p.next)&&delete p.next,r?(i?r.next=i:delete r.next,this):n?(i?n[l]=i:delete n[l],(p=n[0]||n[1]||n[2]||n[3])&&p===(n[3]||n[2]||n[1]||n[0])&&!p.length&&(e?e[h]=p:this._root=p),this):(this._root=i,this)},dv=function(){return this._root},vv=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t},_v=function(t){var n,e,r,i,o,u,a=[],c=this._root;for(c&&a.push(new lv(c,this._x0,this._y0,this._x1,this._y1));n=a.pop();)if(!t(c=n.node,r=n.x0,i=n.y0,o=n.x1,u=n.y1)&&c.length){var s=(r+o)/2,f=(i+u)/2;(e=c[3])&&a.push(new lv(e,s,f,o,u)),(e=c[2])&&a.push(new lv(e,r,f,s,u)),(e=c[1])&&a.push(new lv(e,s,i,o,f)),(e=c[0])&&a.push(new lv(e,r,i,s,f))}return this},yv=function(t){var n,e=[],r=[];for(this._root&&e.push(new lv(this._root,this._x0,this._y0,this._x1,this._y1));n=e.pop();){var i=n.node;if(i.length){var o,u=n.x0,a=n.y0,c=n.x1,s=n.y1,f=(u+c)/2,l=(a+s)/2;(o=i[0])&&e.push(new lv(o,u,a,f,l)),(o=i[1])&&e.push(new lv(o,f,a,c,l)),(o=i[2])&&e.push(new lv(o,u,l,f,s)),(o=i[3])&&e.push(new lv(o,f,l,c,s))}r.push(n)}for(;n=r.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this},gv=function(t){return arguments.length?(this._x=t,this):this._x},mv=function(t){return arguments.length?(this._y=t,this):this._y},xv=ir.prototype=or.prototype;xv.copy=function(){var t,n,e=new or(this._x,this._y,this._x0,this._y0,this._x1,this._y1),r=this._root;if(!r)return e;if(!r.length)return e._root=ur(r),e;for(t=[{source:r,target:e._root=new Array(4)}];r=t.pop();)for(var i=0;i<4;++i)(n=r.source[i])&&(n.length?t.push({source:n,target:r.target[i]=new Array(4)}):r.target[i]=ur(n));return e},xv.add=av,xv.addAll=tr,xv.cover=cv,xv.data=sv,xv.extent=fv,xv.find=hv,xv.remove=pv,xv.removeAll=nr,xv.root=dv,xv.size=vv,xv.visit=_v,xv.visitAfter=yv,xv.x=gv,xv.y=mv;var bv,wv=function(t){function n(){function t(t,n,e,r,i){var o=t.data,a=t.r,p=l+a;{if(!o)return n>s+p||r<s-p||e>f+p||i<f-p;if(o.index>c.index){var d=s-o.x-o.vx,v=f-o.y-o.vy,_=d*d+v*v;_<p*p&&(0===d&&(d=uv(),_+=d*d),0===v&&(v=uv(),_+=v*v),_=(p-(_=Math.sqrt(_)))/_*u,c.vx+=(d*=_)*(p=(a*=a)/(h+a)),c.vy+=(v*=_)*p,o.vx-=d*(p=1-p),o.vy-=v*p)}}}for(var n,r,c,s,f,l,h,p=i.length,d=0;d<a;++d)for(r=ir(i,ar,cr).visitAfter(e),n=0;n<p;++n)c=i[n],l=o[c.index],h=l*l,s=c.x+c.vx,f=c.y+c.vy,r.visit(t)}function e(t){if(t.data)return t.r=o[t.data.index];for(var n=t.r=0;n<4;++n)t[n]&&t[n].r>t.r&&(t.r=t[n].r)}function r(){if(i){var n,e,r=i.length;for(o=new Array(r),n=0;n<r;++n)e=i[n],o[e.index]=+t(e,n,i)}}var i,o,u=1,a=1\n;return\"function\"!=typeof t&&(t=ov(null==t?1:+t)),n.initialize=function(t){i=t,r()},n.iterations=function(t){return arguments.length?(a=+t,n):a},n.strength=function(t){return arguments.length?(u=+t,n):u},n.radius=function(e){return arguments.length?(t=\"function\"==typeof e?e:ov(+e),r(),n):t},n},Mv=function(t){function n(t){return 1/Math.min(s[t.source.index],s[t.target.index])}function e(n){for(var e=0,r=t.length;e<d;++e)for(var i,o,c,s,l,h,p,v=0;v<r;++v)i=t[v],o=i.source,c=i.target,s=c.x+c.vx-o.x-o.vx||uv(),l=c.y+c.vy-o.y-o.vy||uv(),h=Math.sqrt(s*s+l*l),h=(h-a[v])/h*n*u[v],s*=h,l*=h,c.vx-=s*(p=f[v]),c.vy-=l*p,o.vx+=s*(p=1-p),o.vy+=l*p}function r(){if(c){var n,e,r=c.length,h=t.length,p=He(c,l);for(n=0,s=new Array(r);n<h;++n)e=t[n],e.index=n,\"object\"!=typeof e.source&&(e.source=fr(p,e.source)),\"object\"!=typeof e.target&&(e.target=fr(p,e.target)),s[e.source.index]=(s[e.source.index]||0)+1,s[e.target.index]=(s[e.target.index]||0)+1;for(n=0,f=new Array(h);n<h;++n)e=t[n],f[n]=s[e.source.index]/(s[e.source.index]+s[e.target.index]);u=new Array(h),i(),a=new Array(h),o()}}function i(){if(c)for(var n=0,e=t.length;n<e;++n)u[n]=+h(t[n],n,t)}function o(){if(c)for(var n=0,e=t.length;n<e;++n)a[n]=+p(t[n],n,t)}var u,a,c,s,f,l=sr,h=n,p=ov(30),d=1;return null==t&&(t=[]),e.initialize=function(t){c=t,r()},e.links=function(n){return arguments.length?(t=n,r(),e):t},e.id=function(t){return arguments.length?(l=t,e):l},e.iterations=function(t){return arguments.length?(d=+t,e):d},e.strength=function(t){return arguments.length?(h=\"function\"==typeof t?t:ov(+t),i(),e):h},e.distance=function(t){return arguments.length?(p=\"function\"==typeof t?t:ov(+t),o(),e):p},e},Tv=10,kv=Math.PI*(3-Math.sqrt(5)),Nv=function(t){function n(){e(),p.call(\"tick\",o),u<a&&(h.stop(),p.call(\"end\",o))}function e(){var n,e,r=t.length;for(u+=(s-u)*c,l.each(function(t){t(u)}),n=0;n<r;++n)e=t[n],null==e.fx?e.x+=e.vx*=f:(e.x=e.fx,e.vx=0),null==e.fy?e.y+=e.vy*=f:(e.y=e.fy,e.vy=0)}function r(){for(var n,e=0,r=t.length;e<r;++e){if(n=t[e],n.index=e,isNaN(n.x)||isNaN(n.y)){var i=Tv*Math.sqrt(e),o=e*kv;n.x=i*Math.cos(o),n.y=i*Math.sin(o)}(isNaN(n.vx)||isNaN(n.vy))&&(n.vx=n.vy=0)}}function i(n){return n.initialize&&n.initialize(t),n}var o,u=1,a=.001,c=1-Math.pow(a,1/300),s=0,f=.6,l=He(),h=mn(n),p=v(\"tick\",\"end\");return null==t&&(t=[]),r(),o={tick:e,restart:function(){return h.restart(n),o},stop:function(){return h.stop(),o},nodes:function(n){return arguments.length?(t=n,r(),l.each(i),o):t},alpha:function(t){return arguments.length?(u=+t,o):u},alphaMin:function(t){return arguments.length?(a=+t,o):a},alphaDecay:function(t){return arguments.length?(c=+t,o):+c},alphaTarget:function(t){return arguments.length?(s=+t,o):s},velocityDecay:function(t){return arguments.length?(f=1-t,o):1-f},force:function(t,n){return arguments.length>1?(null==n?l.remove(t):l.set(t,i(n)),o):l.get(t)},find:function(n,e,r){var i,o,u,a,c,s=0,f=t.length;for(null==r?r=1/0:r*=r,s=0;s<f;++s)a=t[s],i=n-a.x,o=e-a.y,(u=i*i+o*o)<r&&(c=a,r=u);return c},on:function(t,n){return arguments.length>1?(p.on(t,n),o):p.on(t)}}},Sv=function(){function t(t){var n,a=i.length,c=ir(i,lr,hr).visitAfter(e);for(u=t,n=0;n<a;++n)o=i[n],c.visit(r)}function n(){if(i){var t,n,e=i.length;for(a=new Array(e),t=0;t<e;++t)n=i[t],a[n.index]=+c(n,t,i)}}function e(t){var n,e,r,i,o,u=0;if(t.length){for(r=i=o=0;o<4;++o)(n=t[o])&&(e=n.value)&&(u+=e,r+=e*n.x,i+=e*n.y);t.x=r/u,t.y=i/u}else{n=t,n.x=n.data.x,n.y=n.data.y;do{u+=a[n.data.index]}while(n=n.next)}t.value=u}function r(t,n,e,r){if(!t.value)return!0;var i=t.x-o.x,c=t.y-o.y,h=r-n,p=i*i+c*c;if(h*h/l<p)return p<f&&(0===i&&(i=uv(),p+=i*i),0===c&&(c=uv(),p+=c*c),p<s&&(p=Math.sqrt(s*p)),o.vx+=i*t.value*u/p,o.vy+=c*t.value*u/p),!0;if(!(t.length||p>=f)){(t.data!==o||t.next)&&(0===i&&(i=uv(),p+=i*i),0===c&&(c=uv(),p+=c*c),p<s&&(p=Math.sqrt(s*p)));do{t.data!==o&&(h=a[t.data.index]*u/p,o.vx+=i*h,o.vy+=c*h)}while(t=t.next)}}var i,o,u,a,c=ov(-30),s=1,f=1/0,l=.81;return t.initialize=function(t){i=t,n()},t.strength=function(e){return arguments.length?(c=\"function\"==typeof e?e:ov(+e),n(),t):c},t.distanceMin=function(n){return arguments.length?(s=n*n,t):Math.sqrt(s)},t.distanceMax=function(n){return arguments.length?(f=n*n,t):Math.sqrt(f)},t.theta=function(n){return arguments.length?(l=n*n,t):Math.sqrt(l)},t},Ev=function(t){function n(t){for(var n,e=0,u=r.length;e<u;++e)n=r[e],n.vx+=(o[e]-n.x)*i[e]*t}function e(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)i[n]=isNaN(o[n]=+t(r[n],n,r))?0:+u(r[n],n,r)}}var r,i,o,u=ov(.1);return\"function\"!=typeof t&&(t=ov(null==t?0:+t)),n.initialize=function(t){r=t,e()},n.strength=function(t){return arguments.length?(u=\"function\"==typeof t?t:ov(+t),e(),n):u},n.x=function(r){return arguments.length?(t=\"function\"==typeof r?r:ov(+r),e(),n):t},n},Av=function(t){function n(t){for(var n,e=0,u=r.length;e<u;++e)n=r[e],n.vy+=(o[e]-n.y)*i[e]*t}function e(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)i[n]=isNaN(o[n]=+t(r[n],n,r))?0:+u(r[n],n,r)}}var r,i,o,u=ov(.1);return\"function\"!=typeof t&&(t=ov(null==t?0:+t)),n.initialize=function(t){r=t,e()},n.strength=function(t){return arguments.length?(u=\"function\"==typeof t?t:ov(+t),e(),n):u},n.y=function(r){return arguments.length?(t=\"function\"==typeof r?r:ov(+r),e(),n):t},n},Cv=function(t,n){if((e=(t=n?t.toExponential(n-1):t.toExponential()).indexOf(\"e\"))<0)return null;var e,r=t.slice(0,e);return[r.length>1?r[0]+r.slice(2):r,+t.slice(e+1)]},zv=function(t){return t=Cv(Math.abs(t)),t?t[1]:NaN},Pv=function(t,n){return function(e,r){for(var i=e.length,o=[],u=0,a=t[0],c=0;i>0&&a>0&&(c+a+1>r&&(a=Math.max(1,r-c)),o.push(e.substring(i-=a,i+a)),!((c+=a+1)>r));)a=t[u=(u+1)%t.length];return o.reverse().join(n)}},Lv=function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}},Rv=function(t,n){t=t.toPrecision(n);t:for(var e,r=t.length,i=1,o=-1;i<r;++i)switch(t[i]){case\".\":o=e=i;break;case\"0\":0===o&&(o=i),e=i;break;case\"e\":break t;default:o>0&&(o=0)}return o>0?t.slice(0,o)+t.slice(e+1):t},qv=function(t,n){var e=Cv(t,n);if(!e)return t+\"\";var r=e[0],i=e[1],o=i-(bv=3*Math.max(-8,Math.min(8,Math.floor(i/3))))+1,u=r.length;return o===u?r:o>u?r+new Array(o-u+1).join(\"0\"):o>0?r.slice(0,o)+\".\"+r.slice(o):\"0.\"+new Array(1-o).join(\"0\")+Cv(t,Math.max(0,n+o-1))[0]},Uv=function(t,n){var e=Cv(t,n);if(!e)return t+\"\";var r=e[0],i=e[1];return i<0?\"0.\"+new Array(-i).join(\"0\")+r:r.length>i+1?r.slice(0,i+1)+\".\"+r.slice(i+1):r+new Array(i-r.length+2).join(\"0\")},Dv={\"\":Rv,\"%\":function(t,n){return(100*t).toFixed(n)},b:function(t){return Math.round(t).toString(2)},c:function(t){return t+\"\"},d:function(t){return Math.round(t).toString(10)},e:function(t,n){return t.toExponential(n)},f:function(t,n){return t.toFixed(n)},g:function(t,n){return t.toPrecision(n)},o:function(t){return Math.round(t).toString(8)},p:function(t,n){return Uv(100*t,n)},r:Uv,s:qv,X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}},Ov=/^(?:(.)?([<>=^]))?([+\\-\\( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?([a-z%])?$/i;pr.prototype=dr.prototype,dr.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?\"0\":\"\")+(null==this.width?\"\":Math.max(1,0|this.width))+(this.comma?\",\":\"\")+(null==this.precision?\"\":\".\"+Math.max(0,0|this.precision))+this.type};var Fv,Iv=function(t){return t},Yv=[\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"µ\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"],Bv=function(t){function n(t){function n(t){var n,i,a,f=_,x=y;if(\"c\"===v)x=g(t)+x,t=\"\";else{t=+t;var b=t<0;if(t=g(Math.abs(t),d),b&&0==+t&&(b=!1),f=(b?\"(\"===s?s:\"-\":\"-\"===s||\"(\"===s?\"\":s)+f,x=x+(\"s\"===v?Yv[8+bv/3]:\"\")+(b&&\"(\"===s?\")\":\"\"),m)for(n=-1,i=t.length;++n<i;)if(48>(a=t.charCodeAt(n))||a>57){x=(46===a?o+t.slice(n+1):t.slice(n))+x,t=t.slice(0,n);break}}p&&!l&&(t=r(t,1/0));var w=f.length+t.length+x.length,M=w<h?new Array(h-w+1).join(e):\"\";switch(p&&l&&(t=r(M+t,M.length?h-x.length:1/0),M=\"\"),c){case\"<\":t=f+t+x+M;break;case\"=\":t=f+M+t+x;break;case\"^\":t=M.slice(0,w=M.length>>1)+f+t+x+M.slice(w);break;default:t=M+f+t+x}return u(t)}t=pr(t);var e=t.fill,c=t.align,s=t.sign,f=t.symbol,l=t.zero,h=t.width,p=t.comma,d=t.precision,v=t.type,_=\"$\"===f?i[0]:\"#\"===f&&/[boxX]/.test(v)?\"0\"+v.toLowerCase():\"\",y=\"$\"===f?i[1]:/[%p]/.test(v)?a:\"\",g=Dv[v],m=!v||/[defgprs%]/.test(v);return d=null==d?v?6:12:/[gprs]/.test(v)?Math.max(1,Math.min(21,d)):Math.max(0,Math.min(20,d)),n.toString=function(){return t+\"\"},n}function e(t,e){var r=n((t=pr(t),t.type=\"f\",t)),i=3*Math.max(-8,Math.min(8,Math.floor(zv(e)/3))),o=Math.pow(10,-i),u=Yv[8+i/3];return function(t){return r(o*t)+u}}var r=t.grouping&&t.thousands?Pv(t.grouping,t.thousands):Iv,i=t.currency,o=t.decimal,u=t.numerals?Lv(t.numerals):Iv,a=t.percent||\"%\";return{format:n,formatPrefix:e}};vr({decimal:\".\",thousands:\",\",grouping:[3],currency:[\"$\",\"\"]});var Hv=function(t){return Math.max(0,-zv(Math.abs(t)))},jv=function(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(zv(n)/3)))-zv(Math.abs(t)))},Xv=function(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,zv(n)-zv(t))+1},$v=function(){return new _r};_r.prototype={constructor:_r,reset:function(){this.s=this.t=0},add:function(t){yr(T_,t,this.t),yr(this,T_.s,this.s),this.s?this.t+=T_.t:this.s=T_.t},valueOf:function(){return this.s}};var Vv,Wv,Zv,Gv,Jv,Qv,Kv,t_,n_,e_,r_,i_,o_,u_,a_,c_,s_,f_,l_,h_,p_,d_,v_,__,y_,g_,m_,x_,b_,w_,M_,T_=new _r,k_=1e-6,N_=Math.PI,S_=N_/2,E_=N_/4,A_=2*N_,C_=180/N_,z_=N_/180,P_=Math.abs,L_=Math.atan,R_=Math.atan2,q_=Math.cos,U_=Math.ceil,D_=Math.exp,O_=Math.log,F_=Math.pow,I_=Math.sin,Y_=Math.sign||function(t){return t>0?1:t<0?-1:0},B_=Math.sqrt,H_=Math.tan,j_={Feature:function(t,n){wr(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)wr(e[r].geometry,n)}},X_={Sphere:function(t,n){n.sphere()},Point:function(t,n){t=t.coordinates,n.point(t[0],t[1],t[2])},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)t=e[r],n.point(t[0],t[1],t[2])},LineString:function(t,n){Mr(t.coordinates,n,0)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)Mr(e[r],n,0)},Polygon:function(t,n){Tr(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)Tr(e[r],n)},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)wr(e[r],n)}},$_=function(t,n){t&&j_.hasOwnProperty(t.type)?j_[t.type](t,n):wr(t,n)},V_=$v(),W_=$v(),Z_={point:br,lineStart:br,lineEnd:br,polygonStart:function(){V_.reset(),Z_.lineStart=kr,Z_.lineEnd=Nr},polygonEnd:function(){var t=+V_;W_.add(t<0?A_+t:t),this.lineStart=this.lineEnd=this.point=br},sphere:function(){W_.add(A_)}},G_=function(t){return W_.reset(),$_(t,Z_),2*W_},J_=$v(),Q_={point:Ur,lineStart:Or,lineEnd:Fr,polygonStart:function(){Q_.point=Ir,Q_.lineStart=Yr,Q_.lineEnd=Br,J_.reset(),Z_.polygonStart()},polygonEnd:function(){Z_.polygonEnd(),Q_.point=Ur,Q_.lineStart=Or,Q_.lineEnd=Fr,V_<0?(Qv=-(t_=180),Kv=-(n_=90)):J_>k_?n_=90:J_<-k_&&(Kv=-90),a_[0]=Qv,a_[1]=t_}},K_=function(t){var n,e,r,i,o,u,a;if(n_=t_=-(Qv=Kv=1/0),u_=[],$_(t,Q_),e=u_.length){for(u_.sort(jr),n=1,r=u_[0],o=[r];n<e;++n)i=u_[n],Xr(r,i[0])||Xr(r,i[1])?(Hr(r[0],i[1])>Hr(r[0],r[1])&&(r[1]=i[1]),Hr(i[0],r[1])>Hr(r[0],r[1])&&(r[0]=i[0])):o.push(r=i);for(u=-1/0,e=o.length-1,n=0,r=o[e];n<=e;r=i,++n)i=o[n],(a=Hr(r[1],i[0]))>u&&(u=a,Qv=i[0],t_=r[1])}return u_=a_=null,Qv===1/0||Kv===1/0?[[NaN,NaN],[NaN,NaN]]:[[Qv,Kv],[t_,n_]]},ty={sphere:br,point:$r,lineStart:Wr,lineEnd:Jr,polygonStart:function(){ty.lineStart=Qr,ty.lineEnd=Kr},polygonEnd:function(){ty.lineStart=Wr,ty.lineEnd=Jr}},ny=function(t){c_=s_=f_=l_=h_=p_=d_=v_=__=y_=g_=0,$_(t,ty);var n=__,e=y_,r=g_,i=n*n+e*e+r*r;return i<1e-12&&(n=p_,e=d_,r=v_,s_<k_&&(n=f_,e=l_,r=h_),(i=n*n+e*e+r*r)<1e-12)?[NaN,NaN]:[R_(e,n)*C_,mr(r/B_(i))*C_]},ey=function(t){return function(){return t}},ry=function(t,n){function e(e,r){return e=t(e,r),n(e[0],e[1])}return t.invert&&n.invert&&(e.invert=function(e,r){return(e=n.invert(e,r))&&t.invert(e[0],e[1])}),e};ei.invert=ei;var iy,oy,uy,ay,cy,sy,fy,ly,hy,py,dy,vy=function(t){function n(n){return n=t(n[0]*z_,n[1]*z_),n[0]*=C_,n[1]*=C_,n}return t=ri(t[0]*z_,t[1]*z_,t.length>2?t[2]*z_:0),n.invert=function(n){return n=t.invert(n[0]*z_,n[1]*z_),n[0]*=C_,n[1]*=C_,n},n},_y=function(){function t(t,n){e.push(t=r(t,n)),t[0]*=C_,t[1]*=C_}function n(){var t=i.apply(this,arguments),n=o.apply(this,arguments)*z_,c=u.apply(this,arguments)*z_;return e=[],r=ri(-t[0]*z_,-t[1]*z_,0).invert,ai(a,n,c,1),t={type:\"Polygon\",coordinates:[e]},e=r=null,t}var e,r,i=ey([0,0]),o=ey(90),u=ey(6),a={point:t};return n.center=function(t){return arguments.length?(i=\"function\"==typeof t?t:ey([+t[0],+t[1]]),n):i},n.radius=function(t){return arguments.length?(o=\"function\"==typeof t?t:ey(+t),n):o},n.precision=function(t){return arguments.length?(u=\"function\"==typeof t?t:ey(+t),n):u},n},yy=function(){var t,n=[];return{point:function(n,e){t.push([n,e])},lineStart:function(){n.push(t=[])},lineEnd:br,rejoin:function(){n.length>1&&n.push(n.pop().concat(n.shift()))},result:function(){var e=n;return n=[],t=null,e}}},gy=function(t,n,e,r,i,o){var u,a=t[0],c=t[1],s=n[0],f=n[1],l=0,h=1,p=s-a,d=f-c;if(u=e-a,p||!(u>0)){if(u/=p,p<0){if(u<l)return;u<h&&(h=u)}else if(p>0){if(u>h)return;u>l&&(l=u)}if(u=i-a,p||!(u<0)){if(u/=p,p<0){if(u>h)return;u>l&&(l=u)}else if(p>0){if(u<l)return;u<h&&(h=u)}if(u=r-c,d||!(u>0)){if(u/=d,d<0){if(u<l)return;u<h&&(h=u)}else if(d>0){if(u>h)return;u>l&&(l=u)}if(u=o-c,d||!(u<0)){if(u/=d,d<0){if(u>h)return;u>l&&(l=u)}else if(d>0){if(u<l)return;u<h&&(h=u)}return l>0&&(t[0]=a+l*p,t[1]=c+l*d),h<1&&(n[0]=a+h*p,n[1]=c+h*d),!0}}}}},my=function(t,n){return P_(t[0]-n[0])<k_&&P_(t[1]-n[1])<k_},xy=function(t,n,e,r,i){var o,u,a=[],c=[];if(t.forEach(function(t){if(!((n=t.length-1)<=0)){var n,e,r=t[0],u=t[n];if(my(r,u)){for(i.lineStart(),o=0;o<n;++o)i.point((r=t[o])[0],r[1]);return void i.lineEnd()}a.push(e=new si(r,t,null,!0)),c.push(e.o=new si(r,null,e,!1)),a.push(e=new si(u,t,null,!1)),c.push(e.o=new si(u,null,e,!0))}}),a.length){for(c.sort(n),fi(a),fi(c),o=0,u=c.length;o<u;++o)c[o].e=e=!e;for(var s,f,l=a[0];;){for(var h=l,p=!0;h.v;)if((h=h.n)===l)return;s=h.z,i.lineStart();do{if(h.v=h.o.v=!0,h.e){if(p)for(o=0,u=s.length;o<u;++o)i.point((f=s[o])[0],f[1]);else r(h.x,h.n.x,1,i);h=h.n}else{if(p)for(s=h.p.z,o=s.length-1;o>=0;--o)i.point((f=s[o])[0],f[1]);else r(h.x,h.p.x,-1,i);h=h.p}h=h.o,s=h.z,p=!p}while(!h.v);i.lineEnd()}}},by=1e9,wy=-by,My=function(){var t,n,e,r=0,i=0,o=960,u=500;return e={stream:function(e){return t&&n===e?t:t=li(r,i,o,u)(n=e)},extent:function(a){return arguments.length?(r=+a[0][0],i=+a[0][1],o=+a[1][0],u=+a[1][1],t=n=null,e):[[r,i],[o,u]]}}},Ty=$v(),ky=function(t,n){var e=n[0],r=n[1],i=[I_(e),-q_(e),0],o=0,u=0;Ty.reset();for(var a=0,c=t.length;a<c;++a)if(f=(s=t[a]).length)for(var s,f,l=s[f-1],h=l[0],p=l[1]/2+E_,d=I_(p),v=q_(p),_=0;_<f;++_,h=g,d=x,v=b,l=y){var y=s[_],g=y[0],m=y[1]/2+E_,x=I_(m),b=q_(m),w=g-h,M=w>=0?1:-1,T=M*w,k=T>N_,N=d*x;if(Ty.add(R_(N*M*I_(T),v*b+N*q_(T))),o+=k?w+M*A_:w,k^h>=e^g>=e){var S=Pr(Cr(l),Cr(y));qr(S);var E=Pr(i,S);qr(E);var A=(k^w>=0?-1:1)*mr(E[2]);(r>A||r===A&&(S[0]||S[1]))&&(u+=k^w>=0?1:-1)}}return(o<-k_||o<k_&&Ty<-k_)^1&u},Ny=$v(),Sy={sphere:br,point:br,lineStart:hi,lineEnd:br,polygonStart:br,polygonEnd:br},Ey=function(t){return Ny.reset(),$_(t,Sy),+Ny},Ay=[null,null],Cy={type:\"LineString\",coordinates:Ay},zy=function(t,n){return Ay[0]=t,Ay[1]=n,Ey(Cy)},Py={Feature:function(t,n){return _i(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)if(_i(e[r].geometry,n))return!0;return!1}},Ly={Sphere:function(){return!0},Point:function(t,n){return yi(t.coordinates,n)},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(yi(e[r],n))return!0;return!1},LineString:function(t,n){return gi(t.coordinates,n)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(gi(e[r],n))return!0;return!1},Polygon:function(t,n){return mi(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(mi(e[r],n))return!0;return!1},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)if(_i(e[r],n))return!0;return!1}},Ry=function(t,n){return(t&&Py.hasOwnProperty(t.type)?Py[t.type]:_i)(t,n)},qy=function(t,n){var e=t[0]*z_,r=t[1]*z_,i=n[0]*z_,o=n[1]*z_,u=q_(r),a=I_(r),c=q_(o),s=I_(o),f=u*q_(e),l=u*I_(e),h=c*q_(i),p=c*I_(i),d=2*mr(B_(xr(o-r)+u*c*xr(i-e))),v=I_(d),_=d?function(t){var n=I_(t*=d)/v,e=I_(d-t)/v,r=e*f+n*h,i=e*l+n*p,o=e*a+n*s;return[R_(i,r)*C_,R_(o,B_(r*r+i*i))*C_]}:function(){return[e*C_,r*C_]};return _.distance=d,_},Uy=function(t){return t},Dy=$v(),Oy=$v(),Fy={point:br,lineStart:br,lineEnd:br,polygonStart:function(){Fy.lineStart=Ni,Fy.lineEnd=Ai},polygonEnd:function(){Fy.lineStart=Fy.lineEnd=Fy.point=br,Dy.add(P_(Oy)),Oy.reset()},result:function(){var t=Dy/2;return Dy.reset(),t}},Iy=1/0,Yy=Iy,By=-Iy,Hy=By,jy={point:Ci,lineStart:br,lineEnd:br,polygonStart:br,polygonEnd:br,result:function(){var t=[[Iy,Yy],[By,Hy]];return By=Hy=-(Yy=Iy=1/0),t}},Xy=0,$y=0,Vy=0,Wy=0,Zy=0,Gy=0,Jy=0,Qy=0,Ky=0,tg={point:zi,lineStart:Pi,lineEnd:qi,polygonStart:function(){tg.lineStart=Ui,tg.lineEnd=Di},polygonEnd:function(){tg.point=zi,tg.lineStart=Pi,tg.lineEnd=qi},result:function(){var t=Ky?[Jy/Ky,Qy/Ky]:Gy?[Wy/Gy,Zy/Gy]:Vy?[Xy/Vy,$y/Vy]:[NaN,NaN];return Xy=$y=Vy=Wy=Zy=Gy=Jy=Qy=Ky=0,t}};Ii.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._context.moveTo(t,n),this._point=1;break;case 1:this._context.lineTo(t,n);break;default:this._context.moveTo(t+this._radius,n),this._context.arc(t,n,this._radius,0,A_)}},result:br};var ng,eg,rg,ig,og,ug=$v(),ag={point:br,lineStart:function(){ag.point=Yi},lineEnd:function(){ng&&Bi(eg,rg),ag.point=br},polygonStart:function(){ng=!0},polygonEnd:function(){ng=null},result:function(){var t=+ug;return ug.reset(),t}};Hi.prototype={_radius:4.5,_circle:ji(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push(\"Z\"),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._string.push(\"M\",t,\",\",n),this._point=1;break;case 1:this._string.push(\"L\",t,\",\",n);break;default:null==this._circle&&(this._circle=ji(this._radius)),this._string.push(\"M\",t,\",\",n,this._circle)}},result:function(){if(this._string.length){var t=this._string.join(\"\");return this._string=[],t}return null}};var cg=function(t,n){function e(t){return t&&(\"function\"==typeof o&&i.pointRadius(+o.apply(this,arguments)),$_(t,r(i))),i.result()}var r,i,o=4.5;return e.area=function(t){return $_(t,r(Fy)),Fy.result()},e.measure=function(t){return $_(t,r(ag)),ag.result()},e.bounds=function(t){return $_(t,r(jy)),jy.result()},e.centroid=function(t){return $_(t,r(tg)),tg.result()},e.projection=function(n){return arguments.length?(r=null==n?(t=null,Uy):(t=n).stream,e):t},e.context=function(t){return arguments.length?(i=null==t?(n=null,new Hi):new Ii(n=t),\"function\"!=typeof o&&i.pointRadius(o),e):n},e.pointRadius=function(t){return arguments.length?(o=\"function\"==typeof t?t:(i.pointRadius(+t),+t),e):o},e.projection(t).context(n)},sg=function(t,n,e,r){return function(i,o){function u(n,e){var r=i(n,e);t(n=r[0],e=r[1])&&o.point(n,e)}function a(t,n){var e=i(t,n);_.point(e[0],e[1])}function c(){b.point=a,_.lineStart()}function s(){b.point=u,_.lineEnd()}function f(t,n){v.push([t,n]);var e=i(t,n);m.point(e[0],e[1])}function l(){m.lineStart(),v=[]}function h(){f(v[0][0],v[0][1]),m.lineEnd();var t,n,e,r,i=m.clean(),u=g.result(),a=u.length;if(v.pop(),p.push(v),v=null,a)if(1&i){if(e=u[0],(n=e.length-1)>0){for(x||(o.polygonStart(),x=!0),o.lineStart(),t=0;t<n;++t)o.point((r=e[t])[0],r[1]);o.lineEnd()}}else a>1&&2&i&&u.push(u.pop().concat(u.shift())),d.push(u.filter(Xi))}var p,d,v,_=n(o),y=i.invert(r[0],r[1]),g=yy(),m=n(g),x=!1,b={point:u,lineStart:c,lineEnd:s,polygonStart:function(){b.point=f,b.lineStart=l,b.lineEnd=h,d=[],p=[]},polygonEnd:function(){b.point=u,b.lineStart=c,b.lineEnd=s,d=bf(d);var t=ky(p,y);d.length?(x||(o.polygonStart(),x=!0),xy(d,$i,t,e,o)):t&&(x||(o.polygonStart(),x=!0),o.lineStart(),e(null,null,1,o),o.lineEnd()),x&&(o.polygonEnd(),x=!1),d=p=null},sphere:function(){o.polygonStart(),o.lineStart(),e(null,null,1,o),o.lineEnd(),o.polygonEnd()}};return b}},fg=sg(function(){return!0},Vi,Zi,[-N_,-S_]),lg=function(t,n){function e(e,r,i,o){ai(o,t,n,i,e,r)}function r(t,n){return q_(t)*q_(n)>a}function i(t){var n,e,i,a,f;return{lineStart:function(){a=i=!1,f=1},point:function(l,h){var p,d=[l,h],v=r(l,h),_=c?v?0:u(l,h):v?u(l+(l<0?N_:-N_),h):0;if(!n&&(a=i=v)&&t.lineStart(),v!==i&&(!(p=o(n,d))||my(n,p)||my(d,p))&&(d[0]+=k_,d[1]+=k_,v=r(d[0],d[1])),v!==i)f=0,v?(t.lineStart(),p=o(d,n),t.point(p[0],p[1])):(p=o(n,d),t.point(p[0],p[1]),t.lineEnd()),n=p;else if(s&&n&&c^v){var y;_&e||!(y=o(d,n,!0))||(f=0,c?(t.lineStart(),t.point(y[0][0],y[0][1]),t.point(y[1][0],y[1][1]),t.lineEnd()):(t.point(y[1][0],y[1][1]),t.lineEnd(),t.lineStart(),t.point(y[0][0],y[0][1])))}!v||n&&my(n,d)||t.point(d[0],d[1]),n=d,i=v,e=_},lineEnd:function(){i&&t.lineEnd(),n=null},clean:function(){return f|(a&&i)<<1}}}function o(t,n,e){var r=Cr(t),i=Cr(n),o=[1,0,0],u=Pr(r,i),c=zr(u,u),s=u[0],f=c-s*s;if(!f)return!e&&t;var l=a*c/f,h=-a*s/f,p=Pr(o,u),d=Rr(o,l);Lr(d,Rr(u,h));var v=p,_=zr(d,v),y=zr(v,v),g=_*_-y*(zr(d,d)-1);if(!(g<0)){var m=B_(g),x=Rr(v,(-_-m)/y);if(Lr(x,d),x=Ar(x),!e)return x;var b,w=t[0],M=n[0],T=t[1],k=n[1];M<w&&(b=w,w=M,M=b);var N=M-w,S=P_(N-N_)<k_,E=S||N<k_;if(!S&&k<T&&(b=T,T=k,k=b),E?S?T+k>0^x[1]<(P_(x[0]-w)<k_?T:k):T<=x[1]&&x[1]<=k:N>N_^(w<=x[0]&&x[0]<=M)){var A=Rr(v,(-_+m)/y);return Lr(A,d),[x,Ar(A)]}}}function u(n,e){var r=c?t:N_-t,i=0;return n<-r?i|=1:n>r&&(i|=2),e<-r?i|=4:e>r&&(i|=8),i}var a=q_(t),c=a>0,s=P_(a)>k_;return sg(r,i,e,c?[0,-t]:[-N_,t-N_])},hg=function(t){return{stream:Gi(t)}};Ji.prototype={constructor:Ji,point:function(t,n){this.stream.point(t,n)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};var pg=16,dg=q_(30*z_),vg=function(t,n){return+n?no(t,n):to(t)},_g=Gi({point:function(t,n){this.stream.point(t*z_,n*z_)}}),yg=function(){return io(uo).scale(155.424).center([0,33.6442])},gg=function(){return yg().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])},mg=function(){function t(t){var n=t[0],e=t[1];return a=null,i.point(n,e),a||(o.point(n,e),a)||(u.point(n,e),a)}function n(){return e=r=null,t}var e,r,i,o,u,a,c=gg(),s=yg().rotate([154,0]).center([-2,58.5]).parallels([55,65]),f=yg().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l={point:function(t,n){a=[t,n]}};return t.invert=function(t){var n=c.scale(),e=c.translate(),r=(t[0]-e[0])/n,i=(t[1]-e[1])/n;return(i>=.12&&i<.234&&r>=-.425&&r<-.214?s:i>=.166&&i<.234&&r>=-.214&&r<-.115?f:c).invert(t)},t.stream=function(t){return e&&r===t?e:e=ao([c.stream(r=t),s.stream(t),f.stream(t)])},t.precision=function(t){return arguments.length?(c.precision(t),s.precision(t),f.precision(t),n()):c.precision()},t.scale=function(n){return arguments.length?(c.scale(n),s.scale(.35*n),f.scale(n),t.translate(c.translate())):c.scale()},t.translate=function(t){if(!arguments.length)return c.translate();var e=c.scale(),r=+t[0],a=+t[1];return i=c.translate(t).clipExtent([[r-.455*e,a-.238*e],[r+.455*e,a+.238*e]]).stream(l),o=s.translate([r-.307*e,a+.201*e]).clipExtent([[r-.425*e+k_,a+.12*e+k_],[r-.214*e-k_,a+.234*e-k_]]).stream(l),u=f.translate([r-.205*e,a+.212*e]).clipExtent([[r-.214*e+k_,a+.166*e+k_],[r-.115*e-k_,a+.234*e-k_]]).stream(l),n()},t.fitExtent=function(n,e){return Qi(t,n,e)},t.fitSize=function(n,e){return Ki(t,n,e)},t.scale(1070)},xg=co(function(t){return B_(2/(1+t))});xg.invert=so(function(t){return 2*mr(t/2)});var bg=function(){return eo(xg).scale(124.75).clipAngle(179.999)},wg=co(function(t){return(t=gr(t))&&t/I_(t)});wg.invert=so(function(t){return t});var Mg=function(){return eo(wg).scale(79.4188).clipAngle(179.999)};fo.invert=function(t,n){return[t,2*L_(D_(n))-S_]};var Tg=function(){return lo(fo).scale(961/A_)},kg=function(){return io(po).scale(109.5).parallels([30,30])};vo.invert=vo;var Ng=function(){return eo(vo).scale(152.63)},Sg=function(){return io(_o).scale(131.154).center([0,13.9389])};yo.invert=so(L_);var Eg=function(){return eo(yo).scale(144.049).clipAngle(60)},Ag=function(){function t(){return i=o=null,u}var n,e,r,i,o,u,a=1,c=0,s=0,f=1,l=1,h=Uy,p=null,d=Uy;return u={stream:function(t){return i&&o===t?i:i=h(d(o=t))},clipExtent:function(i){return arguments.length?(d=null==i?(p=n=e=r=null,Uy):li(p=+i[0][0],n=+i[0][1],e=+i[1][0],r=+i[1][1]),t()):null==p?null:[[p,n],[e,r]]},scale:function(n){return arguments.length?(h=go((a=+n)*f,a*l,c,s),t()):a},translate:function(n){return arguments.length?(h=go(a*f,a*l,c=+n[0],s=+n[1]),t()):[c,s]},reflectX:function(n){return arguments.length?(h=go(a*(f=n?-1:1),a*l,c,s),t()):f<0},reflectY:function(n){return arguments.length?(h=go(a*f,a*(l=n?-1:1),c,s),t()):l<0},fitExtent:function(t,n){return Qi(u,t,n)},fitSize:function(t,n){return Ki(u,t,n)}}};mo.invert=so(mr);var Cg=function(){return eo(mo).scale(249.5).clipAngle(90+k_)};xo.invert=so(function(t){return 2*L_(t)});var zg=function(){return eo(xo).scale(250).clipAngle(142)};bo.invert=function(t,n){return[-n,2*L_(D_(t))-S_]};var Pg=function(){var t=lo(bo),n=t.center,e=t.rotate;return t.center=function(t){return arguments.length?n([-t[1],t[0]]):(t=n(),[t[1],-t[0]])},t.rotate=function(t){return arguments.length?e([t[0],t[1],t.length>2?t[2]+90:90]):(t=e(),[t[0],t[1],t[2]-90])},e([0,0,90]).scale(159.155)},Lg=function(){function t(t){var o,u=0;t.eachAfter(function(t){var e=t.children;e?(t.x=Mo(e),t.y=ko(e)):(t.x=o?u+=n(t,o):0,t.y=0,o=t)});var a=So(t),c=Eo(t),s=a.x-n(a,c)/2,f=c.x+n(c,a)/2;return t.eachAfter(i?function(n){n.x=(n.x-t.x)*e,n.y=(t.y-n.y)*r}:function(n){n.x=(n.x-s)/(f-s)*e,n.y=(1-(t.y?n.y/t.y:1))*r})}var n=wo,e=1,r=1,i=!1;return t.separation=function(e){return arguments.length?(n=e,t):n},t.size=function(n){return arguments.length?(i=!1,e=+n[0],r=+n[1],t):i?null:[e,r]},t.nodeSize=function(n){return arguments.length?(i=!0,e=+n[0],r=+n[1],t):i?[e,r]:null},t},Rg=function(){return this.eachAfter(Ao)},qg=function(t){var n,e,r,i,o=this,u=[o];do{for(n=u.reverse(),u=[];o=n.pop();)if(t(o),e=o.children)for(r=0,i=e.length;r<i;++r)u.push(e[r])}while(u.length);return this},Ug=function(t){for(var n,e,r=this,i=[r];r=i.pop();)if(t(r),n=r.children)for(e=n.length-1;e>=0;--e)i.push(n[e]);return this},Dg=function(t){for(var n,e,r,i=this,o=[i],u=[];i=o.pop();)if(u.push(i),n=i.children)for(e=0,r=n.length;e<r;++e)o.push(n[e]);for(;i=u.pop();)t(i);return this},Og=function(t){return this.eachAfter(function(n){for(var e=+t(n.data)||0,r=n.children,i=r&&r.length;--i>=0;)e+=r[i].value;n.value=e})},Fg=function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})},Ig=function(t){for(var n=this,e=Co(n,t),r=[n];n!==e;)n=n.parent,r.push(n);for(var i=r.length;t!==e;)r.splice(i,0,t),t=t.parent;return r},Yg=function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n},Bg=function(){var t=[];return this.each(function(n){t.push(n)}),t},Hg=function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t},jg=function(){var t=this,n=[];return t.each(function(e){e!==t&&n.push({source:e.parent,target:e})}),n};Uo.prototype=zo.prototype={constructor:Uo,count:Rg,each:qg,eachAfter:Dg,eachBefore:Ug,sum:Og,sort:Fg,path:Ig,ancestors:Yg,descendants:Bg,leaves:Hg,links:jg,copy:Po};var Xg=function(t){for(var n=(t=t.slice()).length,e=null,r=e;n;){var i=new Do(t[n-1]);r=r?r.next=i:e=i,t[void 0]=t[--n]}return{head:e,tail:r}},$g=function(t){return Fo(Xg(t),[])},Vg=function(t){return Vo(t),t},Wg=function(t){return function(){return t}},Zg=function(){function t(t){return t.x=e/2,t.y=r/2,n?t.eachBefore(Qo(n)).eachAfter(Ko(i,.5)).eachBefore(tu(1)):t.eachBefore(Qo(Jo)).eachAfter(Ko(Go,1)).eachAfter(Ko(i,t.r/Math.min(e,r))).eachBefore(tu(Math.min(e,r)/(2*t.r))),t}var n=null,e=1,r=1,i=Go;return t.radius=function(e){return arguments.length?(n=Wo(e),t):n},t.size=function(n){return arguments.length?(e=+n[0],r=+n[1],t):[e,r]},t.padding=function(n){return arguments.length?(i=\"function\"==typeof n?n:Wg(+n),t):i},t},Gg=function(t){t.x0=Math.round(t.x0),t.y0=Math.round(t.y0),t.x1=Math.round(t.x1),t.y1=Math.round(t.y1)},Jg=function(t,n,e,r,i){for(var o,u=t.children,a=-1,c=u.length,s=t.value&&(r-n)/t.value;++a<c;)o=u[a],o.y0=e,o.y1=i,o.x0=n,o.x1=n+=o.value*s},Qg=function(){function t(t){var u=t.height+1;return t.x0=t.y0=i,t.x1=e,t.y1=r/u,t.eachBefore(n(r,u)),o&&t.eachBefore(Gg),t}function n(t,n){return function(e){e.children&&Jg(e,e.x0,t*(e.depth+1)/n,e.x1,t*(e.depth+2)/n);var r=e.x0,o=e.y0,u=e.x1-i,a=e.y1-i;u<r&&(r=u=(r+u)/2),a<o&&(o=a=(o+a)/2),e.x0=r,e.y0=o,e.x1=u,e.y1=a}}var e=1,r=1,i=0,o=!1;return t.round=function(n){return arguments.length?(o=!!n,t):o},t.size=function(n){return arguments.length?(e=+n[0],r=+n[1],t):[e,r]},t.padding=function(n){return arguments.length?(i=+n,t):i},t},Kg=\"$\",tm={depth:-1},nm={},em=function(){function t(t){var r,i,o,u,a,c,s,f=t.length,l=new Array(f),h={};for(i=0;i<f;++i)r=t[i],a=l[i]=new Uo(r),null!=(c=n(r,i,t))&&(c+=\"\")&&(s=Kg+(a.id=c),h[s]=s in h?nm:a);for(i=0;i<f;++i)if(a=l[i],null!=(c=e(t[i],i,t))&&(c+=\"\")){if(!(u=h[Kg+c]))throw new Error(\"missing: \"+c);if(u===nm)throw new Error(\"ambiguous: \"+c);u.children?u.children.push(a):u.children=[a],a.parent=u}else{if(o)throw new Error(\"multiple roots\");o=a}if(!o)throw new Error(\"no root\");if(o.parent=tm,o.eachBefore(function(t){t.depth=t.parent.depth+1,--f}).eachBefore(qo),o.parent=null,f>0)throw new Error(\"cycle\");return o}var n=nu,e=eu;return t.id=function(e){return arguments.length?(n=Zo(e),t):n},t.parentId=function(n){return arguments.length?(e=Zo(n),t):e},t};su.prototype=Object.create(Uo.prototype);var rm=function(){function t(t){var r=fu(t);if(r.eachAfter(n),r.parent.m=-r.z,r.eachBefore(e),c)t.eachBefore(i);else{var s=t,f=t,l=t;t.eachBefore(function(t){t.x<s.x&&(s=t),t.x>f.x&&(f=t),t.depth>l.depth&&(l=t)});var h=s===f?1:o(s,f)/2,p=h-s.x,d=u/(f.x+h+p),v=a/(l.depth||1);t.eachBefore(function(t){t.x=(t.x+p)*d,t.y=t.depth*v})}return t}function n(t){var n=t.children,e=t.parent.children,i=t.i?e[t.i-1]:null;if(n){au(t);var u=(n[0].z+n[n.length-1].z)/2;i?(t.z=i.z+o(t._,i._),t.m=t.z-u):t.z=u}else i&&(t.z=i.z+o(t._,i._));t.parent.A=r(t,i,t.parent.A||e[0])}function e(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function r(t,n,e){if(n){for(var r,i=t,u=t,a=n,c=i.parent.children[0],s=i.m,f=u.m,l=a.m,h=c.m;a=ou(a),i=iu(i),a&&i;)c=iu(c),u=ou(u),u.a=t,r=a.z+l-i.z-s+o(a._,i._),r>0&&(uu(cu(a,t,e),t,r),s+=r,f+=r),l+=a.m,s+=i.m,h+=c.m,f+=u.m;a&&!ou(u)&&(u.t=a,u.m+=l-f),i&&!iu(c)&&(c.t=i,c.m+=s-h,e=t)}return e}function i(t){t.x*=u,t.y=t.depth*a}var o=ru,u=1,a=1,c=null;return t.separation=function(n){return arguments.length?(o=n,t):o},t.size=function(n){return arguments.length?(c=!1,u=+n[0],a=+n[1],t):c?null:[u,a]},t.nodeSize=function(n){return arguments.length?(c=!0,u=+n[0],a=+n[1],t):c?[u,a]:null},t},im=function(t,n,e,r,i){for(var o,u=t.children,a=-1,c=u.length,s=t.value&&(i-e)/t.value;++a<c;)o=u[a],o.x0=n,o.x1=r,o.y0=e,o.y1=e+=o.value*s},om=(1+Math.sqrt(5))/2,um=function t(n){function e(t,e,r,i,o){lu(n,t,e,r,i,o)}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}(om),am=function(){function t(t){return t.x0=t.y0=0,t.x1=i,t.y1=o,t.eachBefore(n),u=[0],r&&t.eachBefore(Gg),t}function n(t){var n=u[t.depth],r=t.x0+n,i=t.y0+n,o=t.x1-n,h=t.y1-n;o<r&&(r=o=(r+o)/2),h<i&&(i=h=(i+h)/2),t.x0=r,t.y0=i,t.x1=o,t.y1=h,\nt.children&&(n=u[t.depth+1]=a(t)/2,r+=l(t)-n,i+=c(t)-n,o-=s(t)-n,h-=f(t)-n,o<r&&(r=o=(r+o)/2),h<i&&(i=h=(i+h)/2),e(t,r,i,o,h))}var e=um,r=!1,i=1,o=1,u=[0],a=Go,c=Go,s=Go,f=Go,l=Go;return t.round=function(n){return arguments.length?(r=!!n,t):r},t.size=function(n){return arguments.length?(i=+n[0],o=+n[1],t):[i,o]},t.tile=function(n){return arguments.length?(e=Zo(n),t):e},t.padding=function(n){return arguments.length?t.paddingInner(n).paddingOuter(n):t.paddingInner()},t.paddingInner=function(n){return arguments.length?(a=\"function\"==typeof n?n:Wg(+n),t):a},t.paddingOuter=function(n){return arguments.length?t.paddingTop(n).paddingRight(n).paddingBottom(n).paddingLeft(n):t.paddingTop()},t.paddingTop=function(n){return arguments.length?(c=\"function\"==typeof n?n:Wg(+n),t):c},t.paddingRight=function(n){return arguments.length?(s=\"function\"==typeof n?n:Wg(+n),t):s},t.paddingBottom=function(n){return arguments.length?(f=\"function\"==typeof n?n:Wg(+n),t):f},t.paddingLeft=function(n){return arguments.length?(l=\"function\"==typeof n?n:Wg(+n),t):l},t},cm=function(t,n,e,r,i){function o(t,n,e,r,i,u,a){if(t>=n-1){var s=c[t];return s.x0=r,s.y0=i,s.x1=u,s.y1=a,void 0}for(var l=f[t],h=e/2+l,p=t+1,d=n-1;p<d;){var v=p+d>>>1;f[v]<h?p=v+1:d=v}h-f[p-1]<f[p]-h&&t+1<p&&--p;var _=f[p]-l,y=e-_;if(u-r>a-i){var g=(r*y+u*_)/e;o(t,p,_,r,i,g,a),o(p,n,y,g,i,u,a)}else{var m=(i*y+a*_)/e;o(t,p,_,r,i,u,m),o(p,n,y,r,m,u,a)}}var u,a,c=t.children,s=c.length,f=new Array(s+1);for(f[0]=a=u=0;u<s;++u)f[u+1]=a+=c[u].value;o(0,s,t.value,n,e,r,i)},sm=function(t,n,e,r,i){(1&t.depth?im:Jg)(t,n,e,r,i)},fm=function t(n){function e(t,e,r,i,o){if((u=t._squarify)&&u.ratio===n)for(var u,a,c,s,f,l=-1,h=u.length,p=t.value;++l<h;){for(a=u[l],c=a.children,s=a.value=0,f=c.length;s<f;++s)a.value+=c[s].value;a.dice?Jg(a,e,r,i,r+=(o-r)*a.value/p):im(a,e,r,e+=(i-e)*a.value/p,o),p-=a.value}else t._squarify=u=lu(n,t,e,r,i,o),u.ratio=n}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}(om),lm=function(t){for(var n,e=-1,r=t.length,i=t[r-1],o=0;++e<r;)n=i,i=t[e],o+=n[1]*i[0]-n[0]*i[1];return o/2},hm=function(t){for(var n,e,r=-1,i=t.length,o=0,u=0,a=t[i-1],c=0;++r<i;)n=a,a=t[r],c+=e=n[0]*a[1]-a[0]*n[1],o+=(n[0]+a[0])*e,u+=(n[1]+a[1])*e;return c*=3,[o/c,u/c]},pm=function(t,n,e){return(n[0]-t[0])*(e[1]-t[1])-(n[1]-t[1])*(e[0]-t[0])},dm=function(t){if((e=t.length)<3)return null;var n,e,r=new Array(e),i=new Array(e);for(n=0;n<e;++n)r[n]=[+t[n][0],+t[n][1],n];for(r.sort(hu),n=0;n<e;++n)i[n]=[r[n][0],-r[n][1]];var o=pu(r),u=pu(i),a=u[0]===o[0],c=u[u.length-1]===o[o.length-1],s=[];for(n=o.length-1;n>=0;--n)s.push(t[r[o[n]][2]]);for(n=+a;n<u.length-c;++n)s.push(t[r[u[n]][2]]);return s},vm=function(t,n){for(var e,r,i=t.length,o=t[i-1],u=n[0],a=n[1],c=o[0],s=o[1],f=!1,l=0;l<i;++l)o=t[l],e=o[0],r=o[1],r>a!=s>a&&u<(c-e)*(a-r)/(s-r)+e&&(f=!f),c=e,s=r;return f},_m=function(t){for(var n,e,r=-1,i=t.length,o=t[i-1],u=o[0],a=o[1],c=0;++r<i;)n=u,e=a,o=t[r],u=o[0],a=o[1],n-=u,e-=a,c+=Math.sqrt(n*n+e*e);return c},ym=[].slice,gm={};du.prototype=xu.prototype={constructor:du,defer:function(t){if(\"function\"!=typeof t)throw new Error(\"invalid callback\");if(this._call)throw new Error(\"defer after await\");if(null!=this._error)return this;var n=ym.call(arguments,1);return n.push(t),++this._waiting,this._tasks.push(n),vu(this),this},abort:function(){return null==this._error&&gu(this,new Error(\"abort\")),this},await:function(t){if(\"function\"!=typeof t)throw new Error(\"invalid callback\");if(this._call)throw new Error(\"multiple await\");return this._call=function(n,e){t.apply(null,[n].concat(e))},mu(this),this},awaitAll:function(t){if(\"function\"!=typeof t)throw new Error(\"invalid callback\");if(this._call)throw new Error(\"multiple await\");return this._call=t,mu(this),this}};var mm=function(){return Math.random()},xm=function t(n){function e(t,e){return t=null==t?0:+t,e=null==e?1:+e,1===arguments.length?(e=t,t=0):e-=t,function(){return n()*e+t}}return e.source=t,e}(mm),bm=function t(n){function e(t,e){var r,i;return t=null==t?0:+t,e=null==e?1:+e,function(){var o;if(null!=r)o=r,r=null;else do{r=2*n()-1,o=2*n()-1,i=r*r+o*o}while(!i||i>1);return t+e*o*Math.sqrt(-2*Math.log(i)/i)}}return e.source=t,e}(mm),wm=function t(n){function e(){var t=bm.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return e.source=t,e}(mm),Mm=function t(n){function e(t){return function(){for(var e=0,r=0;r<t;++r)e+=n();return e}}return e.source=t,e}(mm),Tm=function t(n){function e(t){var e=Mm.source(n)(t);return function(){return e()/t}}return e.source=t,e}(mm),km=function t(n){function e(t){return function(){return-Math.log(1-n())/t}}return e.source=t,e}(mm),Nm=function(t,n){function e(t){var n,e=s.status;if(!e&&wu(s)||e>=200&&e<300||304===e){if(o)try{n=o.call(r,s)}catch(t){return void a.call(\"error\",r,t)}else n=s;a.call(\"load\",r,n)}else a.call(\"error\",r,t)}var r,i,o,u,a=v(\"beforesend\",\"progress\",\"load\",\"error\"),c=He(),s=new XMLHttpRequest,f=null,l=null,h=0;if(\"undefined\"==typeof XDomainRequest||\"withCredentials\"in s||!/^(http(s)?:)?\\/\\//.test(t)||(s=new XDomainRequest),\"onload\"in s?s.onload=s.onerror=s.ontimeout=e:s.onreadystatechange=function(t){s.readyState>3&&e(t)},s.onprogress=function(t){a.call(\"progress\",r,t)},r={header:function(t,n){return t=(t+\"\").toLowerCase(),arguments.length<2?c.get(t):(null==n?c.remove(t):c.set(t,n+\"\"),r)},mimeType:function(t){return arguments.length?(i=null==t?null:t+\"\",r):i},responseType:function(t){return arguments.length?(u=t,r):u},timeout:function(t){return arguments.length?(h=+t,r):h},user:function(t){return arguments.length<1?f:(f=null==t?null:t+\"\",r)},password:function(t){return arguments.length<1?l:(l=null==t?null:t+\"\",r)},response:function(t){return o=t,r},get:function(t,n){return r.send(\"GET\",t,n)},post:function(t,n){return r.send(\"POST\",t,n)},send:function(n,e,o){return s.open(n,t,!0,f,l),null==i||c.has(\"accept\")||c.set(\"accept\",i+\",*/*\"),s.setRequestHeader&&c.each(function(t,n){s.setRequestHeader(n,t)}),null!=i&&s.overrideMimeType&&s.overrideMimeType(i),null!=u&&(s.responseType=u),h>0&&(s.timeout=h),null==o&&\"function\"==typeof e&&(o=e,e=null),null!=o&&1===o.length&&(o=bu(o)),null!=o&&r.on(\"error\",o).on(\"load\",function(t){o(null,t)}),a.call(\"beforesend\",r,s),s.send(null==e?null:e),r},abort:function(){return s.abort(),r},on:function(){var t=a.on.apply(a,arguments);return t===a?r:t}},null!=n){if(\"function\"!=typeof n)throw new Error(\"invalid callback: \"+n);return r.get(n)}return r},Sm=function(t,n){return function(e,r){var i=Nm(e).mimeType(t).response(n);if(null!=r){if(\"function\"!=typeof r)throw new Error(\"invalid callback: \"+r);return i.get(r)}return i}},Em=Sm(\"text/html\",function(t){return document.createRange().createContextualFragment(t.responseText)}),Am=Sm(\"application/json\",function(t){return JSON.parse(t.responseText)}),Cm=Sm(\"text/plain\",function(t){return t.responseText}),zm=Sm(\"application/xml\",function(t){var n=t.responseXML;if(!n)throw new Error(\"parse error\");return n}),Pm=function(t,n){return function(e,r,i){arguments.length<3&&(i=r,r=null);var o=Nm(e).mimeType(t);return o.row=function(t){return arguments.length?o.response(Mu(n,r=t)):r},o.row(r),i?o.get(i):o}},Lm=Pm(\"text/csv\",Zd),Rm=Pm(\"text/tab-separated-values\",tv),qm=Array.prototype,Um=qm.map,Dm=qm.slice,Om={name:\"implicit\"},Fm=function(t){return function(){return t}},Im=function(t){return+t},Ym=[0,1],Bm=function(n,e,r){var o,u=n[0],a=n[n.length-1],c=i(u,a,null==e?10:e);switch(r=pr(null==r?\",f\":r),r.type){case\"s\":var s=Math.max(Math.abs(u),Math.abs(a));return null!=r.precision||isNaN(o=jv(c,s))||(r.precision=o),t.formatPrefix(r,s);case\"\":case\"e\":case\"g\":case\"p\":case\"r\":null!=r.precision||isNaN(o=Xv(c,Math.max(Math.abs(u),Math.abs(a))))||(r.precision=o-(\"e\"===r.type));break;case\"f\":case\"%\":null!=r.precision||isNaN(o=Hv(c))||(r.precision=o-2*(\"%\"===r.type))}return t.format(r)},Hm=function(t,n){t=t.slice();var e,r=0,i=t.length-1,o=t[r],u=t[i];return u<o&&(e=r,r=i,i=e,e=o,o=u,u=e),t[r]=n.floor(o),t[i]=n.ceil(u),t},jm=new Date,Xm=new Date,$m=Ju(function(){},function(t,n){t.setTime(+t+n)},function(t,n){return n-t});$m.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?Ju(function(n){n.setTime(Math.floor(n/t)*t)},function(n,e){n.setTime(+n+e*t)},function(n,e){return(e-n)/t}):$m:null};var Vm=$m.range,Wm=6e4,Zm=6048e5,Gm=Ju(function(t){t.setTime(1e3*Math.floor(t/1e3))},function(t,n){t.setTime(+t+1e3*n)},function(t,n){return(n-t)/1e3},function(t){return t.getUTCSeconds()}),Jm=Gm.range,Qm=Ju(function(t){t.setTime(Math.floor(t/Wm)*Wm)},function(t,n){t.setTime(+t+n*Wm)},function(t,n){return(n-t)/Wm},function(t){return t.getMinutes()}),Km=Qm.range,tx=Ju(function(t){var n=t.getTimezoneOffset()*Wm%36e5;n<0&&(n+=36e5),t.setTime(36e5*Math.floor((+t-n)/36e5)+n)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getHours()}),nx=tx.range,ex=Ju(function(t){t.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Wm)/864e5},function(t){return t.getDate()-1}),rx=ex.range,ix=Qu(0),ox=Qu(1),ux=Qu(2),ax=Qu(3),cx=Qu(4),sx=Qu(5),fx=Qu(6),lx=ix.range,hx=ox.range,px=ux.range,dx=ax.range,vx=cx.range,_x=sx.range,yx=fx.range,gx=Ju(function(t){t.setDate(1),t.setHours(0,0,0,0)},function(t,n){t.setMonth(t.getMonth()+n)},function(t,n){return n.getMonth()-t.getMonth()+12*(n.getFullYear()-t.getFullYear())},function(t){return t.getMonth()}),mx=gx.range,xx=Ju(function(t){t.setMonth(0,1),t.setHours(0,0,0,0)},function(t,n){t.setFullYear(t.getFullYear()+n)},function(t,n){return n.getFullYear()-t.getFullYear()},function(t){return t.getFullYear()});xx.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Ju(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,e){n.setFullYear(n.getFullYear()+e*t)}):null};var bx=xx.range,wx=Ju(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*Wm)},function(t,n){return(n-t)/Wm},function(t){return t.getUTCMinutes()}),Mx=wx.range,Tx=Ju(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getUTCHours()}),kx=Tx.range,Nx=Ju(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/864e5},function(t){return t.getUTCDate()-1}),Sx=Nx.range,Ex=Ku(0),Ax=Ku(1),Cx=Ku(2),zx=Ku(3),Px=Ku(4),Lx=Ku(5),Rx=Ku(6),qx=Ex.range,Ux=Ax.range,Dx=Cx.range,Ox=zx.range,Fx=Px.range,Ix=Lx.range,Yx=Rx.range,Bx=Ju(function(t){t.setUTCDate(1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCMonth(t.getUTCMonth()+n)},function(t,n){return n.getUTCMonth()-t.getUTCMonth()+12*(n.getUTCFullYear()-t.getUTCFullYear())},function(t){return t.getUTCMonth()}),Hx=Bx.range,jx=Ju(function(t){t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCFullYear(t.getUTCFullYear()+n)},function(t,n){return n.getUTCFullYear()-t.getUTCFullYear()},function(t){return t.getUTCFullYear()});jx.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Ju(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,e){n.setUTCFullYear(n.getUTCFullYear()+e*t)}):null};var Xx,$x=jx.range,Vx={\"-\":\"\",_:\" \",0:\"0\"},Wx=/^\\s*\\d+/,Zx=/^%/,Gx=/[\\\\\\^\\$\\*\\+\\?\\|\\[\\]\\(\\)\\.\\{\\}]/g;Ja({dateTime:\"%x, %X\",date:\"%-m/%-d/%Y\",time:\"%-I:%M:%S %p\",periods:[\"AM\",\"PM\"],days:[\"Sunday\",\"Monday\",\"Tuesday\",\"Wednesday\",\"Thursday\",\"Friday\",\"Saturday\"],shortDays:[\"Sun\",\"Mon\",\"Tue\",\"Wed\",\"Thu\",\"Fri\",\"Sat\"],months:[\"January\",\"February\",\"March\",\"April\",\"May\",\"June\",\"July\",\"August\",\"September\",\"October\",\"November\",\"December\"],shortMonths:[\"Jan\",\"Feb\",\"Mar\",\"Apr\",\"May\",\"Jun\",\"Jul\",\"Aug\",\"Sep\",\"Oct\",\"Nov\",\"Dec\"]});var Jx=Date.prototype.toISOString?Qa:t.utcFormat(\"%Y-%m-%dT%H:%M:%S.%LZ\"),Qx=+new Date(\"2000-01-01T00:00:00.000Z\")?Ka:t.utcParse(\"%Y-%m-%dT%H:%M:%S.%LZ\"),Kx=1e3,tb=60*Kx,nb=60*tb,eb=24*nb,rb=7*eb,ib=30*eb,ob=365*eb,ub=function(){return ec(xx,gx,ix,ex,tx,Qm,Gm,$m,t.timeFormat).domain([new Date(2e3,0,1),new Date(2e3,0,2)])},ab=function(){return ec(jx,Bx,Ex,Nx,Tx,wx,Gm,$m,t.utcFormat).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])},cb=function(t){return t.match(/.{6}/g).map(function(t){return\"#\"+t})},sb=cb(\"1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf\"),fb=cb(\"393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6\"),lb=cb(\"3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9\"),hb=cb(\"1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5\"),pb=Zh(Wt(300,.5,0),Wt(-240,.5,1)),db=Zh(Wt(-100,.75,.35),Wt(80,1.5,.8)),vb=Zh(Wt(260,.75,.35),Wt(80,1.5,.8)),_b=Wt(),yb=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return _b.h=360*t-100,_b.s=1.5-1.5*n,_b.l=.8-.9*n,_b+\"\"},gb=rc(cb(\"44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725\")),mb=rc(cb(\"00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf\")),xb=rc(cb(\"00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4\")),bb=rc(cb(\"0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921\")),wb=function(t){return function(){return t}},Mb=Math.abs,Tb=Math.atan2,kb=Math.cos,Nb=Math.max,Sb=Math.min,Eb=Math.sin,Ab=Math.sqrt,Cb=1e-12,zb=Math.PI,Pb=zb/2,Lb=2*zb,Rb=function(){function t(){var t,s,f=+n.apply(this,arguments),l=+e.apply(this,arguments),h=o.apply(this,arguments)-Pb,p=u.apply(this,arguments)-Pb,d=Mb(p-h),v=p>h;if(c||(c=t=Ue()),l<f&&(s=l,l=f,f=s),l>Cb)if(d>Lb-Cb)c.moveTo(l*kb(h),l*Eb(h)),c.arc(0,0,l,h,p,!v),f>Cb&&(c.moveTo(f*kb(p),f*Eb(p)),c.arc(0,0,f,p,h,v));else{var _,y,g=h,m=p,x=h,b=p,w=d,M=d,T=a.apply(this,arguments)/2,k=T>Cb&&(i?+i.apply(this,arguments):Ab(f*f+l*l)),N=Sb(Mb(l-f)/2,+r.apply(this,arguments)),S=N,E=N;if(k>Cb){var A=uc(k/f*Eb(T)),C=uc(k/l*Eb(T));(w-=2*A)>Cb?(A*=v?1:-1,x+=A,b-=A):(w=0,x=b=(h+p)/2),(M-=2*C)>Cb?(C*=v?1:-1,g+=C,m-=C):(M=0,g=m=(h+p)/2)}var z=l*kb(g),P=l*Eb(g),L=f*kb(b),R=f*Eb(b);if(N>Cb){var q=l*kb(m),U=l*Eb(m),D=f*kb(x),O=f*Eb(x);if(d<zb){var F=w>Cb?hc(z,P,D,O,q,U,L,R):[L,R],I=z-F[0],Y=P-F[1],B=q-F[0],H=U-F[1],j=1/Eb(oc((I*B+Y*H)/(Ab(I*I+Y*Y)*Ab(B*B+H*H)))/2),X=Ab(F[0]*F[0]+F[1]*F[1]);S=Sb(N,(f-X)/(j-1)),E=Sb(N,(l-X)/(j+1))}}M>Cb?E>Cb?(_=pc(D,O,z,P,l,E,v),y=pc(q,U,L,R,l,E,v),c.moveTo(_.cx+_.x01,_.cy+_.y01),E<N?c.arc(_.cx,_.cy,E,Tb(_.y01,_.x01),Tb(y.y01,y.x01),!v):(c.arc(_.cx,_.cy,E,Tb(_.y01,_.x01),Tb(_.y11,_.x11),!v),c.arc(0,0,l,Tb(_.cy+_.y11,_.cx+_.x11),Tb(y.cy+y.y11,y.cx+y.x11),!v),c.arc(y.cx,y.cy,E,Tb(y.y11,y.x11),Tb(y.y01,y.x01),!v))):(c.moveTo(z,P),c.arc(0,0,l,g,m,!v)):c.moveTo(z,P),f>Cb&&w>Cb?S>Cb?(_=pc(L,R,q,U,f,-S,v),y=pc(z,P,D,O,f,-S,v),c.lineTo(_.cx+_.x01,_.cy+_.y01),S<N?c.arc(_.cx,_.cy,S,Tb(_.y01,_.x01),Tb(y.y01,y.x01),!v):(c.arc(_.cx,_.cy,S,Tb(_.y01,_.x01),Tb(_.y11,_.x11),!v),c.arc(0,0,f,Tb(_.cy+_.y11,_.cx+_.x11),Tb(y.cy+y.y11,y.cx+y.x11),v),c.arc(y.cx,y.cy,S,Tb(y.y11,y.x11),Tb(y.y01,y.x01),!v))):c.arc(0,0,f,b,x,v):c.lineTo(L,R)}else c.moveTo(0,0);if(c.closePath(),t)return c=null,t+\"\"||null}var n=ac,e=cc,r=wb(0),i=null,o=sc,u=fc,a=lc,c=null;return t.centroid=function(){var t=(+n.apply(this,arguments)+ +e.apply(this,arguments))/2,r=(+o.apply(this,arguments)+ +u.apply(this,arguments))/2-zb/2;return[kb(r)*t,Eb(r)*t]},t.innerRadius=function(e){return arguments.length?(n=\"function\"==typeof e?e:wb(+e),t):n},t.outerRadius=function(n){return arguments.length?(e=\"function\"==typeof n?n:wb(+n),t):e},t.cornerRadius=function(n){return arguments.length?(r=\"function\"==typeof n?n:wb(+n),t):r},t.padRadius=function(n){return arguments.length?(i=null==n?null:\"function\"==typeof n?n:wb(+n),t):i},t.startAngle=function(n){return arguments.length?(o=\"function\"==typeof n?n:wb(+n),t):o},t.endAngle=function(n){return arguments.length?(u=\"function\"==typeof n?n:wb(+n),t):u},t.padAngle=function(n){return arguments.length?(a=\"function\"==typeof n?n:wb(+n),t):a},t.context=function(n){return arguments.length?(c=null==n?null:n,t):c},t};dc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:this._context.lineTo(t,n)}}};var qb=function(t){return new dc(t)},Ub=function(){function t(t){var a,c,s,f=t.length,l=!1;for(null==i&&(u=o(s=Ue())),a=0;a<=f;++a)!(a<f&&r(c=t[a],a,t))===l&&((l=!l)?u.lineStart():u.lineEnd()),l&&u.point(+n(c,a,t),+e(c,a,t));if(s)return u=null,s+\"\"||null}var n=vc,e=_c,r=wb(!0),i=null,o=qb,u=null;return t.x=function(e){return arguments.length?(n=\"function\"==typeof e?e:wb(+e),t):n},t.y=function(n){return arguments.length?(e=\"function\"==typeof n?n:wb(+n),t):e},t.defined=function(n){return arguments.length?(r=\"function\"==typeof n?n:wb(!!n),t):r},t.curve=function(n){return arguments.length?(o=n,null!=i&&(u=o(i)),t):o},t.context=function(n){return arguments.length?(null==n?i=u=null:u=o(i=n),t):i},t},Db=function(){function t(t){var n,f,l,h,p,d=t.length,v=!1,_=new Array(d),y=new Array(d);for(null==a&&(s=c(p=Ue())),n=0;n<=d;++n){if(!(n<d&&u(h=t[n],n,t))===v)if(v=!v)f=n,s.areaStart(),s.lineStart();else{for(s.lineEnd(),s.lineStart(),l=n-1;l>=f;--l)s.point(_[l],y[l]);s.lineEnd(),s.areaEnd()}v&&(_[n]=+e(h,n,t),y[n]=+i(h,n,t),s.point(r?+r(h,n,t):_[n],o?+o(h,n,t):y[n]))}if(p)return s=null,p+\"\"||null}function n(){return Ub().defined(u).curve(c).context(a)}var e=vc,r=null,i=wb(0),o=_c,u=wb(!0),a=null,c=qb,s=null;return t.x=function(n){return arguments.length?(e=\"function\"==typeof n?n:wb(+n),r=null,t):e},t.x0=function(n){return arguments.length?(e=\"function\"==typeof n?n:wb(+n),t):e},t.x1=function(n){return arguments.length?(r=null==n?null:\"function\"==typeof n?n:wb(+n),t):r},t.y=function(n){return arguments.length?(i=\"function\"==typeof n?n:wb(+n),o=null,t):i},t.y0=function(n){return arguments.length?(i=\"function\"==typeof n?n:wb(+n),t):i},t.y1=function(n){return arguments.length?(o=null==n?null:\"function\"==typeof n?n:wb(+n),t):o},t.lineX0=t.lineY0=function(){return n().x(e).y(i)},t.lineY1=function(){return n().x(e).y(o)},t.lineX1=function(){return n().x(r).y(i)},t.defined=function(n){return arguments.length?(u=\"function\"==typeof n?n:wb(!!n),t):u},t.curve=function(n){return arguments.length?(c=n,null!=a&&(s=c(a)),t):c},t.context=function(n){return arguments.length?(null==n?a=s=null:s=c(a=n),t):a},t},Ob=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},Fb=function(t){return t},Ib=function(){function t(t){var a,c,s,f,l,h=t.length,p=0,d=new Array(h),v=new Array(h),_=+i.apply(this,arguments),y=Math.min(Lb,Math.max(-Lb,o.apply(this,arguments)-_)),g=Math.min(Math.abs(y)/h,u.apply(this,arguments)),m=g*(y<0?-1:1);for(a=0;a<h;++a)(l=v[d[a]=a]=+n(t[a],a,t))>0&&(p+=l);for(null!=e?d.sort(function(t,n){return e(v[t],v[n])}):null!=r&&d.sort(function(n,e){return r(t[n],t[e])}),a=0,s=p?(y-h*m)/p:0;a<h;++a,_=f)c=d[a],l=v[c],f=_+(l>0?l*s:0)+m,v[c]={data:t[c],index:a,value:l,startAngle:_,endAngle:f,padAngle:g};return v}var n=Fb,e=Ob,r=null,i=wb(0),o=wb(Lb),u=wb(0);return t.value=function(e){return arguments.length?(n=\"function\"==typeof e?e:wb(+e),t):n},t.sortValues=function(n){return arguments.length?(e=n,r=null,t):e},t.sort=function(n){return arguments.length?(r=n,e=null,t):r},t.startAngle=function(n){return arguments.length?(i=\"function\"==typeof n?n:wb(+n),t):i},t.endAngle=function(n){return arguments.length?(o=\"function\"==typeof n?n:wb(+n),t):o},t.padAngle=function(n){return arguments.length?(u=\"function\"==typeof n?n:wb(+n),t):u},t},Yb=gc(qb);yc.prototype={areaStart:function(){this._curve.areaStart()},areaEnd:function(){this._curve.areaEnd()},lineStart:function(){this._curve.lineStart()},lineEnd:function(){this._curve.lineEnd()},point:function(t,n){this._curve.point(n*Math.sin(t),n*-Math.cos(t))}};var Bb=function(){return mc(Ub().curve(Yb))},Hb=function(){var t=Db().curve(Yb),n=t.curve,e=t.lineX0,r=t.lineX1,i=t.lineY0,o=t.lineY1;return t.angle=t.x,delete t.x,t.startAngle=t.x0,delete t.x0,t.endAngle=t.x1,delete t.x1,t.radius=t.y,delete t.y,t.innerRadius=t.y0,delete t.y0,t.outerRadius=t.y1,delete t.y1,t.lineStartAngle=function(){return mc(e())},delete t.lineX0,t.lineEndAngle=function(){return mc(r())},delete t.lineX1,t.lineInnerRadius=function(){return mc(i())},delete t.lineY0,t.lineOuterRadius=function(){return mc(o())},delete t.lineY1,t.curve=function(t){return arguments.length?n(gc(t)):n()._curve},t},jb=Array.prototype.slice,Xb=function(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]},$b={draw:function(t,n){var e=Math.sqrt(n/zb);t.moveTo(e,0),t.arc(0,0,e,0,Lb)}},Vb={draw:function(t,n){var e=Math.sqrt(n/5)/2;t.moveTo(-3*e,-e),t.lineTo(-e,-e),t.lineTo(-e,-3*e),t.lineTo(e,-3*e),t.lineTo(e,-e),t.lineTo(3*e,-e),t.lineTo(3*e,e),t.lineTo(e,e),t.lineTo(e,3*e),t.lineTo(-e,3*e),t.lineTo(-e,e),t.lineTo(-3*e,e),t.closePath()}},Wb=Math.sqrt(1/3),Zb=2*Wb,Gb={draw:function(t,n){var e=Math.sqrt(n/Zb),r=e*Wb;t.moveTo(0,-e),t.lineTo(r,0),t.lineTo(0,e),t.lineTo(-r,0),t.closePath()}},Jb=Math.sin(zb/10)/Math.sin(7*zb/10),Qb=Math.sin(Lb/10)*Jb,Kb=-Math.cos(Lb/10)*Jb,tw={draw:function(t,n){var e=Math.sqrt(.8908130915292852*n),r=Qb*e,i=Kb*e;t.moveTo(0,-e),t.lineTo(r,i);for(var o=1;o<5;++o){var u=Lb*o/5,a=Math.cos(u),c=Math.sin(u);t.lineTo(c*e,-a*e),t.lineTo(a*r-c*i,c*r+a*i)}t.closePath()}},nw={draw:function(t,n){var e=Math.sqrt(n),r=-e/2;t.rect(r,r,e,e)}},ew=Math.sqrt(3),rw={draw:function(t,n){var e=-Math.sqrt(n/(3*ew));t.moveTo(0,2*e),t.lineTo(-ew*e,-e),t.lineTo(ew*e,-e),t.closePath()}},iw=-.5,ow=Math.sqrt(3)/2,uw=1/Math.sqrt(12),aw=3*(uw/2+1),cw={draw:function(t,n){var e=Math.sqrt(n/aw),r=e/2,i=e*uw,o=r,u=e*uw+e,a=-o,c=u;t.moveTo(r,i),t.lineTo(o,u),t.lineTo(a,c),t.lineTo(iw*r-ow*i,ow*r+iw*i),t.lineTo(iw*o-ow*u,ow*o+iw*u),t.lineTo(iw*a-ow*c,ow*a+iw*c),t.lineTo(iw*r+ow*i,iw*i-ow*r),t.lineTo(iw*o+ow*u,iw*u-ow*o),t.lineTo(iw*a+ow*c,iw*c-ow*a),t.closePath()}},sw=[$b,Vb,Gb,nw,tw,rw,cw],fw=function(){function t(){var t;if(r||(r=t=Ue()),n.apply(this,arguments).draw(r,+e.apply(this,arguments)),t)return r=null,t+\"\"||null}var n=wb($b),e=wb(64),r=null;return t.type=function(e){return arguments.length?(n=\"function\"==typeof e?e:wb(e),t):n},t.size=function(n){return arguments.length?(e=\"function\"==typeof n?n:wb(+n),t):e},t.context=function(n){return arguments.length?(r=null==n?null:n,t):r},t},lw=function(){};Cc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:Ac(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:Ac(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};var hw=function(t){return new Cc(t)};zc.prototype={areaStart:lw,areaEnd:lw,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x2,this._y2),this._context.closePath();break;case 2:this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break;case 3:this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x2=t,this._y2=n;break;case 1:this._point=2,this._x3=t,this._y3=n;break;case 2:this._point=3,this._x4=t,this._y4=n,this._context.moveTo((this._x0+4*this._x1+t)/6,(this._y0+4*this._y1+n)/6);break;default:Ac(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};var pw=function(t){return new zc(t)};Pc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var e=(this._x0+4*this._x1+t)/6,r=(this._y0+4*this._y1+n)/6;this._line?this._context.lineTo(e,r):this._context.moveTo(e,r);break;case 3:this._point=4;default:Ac(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}};var dw=function(t){return new Pc(t)};Lc.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var t=this._x,n=this._y,e=t.length-1;if(e>0)for(var r,i=t[0],o=n[0],u=t[e]-i,a=n[e]-o,c=-1;++c<=e;)r=c/e,this._basis.point(this._beta*t[c]+(1-this._beta)*(i+r*u),this._beta*n[c]+(1-this._beta)*(o+r*a));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}};var vw=function t(n){function e(t){return 1===n?new Cc(t):new Lc(t,n)}return e.beta=function(n){return t(+n)},e}(.85);qc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:Rc(this,this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2,this._x1=t,this._y1=n;break;case 2:this._point=3;default:Rc(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,\nthis._y1=this._y2,this._y2=n}};var _w=function t(n){function e(t){return new qc(t,n)}return e.tension=function(n){return t(+n)},e}(0);Uc.prototype={areaStart:lw,areaEnd:lw,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:Rc(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var yw=function t(n){function e(t){return new Uc(t,n)}return e.tension=function(n){return t(+n)},e}(0);Dc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:Rc(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var gw=function t(n){function e(t){return new Dc(t,n)}return e.tension=function(n){return t(+n)},e}(0);Fc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3;default:Oc(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var mw=function t(n){function e(t){return n?new Fc(t,n):new qc(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);Ic.prototype={areaStart:lw,areaEnd:lw,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:Oc(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var xw=function t(n){function e(t){return n?new Ic(t,n):new Uc(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);Yc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:Oc(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var bw=function t(n){function e(t){return n?new Yc(t,n):new Dc(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);Bc.prototype={areaStart:lw,areaEnd:lw,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(t,n){t=+t,n=+n,this._point?this._context.lineTo(t,n):(this._point=1,this._context.moveTo(t,n))}};var ww=function(t){return new Bc(t)};Vc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:$c(this,this._t0,Xc(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var e=NaN;if(t=+t,n=+n,t!==this._x1||n!==this._y1){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,$c(this,Xc(this,e=jc(this,t,n)),e);break;default:$c(this,this._t0,e=jc(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=e}}},(Wc.prototype=Object.create(Vc.prototype)).point=function(t,n){Vc.prototype.point.call(this,n,t)},Zc.prototype={moveTo:function(t,n){this._context.moveTo(n,t)},closePath:function(){this._context.closePath()},lineTo:function(t,n){this._context.lineTo(n,t)},bezierCurveTo:function(t,n,e,r,i,o){this._context.bezierCurveTo(n,t,r,e,o,i)}},Qc.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var t=this._x,n=this._y,e=t.length;if(e)if(this._line?this._context.lineTo(t[0],n[0]):this._context.moveTo(t[0],n[0]),2===e)this._context.lineTo(t[1],n[1]);else for(var r=Kc(t),i=Kc(n),o=0,u=1;u<e;++o,++u)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],t[u],n[u]);(this._line||0!==this._line&&1===e)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(t,n){this._x.push(+t),this._y.push(+n)}};var Mw=function(t){return new Qc(t)};ts.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&2===this._point&&this._context.lineTo(this._x,this._y),(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line>=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:if(this._t<=0)this._context.lineTo(this._x,n),this._context.lineTo(t,n);else{var e=this._x*(1-this._t)+t*this._t;this._context.lineTo(e,this._y),this._context.lineTo(e,n)}}this._x=t,this._y=n}};var Tw=function(t){return new ts(t,.5)},kw=function(t,n){if((i=t.length)>1)for(var e,r,i,o=1,u=t[n[0]],a=u.length;o<i;++o)for(r=u,u=t[n[o]],e=0;e<a;++e)u[e][1]+=u[e][0]=isNaN(r[e][1])?r[e][0]:r[e][1]},Nw=function(t){for(var n=t.length,e=new Array(n);--n>=0;)e[n]=n;return e},Sw=function(){function t(t){var o,u,a=n.apply(this,arguments),c=t.length,s=a.length,f=new Array(s);for(o=0;o<s;++o){for(var l,h=a[o],p=f[o]=new Array(c),d=0;d<c;++d)p[d]=l=[0,+i(t[d],h,d,t)],l.data=t[d];p.key=h}for(o=0,u=e(f);o<s;++o)f[u[o]].index=o;return r(f,u),f}var n=wb([]),e=Nw,r=kw,i=rs;return t.keys=function(e){return arguments.length?(n=\"function\"==typeof e?e:wb(jb.call(e)),t):n},t.value=function(n){return arguments.length?(i=\"function\"==typeof n?n:wb(+n),t):i},t.order=function(n){return arguments.length?(e=null==n?Nw:\"function\"==typeof n?n:wb(jb.call(n)),t):e},t.offset=function(n){return arguments.length?(r=null==n?kw:n,t):r},t},Ew=function(t,n){if((r=t.length)>0){for(var e,r,i,o=0,u=t[0].length;o<u;++o){for(i=e=0;e<r;++e)i+=t[e][o][1]||0;if(i)for(e=0;e<r;++e)t[e][o][1]/=i}kw(t,n)}},Aw=function(t,n){if((a=t.length)>1)for(var e,r,i,o,u,a,c=0,s=t[n[0]].length;c<s;++c)for(o=u=0,e=0;e<a;++e)(i=(r=t[n[e]][c])[1]-r[0])>=0?(r[0]=o,r[1]=o+=i):i<0?(r[1]=u,r[0]=u+=i):r[0]=o},Cw=function(t,n){if((e=t.length)>0){for(var e,r=0,i=t[n[0]],o=i.length;r<o;++r){for(var u=0,a=0;u<e;++u)a+=t[u][r][1]||0;i[r][1]+=i[r][0]=-a/2}kw(t,n)}},zw=function(t,n){if((i=t.length)>0&&(r=(e=t[n[0]]).length)>0){for(var e,r,i,o=0,u=1;u<r;++u){for(var a=0,c=0,s=0;a<i;++a){for(var f=t[n[a]],l=f[u][1]||0,h=f[u-1][1]||0,p=(l-h)/2,d=0;d<a;++d){var v=t[n[d]];p+=(v[u][1]||0)-(v[u-1][1]||0)}c+=l,s+=p*l}e[u-1][1]+=e[u-1][0]=o,c&&(o-=s/c)}e[u-1][1]+=e[u-1][0]=o,kw(t,n)}},Pw=function(t){var n=t.map(is);return Nw(t).sort(function(t,e){return n[t]-n[e]})},Lw=function(t){return Pw(t).reverse()},Rw=function(t){var n,e,r=t.length,i=t.map(is),o=Nw(t).sort(function(t,n){return i[n]-i[t]}),u=0,a=0,c=[],s=[];for(n=0;n<r;++n)e=o[n],u<a?(u+=i[e],c.push(e)):(a+=i[e],s.push(e));return s.reverse().concat(c)},qw=function(t){return Nw(t).reverse()},Uw=function(t){return function(){return t}};as.prototype={constructor:as,insert:function(t,n){var e,r,i;if(t){if(n.P=t,n.N=t.N,t.N&&(t.N.P=n),t.N=n,t.R){for(t=t.R;t.L;)t=t.L;t.L=n}else t.R=n;e=t}else this._?(t=ls(this._),n.P=null,n.N=t,t.P=t.L=n,e=t):(n.P=n.N=null,this._=n,e=null);for(n.L=n.R=null,n.U=e,n.C=!0,t=n;e&&e.C;)r=e.U,e===r.L?(i=r.R,i&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.R&&(ss(this,e),t=e,e=t.U),e.C=!1,r.C=!0,fs(this,r))):(i=r.L,i&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.L&&(fs(this,e),t=e,e=t.U),e.C=!1,r.C=!0,ss(this,r))),e=t.U;this._.C=!1},remove:function(t){t.N&&(t.N.P=t.P),t.P&&(t.P.N=t.N),t.N=t.P=null;var n,e,r,i=t.U,o=t.L,u=t.R;if(e=o?u?ls(u):o:u,i?i.L===t?i.L=e:i.R=e:this._=e,o&&u?(r=e.C,e.C=t.C,e.L=o,o.U=e,e!==u?(i=e.U,e.U=t.U,t=e.R,i.L=t,e.R=u,u.U=e):(e.U=i,i=e,t=e.R)):(r=t.C,t=e),t&&(t.U=i),!r){if(t&&t.C)return void(t.C=!1);do{if(t===this._)break;if(t===i.L){if(n=i.R,n.C&&(n.C=!1,i.C=!0,ss(this,i),n=i.R),n.L&&n.L.C||n.R&&n.R.C){n.R&&n.R.C||(n.L.C=!1,n.C=!0,fs(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,ss(this,i),t=this._;break}}else if(n=i.L,n.C&&(n.C=!1,i.C=!0,fs(this,i),n=i.L),n.L&&n.L.C||n.R&&n.R.C){n.L&&n.L.C||(n.R.C=!1,n.C=!0,ss(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,fs(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}};var Dw,Ow,Fw,Iw,Yw,Bw=[],Hw=[],jw=1e-6,Xw=1e-12;Us.prototype={constructor:Us,polygons:function(){var t=this.edges;return this.cells.map(function(n){var e=n.halfedges.map(function(e){return xs(n,t[e])});return e.data=n.site.data,e})},triangles:function(){var t=[],n=this.edges;return this.cells.forEach(function(e,r){if(o=(i=e.halfedges).length)for(var i,o,u,a=e.site,c=-1,s=n[i[o-1]],f=s.left===a?s.right:s.left;++c<o;)u=f,s=n[i[c]],f=s.left===a?s.right:s.left,u&&f&&r<u.index&&r<f.index&&Rs(a,u,f)<0&&t.push([a.data,u.data,f.data])}),t},links:function(){return this.edges.filter(function(t){return t.right}).map(function(t){return{source:t.left.data,target:t.right.data}})},find:function(t,n,e){for(var r,i,o=this,u=o._found||0,a=o.cells.length;!(i=o.cells[u]);)if(++u>=a)return null;var c=t-i.site[0],s=n-i.site[1],f=c*c+s*s;do{i=o.cells[r=u],u=null,i.halfedges.forEach(function(e){var r=o.edges[e],a=r.left;if(a!==i.site&&a||(a=r.right)){var c=t-a[0],s=n-a[1],l=c*c+s*s;l<f&&(f=l,u=a.index)}})}while(null!==u);return o._found=r,null==e||f<=e*e?i.site:null}};var $w=function(){function t(t){return new Us(t.map(function(r,i){var o=[Math.round(n(r,i,t)/jw)*jw,Math.round(e(r,i,t)/jw)*jw];return o.index=i,o.data=r,o}),r)}var n=os,e=us,r=null;return t.polygons=function(n){return t(n).polygons()},t.links=function(n){return t(n).links()},t.triangles=function(n){return t(n).triangles()},t.x=function(e){return arguments.length?(n=\"function\"==typeof e?e:Uw(+e),t):n},t.y=function(n){return arguments.length?(e=\"function\"==typeof n?n:Uw(+n),t):e},t.extent=function(n){return arguments.length?(r=null==n?null:[[+n[0][0],+n[0][1]],[+n[1][0],+n[1][1]]],t):r&&[[r[0][0],r[0][1]],[r[1][0],r[1][1]]]},t.size=function(n){return arguments.length?(r=null==n?null:[[0,0],[+n[0],+n[1]]],t):r&&[r[1][0]-r[0][0],r[1][1]-r[0][1]]},t},Vw=function(t){return function(){return t}};Os.prototype={constructor:Os,scale:function(t){return 1===t?this:new Os(this.k*t,this.x,this.y)},translate:function(t,n){return 0===t&0===n?this:new Os(this.k,this.x+this.k*t,this.y+this.k*n)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return\"translate(\"+this.x+\",\"+this.y+\") scale(\"+this.k+\")\"}};var Ww=new Os(1,0,0);Fs.prototype=Os.prototype;var Zw=function(){t.event.preventDefault(),t.event.stopImmediatePropagation()},Gw=function(){function n(t){t.on(\"wheel.zoom\",s).on(\"mousedown.zoom\",f).on(\"dblclick.zoom\",l).on(\"touchstart.zoom\",h).on(\"touchmove.zoom\",p).on(\"touchend.zoom touchcancel.zoom\",d).style(\"-webkit-tap-highlight-color\",\"rgba(0,0,0,0)\").property(\"__zoom\",Hs)}function e(t,n){return n=Math.max(x,Math.min(b,n)),n===t.k?t:new Os(n,t.x,t.y)}function r(t,n,e){var r=n[0]-e[0]*t.k,i=n[1]-e[1]*t.k;return r===t.x&&i===t.y?t:new Os(t.k,r,i)}function i(t,n){var e=t.invertX(n[0][0])-w,r=t.invertX(n[1][0])-M,i=t.invertY(n[0][1])-T,o=t.invertY(n[1][1])-k;return t.translate(r>e?(e+r)/2:Math.min(0,e)||Math.max(0,r),o>i?(i+o)/2:Math.min(0,i)||Math.max(0,o))}function o(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function u(t,n,e){t.on(\"start.zoom\",function(){a(this,arguments).start()}).on(\"interrupt.zoom end.zoom\",function(){a(this,arguments).end()}).tween(\"zoom\",function(){var t=this,r=arguments,i=a(t,r),u=m.apply(t,r),c=e||o(u),s=Math.max(u[1][0]-u[0][0],u[1][1]-u[0][1]),f=t.__zoom,l=\"function\"==typeof n?n.apply(t,r):n,h=S(f.invert(c).concat(s/f.k),l.invert(c).concat(s/l.k));return function(t){if(1===t)t=l;else{var n=h(t),e=s/n[2];t=new Os(e,c[0]-n[0]*e,c[1]-n[1]*e)}i.zoom(null,t)}})}function a(t,n){for(var e,r=0,i=E.length;r<i;++r)if((e=E[r]).that===t)return e;return new c(t,n)}function c(t,n){this.that=t,this.args=n,this.index=-1,this.active=0,this.extent=m.apply(t,n)}function s(){function n(){o.wheel=null,o.end()}if(g.apply(this,arguments)){var o=a(this,arguments),u=this.__zoom,c=Math.max(x,Math.min(b,u.k*Math.pow(2,-t.event.deltaY*(t.event.deltaMode?120:1)/500))),s=Gf(this);if(o.wheel)o.mouse[0][0]===s[0]&&o.mouse[0][1]===s[1]||(o.mouse[1]=u.invert(o.mouse[0]=s)),clearTimeout(o.wheel);else{if(u.k===c)return;o.mouse=[s,u.invert(s)],gp(this),o.start()}Zw(),o.wheel=setTimeout(n,P),o.zoom(\"mouse\",i(r(e(u,c),o.mouse[0],o.mouse[1]),o.extent))}}function f(){function n(){if(Zw(),!o.moved){var n=t.event.clientX-s,e=t.event.clientY-f;o.moved=n*n+e*e>L}o.zoom(\"mouse\",i(r(o.that.__zoom,o.mouse[0]=Gf(o.that),o.mouse[1]),o.extent))}function e(){u.on(\"mousemove.zoom mouseup.zoom\",null),mt(t.event.view,o.moved),Zw(),o.end()}if(!y&&g.apply(this,arguments)){var o=a(this,arguments),u=Pl(t.event.view).on(\"mousemove.zoom\",n,!0).on(\"mouseup.zoom\",e,!0),c=Gf(this),s=t.event.clientX,f=t.event.clientY;Dl(t.event.view),Is(),o.mouse=[c,this.__zoom.invert(c)],gp(this),o.start()}}function l(){if(g.apply(this,arguments)){var o=this.__zoom,a=Gf(this),c=o.invert(a),s=o.k*(t.event.shiftKey?.5:2),f=i(r(e(o,s),a,c),m.apply(this,arguments));Zw(),N>0?Pl(this).transition().duration(N).call(u,f,a):Pl(this).call(n.transform,f)}}function h(){if(g.apply(this,arguments)){var n,e,r,i,o=a(this,arguments),u=t.event.changedTouches,c=u.length;for(Is(),e=0;e<c;++e)r=u[e],i=Rl(this,u,r.identifier),i=[i,this.__zoom.invert(i),r.identifier],o.touch0?o.touch1||(o.touch1=i):(o.touch0=i,n=!0);if(_&&(_=clearTimeout(_),!o.touch1))return o.end(),void((i=Pl(this).on(\"dblclick.zoom\"))&&i.apply(this,arguments));n&&(_=setTimeout(function(){_=null},z),gp(this),o.start())}}function p(){var n,o,u,c,s=a(this,arguments),f=t.event.changedTouches,l=f.length;for(Zw(),_&&(_=clearTimeout(_)),n=0;n<l;++n)o=f[n],u=Rl(this,f,o.identifier),s.touch0&&s.touch0[2]===o.identifier?s.touch0[0]=u:s.touch1&&s.touch1[2]===o.identifier&&(s.touch1[0]=u);if(o=s.that.__zoom,s.touch1){var h=s.touch0[0],p=s.touch0[1],d=s.touch1[0],v=s.touch1[1],y=(y=d[0]-h[0])*y+(y=d[1]-h[1])*y,g=(g=v[0]-p[0])*g+(g=v[1]-p[1])*g;o=e(o,Math.sqrt(y/g)),u=[(h[0]+d[0])/2,(h[1]+d[1])/2],c=[(p[0]+v[0])/2,(p[1]+v[1])/2]}else{if(!s.touch0)return;u=s.touch0[0],c=s.touch0[1]}s.zoom(\"touch\",i(r(o,u,c),s.extent))}function d(){var n,e,r=a(this,arguments),i=t.event.changedTouches,o=i.length;for(Is(),y&&clearTimeout(y),y=setTimeout(function(){y=null},z),n=0;n<o;++n)e=i[n],r.touch0&&r.touch0[2]===e.identifier?delete r.touch0:r.touch1&&r.touch1[2]===e.identifier&&delete r.touch1;r.touch1&&!r.touch0&&(r.touch0=r.touch1,delete r.touch1),r.touch0?r.touch0[1]=this.__zoom.invert(r.touch0[0]):r.end()}var _,y,g=Ys,m=Bs,x=0,b=1/0,w=-b,M=b,T=w,k=M,N=250,S=Hh,E=[],C=v(\"start\",\"zoom\",\"end\"),z=500,P=150,L=0;return n.transform=function(t,n){var e=t.selection?t.selection():t;e.property(\"__zoom\",Hs),t!==e?u(t,n):e.interrupt().each(function(){a(this,arguments).start().zoom(null,\"function\"==typeof n?n.apply(this,arguments):n).end()})},n.scaleBy=function(t,e){n.scaleTo(t,function(){return this.__zoom.k*(\"function\"==typeof e?e.apply(this,arguments):e)})},n.scaleTo=function(t,u){n.transform(t,function(){var t=m.apply(this,arguments),n=this.__zoom,a=o(t),c=n.invert(a);return i(r(e(n,\"function\"==typeof u?u.apply(this,arguments):u),a,c),t)})},n.translateBy=function(t,e,r){n.transform(t,function(){return i(this.__zoom.translate(\"function\"==typeof e?e.apply(this,arguments):e,\"function\"==typeof r?r.apply(this,arguments):r),m.apply(this,arguments))})},c.prototype={start:function(){return 1==++this.active&&(this.index=E.push(this)-1,this.emit(\"start\")),this},zoom:function(t,n){return this.mouse&&\"mouse\"!==t&&(this.mouse[1]=n.invert(this.mouse[0])),this.touch0&&\"touch\"!==t&&(this.touch0[1]=n.invert(this.touch0[0])),this.touch1&&\"touch\"!==t&&(this.touch1[1]=n.invert(this.touch1[0])),this.that.__zoom=n,this.emit(\"zoom\"),this},end:function(){return 0==--this.active&&(E.splice(this.index,1),this.index=-1,this.emit(\"end\")),this},emit:function(t){A(new Ds(n,t,this.that.__zoom),C.apply,C,[t,this.that,this.args])}},n.filter=function(t){return arguments.length?(g=\"function\"==typeof t?t:Vw(!!t),n):g},n.extent=function(t){return arguments.length?(m=\"function\"==typeof t?t:Vw([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),n):m},n.scaleExtent=function(t){return arguments.length?(x=+t[0],b=+t[1],n):[x,b]},n.translateExtent=function(t){return arguments.length?(w=+t[0][0],M=+t[1][0],T=+t[0][1],k=+t[1][1],n):[[w,T],[M,k]]},n.duration=function(t){return arguments.length?(N=+t,n):N},n.interpolate=function(t){return arguments.length?(S=t,n):S},n.on=function(){var t=C.on.apply(C,arguments);return t===C?n:t},n.clickDistance=function(t){return arguments.length?(L=(t=+t)*t,n):Math.sqrt(L)},n};t.version=\"4.9.1\",t.bisect=Vs,t.bisectRight=Vs,t.bisectLeft=Ws,t.ascending=js,t.bisector=Xs,t.cross=Gs,t.descending=Js,t.deviation=tf,t.extent=nf,t.histogram=df,t.thresholdFreedmanDiaconis=_f,t.thresholdScott=yf,t.thresholdSturges=pf,t.max=gf,t.mean=mf,t.median=xf,t.merge=bf,t.min=wf,t.pairs=Zs,t.permute=Mf,t.quantile=vf,t.range=cf,t.scan=Tf,t.shuffle=kf,t.sum=Nf,t.ticks=hf,t.tickIncrement=r,t.tickStep=i,t.transpose=Sf,t.variance=Ks,t.zip=Ef,t.axisTop=l,t.axisRight=h,t.axisBottom=p,t.axisLeft=d,t.brush=Ed,t.brushX=ze,t.brushY=Pe,t.brushSelection=Ce,t.chord=qd,t.ribbon=Yd,t.nest=Bd,t.set=Ze,t.map=He,t.keys=jd,t.values=Xd,t.entries=$d,t.color=Nt,t.rgb=Ct,t.hsl=Rt,t.lab=Ot,t.hcl=Xt,t.cubehelix=Wt,t.dispatch=v,t.drag=Fl,t.dragDisable=Dl,t.dragEnable=mt,t.dsvFormat=Vd,t.csvParse=Zd,t.csvParseRows=Gd,t.csvFormat=Jd,t.csvFormatRows=Qd,t.tsvParse=tv,t.tsvParseRows=nv,t.tsvFormat=ev,t.tsvFormatRows=rv,t.easeLinear=ie,t.easeQuad=ae,t.easeQuadIn=oe,t.easeQuadOut=ue,t.easeQuadInOut=ae,t.easeCubic=fe,t.easeCubicIn=ce,t.easeCubicOut=se,t.easeCubicInOut=fe,t.easePoly=Hp,t.easePolyIn=Yp,t.easePolyOut=Bp,t.easePolyInOut=Hp,t.easeSin=pe,t.easeSinIn=le,t.easeSinOut=he,t.easeSinInOut=pe,t.easeExp=_e,t.easeExpIn=de,t.easeExpOut=ve,t.easeExpInOut=_e,t.easeCircle=me,t.easeCircleIn=ye,t.easeCircleOut=ge,t.easeCircleInOut=me,t.easeBounce=be,t.easeBounceIn=xe,t.easeBounceOut=be,t.easeBounceInOut=we,t.easeBack=id,t.easeBackIn=ed,t.easeBackOut=rd,t.easeBackInOut=id,t.easeElastic=ad,t.easeElasticIn=ud,t.easeElasticOut=ad,t.easeElasticInOut=cd,t.forceCenter=iv,t.forceCollide=wv,t.forceLink=Mv,t.forceManyBody=Sv,t.forceSimulation=Nv,t.forceX=Ev,t.forceY=Av,t.formatDefaultLocale=vr,t.formatLocale=Bv,t.formatSpecifier=pr,t.precisionFixed=Hv,t.precisionPrefix=jv,t.precisionRound=Xv,t.geoArea=G_,t.geoBounds=K_,t.geoCentroid=ny,t.geoCircle=_y,t.geoClipExtent=My,t.geoContains=Ry,t.geoDistance=zy,t.geoGraticule=Ti,t.geoGraticule10=ki,t.geoInterpolate=qy,t.geoLength=Ey,t.geoPath=cg,t.geoAlbers=gg,t.geoAlbersUsa=mg,t.geoAzimuthalEqualArea=bg,t.geoAzimuthalEqualAreaRaw=xg,t.geoAzimuthalEquidistant=Mg,t.geoAzimuthalEquidistantRaw=wg,t.geoConicConformal=kg,t.geoConicConformalRaw=po,t.geoConicEqualArea=yg,t.geoConicEqualAreaRaw=uo,t.geoConicEquidistant=Sg,t.geoConicEquidistantRaw=_o,t.geoEquirectangular=Ng,t.geoEquirectangularRaw=vo,t.geoGnomonic=Eg,t.geoGnomonicRaw=yo,t.geoIdentity=Ag,t.geoProjection=eo,t.geoProjectionMutator=ro,t.geoMercator=Tg,t.geoMercatorRaw=fo,t.geoOrthographic=Cg,t.geoOrthographicRaw=mo,t.geoStereographic=zg,t.geoStereographicRaw=xo,t.geoTransverseMercator=Pg,t.geoTransverseMercatorRaw=bo,t.geoRotation=vy,t.geoStream=$_,t.geoTransform=hg,t.cluster=Lg,t.hierarchy=zo,t.pack=Zg,t.packSiblings=Vg,t.packEnclose=$g,t.partition=Qg,t.stratify=em,t.tree=rm,t.treemap=am,t.treemapBinary=cm,t.treemapDice=Jg,t.treemapSlice=im,t.treemapSliceDice=sm,t.treemapSquarify=um,t.treemapResquarify=fm,t.interpolate=qh,t.interpolateArray=Eh,t.interpolateBasis=wh,t.interpolateBasisClosed=Mh,t.interpolateDate=Ah,t.interpolateNumber=Ch,t.interpolateObject=zh,t.interpolateRound=Uh,t.interpolateString=Rh,t.interpolateTransformCss=Ih,t.interpolateTransformSvg=Yh,t.interpolateZoom=Hh,t.interpolateRgb=kh,t.interpolateRgbBasis=Nh,t.interpolateRgbBasisClosed=Sh,t.interpolateHsl=jh,t.interpolateHslLong=Xh,t.interpolateLab=pn,t.interpolateHcl=$h,t.interpolateHclLong=Vh,t.interpolateCubehelix=Wh,t.interpolateCubehelixLong=Zh,t.quantize=Gh,t.path=Ue,t.polygonArea=lm,t.polygonCentroid=hm;t.polygonHull=dm,t.polygonContains=vm,t.polygonLength=_m,t.quadtree=ir,t.queue=xu,t.randomUniform=xm,t.randomNormal=bm,t.randomLogNormal=wm,t.randomBates=Tm,t.randomIrwinHall=Mm,t.randomExponential=km,t.request=Nm,t.html=Em,t.json=Am,t.text=Cm,t.xml=zm,t.csv=Lm,t.tsv=Rm,t.scaleBand=ku,t.scalePoint=Su,t.scaleIdentity=Du,t.scaleLinear=Uu,t.scaleLog=ju,t.scaleOrdinal=Tu,t.scaleImplicit=Om,t.scalePow=$u,t.scaleSqrt=Vu,t.scaleQuantile=Wu,t.scaleQuantize=Zu,t.scaleThreshold=Gu,t.scaleTime=ub,t.scaleUtc=ab,t.schemeCategory10=sb,t.schemeCategory20b=fb,t.schemeCategory20c=lb,t.schemeCategory20=hb,t.interpolateCubehelixDefault=pb,t.interpolateRainbow=yb,t.interpolateWarm=db,t.interpolateCool=vb,t.interpolateViridis=gb,t.interpolateMagma=mb,t.interpolateInferno=xb,t.interpolatePlasma=bb,t.scaleSequential=ic,t.creator=If,t.local=w,t.matcher=Xf,t.mouse=Gf,t.namespace=Ff,t.namespaces=Of,t.select=Pl,t.selectAll=Ll,t.selection=yt,t.selector=Jf,t.selectorAll=Kf,t.style=X,t.touch=Rl,t.touches=ql,t.window=gl,t.customEvent=A,t.arc=Rb,t.area=Db,t.line=Ub,t.pie=Ib,t.radialArea=Hb,t.radialLine=Bb,t.linkHorizontal=Nc,t.linkVertical=Sc,t.linkRadial=Ec,t.symbol=fw,t.symbols=sw,t.symbolCircle=$b,t.symbolCross=Vb,t.symbolDiamond=Gb,t.symbolSquare=nw,t.symbolStar=tw,t.symbolTriangle=rw,t.symbolWye=cw,t.curveBasisClosed=pw,t.curveBasisOpen=dw,t.curveBasis=hw,t.curveBundle=vw,t.curveCardinalClosed=yw,t.curveCardinalOpen=gw,t.curveCardinal=_w,t.curveCatmullRomClosed=xw,t.curveCatmullRomOpen=bw,t.curveCatmullRom=mw,t.curveLinearClosed=ww,t.curveLinear=qb,t.curveMonotoneX=Gc,t.curveMonotoneY=Jc,t.curveNatural=Mw,t.curveStep=Tw,t.curveStepAfter=es,t.curveStepBefore=ns,t.stack=Sw,t.stackOffsetExpand=Ew,t.stackOffsetDiverging=Aw,t.stackOffsetNone=kw,t.stackOffsetSilhouette=Cw,t.stackOffsetWiggle=zw,t.stackOrderAscending=Pw,t.stackOrderDescending=Lw,t.stackOrderInsideOut=Rw,t.stackOrderNone=Nw,t.stackOrderReverse=qw,t.timeInterval=Ju,t.timeMillisecond=$m,t.timeMilliseconds=Vm,t.utcMillisecond=$m,t.utcMilliseconds=Vm,t.timeSecond=Gm,t.timeSeconds=Jm,t.utcSecond=Gm,t.utcSeconds=Jm,t.timeMinute=Qm,t.timeMinutes=Km,t.timeHour=tx,t.timeHours=nx,t.timeDay=ex,t.timeDays=rx,t.timeWeek=ix,t.timeWeeks=lx,t.timeSunday=ix,t.timeSundays=lx,t.timeMonday=ox,t.timeMondays=hx,t.timeTuesday=ux,t.timeTuesdays=px,t.timeWednesday=ax,t.timeWednesdays=dx,t.timeThursday=cx,t.timeThursdays=vx,t.timeFriday=sx,t.timeFridays=_x,t.timeSaturday=fx,t.timeSaturdays=yx,t.timeMonth=gx,t.timeMonths=mx,t.timeYear=xx,t.timeYears=bx,t.utcMinute=wx,t.utcMinutes=Mx,t.utcHour=Tx,t.utcHours=kx,t.utcDay=Nx,t.utcDays=Sx,t.utcWeek=Ex,t.utcWeeks=qx,t.utcSunday=Ex,t.utcSundays=qx,t.utcMonday=Ax,t.utcMondays=Ux,t.utcTuesday=Cx,t.utcTuesdays=Dx,t.utcWednesday=zx,t.utcWednesdays=Ox,t.utcThursday=Px,t.utcThursdays=Fx,t.utcFriday=Lx,t.utcFridays=Ix,t.utcSaturday=Rx,t.utcSaturdays=Yx,t.utcMonth=Bx,t.utcMonths=Hx,t.utcYear=jx,t.utcYears=$x,t.timeFormatDefaultLocale=Ja,t.timeFormatLocale=ra,t.isoFormat=Jx,t.isoParse=Qx,t.now=_n,t.timer=mn,t.timerFlush=xn,t.timeout=up,t.interval=ap,t.transition=ee,t.active=hd,t.interrupt=gp,t.voronoi=$w,t.zoom=Gw,t.zoomTransform=Fs,t.zoomIdentity=Ww,Object.defineProperty(t,\"__esModule\",{value:!0})});"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/gmaps.js",
    "content": "\"use strict\";\n(function(root, factory) {\n  if(typeof exports === 'object') {\n    module.exports = factory();\n  }\n  else if(typeof define === 'function' && define.amd) {\n    define('GMaps', [], factory);\n  }\n\n  root.GMaps = factory();\n\n}(this, function() {\n\n/*!\n * GMaps.js v0.4.18\n * http://hpneo.github.com/gmaps/\n *\n * Copyright 2015, Gustavo Leon\n * Released under the MIT License.\n */\n\nif (!(typeof window.google === 'object' && window.google.maps)) {\n  throw 'Google Maps API is required. Please register the following JavaScript library http://maps.google.com/maps/api/js?sensor=true.'\n}\n\nvar extend_object = function(obj, new_obj) {\n  var name;\n\n  if (obj === new_obj) {\n    return obj;\n  }\n\n  for (name in new_obj) {\n    obj[name] = new_obj[name];\n  }\n\n  return obj;\n};\n\nvar replace_object = function(obj, replace) {\n  var name;\n\n  if (obj === replace) {\n    return obj;\n  }\n\n  for (name in replace) {\n    if (obj[name] != undefined) {\n      obj[name] = replace[name];\n    }\n  }\n\n  return obj;\n};\n\nvar array_map = function(array, callback) {\n  var original_callback_params = Array.prototype.slice.call(arguments, 2),\n      array_return = [],\n      array_length = array.length,\n      i;\n\n  if (Array.prototype.map && array.map === Array.prototype.map) {\n    array_return = Array.prototype.map.call(array, function(item) {\n      var callback_params = original_callback_params.slice(0);\n      callback_params.splice(0, 0, item);\n\n      return callback.apply(this, callback_params);\n    });\n  }\n  else {\n    for (i = 0; i < array_length; i++) {\n      callback_params = original_callback_params;\n      callback_params.splice(0, 0, array[i]);\n      array_return.push(callback.apply(this, callback_params));\n    }\n  }\n\n  return array_return;\n};\n\nvar array_flat = function(array) {\n  var new_array = [],\n      i;\n\n  for (i = 0; i < array.length; i++) {\n    new_array = new_array.concat(array[i]);\n  }\n\n  return new_array;\n};\n\nvar coordsToLatLngs = function(coords, useGeoJSON) {\n  var first_coord = coords[0],\n      second_coord = coords[1];\n\n  if (useGeoJSON) {\n    first_coord = coords[1];\n    second_coord = coords[0];\n  }\n\n  return new google.maps.LatLng(first_coord, second_coord);\n};\n\nvar arrayToLatLng = function(coords, useGeoJSON) {\n  var i;\n\n  for (i = 0; i < coords.length; i++) {\n    if (!(coords[i] instanceof google.maps.LatLng)) {\n      if (coords[i].length > 0 && typeof(coords[i][0]) === \"object\") {\n        coords[i] = arrayToLatLng(coords[i], useGeoJSON);\n      }\n      else {\n        coords[i] = coordsToLatLngs(coords[i], useGeoJSON);\n      }\n    }\n  }\n\n  return coords;\n};\n\n\nvar getElementsByClassName = function (class_name, context) {\n\n    var element,\n        _class = class_name.replace('.', '');\n\n    if ('jQuery' in this && context) {\n        element = $(\".\" + _class, context)[0];\n    } else {\n        element = document.getElementsByClassName(_class)[0];\n    }\n    return element;\n\n};\n\nvar getElementById = function(id, context) {\n  var element,\n  id = id.replace('#', '');\n\n  if ('jQuery' in window && context) {\n    element = $('#' + id, context)[0];\n  } else {\n    element = document.getElementById(id);\n  };\n\n  return element;\n};\n\nvar findAbsolutePosition = function(obj)  {\n  var curleft = 0,\n      curtop = 0;\n\n  if (obj.offsetParent) {\n    do {\n      curleft += obj.offsetLeft;\n      curtop += obj.offsetTop;\n    } while (obj = obj.offsetParent);\n  }\n\n  return [curleft, curtop];\n};\n\nvar GMaps = (function(global) {\n  \"use strict\";\n\n  var doc = document;\n\n  var GMaps = function(options) {\n    if (!this) return new GMaps(options);\n\n    options.zoom = options.zoom || 15;\n    options.mapType = options.mapType || 'roadmap';\n\n    var self = this,\n        i,\n        events_that_hide_context_menu = [\n          'bounds_changed', 'center_changed', 'click', 'dblclick', 'drag',\n          'dragend', 'dragstart', 'idle', 'maptypeid_changed', 'projection_changed',\n          'resize', 'tilesloaded', 'zoom_changed'\n        ],\n        events_that_doesnt_hide_context_menu = ['mousemove', 'mouseout', 'mouseover'],\n        options_to_be_deleted = ['el', 'lat', 'lng', 'mapType', 'width', 'height', 'markerClusterer', 'enableNewStyle'],\n        identifier = options.el || options.div,\n        markerClustererFunction = options.markerClusterer,\n        mapType = google.maps.MapTypeId[options.mapType.toUpperCase()],\n        map_center = new google.maps.LatLng(options.lat, options.lng),\n        zoomControl = options.zoomControl || true,\n        zoomControlOpt = options.zoomControlOpt || {\n          style: 'DEFAULT',\n          position: 'TOP_LEFT'\n        },\n        zoomControlStyle = zoomControlOpt.style || 'DEFAULT',\n        zoomControlPosition = zoomControlOpt.position || 'TOP_LEFT',\n        panControl = options.panControl || true,\n        mapTypeControl = options.mapTypeControl || true,\n        scaleControl = options.scaleControl || true,\n        streetViewControl = options.streetViewControl || true,\n        overviewMapControl = overviewMapControl || true,\n        map_options = {},\n        map_base_options = {\n          zoom: this.zoom,\n          center: map_center,\n          mapTypeId: mapType\n        },\n        map_controls_options = {\n          panControl: panControl,\n          zoomControl: zoomControl,\n          zoomControlOptions: {\n            style: google.maps.ZoomControlStyle[zoomControlStyle],\n            position: google.maps.ControlPosition[zoomControlPosition]\n          },\n          mapTypeControl: mapTypeControl,\n          scaleControl: scaleControl,\n          streetViewControl: streetViewControl,\n          overviewMapControl: overviewMapControl\n        };\n\n      if (typeof(options.el) === 'string' || typeof(options.div) === 'string') {\n\n          if (identifier.indexOf(\"#\") > -1) {\n              this.el = getElementById(identifier, options.context);\n          } else {\n              this.el = getElementsByClassName.apply(this, [identifier, options.context]);\n          }\n\n      } else {\n          this.el = identifier;\n      }\n\n    if (typeof(this.el) === 'undefined' || this.el === null) {\n      throw 'No element defined.';\n    }\n\n    window.context_menu = window.context_menu || {};\n    window.context_menu[self.el.id] = {};\n\n    this.controls = [];\n    this.overlays = [];\n    this.layers = []; // array with kml/georss and fusiontables layers, can be as many\n    this.singleLayers = {}; // object with the other layers, only one per layer\n    this.markers = [];\n    this.polylines = [];\n    this.routes = [];\n    this.polygons = [];\n    this.infoWindow = null;\n    this.overlay_el = null;\n    this.zoom = options.zoom;\n    this.registered_events = {};\n\n    this.el.style.width = options.width || this.el.scrollWidth || this.el.offsetWidth;\n    this.el.style.height = options.height || this.el.scrollHeight || this.el.offsetHeight;\n\n    google.maps.visualRefresh = options.enableNewStyle;\n\n    for (i = 0; i < options_to_be_deleted.length; i++) {\n      delete options[options_to_be_deleted[i]];\n    }\n\n    if(options.disableDefaultUI != true) {\n      map_base_options = extend_object(map_base_options, map_controls_options);\n    }\n\n    map_options = extend_object(map_base_options, options);\n\n    for (i = 0; i < events_that_hide_context_menu.length; i++) {\n      delete map_options[events_that_hide_context_menu[i]];\n    }\n\n    for (i = 0; i < events_that_doesnt_hide_context_menu.length; i++) {\n      delete map_options[events_that_doesnt_hide_context_menu[i]];\n    }\n\n    this.map = new google.maps.Map(this.el, map_options);\n\n    if (markerClustererFunction) {\n      this.markerClusterer = markerClustererFunction.apply(this, [this.map]);\n    }\n\n    var buildContextMenuHTML = function(control, e) {\n      var html = '',\n          options = window.context_menu[self.el.id][control];\n\n      for (var i in options){\n        if (options.hasOwnProperty(i)) {\n          var option = options[i];\n\n          html += '<li><a id=\"' + control + '_' + i + '\" href=\"#\">' + option.title + '</a></li>';\n        }\n      }\n\n      if (!getElementById('gmaps_context_menu')) return;\n\n      var context_menu_element = getElementById('gmaps_context_menu');\n      \n      context_menu_element.innerHTML = html;\n\n      var context_menu_items = context_menu_element.getElementsByTagName('a'),\n          context_menu_items_count = context_menu_items.length,\n          i;\n\n      for (i = 0; i < context_menu_items_count; i++) {\n        var context_menu_item = context_menu_items[i];\n\n        var assign_menu_item_action = function(ev){\n          ev.preventDefault();\n\n          options[this.id.replace(control + '_', '')].action.apply(self, [e]);\n          self.hideContextMenu();\n        };\n\n        google.maps.event.clearListeners(context_menu_item, 'click');\n        google.maps.event.addDomListenerOnce(context_menu_item, 'click', assign_menu_item_action, false);\n      }\n\n      var position = findAbsolutePosition.apply(this, [self.el]),\n          left = position[0] + e.pixel.x - 15,\n          top = position[1] + e.pixel.y- 15;\n\n      context_menu_element.style.left = left + \"px\";\n      context_menu_element.style.top = top + \"px\";\n\n      context_menu_element.style.display = 'block';\n    };\n\n    this.buildContextMenu = function(control, e) {\n      if (control === 'marker') {\n        e.pixel = {};\n\n        var overlay = new google.maps.OverlayView();\n        overlay.setMap(self.map);\n        \n        overlay.draw = function() {\n          var projection = overlay.getProjection(),\n              position = e.marker.getPosition();\n          \n          e.pixel = projection.fromLatLngToContainerPixel(position);\n\n          buildContextMenuHTML(control, e);\n        };\n      }\n      else {\n        buildContextMenuHTML(control, e);\n      }\n    };\n\n    this.setContextMenu = function(options) {\n      window.context_menu[self.el.id][options.control] = {};\n\n      var i,\n          ul = doc.createElement('ul');\n\n      for (i in options.options) {\n        if (options.options.hasOwnProperty(i)) {\n          var option = options.options[i];\n\n          window.context_menu[self.el.id][options.control][option.name] = {\n            title: option.title,\n            action: option.action\n          };\n        }\n      }\n\n      ul.id = 'gmaps_context_menu';\n      ul.style.display = 'none';\n      ul.style.position = 'absolute';\n      ul.style.minWidth = '100px';\n      ul.style.background = 'white';\n      ul.style.listStyle = 'none';\n      ul.style.padding = '8px';\n      ul.style.boxShadow = '2px 2px 6px #ccc';\n\n      doc.body.appendChild(ul);\n\n      var context_menu_element = getElementById('gmaps_context_menu')\n\n      google.maps.event.addDomListener(context_menu_element, 'mouseout', function(ev) {\n        if (!ev.relatedTarget || !this.contains(ev.relatedTarget)) {\n          window.setTimeout(function(){\n            context_menu_element.style.display = 'none';\n          }, 400);\n        }\n      }, false);\n    };\n\n    this.hideContextMenu = function() {\n      var context_menu_element = getElementById('gmaps_context_menu');\n\n      if (context_menu_element) {\n        context_menu_element.style.display = 'none';\n      }\n    };\n\n    var setupListener = function(object, name) {\n      google.maps.event.addListener(object, name, function(e){\n        if (e == undefined) {\n          e = this;\n        }\n\n        options[name].apply(this, [e]);\n\n        self.hideContextMenu();\n      });\n    };\n\n    //google.maps.event.addListener(this.map, 'idle', this.hideContextMenu);\n    google.maps.event.addListener(this.map, 'zoom_changed', this.hideContextMenu);\n\n    for (var ev = 0; ev < events_that_hide_context_menu.length; ev++) {\n      var name = events_that_hide_context_menu[ev];\n\n      if (name in options) {\n        setupListener(this.map, name);\n      }\n    }\n\n    for (var ev = 0; ev < events_that_doesnt_hide_context_menu.length; ev++) {\n      var name = events_that_doesnt_hide_context_menu[ev];\n\n      if (name in options) {\n        setupListener(this.map, name);\n      }\n    }\n\n    google.maps.event.addListener(this.map, 'rightclick', function(e) {\n      if (options.rightclick) {\n        options.rightclick.apply(this, [e]);\n      }\n\n      if(window.context_menu[self.el.id]['map'] != undefined) {\n        self.buildContextMenu('map', e);\n      }\n    });\n\n    this.refresh = function() {\n      google.maps.event.trigger(this.map, 'resize');\n    };\n\n    this.fitZoom = function() {\n      var latLngs = [],\n          markers_length = this.markers.length,\n          i;\n\n      for (i = 0; i < markers_length; i++) {\n        if(typeof(this.markers[i].visible) === 'boolean' && this.markers[i].visible) {\n          latLngs.push(this.markers[i].getPosition());\n        }\n      }\n\n      this.fitLatLngBounds(latLngs);\n    };\n\n    this.fitLatLngBounds = function(latLngs) {\n      var total = latLngs.length,\n          bounds = new google.maps.LatLngBounds(),\n          i;\n\n      for(i = 0; i < total; i++) {\n        bounds.extend(latLngs[i]);\n      }\n\n      this.map.fitBounds(bounds);\n    };\n\n    this.setCenter = function(lat, lng, callback) {\n      this.map.panTo(new google.maps.LatLng(lat, lng));\n\n      if (callback) {\n        callback();\n      }\n    };\n\n    this.getElement = function() {\n      return this.el;\n    };\n\n    this.zoomIn = function(value) {\n      value = value || 1;\n\n      this.zoom = this.map.getZoom() + value;\n      this.map.setZoom(this.zoom);\n    };\n\n    this.zoomOut = function(value) {\n      value = value || 1;\n\n      this.zoom = this.map.getZoom() - value;\n      this.map.setZoom(this.zoom);\n    };\n\n    var native_methods = [],\n        method;\n\n    for (method in this.map) {\n      if (typeof(this.map[method]) == 'function' && !this[method]) {\n        native_methods.push(method);\n      }\n    }\n\n    for (i = 0; i < native_methods.length; i++) {\n      (function(gmaps, scope, method_name) {\n        gmaps[method_name] = function(){\n          return scope[method_name].apply(scope, arguments);\n        };\n      })(this, this.map, native_methods[i]);\n    }\n  };\n\n  return GMaps;\n})(this);\n\nGMaps.prototype.createControl = function(options) {\n  var control = document.createElement('div');\n\n  control.style.cursor = 'pointer';\n  \n  if (options.disableDefaultStyles !== true) {\n    control.style.fontFamily = 'Roboto, Arial, sans-serif';\n    control.style.fontSize = '11px';\n    control.style.boxShadow = 'rgba(0, 0, 0, 0.298039) 0px 1px 4px -1px';\n  }\n\n  for (var option in options.style) {\n    control.style[option] = options.style[option];\n  }\n\n  if (options.id) {\n    control.id = options.id;\n  }\n\n  if (options.classes) {\n    control.className = options.classes;\n  }\n\n  if (options.content) {\n    if (typeof options.content === 'string') {\n      control.innerHTML = options.content;\n    }\n    else if (options.content instanceof HTMLElement) {\n      control.appendChild(options.content);\n    }\n  }\n\n  if (options.position) {\n    control.position = google.maps.ControlPosition[options.position.toUpperCase()];\n  }\n\n  for (var ev in options.events) {\n    (function(object, name) {\n      google.maps.event.addDomListener(object, name, function(){\n        options.events[name].apply(this, [this]);\n      });\n    })(control, ev);\n  }\n\n  control.index = 1;\n\n  return control;\n};\n\nGMaps.prototype.addControl = function(options) {\n  var control = this.createControl(options);\n  \n  this.controls.push(control);\n  this.map.controls[control.position].push(control);\n\n  return control;\n};\n\nGMaps.prototype.removeControl = function(control) {\n  var position = null,\n      i;\n\n  for (i = 0; i < this.controls.length; i++) {\n    if (this.controls[i] == control) {\n      position = this.controls[i].position;\n      this.controls.splice(i, 1);\n    }\n  }\n\n  if (position) {\n    for (i = 0; i < this.map.controls.length; i++) {\n      var controlsForPosition = this.map.controls[control.position];\n\n      if (controlsForPosition.getAt(i) == control) {\n        controlsForPosition.removeAt(i);\n\n        break;\n      }\n    }\n  }\n\n  return control;\n};\n\nGMaps.prototype.createMarker = function(options) {\n  if (options.lat == undefined && options.lng == undefined && options.position == undefined) {\n    throw 'No latitude or longitude defined.';\n  }\n\n  var self = this,\n      details = options.details,\n      fences = options.fences,\n      outside = options.outside,\n      base_options = {\n        position: new google.maps.LatLng(options.lat, options.lng),\n        map: null\n      },\n      marker_options = extend_object(base_options, options);\n\n  delete marker_options.lat;\n  delete marker_options.lng;\n  delete marker_options.fences;\n  delete marker_options.outside;\n\n  var marker = new google.maps.Marker(marker_options);\n\n  marker.fences = fences;\n\n  if (options.infoWindow) {\n    marker.infoWindow = new google.maps.InfoWindow(options.infoWindow);\n\n    var info_window_events = ['closeclick', 'content_changed', 'domready', 'position_changed', 'zindex_changed'];\n\n    for (var ev = 0; ev < info_window_events.length; ev++) {\n      (function(object, name) {\n        if (options.infoWindow[name]) {\n          google.maps.event.addListener(object, name, function(e){\n            options.infoWindow[name].apply(this, [e]);\n          });\n        }\n      })(marker.infoWindow, info_window_events[ev]);\n    }\n  }\n\n  var marker_events = ['animation_changed', 'clickable_changed', 'cursor_changed', 'draggable_changed', 'flat_changed', 'icon_changed', 'position_changed', 'shadow_changed', 'shape_changed', 'title_changed', 'visible_changed', 'zindex_changed'];\n\n  var marker_events_with_mouse = ['dblclick', 'drag', 'dragend', 'dragstart', 'mousedown', 'mouseout', 'mouseover', 'mouseup'];\n\n  for (var ev = 0; ev < marker_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(){\n          options[name].apply(this, [this]);\n        });\n      }\n    })(marker, marker_events[ev]);\n  }\n\n  for (var ev = 0; ev < marker_events_with_mouse.length; ev++) {\n    (function(map, object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(me){\n          if(!me.pixel){\n            me.pixel = map.getProjection().fromLatLngToPoint(me.latLng)\n          }\n          \n          options[name].apply(this, [me]);\n        });\n      }\n    })(this.map, marker, marker_events_with_mouse[ev]);\n  }\n\n  google.maps.event.addListener(marker, 'click', function() {\n    this.details = details;\n\n    if (options.click) {\n      options.click.apply(this, [this]);\n    }\n\n    if (marker.infoWindow) {\n      self.hideInfoWindows();\n      marker.infoWindow.open(self.map, marker);\n    }\n  });\n\n  google.maps.event.addListener(marker, 'rightclick', function(e) {\n    e.marker = this;\n\n    if (options.rightclick) {\n      options.rightclick.apply(this, [e]);\n    }\n\n    if (window.context_menu[self.el.id]['marker'] != undefined) {\n      self.buildContextMenu('marker', e);\n    }\n  });\n\n  if (marker.fences) {\n    google.maps.event.addListener(marker, 'dragend', function() {\n      self.checkMarkerGeofence(marker, function(m, f) {\n        outside(m, f);\n      });\n    });\n  }\n\n  return marker;\n};\n\nGMaps.prototype.addMarker = function(options) {\n  var marker;\n  if(options.hasOwnProperty('gm_accessors_')) {\n    // Native google.maps.Marker object\n    marker = options;\n  }\n  else {\n    if ((options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) || options.position) {\n      marker = this.createMarker(options);\n    }\n    else {\n      throw 'No latitude or longitude defined.';\n    }\n  }\n\n  marker.setMap(this.map);\n\n  if(this.markerClusterer) {\n    this.markerClusterer.addMarker(marker);\n  }\n\n  this.markers.push(marker);\n\n  GMaps.fire('marker_added', marker, this);\n\n  return marker;\n};\n\nGMaps.prototype.addMarkers = function(array) {\n  for (var i = 0, marker; marker=array[i]; i++) {\n    this.addMarker(marker);\n  }\n\n  return this.markers;\n};\n\nGMaps.prototype.hideInfoWindows = function() {\n  for (var i = 0, marker; marker = this.markers[i]; i++){\n    if (marker.infoWindow) {\n      marker.infoWindow.close();\n    }\n  }\n};\n\nGMaps.prototype.removeMarker = function(marker) {\n  for (var i = 0; i < this.markers.length; i++) {\n    if (this.markers[i] === marker) {\n      this.markers[i].setMap(null);\n      this.markers.splice(i, 1);\n\n      if(this.markerClusterer) {\n        this.markerClusterer.removeMarker(marker);\n      }\n\n      GMaps.fire('marker_removed', marker, this);\n\n      break;\n    }\n  }\n\n  return marker;\n};\n\nGMaps.prototype.removeMarkers = function (collection) {\n  var new_markers = [];\n\n  if (typeof collection == 'undefined') {\n    for (var i = 0; i < this.markers.length; i++) {\n      var marker = this.markers[i];\n      marker.setMap(null);\n\n      if(this.markerClusterer) {\n        this.markerClusterer.removeMarker(marker);\n      }\n\n      GMaps.fire('marker_removed', marker, this);\n    }\n    \n    this.markers = new_markers;\n  }\n  else {\n    for (var i = 0; i < collection.length; i++) {\n      var index = this.markers.indexOf(collection[i]);\n\n      if (index > -1) {\n        var marker = this.markers[index];\n        marker.setMap(null);\n\n        if(this.markerClusterer) {\n          this.markerClusterer.removeMarker(marker);\n        }\n\n        GMaps.fire('marker_removed', marker, this);\n      }\n    }\n\n    for (var i = 0; i < this.markers.length; i++) {\n      var marker = this.markers[i];\n      if (marker.getMap() != null) {\n        new_markers.push(marker);\n      }\n    }\n\n    this.markers = new_markers;\n  }\n};\n\nGMaps.prototype.drawOverlay = function(options) {\n  var overlay = new google.maps.OverlayView(),\n      auto_show = true;\n\n  overlay.setMap(this.map);\n\n  if (options.auto_show != null) {\n    auto_show = options.auto_show;\n  }\n\n  overlay.onAdd = function() {\n    var el = document.createElement('div');\n\n    el.style.borderStyle = \"none\";\n    el.style.borderWidth = \"0px\";\n    el.style.position = \"absolute\";\n    el.style.zIndex = 100;\n    el.innerHTML = options.content;\n\n    overlay.el = el;\n\n    if (!options.layer) {\n      options.layer = 'overlayLayer';\n    }\n    \n    var panes = this.getPanes(),\n        overlayLayer = panes[options.layer],\n        stop_overlay_events = ['contextmenu', 'DOMMouseScroll', 'dblclick', 'mousedown'];\n\n    overlayLayer.appendChild(el);\n\n    for (var ev = 0; ev < stop_overlay_events.length; ev++) {\n      (function(object, name) {\n        google.maps.event.addDomListener(object, name, function(e){\n          if (navigator.userAgent.toLowerCase().indexOf('msie') != -1 && document.all) {\n            e.cancelBubble = true;\n            e.returnValue = false;\n          }\n          else {\n            e.stopPropagation();\n          }\n        });\n      })(el, stop_overlay_events[ev]);\n    }\n\n    if (options.click) {\n      panes.overlayMouseTarget.appendChild(overlay.el);\n      google.maps.event.addDomListener(overlay.el, 'click', function() {\n        options.click.apply(overlay, [overlay]);\n      });\n    }\n\n    google.maps.event.trigger(this, 'ready');\n  };\n\n  overlay.draw = function() {\n    var projection = this.getProjection(),\n        pixel = projection.fromLatLngToDivPixel(new google.maps.LatLng(options.lat, options.lng));\n\n    options.horizontalOffset = options.horizontalOffset || 0;\n    options.verticalOffset = options.verticalOffset || 0;\n\n    var el = overlay.el,\n        content = el.children[0],\n        content_height = content.clientHeight,\n        content_width = content.clientWidth;\n\n    switch (options.verticalAlign) {\n      case 'top':\n        el.style.top = (pixel.y - content_height + options.verticalOffset) + 'px';\n        break;\n      default:\n      case 'middle':\n        el.style.top = (pixel.y - (content_height / 2) + options.verticalOffset) + 'px';\n        break;\n      case 'bottom':\n        el.style.top = (pixel.y + options.verticalOffset) + 'px';\n        break;\n    }\n\n    switch (options.horizontalAlign) {\n      case 'left':\n        el.style.left = (pixel.x - content_width + options.horizontalOffset) + 'px';\n        break;\n      default:\n      case 'center':\n        el.style.left = (pixel.x - (content_width / 2) + options.horizontalOffset) + 'px';\n        break;\n      case 'right':\n        el.style.left = (pixel.x + options.horizontalOffset) + 'px';\n        break;\n    }\n\n    el.style.display = auto_show ? 'block' : 'none';\n\n    if (!auto_show) {\n      options.show.apply(this, [el]);\n    }\n  };\n\n  overlay.onRemove = function() {\n    var el = overlay.el;\n\n    if (options.remove) {\n      options.remove.apply(this, [el]);\n    }\n    else {\n      overlay.el.parentNode.removeChild(overlay.el);\n      overlay.el = null;\n    }\n  };\n\n  this.overlays.push(overlay);\n  return overlay;\n};\n\nGMaps.prototype.removeOverlay = function(overlay) {\n  for (var i = 0; i < this.overlays.length; i++) {\n    if (this.overlays[i] === overlay) {\n      this.overlays[i].setMap(null);\n      this.overlays.splice(i, 1);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removeOverlays = function() {\n  for (var i = 0, item; item = this.overlays[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.overlays = [];\n};\n\nGMaps.prototype.drawPolyline = function(options) {\n  var path = [],\n      points = options.path;\n\n  if (points.length) {\n    if (points[0][0] === undefined) {\n      path = points;\n    }\n    else {\n      for (var i = 0, latlng; latlng = points[i]; i++) {\n        path.push(new google.maps.LatLng(latlng[0], latlng[1]));\n      }\n    }\n  }\n\n  var polyline_options = {\n    map: this.map,\n    path: path,\n    strokeColor: options.strokeColor,\n    strokeOpacity: options.strokeOpacity,\n    strokeWeight: options.strokeWeight,\n    geodesic: options.geodesic,\n    clickable: true,\n    editable: false,\n    visible: true\n  };\n\n  if (options.hasOwnProperty(\"clickable\")) {\n    polyline_options.clickable = options.clickable;\n  }\n\n  if (options.hasOwnProperty(\"editable\")) {\n    polyline_options.editable = options.editable;\n  }\n\n  if (options.hasOwnProperty(\"icons\")) {\n    polyline_options.icons = options.icons;\n  }\n\n  if (options.hasOwnProperty(\"zIndex\")) {\n    polyline_options.zIndex = options.zIndex;\n  }\n\n  var polyline = new google.maps.Polyline(polyline_options);\n\n  var polyline_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polyline_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polyline, polyline_events[ev]);\n  }\n\n  this.polylines.push(polyline);\n\n  GMaps.fire('polyline_added', polyline, this);\n\n  return polyline;\n};\n\nGMaps.prototype.removePolyline = function(polyline) {\n  for (var i = 0; i < this.polylines.length; i++) {\n    if (this.polylines[i] === polyline) {\n      this.polylines[i].setMap(null);\n      this.polylines.splice(i, 1);\n\n      GMaps.fire('polyline_removed', polyline, this);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removePolylines = function() {\n  for (var i = 0, item; item = this.polylines[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.polylines = [];\n};\n\nGMaps.prototype.drawCircle = function(options) {\n  options =  extend_object({\n    map: this.map,\n    center: new google.maps.LatLng(options.lat, options.lng)\n  }, options);\n\n  delete options.lat;\n  delete options.lng;\n\n  var polygon = new google.maps.Circle(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  return polygon;\n};\n\nGMaps.prototype.drawRectangle = function(options) {\n  options = extend_object({\n    map: this.map\n  }, options);\n\n  var latLngBounds = new google.maps.LatLngBounds(\n    new google.maps.LatLng(options.bounds[0][0], options.bounds[0][1]),\n    new google.maps.LatLng(options.bounds[1][0], options.bounds[1][1])\n  );\n\n  options.bounds = latLngBounds;\n\n  var polygon = new google.maps.Rectangle(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  return polygon;\n};\n\nGMaps.prototype.drawPolygon = function(options) {\n  var useGeoJSON = false;\n\n  if(options.hasOwnProperty(\"useGeoJSON\")) {\n    useGeoJSON = options.useGeoJSON;\n  }\n\n  delete options.useGeoJSON;\n\n  options = extend_object({\n    map: this.map\n  }, options);\n\n  if (useGeoJSON == false) {\n    options.paths = [options.paths.slice(0)];\n  }\n\n  if (options.paths.length > 0) {\n    if (options.paths[0].length > 0) {\n      options.paths = array_flat(array_map(options.paths, arrayToLatLng, useGeoJSON));\n    }\n  }\n\n  var polygon = new google.maps.Polygon(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  GMaps.fire('polygon_added', polygon, this);\n\n  return polygon;\n};\n\nGMaps.prototype.removePolygon = function(polygon) {\n  for (var i = 0; i < this.polygons.length; i++) {\n    if (this.polygons[i] === polygon) {\n      this.polygons[i].setMap(null);\n      this.polygons.splice(i, 1);\n\n      GMaps.fire('polygon_removed', polygon, this);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removePolygons = function() {\n  for (var i = 0, item; item = this.polygons[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.polygons = [];\n};\n\nGMaps.prototype.getFromFusionTables = function(options) {\n  var events = options.events;\n\n  delete options.events;\n\n  var fusion_tables_options = options,\n      layer = new google.maps.FusionTablesLayer(fusion_tables_options);\n\n  for (var ev in events) {\n    (function(object, name) {\n      google.maps.event.addListener(object, name, function(e) {\n        events[name].apply(this, [e]);\n      });\n    })(layer, ev);\n  }\n\n  this.layers.push(layer);\n\n  return layer;\n};\n\nGMaps.prototype.loadFromFusionTables = function(options) {\n  var layer = this.getFromFusionTables(options);\n  layer.setMap(this.map);\n\n  return layer;\n};\n\nGMaps.prototype.getFromKML = function(options) {\n  var url = options.url,\n      events = options.events;\n\n  delete options.url;\n  delete options.events;\n\n  var kml_options = options,\n      layer = new google.maps.KmlLayer(url, kml_options);\n\n  for (var ev in events) {\n    (function(object, name) {\n      google.maps.event.addListener(object, name, function(e) {\n        events[name].apply(this, [e]);\n      });\n    })(layer, ev);\n  }\n\n  this.layers.push(layer);\n\n  return layer;\n};\n\nGMaps.prototype.loadFromKML = function(options) {\n  var layer = this.getFromKML(options);\n  layer.setMap(this.map);\n\n  return layer;\n};\n\nGMaps.prototype.addLayer = function(layerName, options) {\n  //var default_layers = ['weather', 'clouds', 'traffic', 'transit', 'bicycling', 'panoramio', 'places'];\n  options = options || {};\n  var layer;\n\n  switch(layerName) {\n    case 'weather': this.singleLayers.weather = layer = new google.maps.weather.WeatherLayer();\n      break;\n    case 'clouds': this.singleLayers.clouds = layer = new google.maps.weather.CloudLayer();\n      break;\n    case 'traffic': this.singleLayers.traffic = layer = new google.maps.TrafficLayer();\n      break;\n    case 'transit': this.singleLayers.transit = layer = new google.maps.TransitLayer();\n      break;\n    case 'bicycling': this.singleLayers.bicycling = layer = new google.maps.BicyclingLayer();\n      break;\n    case 'panoramio':\n        this.singleLayers.panoramio = layer = new google.maps.panoramio.PanoramioLayer();\n        layer.setTag(options.filter);\n        delete options.filter;\n\n        //click event\n        if (options.click) {\n          google.maps.event.addListener(layer, 'click', function(event) {\n            options.click(event);\n            delete options.click;\n          });\n        }\n      break;\n      case 'places':\n        this.singleLayers.places = layer = new google.maps.places.PlacesService(this.map);\n\n        //search, nearbySearch, radarSearch callback, Both are the same\n        if (options.search || options.nearbySearch || options.radarSearch) {\n          var placeSearchRequest  = {\n            bounds : options.bounds || null,\n            keyword : options.keyword || null,\n            location : options.location || null,\n            name : options.name || null,\n            radius : options.radius || null,\n            rankBy : options.rankBy || null,\n            types : options.types || null\n          };\n\n          if (options.radarSearch) {\n            layer.radarSearch(placeSearchRequest, options.radarSearch);\n          }\n\n          if (options.search) {\n            layer.search(placeSearchRequest, options.search);\n          }\n\n          if (options.nearbySearch) {\n            layer.nearbySearch(placeSearchRequest, options.nearbySearch);\n          }\n        }\n\n        //textSearch callback\n        if (options.textSearch) {\n          var textSearchRequest  = {\n            bounds : options.bounds || null,\n            location : options.location || null,\n            query : options.query || null,\n            radius : options.radius || null\n          };\n\n          layer.textSearch(textSearchRequest, options.textSearch);\n        }\n      break;\n  }\n\n  if (layer !== undefined) {\n    if (typeof layer.setOptions == 'function') {\n      layer.setOptions(options);\n    }\n    if (typeof layer.setMap == 'function') {\n      layer.setMap(this.map);\n    }\n\n    return layer;\n  }\n};\n\nGMaps.prototype.removeLayer = function(layer) {\n  if (typeof(layer) == \"string\" && this.singleLayers[layer] !== undefined) {\n     this.singleLayers[layer].setMap(null);\n\n     delete this.singleLayers[layer];\n  }\n  else {\n    for (var i = 0; i < this.layers.length; i++) {\n      if (this.layers[i] === layer) {\n        this.layers[i].setMap(null);\n        this.layers.splice(i, 1);\n\n        break;\n      }\n    }\n  }\n};\n\nvar travelMode, unitSystem;\n\nGMaps.prototype.getRoutes = function(options) {\n  switch (options.travelMode) {\n    case 'bicycling':\n      travelMode = google.maps.TravelMode.BICYCLING;\n      break;\n    case 'transit':\n      travelMode = google.maps.TravelMode.TRANSIT;\n      break;\n    case 'driving':\n      travelMode = google.maps.TravelMode.DRIVING;\n      break;\n    default:\n      travelMode = google.maps.TravelMode.WALKING;\n      break;\n  }\n\n  if (options.unitSystem === 'imperial') {\n    unitSystem = google.maps.UnitSystem.IMPERIAL;\n  }\n  else {\n    unitSystem = google.maps.UnitSystem.METRIC;\n  }\n\n  var base_options = {\n        avoidHighways: false,\n        avoidTolls: false,\n        optimizeWaypoints: false,\n        waypoints: []\n      },\n      request_options =  extend_object(base_options, options);\n\n  request_options.origin = /string/.test(typeof options.origin) ? options.origin : new google.maps.LatLng(options.origin[0], options.origin[1]);\n  request_options.destination = /string/.test(typeof options.destination) ? options.destination : new google.maps.LatLng(options.destination[0], options.destination[1]);\n  request_options.travelMode = travelMode;\n  request_options.unitSystem = unitSystem;\n\n  delete request_options.callback;\n  delete request_options.error;\n\n  var self = this,\n      service = new google.maps.DirectionsService();\n\n  service.route(request_options, function(result, status) {\n    if (status === google.maps.DirectionsStatus.OK) {\n      for (var r in result.routes) {\n        if (result.routes.hasOwnProperty(r)) {\n          self.routes.push(result.routes[r]);\n        }\n      }\n\n      if (options.callback) {\n        options.callback(self.routes);\n      }\n    }\n    else {\n      if (options.error) {\n        options.error(result, status);\n      }\n    }\n  });\n};\n\nGMaps.prototype.removeRoutes = function() {\n  this.routes = [];\n};\n\nGMaps.prototype.getElevations = function(options) {\n  options = extend_object({\n    locations: [],\n    path : false,\n    samples : 256\n  }, options);\n\n  if (options.locations.length > 0) {\n    if (options.locations[0].length > 0) {\n      options.locations = array_flat(array_map([options.locations], arrayToLatLng,  false));\n    }\n  }\n\n  var callback = options.callback;\n  delete options.callback;\n\n  var service = new google.maps.ElevationService();\n\n  //location request\n  if (!options.path) {\n    delete options.path;\n    delete options.samples;\n\n    service.getElevationForLocations(options, function(result, status) {\n      if (callback && typeof(callback) === \"function\") {\n        callback(result, status);\n      }\n    });\n  //path request\n  } else {\n    var pathRequest = {\n      path : options.locations,\n      samples : options.samples\n    };\n\n    service.getElevationAlongPath(pathRequest, function(result, status) {\n     if (callback && typeof(callback) === \"function\") {\n        callback(result, status);\n      }\n    });\n  }\n};\n\nGMaps.prototype.cleanRoute = GMaps.prototype.removePolylines;\n\nGMaps.prototype.drawRoute = function(options) {\n  var self = this;\n\n  this.getRoutes({\n    origin: options.origin,\n    destination: options.destination,\n    travelMode: options.travelMode,\n    waypoints: options.waypoints,\n    unitSystem: options.unitSystem,\n    error: options.error,\n    callback: function(e) {\n      if (e.length > 0) {\n        var polyline_options = {\n          path: e[e.length - 1].overview_path,\n          strokeColor: options.strokeColor,\n          strokeOpacity: options.strokeOpacity,\n          strokeWeight: options.strokeWeight\n        };\n\n        if (options.hasOwnProperty(\"icons\")) {\n          polyline_options.icons = options.icons;\n        }\n\n        self.drawPolyline(polyline_options);\n        \n        if (options.callback) {\n          options.callback(e[e.length - 1]);\n        }\n      }\n    }\n  });\n};\n\nGMaps.prototype.travelRoute = function(options) {\n  if (options.origin && options.destination) {\n    this.getRoutes({\n      origin: options.origin,\n      destination: options.destination,\n      travelMode: options.travelMode,\n      waypoints : options.waypoints,\n      unitSystem: options.unitSystem,\n      error: options.error,\n      callback: function(e) {\n        //start callback\n        if (e.length > 0 && options.start) {\n          options.start(e[e.length - 1]);\n        }\n\n        //step callback\n        if (e.length > 0 && options.step) {\n          var route = e[e.length - 1];\n          if (route.legs.length > 0) {\n            var steps = route.legs[0].steps;\n            for (var i = 0, step; step = steps[i]; i++) {\n              step.step_number = i;\n              options.step(step, (route.legs[0].steps.length - 1));\n            }\n          }\n        }\n\n        //end callback\n        if (e.length > 0 && options.end) {\n           options.end(e[e.length - 1]);\n        }\n      }\n    });\n  }\n  else if (options.route) {\n    if (options.route.legs.length > 0) {\n      var steps = options.route.legs[0].steps;\n      for (var i = 0, step; step = steps[i]; i++) {\n        step.step_number = i;\n        options.step(step);\n      }\n    }\n  }\n};\n\nGMaps.prototype.drawSteppedRoute = function(options) {\n  var self = this;\n  \n  if (options.origin && options.destination) {\n    this.getRoutes({\n      origin: options.origin,\n      destination: options.destination,\n      travelMode: options.travelMode,\n      waypoints : options.waypoints,\n      error: options.error,\n      callback: function(e) {\n        //start callback\n        if (e.length > 0 && options.start) {\n          options.start(e[e.length - 1]);\n        }\n\n        //step callback\n        if (e.length > 0 && options.step) {\n          var route = e[e.length - 1];\n          if (route.legs.length > 0) {\n            var steps = route.legs[0].steps;\n            for (var i = 0, step; step = steps[i]; i++) {\n              step.step_number = i;\n              var polyline_options = {\n                path: step.path,\n                strokeColor: options.strokeColor,\n                strokeOpacity: options.strokeOpacity,\n                strokeWeight: options.strokeWeight\n              };\n\n              if (options.hasOwnProperty(\"icons\")) {\n                polyline_options.icons = options.icons;\n              }\n\n              self.drawPolyline(polyline_options);\n              options.step(step, (route.legs[0].steps.length - 1));\n            }\n          }\n        }\n\n        //end callback\n        if (e.length > 0 && options.end) {\n           options.end(e[e.length - 1]);\n        }\n      }\n    });\n  }\n  else if (options.route) {\n    if (options.route.legs.length > 0) {\n      var steps = options.route.legs[0].steps;\n      for (var i = 0, step; step = steps[i]; i++) {\n        step.step_number = i;\n        var polyline_options = {\n          path: step.path,\n          strokeColor: options.strokeColor,\n          strokeOpacity: options.strokeOpacity,\n          strokeWeight: options.strokeWeight\n        };\n\n        if (options.hasOwnProperty(\"icons\")) {\n          polyline_options.icons = options.icons;\n        }\n\n        self.drawPolyline(polyline_options);\n        options.step(step);\n      }\n    }\n  }\n};\n\nGMaps.Route = function(options) {\n  this.origin = options.origin;\n  this.destination = options.destination;\n  this.waypoints = options.waypoints;\n\n  this.map = options.map;\n  this.route = options.route;\n  this.step_count = 0;\n  this.steps = this.route.legs[0].steps;\n  this.steps_length = this.steps.length;\n\n  var polyline_options = {\n    path: new google.maps.MVCArray(),\n    strokeColor: options.strokeColor,\n    strokeOpacity: options.strokeOpacity,\n    strokeWeight: options.strokeWeight\n  };\n\n  if (options.hasOwnProperty(\"icons\")) {\n    polyline_options.icons = options.icons;\n  }\n\n  this.polyline = this.map.drawPolyline(polyline_options).getPath();\n};\n\nGMaps.Route.prototype.getRoute = function(options) {\n  var self = this;\n\n  this.map.getRoutes({\n    origin : this.origin,\n    destination : this.destination,\n    travelMode : options.travelMode,\n    waypoints : this.waypoints || [],\n    error: options.error,\n    callback : function() {\n      self.route = e[0];\n\n      if (options.callback) {\n        options.callback.call(self);\n      }\n    }\n  });\n};\n\nGMaps.Route.prototype.back = function() {\n  if (this.step_count > 0) {\n    this.step_count--;\n    var path = this.route.legs[0].steps[this.step_count].path;\n\n    for (var p in path){\n      if (path.hasOwnProperty(p)){\n        this.polyline.pop();\n      }\n    }\n  }\n};\n\nGMaps.Route.prototype.forward = function() {\n  if (this.step_count < this.steps_length) {\n    var path = this.route.legs[0].steps[this.step_count].path;\n\n    for (var p in path){\n      if (path.hasOwnProperty(p)){\n        this.polyline.push(path[p]);\n      }\n    }\n    this.step_count++;\n  }\n};\n\nGMaps.prototype.checkGeofence = function(lat, lng, fence) {\n  return fence.containsLatLng(new google.maps.LatLng(lat, lng));\n};\n\nGMaps.prototype.checkMarkerGeofence = function(marker, outside_callback) {\n  if (marker.fences) {\n    for (var i = 0, fence; fence = marker.fences[i]; i++) {\n      var pos = marker.getPosition();\n      if (!this.checkGeofence(pos.lat(), pos.lng(), fence)) {\n        outside_callback(marker, fence);\n      }\n    }\n  }\n};\n\nGMaps.prototype.toImage = function(options) {\n  var options = options || {},\n      static_map_options = {};\n\n  static_map_options['size'] = options['size'] || [this.el.clientWidth, this.el.clientHeight];\n  static_map_options['lat'] = this.getCenter().lat();\n  static_map_options['lng'] = this.getCenter().lng();\n\n  if (this.markers.length > 0) {\n    static_map_options['markers'] = [];\n    \n    for (var i = 0; i < this.markers.length; i++) {\n      static_map_options['markers'].push({\n        lat: this.markers[i].getPosition().lat(),\n        lng: this.markers[i].getPosition().lng()\n      });\n    }\n  }\n\n  if (this.polylines.length > 0) {\n    var polyline = this.polylines[0];\n    \n    static_map_options['polyline'] = {};\n    static_map_options['polyline']['path'] = google.maps.geometry.encoding.encodePath(polyline.getPath());\n    static_map_options['polyline']['strokeColor'] = polyline.strokeColor\n    static_map_options['polyline']['strokeOpacity'] = polyline.strokeOpacity\n    static_map_options['polyline']['strokeWeight'] = polyline.strokeWeight\n  }\n\n  return GMaps.staticMapURL(static_map_options);\n};\n\nGMaps.staticMapURL = function(options){\n  var parameters = [],\n      data,\n      static_root = (location.protocol === 'file:' ? 'http:' : location.protocol ) + '//maps.googleapis.com/maps/api/staticmap';\n\n  if (options.url) {\n    static_root = options.url;\n    delete options.url;\n  }\n\n  static_root += '?';\n\n  var markers = options.markers;\n  \n  delete options.markers;\n\n  if (!markers && options.marker) {\n    markers = [options.marker];\n    delete options.marker;\n  }\n\n  var styles = options.styles;\n\n  delete options.styles;\n\n  var polyline = options.polyline;\n  delete options.polyline;\n\n  /** Map options **/\n  if (options.center) {\n    parameters.push('center=' + options.center);\n    delete options.center;\n  }\n  else if (options.address) {\n    parameters.push('center=' + options.address);\n    delete options.address;\n  }\n  else if (options.lat) {\n    parameters.push(['center=', options.lat, ',', options.lng].join(''));\n    delete options.lat;\n    delete options.lng;\n  }\n  else if (options.visible) {\n    var visible = encodeURI(options.visible.join('|'));\n    parameters.push('visible=' + visible);\n  }\n\n  var size = options.size;\n  if (size) {\n    if (size.join) {\n      size = size.join('x');\n    }\n    delete options.size;\n  }\n  else {\n    size = '630x300';\n  }\n  parameters.push('size=' + size);\n\n  if (!options.zoom && options.zoom !== false) {\n    options.zoom = 15;\n  }\n\n  var sensor = options.hasOwnProperty('sensor') ? !!options.sensor : true;\n  delete options.sensor;\n  parameters.push('sensor=' + sensor);\n\n  for (var param in options) {\n    if (options.hasOwnProperty(param)) {\n      parameters.push(param + '=' + options[param]);\n    }\n  }\n\n  /** Markers **/\n  if (markers) {\n    var marker, loc;\n\n    for (var i = 0; data = markers[i]; i++) {\n      marker = [];\n\n      if (data.size && data.size !== 'normal') {\n        marker.push('size:' + data.size);\n        delete data.size;\n      }\n      else if (data.icon) {\n        marker.push('icon:' + encodeURI(data.icon));\n        delete data.icon;\n      }\n\n      if (data.color) {\n        marker.push('color:' + data.color.replace('#', '0x'));\n        delete data.color;\n      }\n\n      if (data.label) {\n        marker.push('label:' + data.label[0].toUpperCase());\n        delete data.label;\n      }\n\n      loc = (data.address ? data.address : data.lat + ',' + data.lng);\n      delete data.address;\n      delete data.lat;\n      delete data.lng;\n\n      for(var param in data){\n        if (data.hasOwnProperty(param)) {\n          marker.push(param + ':' + data[param]);\n        }\n      }\n\n      if (marker.length || i === 0) {\n        marker.push(loc);\n        marker = marker.join('|');\n        parameters.push('markers=' + encodeURI(marker));\n      }\n      // New marker without styles\n      else {\n        marker = parameters.pop() + encodeURI('|' + loc);\n        parameters.push(marker);\n      }\n    }\n  }\n\n  /** Map Styles **/\n  if (styles) {\n    for (var i = 0; i < styles.length; i++) {\n      var styleRule = [];\n      if (styles[i].featureType){\n        styleRule.push('feature:' + styles[i].featureType.toLowerCase());\n      }\n\n      if (styles[i].elementType) {\n        styleRule.push('element:' + styles[i].elementType.toLowerCase());\n      }\n\n      for (var j = 0; j < styles[i].stylers.length; j++) {\n        for (var p in styles[i].stylers[j]) {\n          var ruleArg = styles[i].stylers[j][p];\n          if (p == 'hue' || p == 'color') {\n            ruleArg = '0x' + ruleArg.substring(1);\n          }\n          styleRule.push(p + ':' + ruleArg);\n        }\n      }\n\n      var rule = styleRule.join('|');\n      if (rule != '') {\n        parameters.push('style=' + rule);\n      }\n    }\n  }\n\n  /** Polylines **/\n  function parseColor(color, opacity) {\n    if (color[0] === '#'){\n      color = color.replace('#', '0x');\n\n      if (opacity) {\n        opacity = parseFloat(opacity);\n        opacity = Math.min(1, Math.max(opacity, 0));\n        if (opacity === 0) {\n          return '0x00000000';\n        }\n        opacity = (opacity * 255).toString(16);\n        if (opacity.length === 1) {\n          opacity += opacity;\n        }\n\n        color = color.slice(0,8) + opacity;\n      }\n    }\n    return color;\n  }\n\n  if (polyline) {\n    data = polyline;\n    polyline = [];\n\n    if (data.strokeWeight) {\n      polyline.push('weight:' + parseInt(data.strokeWeight, 10));\n    }\n\n    if (data.strokeColor) {\n      var color = parseColor(data.strokeColor, data.strokeOpacity);\n      polyline.push('color:' + color);\n    }\n\n    if (data.fillColor) {\n      var fillcolor = parseColor(data.fillColor, data.fillOpacity);\n      polyline.push('fillcolor:' + fillcolor);\n    }\n\n    var path = data.path;\n    if (path.join) {\n      for (var j=0, pos; pos=path[j]; j++) {\n        polyline.push(pos.join(','));\n      }\n    }\n    else {\n      polyline.push('enc:' + path);\n    }\n\n    polyline = polyline.join('|');\n    parameters.push('path=' + encodeURI(polyline));\n  }\n\n  /** Retina support **/\n  var dpi = window.devicePixelRatio || 1;\n  parameters.push('scale=' + dpi);\n\n  parameters = parameters.join('&');\n  return static_root + parameters;\n};\n\nGMaps.prototype.addMapType = function(mapTypeId, options) {\n  if (options.hasOwnProperty(\"getTileUrl\") && typeof(options[\"getTileUrl\"]) == \"function\") {\n    options.tileSize = options.tileSize || new google.maps.Size(256, 256);\n\n    var mapType = new google.maps.ImageMapType(options);\n\n    this.map.mapTypes.set(mapTypeId, mapType);\n  }\n  else {\n    throw \"'getTileUrl' function required.\";\n  }\n};\n\nGMaps.prototype.addOverlayMapType = function(options) {\n  if (options.hasOwnProperty(\"getTile\") && typeof(options[\"getTile\"]) == \"function\") {\n    var overlayMapTypeIndex = options.index;\n\n    delete options.index;\n\n    this.map.overlayMapTypes.insertAt(overlayMapTypeIndex, options);\n  }\n  else {\n    throw \"'getTile' function required.\";\n  }\n};\n\nGMaps.prototype.removeOverlayMapType = function(overlayMapTypeIndex) {\n  this.map.overlayMapTypes.removeAt(overlayMapTypeIndex);\n};\n\nGMaps.prototype.addStyle = function(options) {\n  var styledMapType = new google.maps.StyledMapType(options.styles, { name: options.styledMapName });\n\n  this.map.mapTypes.set(options.mapTypeId, styledMapType);\n};\n\nGMaps.prototype.setStyle = function(mapTypeId) {\n  this.map.setMapTypeId(mapTypeId);\n};\n\nGMaps.prototype.createPanorama = function(streetview_options) {\n  if (!streetview_options.hasOwnProperty('lat') || !streetview_options.hasOwnProperty('lng')) {\n    streetview_options.lat = this.getCenter().lat();\n    streetview_options.lng = this.getCenter().lng();\n  }\n\n  this.panorama = GMaps.createPanorama(streetview_options);\n\n  this.map.setStreetView(this.panorama);\n\n  return this.panorama;\n};\n\nGMaps.createPanorama = function(options) {\n  var el = getElementById(options.el, options.context);\n\n  options.position = new google.maps.LatLng(options.lat, options.lng);\n\n  delete options.el;\n  delete options.context;\n  delete options.lat;\n  delete options.lng;\n\n  var streetview_events = ['closeclick', 'links_changed', 'pano_changed', 'position_changed', 'pov_changed', 'resize', 'visible_changed'],\n      streetview_options = extend_object({visible : true}, options);\n\n  for (var i = 0; i < streetview_events.length; i++) {\n    delete streetview_options[streetview_events[i]];\n  }\n\n  var panorama = new google.maps.StreetViewPanorama(el, streetview_options);\n\n  for (var i = 0; i < streetview_events.length; i++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(){\n          options[name].apply(this);\n        });\n      }\n    })(panorama, streetview_events[i]);\n  }\n\n  return panorama;\n};\n\nGMaps.prototype.on = function(event_name, handler) {\n  return GMaps.on(event_name, this, handler);\n};\n\nGMaps.prototype.off = function(event_name) {\n  GMaps.off(event_name, this);\n};\n\nGMaps.custom_events = ['marker_added', 'marker_removed', 'polyline_added', 'polyline_removed', 'polygon_added', 'polygon_removed', 'geolocated', 'geolocation_failed'];\n\nGMaps.on = function(event_name, object, handler) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    if(object instanceof GMaps) object = object.map; \n    return google.maps.event.addListener(object, event_name, handler);\n  }\n  else {\n    var registered_event = {\n      handler : handler,\n      eventName : event_name\n    };\n\n    object.registered_events[event_name] = object.registered_events[event_name] || [];\n    object.registered_events[event_name].push(registered_event);\n\n    return registered_event;\n  }\n};\n\nGMaps.off = function(event_name, object) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    if(object instanceof GMaps) object = object.map; \n    google.maps.event.clearListeners(object, event_name);\n  }\n  else {\n    object.registered_events[event_name] = [];\n  }\n};\n\nGMaps.fire = function(event_name, object, scope) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    google.maps.event.trigger(object, event_name, Array.prototype.slice.apply(arguments).slice(2));\n  }\n  else {\n    if(event_name in scope.registered_events) {\n      var firing_events = scope.registered_events[event_name];\n\n      for(var i = 0; i < firing_events.length; i++) {\n        (function(handler, scope, object) {\n          handler.apply(scope, [object]);\n        })(firing_events[i]['handler'], scope, object);\n      }\n    }\n  }\n};\n\nGMaps.geolocate = function(options) {\n  var complete_callback = options.always || options.complete;\n\n  if (navigator.geolocation) {\n    navigator.geolocation.getCurrentPosition(function(position) {\n      options.success(position);\n\n      if (complete_callback) {\n        complete_callback();\n      }\n    }, function(error) {\n      options.error(error);\n\n      if (complete_callback) {\n        complete_callback();\n      }\n    }, options.options);\n  }\n  else {\n    options.not_supported();\n\n    if (complete_callback) {\n      complete_callback();\n    }\n  }\n};\n\nGMaps.geocode = function(options) {\n  this.geocoder = new google.maps.Geocoder();\n  var callback = options.callback;\n  if (options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) {\n    options.latLng = new google.maps.LatLng(options.lat, options.lng);\n  }\n\n  delete options.lat;\n  delete options.lng;\n  delete options.callback;\n  \n  this.geocoder.geocode(options, function(results, status) {\n    callback(results, status);\n  });\n};\n\n//==========================\n// Polygon containsLatLng\n// https://github.com/tparkin/Google-Maps-Point-in-Polygon\n// Poygon getBounds extension - google-maps-extensions\n// http://code.google.com/p/google-maps-extensions/source/browse/google.maps.Polygon.getBounds.js\nif (!google.maps.Polygon.prototype.getBounds) {\n  google.maps.Polygon.prototype.getBounds = function(latLng) {\n    var bounds = new google.maps.LatLngBounds();\n    var paths = this.getPaths();\n    var path;\n\n    for (var p = 0; p < paths.getLength(); p++) {\n      path = paths.getAt(p);\n      for (var i = 0; i < path.getLength(); i++) {\n        bounds.extend(path.getAt(i));\n      }\n    }\n\n    return bounds;\n  };\n}\n\nif (!google.maps.Polygon.prototype.containsLatLng) {\n  // Polygon containsLatLng - method to determine if a latLng is within a polygon\n  google.maps.Polygon.prototype.containsLatLng = function(latLng) {\n    // Exclude points outside of bounds as there is no way they are in the poly\n    var bounds = this.getBounds();\n\n    if (bounds !== null && !bounds.contains(latLng)) {\n      return false;\n    }\n\n    // Raycast point in polygon method\n    var inPoly = false;\n\n    var numPaths = this.getPaths().getLength();\n    for (var p = 0; p < numPaths; p++) {\n      var path = this.getPaths().getAt(p);\n      var numPoints = path.getLength();\n      var j = numPoints - 1;\n\n      for (var i = 0; i < numPoints; i++) {\n        var vertex1 = path.getAt(i);\n        var vertex2 = path.getAt(j);\n\n        if (vertex1.lng() < latLng.lng() && vertex2.lng() >= latLng.lng() || vertex2.lng() < latLng.lng() && vertex1.lng() >= latLng.lng()) {\n          if (vertex1.lat() + (latLng.lng() - vertex1.lng()) / (vertex2.lng() - vertex1.lng()) * (vertex2.lat() - vertex1.lat()) < latLng.lat()) {\n            inPoly = !inPoly;\n          }\n        }\n\n        j = i;\n      }\n    }\n\n    return inPoly;\n  };\n}\n\nif (!google.maps.Circle.prototype.containsLatLng) {\n  google.maps.Circle.prototype.containsLatLng = function(latLng) {\n    if (google.maps.geometry) {\n      return google.maps.geometry.spherical.computeDistanceBetween(this.getCenter(), latLng) <= this.getRadius();\n    }\n    else {\n      return true;\n    }\n  };\n}\n\ngoogle.maps.LatLngBounds.prototype.containsLatLng = function(latLng) {\n  return this.contains(latLng);\n};\n\ngoogle.maps.Marker.prototype.setFences = function(fences) {\n  this.fences = fences;\n};\n\ngoogle.maps.Marker.prototype.addFence = function(fence) {\n  this.fences.push(fence);\n};\n\ngoogle.maps.Marker.prototype.getId = function() {\n  return this['__gm_id'];\n};\n\n//==========================\n// Array indexOf\n// https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array/indexOf\nif (!Array.prototype.indexOf) {\n  Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {\n      \"use strict\";\n      if (this == null) {\n          throw new TypeError();\n      }\n      var t = Object(this);\n      var len = t.length >>> 0;\n      if (len === 0) {\n          return -1;\n      }\n      var n = 0;\n      if (arguments.length > 1) {\n          n = Number(arguments[1]);\n          if (n != n) { // shortcut for verifying if it's NaN\n              n = 0;\n          } else if (n != 0 && n != Infinity && n != -Infinity) {\n              n = (n > 0 || -1) * Math.floor(Math.abs(n));\n          }\n      }\n      if (n >= len) {\n          return -1;\n      }\n      var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);\n      for (; k < len; k++) {\n          if (k in t && t[k] === searchElement) {\n              return k;\n          }\n      }\n      return -1;\n  }\n}\n  \nreturn GMaps;\n}));\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/jquery.gmaps.js",
    "content": "$(function() {\n    map = new GMaps({\n        el: '#gmaps-simple',\n        lat: 34.05,\n        lng: -78.72,\n        zoom: 5,\n        panControl: false,\n        streetViewControl: false,\n        mapTypeControl: false,\n        overviewMapControl: false\n    });\n});\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.controls.js",
    "content": "GMaps.prototype.createControl = function(options) {\n  var control = document.createElement('div');\n\n  control.style.cursor = 'pointer';\n  \n  if (options.disableDefaultStyles !== true) {\n    control.style.fontFamily = 'Roboto, Arial, sans-serif';\n    control.style.fontSize = '11px';\n    control.style.boxShadow = 'rgba(0, 0, 0, 0.298039) 0px 1px 4px -1px';\n  }\n\n  for (var option in options.style) {\n    control.style[option] = options.style[option];\n  }\n\n  if (options.id) {\n    control.id = options.id;\n  }\n\n  if (options.classes) {\n    control.className = options.classes;\n  }\n\n  if (options.content) {\n    if (typeof options.content === 'string') {\n      control.innerHTML = options.content;\n    }\n    else if (options.content instanceof HTMLElement) {\n      control.appendChild(options.content);\n    }\n  }\n\n  if (options.position) {\n    control.position = google.maps.ControlPosition[options.position.toUpperCase()];\n  }\n\n  for (var ev in options.events) {\n    (function(object, name) {\n      google.maps.event.addDomListener(object, name, function(){\n        options.events[name].apply(this, [this]);\n      });\n    })(control, ev);\n  }\n\n  control.index = 1;\n\n  return control;\n};\n\nGMaps.prototype.addControl = function(options) {\n  var control = this.createControl(options);\n  \n  this.controls.push(control);\n  this.map.controls[control.position].push(control);\n\n  return control;\n};\n\nGMaps.prototype.removeControl = function(control) {\n  var position = null,\n      i;\n\n  for (i = 0; i < this.controls.length; i++) {\n    if (this.controls[i] == control) {\n      position = this.controls[i].position;\n      this.controls.splice(i, 1);\n    }\n  }\n\n  if (position) {\n    for (i = 0; i < this.map.controls.length; i++) {\n      var controlsForPosition = this.map.controls[control.position];\n\n      if (controlsForPosition.getAt(i) == control) {\n        controlsForPosition.removeAt(i);\n\n        break;\n      }\n    }\n  }\n\n  return control;\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.core.js",
    "content": "if (!(typeof window.google === 'object' && window.google.maps)) {\n  throw 'Google Maps API is required. Please register the following JavaScript library http://maps.google.com/maps/api/js?sensor=true.'\n}\n\nvar extend_object = function(obj, new_obj) {\n  var name;\n\n  if (obj === new_obj) {\n    return obj;\n  }\n\n  for (name in new_obj) {\n    obj[name] = new_obj[name];\n  }\n\n  return obj;\n};\n\nvar replace_object = function(obj, replace) {\n  var name;\n\n  if (obj === replace) {\n    return obj;\n  }\n\n  for (name in replace) {\n    if (obj[name] != undefined) {\n      obj[name] = replace[name];\n    }\n  }\n\n  return obj;\n};\n\nvar array_map = function(array, callback) {\n  var original_callback_params = Array.prototype.slice.call(arguments, 2),\n      array_return = [],\n      array_length = array.length,\n      i;\n\n  if (Array.prototype.map && array.map === Array.prototype.map) {\n    array_return = Array.prototype.map.call(array, function(item) {\n      var callback_params = original_callback_params.slice(0);\n      callback_params.splice(0, 0, item);\n\n      return callback.apply(this, callback_params);\n    });\n  }\n  else {\n    for (i = 0; i < array_length; i++) {\n      callback_params = original_callback_params;\n      callback_params.splice(0, 0, array[i]);\n      array_return.push(callback.apply(this, callback_params));\n    }\n  }\n\n  return array_return;\n};\n\nvar array_flat = function(array) {\n  var new_array = [],\n      i;\n\n  for (i = 0; i < array.length; i++) {\n    new_array = new_array.concat(array[i]);\n  }\n\n  return new_array;\n};\n\nvar coordsToLatLngs = function(coords, useGeoJSON) {\n  var first_coord = coords[0],\n      second_coord = coords[1];\n\n  if (useGeoJSON) {\n    first_coord = coords[1];\n    second_coord = coords[0];\n  }\n\n  return new google.maps.LatLng(first_coord, second_coord);\n};\n\nvar arrayToLatLng = function(coords, useGeoJSON) {\n  var i;\n\n  for (i = 0; i < coords.length; i++) {\n    if (!(coords[i] instanceof google.maps.LatLng)) {\n      if (coords[i].length > 0 && typeof(coords[i][0]) === \"object\") {\n        coords[i] = arrayToLatLng(coords[i], useGeoJSON);\n      }\n      else {\n        coords[i] = coordsToLatLngs(coords[i], useGeoJSON);\n      }\n    }\n  }\n\n  return coords;\n};\n\n\nvar getElementsByClassName = function (class_name, context) {\n\n    var element,\n        _class = class_name.replace('.', '');\n\n    if ('jQuery' in this && context) {\n        element = $(\".\" + _class, context)[0];\n    } else {\n        element = document.getElementsByClassName(_class)[0];\n    }\n    return element;\n\n};\n\nvar getElementById = function(id, context) {\n  var element,\n  id = id.replace('#', '');\n\n  if ('jQuery' in window && context) {\n    element = $('#' + id, context)[0];\n  } else {\n    element = document.getElementById(id);\n  };\n\n  return element;\n};\n\nvar findAbsolutePosition = function(obj)  {\n  var curleft = 0,\n      curtop = 0;\n\n  if (obj.offsetParent) {\n    do {\n      curleft += obj.offsetLeft;\n      curtop += obj.offsetTop;\n    } while (obj = obj.offsetParent);\n  }\n\n  return [curleft, curtop];\n};\n\nvar GMaps = (function(global) {\n  \"use strict\";\n\n  var doc = document;\n\n  var GMaps = function(options) {\n    if (!this) return new GMaps(options);\n\n    options.zoom = options.zoom || 15;\n    options.mapType = options.mapType || 'roadmap';\n\n    var self = this,\n        i,\n        events_that_hide_context_menu = [\n          'bounds_changed', 'center_changed', 'click', 'dblclick', 'drag',\n          'dragend', 'dragstart', 'idle', 'maptypeid_changed', 'projection_changed',\n          'resize', 'tilesloaded', 'zoom_changed'\n        ],\n        events_that_doesnt_hide_context_menu = ['mousemove', 'mouseout', 'mouseover'],\n        options_to_be_deleted = ['el', 'lat', 'lng', 'mapType', 'width', 'height', 'markerClusterer', 'enableNewStyle'],\n        identifier = options.el || options.div,\n        markerClustererFunction = options.markerClusterer,\n        mapType = google.maps.MapTypeId[options.mapType.toUpperCase()],\n        map_center = new google.maps.LatLng(options.lat, options.lng),\n        zoomControl = options.zoomControl || true,\n        zoomControlOpt = options.zoomControlOpt || {\n          style: 'DEFAULT',\n          position: 'TOP_LEFT'\n        },\n        zoomControlStyle = zoomControlOpt.style || 'DEFAULT',\n        zoomControlPosition = zoomControlOpt.position || 'TOP_LEFT',\n        panControl = options.panControl || true,\n        mapTypeControl = options.mapTypeControl || true,\n        scaleControl = options.scaleControl || true,\n        streetViewControl = options.streetViewControl || true,\n        overviewMapControl = overviewMapControl || true,\n        map_options = {},\n        map_base_options = {\n          zoom: this.zoom,\n          center: map_center,\n          mapTypeId: mapType\n        },\n        map_controls_options = {\n          panControl: panControl,\n          zoomControl: zoomControl,\n          zoomControlOptions: {\n            style: google.maps.ZoomControlStyle[zoomControlStyle],\n            position: google.maps.ControlPosition[zoomControlPosition]\n          },\n          mapTypeControl: mapTypeControl,\n          scaleControl: scaleControl,\n          streetViewControl: streetViewControl,\n          overviewMapControl: overviewMapControl\n        };\n\n      if (typeof(options.el) === 'string' || typeof(options.div) === 'string') {\n\n          if (identifier.indexOf(\"#\") > -1) {\n              this.el = getElementById(identifier, options.context);\n          } else {\n              this.el = getElementsByClassName.apply(this, [identifier, options.context]);\n          }\n\n      } else {\n          this.el = identifier;\n      }\n\n    if (typeof(this.el) === 'undefined' || this.el === null) {\n      throw 'No element defined.';\n    }\n\n    window.context_menu = window.context_menu || {};\n    window.context_menu[self.el.id] = {};\n\n    this.controls = [];\n    this.overlays = [];\n    this.layers = []; // array with kml/georss and fusiontables layers, can be as many\n    this.singleLayers = {}; // object with the other layers, only one per layer\n    this.markers = [];\n    this.polylines = [];\n    this.routes = [];\n    this.polygons = [];\n    this.infoWindow = null;\n    this.overlay_el = null;\n    this.zoom = options.zoom;\n    this.registered_events = {};\n\n    this.el.style.width = options.width || this.el.scrollWidth || this.el.offsetWidth;\n    this.el.style.height = options.height || this.el.scrollHeight || this.el.offsetHeight;\n\n    google.maps.visualRefresh = options.enableNewStyle;\n\n    for (i = 0; i < options_to_be_deleted.length; i++) {\n      delete options[options_to_be_deleted[i]];\n    }\n\n    if(options.disableDefaultUI != true) {\n      map_base_options = extend_object(map_base_options, map_controls_options);\n    }\n\n    map_options = extend_object(map_base_options, options);\n\n    for (i = 0; i < events_that_hide_context_menu.length; i++) {\n      delete map_options[events_that_hide_context_menu[i]];\n    }\n\n    for (i = 0; i < events_that_doesnt_hide_context_menu.length; i++) {\n      delete map_options[events_that_doesnt_hide_context_menu[i]];\n    }\n\n    this.map = new google.maps.Map(this.el, map_options);\n\n    if (markerClustererFunction) {\n      this.markerClusterer = markerClustererFunction.apply(this, [this.map]);\n    }\n\n    var buildContextMenuHTML = function(control, e) {\n      var html = '',\n          options = window.context_menu[self.el.id][control];\n\n      for (var i in options){\n        if (options.hasOwnProperty(i)) {\n          var option = options[i];\n\n          html += '<li><a id=\"' + control + '_' + i + '\" href=\"#\">' + option.title + '</a></li>';\n        }\n      }\n\n      if (!getElementById('gmaps_context_menu')) return;\n\n      var context_menu_element = getElementById('gmaps_context_menu');\n      \n      context_menu_element.innerHTML = html;\n\n      var context_menu_items = context_menu_element.getElementsByTagName('a'),\n          context_menu_items_count = context_menu_items.length,\n          i;\n\n      for (i = 0; i < context_menu_items_count; i++) {\n        var context_menu_item = context_menu_items[i];\n\n        var assign_menu_item_action = function(ev){\n          ev.preventDefault();\n\n          options[this.id.replace(control + '_', '')].action.apply(self, [e]);\n          self.hideContextMenu();\n        };\n\n        google.maps.event.clearListeners(context_menu_item, 'click');\n        google.maps.event.addDomListenerOnce(context_menu_item, 'click', assign_menu_item_action, false);\n      }\n\n      var position = findAbsolutePosition.apply(this, [self.el]),\n          left = position[0] + e.pixel.x - 15,\n          top = position[1] + e.pixel.y- 15;\n\n      context_menu_element.style.left = left + \"px\";\n      context_menu_element.style.top = top + \"px\";\n\n      context_menu_element.style.display = 'block';\n    };\n\n    this.buildContextMenu = function(control, e) {\n      if (control === 'marker') {\n        e.pixel = {};\n\n        var overlay = new google.maps.OverlayView();\n        overlay.setMap(self.map);\n        \n        overlay.draw = function() {\n          var projection = overlay.getProjection(),\n              position = e.marker.getPosition();\n          \n          e.pixel = projection.fromLatLngToContainerPixel(position);\n\n          buildContextMenuHTML(control, e);\n        };\n      }\n      else {\n        buildContextMenuHTML(control, e);\n      }\n    };\n\n    this.setContextMenu = function(options) {\n      window.context_menu[self.el.id][options.control] = {};\n\n      var i,\n          ul = doc.createElement('ul');\n\n      for (i in options.options) {\n        if (options.options.hasOwnProperty(i)) {\n          var option = options.options[i];\n\n          window.context_menu[self.el.id][options.control][option.name] = {\n            title: option.title,\n            action: option.action\n          };\n        }\n      }\n\n      ul.id = 'gmaps_context_menu';\n      ul.style.display = 'none';\n      ul.style.position = 'absolute';\n      ul.style.minWidth = '100px';\n      ul.style.background = 'white';\n      ul.style.listStyle = 'none';\n      ul.style.padding = '8px';\n      ul.style.boxShadow = '2px 2px 6px #ccc';\n\n      doc.body.appendChild(ul);\n\n      var context_menu_element = getElementById('gmaps_context_menu')\n\n      google.maps.event.addDomListener(context_menu_element, 'mouseout', function(ev) {\n        if (!ev.relatedTarget || !this.contains(ev.relatedTarget)) {\n          window.setTimeout(function(){\n            context_menu_element.style.display = 'none';\n          }, 400);\n        }\n      }, false);\n    };\n\n    this.hideContextMenu = function() {\n      var context_menu_element = getElementById('gmaps_context_menu');\n\n      if (context_menu_element) {\n        context_menu_element.style.display = 'none';\n      }\n    };\n\n    var setupListener = function(object, name) {\n      google.maps.event.addListener(object, name, function(e){\n        if (e == undefined) {\n          e = this;\n        }\n\n        options[name].apply(this, [e]);\n\n        self.hideContextMenu();\n      });\n    };\n\n    //google.maps.event.addListener(this.map, 'idle', this.hideContextMenu);\n    google.maps.event.addListener(this.map, 'zoom_changed', this.hideContextMenu);\n\n    for (var ev = 0; ev < events_that_hide_context_menu.length; ev++) {\n      var name = events_that_hide_context_menu[ev];\n\n      if (name in options) {\n        setupListener(this.map, name);\n      }\n    }\n\n    for (var ev = 0; ev < events_that_doesnt_hide_context_menu.length; ev++) {\n      var name = events_that_doesnt_hide_context_menu[ev];\n\n      if (name in options) {\n        setupListener(this.map, name);\n      }\n    }\n\n    google.maps.event.addListener(this.map, 'rightclick', function(e) {\n      if (options.rightclick) {\n        options.rightclick.apply(this, [e]);\n      }\n\n      if(window.context_menu[self.el.id]['map'] != undefined) {\n        self.buildContextMenu('map', e);\n      }\n    });\n\n    this.refresh = function() {\n      google.maps.event.trigger(this.map, 'resize');\n    };\n\n    this.fitZoom = function() {\n      var latLngs = [],\n          markers_length = this.markers.length,\n          i;\n\n      for (i = 0; i < markers_length; i++) {\n        if(typeof(this.markers[i].visible) === 'boolean' && this.markers[i].visible) {\n          latLngs.push(this.markers[i].getPosition());\n        }\n      }\n\n      this.fitLatLngBounds(latLngs);\n    };\n\n    this.fitLatLngBounds = function(latLngs) {\n      var total = latLngs.length,\n          bounds = new google.maps.LatLngBounds(),\n          i;\n\n      for(i = 0; i < total; i++) {\n        bounds.extend(latLngs[i]);\n      }\n\n      this.map.fitBounds(bounds);\n    };\n\n    this.setCenter = function(lat, lng, callback) {\n      this.map.panTo(new google.maps.LatLng(lat, lng));\n\n      if (callback) {\n        callback();\n      }\n    };\n\n    this.getElement = function() {\n      return this.el;\n    };\n\n    this.zoomIn = function(value) {\n      value = value || 1;\n\n      this.zoom = this.map.getZoom() + value;\n      this.map.setZoom(this.zoom);\n    };\n\n    this.zoomOut = function(value) {\n      value = value || 1;\n\n      this.zoom = this.map.getZoom() - value;\n      this.map.setZoom(this.zoom);\n    };\n\n    var native_methods = [],\n        method;\n\n    for (method in this.map) {\n      if (typeof(this.map[method]) == 'function' && !this[method]) {\n        native_methods.push(method);\n      }\n    }\n\n    for (i = 0; i < native_methods.length; i++) {\n      (function(gmaps, scope, method_name) {\n        gmaps[method_name] = function(){\n          return scope[method_name].apply(scope, arguments);\n        };\n      })(this, this.map, native_methods[i]);\n    }\n  };\n\n  return GMaps;\n})(this);\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.events.js",
    "content": "GMaps.prototype.on = function(event_name, handler) {\n  return GMaps.on(event_name, this, handler);\n};\n\nGMaps.prototype.off = function(event_name) {\n  GMaps.off(event_name, this);\n};\n\nGMaps.custom_events = ['marker_added', 'marker_removed', 'polyline_added', 'polyline_removed', 'polygon_added', 'polygon_removed', 'geolocated', 'geolocation_failed'];\n\nGMaps.on = function(event_name, object, handler) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    if(object instanceof GMaps) object = object.map; \n    return google.maps.event.addListener(object, event_name, handler);\n  }\n  else {\n    var registered_event = {\n      handler : handler,\n      eventName : event_name\n    };\n\n    object.registered_events[event_name] = object.registered_events[event_name] || [];\n    object.registered_events[event_name].push(registered_event);\n\n    return registered_event;\n  }\n};\n\nGMaps.off = function(event_name, object) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    if(object instanceof GMaps) object = object.map; \n    google.maps.event.clearListeners(object, event_name);\n  }\n  else {\n    object.registered_events[event_name] = [];\n  }\n};\n\nGMaps.fire = function(event_name, object, scope) {\n  if (GMaps.custom_events.indexOf(event_name) == -1) {\n    google.maps.event.trigger(object, event_name, Array.prototype.slice.apply(arguments).slice(2));\n  }\n  else {\n    if(event_name in scope.registered_events) {\n      var firing_events = scope.registered_events[event_name];\n\n      for(var i = 0; i < firing_events.length; i++) {\n        (function(handler, scope, object) {\n          handler.apply(scope, [object]);\n        })(firing_events[i]['handler'], scope, object);\n      }\n    }\n  }\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.geofences.js",
    "content": "GMaps.prototype.checkGeofence = function(lat, lng, fence) {\n  return fence.containsLatLng(new google.maps.LatLng(lat, lng));\n};\n\nGMaps.prototype.checkMarkerGeofence = function(marker, outside_callback) {\n  if (marker.fences) {\n    for (var i = 0, fence; fence = marker.fences[i]; i++) {\n      var pos = marker.getPosition();\n      if (!this.checkGeofence(pos.lat(), pos.lng(), fence)) {\n        outside_callback(marker, fence);\n      }\n    }\n  }\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.geometry.js",
    "content": "GMaps.prototype.drawPolyline = function(options) {\n  var path = [],\n      points = options.path;\n\n  if (points.length) {\n    if (points[0][0] === undefined) {\n      path = points;\n    }\n    else {\n      for (var i = 0, latlng; latlng = points[i]; i++) {\n        path.push(new google.maps.LatLng(latlng[0], latlng[1]));\n      }\n    }\n  }\n\n  var polyline_options = {\n    map: this.map,\n    path: path,\n    strokeColor: options.strokeColor,\n    strokeOpacity: options.strokeOpacity,\n    strokeWeight: options.strokeWeight,\n    geodesic: options.geodesic,\n    clickable: true,\n    editable: false,\n    visible: true\n  };\n\n  if (options.hasOwnProperty(\"clickable\")) {\n    polyline_options.clickable = options.clickable;\n  }\n\n  if (options.hasOwnProperty(\"editable\")) {\n    polyline_options.editable = options.editable;\n  }\n\n  if (options.hasOwnProperty(\"icons\")) {\n    polyline_options.icons = options.icons;\n  }\n\n  if (options.hasOwnProperty(\"zIndex\")) {\n    polyline_options.zIndex = options.zIndex;\n  }\n\n  var polyline = new google.maps.Polyline(polyline_options);\n\n  var polyline_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polyline_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polyline, polyline_events[ev]);\n  }\n\n  this.polylines.push(polyline);\n\n  GMaps.fire('polyline_added', polyline, this);\n\n  return polyline;\n};\n\nGMaps.prototype.removePolyline = function(polyline) {\n  for (var i = 0; i < this.polylines.length; i++) {\n    if (this.polylines[i] === polyline) {\n      this.polylines[i].setMap(null);\n      this.polylines.splice(i, 1);\n\n      GMaps.fire('polyline_removed', polyline, this);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removePolylines = function() {\n  for (var i = 0, item; item = this.polylines[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.polylines = [];\n};\n\nGMaps.prototype.drawCircle = function(options) {\n  options =  extend_object({\n    map: this.map,\n    center: new google.maps.LatLng(options.lat, options.lng)\n  }, options);\n\n  delete options.lat;\n  delete options.lng;\n\n  var polygon = new google.maps.Circle(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  return polygon;\n};\n\nGMaps.prototype.drawRectangle = function(options) {\n  options = extend_object({\n    map: this.map\n  }, options);\n\n  var latLngBounds = new google.maps.LatLngBounds(\n    new google.maps.LatLng(options.bounds[0][0], options.bounds[0][1]),\n    new google.maps.LatLng(options.bounds[1][0], options.bounds[1][1])\n  );\n\n  options.bounds = latLngBounds;\n\n  var polygon = new google.maps.Rectangle(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  return polygon;\n};\n\nGMaps.prototype.drawPolygon = function(options) {\n  var useGeoJSON = false;\n\n  if(options.hasOwnProperty(\"useGeoJSON\")) {\n    useGeoJSON = options.useGeoJSON;\n  }\n\n  delete options.useGeoJSON;\n\n  options = extend_object({\n    map: this.map\n  }, options);\n\n  if (useGeoJSON == false) {\n    options.paths = [options.paths.slice(0)];\n  }\n\n  if (options.paths.length > 0) {\n    if (options.paths[0].length > 0) {\n      options.paths = array_flat(array_map(options.paths, arrayToLatLng, useGeoJSON));\n    }\n  }\n\n  var polygon = new google.maps.Polygon(options),\n      polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];\n\n  for (var ev = 0; ev < polygon_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(e){\n          options[name].apply(this, [e]);\n        });\n      }\n    })(polygon, polygon_events[ev]);\n  }\n\n  this.polygons.push(polygon);\n\n  GMaps.fire('polygon_added', polygon, this);\n\n  return polygon;\n};\n\nGMaps.prototype.removePolygon = function(polygon) {\n  for (var i = 0; i < this.polygons.length; i++) {\n    if (this.polygons[i] === polygon) {\n      this.polygons[i].setMap(null);\n      this.polygons.splice(i, 1);\n\n      GMaps.fire('polygon_removed', polygon, this);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removePolygons = function() {\n  for (var i = 0, item; item = this.polygons[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.polygons = [];\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.layers.js",
    "content": "GMaps.prototype.getFromFusionTables = function(options) {\n  var events = options.events;\n\n  delete options.events;\n\n  var fusion_tables_options = options,\n      layer = new google.maps.FusionTablesLayer(fusion_tables_options);\n\n  for (var ev in events) {\n    (function(object, name) {\n      google.maps.event.addListener(object, name, function(e) {\n        events[name].apply(this, [e]);\n      });\n    })(layer, ev);\n  }\n\n  this.layers.push(layer);\n\n  return layer;\n};\n\nGMaps.prototype.loadFromFusionTables = function(options) {\n  var layer = this.getFromFusionTables(options);\n  layer.setMap(this.map);\n\n  return layer;\n};\n\nGMaps.prototype.getFromKML = function(options) {\n  var url = options.url,\n      events = options.events;\n\n  delete options.url;\n  delete options.events;\n\n  var kml_options = options,\n      layer = new google.maps.KmlLayer(url, kml_options);\n\n  for (var ev in events) {\n    (function(object, name) {\n      google.maps.event.addListener(object, name, function(e) {\n        events[name].apply(this, [e]);\n      });\n    })(layer, ev);\n  }\n\n  this.layers.push(layer);\n\n  return layer;\n};\n\nGMaps.prototype.loadFromKML = function(options) {\n  var layer = this.getFromKML(options);\n  layer.setMap(this.map);\n\n  return layer;\n};\n\nGMaps.prototype.addLayer = function(layerName, options) {\n  //var default_layers = ['weather', 'clouds', 'traffic', 'transit', 'bicycling', 'panoramio', 'places'];\n  options = options || {};\n  var layer;\n\n  switch(layerName) {\n    case 'weather': this.singleLayers.weather = layer = new google.maps.weather.WeatherLayer();\n      break;\n    case 'clouds': this.singleLayers.clouds = layer = new google.maps.weather.CloudLayer();\n      break;\n    case 'traffic': this.singleLayers.traffic = layer = new google.maps.TrafficLayer();\n      break;\n    case 'transit': this.singleLayers.transit = layer = new google.maps.TransitLayer();\n      break;\n    case 'bicycling': this.singleLayers.bicycling = layer = new google.maps.BicyclingLayer();\n      break;\n    case 'panoramio':\n        this.singleLayers.panoramio = layer = new google.maps.panoramio.PanoramioLayer();\n        layer.setTag(options.filter);\n        delete options.filter;\n\n        //click event\n        if (options.click) {\n          google.maps.event.addListener(layer, 'click', function(event) {\n            options.click(event);\n            delete options.click;\n          });\n        }\n      break;\n      case 'places':\n        this.singleLayers.places = layer = new google.maps.places.PlacesService(this.map);\n\n        //search, nearbySearch, radarSearch callback, Both are the same\n        if (options.search || options.nearbySearch || options.radarSearch) {\n          var placeSearchRequest  = {\n            bounds : options.bounds || null,\n            keyword : options.keyword || null,\n            location : options.location || null,\n            name : options.name || null,\n            radius : options.radius || null,\n            rankBy : options.rankBy || null,\n            types : options.types || null\n          };\n\n          if (options.radarSearch) {\n            layer.radarSearch(placeSearchRequest, options.radarSearch);\n          }\n\n          if (options.search) {\n            layer.search(placeSearchRequest, options.search);\n          }\n\n          if (options.nearbySearch) {\n            layer.nearbySearch(placeSearchRequest, options.nearbySearch);\n          }\n        }\n\n        //textSearch callback\n        if (options.textSearch) {\n          var textSearchRequest  = {\n            bounds : options.bounds || null,\n            location : options.location || null,\n            query : options.query || null,\n            radius : options.radius || null\n          };\n\n          layer.textSearch(textSearchRequest, options.textSearch);\n        }\n      break;\n  }\n\n  if (layer !== undefined) {\n    if (typeof layer.setOptions == 'function') {\n      layer.setOptions(options);\n    }\n    if (typeof layer.setMap == 'function') {\n      layer.setMap(this.map);\n    }\n\n    return layer;\n  }\n};\n\nGMaps.prototype.removeLayer = function(layer) {\n  if (typeof(layer) == \"string\" && this.singleLayers[layer] !== undefined) {\n     this.singleLayers[layer].setMap(null);\n\n     delete this.singleLayers[layer];\n  }\n  else {\n    for (var i = 0; i < this.layers.length; i++) {\n      if (this.layers[i] === layer) {\n        this.layers[i].setMap(null);\n        this.layers.splice(i, 1);\n\n        break;\n      }\n    }\n  }\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.map_types.js",
    "content": "GMaps.prototype.addMapType = function(mapTypeId, options) {\n  if (options.hasOwnProperty(\"getTileUrl\") && typeof(options[\"getTileUrl\"]) == \"function\") {\n    options.tileSize = options.tileSize || new google.maps.Size(256, 256);\n\n    var mapType = new google.maps.ImageMapType(options);\n\n    this.map.mapTypes.set(mapTypeId, mapType);\n  }\n  else {\n    throw \"'getTileUrl' function required.\";\n  }\n};\n\nGMaps.prototype.addOverlayMapType = function(options) {\n  if (options.hasOwnProperty(\"getTile\") && typeof(options[\"getTile\"]) == \"function\") {\n    var overlayMapTypeIndex = options.index;\n\n    delete options.index;\n\n    this.map.overlayMapTypes.insertAt(overlayMapTypeIndex, options);\n  }\n  else {\n    throw \"'getTile' function required.\";\n  }\n};\n\nGMaps.prototype.removeOverlayMapType = function(overlayMapTypeIndex) {\n  this.map.overlayMapTypes.removeAt(overlayMapTypeIndex);\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.markers.js",
    "content": "GMaps.prototype.createMarker = function(options) {\n  if (options.lat == undefined && options.lng == undefined && options.position == undefined) {\n    throw 'No latitude or longitude defined.';\n  }\n\n  var self = this,\n      details = options.details,\n      fences = options.fences,\n      outside = options.outside,\n      base_options = {\n        position: new google.maps.LatLng(options.lat, options.lng),\n        map: null\n      },\n      marker_options = extend_object(base_options, options);\n\n  delete marker_options.lat;\n  delete marker_options.lng;\n  delete marker_options.fences;\n  delete marker_options.outside;\n\n  var marker = new google.maps.Marker(marker_options);\n\n  marker.fences = fences;\n\n  if (options.infoWindow) {\n    marker.infoWindow = new google.maps.InfoWindow(options.infoWindow);\n\n    var info_window_events = ['closeclick', 'content_changed', 'domready', 'position_changed', 'zindex_changed'];\n\n    for (var ev = 0; ev < info_window_events.length; ev++) {\n      (function(object, name) {\n        if (options.infoWindow[name]) {\n          google.maps.event.addListener(object, name, function(e){\n            options.infoWindow[name].apply(this, [e]);\n          });\n        }\n      })(marker.infoWindow, info_window_events[ev]);\n    }\n  }\n\n  var marker_events = ['animation_changed', 'clickable_changed', 'cursor_changed', 'draggable_changed', 'flat_changed', 'icon_changed', 'position_changed', 'shadow_changed', 'shape_changed', 'title_changed', 'visible_changed', 'zindex_changed'];\n\n  var marker_events_with_mouse = ['dblclick', 'drag', 'dragend', 'dragstart', 'mousedown', 'mouseout', 'mouseover', 'mouseup'];\n\n  for (var ev = 0; ev < marker_events.length; ev++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(){\n          options[name].apply(this, [this]);\n        });\n      }\n    })(marker, marker_events[ev]);\n  }\n\n  for (var ev = 0; ev < marker_events_with_mouse.length; ev++) {\n    (function(map, object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(me){\n          if(!me.pixel){\n            me.pixel = map.getProjection().fromLatLngToPoint(me.latLng)\n          }\n          \n          options[name].apply(this, [me]);\n        });\n      }\n    })(this.map, marker, marker_events_with_mouse[ev]);\n  }\n\n  google.maps.event.addListener(marker, 'click', function() {\n    this.details = details;\n\n    if (options.click) {\n      options.click.apply(this, [this]);\n    }\n\n    if (marker.infoWindow) {\n      self.hideInfoWindows();\n      marker.infoWindow.open(self.map, marker);\n    }\n  });\n\n  google.maps.event.addListener(marker, 'rightclick', function(e) {\n    e.marker = this;\n\n    if (options.rightclick) {\n      options.rightclick.apply(this, [e]);\n    }\n\n    if (window.context_menu[self.el.id]['marker'] != undefined) {\n      self.buildContextMenu('marker', e);\n    }\n  });\n\n  if (marker.fences) {\n    google.maps.event.addListener(marker, 'dragend', function() {\n      self.checkMarkerGeofence(marker, function(m, f) {\n        outside(m, f);\n      });\n    });\n  }\n\n  return marker;\n};\n\nGMaps.prototype.addMarker = function(options) {\n  var marker;\n  if(options.hasOwnProperty('gm_accessors_')) {\n    // Native google.maps.Marker object\n    marker = options;\n  }\n  else {\n    if ((options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) || options.position) {\n      marker = this.createMarker(options);\n    }\n    else {\n      throw 'No latitude or longitude defined.';\n    }\n  }\n\n  marker.setMap(this.map);\n\n  if(this.markerClusterer) {\n    this.markerClusterer.addMarker(marker);\n  }\n\n  this.markers.push(marker);\n\n  GMaps.fire('marker_added', marker, this);\n\n  return marker;\n};\n\nGMaps.prototype.addMarkers = function(array) {\n  for (var i = 0, marker; marker=array[i]; i++) {\n    this.addMarker(marker);\n  }\n\n  return this.markers;\n};\n\nGMaps.prototype.hideInfoWindows = function() {\n  for (var i = 0, marker; marker = this.markers[i]; i++){\n    if (marker.infoWindow) {\n      marker.infoWindow.close();\n    }\n  }\n};\n\nGMaps.prototype.removeMarker = function(marker) {\n  for (var i = 0; i < this.markers.length; i++) {\n    if (this.markers[i] === marker) {\n      this.markers[i].setMap(null);\n      this.markers.splice(i, 1);\n\n      if(this.markerClusterer) {\n        this.markerClusterer.removeMarker(marker);\n      }\n\n      GMaps.fire('marker_removed', marker, this);\n\n      break;\n    }\n  }\n\n  return marker;\n};\n\nGMaps.prototype.removeMarkers = function (collection) {\n  var new_markers = [];\n\n  if (typeof collection == 'undefined') {\n    for (var i = 0; i < this.markers.length; i++) {\n      var marker = this.markers[i];\n      marker.setMap(null);\n\n      if(this.markerClusterer) {\n        this.markerClusterer.removeMarker(marker);\n      }\n\n      GMaps.fire('marker_removed', marker, this);\n    }\n    \n    this.markers = new_markers;\n  }\n  else {\n    for (var i = 0; i < collection.length; i++) {\n      var index = this.markers.indexOf(collection[i]);\n\n      if (index > -1) {\n        var marker = this.markers[index];\n        marker.setMap(null);\n\n        if(this.markerClusterer) {\n          this.markerClusterer.removeMarker(marker);\n        }\n\n        GMaps.fire('marker_removed', marker, this);\n      }\n    }\n\n    for (var i = 0; i < this.markers.length; i++) {\n      var marker = this.markers[i];\n      if (marker.getMap() != null) {\n        new_markers.push(marker);\n      }\n    }\n\n    this.markers = new_markers;\n  }\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.native_extensions.js",
    "content": "//==========================\n// Polygon containsLatLng\n// https://github.com/tparkin/Google-Maps-Point-in-Polygon\n// Poygon getBounds extension - google-maps-extensions\n// http://code.google.com/p/google-maps-extensions/source/browse/google.maps.Polygon.getBounds.js\nif (!google.maps.Polygon.prototype.getBounds) {\n  google.maps.Polygon.prototype.getBounds = function(latLng) {\n    var bounds = new google.maps.LatLngBounds();\n    var paths = this.getPaths();\n    var path;\n\n    for (var p = 0; p < paths.getLength(); p++) {\n      path = paths.getAt(p);\n      for (var i = 0; i < path.getLength(); i++) {\n        bounds.extend(path.getAt(i));\n      }\n    }\n\n    return bounds;\n  };\n}\n\nif (!google.maps.Polygon.prototype.containsLatLng) {\n  // Polygon containsLatLng - method to determine if a latLng is within a polygon\n  google.maps.Polygon.prototype.containsLatLng = function(latLng) {\n    // Exclude points outside of bounds as there is no way they are in the poly\n    var bounds = this.getBounds();\n\n    if (bounds !== null && !bounds.contains(latLng)) {\n      return false;\n    }\n\n    // Raycast point in polygon method\n    var inPoly = false;\n\n    var numPaths = this.getPaths().getLength();\n    for (var p = 0; p < numPaths; p++) {\n      var path = this.getPaths().getAt(p);\n      var numPoints = path.getLength();\n      var j = numPoints - 1;\n\n      for (var i = 0; i < numPoints; i++) {\n        var vertex1 = path.getAt(i);\n        var vertex2 = path.getAt(j);\n\n        if (vertex1.lng() < latLng.lng() && vertex2.lng() >= latLng.lng() || vertex2.lng() < latLng.lng() && vertex1.lng() >= latLng.lng()) {\n          if (vertex1.lat() + (latLng.lng() - vertex1.lng()) / (vertex2.lng() - vertex1.lng()) * (vertex2.lat() - vertex1.lat()) < latLng.lat()) {\n            inPoly = !inPoly;\n          }\n        }\n\n        j = i;\n      }\n    }\n\n    return inPoly;\n  };\n}\n\nif (!google.maps.Circle.prototype.containsLatLng) {\n  google.maps.Circle.prototype.containsLatLng = function(latLng) {\n    if (google.maps.geometry) {\n      return google.maps.geometry.spherical.computeDistanceBetween(this.getCenter(), latLng) <= this.getRadius();\n    }\n    else {\n      return true;\n    }\n  };\n}\n\ngoogle.maps.LatLngBounds.prototype.containsLatLng = function(latLng) {\n  return this.contains(latLng);\n};\n\ngoogle.maps.Marker.prototype.setFences = function(fences) {\n  this.fences = fences;\n};\n\ngoogle.maps.Marker.prototype.addFence = function(fence) {\n  this.fences.push(fence);\n};\n\ngoogle.maps.Marker.prototype.getId = function() {\n  return this['__gm_id'];\n};\n\n//==========================\n// Array indexOf\n// https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array/indexOf\nif (!Array.prototype.indexOf) {\n  Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {\n      \"use strict\";\n      if (this == null) {\n          throw new TypeError();\n      }\n      var t = Object(this);\n      var len = t.length >>> 0;\n      if (len === 0) {\n          return -1;\n      }\n      var n = 0;\n      if (arguments.length > 1) {\n          n = Number(arguments[1]);\n          if (n != n) { // shortcut for verifying if it's NaN\n              n = 0;\n          } else if (n != 0 && n != Infinity && n != -Infinity) {\n              n = (n > 0 || -1) * Math.floor(Math.abs(n));\n          }\n      }\n      if (n >= len) {\n          return -1;\n      }\n      var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);\n      for (; k < len; k++) {\n          if (k in t && t[k] === searchElement) {\n              return k;\n          }\n      }\n      return -1;\n  }\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.overlays.js",
    "content": "GMaps.prototype.drawOverlay = function(options) {\n  var overlay = new google.maps.OverlayView(),\n      auto_show = true;\n\n  overlay.setMap(this.map);\n\n  if (options.auto_show != null) {\n    auto_show = options.auto_show;\n  }\n\n  overlay.onAdd = function() {\n    var el = document.createElement('div');\n\n    el.style.borderStyle = \"none\";\n    el.style.borderWidth = \"0px\";\n    el.style.position = \"absolute\";\n    el.style.zIndex = 100;\n    el.innerHTML = options.content;\n\n    overlay.el = el;\n\n    if (!options.layer) {\n      options.layer = 'overlayLayer';\n    }\n    \n    var panes = this.getPanes(),\n        overlayLayer = panes[options.layer],\n        stop_overlay_events = ['contextmenu', 'DOMMouseScroll', 'dblclick', 'mousedown'];\n\n    overlayLayer.appendChild(el);\n\n    for (var ev = 0; ev < stop_overlay_events.length; ev++) {\n      (function(object, name) {\n        google.maps.event.addDomListener(object, name, function(e){\n          if (navigator.userAgent.toLowerCase().indexOf('msie') != -1 && document.all) {\n            e.cancelBubble = true;\n            e.returnValue = false;\n          }\n          else {\n            e.stopPropagation();\n          }\n        });\n      })(el, stop_overlay_events[ev]);\n    }\n\n    if (options.click) {\n      panes.overlayMouseTarget.appendChild(overlay.el);\n      google.maps.event.addDomListener(overlay.el, 'click', function() {\n        options.click.apply(overlay, [overlay]);\n      });\n    }\n\n    google.maps.event.trigger(this, 'ready');\n  };\n\n  overlay.draw = function() {\n    var projection = this.getProjection(),\n        pixel = projection.fromLatLngToDivPixel(new google.maps.LatLng(options.lat, options.lng));\n\n    options.horizontalOffset = options.horizontalOffset || 0;\n    options.verticalOffset = options.verticalOffset || 0;\n\n    var el = overlay.el,\n        content = el.children[0],\n        content_height = content.clientHeight,\n        content_width = content.clientWidth;\n\n    switch (options.verticalAlign) {\n      case 'top':\n        el.style.top = (pixel.y - content_height + options.verticalOffset) + 'px';\n        break;\n      default:\n      case 'middle':\n        el.style.top = (pixel.y - (content_height / 2) + options.verticalOffset) + 'px';\n        break;\n      case 'bottom':\n        el.style.top = (pixel.y + options.verticalOffset) + 'px';\n        break;\n    }\n\n    switch (options.horizontalAlign) {\n      case 'left':\n        el.style.left = (pixel.x - content_width + options.horizontalOffset) + 'px';\n        break;\n      default:\n      case 'center':\n        el.style.left = (pixel.x - (content_width / 2) + options.horizontalOffset) + 'px';\n        break;\n      case 'right':\n        el.style.left = (pixel.x + options.horizontalOffset) + 'px';\n        break;\n    }\n\n    el.style.display = auto_show ? 'block' : 'none';\n\n    if (!auto_show) {\n      options.show.apply(this, [el]);\n    }\n  };\n\n  overlay.onRemove = function() {\n    var el = overlay.el;\n\n    if (options.remove) {\n      options.remove.apply(this, [el]);\n    }\n    else {\n      overlay.el.parentNode.removeChild(overlay.el);\n      overlay.el = null;\n    }\n  };\n\n  this.overlays.push(overlay);\n  return overlay;\n};\n\nGMaps.prototype.removeOverlay = function(overlay) {\n  for (var i = 0; i < this.overlays.length; i++) {\n    if (this.overlays[i] === overlay) {\n      this.overlays[i].setMap(null);\n      this.overlays.splice(i, 1);\n\n      break;\n    }\n  }\n};\n\nGMaps.prototype.removeOverlays = function() {\n  for (var i = 0, item; item = this.overlays[i]; i++) {\n    item.setMap(null);\n  }\n\n  this.overlays = [];\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.routes.js",
    "content": "var travelMode, unitSystem;\n\nGMaps.prototype.getRoutes = function(options) {\n  switch (options.travelMode) {\n    case 'bicycling':\n      travelMode = google.maps.TravelMode.BICYCLING;\n      break;\n    case 'transit':\n      travelMode = google.maps.TravelMode.TRANSIT;\n      break;\n    case 'driving':\n      travelMode = google.maps.TravelMode.DRIVING;\n      break;\n    default:\n      travelMode = google.maps.TravelMode.WALKING;\n      break;\n  }\n\n  if (options.unitSystem === 'imperial') {\n    unitSystem = google.maps.UnitSystem.IMPERIAL;\n  }\n  else {\n    unitSystem = google.maps.UnitSystem.METRIC;\n  }\n\n  var base_options = {\n        avoidHighways: false,\n        avoidTolls: false,\n        optimizeWaypoints: false,\n        waypoints: []\n      },\n      request_options =  extend_object(base_options, options);\n\n  request_options.origin = /string/.test(typeof options.origin) ? options.origin : new google.maps.LatLng(options.origin[0], options.origin[1]);\n  request_options.destination = /string/.test(typeof options.destination) ? options.destination : new google.maps.LatLng(options.destination[0], options.destination[1]);\n  request_options.travelMode = travelMode;\n  request_options.unitSystem = unitSystem;\n\n  delete request_options.callback;\n  delete request_options.error;\n\n  var self = this,\n      service = new google.maps.DirectionsService();\n\n  service.route(request_options, function(result, status) {\n    if (status === google.maps.DirectionsStatus.OK) {\n      for (var r in result.routes) {\n        if (result.routes.hasOwnProperty(r)) {\n          self.routes.push(result.routes[r]);\n        }\n      }\n\n      if (options.callback) {\n        options.callback(self.routes);\n      }\n    }\n    else {\n      if (options.error) {\n        options.error(result, status);\n      }\n    }\n  });\n};\n\nGMaps.prototype.removeRoutes = function() {\n  this.routes = [];\n};\n\nGMaps.prototype.getElevations = function(options) {\n  options = extend_object({\n    locations: [],\n    path : false,\n    samples : 256\n  }, options);\n\n  if (options.locations.length > 0) {\n    if (options.locations[0].length > 0) {\n      options.locations = array_flat(array_map([options.locations], arrayToLatLng,  false));\n    }\n  }\n\n  var callback = options.callback;\n  delete options.callback;\n\n  var service = new google.maps.ElevationService();\n\n  //location request\n  if (!options.path) {\n    delete options.path;\n    delete options.samples;\n\n    service.getElevationForLocations(options, function(result, status) {\n      if (callback && typeof(callback) === \"function\") {\n        callback(result, status);\n      }\n    });\n  //path request\n  } else {\n    var pathRequest = {\n      path : options.locations,\n      samples : options.samples\n    };\n\n    service.getElevationAlongPath(pathRequest, function(result, status) {\n     if (callback && typeof(callback) === \"function\") {\n        callback(result, status);\n      }\n    });\n  }\n};\n\nGMaps.prototype.cleanRoute = GMaps.prototype.removePolylines;\n\nGMaps.prototype.drawRoute = function(options) {\n  var self = this;\n\n  this.getRoutes({\n    origin: options.origin,\n    destination: options.destination,\n    travelMode: options.travelMode,\n    waypoints: options.waypoints,\n    unitSystem: options.unitSystem,\n    error: options.error,\n    callback: function(e) {\n      if (e.length > 0) {\n        var polyline_options = {\n          path: e[e.length - 1].overview_path,\n          strokeColor: options.strokeColor,\n          strokeOpacity: options.strokeOpacity,\n          strokeWeight: options.strokeWeight\n        };\n\n        if (options.hasOwnProperty(\"icons\")) {\n          polyline_options.icons = options.icons;\n        }\n\n        self.drawPolyline(polyline_options);\n        \n        if (options.callback) {\n          options.callback(e[e.length - 1]);\n        }\n      }\n    }\n  });\n};\n\nGMaps.prototype.travelRoute = function(options) {\n  if (options.origin && options.destination) {\n    this.getRoutes({\n      origin: options.origin,\n      destination: options.destination,\n      travelMode: options.travelMode,\n      waypoints : options.waypoints,\n      unitSystem: options.unitSystem,\n      error: options.error,\n      callback: function(e) {\n        //start callback\n        if (e.length > 0 && options.start) {\n          options.start(e[e.length - 1]);\n        }\n\n        //step callback\n        if (e.length > 0 && options.step) {\n          var route = e[e.length - 1];\n          if (route.legs.length > 0) {\n            var steps = route.legs[0].steps;\n            for (var i = 0, step; step = steps[i]; i++) {\n              step.step_number = i;\n              options.step(step, (route.legs[0].steps.length - 1));\n            }\n          }\n        }\n\n        //end callback\n        if (e.length > 0 && options.end) {\n           options.end(e[e.length - 1]);\n        }\n      }\n    });\n  }\n  else if (options.route) {\n    if (options.route.legs.length > 0) {\n      var steps = options.route.legs[0].steps;\n      for (var i = 0, step; step = steps[i]; i++) {\n        step.step_number = i;\n        options.step(step);\n      }\n    }\n  }\n};\n\nGMaps.prototype.drawSteppedRoute = function(options) {\n  var self = this;\n  \n  if (options.origin && options.destination) {\n    this.getRoutes({\n      origin: options.origin,\n      destination: options.destination,\n      travelMode: options.travelMode,\n      waypoints : options.waypoints,\n      error: options.error,\n      callback: function(e) {\n        //start callback\n        if (e.length > 0 && options.start) {\n          options.start(e[e.length - 1]);\n        }\n\n        //step callback\n        if (e.length > 0 && options.step) {\n          var route = e[e.length - 1];\n          if (route.legs.length > 0) {\n            var steps = route.legs[0].steps;\n            for (var i = 0, step; step = steps[i]; i++) {\n              step.step_number = i;\n              var polyline_options = {\n                path: step.path,\n                strokeColor: options.strokeColor,\n                strokeOpacity: options.strokeOpacity,\n                strokeWeight: options.strokeWeight\n              };\n\n              if (options.hasOwnProperty(\"icons\")) {\n                polyline_options.icons = options.icons;\n              }\n\n              self.drawPolyline(polyline_options);\n              options.step(step, (route.legs[0].steps.length - 1));\n            }\n          }\n        }\n\n        //end callback\n        if (e.length > 0 && options.end) {\n           options.end(e[e.length - 1]);\n        }\n      }\n    });\n  }\n  else if (options.route) {\n    if (options.route.legs.length > 0) {\n      var steps = options.route.legs[0].steps;\n      for (var i = 0, step; step = steps[i]; i++) {\n        step.step_number = i;\n        var polyline_options = {\n          path: step.path,\n          strokeColor: options.strokeColor,\n          strokeOpacity: options.strokeOpacity,\n          strokeWeight: options.strokeWeight\n        };\n\n        if (options.hasOwnProperty(\"icons\")) {\n          polyline_options.icons = options.icons;\n        }\n\n        self.drawPolyline(polyline_options);\n        options.step(step);\n      }\n    }\n  }\n};\n\nGMaps.Route = function(options) {\n  this.origin = options.origin;\n  this.destination = options.destination;\n  this.waypoints = options.waypoints;\n\n  this.map = options.map;\n  this.route = options.route;\n  this.step_count = 0;\n  this.steps = this.route.legs[0].steps;\n  this.steps_length = this.steps.length;\n\n  var polyline_options = {\n    path: new google.maps.MVCArray(),\n    strokeColor: options.strokeColor,\n    strokeOpacity: options.strokeOpacity,\n    strokeWeight: options.strokeWeight\n  };\n\n  if (options.hasOwnProperty(\"icons\")) {\n    polyline_options.icons = options.icons;\n  }\n\n  this.polyline = this.map.drawPolyline(polyline_options).getPath();\n};\n\nGMaps.Route.prototype.getRoute = function(options) {\n  var self = this;\n\n  this.map.getRoutes({\n    origin : this.origin,\n    destination : this.destination,\n    travelMode : options.travelMode,\n    waypoints : this.waypoints || [],\n    error: options.error,\n    callback : function() {\n      self.route = e[0];\n\n      if (options.callback) {\n        options.callback.call(self);\n      }\n    }\n  });\n};\n\nGMaps.Route.prototype.back = function() {\n  if (this.step_count > 0) {\n    this.step_count--;\n    var path = this.route.legs[0].steps[this.step_count].path;\n\n    for (var p in path){\n      if (path.hasOwnProperty(p)){\n        this.polyline.pop();\n      }\n    }\n  }\n};\n\nGMaps.Route.prototype.forward = function() {\n  if (this.step_count < this.steps_length) {\n    var path = this.route.legs[0].steps[this.step_count].path;\n\n    for (var p in path){\n      if (path.hasOwnProperty(p)){\n        this.polyline.push(path[p]);\n      }\n    }\n    this.step_count++;\n  }\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.static.js",
    "content": "GMaps.prototype.toImage = function(options) {\n  var options = options || {},\n      static_map_options = {};\n\n  static_map_options['size'] = options['size'] || [this.el.clientWidth, this.el.clientHeight];\n  static_map_options['lat'] = this.getCenter().lat();\n  static_map_options['lng'] = this.getCenter().lng();\n\n  if (this.markers.length > 0) {\n    static_map_options['markers'] = [];\n    \n    for (var i = 0; i < this.markers.length; i++) {\n      static_map_options['markers'].push({\n        lat: this.markers[i].getPosition().lat(),\n        lng: this.markers[i].getPosition().lng()\n      });\n    }\n  }\n\n  if (this.polylines.length > 0) {\n    var polyline = this.polylines[0];\n    \n    static_map_options['polyline'] = {};\n    static_map_options['polyline']['path'] = google.maps.geometry.encoding.encodePath(polyline.getPath());\n    static_map_options['polyline']['strokeColor'] = polyline.strokeColor\n    static_map_options['polyline']['strokeOpacity'] = polyline.strokeOpacity\n    static_map_options['polyline']['strokeWeight'] = polyline.strokeWeight\n  }\n\n  return GMaps.staticMapURL(static_map_options);\n};\n\nGMaps.staticMapURL = function(options){\n  var parameters = [],\n      data,\n      static_root = (location.protocol === 'file:' ? 'http:' : location.protocol ) + '//maps.googleapis.com/maps/api/staticmap';\n\n  if (options.url) {\n    static_root = options.url;\n    delete options.url;\n  }\n\n  static_root += '?';\n\n  var markers = options.markers;\n  \n  delete options.markers;\n\n  if (!markers && options.marker) {\n    markers = [options.marker];\n    delete options.marker;\n  }\n\n  var styles = options.styles;\n\n  delete options.styles;\n\n  var polyline = options.polyline;\n  delete options.polyline;\n\n  /** Map options **/\n  if (options.center) {\n    parameters.push('center=' + options.center);\n    delete options.center;\n  }\n  else if (options.address) {\n    parameters.push('center=' + options.address);\n    delete options.address;\n  }\n  else if (options.lat) {\n    parameters.push(['center=', options.lat, ',', options.lng].join(''));\n    delete options.lat;\n    delete options.lng;\n  }\n  else if (options.visible) {\n    var visible = encodeURI(options.visible.join('|'));\n    parameters.push('visible=' + visible);\n  }\n\n  var size = options.size;\n  if (size) {\n    if (size.join) {\n      size = size.join('x');\n    }\n    delete options.size;\n  }\n  else {\n    size = '630x300';\n  }\n  parameters.push('size=' + size);\n\n  if (!options.zoom && options.zoom !== false) {\n    options.zoom = 15;\n  }\n\n  var sensor = options.hasOwnProperty('sensor') ? !!options.sensor : true;\n  delete options.sensor;\n  parameters.push('sensor=' + sensor);\n\n  for (var param in options) {\n    if (options.hasOwnProperty(param)) {\n      parameters.push(param + '=' + options[param]);\n    }\n  }\n\n  /** Markers **/\n  if (markers) {\n    var marker, loc;\n\n    for (var i = 0; data = markers[i]; i++) {\n      marker = [];\n\n      if (data.size && data.size !== 'normal') {\n        marker.push('size:' + data.size);\n        delete data.size;\n      }\n      else if (data.icon) {\n        marker.push('icon:' + encodeURI(data.icon));\n        delete data.icon;\n      }\n\n      if (data.color) {\n        marker.push('color:' + data.color.replace('#', '0x'));\n        delete data.color;\n      }\n\n      if (data.label) {\n        marker.push('label:' + data.label[0].toUpperCase());\n        delete data.label;\n      }\n\n      loc = (data.address ? data.address : data.lat + ',' + data.lng);\n      delete data.address;\n      delete data.lat;\n      delete data.lng;\n\n      for(var param in data){\n        if (data.hasOwnProperty(param)) {\n          marker.push(param + ':' + data[param]);\n        }\n      }\n\n      if (marker.length || i === 0) {\n        marker.push(loc);\n        marker = marker.join('|');\n        parameters.push('markers=' + encodeURI(marker));\n      }\n      // New marker without styles\n      else {\n        marker = parameters.pop() + encodeURI('|' + loc);\n        parameters.push(marker);\n      }\n    }\n  }\n\n  /** Map Styles **/\n  if (styles) {\n    for (var i = 0; i < styles.length; i++) {\n      var styleRule = [];\n      if (styles[i].featureType){\n        styleRule.push('feature:' + styles[i].featureType.toLowerCase());\n      }\n\n      if (styles[i].elementType) {\n        styleRule.push('element:' + styles[i].elementType.toLowerCase());\n      }\n\n      for (var j = 0; j < styles[i].stylers.length; j++) {\n        for (var p in styles[i].stylers[j]) {\n          var ruleArg = styles[i].stylers[j][p];\n          if (p == 'hue' || p == 'color') {\n            ruleArg = '0x' + ruleArg.substring(1);\n          }\n          styleRule.push(p + ':' + ruleArg);\n        }\n      }\n\n      var rule = styleRule.join('|');\n      if (rule != '') {\n        parameters.push('style=' + rule);\n      }\n    }\n  }\n\n  /** Polylines **/\n  function parseColor(color, opacity) {\n    if (color[0] === '#'){\n      color = color.replace('#', '0x');\n\n      if (opacity) {\n        opacity = parseFloat(opacity);\n        opacity = Math.min(1, Math.max(opacity, 0));\n        if (opacity === 0) {\n          return '0x00000000';\n        }\n        opacity = (opacity * 255).toString(16);\n        if (opacity.length === 1) {\n          opacity += opacity;\n        }\n\n        color = color.slice(0,8) + opacity;\n      }\n    }\n    return color;\n  }\n\n  if (polyline) {\n    data = polyline;\n    polyline = [];\n\n    if (data.strokeWeight) {\n      polyline.push('weight:' + parseInt(data.strokeWeight, 10));\n    }\n\n    if (data.strokeColor) {\n      var color = parseColor(data.strokeColor, data.strokeOpacity);\n      polyline.push('color:' + color);\n    }\n\n    if (data.fillColor) {\n      var fillcolor = parseColor(data.fillColor, data.fillOpacity);\n      polyline.push('fillcolor:' + fillcolor);\n    }\n\n    var path = data.path;\n    if (path.join) {\n      for (var j=0, pos; pos=path[j]; j++) {\n        polyline.push(pos.join(','));\n      }\n    }\n    else {\n      polyline.push('enc:' + path);\n    }\n\n    polyline = polyline.join('|');\n    parameters.push('path=' + encodeURI(polyline));\n  }\n\n  /** Retina support **/\n  var dpi = window.devicePixelRatio || 1;\n  parameters.push('scale=' + dpi);\n\n  parameters = parameters.join('&');\n  return static_root + parameters;\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.streetview.js",
    "content": "GMaps.prototype.createPanorama = function(streetview_options) {\n  if (!streetview_options.hasOwnProperty('lat') || !streetview_options.hasOwnProperty('lng')) {\n    streetview_options.lat = this.getCenter().lat();\n    streetview_options.lng = this.getCenter().lng();\n  }\n\n  this.panorama = GMaps.createPanorama(streetview_options);\n\n  this.map.setStreetView(this.panorama);\n\n  return this.panorama;\n};\n\nGMaps.createPanorama = function(options) {\n  var el = getElementById(options.el, options.context);\n\n  options.position = new google.maps.LatLng(options.lat, options.lng);\n\n  delete options.el;\n  delete options.context;\n  delete options.lat;\n  delete options.lng;\n\n  var streetview_events = ['closeclick', 'links_changed', 'pano_changed', 'position_changed', 'pov_changed', 'resize', 'visible_changed'],\n      streetview_options = extend_object({visible : true}, options);\n\n  for (var i = 0; i < streetview_events.length; i++) {\n    delete streetview_options[streetview_events[i]];\n  }\n\n  var panorama = new google.maps.StreetViewPanorama(el, streetview_options);\n\n  for (var i = 0; i < streetview_events.length; i++) {\n    (function(object, name) {\n      if (options[name]) {\n        google.maps.event.addListener(object, name, function(){\n          options[name].apply(this);\n        });\n      }\n    })(panorama, streetview_events[i]);\n  }\n\n  return panorama;\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.styles.js",
    "content": "GMaps.prototype.addStyle = function(options) {\n  var styledMapType = new google.maps.StyledMapType(options.styles, { name: options.styledMapName });\n\n  this.map.mapTypes.set(options.mapTypeId, styledMapType);\n};\n\nGMaps.prototype.setStyle = function(mapTypeId) {\n  this.map.setMapTypeId(mapTypeId);\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/gmaps/lib/gmaps.utils.js",
    "content": "GMaps.geolocate = function(options) {\n  var complete_callback = options.always || options.complete;\n\n  if (navigator.geolocation) {\n    navigator.geolocation.getCurrentPosition(function(position) {\n      options.success(position);\n\n      if (complete_callback) {\n        complete_callback();\n      }\n    }, function(error) {\n      options.error(error);\n\n      if (complete_callback) {\n        complete_callback();\n      }\n    }, options.options);\n  }\n  else {\n    options.not_supported();\n\n    if (complete_callback) {\n      complete_callback();\n    }\n  }\n};\n\nGMaps.geocode = function(options) {\n  this.geocoder = new google.maps.Geocoder();\n  var callback = options.callback;\n  if (options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) {\n    options.latLng = new google.maps.LatLng(options.lat, options.lng);\n  }\n\n  delete options.lat;\n  delete options.lng;\n  delete options.callback;\n  \n  this.geocoder.geocode(options, function(results, status) {\n    callback(results, status);\n  });\n};\n"
  },
  {
    "path": "src/main/resources/static/dashboard/assets/plugins/sticky-kit-master/dist/sticky-kit.js",
    "content": "// Generated by CoffeeScript 1.10.0\n\n/**\n@license Sticky-kit v1.1.3 | MIT | Leaf Corcoran 2015 | http://leafo.net\n */\n\n(function() {\n  var $, win;\n\n  $ = window.jQuery;\n\n  win = $(window);\n\n  $.fn.stick_in_parent = function(opts) {\n    var doc, elm, enable_bottoming, fn, i, inner_scrolling, len, manual_spacer, offset_top, outer_width, parent_selector, recalc_every, sticky_class;\n    if (opts == null) {\n      opts = {};\n    }\n    sticky_class = opts.sticky_class, inner_scrolling = opts.inner_scrolling, recalc_every = opts.recalc_every, parent_selector = opts.parent, offset_top = opts.offset_top, manual_spacer = opts.spacer, enable_bottoming = opts.bottoming;\n    if (offset_top == null) {\n      offset_top = 0;\n    }\n    if (parent_selector == null) {\n      parent_selector = void 0;\n    }\n    if (inner_scrolling == null) {\n      inner_scrolling = true;\n    }\n    if (sticky_class == null) {\n      sticky_class = \"is_stuck\";\n    }\n    doc = $(document);\n    if (enable_bottoming == null) {\n      enable_bottoming = true;\n    }\n    outer_width = function(el) {\n      var _el, computed, w;\n      if (window.getComputedStyle) {\n        _el = el[0];\n        computed = window.getComputedStyle(el[0]);\n        w = parseFloat(computed.getPropertyValue(\"width\")) + parseFloat(computed.getPropertyValue(\"margin-left\")) + parseFloat(computed.getPropertyValue(\"margin-right\"));\n        if (computed.getPropertyValue(\"box-sizing\") !== \"border-box\") {\n          w += parseFloat(computed.getPropertyValue(\"border-left-width\")) + parseFloat(computed.getPropertyValue(\"border-right-width\")) + parseFloat(computed.getPropertyValue(\"padding-left\")) + parseFloat(computed.getPropertyValue(\"padding-right\"));\n        }\n        return w;\n      } else {\n        return el.outerWidth(true);\n      }\n    };\n    fn = function(elm, padding_bottom, parent_top, parent_height, top, height, el_float, detached) {\n      var bottomed, detach, fixed, last_pos, last_scroll_height, offset, parent, recalc, recalc_and_tick, recalc_counter, spacer, tick;\n      if (elm.data(\"sticky_kit\")) {\n        return;\n      }\n      elm.data(\"sticky_kit\", true);\n      last_scroll_height = doc.height();\n      parent = elm.parent();\n      if (parent_selector != null) {\n        parent = parent.closest(parent_selector);\n      }\n      if (!parent.length) {\n        throw \"failed to find stick parent\";\n      }\n      fixed = false;\n      bottomed = false;\n      spacer = manual_spacer != null ? manual_spacer && elm.closest(manual_spacer) : $(\"<div />\");\n      if (spacer) {\n        spacer.css('position', elm.css('position'));\n      }\n      recalc = function() {\n        var border_top, padding_top, restore;\n        if (detached) {\n          return;\n        }\n        last_scroll_height = doc.height();\n        border_top = parseInt(parent.css(\"border-top-width\"), 10);\n        padding_top = parseInt(parent.css(\"padding-top\"), 10);\n        padding_bottom = parseInt(parent.css(\"padding-bottom\"), 10);\n        parent_top = parent.offset().top + border_top + padding_top;\n        parent_height = parent.height();\n        if (fixed) {\n          fixed = false;\n          bottomed = false;\n          if (manual_spacer == null) {\n            elm.insertAfter(spacer);\n            spacer.detach();\n          }\n          elm.css({\n            position: \"\",\n            top: \"\",\n            width: \"\",\n            bottom: \"\"\n          }).removeClass(sticky_class);\n          restore = true;\n        }\n        top = elm.offset().top - (parseInt(elm.css(\"margin-top\"), 10) || 0) - offset_top;\n        height = elm.outerHeight(true);\n        el_float = elm.css(\"float\");\n        if (spacer) {\n          spacer.css({\n            width: outer_width(elm),\n            height: height,\n            display: elm.css(\"display\"),\n            \"vertical-align\": elm.css(\"vertical-align\"),\n            \"float\": el_float\n          });\n        }\n        if (restore) {\n          return tick();\n        }\n      };\n      recalc();\n      if (height === parent_height) {\n        return;\n      }\n      last_pos = void 0;\n      offset = offset_top;\n      recalc_counter = recalc_every;\n      tick = function() {\n        var css, delta, recalced, scroll, will_bottom, win_height;\n        if (detached) {\n          return;\n        }\n        recalced = false;\n        if (recalc_counter != null) {\n          recalc_counter -= 1;\n          if (recalc_counter <= 0) {\n            recalc_counter = recalc_every;\n            recalc();\n            recalced = true;\n          }\n        }\n        if (!recalced && doc.height() !== last_scroll_height) {\n          recalc();\n          recalced = true;\n        }\n        scroll = win.scrollTop();\n        if (last_pos != null) {\n          delta = scroll - last_pos;\n        }\n        last_pos = scroll;\n        if (fixed) {\n          if (enable_bottoming) {\n            will_bottom = scroll + height + offset > parent_height + parent_top;\n            if (bottomed && !will_bottom) {\n              bottomed = false;\n              elm.css({\n                position: \"fixed\",\n                bottom: \"\",\n                top: offset\n              }).trigger(\"sticky_kit:unbottom\");\n            }\n          }\n          if (scroll < top) {\n            fixed = false;\n            offset = offset_top;\n            if (manual_spacer == null) {\n              if (el_float === \"left\" || el_float === \"right\") {\n                elm.insertAfter(spacer);\n              }\n              spacer.detach();\n            }\n            css = {\n              position: \"\",\n              width: \"\",\n              top: \"\"\n            };\n            elm.css(css).removeClass(sticky_class).trigger(\"sticky_kit:unstick\");\n          }\n          if (inner_scrolling) {\n            win_height = win.height();\n            if (height + offset_top > win_height) {\n              if (!bottomed) {\n                offset -= delta;\n                offset = Math.max(win_height - height, offset);\n                offset = Math.min(offset_top, offset);\n                if (fixed) {\n                  elm.css({\n                    top: offset + \"px\"\n                  });\n                }\n              }\n            }\n          }\n        } else {\n          if (scroll > top) {\n            fixed = true;\n            css = {\n              position: \"fixed\",\n              top: offset\n            };\n            css.width = elm.css(\"box-sizing\") === \"border-box\" ? elm.outerWidth() + \"px\" : elm.width() + \"px\";\n            elm.css(css).addClass(sticky_class);\n            if (manual_spacer == null) {\n              elm.after(spacer);\n              if (el_float === \"left\" || el_float === \"right\") {\n                spacer.append(elm);\n              }\n            }\n            elm.trigger(\"sticky_kit:stick\");\n          }\n        }\n        if (fixed && enable_bottoming) {\n          if (will_bottom == null) {\n            will_bottom = scroll + height + offset > parent_height + parent_top;\n          }\n          if (!bottomed && will_bottom) {\n            bottomed = true;\n            if (parent.css(\"position\") === \"static\") {\n              parent.css({\n                position: \"relative\"\n              });\n            }\n            return elm.css({\n              position: \"absolute\",\n              bottom: padding_bottom,\n              top: \"auto\"\n            }).trigger(\"sticky_kit:bottom\");\n          }\n        }\n      };\n      recalc_and_tick = function() {\n        recalc();\n        return tick();\n      };\n      detach = function() {\n        detached = true;\n        win.off(\"touchmove\", tick);\n        win.off(\"scroll\", tick);\n        win.off(\"resize\", recalc_and_tick);\n        $(document.body).off(\"sticky_kit:recalc\", recalc_and_tick);\n        elm.off(\"sticky_kit:detach\", detach);\n        elm.removeData(\"sticky_kit\");\n        elm.css({\n          position: \"\",\n          bottom: \"\",\n          top: \"\",\n          width: \"\"\n        });\n        parent.position(\"position\", \"\");\n        if (fixed) {\n          if (manual_spacer == null) {\n            if (el_float === \"left\" || el_float === \"right\") {\n              elm.insertAfter(spacer);\n            }\n            spacer.remove();\n          }\n          return elm.removeClass(sticky_class);\n        }\n      };\n      win.on(\"touchmove\", tick);\n      win.on(\"scroll\", tick);\n      win.on(\"resize\", recalc_and_tick);\n      $(document.body).on(\"sticky_kit:recalc\", recalc_and_tick);\n      elm.on(\"sticky_kit:detach\", detach);\n      return setTimeout(tick, 0);\n    };\n    for (i = 0, len = this.length; i < len; i++) {\n      elm = this[i];\n      fn($(elm));\n    }\n    return this;\n  };\n\n}).call(this);\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/css/animate.css",
    "content": "@charset \"UTF-8\";/*!\n * animate.css -http://daneden.me/animate\n * Version - 3.5.1\n * Licensed under the MIT license - http://opensource.org/licenses/MIT\n *\n * Copyright (c) 2016 Daniel Eden\n */.animated{-webkit-animation-duration:1s;animation-duration:1s;-webkit-animation-fill-mode:both;animation-fill-mode:both}.animated.infinite{-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}.animated.hinge{-webkit-animation-duration:2s;animation-duration:2s}.animated.flipOutX,.animated.flipOutY,.animated.bounceIn,.animated.bounceOut{-webkit-animation-duration:.75s;animation-duration:.75s}@-webkit-keyframes bounce{from,20%,53%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000);-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}40%,43%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:translate3d(0,-30px,0);transform:translate3d(0,-30px,0)}70%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:translate3d(0,-15px,0);transform:translate3d(0,-15px,0)}90%{-webkit-transform:translate3d(0,-4px,0);transform:translate3d(0,-4px,0)}}@keyframes bounce{from,20%,53%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000);-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}40%,43%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:translate3d(0,-30px,0);transform:translate3d(0,-30px,0)}70%{-webkit-animation-timing-function:cubic-bezier(.755,.05,.855,.06);animation-timing-function:cubic-bezier(.755,.05,.855,.06);-webkit-transform:translate3d(0,-15px,0);transform:translate3d(0,-15px,0)}90%{-webkit-transform:translate3d(0,-4px,0);transform:translate3d(0,-4px,0)}}.bounce{-webkit-animation-name:bounce;animation-name:bounce;-webkit-transform-origin:center bottom;transform-origin:center bottom}@-webkit-keyframes flash{from,50%,to{opacity:1}25%,75%{opacity:0}}@keyframes flash{from,50%,to{opacity:1}25%,75%{opacity:0}}.flash{-webkit-animation-name:flash;animation-name:flash}@-webkit-keyframes pulse{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}50%{-webkit-transform:scale3d(1.05,1.05,1.05);transform:scale3d(1.05,1.05,1.05)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}@keyframes pulse{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}50%{-webkit-transform:scale3d(1.05,1.05,1.05);transform:scale3d(1.05,1.05,1.05)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}.pulse{-webkit-animation-name:pulse;animation-name:pulse}@-webkit-keyframes rubberBand{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}30%{-webkit-transform:scale3d(1.25,.75,1);transform:scale3d(1.25,.75,1)}40%{-webkit-transform:scale3d(.75,1.25,1);transform:scale3d(.75,1.25,1)}50%{-webkit-transform:scale3d(1.15,.85,1);transform:scale3d(1.15,.85,1)}65%{-webkit-transform:scale3d(.95,1.05,1);transform:scale3d(.95,1.05,1)}75%{-webkit-transform:scale3d(1.05,.95,1);transform:scale3d(1.05,.95,1)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}@keyframes rubberBand{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}30%{-webkit-transform:scale3d(1.25,.75,1);transform:scale3d(1.25,.75,1)}40%{-webkit-transform:scale3d(.75,1.25,1);transform:scale3d(.75,1.25,1)}50%{-webkit-transform:scale3d(1.15,.85,1);transform:scale3d(1.15,.85,1)}65%{-webkit-transform:scale3d(.95,1.05,1);transform:scale3d(.95,1.05,1)}75%{-webkit-transform:scale3d(1.05,.95,1);transform:scale3d(1.05,.95,1)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}.rubberBand{-webkit-animation-name:rubberBand;animation-name:rubberBand}@-webkit-keyframes shake{from,to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}10%,30%,50%,70%,90%{-webkit-transform:translate3d(-10px,0,0);transform:translate3d(-10px,0,0)}20%,40%,60%,80%{-webkit-transform:translate3d(10px,0,0);transform:translate3d(10px,0,0)}}@keyframes shake{from,to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}10%,30%,50%,70%,90%{-webkit-transform:translate3d(-10px,0,0);transform:translate3d(-10px,0,0)}20%,40%,60%,80%{-webkit-transform:translate3d(10px,0,0);transform:translate3d(10px,0,0)}}.shake{-webkit-animation-name:shake;animation-name:shake}@-webkit-keyframes headShake{0%{-webkit-transform:translateX(0);transform:translateX(0)}6.5%{-webkit-transform:translateX(-6px) rotateY(-9deg);transform:translateX(-6px) rotateY(-9deg)}18.5%{-webkit-transform:translateX(5px) rotateY(7deg);transform:translateX(5px) rotateY(7deg)}31.5%{-webkit-transform:translateX(-3px) rotateY(-5deg);transform:translateX(-3px) rotateY(-5deg)}43.5%{-webkit-transform:translateX(2px) rotateY(3deg);transform:translateX(2px) rotateY(3deg)}50%{-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes headShake{0%{-webkit-transform:translateX(0);transform:translateX(0)}6.5%{-webkit-transform:translateX(-6px) rotateY(-9deg);transform:translateX(-6px) rotateY(-9deg)}18.5%{-webkit-transform:translateX(5px) rotateY(7deg);transform:translateX(5px) rotateY(7deg)}31.5%{-webkit-transform:translateX(-3px) rotateY(-5deg);transform:translateX(-3px) rotateY(-5deg)}43.5%{-webkit-transform:translateX(2px) rotateY(3deg);transform:translateX(2px) rotateY(3deg)}50%{-webkit-transform:translateX(0);transform:translateX(0)}}.headShake{-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-animation-name:headShake;animation-name:headShake}@-webkit-keyframes swing{20%{-webkit-transform:rotate3d(0,0,1,15deg);transform:rotate3d(0,0,1,15deg)}40%{-webkit-transform:rotate3d(0,0,1,-10deg);transform:rotate3d(0,0,1,-10deg)}60%{-webkit-transform:rotate3d(0,0,1,5deg);transform:rotate3d(0,0,1,5deg)}80%{-webkit-transform:rotate3d(0,0,1,-5deg);transform:rotate3d(0,0,1,-5deg)}to{-webkit-transform:rotate3d(0,0,1,0deg);transform:rotate3d(0,0,1,0deg)}}@keyframes swing{20%{-webkit-transform:rotate3d(0,0,1,15deg);transform:rotate3d(0,0,1,15deg)}40%{-webkit-transform:rotate3d(0,0,1,-10deg);transform:rotate3d(0,0,1,-10deg)}60%{-webkit-transform:rotate3d(0,0,1,5deg);transform:rotate3d(0,0,1,5deg)}80%{-webkit-transform:rotate3d(0,0,1,-5deg);transform:rotate3d(0,0,1,-5deg)}to{-webkit-transform:rotate3d(0,0,1,0deg);transform:rotate3d(0,0,1,0deg)}}.swing{-webkit-transform-origin:top center;transform-origin:top center;-webkit-animation-name:swing;animation-name:swing}@-webkit-keyframes tada{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}10%,20%{-webkit-transform:scale3d(.9,.9,.9) rotate3d(0,0,1,-3deg);transform:scale3d(.9,.9,.9) rotate3d(0,0,1,-3deg)}30%,50%,70%,90%{-webkit-transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,3deg);transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,3deg)}40%,60%,80%{-webkit-transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,-3deg);transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,-3deg)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}@keyframes tada{from{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}10%,20%{-webkit-transform:scale3d(.9,.9,.9) rotate3d(0,0,1,-3deg);transform:scale3d(.9,.9,.9) rotate3d(0,0,1,-3deg)}30%,50%,70%,90%{-webkit-transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,3deg);transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,3deg)}40%,60%,80%{-webkit-transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,-3deg);transform:scale3d(1.1,1.1,1.1) rotate3d(0,0,1,-3deg)}to{-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}.tada{-webkit-animation-name:tada;animation-name:tada}@-webkit-keyframes wobble{from{-webkit-transform:none;transform:none}15%{-webkit-transform:translate3d(-25%,0,0) rotate3d(0,0,1,-5deg);transform:translate3d(-25%,0,0) rotate3d(0,0,1,-5deg)}30%{-webkit-transform:translate3d(20%,0,0) rotate3d(0,0,1,3deg);transform:translate3d(20%,0,0) rotate3d(0,0,1,3deg)}45%{-webkit-transform:translate3d(-15%,0,0) rotate3d(0,0,1,-3deg);transform:translate3d(-15%,0,0) rotate3d(0,0,1,-3deg)}60%{-webkit-transform:translate3d(10%,0,0) rotate3d(0,0,1,2deg);transform:translate3d(10%,0,0) rotate3d(0,0,1,2deg)}75%{-webkit-transform:translate3d(-5%,0,0) rotate3d(0,0,1,-1deg);transform:translate3d(-5%,0,0) rotate3d(0,0,1,-1deg)}to{-webkit-transform:none;transform:none}}@keyframes wobble{from{-webkit-transform:none;transform:none}15%{-webkit-transform:translate3d(-25%,0,0) rotate3d(0,0,1,-5deg);transform:translate3d(-25%,0,0) rotate3d(0,0,1,-5deg)}30%{-webkit-transform:translate3d(20%,0,0) rotate3d(0,0,1,3deg);transform:translate3d(20%,0,0) rotate3d(0,0,1,3deg)}45%{-webkit-transform:translate3d(-15%,0,0) rotate3d(0,0,1,-3deg);transform:translate3d(-15%,0,0) rotate3d(0,0,1,-3deg)}60%{-webkit-transform:translate3d(10%,0,0) rotate3d(0,0,1,2deg);transform:translate3d(10%,0,0) rotate3d(0,0,1,2deg)}75%{-webkit-transform:translate3d(-5%,0,0) rotate3d(0,0,1,-1deg);transform:translate3d(-5%,0,0) rotate3d(0,0,1,-1deg)}to{-webkit-transform:none;transform:none}}.wobble{-webkit-animation-name:wobble;animation-name:wobble}@-webkit-keyframes jello{from,11.1%,to{-webkit-transform:none;transform:none}22.2%{-webkit-transform:skewX(-12.5deg) skewY(-12.5deg);transform:skewX(-12.5deg) skewY(-12.5deg)}33.3%{-webkit-transform:skewX(6.25deg) skewY(6.25deg);transform:skewX(6.25deg) skewY(6.25deg)}44.4%{-webkit-transform:skewX(-3.125deg) skewY(-3.125deg);transform:skewX(-3.125deg) skewY(-3.125deg)}55.5%{-webkit-transform:skewX(1.5625deg) skewY(1.5625deg);transform:skewX(1.5625deg) skewY(1.5625deg)}66.6%{-webkit-transform:skewX(-.78125deg) skewY(-.78125deg);transform:skewX(-.78125deg) skewY(-.78125deg)}77.7%{-webkit-transform:skewX(.390625deg) skewY(.390625deg);transform:skewX(.390625deg) skewY(.390625deg)}88.8%{-webkit-transform:skewX(-.1953125deg) skewY(-.1953125deg);transform:skewX(-.1953125deg) skewY(-.1953125deg)}}@keyframes jello{from,11.1%,to{-webkit-transform:none;transform:none}22.2%{-webkit-transform:skewX(-12.5deg) skewY(-12.5deg);transform:skewX(-12.5deg) skewY(-12.5deg)}33.3%{-webkit-transform:skewX(6.25deg) skewY(6.25deg);transform:skewX(6.25deg) skewY(6.25deg)}44.4%{-webkit-transform:skewX(-3.125deg) skewY(-3.125deg);transform:skewX(-3.125deg) skewY(-3.125deg)}55.5%{-webkit-transform:skewX(1.5625deg) skewY(1.5625deg);transform:skewX(1.5625deg) skewY(1.5625deg)}66.6%{-webkit-transform:skewX(-.78125deg) skewY(-.78125deg);transform:skewX(-.78125deg) skewY(-.78125deg)}77.7%{-webkit-transform:skewX(.390625deg) skewY(.390625deg);transform:skewX(.390625deg) skewY(.390625deg)}88.8%{-webkit-transform:skewX(-.1953125deg) skewY(-.1953125deg);transform:skewX(-.1953125deg) skewY(-.1953125deg)}}.jello{-webkit-animation-name:jello;animation-name:jello;-webkit-transform-origin:center;transform-origin:center}@-webkit-keyframes bounceIn{from,20%,40%,60%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}20%{-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}40%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}60%{opacity:1;-webkit-transform:scale3d(1.03,1.03,1.03);transform:scale3d(1.03,1.03,1.03)}80%{-webkit-transform:scale3d(.97,.97,.97);transform:scale3d(.97,.97,.97)}to{opacity:1;-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}@keyframes bounceIn{from,20%,40%,60%,80%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}20%{-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}40%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}60%{opacity:1;-webkit-transform:scale3d(1.03,1.03,1.03);transform:scale3d(1.03,1.03,1.03)}80%{-webkit-transform:scale3d(.97,.97,.97);transform:scale3d(.97,.97,.97)}to{opacity:1;-webkit-transform:scale3d(1,1,1);transform:scale3d(1,1,1)}}.bounceIn{-webkit-animation-name:bounceIn;animation-name:bounceIn}@-webkit-keyframes bounceInDown{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:translate3d(0,-3000px,0);transform:translate3d(0,-3000px,0)}60%{opacity:1;-webkit-transform:translate3d(0,25px,0);transform:translate3d(0,25px,0)}75%{-webkit-transform:translate3d(0,-10px,0);transform:translate3d(0,-10px,0)}90%{-webkit-transform:translate3d(0,5px,0);transform:translate3d(0,5px,0)}to{-webkit-transform:none;transform:none}}@keyframes bounceInDown{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:translate3d(0,-3000px,0);transform:translate3d(0,-3000px,0)}60%{opacity:1;-webkit-transform:translate3d(0,25px,0);transform:translate3d(0,25px,0)}75%{-webkit-transform:translate3d(0,-10px,0);transform:translate3d(0,-10px,0)}90%{-webkit-transform:translate3d(0,5px,0);transform:translate3d(0,5px,0)}to{-webkit-transform:none;transform:none}}.bounceInDown{-webkit-animation-name:bounceInDown;animation-name:bounceInDown}@-webkit-keyframes bounceInLeft{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:translate3d(-3000px,0,0);transform:translate3d(-3000px,0,0)}60%{opacity:1;-webkit-transform:translate3d(25px,0,0);transform:translate3d(25px,0,0)}75%{-webkit-transform:translate3d(-10px,0,0);transform:translate3d(-10px,0,0)}90%{-webkit-transform:translate3d(5px,0,0);transform:translate3d(5px,0,0)}to{-webkit-transform:none;transform:none}}@keyframes bounceInLeft{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}0%{opacity:0;-webkit-transform:translate3d(-3000px,0,0);transform:translate3d(-3000px,0,0)}60%{opacity:1;-webkit-transform:translate3d(25px,0,0);transform:translate3d(25px,0,0)}75%{-webkit-transform:translate3d(-10px,0,0);transform:translate3d(-10px,0,0)}90%{-webkit-transform:translate3d(5px,0,0);transform:translate3d(5px,0,0)}to{-webkit-transform:none;transform:none}}.bounceInLeft{-webkit-animation-name:bounceInLeft;animation-name:bounceInLeft}@-webkit-keyframes bounceInRight{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}from{opacity:0;-webkit-transform:translate3d(3000px,0,0);transform:translate3d(3000px,0,0)}60%{opacity:1;-webkit-transform:translate3d(-25px,0,0);transform:translate3d(-25px,0,0)}75%{-webkit-transform:translate3d(10px,0,0);transform:translate3d(10px,0,0)}90%{-webkit-transform:translate3d(-5px,0,0);transform:translate3d(-5px,0,0)}to{-webkit-transform:none;transform:none}}@keyframes bounceInRight{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}from{opacity:0;-webkit-transform:translate3d(3000px,0,0);transform:translate3d(3000px,0,0)}60%{opacity:1;-webkit-transform:translate3d(-25px,0,0);transform:translate3d(-25px,0,0)}75%{-webkit-transform:translate3d(10px,0,0);transform:translate3d(10px,0,0)}90%{-webkit-transform:translate3d(-5px,0,0);transform:translate3d(-5px,0,0)}to{-webkit-transform:none;transform:none}}.bounceInRight{-webkit-animation-name:bounceInRight;animation-name:bounceInRight}@-webkit-keyframes bounceInUp{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}from{opacity:0;-webkit-transform:translate3d(0,3000px,0);transform:translate3d(0,3000px,0)}60%{opacity:1;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}75%{-webkit-transform:translate3d(0,10px,0);transform:translate3d(0,10px,0)}90%{-webkit-transform:translate3d(0,-5px,0);transform:translate3d(0,-5px,0)}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes bounceInUp{from,60%,75%,90%,to{-webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1.000);animation-timing-function:cubic-bezier(.215,.61,.355,1.000)}from{opacity:0;-webkit-transform:translate3d(0,3000px,0);transform:translate3d(0,3000px,0)}60%{opacity:1;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}75%{-webkit-transform:translate3d(0,10px,0);transform:translate3d(0,10px,0)}90%{-webkit-transform:translate3d(0,-5px,0);transform:translate3d(0,-5px,0)}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.bounceInUp{-webkit-animation-name:bounceInUp;animation-name:bounceInUp}@-webkit-keyframes bounceOut{20%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}50%,55%{opacity:1;-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}to{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}}@keyframes bounceOut{20%{-webkit-transform:scale3d(.9,.9,.9);transform:scale3d(.9,.9,.9)}50%,55%{opacity:1;-webkit-transform:scale3d(1.1,1.1,1.1);transform:scale3d(1.1,1.1,1.1)}to{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}}.bounceOut{-webkit-animation-name:bounceOut;animation-name:bounceOut}@-webkit-keyframes bounceOutDown{20%{-webkit-transform:translate3d(0,10px,0);transform:translate3d(0,10px,0)}40%,45%{opacity:1;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}}@keyframes bounceOutDown{20%{-webkit-transform:translate3d(0,10px,0);transform:translate3d(0,10px,0)}40%,45%{opacity:1;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}}.bounceOutDown{-webkit-animation-name:bounceOutDown;animation-name:bounceOutDown}@-webkit-keyframes bounceOutLeft{20%{opacity:1;-webkit-transform:translate3d(20px,0,0);transform:translate3d(20px,0,0)}to{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}}@keyframes bounceOutLeft{20%{opacity:1;-webkit-transform:translate3d(20px,0,0);transform:translate3d(20px,0,0)}to{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}}.bounceOutLeft{-webkit-animation-name:bounceOutLeft;animation-name:bounceOutLeft}@-webkit-keyframes bounceOutRight{20%{opacity:1;-webkit-transform:translate3d(-20px,0,0);transform:translate3d(-20px,0,0)}to{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}}@keyframes bounceOutRight{20%{opacity:1;-webkit-transform:translate3d(-20px,0,0);transform:translate3d(-20px,0,0)}to{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}}.bounceOutRight{-webkit-animation-name:bounceOutRight;animation-name:bounceOutRight}@-webkit-keyframes bounceOutUp{20%{-webkit-transform:translate3d(0,-10px,0);transform:translate3d(0,-10px,0)}40%,45%{opacity:1;-webkit-transform:translate3d(0,20px,0);transform:translate3d(0,20px,0)}to{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}}@keyframes bounceOutUp{20%{-webkit-transform:translate3d(0,-10px,0);transform:translate3d(0,-10px,0)}40%,45%{opacity:1;-webkit-transform:translate3d(0,20px,0);transform:translate3d(0,20px,0)}to{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}}.bounceOutUp{-webkit-animation-name:bounceOutUp;animation-name:bounceOutUp}@-webkit-keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.fadeIn{-webkit-animation-name:fadeIn;animation-name:fadeIn}@-webkit-keyframes fadeInDown{from{opacity:0;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInDown{from{opacity:0;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInDown{-webkit-animation-name:fadeInDown;animation-name:fadeInDown}@-webkit-keyframes fadeInDownBig{from{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInDownBig{from{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInDownBig{-webkit-animation-name:fadeInDownBig;animation-name:fadeInDownBig}@-webkit-keyframes fadeInLeft{from{opacity:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInLeft{from{opacity:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInLeft{-webkit-animation-name:fadeInLeft;animation-name:fadeInLeft}@-webkit-keyframes fadeInLeftBig{from{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInLeftBig{from{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInLeftBig{-webkit-animation-name:fadeInLeftBig;animation-name:fadeInLeftBig}@-webkit-keyframes fadeInRight{from{opacity:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInRight{from{opacity:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInRight{-webkit-animation-name:fadeInRight;animation-name:fadeInRight}@-webkit-keyframes fadeInRightBig{from{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInRightBig{from{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInRightBig{-webkit-animation-name:fadeInRightBig;animation-name:fadeInRightBig}@-webkit-keyframes fadeInUp{from{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInUp{from{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInUp{-webkit-animation-name:fadeInUp;animation-name:fadeInUp}@-webkit-keyframes fadeInUpBig{from{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes fadeInUpBig{from{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}to{opacity:1;-webkit-transform:none;transform:none}}.fadeInUpBig{-webkit-animation-name:fadeInUpBig;animation-name:fadeInUpBig}@-webkit-keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}.fadeOut{-webkit-animation-name:fadeOut;animation-name:fadeOut}@-webkit-keyframes fadeOutDown{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes fadeOutDown{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}.fadeOutDown{-webkit-animation-name:fadeOutDown;animation-name:fadeOutDown}@-webkit-keyframes fadeOutDownBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}}@keyframes fadeOutDownBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,2000px,0);transform:translate3d(0,2000px,0)}}.fadeOutDownBig{-webkit-animation-name:fadeOutDownBig;animation-name:fadeOutDownBig}@-webkit-keyframes fadeOutLeft{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}@keyframes fadeOutLeft{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.fadeOutLeft{-webkit-animation-name:fadeOutLeft;animation-name:fadeOutLeft}@-webkit-keyframes fadeOutLeftBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}}@keyframes fadeOutLeftBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(-2000px,0,0);transform:translate3d(-2000px,0,0)}}.fadeOutLeftBig{-webkit-animation-name:fadeOutLeftBig;animation-name:fadeOutLeftBig}@-webkit-keyframes fadeOutRight{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}@keyframes fadeOutRight{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}.fadeOutRight{-webkit-animation-name:fadeOutRight;animation-name:fadeOutRight}@-webkit-keyframes fadeOutRightBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}}@keyframes fadeOutRightBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(2000px,0,0);transform:translate3d(2000px,0,0)}}.fadeOutRightBig{-webkit-animation-name:fadeOutRightBig;animation-name:fadeOutRightBig}@-webkit-keyframes fadeOutUp{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}@keyframes fadeOutUp{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}.fadeOutUp{-webkit-animation-name:fadeOutUp;animation-name:fadeOutUp}@-webkit-keyframes fadeOutUpBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}}@keyframes fadeOutUpBig{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(0,-2000px,0);transform:translate3d(0,-2000px,0)}}.fadeOutUpBig{-webkit-animation-name:fadeOutUpBig;animation-name:fadeOutUpBig}@-webkit-keyframes flip{from{-webkit-transform:perspective(400px) rotate3d(0,1,0,-360deg);transform:perspective(400px) rotate3d(0,1,0,-360deg);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}40%{-webkit-transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-190deg);transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-190deg);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}50%{-webkit-transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-170deg);transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-170deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}80%{-webkit-transform:perspective(400px) scale3d(.95,.95,.95);transform:perspective(400px) scale3d(.95,.95,.95);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}to{-webkit-transform:perspective(400px);transform:perspective(400px);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}}@keyframes flip{from{-webkit-transform:perspective(400px) rotate3d(0,1,0,-360deg);transform:perspective(400px) rotate3d(0,1,0,-360deg);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}40%{-webkit-transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-190deg);transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-190deg);-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}50%{-webkit-transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-170deg);transform:perspective(400px) translate3d(0,0,150px) rotate3d(0,1,0,-170deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}80%{-webkit-transform:perspective(400px) scale3d(.95,.95,.95);transform:perspective(400px) scale3d(.95,.95,.95);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}to{-webkit-transform:perspective(400px);transform:perspective(400px);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}}.animated.flip{-webkit-backface-visibility:visible;backface-visibility:visible;-webkit-animation-name:flip;animation-name:flip}@-webkit-keyframes flipInX{from{-webkit-transform:perspective(400px) rotate3d(1,0,0,90deg);transform:perspective(400px) rotate3d(1,0,0,90deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;opacity:0}40%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-20deg);transform:perspective(400px) rotate3d(1,0,0,-20deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}60%{-webkit-transform:perspective(400px) rotate3d(1,0,0,10deg);transform:perspective(400px) rotate3d(1,0,0,10deg);opacity:1}80%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-5deg);transform:perspective(400px) rotate3d(1,0,0,-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}@keyframes flipInX{from{-webkit-transform:perspective(400px) rotate3d(1,0,0,90deg);transform:perspective(400px) rotate3d(1,0,0,90deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;opacity:0}40%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-20deg);transform:perspective(400px) rotate3d(1,0,0,-20deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}60%{-webkit-transform:perspective(400px) rotate3d(1,0,0,10deg);transform:perspective(400px) rotate3d(1,0,0,10deg);opacity:1}80%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-5deg);transform:perspective(400px) rotate3d(1,0,0,-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}.flipInX{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;-webkit-animation-name:flipInX;animation-name:flipInX}@-webkit-keyframes flipInY{from{-webkit-transform:perspective(400px) rotate3d(0,1,0,90deg);transform:perspective(400px) rotate3d(0,1,0,90deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;opacity:0}40%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-20deg);transform:perspective(400px) rotate3d(0,1,0,-20deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}60%{-webkit-transform:perspective(400px) rotate3d(0,1,0,10deg);transform:perspective(400px) rotate3d(0,1,0,10deg);opacity:1}80%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-5deg);transform:perspective(400px) rotate3d(0,1,0,-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}@keyframes flipInY{from{-webkit-transform:perspective(400px) rotate3d(0,1,0,90deg);transform:perspective(400px) rotate3d(0,1,0,90deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;opacity:0}40%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-20deg);transform:perspective(400px) rotate3d(0,1,0,-20deg);-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}60%{-webkit-transform:perspective(400px) rotate3d(0,1,0,10deg);transform:perspective(400px) rotate3d(0,1,0,10deg);opacity:1}80%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-5deg);transform:perspective(400px) rotate3d(0,1,0,-5deg)}to{-webkit-transform:perspective(400px);transform:perspective(400px)}}.flipInY{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;-webkit-animation-name:flipInY;animation-name:flipInY}@-webkit-keyframes flipOutX{from{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-20deg);transform:perspective(400px) rotate3d(1,0,0,-20deg);opacity:1}to{-webkit-transform:perspective(400px) rotate3d(1,0,0,90deg);transform:perspective(400px) rotate3d(1,0,0,90deg);opacity:0}}@keyframes flipOutX{from{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{-webkit-transform:perspective(400px) rotate3d(1,0,0,-20deg);transform:perspective(400px) rotate3d(1,0,0,-20deg);opacity:1}to{-webkit-transform:perspective(400px) rotate3d(1,0,0,90deg);transform:perspective(400px) rotate3d(1,0,0,90deg);opacity:0}}.flipOutX{-webkit-animation-name:flipOutX;animation-name:flipOutX;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@-webkit-keyframes flipOutY{from{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-15deg);transform:perspective(400px) rotate3d(0,1,0,-15deg);opacity:1}to{-webkit-transform:perspective(400px) rotate3d(0,1,0,90deg);transform:perspective(400px) rotate3d(0,1,0,90deg);opacity:0}}@keyframes flipOutY{from{-webkit-transform:perspective(400px);transform:perspective(400px)}30%{-webkit-transform:perspective(400px) rotate3d(0,1,0,-15deg);transform:perspective(400px) rotate3d(0,1,0,-15deg);opacity:1}to{-webkit-transform:perspective(400px) rotate3d(0,1,0,90deg);transform:perspective(400px) rotate3d(0,1,0,90deg);opacity:0}}.flipOutY{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;-webkit-animation-name:flipOutY;animation-name:flipOutY}@-webkit-keyframes lightSpeedIn{from{-webkit-transform:translate3d(100%,0,0) skewX(-30deg);transform:translate3d(100%,0,0) skewX(-30deg);opacity:0}60%{-webkit-transform:skewX(20deg);transform:skewX(20deg);opacity:1}80%{-webkit-transform:skewX(-5deg);transform:skewX(-5deg);opacity:1}to{-webkit-transform:none;transform:none;opacity:1}}@keyframes lightSpeedIn{from{-webkit-transform:translate3d(100%,0,0) skewX(-30deg);transform:translate3d(100%,0,0) skewX(-30deg);opacity:0}60%{-webkit-transform:skewX(20deg);transform:skewX(20deg);opacity:1}80%{-webkit-transform:skewX(-5deg);transform:skewX(-5deg);opacity:1}to{-webkit-transform:none;transform:none;opacity:1}}.lightSpeedIn{-webkit-animation-name:lightSpeedIn;animation-name:lightSpeedIn;-webkit-animation-timing-function:ease-out;animation-timing-function:ease-out}@-webkit-keyframes lightSpeedOut{from{opacity:1}to{-webkit-transform:translate3d(100%,0,0) skewX(30deg);transform:translate3d(100%,0,0) skewX(30deg);opacity:0}}@keyframes lightSpeedOut{from{opacity:1}to{-webkit-transform:translate3d(100%,0,0) skewX(30deg);transform:translate3d(100%,0,0) skewX(30deg);opacity:0}}.lightSpeedOut{-webkit-animation-name:lightSpeedOut;animation-name:lightSpeedOut;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in}@-webkit-keyframes rotateIn{from{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:rotate3d(0,0,1,-200deg);transform:rotate3d(0,0,1,-200deg);opacity:0}to{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:none;transform:none;opacity:1}}@keyframes rotateIn{from{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:rotate3d(0,0,1,-200deg);transform:rotate3d(0,0,1,-200deg);opacity:0}to{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:none;transform:none;opacity:1}}.rotateIn{-webkit-animation-name:rotateIn;animation-name:rotateIn}@-webkit-keyframes rotateInDownLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:none;transform:none;opacity:1}}@keyframes rotateInDownLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:none;transform:none;opacity:1}}.rotateInDownLeft{-webkit-animation-name:rotateInDownLeft;animation-name:rotateInDownLeft}@-webkit-keyframes rotateInDownRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:none;transform:none;opacity:1}}@keyframes rotateInDownRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:none;transform:none;opacity:1}}.rotateInDownRight{-webkit-animation-name:rotateInDownRight;animation-name:rotateInDownRight}@-webkit-keyframes rotateInUpLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:none;transform:none;opacity:1}}@keyframes rotateInUpLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:none;transform:none;opacity:1}}.rotateInUpLeft{-webkit-animation-name:rotateInUpLeft;animation-name:rotateInUpLeft}@-webkit-keyframes rotateInUpRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,-90deg);transform:rotate3d(0,0,1,-90deg);opacity:0}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:none;transform:none;opacity:1}}@keyframes rotateInUpRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,-90deg);transform:rotate3d(0,0,1,-90deg);opacity:0}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:none;transform:none;opacity:1}}.rotateInUpRight{-webkit-animation-name:rotateInUpRight;animation-name:rotateInUpRight}@-webkit-keyframes rotateOut{from{-webkit-transform-origin:center;transform-origin:center;opacity:1}to{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:rotate3d(0,0,1,200deg);transform:rotate3d(0,0,1,200deg);opacity:0}}@keyframes rotateOut{from{-webkit-transform-origin:center;transform-origin:center;opacity:1}to{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:rotate3d(0,0,1,200deg);transform:rotate3d(0,0,1,200deg);opacity:0}}.rotateOut{-webkit-animation-name:rotateOut;animation-name:rotateOut}@-webkit-keyframes rotateOutDownLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;opacity:1}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}}@keyframes rotateOutDownLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;opacity:1}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,45deg);transform:rotate3d(0,0,1,45deg);opacity:0}}.rotateOutDownLeft{-webkit-animation-name:rotateOutDownLeft;animation-name:rotateOutDownLeft}@-webkit-keyframes rotateOutDownRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;opacity:1}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}}@keyframes rotateOutDownRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;opacity:1}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}}.rotateOutDownRight{-webkit-animation-name:rotateOutDownRight;animation-name:rotateOutDownRight}@-webkit-keyframes rotateOutUpLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;opacity:1}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}}@keyframes rotateOutUpLeft{from{-webkit-transform-origin:left bottom;transform-origin:left bottom;opacity:1}to{-webkit-transform-origin:left bottom;transform-origin:left bottom;-webkit-transform:rotate3d(0,0,1,-45deg);transform:rotate3d(0,0,1,-45deg);opacity:0}}.rotateOutUpLeft{-webkit-animation-name:rotateOutUpLeft;animation-name:rotateOutUpLeft}@-webkit-keyframes rotateOutUpRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;opacity:1}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,90deg);transform:rotate3d(0,0,1,90deg);opacity:0}}@keyframes rotateOutUpRight{from{-webkit-transform-origin:right bottom;transform-origin:right bottom;opacity:1}to{-webkit-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate3d(0,0,1,90deg);transform:rotate3d(0,0,1,90deg);opacity:0}}.rotateOutUpRight{-webkit-animation-name:rotateOutUpRight;animation-name:rotateOutUpRight}@-webkit-keyframes hinge{0%{-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}20%,60%{-webkit-transform:rotate3d(0,0,1,80deg);transform:rotate3d(0,0,1,80deg);-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}40%,80%{-webkit-transform:rotate3d(0,0,1,60deg);transform:rotate3d(0,0,1,60deg);-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;opacity:1}to{-webkit-transform:translate3d(0,700px,0);transform:translate3d(0,700px,0);opacity:0}}@keyframes hinge{0%{-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}20%,60%{-webkit-transform:rotate3d(0,0,1,80deg);transform:rotate3d(0,0,1,80deg);-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}40%,80%{-webkit-transform:rotate3d(0,0,1,60deg);transform:rotate3d(0,0,1,60deg);-webkit-transform-origin:top left;transform-origin:top left;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;opacity:1}to{-webkit-transform:translate3d(0,700px,0);transform:translate3d(0,700px,0);opacity:0}}.hinge{-webkit-animation-name:hinge;animation-name:hinge}@-webkit-keyframes rollIn{from{opacity:0;-webkit-transform:translate3d(-100%,0,0) rotate3d(0,0,1,-120deg);transform:translate3d(-100%,0,0) rotate3d(0,0,1,-120deg)}to{opacity:1;-webkit-transform:none;transform:none}}@keyframes rollIn{from{opacity:0;-webkit-transform:translate3d(-100%,0,0) rotate3d(0,0,1,-120deg);transform:translate3d(-100%,0,0) rotate3d(0,0,1,-120deg)}to{opacity:1;-webkit-transform:none;transform:none}}.rollIn{-webkit-animation-name:rollIn;animation-name:rollIn}@-webkit-keyframes rollOut{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(100%,0,0) rotate3d(0,0,1,120deg);transform:translate3d(100%,0,0) rotate3d(0,0,1,120deg)}}@keyframes rollOut{from{opacity:1}to{opacity:0;-webkit-transform:translate3d(100%,0,0) rotate3d(0,0,1,120deg);transform:translate3d(100%,0,0) rotate3d(0,0,1,120deg)}}.rollOut{-webkit-animation-name:rollOut;animation-name:rollOut}@-webkit-keyframes zoomIn{from{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes zoomIn{from{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}50%{opacity:1}}.zoomIn{-webkit-animation-name:zoomIn;animation-name:zoomIn}@-webkit-keyframes zoomInDown{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,-1000px,0);transform:scale3d(.1,.1,.1) translate3d(0,-1000px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,60px,0);transform:scale3d(.475,.475,.475) translate3d(0,60px,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomInDown{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,-1000px,0);transform:scale3d(.1,.1,.1) translate3d(0,-1000px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,60px,0);transform:scale3d(.475,.475,.475) translate3d(0,60px,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInDown{-webkit-animation-name:zoomInDown;animation-name:zoomInDown}@-webkit-keyframes zoomInLeft{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(-1000px,0,0);transform:scale3d(.1,.1,.1) translate3d(-1000px,0,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(10px,0,0);transform:scale3d(.475,.475,.475) translate3d(10px,0,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomInLeft{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(-1000px,0,0);transform:scale3d(.1,.1,.1) translate3d(-1000px,0,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(10px,0,0);transform:scale3d(.475,.475,.475) translate3d(10px,0,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInLeft{-webkit-animation-name:zoomInLeft;animation-name:zoomInLeft}@-webkit-keyframes zoomInRight{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(1000px,0,0);transform:scale3d(.1,.1,.1) translate3d(1000px,0,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(-10px,0,0);transform:scale3d(.475,.475,.475) translate3d(-10px,0,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomInRight{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(1000px,0,0);transform:scale3d(.1,.1,.1) translate3d(1000px,0,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(-10px,0,0);transform:scale3d(.475,.475,.475) translate3d(-10px,0,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInRight{-webkit-animation-name:zoomInRight;animation-name:zoomInRight}@-webkit-keyframes zoomInUp{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,1000px,0);transform:scale3d(.1,.1,.1) translate3d(0,1000px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomInUp{from{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,1000px,0);transform:scale3d(.1,.1,.1) translate3d(0,1000px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInUp{-webkit-animation-name:zoomInUp;animation-name:zoomInUp}@-webkit-keyframes zoomOut{from{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}@keyframes zoomOut{from{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}.zoomOut{-webkit-animation-name:zoomOut;animation-name:zoomOut}@-webkit-keyframes zoomOutDown{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,2000px,0);transform:scale3d(.1,.1,.1) translate3d(0,2000px,0);-webkit-transform-origin:center bottom;transform-origin:center bottom;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomOutDown{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,2000px,0);transform:scale3d(.1,.1,.1) translate3d(0,2000px,0);-webkit-transform-origin:center bottom;transform-origin:center bottom;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomOutDown{-webkit-animation-name:zoomOutDown;animation-name:zoomOutDown}@-webkit-keyframes zoomOutLeft{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(42px,0,0);transform:scale3d(.475,.475,.475) translate3d(42px,0,0)}to{opacity:0;-webkit-transform:scale(.1) translate3d(-2000px,0,0);transform:scale(.1) translate3d(-2000px,0,0);-webkit-transform-origin:left center;transform-origin:left center}}@keyframes zoomOutLeft{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(42px,0,0);transform:scale3d(.475,.475,.475) translate3d(42px,0,0)}to{opacity:0;-webkit-transform:scale(.1) translate3d(-2000px,0,0);transform:scale(.1) translate3d(-2000px,0,0);-webkit-transform-origin:left center;transform-origin:left center}}.zoomOutLeft{-webkit-animation-name:zoomOutLeft;animation-name:zoomOutLeft}@-webkit-keyframes zoomOutRight{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(-42px,0,0);transform:scale3d(.475,.475,.475) translate3d(-42px,0,0)}to{opacity:0;-webkit-transform:scale(.1) translate3d(2000px,0,0);transform:scale(.1) translate3d(2000px,0,0);-webkit-transform-origin:right center;transform-origin:right center}}@keyframes zoomOutRight{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(-42px,0,0);transform:scale3d(.475,.475,.475) translate3d(-42px,0,0)}to{opacity:0;-webkit-transform:scale(.1) translate3d(2000px,0,0);transform:scale(.1) translate3d(2000px,0,0);-webkit-transform-origin:right center;transform-origin:right center}}.zoomOutRight{-webkit-animation-name:zoomOutRight;animation-name:zoomOutRight}@-webkit-keyframes zoomOutUp{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,60px,0);transform:scale3d(.475,.475,.475) translate3d(0,60px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,-2000px,0);transform:scale3d(.1,.1,.1) translate3d(0,-2000px,0);-webkit-transform-origin:center bottom;transform-origin:center bottom;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}@keyframes zoomOutUp{40%{opacity:1;-webkit-transform:scale3d(.475,.475,.475) translate3d(0,60px,0);transform:scale3d(.475,.475,.475) translate3d(0,60px,0);-webkit-animation-timing-function:cubic-bezier(.55,.055,.675,.19);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;-webkit-transform:scale3d(.1,.1,.1) translate3d(0,-2000px,0);transform:scale3d(.1,.1,.1) translate3d(0,-2000px,0);-webkit-transform-origin:center bottom;transform-origin:center bottom;-webkit-animation-timing-function:cubic-bezier(.175,.885,.32,1);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomOutUp{-webkit-animation-name:zoomOutUp;animation-name:zoomOutUp}@-webkit-keyframes slideInDown{from{-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInDown{from{-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.slideInDown{-webkit-animation-name:slideInDown;animation-name:slideInDown}@-webkit-keyframes slideInLeft{from{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInLeft{from{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.slideInLeft{-webkit-animation-name:slideInLeft;animation-name:slideInLeft}@-webkit-keyframes slideInRight{from{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInRight{from{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.slideInRight{-webkit-animation-name:slideInRight;animation-name:slideInRight}@-webkit-keyframes slideInUp{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInUp{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.slideInUp{-webkit-animation-name:slideInUp;animation-name:slideInUp}@-webkit-keyframes slideOutDown{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes slideOutDown{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}.slideOutDown{-webkit-animation-name:slideOutDown;animation-name:slideOutDown}@-webkit-keyframes slideOutLeft{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}@keyframes slideOutLeft{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.slideOutLeft{-webkit-animation-name:slideOutLeft;animation-name:slideOutLeft}@-webkit-keyframes slideOutRight{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}@keyframes slideOutRight{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}.slideOutRight{-webkit-animation-name:slideOutRight;animation-name:slideOutRight}@-webkit-keyframes slideOutUp{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}@keyframes slideOutUp{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}.slideOutUp{-webkit-animation-name:slideOutUp;animation-name:slideOutUp}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/css/colors/blue.css",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n@import url(\"https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700\");\n/*Theme Colors*/\n/*bootstrap Color*/\n/*Light colors*/\n/*Normal Color*/\n/*Extra Variable*/\n/*Preloader*/\n.preloader {\n  width: 100%;\n  height: 100%;\n  top: 0px;\n  position: fixed;\n  z-index: 99999;\n  background: #fff; }\n  .preloader .cssload-speeding-wheel {\n    position: absolute;\n    top: calc(50% - 3.5px);\n    left: calc(50% - 3.5px); }\n\n/*******************\n/*Top bar\n*******************/\n.topbar {\n  background: #1e88e5; }\n  .topbar .navbar-header {\n    background: rgba(0, 0, 0, 0.05); }\n  .topbar .top-navbar .navbar-header .navbar-brand .dark-logo {\n    display: none; }\n  .topbar .top-navbar .navbar-header .navbar-brand .light-logo {\n    display: inline-block;\n    color: rgba(255, 255, 255, 0.8); }\n  .topbar .navbar-light .navbar-nav .nav-item > a.nav-link {\n    color: #ffffff !important; }\n    .topbar .navbar-light .navbar-nav .nav-item > a.nav-link:hover, .topbar .navbar-light .navbar-nav .nav-item > a.nav-link:focus {\n      color: rgba(255, 255, 255, 0.8) !important; }\n\n/*******************\n/*General Elements\n*******************/\na.link:hover, a.link:focus {\n  color: #1e88e5 !important; }\n\n.bg-theme {\n  background-color: #1e88e5 !important; }\n\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n  background-color: #1e88e5;\n  border-color: #1e88e5; }\n\n.right-sidebar .rpanel-title {\n  background: #1e88e5; }\n\n.stylish-table tbody tr:hover, .stylish-table tbody tr.active {\n  border-left: 4px solid #1e88e5; }\n\n.text-themecolor {\n  color: #1e88e5 !important; }\n\n.profile-tab li a.nav-link.active,\n.customtab li a.nav-link.active {\n  border-bottom: 2px solid #1e88e5;\n  color: #1e88e5; }\n\n.profile-tab li a.nav-link:hover,\n.customtab li a.nav-link:hover {\n  color: #1e88e5; }\n\n/*******************\n/*Buttons\n*******************/\n.btn-themecolor,\n.btn-themecolor.disabled {\n  background: #1e88e5;\n  color: #ffffff;\n  border: 1px solid #1e88e5; }\n  .btn-themecolor:hover,\n  .btn-themecolor.disabled:hover {\n    background: #1e88e5;\n    opacity: 0.7;\n    border: 1px solid #1e88e5; }\n  .btn-themecolor.active, .btn-themecolor:focus,\n  .btn-themecolor.disabled.active,\n  .btn-themecolor.disabled:focus {\n    background: #028ee1; }\n\n/*******************\n/*sidebar navigation\n*******************/\n.sidebar-nav {\n  background: #fff; }\n  .sidebar-nav ul li a {\n    color: #607d8b; }\n    .sidebar-nav ul li a.active, .sidebar-nav ul li a:hover {\n      color: #26c6da; }\n    .sidebar-nav ul li a.active {\n      color: #263238; }\n  .sidebar-nav ul li.nav-small-cap {\n    color: #99abb4; }\n  .sidebar-nav > ul > li.active > a,\n  .sidebar-nav > ul > li.active:hover > a {\n    color: #ffffff;\n    background: #26c6da; }\n    .sidebar-nav > ul > li.active > a i,\n    .sidebar-nav > ul > li.active:hover > a i {\n      color: #ffffff; }\n    .sidebar-nav > ul > li.active > a:after,\n    .sidebar-nav > ul > li.active:hover > a:after {\n      border-color: #ffffff; }\n  .sidebar-nav > ul > li > a.active i, .sidebar-nav > ul > li > a:hover i {\n    color: #26c6da; }\n  .sidebar-nav > ul > li > a i {\n    color: #99abb4; }\n  .sidebar-nav > ul > li > a.active {\n    font-weight: 400;\n    background: #ffffff;\n    color: #1e88e5; }\n\n.card-no-border .sidebar-nav > ul > li > a.active {\n  color: #ffffff;\n  background: #26c6da; }\n  .card-no-border .sidebar-nav > ul > li > a.active i {\n    color: #ffffff; }\n  .card-no-border .sidebar-nav > ul > li > a.active:after {\n    border-color: #ffffff; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/css/spinners.css",
    "content": "\n\n.preloader{\n  position: relative;\n  margin: 0 auto;\n  width: 100px;\n}\n.preloader:before{\n    content: '';\n    display: block;\n    padding-top: 100%;\n}\n.circular {\n  animation: rotate 2s linear infinite;\n  height: 50px;\n  transform-origin: center center;\n  width: 50px;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  right: 0;\n  margin: auto;\n}\n.path {\n  stroke-dasharray: 1, 200;\n  stroke-dashoffset: 0;\n  animation: dash 1.5s ease-in-out infinite, color 6s ease-in-out infinite;\n  stroke-linecap: round;\n}\n@keyframes rotate {\n  100% {\n    transform: rotate(360deg);\n  }\n}\n\n@keyframes dash {\n  0% {\n    stroke-dasharray: 1, 200;\n    stroke-dashoffset: 0;\n  }\n  50% {\n    stroke-dasharray: 89, 200;\n    stroke-dashoffset: -35px;\n  }\n  100% {\n    stroke-dasharray: 89, 200;\n    stroke-dashoffset: -124px;\n  }\n}\n\n@keyframes color {\n  100%,\n  0% {\n    stroke: #d62d20;\n  }\n  40% {\n    stroke: #0057e7;\n  }\n  66% {\n    stroke: #008744;\n  }\n  80%,\n  90% {\n    stroke: #ffa700;\n  }\n}\n.bd-booticon{display:block;width:9rem;height:9rem;font-size:6.5rem;line-height:9rem;color:#fff;text-align:center;cursor:default;background-color:#563d7c;border-radius:15%}.bd-booticon.inverse{color:#563d7c;background-color:#fff}.bd-booticon.outline{background-color:transparent;border:1px solid #cdbfe3}.bd-navbar .navbar-nav .nav-link{color:#8e869d}.bd-navbar .navbar-nav .nav-link.active,.bd-navbar .navbar-nav .nav-link:focus,.bd-navbar .navbar-nav .nav-link:hover{color:#292b2c;background-color:transparent}.bd-navbar .navbar-nav .nav-link.active{font-weight:500;color:#040404}.bd-navbar .dropdown-menu{font-size:inherit}.bd-masthead{position:relative;padding:3rem 15px 2rem;color:#cdbfe3;text-align:center;background-image:-webkit-linear-gradient(315deg,#271b38,#563d7c,#7952b3);background-image:-o-linear-gradient(315deg,#271b38,#563d7c,#7952b3);background-image:linear-gradient(135deg,#271b38,#563d7c,#7952b3)}.bd-masthead .bd-booticon{margin:0 auto 2rem;color:#cdbfe3;border-color:#cdbfe3}.bd-masthead h1{font-weight:300;line-height:1}.bd-masthead .lead{margin-right:auto;margin-bottom:2rem;margin-left:auto;font-size:1.25rem;color:#fff}.bd-masthead .version{margin-top:-1rem;margin-bottom:2rem}.bd-masthead .btn{width:100%;padding:1rem 2rem;font-size:1.25rem;font-weight:500;color:#ffe484;border-color:#ffe484}.bd-masthead .btn:hover{color:#2a2730;background-color:#ffe484;border-color:#ffe484}.bd-masthead .carbonad{margin-bottom:-2rem!important}@media (min-width:576px){.bd-masthead{padding-top:8rem;padding-bottom:2rem}.bd-masthead .btn{width:auto}.bd-masthead .carbonad{margin-bottom:0!important}}@media (min-width:768px){.bd-masthead{padding-bottom:4rem}.bd-masthead .bd-header{margin-bottom:4rem}.bd-masthead h1{font-size:4rem}.bd-masthead .lead{font-size:1.5rem}.bd-masthead .carbonad{margin-top:3rem!important}}@media (min-width:992px){.bd-masthead .lead{width:85%;font-size:2rem}}.bd-featurette{padding-top:3rem;padding-bottom:3rem;font-size:1rem;line-height:1.5;color:#555;text-align:center;background-color:#fff;border-top:1px solid #eee}.bd-featurette .highlight{text-align:left}.bd-featurette .lead{margin-right:auto;margin-bottom:2rem;margin-left:auto;font-size:1rem;text-align:center}@media (min-width:576px){.bd-featurette{text-align:left}}@media (min-width:768px){.bd-featurette .col-sm-6:first-child{padding-right:45px}.bd-featurette .col-sm-6:last-child{padding-left:45px}}.bd-featurette-title{margin-bottom:.5rem;font-size:2rem;font-weight:400;color:#333;text-align:center}.half-rule{width:6rem;margin:2.5rem auto}@media (min-width:576px){.half-rule{margin-right:0;margin-left:0}}.bd-featurette h4{margin-top:1rem;margin-bottom:.5rem;font-weight:400;color:#333}.bd-featurette-img{display:block;margin-bottom:1.25rem;color:#333}.bd-featurette-img:hover{color:#0275d8;text-decoration:none}.bd-featurette-img img{display:block;margin-bottom:1rem}@media (min-width:480px){.bd-featurette .img-fluid{margin-top:2rem}}@media (min-width:768px){.bd-featurette{padding-top:6rem;padding-bottom:6rem}.bd-featurette-title{font-size:2.5rem}.bd-featurette-title+.lead{font-size:1.5rem}.bd-featurette .lead{max-width:80%}.bd-featurette .img-fluid{margin-top:0}}.bd-featured-sites{margin-right:-1px;margin-left:-1px}.bd-featured-sites .col-6{padding:1px}.bd-featured-sites .img-fluid{margin-top:0}@media (min-width:768px){.bd-featured-sites .col-sm-3:first-child img{border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.bd-featured-sites .col-sm-3:last-child img{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}}#carbonads{display:block;padding:15px 15px 15px 160px;margin:50px -15px 0;overflow:hidden;font-size:13px;line-height:1.5;text-align:left;border:solid #866ab3;border-width:1px 0 0}#carbonads a{color:#fff;text-decoration:none}@media (min-width:576px){#carbonads{max-width:330px;margin:50px auto 0;border-width:1px;border-radius:4px}}@media (min-width:992px){#carbonads{position:absolute;top:0;right:15px;margin-top:0}.bd-masthead #carbonads{position:static}}.carbon-img{float:left;margin-left:-145px}.carbon-poweredby{display:block;color:#cdbfe3!important}.bd-content>table{display:block;width:100%;max-width:100%;margin-bottom:1rem;overflow-y:auto}.bd-content>table>tbody>tr>td,.bd-content>table>tbody>tr>th,.bd-content>table>tfoot>tr>td,.bd-content>table>tfoot>tr>th,.bd-content>table>thead>tr>td,.bd-content>table>thead>tr>th{padding:.75rem;vertical-align:top;border:1px solid #eceeef}.bd-content>table>tbody>tr>td>p:last-child,.bd-content>table>tbody>tr>th>p:last-child,.bd-content>table>tfoot>tr>td>p:last-child,.bd-content>table>tfoot>tr>th>p:last-child,.bd-content>table>thead>tr>td>p:last-child,.bd-content>table>thead>tr>th>p:last-child{margin-bottom:0}.bd-content>table td:first-child>code{white-space:nowrap}.bd-content>h2:not(:first-child){margin-top:3rem}.bd-content>h3{margin-top:1.5rem}.bd-content>ol li,.bd-content>ul li{margin-bottom:.25rem}@media (min-width:576px){.bd-title{font-size:3rem}.bd-title+p{font-size:1.25rem;font-weight:300}}#markdown-toc>li:first-child{display:none}#markdown-toc ul{padding-left:2rem;margin-top:.25rem;margin-bottom:.25rem}.bd-pageheader{padding:2rem 15px;margin-bottom:1.5rem;color:#cdbfe3;text-align:center;background-color:#563d7c}.bd-pageheader .container{position:relative}.bd-pageheader h1{font-size:3rem;font-weight:400;color:#fff}.bd-pageheader p{margin-bottom:0;font-size:1.25rem;font-weight:300}@media (min-width:576px){.bd-pageheader{padding-top:4rem;padding-bottom:4rem;margin-bottom:3rem;text-align:left}.bd-pageheader .carbonad{margin:2rem 0 0!important}}@media (min-width:768px){.bd-pageheader h1{font-size:4rem}.bd-pageheader p{font-size:1.5rem}}@media (min-width:992px){.bd-pageheader h1,.bd-pageheader p{margin-right:380px}.bd-pageheader .carbonad{position:absolute;top:0;right:.75rem;margin:0!important}}#skippy{display:block;padding:1em;color:#fff;background-color:#563d7c;outline:0}#skippy .skiplink-text{padding:.5em;outline:1px dotted}@media (min-width:768px){.bd-sidebar{padding-left:1rem}}.bd-search{position:relative;margin-bottom:1.5rem}.bd-search .form-control{height:2.45rem;padding-top:.4rem;padding-bottom:.4rem;background-color:#fafafa}.bd-search .form-control:focus{background-color:#fff}.bd-search-results{right:0;display:block;padding:0;overflow:hidden;font-size:.9rem}.bd-search-results:empty{display:none}.bd-search-results .dropdown-item{padding-right:.75rem;padding-left:.75rem}.bd-search-results .dropdown-item:first-child{margin-top:.25rem}.bd-search-results .dropdown-item:last-child{margin-bottom:.25rem}.bd-search-results .no-results{padding:.75rem 1rem;color:#7a7a7a;text-align:center;white-space:normal}.bd-sidenav{display:none}.bd-toc-link{display:block;padding:.25rem .75rem;color:#464a4c}.bd-toc-link:focus,.bd-toc-link:hover{color:#0275d8;text-decoration:none}.active>.bd-toc-link{font-weight:500;color:#292b2c}.active>.bd-sidenav{display:block}.bd-toc-item.active{margin-top:1rem;margin-bottom:1rem}.bd-toc-item:first-child{margin-top:0}.bd-toc-item:last-child{margin-bottom:2rem}.bd-sidebar .nav>li>a{display:block;padding:.25rem .75rem;font-size:90%;color:#99979c}.bd-sidebar .nav>li>a:focus,.bd-sidebar .nav>li>a:hover{color:#0275d8;text-decoration:none;background-color:transparent}.bd-sidebar .nav>.active:focus>a,.bd-sidebar .nav>.active:hover>a,.bd-sidebar .nav>.active>a{font-weight:500;color:#292b2c;background-color:transparent}.bd-footer{padding:4rem 0;margin-top:4rem;font-size:85%;text-align:center;background-color:#f7f7f7}.bd-footer a{font-weight:500;color:#464a4c}.bd-footer a:hover{color:#0275d8}.bd-footer p{margin-bottom:0}@media (min-width:576px){.bd-footer{text-align:left}}.bd-footer-links{padding-left:0;margin-bottom:1rem}.bd-footer-links li{display:inline-block}.bd-footer-links li+li{margin-left:1rem}.bd-example-row .row+.row{margin-top:1rem}.bd-example-row .row>.col,.bd-example-row .row>[class^=col-]{padding-top:.75rem;padding-bottom:.75rem;background-color:rgba(86,61,124,.15);border:1px solid rgba(86,61,124,.2)}.bd-example-row .flex-items-bottom,.bd-example-row .flex-items-middle,.bd-example-row .flex-items-top{min-height:6rem;background-color:rgba(255,0,0,.1)}.bd-example-row-flex-cols .row{min-height:10rem;background-color:rgba(255,0,0,.1)}.bd-highlight{background-color:rgba(86,61,124,.15);border:1px solid rgba(86,61,124,.15)}.bd-example-container{min-width:16rem;max-width:25rem;margin-right:auto;margin-left:auto}.bd-example-container-header{height:3rem;margin-bottom:.5rem;background-color:#daeeff;border-radius:.25rem}.bd-example-container-sidebar{float:right;width:4rem;height:8rem;background-color:#fae3c4;border-radius:.25rem}.bd-example-container-body{height:8rem;margin-right:4.5rem;background-color:#957bbe;border-radius:.25rem}.bd-example-container-fluid{max-width:none}.bd-example{position:relative;padding:1rem;margin:1rem -1rem;border:solid #f7f7f9;border-width:.2rem 0 0}.bd-example::after{display:block;content:\"\";clear:both}@media (min-width:576px){.bd-example{padding:1.5rem;margin-right:0;margin-bottom:0;margin-left:0;border-width:.2rem}}.bd-example+.clipboard+.highlight,.bd-example+.highlight{margin-top:0}.bd-example+p{margin-top:2rem}.bd-example .pos-f-t{position:relative;margin:-1rem}@media (min-width:576px){.bd-example .pos-f-t{margin:-1.5rem}}.bd-example>.form-control+.form-control{margin-top:.5rem}.bd-example>.alert+.alert,.bd-example>.nav+.nav,.bd-example>.navbar+.navbar,.bd-example>.progress+.btn,.bd-example>.progress+.progress{margin-top:1rem}.bd-example>.dropdown-menu:first-child{position:static;display:block}.bd-example>.form-group:last-child{margin-bottom:0}.bd-example>.close{float:none}.bd-example-type .table .type-info{color:#999;vertical-align:middle}.bd-example-type .table td{padding:1rem 0;border-color:#eee}.bd-example-type .table tr:first-child td{border-top:0}.bd-example-type h1,.bd-example-type h2,.bd-example-type h3,.bd-example-type h4,.bd-example-type h5,.bd-example-type h6{margin:0}.bd-example-bg-classes p{padding:1rem}.bd-example>img+img{margin-left:.5rem}.bd-example>.btn-group{margin-top:.25rem;margin-bottom:.25rem}.bd-example>.btn-toolbar+.btn-toolbar{margin-top:.5rem}.bd-example-control-sizing input[type=text]+input[type=text],.bd-example-control-sizing select{margin-top:.5rem}.bd-example-form .input-group{margin-bottom:.5rem}.bd-example>textarea.form-control{resize:vertical}.bd-example>.list-group{max-width:400px}.bd-example .fixed-top,.bd-example .sticky-top{position:static;margin:-1rem -1rem 1rem}.bd-example .fixed-bottom{position:static;margin:1rem -1rem -1rem}@media (min-width:576px){.bd-example .fixed-top,.bd-example .sticky-top{margin:-1.5rem -1.5rem 1rem}.bd-example .fixed-bottom{margin:1rem -1.5rem -1.5rem}}.bd-example .pagination{margin-top:.5rem;margin-bottom:.5rem}.bd-example-modal{background-color:#fafafa}.bd-example-modal .modal{position:relative;top:auto;right:auto;bottom:auto;left:auto;z-index:1;display:block}.bd-example-modal .modal-dialog{left:auto;margin-right:auto;margin-left:auto}.bd-example-tabs .nav-tabs{margin-bottom:1rem}.bd-example-tooltips{text-align:center}.bd-example-tooltips>.btn{margin-top:.25rem;margin-bottom:.25rem}.bd-example-popover-static{padding-bottom:1.5rem;background-color:#f9f9f9}.bd-example-popover-static .popover{position:relative;display:block;float:left;width:260px;margin:1.25rem}.tooltip-demo a{white-space:nowrap}.bd-example-tooltip-static .tooltip{position:relative;display:inline-block;margin:10px 20px;opacity:1}.scrollspy-example{position:relative;height:200px;margin-top:.5rem;overflow:auto}.bd-example>.bg-danger:not(.navbar),.bd-example>.bg-faded:not(.navbar),.bd-example>.bg-info:not(.navbar),.bd-example>.bg-inverse:not(.navbar),.bd-example>.bg-primary:not(.navbar),.bd-example>.bg-success:not(.navbar),.bd-example>.bg-warning:not(.navbar){padding:.5rem;margin-top:.5rem;margin-bottom:.5rem}.bd-example-border-utils [class^=border-]{display:inline-block;width:6rem;height:6rem;margin:.25rem;background-color:#f5f5f5;border:1px solid}.highlight{padding:1rem;margin:1rem -15px;background-color:#f7f7f9;-ms-overflow-style:-ms-autohiding-scrollbar}@media (min-width:576px){.highlight{padding:1.5rem;margin-right:0;margin-left:0}}.highlight pre{padding:0;margin-top:0;margin-bottom:0;background-color:transparent;border:0}.highlight pre code{font-size:inherit;color:#292b2c}.table-responsive .highlight pre{white-space:normal}.bd-table th small,.responsive-utilities th small{display:block;font-weight:400;color:#999}.responsive-utilities tbody th{font-weight:400}.responsive-utilities td{text-align:center}.responsive-utilities .is-visible{color:#468847;background-color:#dff0d8!important}.responsive-utilities .is-hidden{color:#ccc;background-color:#f9f9f9!important}.responsive-utilities-test{margin-top:.25rem}.responsive-utilities-test .col-6{margin-top:.5rem;margin-bottom:.5rem}.responsive-utilities-test span{display:block;padding:1rem .5rem;font-size:1rem;font-weight:700;line-height:1.1;text-align:center;border-radius:.25rem}.hidden-on .col-6>.not-visible,.visible-on .col-6>.not-visible{color:#999;border:1px solid #ddd}.hidden-on .col-6 .visible,.visible-on .col-6 .visible{color:#468847;background-color:#dff0d8;border:1px solid #d6e9c6}@media (max-width:575px){.hidden-xs-only{display:none!important}}@media (min-width:576px) and (max-width:767px){.hidden-sm-only{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-md-only{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-lg-only{display:none!important}}@media (min-width:1200px){.hidden-xl-only{display:none!important}}.btn-bs{font-weight:500;color:#7952b3;border-color:#7952b3}.btn-bs:active,.btn-bs:focus,.btn-bs:hover{color:#fff;background-color:#7952b3;border-color:#7952b3}.bd-callout{padding:1.25rem;margin-top:1.25rem;margin-bottom:1.25rem;border:1px solid #eee;border-left-width:.25rem;border-radius:.25rem}.bd-callout h4{margin-top:0;margin-bottom:.25rem}.bd-callout p:last-child{margin-bottom:0}.bd-callout code{border-radius:.25rem}.bd-callout+.bd-callout{margin-top:-.25rem}.bd-callout-info{border-left-color:#5bc0de}.bd-callout-info h4{color:#5bc0de}.bd-callout-warning{border-left-color:#f0ad4e}.bd-callout-warning h4{color:#f0ad4e}.bd-callout-danger{border-left-color:#d9534f}.bd-callout-danger h4{color:#d9534f}.bd-examples .img-thumbnail{margin-bottom:.75rem}.bd-examples h4{margin-bottom:.25rem}.bd-examples p{margin-bottom:1.25rem}@media (max-width:480px){.bd-examples{margin-right:-.75rem;margin-left:-.75rem}.bd-examples>[class^=col-]{padding-right:.75rem;padding-left:.75rem}}.bd-team{margin-bottom:1.5rem}.bd-team .team-member{line-height:2rem;color:#555}.bd-team .team-member:hover{color:#333;text-decoration:none}.bd-team .github-btn{float:right;width:180px;height:1.25rem;margin-top:.25rem;border:0}.bd-team img{float:left;width:2rem;margin-right:.5rem;border-radius:.25rem}.bd-browser-bugs td p{margin-bottom:0}.bd-browser-bugs th:first-child{width:18%}.bd-brand-logos{display:table;width:100%;margin-bottom:1rem;overflow:hidden;color:#563d7c;background-color:#f9f9f9;border-radius:.25rem}.bd-brand-item{padding:4rem 0;text-align:center}.bd-brand-item+.bd-brand-item{border-top:1px solid #fff}.bd-brand-logos .inverse{color:#fff;background-color:#563d7c}.bd-brand-item h1,.bd-brand-item h3{margin-top:0;margin-bottom:0}.bd-brand-item .bd-booticon{margin-right:auto;margin-left:auto}@media (min-width:768px){.bd-brand-item{display:table-cell;width:1%}.bd-brand-item+.bd-brand-item{border-top:0;border-left:1px solid #fff}.bd-brand-item h1{font-size:4rem}}.color-swatches{margin:0 -5px;overflow:hidden}.color-swatch{float:left;width:4rem;height:4rem;margin-right:.25rem;margin-left:.25rem;border-radius:.25rem}@media (min-width:768px){.color-swatch{width:6rem;height:6rem}}.color-swatches .bd-purple{background-color:#563d7c}.color-swatches .bd-purple-light{background-color:#cdbfe3}.color-swatches .bd-purple-lighter{background-color:#e5e1ea}.color-swatches .bd-gray{background-color:#f9f9f9}.bd-clipboard{position:relative;display:none;float:right}.bd-clipboard+.highlight{margin-top:0}.btn-clipboard{position:absolute;top:.5rem;right:.5rem;z-index:10;display:block;padding:.25rem .5rem;font-size:75%;color:#818a91;cursor:pointer;background-color:transparent;border-radius:.25rem}.btn-clipboard:hover{color:#fff;background-color:#027de7}@media (min-width:768px){.bd-clipboard{display:block}}.hll{background-color:#ffc}.c{color:#999}.k{color:#069}.o{color:#555}.cm{color:#999}.cp{color:#099}.c1{color:#999}.cs{color:#999}.gd{background-color:#fcc;border:1px solid #c00}.ge{font-style:italic}.gr{color:red}.gh{color:#030}.gi{background-color:#cfc;border:1px solid #0c0}.go{color:#aaa}.gp{color:#009}.gu{color:#030}.gt{color:#9c6}.kc{color:#069}.kd{color:#069}.kn{color:#069}.kp{color:#069}.kr{color:#069}.kt{color:#078}.m{color:#f60}.s{color:#d44950}.na{color:#4f9fcf}.nb{color:#366}.nc{color:#0a8}.no{color:#360}.nd{color:#99f}.ni{color:#999}.ne{color:#c00}.nf{color:#c0f}.nl{color:#99f}.nn{color:#0cf}.nt{color:#2f6f9f}.nv{color:#033}.ow{color:#000}.w{color:#bbb}.mf{color:#f60}.mh{color:#f60}.mi{color:#f60}.mo{color:#f60}.sb{color:#c30}.sc{color:#c30}.sd{font-style:italic;color:#c30}.s2{color:#c30}.se{color:#c30}.sh{color:#c30}.si{color:#a00}.sx{color:#c30}.sr{color:#3aa}.s1{color:#c30}.ss{color:#fc3}.bp{color:#366}.vc{color:#033}.vg{color:#033}.vi{color:#033}.il{color:#f60}.css .nt+.nt,.css .o,.css .o+.nt{color:#999}.language-bash::before{color:#009;content:\"$ \";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.language-powershell::before{color:#009;content:\"PM> \";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.anchorjs-link{color:inherit}@media (max-width:480px){.anchorjs-link{display:none}}:hover>.anchorjs-link{opacity:.75;-webkit-transition:color .16s linear;-o-transition:color .16s linear;transition:color .16s linear}.anchorjs-link:focus,:hover>.anchorjs-link:hover{text-decoration:none;opacity:1}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/css/style.css",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/**\n * Table Of Content\n *\n * \t1. Globals\n *\t2. Headers\n *\t3. Navigations\n *\t4. Banners\n *\t5. Footers\n *\t6. app\n *\t7. Widgets\n *\t8. Custom Templates\n */\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n@import url(\"https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700\");\n/*Theme Colors*/\n/*bootstrap Color*/\n/*Light colors*/\n/*Normal Color*/\n/*Extra Variable*/\n/*Preloader*/\n@import url(../scss/icons/font-awesome/css/font-awesome.min.css);\n@import url(../scss/icons/simple-line-icons/css/simple-line-icons.css);\n@import url(../scss/icons/weather-icons/css/weather-icons.min.css);\n@import url(../scss/icons/linea-icons/linea.css);\n@import url(../scss/icons/themify-icons/themify-icons.css);\n@import url(../scss/icons/flag-icon-css/flag-icon.min.css);\n@import url(../scss/icons/material-design-iconic-font/css/materialdesignicons.min.css);\n@import url(\"https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700\");\n@import url(../css/spinners.css);\n@import url(../css/animate.css);\n.preloader {\n  width: 100%;\n  height: 100%;\n  top: 0px;\n  position: fixed;\n  z-index: 99999;\n  background: #fff; }\n  .preloader .cssload-speeding-wheel {\n    position: absolute;\n    top: calc(50% - 3.5px);\n    left: calc(50% - 3.5px); }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/**\n * Table Of Content\n *\n * \t1. Globals\n *\t2. Headers\n *\t3. Navigations\n *\t4. Banners\n *\t5. Footers\n *\t6. Posts\n *\t7. Widgets\n *\t8. Custom Templates\n */\n/******************* \nGlobal Styles \n*******************/\n* {\n  outline: none; }\n\nbody {\n  background: #fff;\n  font-family: \"Poppins\", sans-serif;\n  margin: 0;\n  overflow-x: hidden;\n  color: #67757c;\n  font-weight: 300; }\n\nhtml {\n  position: relative;\n  min-height: 100%;\n  background: #ffffff; }\n\na:hover, a:focus {\n  text-decoration: none; }\n\na.link {\n  color: #455a64; }\n  a.link:hover, a.link:focus {\n    color: #009efb; }\n\n.img-responsive {\n  width: 100%;\n  height: auto;\n  display: inline-block; }\n\n.img-rounded {\n  border-radius: 4px; }\n\nhtml body .mdi:before, html body .mdi-set {\n  line-height: initial; }\n\n/*******************\nHeadings\n*******************/\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n  color: #455a64;\n  font-family: \"Poppins\", sans-serif;\n  font-weight: 400; }\n\nh1 {\n  line-height: 40px;\n  font-size: 36px; }\n\nh2 {\n  line-height: 36px;\n  font-size: 24px; }\n\nh3 {\n  line-height: 30px;\n  font-size: 21px; }\n\nh4 {\n  line-height: 22px;\n  font-size: 18px; }\n\nh5 {\n  line-height: 18px;\n  font-size: 16px;\n  font-weight: 400; }\n\nh6 {\n  line-height: 16px;\n  font-size: 14px;\n  font-weight: 400; }\n\n.display-5 {\n  font-size: 3rem; }\n\n.display-6 {\n  font-size: 36px; }\n\n.box {\n  border-radius: 4px;\n  padding: 10px; }\n\nhtml body .dl {\n  display: inline-block; }\n\nhtml body .db {\n  display: block; }\n\n.no-wrap td, .no-wrap th {\n  white-space: nowrap; }\n\n/*******************\nBlockquote\n*******************/\nhtml body blockquote {\n  border-left: 5px solid #009efb;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  padding: 15px; }\n\n.clear {\n  clear: both; }\n\nol li {\n  margin: 5px 0; }\n\n/*******************\nPaddings\n*******************/\nhtml body .p-0 {\n  padding: 0px; }\n\nhtml body .p-10 {\n  padding: 10px; }\n\nhtml body .p-20 {\n  padding: 20px; }\n\nhtml body .p-30 {\n  padding: 30px; }\n\nhtml body .p-l-0 {\n  padding-left: 0px; }\n\nhtml body .p-l-10 {\n  padding-left: 10px; }\n\nhtml body .p-l-20 {\n  padding-left: 20px; }\n\nhtml body .p-r-0 {\n  padding-right: 0px; }\n\nhtml body .p-r-10 {\n  padding-right: 10px; }\n\nhtml body .p-r-20 {\n  padding-right: 20px; }\n\nhtml body .p-r-30 {\n  padding-right: 30px; }\n\nhtml body .p-r-40 {\n  padding-right: 40px; }\n\nhtml body .p-t-0 {\n  padding-top: 0px; }\n\nhtml body .p-t-10 {\n  padding-top: 10px; }\n\nhtml body .p-t-20 {\n  padding-top: 20px; }\n\nhtml body .p-t-30 {\n  padding-top: 30px; }\n\nhtml body .p-b-0 {\n  padding-bottom: 0px; }\n\nhtml body .p-b-5 {\n  padding-bottom: 5px; }\n\nhtml body .p-b-10 {\n  padding-bottom: 10px; }\n\nhtml body .p-b-20 {\n  padding-bottom: 20px; }\n\nhtml body .p-b-30 {\n  padding-bottom: 30px; }\n\nhtml body .p-b-40 {\n  padding-bottom: 40px; }\n\n/*******************\nMargin\n*******************/\nhtml body .m-0 {\n  margin: 0px; }\n\nhtml body .m-l-5 {\n  margin-left: 5px; }\n\nhtml body .m-l-10 {\n  margin-left: 10px; }\n\nhtml body .m-l-15 {\n  margin-left: 15px; }\n\nhtml body .m-l-20 {\n  margin-left: 20px; }\n\nhtml body .m-l-30 {\n  margin-left: 30px; }\n\nhtml body .m-l-40 {\n  margin-left: 40px; }\n\nhtml body .m-r-5 {\n  margin-right: 5px; }\n\nhtml body .m-r-10 {\n  margin-right: 10px; }\n\nhtml body .m-r-15 {\n  margin-right: 15px; }\n\nhtml body .m-r-20 {\n  margin-right: 20px; }\n\nhtml body .m-r-30 {\n  margin-right: 30px; }\n\nhtml body .m-r-40 {\n  margin-right: 40px; }\n\nhtml body .m-t-0 {\n  margin-top: 0px; }\n\nhtml body .m-t-5 {\n  margin-top: 5px; }\n\nhtml body .m-t-10 {\n  margin-top: 10px; }\n\nhtml body .m-t-15 {\n  margin-top: 15px; }\n\nhtml body .m-t-20 {\n  margin-top: 20px; }\n\nhtml body .m-t-30 {\n  margin-top: 30px; }\n\nhtml body .m-t-40 {\n  margin-top: 40px; }\n\nhtml body .m-b-0 {\n  margin-bottom: 0px; }\n\nhtml body .m-b-5 {\n  margin-bottom: 5px; }\n\nhtml body .m-b-10 {\n  margin-bottom: 10px; }\n\nhtml body .m-b-15 {\n  margin-bottom: 15px; }\n\nhtml body .m-b-20 {\n  margin-bottom: 20px; }\n\nhtml body .m-b-30 {\n  margin-bottom: 30px; }\n\nhtml body .m-b-40 {\n  margin-bottom: 40px; }\n\n/*******************\nvertical alignment\n*******************/\nhtml body .vt {\n  vertical-align: top; }\n\nhtml body .vm {\n  vertical-align: middle; }\n\nhtml body .vb {\n  vertical-align: bottom; }\n\n/*******************\nOpacity\n*******************/\n.op-5 {\n  opacity: 0.5; }\n\n/*******************\nfont weight\n*******************/\nhtml body .font-bold {\n  font-weight: 700; }\n\nhtml body .font-normal {\n  font-weight: normal; }\n\nhtml body .font-light {\n  font-weight: 300; }\n\nhtml body .font-medium {\n  font-weight: 500; }\n\nhtml body .font-16 {\n  font-size: 16px; }\n\nhtml body .font-14 {\n  font-size: 14px; }\n\nhtml body .font-10 {\n  font-size: 10px; }\n\nhtml body .font-18 {\n  font-size: 18px; }\n\nhtml body .font-20 {\n  font-size: 20px; }\n\n/*******************\nBorder\n*******************/\nhtml body .b-0 {\n  border: none; }\n\nhtml body .b-r {\n  border-right: 1px solid rgba(120, 130, 140, 0.13); }\n\nhtml body .b-l {\n  border-left: 1px solid rgba(120, 130, 140, 0.13); }\n\nhtml body .b-b {\n  border-bottom: 1px solid rgba(120, 130, 140, 0.13); }\n\nhtml body .b-t {\n  border-top: 1px solid rgba(120, 130, 140, 0.13); }\n\nhtml body .b-all {\n  border: 1px solid rgba(120, 130, 140, 0.13); }\n\n/*******************\nThumb size\n*******************/\n.thumb-sm {\n  height: 32px;\n  width: 32px; }\n\n.thumb-md {\n  height: 48px;\n  width: 48px; }\n\n.thumb-lg {\n  height: 88px;\n  width: 88px; }\n\n.hide {\n  display: none; }\n\n.img-circle {\n  border-radius: 100%; }\n\n.radius {\n  border-radius: 4px; }\n\n/*******************\nText Colors\n*******************/\n.text-white {\n  color: #ffffff !important; }\n\n.text-danger {\n  color: #fc4b6c !important; }\n\n.text-danger-padded {\n  color: #fc4b6c !important;\n  padding-left: 15px;}\n\n.text-muted {\n  color: #99abb4 !important; }\n\n.text-warning {\n  color: #ffb22b !important; }\n\n.text-success {\n  color: #26c6da !important; }\n\n.text-info {\n  color: #1e88e5 !important; }\n\n.text-inverse {\n  color: #2f3d4a !important; }\n\nhtml body .text-blue {\n  color: #02bec9; }\n\nhtml body .text-purple {\n  color: #7460ee; }\n\nhtml body .text-primary {\n  color: #7460ee; }\n\nhtml body .text-megna {\n  color: #00897b; }\n\nhtml body .text-dark {\n  color: #67757c; }\n\nhtml body .text-themecolor {\n  color: #009efb; }\n\n/*******************\nBackground Colors\n*******************/\n.bg-primary {\n  background-color: #7460ee !important; }\n\n.bg-success {\n  background-color: #26c6da !important; }\n\n.bg-info {\n  background-color: #1e88e5 !important; }\n\n.bg-warning {\n  background-color: #ffb22b !important; }\n\n.bg-danger {\n  background-color: #fc4b6c !important; }\n\nhtml body .bg-megna {\n  background-color: #00897b; }\n\nhtml body .bg-theme {\n  background-color: #009efb; }\n\nhtml body .bg-inverse {\n  background-color: #2f3d4a; }\n\nhtml body .bg-purple {\n  background-color: #7460ee; }\n\nhtml body .bg-light-primary {\n  background-color: #f1effd; }\n\nhtml body .bg-light-success {\n  background-color: #e8fdeb; }\n\nhtml body .bg-light-info {\n  background-color: #cfecfe; }\n\nhtml body .bg-light-extra {\n  background-color: #ebf3f5; }\n\nhtml body .bg-light-warning {\n  background-color: #fff8ec; }\n\nhtml body .bg-light-danger {\n  background-color: #f9e7eb; }\n\nhtml body .bg-light-inverse {\n  background-color: #f6f6f6; }\n\nhtml body .bg-light {\n  background-color: #f2f4f8; }\n\nhtml body .bg-white {\n  background-color: #ffffff; }\n\n/*******************\nRounds\n*******************/\n.round {\n  line-height: 48px;\n  color: #ffffff;\n  width: 45px;\n  height: 45px;\n  display: inline-block;\n  font-weight: 400;\n  text-align: center;\n  border-radius: 100%;\n  background: #1e88e5; }\n  .round img {\n    border-radius: 100%; }\n\n.round-lg {\n  line-height: 65px;\n  width: 60px;\n  height: 60px;\n  font-size: 30px; }\n\n.round.round-info {\n  background: #1e88e5; }\n\n.round.round-warning {\n  background: #ffb22b; }\n\n.round.round-danger {\n  background: #fc4b6c; }\n\n.round.round-success {\n  background: #26c6da; }\n\n.round.round-primary {\n  background: #7460ee; }\n\n/*******************\nLabels\n*******************/\n.label {\n  padding: 3px 10px;\n  line-height: 13px;\n  color: #ffffff;\n  font-weight: 400;\n  border-radius: 4px;\n  font-size: 75%; }\n\n.label-rounded {\n  border-radius: 60px; }\n\n.label-custom {\n  background-color: #00897b; }\n\n.label-success {\n  background-color: #26c6da; }\n\n.label-info {\n  background-color: #1e88e5; }\n\n.label-warning {\n  background-color: #ffb22b; }\n\n.label-danger {\n  background-color: #fc4b6c; }\n\n.label-megna {\n  background-color: #00897b; }\n\n.label-primary {\n  background-color: #7460ee; }\n\n.label-purple {\n  background-color: #7460ee; }\n\n.label-red {\n  background-color: #fb3a3a; }\n\n.label-inverse {\n  background-color: #2f3d4a; }\n\n.label-default {\n  background-color: #f2f4f8; }\n\n.label-white {\n  background-color: #ffffff; }\n\n.label-light-success {\n  background-color: #e8fdeb;\n  color: #26c6da; }\n\n.label-light-info {\n  background-color: #cfecfe;\n  color: #1e88e5; }\n\n.label-light-warning {\n  background-color: #fff8ec;\n  color: #ffb22b; }\n\n.label-light-danger {\n  background-color: #f9e7eb;\n  color: #fc4b6c; }\n\n.label-light-megna {\n  background-color: #e0f2f4;\n  color: #00897b; }\n\n.label-light-primary {\n  background-color: #f1effd;\n  color: #7460ee; }\n\n.label-light-inverse {\n  background-color: #f6f6f6;\n  color: #2f3d4a; }\n\n/*******************\nPagination\n*******************/\n.pagination > li:first-child > a,\n.pagination > li:first-child > span {\n  border-bottom-left-radius: 4px;\n  border-top-left-radius: 4px; }\n\n.pagination > li:last-child > a,\n.pagination > li:last-child > span {\n  border-bottom-right-radius: 4px;\n  border-top-right-radius: 4px; }\n\n.pagination > li > a,\n.pagination > li > span {\n  color: #263238; }\n\n.pagination > li > a:hover,\n.pagination > li > span:hover,\n.pagination > li > a:focus,\n.pagination > li > span:focus {\n  background-color: #f2f4f8; }\n\n.pagination-split li {\n  margin-left: 5px;\n  display: inline-block;\n  float: left; }\n\n.pagination-split li:first-child {\n  margin-left: 0; }\n\n.pagination-split li a {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px; }\n\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n  background-color: #009efb;\n  border-color: #009efb; }\n\n.pager li > a,\n.pager li > span {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px;\n  color: #263238; }\n\n/*******************\nTable Cell\n*******************/\n.table-box {\n  display: table;\n  width: 100%; }\n\n.table.no-border tbody td {\n  border: 0px; }\n\n.cell {\n  display: table-cell;\n  vertical-align: middle; }\n\n.table td, .table th {\n  border-color: #f3f1f1; }\n\n.table thead th, .table th {\n  font-weight: 500; }\n\n.table-hover tbody tr:hover {\n  background: #f2f4f8; }\n\n.v-middle td, .v-middle th {\n  vertical-align: middle; }\n\n/*******************\nWave Effects\n*******************/\n.waves-effect {\n  position: relative;\n  cursor: pointer;\n  display: inline-block;\n  overflow: hidden;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n  -webkit-tap-highlight-color: transparent;\n  vertical-align: middle;\n  z-index: 1;\n  will-change: opacity, transform;\n  -webkit-transition: all 0.1s ease-out;\n  -moz-transition: all 0.1s ease-out;\n  -o-transition: all 0.1s ease-out;\n  -ms-transition: all 0.1s ease-out;\n  transition: all 0.1s ease-out; }\n  .waves-effect .waves-ripple {\n    position: absolute;\n    border-radius: 50%;\n    width: 20px;\n    height: 20px;\n    margin-top: -10px;\n    margin-left: -10px;\n    opacity: 0;\n    background: rgba(0, 0, 0, 0.2);\n    -webkit-transition: all 0.7s ease-out;\n    -moz-transition: all 0.7s ease-out;\n    -o-transition: all 0.7s ease-out;\n    -ms-transition: all 0.7s ease-out;\n    transition: all 0.7s ease-out;\n    -webkit-transition-property: -webkit-transform, opacity;\n    -moz-transition-property: -moz-transform, opacity;\n    -o-transition-property: -o-transform, opacity;\n    -webkit-transition-property: opacity, -webkit-transform;\n    transition-property: opacity, -webkit-transform;\n    -o-transition-property: transform, opacity;\n    transition-property: transform, opacity;\n    transition-property: transform, opacity, -webkit-transform;\n    -webkit-transform: scale(0);\n    -moz-transform: scale(0);\n    -ms-transform: scale(0);\n    -o-transform: scale(0);\n    transform: scale(0);\n    pointer-events: none; }\n\n.waves-effect.waves-light .waves-ripple {\n  background-color: rgba(255, 255, 255, 0.45); }\n\n.waves-effect.waves-red .waves-ripple {\n  background-color: rgba(244, 67, 54, 0.7); }\n\n.waves-effect.waves-yellow .waves-ripple {\n  background-color: rgba(255, 235, 59, 0.7); }\n\n.waves-effect.waves-orange .waves-ripple {\n  background-color: rgba(255, 152, 0, 0.7); }\n\n.waves-effect.waves-purple .waves-ripple {\n  background-color: rgba(156, 39, 176, 0.7); }\n\n.waves-effect.waves-green .waves-ripple {\n  background-color: rgba(76, 175, 80, 0.7); }\n\n.waves-effect.waves-teal .waves-ripple {\n  background-color: rgba(0, 150, 136, 0.7); }\n\nhtml body .waves-notransition {\n  -webkit-transition: none;\n  -moz-transition: none;\n  -o-transition: none;\n  -ms-transition: none;\n  transition: none; }\n\n.waves-circle {\n  -webkit-transform: translateZ(0);\n  -moz-transform: translateZ(0);\n  -ms-transform: translateZ(0);\n  -o-transform: translateZ(0);\n  transform: translateZ(0);\n  text-align: center;\n  width: 2.5em;\n  height: 2.5em;\n  line-height: 2.5em;\n  border-radius: 50%;\n  -webkit-mask-image: none; }\n\n.waves-input-wrapper {\n  border-radius: 0.2em;\n  vertical-align: bottom; }\n  .waves-input-wrapper .waves-button-input {\n    position: relative;\n    top: 0;\n    left: 0;\n    z-index: 1; }\n\n.waves-block {\n  display: block; }\n\n/*Badge*/\n.badge {\n  font-weight: 400; }\n\n.badge-xs {\n  font-size: 9px; }\n\n.badge-xs,\n.badge-sm {\n  -webkit-transform: translate(0, -2px);\n  -ms-transform: translate(0, -2px);\n  -o-transform: translate(0, -2px);\n  transform: translate(0, -2px); }\n\n.badge-success {\n  background-color: #26c6da; }\n\n.badge-info {\n  background-color: #1e88e5; }\n\n.badge-primary {\n  background-color: #7460ee; }\n\n.badge-warning {\n  background-color: #ffb22b; }\n\n.badge-danger {\n  background-color: #fc4b6c; }\n\n.badge-purple {\n  background-color: #7460ee; }\n\n.badge-red {\n  background-color: #fb3a3a; }\n\n.badge-inverse {\n  background-color: #2f3d4a; }\n\n/*******************\nButtons\n******************/\n.btn {\n  padding: 7px 12px;\n  font-size: 14px;\n  cursor: pointer; }\n\n.btn-group label {\n  color: #ffffff !important;\n  margin-bottom: 0px; }\n  .btn-group label.btn-secondary {\n    color: #67757c !important; }\n\n.btn-lg {\n  padding: .75rem 1.5rem;\n  font-size: 1.25rem; }\n\n.btn-md {\n  padding: 12px 55px;\n  font-size: 16px; }\n\n.btn-circle {\n  border-radius: 100%;\n  width: 40px;\n  height: 40px;\n  padding: 10px; }\n\n.btn-circle.btn-sm {\n  width: 35px;\n  height: 35px;\n  padding: 8px 10px;\n  font-size: 14px; }\n\n.btn-circle.btn-lg {\n  width: 50px;\n  height: 50px;\n  padding: 14px 15px;\n  font-size: 18px; }\n\n.btn-circle.btn-xl {\n  width: 70px;\n  height: 70px;\n  padding: 14px 15px;\n  font-size: 24px; }\n\n.btn-sm {\n  padding: .25rem .5rem;\n  font-size: 12px; }\n\n.btn-xs {\n  padding: .25rem .5rem;\n  font-size: 10px; }\n\n.button-list button, .button-list a {\n  margin: 5px 12px 5px 0; }\n\n.btn-outline {\n  color: inherit;\n  background-color: transparent;\n  -webkit-transition: all .5s;\n  -o-transition: all .5s;\n  transition: all .5s; }\n\n.btn-rounded {\n  border-radius: 60px;\n  padding: 7px 18px; }\n  .btn-rounded.btn-lg {\n    padding: .75rem 1.5rem; }\n  .btn-rounded.btn-sm {\n    padding: .25rem .5rem;\n    font-size: 12px; }\n  .btn-rounded.btn-xs {\n    padding: .25rem .5rem;\n    font-size: 10px; }\n  .btn-rounded.btn-md {\n    padding: 12px 35px;\n    font-size: 16px; }\n\n.btn-secondary,\n.btn-secondary.disabled {\n  -webkit-box-shadow: 0 2px 2px 0 rgba(169, 169, 169, 0.14), 0 3px 1px -2px rgba(169, 169, 169, 0.2), 0 1px 5px 0 rgba(169, 169, 169, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(169, 169, 169, 0.14), 0 3px 1px -2px rgba(169, 169, 169, 0.2), 0 1px 5px 0 rgba(169, 169, 169, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-secondary:hover,\n  .btn-secondary.disabled:hover {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2); }\n  .btn-secondary.active, .btn-secondary:focus,\n  .btn-secondary.disabled.active,\n  .btn-secondary.disabled:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2); }\n\n.btn-primary,\n.btn-primary.disabled {\n  background: #7460ee;\n  border: 1px solid #7460ee;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(116, 96, 238, 0.14), 0 3px 1px -2px rgba(116, 96, 238, 0.2), 0 1px 5px 0 rgba(116, 96, 238, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(116, 96, 238, 0.14), 0 3px 1px -2px rgba(116, 96, 238, 0.2), 0 1px 5px 0 rgba(116, 96, 238, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-primary:hover,\n  .btn-primary.disabled:hover {\n    background: #7460ee;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    border: 1px solid #7460ee; }\n  .btn-primary.active, .btn-primary:focus,\n  .btn-primary.disabled.active,\n  .btn-primary.disabled:focus {\n    background: #6352ce;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2); }\n\n.btn-themecolor,\n.btn-themecolor.disabled {\n  background: #009efb;\n  color: #ffffff;\n  border: 1px solid #009efb; }\n  .btn-themecolor:hover,\n  .btn-themecolor.disabled:hover {\n    background: #009efb;\n    opacity: 0.7;\n    border: 1px solid #009efb; }\n  .btn-themecolor.active, .btn-themecolor:focus,\n  .btn-themecolor.disabled.active,\n  .btn-themecolor.disabled:focus {\n    background: #028ee1; }\n\n.btn-success,\n.btn-success.disabled {\n  background: #26c6da;\n  border: 1px solid #26c6da;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(40, 190, 189, 0.14), 0 3px 1px -2px rgba(40, 190, 189, 0.2), 0 1px 5px 0 rgba(40, 190, 189, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(40, 190, 189, 0.14), 0 3px 1px -2px rgba(40, 190, 189, 0.2), 0 1px 5px 0 rgba(40, 190, 189, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-success:hover,\n  .btn-success.disabled:hover {\n    background: #26c6da;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2);\n    border: 1px solid #26c6da; }\n  .btn-success.active, .btn-success:focus,\n  .btn-success.disabled.active,\n  .btn-success.disabled:focus {\n    background: #1eacbe;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2); }\n\n.btn-info,\n.btn-info.disabled {\n  background: #1e88e5;\n  border: 1px solid #1e88e5;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(66, 165, 245, 0.14), 0 3px 1px -2px rgba(66, 165, 245, 0.2), 0 1px 5px 0 rgba(66, 165, 245, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(66, 165, 245, 0.14), 0 3px 1px -2px rgba(66, 165, 245, 0.2), 0 1px 5px 0 rgba(66, 165, 245, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-info:hover,\n  .btn-info.disabled:hover {\n    background: #1e88e5;\n    border: 1px solid #1e88e5;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2); }\n  .btn-info.active, .btn-info:focus,\n  .btn-info.disabled.active,\n  .btn-info.disabled:focus {\n    background: #028ee1;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2); }\n\n.btn-warning,\n.btn-warning.disabled {\n  background: #ffb22b;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(248, 194, 0, 0.14), 0 3px 1px -2px rgba(248, 194, 0, 0.2), 0 1px 5px 0 rgba(248, 194, 0, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(248, 194, 0, 0.14), 0 3px 1px -2px rgba(248, 194, 0, 0.2), 0 1px 5px 0 rgba(248, 194, 0, 0.12);\n  border: 1px solid #ffb22b;\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-warning:hover,\n  .btn-warning.disabled:hover {\n    background: #ffb22b;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2);\n    border: 1px solid #ffb22b; }\n  .btn-warning.active, .btn-warning:focus,\n  .btn-warning.disabled.active,\n  .btn-warning.disabled:focus {\n    background: #e9ab2e;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2); }\n\n.btn-danger,\n.btn-danger.disabled {\n  background: #fc4b6c;\n  border: 1px solid #fc4b6c;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(239, 83, 80, 0.14), 0 3px 1px -2px rgba(239, 83, 80, 0.2), 0 1px 5px 0 rgba(239, 83, 80, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(239, 83, 80, 0.14), 0 3px 1px -2px rgba(239, 83, 80, 0.2), 0 1px 5px 0 rgba(239, 83, 80, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-danger:hover,\n  .btn-danger.disabled:hover {\n    background: #fc4b6c;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    border: 1px solid #fc4b6c; }\n  .btn-danger.active, .btn-danger:focus,\n  .btn-danger.disabled.active,\n  .btn-danger.disabled:focus {\n    background: #e6294b;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2); }\n\n.btn-inverse,\n.btn-inverse.disabled {\n  background: #2f3d4a;\n  border: 1px solid #2f3d4a;\n  color: #ffffff; }\n  .btn-inverse:hover,\n  .btn-inverse.disabled:hover {\n    background: #2f3d4a;\n    opacity: 0.7;\n    color: #ffffff;\n    border: 1px solid #2f3d4a; }\n  .btn-inverse.active, .btn-inverse:focus,\n  .btn-inverse.disabled.active,\n  .btn-inverse.disabled:focus {\n    background: #232a37;\n    color: #ffffff; }\n\n.btn-red,\n.btn-red.disabled {\n  background: #fb3a3a;\n  border: 1px solid #fb3a3a;\n  color: #ffffff; }\n  .btn-red:hover,\n  .btn-red.disabled:hover {\n    opacity: 0.7;\n    border: 1px solid #fb3a3a;\n    background: #fb3a3a; }\n  .btn-red.active, .btn-red:focus,\n  .btn-red.disabled.active,\n  .btn-red.disabled:focus {\n    background: #e6294b; }\n\n.btn-outline-secondary {\n  background-color: #ffffff;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(169, 169, 169, 0.14), 0 3px 1px -2px rgba(169, 169, 169, 0.2), 0 1px 5px 0 rgba(169, 169, 169, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(169, 169, 169, 0.14), 0 3px 1px -2px rgba(169, 169, 169, 0.2), 0 1px 5px 0 rgba(169, 169, 169, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-secondary:hover, .btn-outline-secondary:focus, .btn-outline-secondary.focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2); }\n  .btn-outline-secondary.active, .btn-outline-secondary:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(169, 169, 169, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(169, 169, 169, 0.2); }\n\n.btn-outline-primary {\n  color: #7460ee;\n  background-color: #ffffff;\n  border-color: #7460ee;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(116, 96, 238, 0.14), 0 3px 1px -2px rgba(116, 96, 238, 0.2), 0 1px 5px 0 rgba(116, 96, 238, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(116, 96, 238, 0.14), 0 3px 1px -2px rgba(116, 96, 238, 0.2), 0 1px 5px 0 rgba(116, 96, 238, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-primary:hover, .btn-outline-primary:focus, .btn-outline-primary.focus {\n    background: #7460ee;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    color: #ffffff;\n    border-color: #7460ee; }\n  .btn-outline-primary.active, .btn-outline-primary:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(116, 96, 238, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(116, 96, 238, 0.2); }\n\n.btn-outline-success {\n  color: #26c6da;\n  background-color: transparent;\n  border-color: #26c6da;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(40, 190, 189, 0.14), 0 3px 1px -2px rgba(40, 190, 189, 0.2), 0 1px 5px 0 rgba(40, 190, 189, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(40, 190, 189, 0.14), 0 3px 1px -2px rgba(40, 190, 189, 0.2), 0 1px 5px 0 rgba(40, 190, 189, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-success:hover, .btn-outline-success:focus, .btn-outline-success.focus {\n    background: #26c6da;\n    border-color: #26c6da;\n    color: #ffffff;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2); }\n  .btn-outline-success.active, .btn-outline-success:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(40, 190, 189, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(40, 190, 189, 0.2); }\n\n.btn-outline-info {\n  color: #1e88e5;\n  background-color: transparent;\n  border-color: #1e88e5;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(66, 165, 245, 0.14), 0 3px 1px -2px rgba(66, 165, 245, 0.2), 0 1px 5px 0 rgba(66, 165, 245, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(66, 165, 245, 0.14), 0 3px 1px -2px rgba(66, 165, 245, 0.2), 0 1px 5px 0 rgba(66, 165, 245, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-info:hover, .btn-outline-info:focus, .btn-outline-info.focus {\n    background: #1e88e5;\n    border-color: #1e88e5;\n    color: #ffffff;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2); }\n  .btn-outline-info.active, .btn-outline-info:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(23, 105, 255, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(23, 105, 255, 0.2); }\n\n.btn-outline-warning {\n  color: #ffb22b;\n  background-color: transparent;\n  border-color: #ffb22b;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(248, 194, 0, 0.14), 0 3px 1px -2px rgba(248, 194, 0, 0.2), 0 1px 5px 0 rgba(248, 194, 0, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(248, 194, 0, 0.14), 0 3px 1px -2px rgba(248, 194, 0, 0.2), 0 1px 5px 0 rgba(248, 194, 0, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-warning:hover, .btn-outline-warning:focus, .btn-outline-warning.focus {\n    background: #ffb22b;\n    border-color: #ffb22b;\n    color: #ffffff;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2); }\n  .btn-outline-warning.active, .btn-outline-warning:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(248, 194, 0, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(248, 194, 0, 0.2); }\n\n.btn-outline-danger {\n  color: #fc4b6c;\n  background-color: transparent;\n  border-color: #fc4b6c;\n  -webkit-box-shadow: 0 2px 2px 0 rgba(239, 83, 80, 0.14), 0 3px 1px -2px rgba(239, 83, 80, 0.2), 0 1px 5px 0 rgba(239, 83, 80, 0.12);\n  box-shadow: 0 2px 2px 0 rgba(239, 83, 80, 0.14), 0 3px 1px -2px rgba(239, 83, 80, 0.2), 0 1px 5px 0 rgba(239, 83, 80, 0.12);\n  -webkit-transition: 0.2s ease-in;\n  -o-transition: 0.2s ease-in;\n  transition: 0.2s ease-in; }\n  .btn-outline-danger:hover, .btn-outline-danger:focus, .btn-outline-danger.focus {\n    background: #fc4b6c;\n    border-color: #fc4b6c;\n    color: #ffffff;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2); }\n  .btn-outline-danger.active, .btn-outline-danger:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2); }\n\n.btn-outline-red {\n  color: #fb3a3a;\n  background-color: transparent;\n  border-color: #fb3a3a; }\n  .btn-outline-red:hover, .btn-outline-red:focus, .btn-outline-red.focus {\n    background: #fb3a3a;\n    border-color: #fb3a3a;\n    color: #ffffff;\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2); }\n  .btn-outline-red.active, .btn-outline-red:focus {\n    -webkit-box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2);\n    box-shadow: 0 14px 26px -12px rgba(239, 83, 80, 0.42), 0 4px 23px 0 rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(239, 83, 80, 0.2); }\n\n.btn-outline-inverse {\n  color: #2f3d4a;\n  background-color: transparent;\n  border-color: #2f3d4a; }\n  .btn-outline-inverse:hover, .btn-outline-inverse:focus, .btn-outline-inverse.focus {\n    background: #2f3d4a;\n    border-color: #2f3d4a;\n    color: #ffffff; }\n\n.btn-primary.active.focus,\n.btn-primary.active:focus,\n.btn-primary.active:hover,\n.btn-primary.focus:active,\n.btn-primary:active:focus,\n.btn-primary:active:hover,\n.open > .dropdown-toggle.btn-primary.focus,\n.open > .dropdown-toggle.btn-primary:focus,\n.open > .dropdown-toggle.btn-primary:hover,\n.btn-primary.focus,\n.btn-primary:focus {\n  background-color: #6352ce;\n  border: 1px solid #6352ce; }\n\n.btn-success.active.focus,\n.btn-success.active:focus,\n.btn-success.active:hover,\n.btn-success.focus:active,\n.btn-success:active:focus,\n.btn-success:active:hover,\n.open > .dropdown-toggle.btn-success.focus,\n.open > .dropdown-toggle.btn-success:focus,\n.open > .dropdown-toggle.btn-success:hover,\n.btn-success.focus,\n.btn-success:focus {\n  background-color: #1eacbe;\n  border: 1px solid #1eacbe; }\n\n.btn-info.active.focus,\n.btn-info.active:focus,\n.btn-info.active:hover,\n.btn-info.focus:active,\n.btn-info:active:focus,\n.btn-info:active:hover,\n.open > .dropdown-toggle.btn-info.focus,\n.open > .dropdown-toggle.btn-info:focus,\n.open > .dropdown-toggle.btn-info:hover,\n.btn-info.focus,\n.btn-info:focus {\n  background-color: #028ee1;\n  border: 1px solid #028ee1; }\n\n.btn-warning.active.focus,\n.btn-warning.active:focus,\n.btn-warning.active:hover,\n.btn-warning.focus:active,\n.btn-warning:active:focus,\n.btn-warning:active:hover,\n.open > .dropdown-toggle.btn-warning.focus,\n.open > .dropdown-toggle.btn-warning:focus,\n.open > .dropdown-toggle.btn-warning:hover,\n.btn-warning.focus,\n.btn-warning:focus {\n  background-color: #e9ab2e;\n  border: 1px solid #e9ab2e; }\n\n.btn-danger.active.focus,\n.btn-danger.active:focus,\n.btn-danger.active:hover,\n.btn-danger.focus:active,\n.btn-danger:active:focus,\n.btn-danger:active:hover,\n.open > .dropdown-toggle.btn-danger.focus,\n.open > .dropdown-toggle.btn-danger:focus,\n.open > .dropdown-toggle.btn-danger:hover,\n.btn-danger.focus,\n.btn-danger:focus {\n  background-color: #e6294b;\n  border: 1px solid #e6294b; }\n\n.btn-inverse:hover,\n.btn-inverse:focus,\n.btn-inverse:active,\n.btn-inverse.active,\n.btn-inverse.focus,\n.btn-inverse:active,\n.btn-inverse:focus,\n.btn-inverse:hover,\n.open > .dropdown-toggle.btn-inverse {\n  background-color: #232a37;\n  border: 1px solid #232a37; }\n\n.btn-red:hover,\n.btn-red:focus,\n.btn-red:active,\n.btn-red.active,\n.btn-red.focus,\n.btn-red:active,\n.btn-red:focus,\n.btn-red:hover,\n.open > .dropdown-toggle.btn-red {\n  background-color: #d61f1f;\n  border: 1px solid #d61f1f;\n  color: #ffffff; }\n\n.button-box .btn {\n  margin: 0 8px 8px 0px; }\n\n.btn-label {\n  background: rgba(0, 0, 0, 0.05);\n  display: inline-block;\n  margin: -6px 12px -6px -14px;\n  padding: 7px 15px; }\n\n.btn-facebook {\n  color: #ffffff;\n  background-color: #3b5998; }\n\n.btn-twitter {\n  color: #ffffff;\n  background-color: #55acee; }\n\n.btn-linkedin {\n  color: #ffffff;\n  background-color: #007bb6; }\n\n.btn-dribbble {\n  color: #ffffff;\n  background-color: #ea4c89; }\n\n.btn-googleplus {\n  color: #ffffff;\n  background-color: #dd4b39; }\n\n.btn-instagram {\n  color: #ffffff;\n  background-color: #3f729b; }\n\n.btn-pinterest {\n  color: #ffffff;\n  background-color: #cb2027; }\n\n.btn-dropbox {\n  color: #ffffff;\n  background-color: #007ee5; }\n\n.btn-flickr {\n  color: #ffffff;\n  background-color: #ff0084; }\n\n.btn-tumblr {\n  color: #ffffff;\n  background-color: #32506d; }\n\n.btn-skype {\n  color: #ffffff;\n  background-color: #00aff0; }\n\n.btn-youtube {\n  color: #ffffff;\n  background-color: #bb0000; }\n\n.btn-github {\n  color: #ffffff;\n  background-color: #171515; }\n\n/*******************\nNotify\n*******************/\n.notify {\n  position: relative;\n  top: -25px;\n  right: -7px; }\n  .notify .heartbit {\n    position: absolute;\n    top: -20px;\n    right: -4px;\n    height: 25px;\n    width: 25px;\n    z-index: 10;\n    border: 5px solid #fc4b6c;\n    border-radius: 70px;\n    -moz-animation: heartbit 1s ease-out;\n    -moz-animation-iteration-count: infinite;\n    -o-animation: heartbit 1s ease-out;\n    -o-animation-iteration-count: infinite;\n    -webkit-animation: heartbit 1s ease-out;\n    -webkit-animation-iteration-count: infinite;\n    animation-iteration-count: infinite; }\n  .notify .point {\n    width: 6px;\n    height: 6px;\n    -webkit-border-radius: 30px;\n    -moz-border-radius: 30px;\n    border-radius: 30px;\n    background-color: #fc4b6c;\n    position: absolute;\n    right: 6px;\n    top: -10px; }\n\n@-moz-keyframes heartbit {\n  0% {\n    -moz-transform: scale(0);\n    opacity: 0.0; }\n  25% {\n    -moz-transform: scale(0.1);\n    opacity: 0.1; }\n  50% {\n    -moz-transform: scale(0.5);\n    opacity: 0.3; }\n  75% {\n    -moz-transform: scale(0.8);\n    opacity: 0.5; }\n  100% {\n    -moz-transform: scale(1);\n    opacity: 0.0; } }\n\n@-webkit-keyframes heartbit {\n  0% {\n    -webkit-transform: scale(0);\n    opacity: 0.0; }\n  25% {\n    -webkit-transform: scale(0.1);\n    opacity: 0.1; }\n  50% {\n    -webkit-transform: scale(0.5);\n    opacity: 0.3; }\n  75% {\n    -webkit-transform: scale(0.8);\n    opacity: 0.5; }\n  100% {\n    -webkit-transform: scale(1);\n    opacity: 0.0; } }\n\n/*******************\nCheckbox\n*******************/\n.checkbox {\n  padding-left: 20px; }\n  .checkbox label {\n    display: block;\n    padding-left: 5px;\n    position: relative; }\n    .checkbox label::before {\n      -o-transition: 0.3s ease-in-out;\n      -webkit-transition: 0.3s ease-in-out;\n      background-color: #ffffff;\n      border-radius: 1px;\n      border: 1px solid rgba(120, 130, 140, 0.13);\n      content: \"\";\n      display: inline-block;\n      height: 17px;\n      left: 0;\n      top: 3px;\n      margin-left: -20px;\n      position: absolute;\n      transition: 0.3s ease-in-out;\n      width: 17px;\n      outline: none; }\n    .checkbox label::after {\n      color: #263238;\n      display: inline-block;\n      font-size: 11px;\n      height: 16px;\n      left: 0;\n      margin-left: -20px;\n      padding-left: 3px;\n      padding-top: 1px;\n      position: absolute;\n      top: 3px;\n      width: 16px; }\n  .checkbox input[type=\"checkbox\"] {\n    cursor: pointer;\n    opacity: 0;\n    z-index: 1;\n    position: absolute;\n    left: 0px;\n    outline: none; }\n    .checkbox input[type=\"checkbox\"]:disabled + label {\n      opacity: 0.65; }\n  .checkbox input[type=\"checkbox\"]:focus + label::before {\n    outline-offset: -2px;\n    outline: none; }\n  .checkbox input[type=\"checkbox\"]:checked + label::after {\n    content: \"\\f00c\";\n    font-family: 'FontAwesome'; }\n  .checkbox input[type=\"checkbox\"]:disabled + label::before {\n    background-color: #f2f4f8;\n    cursor: not-allowed; }\n\n.checkbox.checkbox-circle label::before {\n  border-radius: 50%; }\n\n.checkbox.checkbox-inline {\n  margin-top: 0; }\n\n.checkbox.checkbox-single label {\n  height: 17px; }\n\n.checkbox-primary input[type=\"checkbox\"]:checked + label::before {\n  background-color: #7460ee;\n  border-color: #7460ee; }\n\n.checkbox-primary input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-danger input[type=\"checkbox\"]:checked + label::before {\n  background-color: #fc4b6c;\n  border-color: #fc4b6c; }\n\n.checkbox-danger input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-info input[type=\"checkbox\"]:checked + label::before {\n  background-color: #1e88e5;\n  border-color: #1e88e5; }\n\n.checkbox-info input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-warning input[type=\"checkbox\"]:checked + label::before {\n  background-color: #ffb22b;\n  border-color: #ffb22b; }\n\n.checkbox-warning input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-success input[type=\"checkbox\"]:checked + label::before {\n  background-color: #26c6da;\n  border-color: #26c6da; }\n\n.checkbox-success input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-purple input[type=\"checkbox\"]:checked + label::before {\n  background-color: #7460ee;\n  border-color: #7460ee; }\n\n.checkbox-purple input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-red input[type=\"checkbox\"]:checked + label::before {\n  background-color: #fc4b6c;\n  border-color: #fc4b6c; }\n\n.checkbox-red input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n.checkbox-inverse input[type=\"checkbox\"]:checked + label::before {\n  background-color: #2f3d4a;\n  border-color: #2f3d4a; }\n\n.checkbox-inverse input[type=\"checkbox\"]:checked + label::after {\n  color: #ffffff; }\n\n/*******************\nRadios \n*******************/\n.radio {\n  padding-left: 20px; }\n  .radio label {\n    display: inline-block;\n    padding-left: 5px;\n    position: relative; }\n    .radio label::before {\n      -o-transition: border 0.5s ease-in-out;\n      -webkit-transition: border 0.5s ease-in-out;\n      background-color: #ffffff;\n      border-radius: 50%;\n      border: 1px solid rgba(120, 130, 140, 0.13);\n      content: \"\";\n      display: inline-block;\n      height: 17px;\n      left: 0;\n      margin-left: -20px;\n      position: absolute;\n      transition: border 0.5s ease-in-out;\n      width: 17px;\n      outline: none; }\n    .radio label::after {\n      -moz-transition: -moz-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      -ms-transform: scale(0, 0);\n      -o-transform: scale(0, 0);\n      -o-transition: -o-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      -webkit-transform: scale(0, 0);\n      -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      background-color: #263238;\n      border-radius: 50%;\n      content: \" \";\n      display: inline-block;\n      height: 7px;\n      left: 5px;\n      margin-left: -20px;\n      position: absolute;\n      top: 5px;\n      transform: scale(0, 0);\n      transition: -webkit-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      -o-transition: transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      transition: transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      transition: transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33), -webkit-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n      width: 7px; }\n  .radio input[type=\"radio\"] {\n    cursor: pointer;\n    opacity: 0;\n    z-index: 1;\n    outline: none; }\n    .radio input[type=\"radio\"]:disabled + label {\n      opacity: 0.65; }\n  .radio input[type=\"radio\"]:focus + label::before {\n    outline-offset: -2px;\n    outline: none; }\n  .radio input[type=\"radio\"]:checked + label::after {\n    -ms-transform: scale(1, 1);\n    -o-transform: scale(1, 1);\n    -webkit-transform: scale(1, 1);\n    transform: scale(1, 1); }\n  .radio input[type=\"radio\"]:disabled + label::before {\n    cursor: not-allowed; }\n\n.radio.radio-inline {\n  margin-top: 0; }\n\n.radio.radio-single label {\n  height: 17px; }\n\n.radio-primary input[type=\"radio\"] + label::after {\n  background-color: #7460ee; }\n\n.radio-primary input[type=\"radio\"]:checked + label::before {\n  border-color: #7460ee; }\n\n.radio-primary input[type=\"radio\"]:checked + label::after {\n  background-color: #7460ee; }\n\n.radio-danger input[type=\"radio\"] + label::after {\n  background-color: #fc4b6c; }\n\n.radio-danger input[type=\"radio\"]:checked + label::before {\n  border-color: #fc4b6c; }\n\n.radio-danger input[type=\"radio\"]:checked + label::after {\n  background-color: #fc4b6c; }\n\n.radio-info input[type=\"radio\"] + label::after {\n  background-color: #1e88e5; }\n\n.radio-info input[type=\"radio\"]:checked + label::before {\n  border-color: #1e88e5; }\n\n.radio-info input[type=\"radio\"]:checked + label::after {\n  background-color: #1e88e5; }\n\n.radio-warning input[type=\"radio\"] + label::after {\n  background-color: #ffb22b; }\n\n.radio-warning input[type=\"radio\"]:checked + label::before {\n  border-color: #ffb22b; }\n\n.radio-warning input[type=\"radio\"]:checked + label::after {\n  background-color: #ffb22b; }\n\n.radio-success input[type=\"radio\"] + label::after {\n  background-color: #26c6da; }\n\n.radio-success input[type=\"radio\"]:checked + label::before {\n  border-color: #26c6da; }\n\n.radio-success input[type=\"radio\"]:checked + label::after {\n  background-color: #26c6da; }\n\n.radio-purple input[type=\"radio\"] + label::after {\n  background-color: #7460ee; }\n\n.radio-purple input[type=\"radio\"]:checked + label::before {\n  border-color: #7460ee; }\n\n.radio-purple input[type=\"radio\"]:checked + label::after {\n  background-color: #7460ee; }\n\n.radio-red input[type=\"radio\"] + label::after {\n  background-color: #fc4b6c; }\n\n.radio-red input[type=\"radio\"]:checked + label::before {\n  border-color: #fc4b6c; }\n\n.radio-red input[type=\"radio\"]:checked + label::after {\n  background-color: #fc4b6c; }\n\n.checkbox label, .radio label {\n  cursor: pointer; }\n\n/*******************\nFile Upload \n******************/\n.fileupload {\n  overflow: hidden;\n  position: relative; }\n  .fileupload input.upload {\n    cursor: pointer;\n    filter: alpha(opacity=0);\n    font-size: 20px;\n    margin: 0;\n    opacity: 0;\n    padding: 0;\n    position: absolute;\n    right: 0;\n    top: 0; }\n\n/*******************\nMegamenu\n******************/\n.mega-dropdown {\n  position: static;\n  width: 100%; }\n  .mega-dropdown .dropdown-menu {\n    width: 100%;\n    padding: 30px;\n    margin-top: 0px; }\n  .mega-dropdown ul {\n    padding: 0px; }\n    .mega-dropdown ul li {\n      list-style: none; }\n  .mega-dropdown .carousel-item .container {\n    padding: 0px; }\n  .mega-dropdown .nav-accordion .card {\n    margin-bottom: 1px; }\n  .mega-dropdown .nav-accordion .card-header {\n    background: #ffffff; }\n    .mega-dropdown .nav-accordion .card-header h5 {\n      margin: 0px; }\n      .mega-dropdown .nav-accordion .card-header h5 a {\n        text-decoration: none;\n        color: #67757c; }\n\n/*******************\nList-style-none\n******************/\nul.list-style-none {\n  margin: 0px;\n  padding: 0px; }\n  ul.list-style-none li {\n    list-style: none; }\n    ul.list-style-none li a {\n      color: #67757c;\n      padding: 8px 0px;\n      display: block;\n      text-decoration: none; }\n      ul.list-style-none li a:hover {\n        color: #009efb; }\n\n/*******************\ndropdown-item\n******************/\n.dropdown-item {\n  padding: 8px 1rem;\n  color: #67757c; }\n\n/*******************\nCustom-select\n******************/\n.custom-select {\n  background: url(../../assets/images/custom-select.png) right 0.75rem center no-repeat; }\n\n/*******************\ntextarea\n******************/\ntextarea {\n  resize: none; }\n\n/*******************\nForm-control\n******************/\n.form-control {\n  color: #67757c;\n  min-height: 38px;\n  display: initial; }\n\n.form-control-sm {\n  min-height: 20px; }\n\n.form-control:disabled, .form-control[readonly] {\n  opacity: 0.7; }\n\n.custom-control-input:focus ~ .custom-control-indicator {\n  -webkit-box-shadow: none;\n  box-shadow: none; }\n\n.custom-control-input:checked ~ .custom-control-indicator {\n  background-color: #26c6da; }\n\nform label {\n  font-weight: 400; }\n\n.form-group {\n  margin-bottom: 25px; }\n\n.form-horizontal label {\n  margin-bottom: 0px; }\n\n.form-control-static {\n  padding-top: 0px; }\n\n.form-bordered .form-group {\n  border-bottom: 1px solid rgba(120, 130, 140, 0.13);\n  padding-bottom: 20px; }\n\n/*******************\nLayouts\n******************/\n/*Card-noborders*/\n.card-no-border .card {\n  border-color: #d7dfe3;\n  border-radius: 4px;\n  -webkit-box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.05);\n  box-shadow: 0px 5px 20px rgba(0, 0, 0, 0.05); }\n\n.card-no-border .sidebar-footer {\n  background: #f2f6f8; }\n\n.card-no-border .sidebar-nav > ul > li > a.active {\n  background: #ffffff; }\n\n.card-no-border .shadow-none {\n  -webkit-box-shadow: none;\n  box-shadow: none; }\n\n.card-outline-danger, .card-outline-info, .card-outline-warning, .card-outline-success, .card-outline-primary {\n  background: #ffffff; }\n\n.card-fullscreen {\n  position: fixed;\n  top: 0px;\n  left: 0px;\n  width: 100%;\n  height: 100%;\n  z-index: 9999;\n  overflow: auto; }\n\n.card .card-header {\n  background: #ffffff;\n  border-bottom: 0px; }\n\n/*******************/\n/*widgets -app*/\n/*******************/\n.css-bar:after {\n  z-index: 1; }\n\n.css-bar > i {\n  z-index: 10; }\n\n/*******************/\n/*single column*/\n/*******************/\n.single-column .left-sidebar {\n  display: none; }\n\n.single-column .page-wrapper {\n  margin-left: 0px; }\n\n.fix-width {\n  width: 100%;\n  max-width: 1170px;\n  margin: 0 auto; }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*============================================================== \n For all pages \n ============================================================== */\n#main-wrapper {\n  width: 100%; }\n\n.boxed #main-wrapper {\n  width: 100%;\n  max-width: 1300px;\n  margin: 0 auto;\n  -webkit-box-shadow: 0 0 60px rgba(0, 0, 0, 0.1);\n  box-shadow: 0 0 60px rgba(0, 0, 0, 0.1); }\n  .boxed #main-wrapper .sidebar-footer {\n    position: absolute; }\n  .boxed #main-wrapper .footer {\n    display: none; }\n\n.page-wrapper {\n  background: #eef5f9;\n  padding-bottom: 60px; }\n\n.container-fluid {\n  padding: 0 30px 25px 30px; }\n\n/*******************\n Topbar\n*******************/\n.topbar {\n  position: relative;\n  z-index: 50;\n  -webkit-box-shadow: 5px 0px 10px rgba(0, 0, 0, 0.5);\n  box-shadow: 5px 0px 10px rgba(0, 0, 0, 0.5); }\n  .topbar .top-navbar {\n    min-height: 70px;\n    padding: 0px 15px 0 0; }\n    .topbar .top-navbar .dropdown-toggle::after {\n      display: none; }\n    .topbar .top-navbar .navbar-header {\n      line-height: 65px;\n      text-align: center; }\n      .topbar .top-navbar .navbar-header .navbar-brand {\n        margin-right: 0px;\n        padding-bottom: 0px;\n        padding-top: 0px; }\n        .topbar .top-navbar .navbar-header .navbar-brand .light-logo {\n          display: none; }\n        .topbar .top-navbar .navbar-header .navbar-brand b {\n          line-height: 70px;\n          display: inline-block; }\n    .topbar .top-navbar .navbar-nav > .nav-item > .nav-link {\n      padding-left: .75rem;\n      padding-right: .75rem;\n      font-size: 19px;\n      line-height: 50px; }\n    .topbar .top-navbar .navbar-nav > .nav-item.show {\n      background: rgba(0, 0, 0, 0.05); }\n  .topbar .profile-pic {\n    width: 30px;\n    border-radius: 100%; }\n  .topbar .dropdown-menu {\n    box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n    -webkit-box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n    -moz-box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n    border-color: rgba(120, 130, 140, 0.13); }\n    .topbar .dropdown-menu .dropdown-item {\n      padding: 7px 1.5rem; }\n  .topbar ul.dropdown-user {\n    padding: 0px;\n    width: 270px; }\n    .topbar ul.dropdown-user li {\n      list-style: none;\n      padding: 0px;\n      margin: 0px; }\n      .topbar ul.dropdown-user li.divider {\n        height: 1px;\n        margin: 9px 0;\n        overflow: hidden;\n        background-color: rgba(120, 130, 140, 0.13); }\n      .topbar ul.dropdown-user li .dw-user-box {\n        padding: 10px 15px; }\n        .topbar ul.dropdown-user li .dw-user-box .u-img {\n          width: 80px;\n          display: inline-block;\n          vertical-align: top; }\n          .topbar ul.dropdown-user li .dw-user-box .u-img img {\n            width: 100%;\n            border-radius: 5px; }\n        .topbar ul.dropdown-user li .dw-user-box .u-text {\n          display: inline-block;\n          padding-left: 10px; }\n          .topbar ul.dropdown-user li .dw-user-box .u-text h4 {\n            margin: 0px; }\n          .topbar ul.dropdown-user li .dw-user-box .u-text p {\n            margin-bottom: 2px;\n            font-size: 14px; }\n          .topbar ul.dropdown-user li .dw-user-box .u-text .btn {\n            color: #ffffff;\n            padding: 5px 10px;\n            display: inline-block; }\n            .topbar ul.dropdown-user li .dw-user-box .u-text .btn:hover {\n              background: #e6294b; }\n      .topbar ul.dropdown-user li a {\n        padding: 9px 15px;\n        display: block;\n        color: #67757c; }\n        .topbar ul.dropdown-user li a:hover {\n          background: #f2f4f8;\n          color: #009efb;\n          text-decoration: none; }\n\n.search-box .app-search {\n  position: absolute;\n  margin: 0px;\n  display: block;\n  z-index: 110;\n  width: 100%;\n  top: -1px;\n  -webkit-box-shadow: 2px 0px 10px rgba(0, 0, 0, 0.2);\n  box-shadow: 2px 0px 10px rgba(0, 0, 0, 0.2);\n  display: none;\n  left: 0px; }\n  .search-box .app-search input {\n    width: 100%;\n    padding: 25px 40px 25px 20px;\n    border-radius: 0px;\n    font-size: 17px;\n    -webkit-transition: 0.5s ease-in;\n    -o-transition: 0.5s ease-in;\n    transition: 0.5s ease-in; }\n  .search-box .app-search .srh-btn {\n    position: absolute;\n    top: 23px;\n    cursor: pointer;\n    background: #ffffff;\n    width: 15px;\n    height: 15px;\n    right: 20px;\n    font-size: 14px; }\n\n.mini-sidebar .top-navbar .navbar-header {\n  width: 60px;\n  text-align: center; }\n\n.logo-center .top-navbar .navbar-header {\n  position: absolute;\n  left: 0;\n  right: 0;\n  margin: 0 auto; }\n\n/*******************\n Breadcrumb and page title\n*******************/\n.page-titles {\n  background: #ffffff;\n  margin: 0 -30px 30px;\n  padding: 15px;\n  -webkit-box-shadow: 1px 0 5px rgba(0, 0, 0, 0.1);\n  box-shadow: 1px 0 5px rgba(0, 0, 0, 0.1); }\n  .page-titles h3 {\n    margin-bottom: 0px;\n    margin-top: 8px; }\n  .page-titles .breadcrumb {\n    padding: 0px;\n    background: transparent;\n    font-size: 14px; }\n    .page-titles .breadcrumb li {\n      margin-top: 0px;\n      margin-bottom: 0px; }\n    .page-titles .breadcrumb .breadcrumb-item + .breadcrumb-item::before {\n      content: \"\\e649\";\n      font-family: themify;\n      color: #a6b7bf;\n      font-size: 11px; }\n    .page-titles .breadcrumb .breadcrumb-item.active {\n      color: #99abb4; }\n\n/*******************\n Right side toggle\n*******************/\n@-webkit-keyframes rotate {\n  from {\n    -webkit-transform: rotate(0deg); }\n  to {\n    -webkit-transform: rotate(360deg); } }\n\n@-moz-keyframes rotate {\n  from {\n    -moz-transform: rotate(0deg); }\n  to {\n    -moz-transform: rotate(360deg); } }\n\n@keyframes rotate {\n  from {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg); }\n  to {\n    -webkit-transform: rotate(360deg);\n    transform: rotate(360deg); } }\n\n.right-side-toggle {\n  position: relative; }\n\n.right-side-toggle i {\n  -webkit-transition-property: -webkit-transform;\n  -webkit-transition-duration: 1s;\n  -moz-transition-property: -moz-transform;\n  -moz-transition-duration: 1s;\n  transition-property: -webkit-transform;\n  -o-transition-property: transform;\n  transition-property: transform;\n  transition-property: transform, -webkit-transform;\n  -o-transition-duration: 1s;\n  transition-duration: 1s;\n  -webkit-animation-name: rotate;\n  -webkit-animation-duration: 2s;\n  -webkit-animation-iteration-count: infinite;\n  -webkit-animation-timing-function: linear;\n  -moz-animation-name: rotate;\n  -moz-animation-duration: 2s;\n  -moz-animation-iteration-count: infinite;\n  -moz-animation-timing-function: linear;\n  animation-name: rotate;\n  animation-duration: 2s;\n  animation-iteration-count: infinite;\n  animation-timing-function: linear;\n  position: absolute;\n  top: 18px;\n  left: 18px; }\n\n.right-sidebar {\n  position: fixed;\n  right: -240px;\n  width: 240px;\n  display: none;\n  z-index: 1100;\n  background: #ffffff;\n  top: 0px;\n  padding-bottom: 20px;\n  height: 100%;\n  -webkit-box-shadow: 5px 1px 40px rgba(0, 0, 0, 0.1);\n  box-shadow: 5px 1px 40px rgba(0, 0, 0, 0.1);\n  -webkit-transition: all 0.3s ease;\n  -o-transition: all 0.3s ease;\n  transition: all 0.3s ease; }\n  .right-sidebar .rpanel-title {\n    display: block;\n    padding: 24px 20px;\n    color: #ffffff;\n    text-transform: uppercase;\n    font-size: 15px;\n    background: #009efb; }\n    .right-sidebar .rpanel-title span {\n      float: right;\n      cursor: pointer;\n      font-size: 11px; }\n      .right-sidebar .rpanel-title span:hover {\n        color: #ffffff; }\n  .right-sidebar .r-panel-body {\n    padding: 20px; }\n    .right-sidebar .r-panel-body ul {\n      margin: 0px;\n      padding: 0px; }\n      .right-sidebar .r-panel-body ul li {\n        list-style: none;\n        padding: 5px 0; }\n\n.shw-rside {\n  right: 0px;\n  width: 240px;\n  display: block; }\n\n.chatonline img {\n  margin-right: 10px;\n  float: left;\n  width: 30px; }\n\n.chatonline li a {\n  padding: 13px 0;\n  float: left;\n  width: 100%; }\n  .chatonline li a span {\n    color: #67757c; }\n    .chatonline li a span small {\n      display: block;\n      font-size: 10px; }\n\n/*******************\n Right side toggle\n*******************/\nul#themecolors {\n  display: block; }\n  ul#themecolors li {\n    display: inline-block; }\n    ul#themecolors li:first-child {\n      display: block; }\n    ul#themecolors li a {\n      width: 50px;\n      height: 50px;\n      display: inline-block;\n      margin: 5px;\n      color: transparent;\n      position: relative; }\n      ul#themecolors li a.working:before {\n        content: \"\\f00c\";\n        font-family: \"FontAwesome\";\n        font-size: 18px;\n        line-height: 50px;\n        width: 50px;\n        height: 50px;\n        position: absolute;\n        top: 0;\n        left: 0;\n        color: #ffffff;\n        text-align: center; }\n\n.default-theme {\n  background: #99abb4; }\n\n.green-theme {\n  background: #26c6da; }\n\n.yellow-theme {\n  background: #ffb22b; }\n\n.red-theme {\n  background: #fc4b6c; }\n\n.blue-theme {\n  background: #1e88e5; }\n\n.purple-theme {\n  background: #7460ee; }\n\n.megna-theme {\n  background: #00897b; }\n\n.default-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #99abb4 23%, #99abb4 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #99abb4 23%, #99abb4 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #99abb4), color-stop(99%, #99abb4));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #99abb4 23%, #99abb4 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #99abb4 23%, #99abb4 99%); }\n\n.green-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #26c6da 23%, #26c6da 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #00c292 23%, #26c6da 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #26c6da), color-stop(99%, #26c6da));\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #26c6da 23%, #26c6da 99%);\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #26c6da 23%, #26c6da 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #26c6da 23%, #26c6da 99%); }\n\n.yellow-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #fc4b6c), color-stop(99%, #fc4b6c));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%); }\n\n.blue-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #1e88e5 23%, #1e88e5 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #1e88e5 23%, #1e88e5 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #1e88e5), color-stop(99%, #1e88e5));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #1e88e5 23%, #1e88e5 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #1e88e5 23%, #1e88e5 99%); }\n\n.purple-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #7460ee 23%, #7460ee 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #7460ee 23%, #7460ee 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #7460ee), color-stop(99%, #7460ee));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #7460ee 23%, #7460ee 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #7460ee 23%, #7460ee 99%); }\n\n.megna-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #00897b 23%, #00897b 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #00897b 23%, #00897b 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #00897b), color-stop(99%, #00897b));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #00897b 23%, #00897b 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #00897b 23%, #00897b 99%); }\n\n.red-dark-theme {\n  background: #263238;\n  /* Old browsers */\n  background: -moz-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  /* FF3.6-15 */\n  background: -webkit-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  /* Chrome10-25,Safari5.1-6 */\n  background: -webkit-gradient(linear, left top, right top, from(#263238), color-stop(23%, #263238), color-stop(23%, #fc4b6c), color-stop(99%, #fc4b6c));\n  background: -o-linear-gradient(left, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%);\n  background: linear-gradient(to right, #263238 0%, #263238 23%, #fc4b6c 23%, #fc4b6c 99%); }\n\n/*******************\n page title\n*******************/\n.page-titles {\n  padding-bottom: 20px; }\n\n/*******************\n Footer\n*******************/\n.footer {\n  bottom: 0;\n  color: #67757c;\n  left: 0px;\n  padding: 17px 15px;\n  position: absolute;\n  right: 0;\n  border-top: 1px solid rgba(120, 130, 140, 0.13);\n  background: #ffffff; }\n\n/*******************\n Card title\n*******************/\n.card {\n  margin-bottom: 30px; }\n  .card .card-subtitle {\n    font-weight: 300;\n    margin-bottom: 15px;\n    color: #99abb4; }\n\n.card-inverse .card-blockquote .blockquote-footer,\n.card-inverse .card-link,\n.card-inverse .card-subtitle,\n.card-inverse .card-text {\n  color: rgba(255, 255, 255, 0.65); }\n\n.card-success {\n  background: #26c6da;\n  border-color: #26c6da; }\n\n.card-danger {\n  background: #fc4b6c;\n  border-color: #fc4b6c; }\n\n.card-warning {\n  background: #ffb22b;\n  border-color: #ffb22b; }\n\n.card-info {\n  background: #1e88e5;\n  border-color: #1e88e5; }\n\n.card-primary {\n  background: #7460ee;\n  border-color: #7460ee; }\n\n.card-dark {\n  background: #2f3d4a;\n  border-color: #2f3d4a; }\n\n.card-megna {\n  background: #00897b;\n  border-color: #00897b; }\n\n/*============================================================== \n Buttons page\n ============================================================== */\n.button-group .btn {\n  margin-bottom: 5px;\n  margin-right: 5px; }\n\n.no-button-group .btn {\n  margin-bottom: 5px;\n  margin-right: 0px; }\n\n.btn .text-active {\n  display: none; }\n\n.btn.active .text-active {\n  display: inline-block; }\n\n.btn.active .text {\n  display: none; }\n\n/*============================================================== \n Cards page\n ============================================================== */\n.card-actions {\n  float: right; }\n  .card-actions a {\n    cursor: pointer;\n    color: #67757c;\n    opacity: 0.7;\n    padding-left: 7px;\n    font-size: 13px; }\n    .card-actions a:hover {\n      opacity: 1; }\n\n.card-columns .card {\n  margin-bottom: 20px; }\n\n.collapsing {\n  -webkit-transition: height .08s ease;\n  -o-transition: height .08s ease;\n  transition: height .08s ease; }\n\n.card-info {\n  background: #1e88e5;\n  border-color: #1e88e5; }\n\n.card-primary {\n  background: #7460ee;\n  border-color: #7460ee; }\n\n.card-outline-info {\n  border-color: #1e88e5; }\n  .card-outline-info .card-header {\n    background: #1e88e5;\n    border-color: #1e88e5; }\n\n.card-outline-inverse {\n  border-color: #2f3d4a; }\n  .card-outline-inverse .card-header {\n    background: #2f3d4a;\n    border-color: #2f3d4a; }\n\n.card-outline-warning {\n  border-color: #ffb22b; }\n  .card-outline-warning .card-header {\n    background: #ffb22b;\n    border-color: #ffb22b; }\n\n.card-outline-success {\n  border-color: #26c6da; }\n  .card-outline-success .card-header {\n    background: #26c6da;\n    border-color: #26c6da; }\n\n.card-outline-danger {\n  border-color: #fc4b6c; }\n  .card-outline-danger .card-header {\n    background: #fc4b6c;\n    border-color: #fc4b6c; }\n\n.card-outline-primary {\n  border-color: #7460ee; }\n  .card-outline-primary .card-header {\n    background: #7460ee;\n    border-color: #7460ee; }\n\n/*============================================================== \nBreadcrumb\n ============================================================== */\n.bc-colored .breadcrumb-item,\n.bc-colored .breadcrumb-item a {\n  color: #ffffff; }\n  .bc-colored .breadcrumb-item.active,\n  .bc-colored .breadcrumb-item a.active {\n    opacity: 0.7; }\n\n.bc-colored .breadcrumb-item + .breadcrumb-item::before {\n  color: rgba(255, 255, 255, 0.4); }\n\n.breadcrumb {\n  margin-bottom: 0px; }\n\n/*============================================================== \n Ui-bootstrap\n ============================================================== */\nul.list-icons {\n  margin: 0px;\n  padding: 0px; }\n  ul.list-icons li {\n    list-style: none;\n    line-height: 30px;\n    margin: 5px 0;\n    -webkit-transition: 0.2s ease-in;\n    -o-transition: 0.2s ease-in;\n    transition: 0.2s ease-in; }\n    ul.list-icons li a {\n      color: #67757c; }\n      ul.list-icons li a:hover {\n        color: #009efb; }\n    ul.list-icons li i {\n      font-size: 13px;\n      padding-right: 8px; }\n\nul.list-inline li {\n  display: inline-block;\n  padding: 0 8px; }\n\nul.two-part {\n  margin: 0px; }\n  ul.two-part li {\n    width: 48.8%; }\n\n/*Accordion*/\nhtml body .accordion .card {\n  margin-bottom: 0px; }\n\n/*============================================================== \n flot chart\n ============================================================== */\n.flot-chart {\n  display: block;\n  height: 400px; }\n\n.flot-chart-content {\n  width: 100%;\n  height: 100%; }\n\nhtml body .jqstooltip,\nhtml body .flotTip {\n  width: auto !important;\n  height: auto !important;\n  background: #263238;\n  color: #ffffff;\n  padding: 5px 10px; }\n\n/*============================================================== \nEasy pie chart \n ============================================================== */\n.chart {\n  position: relative;\n  display: inline-block;\n  width: 100px;\n  height: 100px;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  text-align: center; }\n  .chart canvas {\n    position: absolute;\n    top: 0;\n    left: 0; }\n\n.chart.chart-widget-pie {\n  margin-top: 5px;\n  margin-bottom: 5px; }\n\n.pie-chart > span {\n  left: 0;\n  margin-top: -2px;\n  position: absolute;\n  right: 0;\n  text-align: center;\n  top: 50%;\n  -webkit-transform: translateY(-50%);\n  -ms-transform: translateY(-50%);\n  transform: translateY(-50%); }\n\n.chart > span > img {\n  left: 0;\n  margin-top: -2px;\n  position: absolute;\n  right: 0;\n  text-align: center;\n  top: 50%;\n  width: 60%;\n  height: 60%;\n  -webkit-transform: translateY(-50%);\n  -ms-transform: translateY(-50%);\n  transform: translateY(-50%);\n  margin: 0 auto; }\n\n.percent {\n  display: inline-block;\n  line-height: 100px;\n  z-index: 2;\n  font-weight: 600;\n  font-size: 18px;\n  color: #263238; }\n  .percent:after {\n    content: '%';\n    margin-left: 0.1em;\n    font-size: .8em; }\n\n/*============================================================== \nDashboard1 chart\n ============================================================== */\n.ct-charts {\n  position: relative; }\n\n.amp-pxl {\n  position: relative; }\n  .amp-pxl .ct-series-a .ct-bar {\n    stroke: #1e88e5; }\n  .amp-pxl .ct-series-b .ct-bar {\n    stroke: #26c6da; }\n\n.c3-chart-arcs-title,\n.c3-legend-item {\n  font-family: \"Poppins\", sans-serif;\n  fill: #67757c; }\n\nhtml body #visitor .c3-chart-arcs-title {\n  font-size: 18px;\n  fill: #99abb4; }\n\n.stylish-table thead th {\n  font-weight: 400;\n  color: #99abb4;\n  border: 0px;\n  border-bottom: 1px; }\n\n.stylish-table tbody tr {\n  border-left: 4px solid #ffffff; }\n  .stylish-table tbody tr:hover, .stylish-table tbody tr.active {\n    border-left: 4px solid #009efb; }\n\n.stylish-table tbody td {\n  vertical-align: middle; }\n  .stylish-table tbody td h6 {\n    font-weight: 500;\n    margin-bottom: 0px;\n    white-space: nowrap; }\n  .stylish-table tbody td small {\n    line-height: 12px;\n    white-space: nowrap; }\n\n/*============================================================== \nDashboard2 chart\n ============================================================== */\n.campaign {\n  height: 280px; }\n  .campaign .ct-series-a .ct-area {\n    fill-opacity: 0.2;\n    fill: url(#gradient); }\n  .campaign .ct-series-a .ct-line,\n  .campaign .ct-series-a .ct-point {\n    stroke: #26c6da;\n    stroke-width: 2px; }\n  .campaign .ct-series-b .ct-area {\n    fill: #1e88e5;\n    fill-opacity: 0.1; }\n  .campaign .ct-series-b .ct-line,\n  .campaign .ct-series-b .ct-point {\n    stroke: #1e88e5;\n    stroke-width: 2px; }\n  .campaign .ct-series-a .ct-point,\n  .campaign .ct-series-b .ct-point {\n    stroke-width: 6px; }\n\n.campaign2 .ct-series-a .ct-area {\n  fill-opacity: 0.2;\n  fill: url(#gradient); }\n\n.campaign2 .ct-series-a .ct-line,\n.campaign2 .ct-series-a .ct-point {\n  stroke: #26c6da;\n  stroke-width: 2px; }\n\n.campaign2 .ct-series-b .ct-area {\n  fill: #1e88e5;\n  fill-opacity: 0.1; }\n\n.campaign2 .ct-series-b .ct-line,\n.campaign2 .ct-series-b .ct-point {\n  stroke: #1e88e5;\n  stroke-width: 2px; }\n\n.campaign2 .ct-series-a .ct-point,\n.campaign2 .ct-series-b .ct-point {\n  stroke-width: 6px; }\n\n.usage .ct-series-a .ct-line {\n  stroke-width: 3px;\n  stroke: rgba(255, 255, 255, 0.5); }\n\n/*============================================================== \nDashboard3 chart\n ============================================================== */\n.total-sales {\n  position: relative; }\n  .total-sales .chartist-tooltip {\n    background: #2f3d4a; }\n  .total-sales .ct-series-a .ct-bar {\n    stroke: #1e88e5; }\n  .total-sales .ct-series-b .ct-bar {\n    stroke: #26c6da; }\n  .total-sales .ct-series-c .ct-bar {\n    stroke: #fc4b6c; }\n\n.ct-chart {\n  position: relative; }\n  .ct-chart .ct-series-a .ct-slice-donut {\n    stroke: #26c6da; }\n  .ct-chart .ct-series-b .ct-slice-donut {\n    stroke: #f2f4f8; }\n  .ct-chart .ct-series-c .ct-slice-donut {\n    stroke: #1e88e5; }\n\n#visitfromworld path.jvectormap-region.jvectormap-element {\n  stroke-width: 1px;\n  stroke: #99abb4; }\n\n.jvectormap-zoomin,\n.jvectormap-zoomout,\n.jvectormap-goback {\n  background: #99abb4; }\n\n.browser td {\n  vertical-align: middle;\n  padding-left: 0px; }\n\n#calendar .fc-today-button {\n  display: none; }\n\n/*============================================================== \nDashboard4 chart\n ============================================================== */\n.total-revenue4 {\n  position: relative; }\n  .total-revenue4 .ct-series-a .ct-line {\n    stroke: #1e88e5;\n    stroke-width: 1px; }\n  .total-revenue4 .ct-series-a .ct-point {\n    stroke: #1e88e5;\n    stroke-width: 5px; }\n  .total-revenue4 .ct-series-b .ct-line {\n    stroke: #26c6da;\n    stroke-width: 1px; }\n  .total-revenue4 .ct-series-b .ct-point {\n    stroke: #26c6da;\n    stroke-width: 5px; }\n  .total-revenue4 .ct-series-a .ct-area {\n    fill: #1e88e5;\n    fill-opacity: 0.2; }\n  .total-revenue4 .ct-series-b .ct-area {\n    fill: #26c6da;\n    fill-opacity: 0.2; }\n\n/*============================================================== \nDashboard6 chart\n ============================================================== */\n.product-overview.table tbody tr td {\n  vertical-align: middle; }\n\n/*============================================================== \nWidget-data\n ============================================================== */\n.sparkchart {\n  margin-bottom: -2px; }\n\n/*============================================================== \nFile upload\n ============================================================== */\n.btn-file {\n  overflow: hidden;\n  position: relative;\n  vertical-align: middle; }\n  .btn-file > input {\n    position: absolute;\n    top: 0;\n    right: 0;\n    margin: 0;\n    opacity: 0;\n    filter: alpha(opacity=0);\n    font-size: 23px;\n    height: 100%;\n    width: 100%;\n    direction: ltr;\n    cursor: pointer;\n    border-radius: 0px; }\n\n.fileinput .input-group-addon {\n  border-right: 1px solid rgba(120, 130, 140, 0.13); }\n\n.fileinput .form-control {\n  padding-top: 7px;\n  padding-bottom: 5px;\n  display: inline-block;\n  margin-bottom: 0px;\n  vertical-align: middle;\n  cursor: text; }\n\n.fileinput .thumbnail {\n  overflow: hidden;\n  display: inline-block;\n  margin-bottom: 5px;\n  vertical-align: middle;\n  text-align: center; }\n\n.fileinput .thumbnail > img {\n  max-height: 100%; }\n\n.fileinput .btn {\n  vertical-align: middle; }\n\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n  display: none; }\n\n.fileinput-inline .fileinput-controls {\n  display: inline; }\n\n.fileinput-filename {\n  vertical-align: middle;\n  display: inline-block;\n  overflow: hidden; }\n\n.form-control .fileinput-filename {\n  vertical-align: bottom; }\n\n.fileinput.input-group > * {\n  position: relative;\n  z-index: 2; }\n\n.fileinput.input-group > .btn-file {\n  z-index: 1; }\n\n/*============================================================== \nwidget-chart-page product review\n ============================================================== */\n.product-review {\n  margin: 0px;\n  padding: 25px; }\n  .product-review li {\n    display: block;\n    padding: 20px 0;\n    list-style: none; }\n    .product-review li .font,\n    .product-review li span {\n      display: inline-block;\n      margin-left: 10px; }\n\n.social-profile {\n  text-align: center;\n  background: rgba(7, 10, 43, 0.8); }\n\n.profile-tab li a.nav-link,\n.customtab li a.nav-link {\n  border: 0px;\n  padding: 15px 20px;\n  color: #67757c; }\n  .profile-tab li a.nav-link.active,\n  .customtab li a.nav-link.active {\n    border-bottom: 2px solid #009efb;\n    color: #009efb; }\n  .profile-tab li a.nav-link:hover,\n  .customtab li a.nav-link:hover {\n    color: #009efb; }\n\n/*============================================================== \nForm addons page\n============================================================== */\n/*Bootstrap select*/\n.bootstrap-select:not([class*=col-]):not([class*=form-control]):not(.input-group-btn) {\n  width: 100%; }\n\n.bootstrap-select .dropdown-menu li a {\n  display: block;\n  padding: 7px 20px;\n  clear: both;\n  font-weight: 400;\n  line-height: 1.42857143;\n  color: #67757c;\n  white-space: nowrap; }\n  .bootstrap-select .dropdown-menu li a:hover {\n    color: #009efb;\n    background: #f2f4f8; }\n\n.bootstrap-touchspin .input-group-btn-vertical > .btn {\n  padding: 9px 10px; }\n\n/*============================================================== \nForm Material page\n ============================================================== */\n/*Material inputs*/\n.form-material .form-group {\n  overflow: hidden; }\n\n.form-material .form-control {\n  background-color: transparent;\n  background-position: center bottom, center calc(100% - 1px);\n  background-repeat: no-repeat;\n  background-size: 0 2px, 100% 1px;\n  padding: 0;\n  -webkit-transition: background 0s ease-out 0s;\n  -o-transition: background 0s ease-out 0s;\n  transition: background 0s ease-out 0s; }\n\n.form-material .form-control,\n.form-material .form-control.focus,\n.form-material .form-control:focus {\n  background-image: -webkit-gradient(linear, left top, left bottom, from(#009efb), to(#009efb)), -webkit-gradient(linear, left top, left bottom, from(#d9d9d9), to(#d9d9d9));\n  background-image: -webkit-linear-gradient(#009efb, #009efb), -webkit-linear-gradient(#d9d9d9, #d9d9d9);\n  background-image: -o-linear-gradient(#009efb, #009efb), -o-linear-gradient(#d9d9d9, #d9d9d9);\n  background-image: linear-gradient(#009efb, #009efb), linear-gradient(#d9d9d9, #d9d9d9);\n  border: 0 none;\n  border-radius: 0;\n  -webkit-box-shadow: none;\n  box-shadow: none;\n  float: none; }\n\n.form-material .form-control.focus,\n.form-material .form-control:focus {\n  background-size: 100% 2px, 100% 1px;\n  outline: 0 none;\n  -webkit-transition-duration: 0.3s;\n  -o-transition-duration: 0.3s;\n  transition-duration: 0.3s; }\n\n.form-control-line .form-group {\n  overflow: hidden; }\n\n.form-control-line .form-control {\n  border: 0px;\n  border-radius: 0px;\n  padding-left: 0px;\n  border-bottom: 1px solid #d9d9d9; }\n  .form-control-line .form-control:focus {\n    border-bottom: 1px solid #009efb; }\n\n/*******************/\n/*Floating Label*/\n/*******************/\n.floating-labels .form-group {\n  position: relative; }\n\n.floating-labels .form-control {\n  padding: 10px 10px 10px 0;\n  display: block;\n  border: none;\n  font-family: \"Poppins\", sans-serif;\n  border-radius: 0px;\n  border-bottom: 1px solid #d9d9d9; }\n\n.floating-labels select.form-control > option {\n  font-size: 14px; }\n\n.floating-labels .has-error .form-control {\n  border-bottom: 1px solid #fc4b6c; }\n\n.floating-labels .has-warning .form-control {\n  border-bottom: 1px solid #ffb22b; }\n\n.floating-labels .has-success .form-control {\n  border-bottom: 1px solid #26c6da; }\n\n.floating-labels .form-control:focus {\n  outline: none;\n  border: none; }\n\n.floating-labels label {\n  color: #67757c;\n  position: absolute;\n  cursor: auto;\n  top: 5px;\n  -o-transition: 0.2s ease all;\n  transition: 0.2s ease all;\n  -moz-transition: 0.2s ease all;\n  -webkit-transition: 0.2s ease all; }\n\n.floating-labels .form-control:focus ~ label,\n.floating-labels .form-control:valid ~ label {\n  top: -20px;\n  font-size: 12px;\n  color: #263238; }\n\n.floating-labels .bar {\n  position: relative;\n  display: block; }\n\n.floating-labels .bar:before,\n.floating-labels .bar:after {\n  content: '';\n  height: 2px;\n  width: 0;\n  bottom: 1px;\n  position: absolute;\n  background: #009efb;\n  -o-transition: 0.2s ease all;\n  transition: 0.2s ease all;\n  -moz-transition: 0.2s ease all;\n  -webkit-transition: 0.2s ease all; }\n\n.floating-labels .bar:before {\n  left: 50%; }\n\n.floating-labels .bar:after {\n  right: 50%; }\n\n.floating-labels .form-control:focus ~ .bar:before,\n.floating-labels .form-control:focus ~ .bar:after {\n  width: 50%; }\n\n.floating-labels .highlight {\n  position: absolute;\n  height: 60%;\n  width: 100px;\n  top: 25%;\n  left: 0;\n  pointer-events: none;\n  opacity: 0.5; }\n\n.floating-labels .input-lg ~ label,\n.floating-labels .input-lg {\n  font-size: 24px; }\n\n.floating-labels .input-sm ~ label,\n.floating-labels .input-sm {\n  font-size: 16px; }\n\n.has-warning .bar:before,\n.has-warning .bar:after {\n  background: #ffb22b; }\n\n.has-success .bar:before,\n.has-success .bar:after {\n  background: #26c6da; }\n\n.has-error .bar:before,\n.has-error .bar:after {\n  background: #fc4b6c; }\n\n.has-warning .form-control:focus ~ label,\n.has-warning .form-control:valid ~ label {\n  color: #ffb22b; }\n\n.has-success .form-control:focus ~ label,\n.has-success .form-control:valid ~ label {\n  color: #26c6da; }\n\n.has-error .form-control:focus ~ label,\n.has-error .form-control:valid ~ label {\n  color: #fc4b6c; }\n\n.has-feedback label ~ .t-0 {\n  top: 0; }\n\n.form-group.error input,\n.form-group.error select,\n.form-group.error textarea {\n  border: 1px solid #fc4b6c; }\n\n.form-group.validate input,\n.form-group.validate select,\n.form-group.validate textarea {\n  border: 1px solid #26c6da; }\n\n.form-group.error .help-block ul {\n  padding: 0px;\n  color: #fc4b6c; }\n  .form-group.error .help-block ul li {\n    list-style: none; }\n\n.form-group.issue .help-block ul {\n  padding: 0px;\n  color: #ffb22b; }\n  .form-group.issue .help-block ul li {\n    list-style: none; }\n\n/*******************\nPagination\n******************/\n.pagination-circle li.active a {\n  background: #26c6da; }\n\n.pagination-circle li a {\n  width: 40px;\n  height: 40px;\n  background: #f2f4f8;\n  border: 0px;\n  text-align: center;\n  border-radius: 100%; }\n  .pagination-circle li a:first-child, .pagination-circle li a:last-child {\n    border-radius: 100%; }\n  .pagination-circle li a:hover {\n    background: #26c6da;\n    color: #ffffff; }\n\n.pagination-circle li.disabled a {\n  background: #f2f4f8;\n  color: rgba(120, 130, 140, 0.13); }\n\n/*******************\nForm Dropzone\n******************/\n.dropzone {\n  border: 1px dashed #d9d9d9; }\n  .dropzone .dz-message {\n    padding: 5% 0;\n    margin: 0px; }\n\n/*******************\nForm Pickers\n******************/\n.asColorPicker-dropdown {\n  max-width: 260px; }\n\n.asColorPicker-trigger {\n  position: absolute;\n  top: 0;\n  right: -35px;\n  height: 38px;\n  width: 37px;\n  border: 0; }\n\n.asColorPicker-clear {\n  display: none;\n  position: absolute;\n  top: 5px;\n  right: 10px;\n  text-decoration: none; }\n\ntable th {\n  font-weight: 400; }\n\n.daterangepicker td.active,\n.daterangepicker td.active:hover {\n  background-color: #009efb; }\n\n.datepicker table tr td.today,\n.datepicker table tr td.today.disabled,\n.datepicker table tr td.today.disabled:hover,\n.datepicker table tr td.today:hover {\n  background: #009efb;\n  color: #ffffff; }\n\n.datepicker td,\n.datepicker th {\n  padding: 5px 10px; }\n\n/*******************\nForm icheck\n******************/\n.icolors,\n.icheck-list {\n  padding: 0;\n  margin: 0;\n  list-style: none; }\n\n.icolors > li {\n  padding: 0;\n  margin: 2px;\n  float: left;\n  display: inline-block;\n  height: 30px;\n  width: 30px;\n  background: #263238;\n  text-align: center; }\n\n.icolors > li.active:after {\n  content: \"\\2713 \";\n  color: #ffffff;\n  line-height: 30px; }\n\n.icolors > li:first-child {\n  margin-left: 0; }\n\n.icolors > li.orange {\n  background: #fc4b6c; }\n\n.icolors > li.yellow {\n  background: #ffb22b; }\n\n.icolors > li.info {\n  background: #1e88e5; }\n\n.icolors > li.green {\n  background: #26c6da; }\n\n.icolors > li.red {\n  background: #fb3a3a; }\n\n.icolors > li.purple {\n  background: #7460ee; }\n\n.icolors > li.blue {\n  background: #02bec9; }\n\n.icheck-list {\n  float: left;\n  padding-right: 50px;\n  padding-top: 10px; }\n\n.icheck-list li {\n  padding-bottom: 5px; }\n\n.icheck-list li label {\n  padding-left: 10px; }\n\n/*******************\nForm summernote\n******************/\n.note-popover,\n.note-icon-caret {\n  display: none; }\n\n.note-editor.note-frame {\n  border: 1px solid #d9d9d9; }\n  .note-editor.note-frame .panel-heading {\n    padding: 6px 10px 10px;\n    border-bottom: 1px solid rgba(120, 130, 140, 0.13); }\n\n.label {\n  display: inline-block; }\n\n/*******************\nTable-Layout\n******************/\n.table thead th,\n.table th {\n  border: 0px; }\n\n.color-table.primary-table thead th {\n  background-color: #7460ee;\n  color: #ffffff; }\n\n.table-striped tbody tr:nth-of-type(odd) {\n  background: #f2f4f8; }\n\n.color-table.success-table thead th {\n  background-color: #26c6da;\n  color: #ffffff; }\n\n.color-table.info-table thead th {\n  background-color: #1e88e5;\n  color: #ffffff; }\n\n.color-table.warning-table thead th {\n  background-color: #ffb22b;\n  color: #ffffff; }\n\n.color-table.danger-table thead th {\n  background-color: #fc4b6c;\n  color: #ffffff; }\n\n.color-table.inverse-table thead th {\n  background-color: #2f3d4a;\n  color: #ffffff; }\n\n.color-table.dark-table thead th {\n  background-color: #263238;\n  color: #ffffff; }\n\n.color-table.red-table thead th {\n  background-color: #fb3a3a;\n  color: #ffffff; }\n\n.color-table.purple-table thead th {\n  background-color: #7460ee;\n  color: #ffffff; }\n\n.color-table.muted-table thead th {\n  background-color: #99abb4;\n  color: #ffffff; }\n\n.color-bordered-table.primary-bordered-table {\n  border: 2px solid #7460ee; }\n  .color-bordered-table.primary-bordered-table thead th {\n    background-color: #7460ee;\n    color: #ffffff; }\n\n.color-bordered-table.success-bordered-table {\n  border: 2px solid #26c6da; }\n  .color-bordered-table.success-bordered-table thead th {\n    background-color: #26c6da;\n    color: #ffffff; }\n\n.color-bordered-table.info-bordered-table {\n  border: 2px solid #1e88e5; }\n  .color-bordered-table.info-bordered-table thead th {\n    background-color: #1e88e5;\n    color: #ffffff; }\n\n.color-bordered-table.warning-bordered-table {\n  border: 2px solid #ffb22b; }\n  .color-bordered-table.warning-bordered-table thead th {\n    background-color: #ffb22b;\n    color: #ffffff; }\n\n.color-bordered-table.danger-bordered-table {\n  border: 2px solid #fc4b6c; }\n  .color-bordered-table.danger-bordered-table thead th {\n    background-color: #fc4b6c;\n    color: #ffffff; }\n\n.color-bordered-table.inverse-bordered-table {\n  border: 2px solid #2f3d4a; }\n  .color-bordered-table.inverse-bordered-table thead th {\n    background-color: #2f3d4a;\n    color: #ffffff; }\n\n.color-bordered-table.dark-bordered-table {\n  border: 2px solid #263238; }\n  .color-bordered-table.dark-bordered-table thead th {\n    background-color: #263238;\n    color: #ffffff; }\n\n.color-bordered-table.red-bordered-table {\n  border: 2px solid #fb3a3a; }\n  .color-bordered-table.red-bordered-table thead th {\n    background-color: #fb3a3a;\n    color: #ffffff; }\n\n.color-bordered-table.purple-bordered-table {\n  border: 2px solid #7460ee; }\n  .color-bordered-table.purple-bordered-table thead th {\n    background-color: #7460ee;\n    color: #ffffff; }\n\n.color-bordered-table.muted-bordered-table {\n  border: 2px solid #99abb4; }\n  .color-bordered-table.muted-bordered-table thead th {\n    background-color: #99abb4;\n    color: #ffffff; }\n\n.full-color-table.full-primary-table {\n  background-color: #f1effd; }\n  .full-color-table.full-primary-table thead th {\n    background-color: #7460ee;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-primary-table tbody td {\n    border: 0; }\n  .full-color-table.full-primary-table tr:hover {\n    background-color: #7460ee;\n    color: #ffffff; }\n\n.full-color-table.full-success-table {\n  background-color: #e8fdeb; }\n  .full-color-table.full-success-table thead th {\n    background-color: #26c6da;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-success-table tbody td {\n    border: 0; }\n  .full-color-table.full-success-table tr:hover {\n    background-color: #26c6da;\n    color: #ffffff; }\n\n.full-color-table.full-info-table {\n  background-color: #cfecfe; }\n  .full-color-table.full-info-table thead th {\n    background-color: #1e88e5;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-info-table tbody td {\n    border: 0; }\n  .full-color-table.full-info-table tr:hover {\n    background-color: #1e88e5;\n    color: #ffffff; }\n\n.full-color-table.full-warning-table {\n  background-color: #fff8ec; }\n  .full-color-table.full-warning-table thead th {\n    background-color: #ffb22b;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-warning-table tbody td {\n    border: 0; }\n  .full-color-table.full-warning-table tr:hover {\n    background-color: #ffb22b;\n    color: #ffffff; }\n\n.full-color-table.full-danger-table {\n  background-color: #f9e7eb; }\n  .full-color-table.full-danger-table thead th {\n    background-color: #fc4b6c;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-danger-table tbody td {\n    border: 0; }\n  .full-color-table.full-danger-table tr:hover {\n    background-color: #fc4b6c;\n    color: #ffffff; }\n\n.full-color-table.full-inverse-table {\n  background-color: #f6f6f6; }\n  .full-color-table.full-inverse-table thead th {\n    background-color: #2f3d4a;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-inverse-table tbody td {\n    border: 0; }\n  .full-color-table.full-inverse-table tr:hover {\n    background-color: #2f3d4a;\n    color: #ffffff; }\n\n.full-color-table.full-dark-table {\n  background-color: rgba(43, 43, 43, 0.8); }\n  .full-color-table.full-dark-table thead th {\n    background-color: #263238;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-dark-table tbody td {\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-dark-table tr:hover {\n    background-color: #263238;\n    color: #ffffff; }\n\n.full-color-table.full-red-table {\n  background-color: #f9e7eb; }\n  .full-color-table.full-red-table thead th {\n    background-color: #fb3a3a;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-red-table tbody td {\n    border: 0; }\n  .full-color-table.full-red-table tr:hover {\n    background-color: #fb3a3a;\n    color: #ffffff; }\n\n.full-color-table.full-purple-table {\n  background-color: #f1effd; }\n  .full-color-table.full-purple-table thead th {\n    background-color: #7460ee;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-purple-table tbody td {\n    border: 0; }\n  .full-color-table.full-purple-table tr:hover {\n    background-color: #7460ee;\n    color: #ffffff; }\n\n.full-color-table.full-muted-table {\n  background-color: rgba(152, 166, 173, 0.2); }\n  .full-color-table.full-muted-table thead th {\n    background-color: #99abb4;\n    border: 0;\n    color: #ffffff; }\n  .full-color-table.full-muted-table tbody td {\n    border: 0; }\n  .full-color-table.full-muted-table tr:hover {\n    background-color: #99abb4;\n    color: #ffffff; }\n\n/*******************\nTable-Data Table\n******************/\n.dt-buttons {\n  display: inline-block;\n  padding-top: 5px; }\n  .dt-buttons .dt-button {\n    padding: 5px 15px;\n    border-radius: 4px;\n    background: #009efb;\n    color: #ffffff;\n    margin-right: 3px; }\n    .dt-buttons .dt-button:hover {\n      background: #2f3d4a; }\n\n.dataTables_info,\n.dataTables_length {\n  display: inline-block; }\n\n.dataTables_filter {\n  float: right; }\n  .dataTables_filter input {\n    border: 1px solid #d9d9d9; }\n\ntable.dataTable thead .sorting,\ntable.dataTable thead .sorting_asc,\ntable.dataTable thead .sorting_desc,\ntable.dataTable thead .sorting_asc_disabled,\ntable.dataTable thead .sorting_desc_disabled {\n  background: transparent; }\n\ntable.dataTable thead .sorting_asc:after {\n  content: \"\\f0de\";\n  margin-left: 10px;\n  font-family: fontawesome;\n  cursor: pointer; }\n\ntable.dataTable thead .sorting_desc:after {\n  content: \"\\f0dd\";\n  margin-left: 10px;\n  font-family: fontawesome;\n  cursor: pointer; }\n\ntable.dataTable thead .sorting:after {\n  content: \"\\f0dc\";\n  margin-left: 10px;\n  font-family: fontawesome !important;\n  cursor: pointer;\n  color: rgba(50, 50, 50, 0.5); }\n\n.dataTables_wrapper .dataTables_paginate {\n  float: right;\n  text-align: right;\n  padding-top: 0.25em; }\n\n.dataTables_wrapper .dataTables_paginate .paginate_button {\n  -webkit-box-sizing: border-box;\n  box-sizing: border-box;\n  display: inline-block;\n  min-width: 1.5em;\n  padding: 0.5em 1em;\n  margin-left: 2px;\n  text-align: center;\n  text-decoration: none;\n  cursor: pointer;\n  *cursor: hand;\n  color: #67757c;\n  border: 1px solid transparent;\n  border-radius: 2px; }\n\n.dataTables_wrapper .dataTables_paginate .paginate_button.current,\n.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {\n  color: #ffffff !important;\n  border: 1px solid #1e88e5;\n  background-color: #1e88e5; }\n\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover,\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:active {\n  cursor: default;\n  color: #67757c;\n  border: 1px solid transparent;\n  background: transparent;\n  -webkit-box-shadow: none;\n  box-shadow: none; }\n\n.dataTables_wrapper .dataTables_paginate .paginate_button:hover {\n  color: white !important;\n  border: 1px solid #7460ee;\n  background-color: #7460ee; }\n\n.dataTables_wrapper .dataTables_paginate .paginate_button:active {\n  outline: none;\n  background-color: #67757c; }\n\n.dataTables_wrapper .dataTables_paginate .ellipsis {\n  padding: 0 1em; }\n\n/*******************\nTable- responsive\n******************/\n.tablesaw-bar .btn-group label {\n  color: #67757c !important; }\n\n/*******************\nTable- editable table\n******************/\n.dt-bootstrap {\n  display: block; }\n\n.paging_simple_numbers .pagination .paginate_button {\n  padding: 0px;\n  background: #ffffff; }\n  .paging_simple_numbers .pagination .paginate_button:hover {\n    background: #ffffff; }\n  .paging_simple_numbers .pagination .paginate_button a {\n    padding: 5px 10px;\n    border-radius: 4px;\n    border: 0px; }\n  .paging_simple_numbers .pagination .paginate_button.active a,\n  .paging_simple_numbers .pagination .paginate_button:hover a {\n    background: #1e88e5;\n    color: #ffffff; }\n\n/*******************\nTable- Footable\n******************/\n.footable .pagination {\n  display: inline-block;\n  padding: 8px 0; }\n  .footable .pagination li {\n    padding: 0px;\n    margin: 0 1px;\n    display: inline-block; }\n    .footable .pagination li a {\n      padding: 5px 10px; }\n      .footable .pagination li a:hover, .footable .pagination li a.active {\n        background: #1e88e5;\n        color: #ffffff;\n        border-radius: 4px; }\n    .footable .pagination li.active a {\n      color: #ffffff;\n      border-radius: 4px; }\n\n.footable-odd {\n  background: #f2f4f8; }\n\n/*******************\nIcon list fontawesom\n******************/\n.icon-list-demo div {\n  cursor: pointer;\n  line-height: 60px;\n  white-space: nowrap;\n  color: #67757c; }\n  .icon-list-demo div:hover {\n    color: #263238; }\n  .icon-list-demo div p {\n    margin: 10px 0;\n    padding: 5px 0; }\n\n.icon-list-demo i {\n  -webkit-transition: all 0.2s;\n  -webkit-transition: font-size .2s;\n  display: inline-block;\n  font-size: 18px;\n  margin: 0 15px 0 10px;\n  text-align: left;\n  -o-transition: all 0.2s;\n  transition: all 0.2s;\n  -o-transition: font-size .2s;\n  transition: font-size .2s;\n  vertical-align: middle;\n  -webkit-transition: all 0.3s ease 0s;\n  -o-transition: all 0.3s ease 0s;\n  transition: all 0.3s ease 0s; }\n\n.icon-list-demo .col-md-4,\n.icon-list-demo .col-3 {\n  border-radius: 4px; }\n  .icon-list-demo .col-md-4:hover,\n  .icon-list-demo .col-3:hover {\n    background-color: #ebf3f5; }\n\n.icon-list-demo .div:hover i {\n  font-size: 2em; }\n\n/*******************\nIcon list material icon\n******************/\n.material-icon-list-demo .mdi {\n  font-size: 21px; }\n\n/*******************\nGridstack Dragable portlet\n******************/\n.grid-stack-item-content {\n  background: #fff;\n  color: #2b2b2b;\n  text-align: center;\n  font-size: 20px; }\n\n.grid-stack > .grid-stack-item > .grid-stack-item-content {\n  border: 1px solid rgba(120, 130, 140, 0.13); }\n\n/*******************\nBootstrap Switch\n******************/\n.bootstrap-switch,\n.bootstrap-switch .bootstrap-switch-container {\n  border-radius: 2px; }\n\n.bootstrap-switch .bootstrap-switch-handle-on {\n  border-bottom-left-radius: 2px;\n  border-top-left-radius: 2px; }\n\n.bootstrap-switch .bootstrap-switch-handle-off {\n  border-bottom-right-radius: 2px;\n  border-top-right-radius: 2px; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-primary,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-primary {\n  color: #ffffff;\n  background: #7460ee; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-info,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-info {\n  color: #ffffff;\n  background: #1e88e5; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-success,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success {\n  color: #ffffff;\n  background: #26c6da; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-warning,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-warning {\n  color: #ffffff;\n  background: #ffb22b; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-danger,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-danger {\n  color: #ffffff;\n  background: #fc4b6c; }\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-default,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-default {\n  color: #263238;\n  background: #f2f4f8; }\n\n.onoffswitch {\n  position: relative;\n  width: 90px;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none; }\n\n.onoffswitch-checkbox {\n  display: none; }\n\n.onoffswitch-label {\n  display: block;\n  overflow: hidden;\n  cursor: pointer;\n  border: 2px solid #26c6da;\n  border-radius: 20px; }\n\n.onoffswitch-inner {\n  display: block;\n  width: 200%;\n  margin-left: -100%;\n  -webkit-transition: margin 0.3s ease-in 0s;\n  -o-transition: margin 0.3s ease-in 0s;\n  transition: margin 0.3s ease-in 0s; }\n\n.onoffswitch-inner:before,\n.onoffswitch-inner:after {\n  display: block;\n  float: left;\n  width: 50%;\n  height: 30px;\n  padding: 0;\n  line-height: 30px;\n  font-size: 14px;\n  color: white;\n  -webkit-box-sizing: border-box;\n  box-sizing: border-box; }\n\n.onoffswitch-inner:before {\n  content: \"ON\";\n  padding-left: 27px;\n  background-color: #26c6da;\n  color: #FFFFFF; }\n\n.onoffswitch-inner:after {\n  content: \"OFF\";\n  padding-right: 24px;\n  background-color: #EEEEEE;\n  color: #999999;\n  text-align: right; }\n\n.onoffswitch-switch {\n  display: block;\n  width: 23px;\n  margin: 6px;\n  background: #FFFFFF;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 56px;\n  border: 2px solid #26c6da;\n  border-radius: 20px;\n  -webkit-transition: all 0.3s ease-in 0s;\n  -o-transition: all 0.3s ease-in 0s;\n  transition: all 0.3s ease-in 0s; }\n\n.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {\n  margin-left: 0; }\n\n.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {\n  right: 0px; }\n\n/*******************\nDate paginator page\n******************/\n.dp-selected[style] {\n  background-color: #009efb !important; }\n\n.datepaginator-sm .pagination li a,\n.datepaginator-lg .pagination li a,\n.datepaginator .pagination li a {\n  padding: 0 5px;\n  height: 60px;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  float: left;\n  position: relative; }\n\n/*******************\nsweet alert page\n******************/\n.model_img {\n  cursor: pointer; }\n\n/*******************\nGrid page\n******************/\n.show-grid {\n  margin-bottom: 10px;\n  padding: 0 15px; }\n\n.show-grid [class^=col-] {\n  padding-top: 10px;\n  padding-bottom: 10px;\n  border: 1px solid #d9d9d9;\n  background-color: #f2f4f8; }\n\n/*******************\nVertical tabs\n******************/\n.vtabs {\n  display: table; }\n  .vtabs .tabs-vertical {\n    width: 150px;\n    border-bottom: 0px;\n    border-right: 1px solid rgba(120, 130, 140, 0.13);\n    display: table-cell;\n    vertical-align: top; }\n    .vtabs .tabs-vertical li .nav-link {\n      color: #263238;\n      margin-bottom: 10px;\n      border: 0px;\n      border-radius: 4px 0 0 4px; }\n  .vtabs .tab-content {\n    display: table-cell;\n    padding: 20px;\n    vertical-align: top; }\n\n.tabs-vertical li .nav-link.active,\n.tabs-vertical li .nav-link:hover,\n.tabs-vertical li .nav-link.active:focus {\n  background: #009efb;\n  border: 0px;\n  color: #ffffff; }\n\n/*Custom vertical tab*/\n.customvtab .tabs-vertical li .nav-link.active,\n.customvtab .tabs-vertical li .nav-link:hover,\n.customvtab .tabs-vertical li .nav-link:focus {\n  background: #ffffff;\n  border: 0px;\n  border-right: 2px solid #009efb;\n  margin-right: -1px;\n  color: #009efb; }\n\n.tabcontent-border {\n  border: 1px solid #ddd;\n  border-top: 0px; }\n\n.customtab2 li a.nav-link {\n  border: 0px;\n  margin-right: 3px;\n  color: #67757c; }\n  .customtab2 li a.nav-link.active {\n    background: #009efb;\n    color: #ffffff; }\n  .customtab2 li a.nav-link:hover {\n    color: #ffffff;\n    background: #009efb; }\n\n/*******************\nProgress bar\n******************/\n.progress.active .progress-bar,\n.progress-bar.active {\n  -webkit-animation: progress-bar-stripes 2s linear infinite;\n  -o-animation: progress-bar-stripes 2s linear infinite;\n  animation: progress-bar-stripes 2s linear infinite; }\n\n.progress-vertical {\n  min-height: 250px;\n  height: 250px;\n  position: relative;\n  display: inline-block;\n  margin-bottom: 0;\n  margin-right: 20px; }\n\n.progress-vertical-bottom {\n  min-height: 250px;\n  height: 250px;\n  position: relative;\n  display: inline-block;\n  margin-bottom: 0;\n  margin-right: 20px;\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg); }\n\n.progress-animated {\n  -webkit-animation-duration: 5s;\n  -webkit-animation-name: myanimation;\n  -webkit-transition: 5s all;\n  animation-duration: 5s;\n  animation-name: myanimation;\n  -o-transition: 5s all;\n  transition: 5s all; }\n\n@-webkit-keyframes myanimation {\n  from {\n    width: 0; } }\n\n@keyframes myanimation {\n  from {\n    width: 0; } }\n\n/*******************\nNotification page Jquery toaster\n******************/\n.jq-icon-info {\n  background-color: #1e88e5;\n  color: #ffffff; }\n\n.jq-icon-success {\n  background-color: #26c6da;\n  color: #ffffff; }\n\n.jq-icon-error {\n  background-color: #fc4b6c;\n  color: #ffffff; }\n\n.jq-icon-warning {\n  background-color: #ffb22b;\n  color: #ffffff; }\n\n.alert-rounded {\n  border-radius: 60px; }\n\n/*******************\nlist and media\n******************/\n.list-group a.list-group-item:hover {\n  background: #f2f4f8; }\n\n.list-group-item.active,\n.list-group .list-group-item.active:hover {\n  background: #009efb;\n  border-color: #009efb; }\n\n.list-group-item.disabled {\n  color: #99abb4;\n  background: #f2f4f8; }\n\n.media {\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  margin-bottom: 10px;\n  padding: 15px; }\n\n/*******************\nUser card page\n******************/\n.el-element-overlay .white-box {\n  padding: 0px; }\n\n.el-element-overlay .el-card-item {\n  position: relative;\n  padding-bottom: 25px; }\n  .el-element-overlay .el-card-item .el-card-avatar {\n    margin-bottom: 15px; }\n  .el-element-overlay .el-card-item .el-card-content {\n    text-align: center; }\n    .el-element-overlay .el-card-item .el-card-content h3 {\n      margin: 0px; }\n    .el-element-overlay .el-card-item .el-card-content a {\n      color: #67757c; }\n      .el-element-overlay .el-card-item .el-card-content a:hover {\n        color: #009efb; }\n  .el-element-overlay .el-card-item .el-overlay-1 {\n    width: 100%;\n    height: 100%;\n    overflow: hidden;\n    position: relative;\n    text-align: center;\n    cursor: default; }\n    .el-element-overlay .el-card-item .el-overlay-1 img {\n      display: block;\n      position: relative;\n      -webkit-transition: all .4s linear;\n      -o-transition: all .4s linear;\n      transition: all .4s linear;\n      width: 100%;\n      height: auto; }\n    .el-element-overlay .el-card-item .el-overlay-1:hover img {\n      -ms-transform: scale(1.2) translateZ(0);\n      -webkit-transform: scale(1.2) translateZ(0);\n      /* transform: scale(1.2) translateZ(0); */ }\n    .el-element-overlay .el-card-item .el-overlay-1 .el-info {\n      text-decoration: none;\n      display: inline-block;\n      text-transform: uppercase;\n      color: #ffffff;\n      background-color: transparent;\n      filter: alpha(opacity=0);\n      -webkit-transition: all .2s ease-in-out;\n      -o-transition: all .2s ease-in-out;\n      transition: all .2s ease-in-out;\n      padding: 0;\n      margin: auto;\n      position: absolute;\n      top: 50%;\n      left: 0;\n      right: 0;\n      transform: translateY(-50%) translateZ(0);\n      -webkit-transform: translateY(-50%) translateZ(0);\n      -ms-transform: translateY(-50%) translateZ(0); }\n      .el-element-overlay .el-card-item .el-overlay-1 .el-info > li {\n        list-style: none;\n        display: inline-block;\n        margin: 0 3px; }\n        .el-element-overlay .el-card-item .el-overlay-1 .el-info > li a {\n          border-color: #ffffff;\n          color: #ffffff;\n          padding: 12px 15px 10px; }\n          .el-element-overlay .el-card-item .el-overlay-1 .el-info > li a:hover {\n            background: #009efb;\n            border-color: #009efb; }\n  .el-element-overlay .el-card-item .el-overlay {\n    width: 100%;\n    height: 100%;\n    position: absolute;\n    overflow: hidden;\n    top: 0;\n    left: 0;\n    opacity: 0;\n    background-color: rgba(0, 0, 0, 0.7);\n    -webkit-transition: all .4s ease-in-out;\n    -o-transition: all .4s ease-in-out;\n    transition: all .4s ease-in-out; }\n  .el-element-overlay .el-card-item .el-overlay-1:hover .el-overlay {\n    opacity: 1;\n    filter: alpha(opacity=100);\n    -webkit-transform: translateZ(0);\n    -ms-transform: translateZ(0);\n    transform: translateZ(0); }\n  .el-element-overlay .el-card-item .el-overlay-1 .scrl-dwn {\n    top: -100%; }\n  .el-element-overlay .el-card-item .el-overlay-1 .scrl-up {\n    top: 100%;\n    height: 0px; }\n  .el-element-overlay .el-card-item .el-overlay-1:hover .scrl-dwn {\n    top: 0px; }\n  .el-element-overlay .el-card-item .el-overlay-1:hover .scrl-up {\n    top: 0px;\n    height: 100%; }\n\n/*******************\nTimeline page\n******************/\n.timeline {\n  position: relative;\n  padding: 20px 0 20px;\n  list-style: none;\n  max-width: 1200px;\n  margin: 0 auto; }\n\n.timeline:before {\n  content: \" \";\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  left: 50%;\n  width: 3px;\n  margin-left: -1.5px;\n  background-color: #f2f4f8; }\n\n.timeline > li {\n  position: relative;\n  margin-bottom: 20px; }\n\n.timeline > li:before,\n.timeline > li:after {\n  content: \" \";\n  display: table; }\n\n.timeline > li:after {\n  clear: both; }\n\n.timeline > li:before,\n.timeline > li:after {\n  content: \" \";\n  display: table; }\n\n.timeline > li:after {\n  clear: both; }\n\n.timeline > li > .timeline-panel {\n  float: left;\n  position: relative;\n  width: 46%;\n  padding: 20px;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  border-radius: 4px;\n  -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);\n  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05); }\n\n.timeline > li > .timeline-panel:before {\n  content: \" \";\n  display: inline-block;\n  position: absolute;\n  top: 26px;\n  right: -8px;\n  border-top: 8px solid transparent;\n  border-right: 0 solid rgba(120, 130, 140, 0.13);\n  border-bottom: 8px solid transparent;\n  border-left: 8px solid rgba(120, 130, 140, 0.13); }\n\n.timeline > li > .timeline-panel:after {\n  content: \" \";\n  display: inline-block;\n  position: absolute;\n  top: 27px;\n  right: -7px;\n  border-top: 7px solid transparent;\n  border-right: 0 solid #ffffff;\n  border-bottom: 7px solid transparent;\n  border-left: 7px solid #ffffff; }\n\n.timeline > li > .timeline-badge {\n  z-index: 10;\n  position: absolute;\n  top: 16px;\n  left: 50%;\n  width: 50px;\n  height: 50px;\n  margin-left: -25px;\n  border-radius: 50% 50% 50% 50%;\n  text-align: center;\n  font-size: 1.4em;\n  line-height: 50px;\n  color: #fff;\n  overflow: hidden; }\n\n.timeline > li.timeline-inverted > .timeline-panel {\n  float: right; }\n\n.timeline > li.timeline-inverted > .timeline-panel:before {\n  right: auto;\n  left: -8px;\n  border-right-width: 8px;\n  border-left-width: 0; }\n\n.timeline > li.timeline-inverted > .timeline-panel:after {\n  right: auto;\n  left: -7px;\n  border-right-width: 7px;\n  border-left-width: 0; }\n\n.timeline-badge.primary {\n  background-color: #7460ee; }\n\n.timeline-badge.success {\n  background-color: #26c6da; }\n\n.timeline-badge.warning {\n  background-color: #ffb22b; }\n\n.timeline-badge.danger {\n  background-color: #fc4b6c; }\n\n.timeline-badge.info {\n  background-color: #1e88e5; }\n\n.timeline-title {\n  margin-top: 0;\n  color: inherit;\n  font-weight: 400; }\n\n.timeline-body > p,\n.timeline-body > ul {\n  margin-bottom: 0; }\n\n.timeline-body > p + p {\n  margin-top: 5px; }\n\n/*******************\nHorizontal Timeline page\n******************/\n.cd-horizontal-timeline .events a {\n  padding-bottom: 6px;\n  color: #009efb; }\n\n.cd-horizontal-timeline .filling-line,\n.cd-horizontal-timeline .events a.selected::after {\n  background: #009efb; }\n\n.cd-horizontal-timeline .events a.selected::after {\n  border-color: #009efb; }\n\n.myadmin-dd .dd-list .dd-item .dd-handle {\n  background: #ffffff;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  padding: 8px 16px;\n  height: auto;\n  font-family: \"Poppins\", sans-serif;\n  font-weight: 400;\n  border-radius: 0; }\n\n.myadmin-dd-empty .dd-list .dd3-content {\n  height: auto;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  padding: 8px 16px 8px 46px;\n  background: #ffffff;\n  font-weight: 400; }\n\n.myadmin-dd-empty .dd-list .dd3-handle {\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  border-bottom: 0;\n  background: #ffffff;\n  height: 36px;\n  width: 36px; }\n\n.dd3-handle:before {\n  color: #67757c;\n  top: 7px; }\n\n/*******************\nribbons page\n******************/\n.ribbon-wrapper,\n.ribbon-wrapper-reverse,\n.ribbon-wrapper-bottom,\n.ribbon-wrapper-right-bottom {\n  position: relative;\n  padding: 50px 15px 15px 15px; }\n\n.ribbon-vwrapper {\n  padding: 15px 15px 15px 50px;\n  position: relative; }\n\n.ribbon-overflow {\n  overflow: hidden; }\n\n.ribbon-vwrapper-reverse {\n  padding: 15px 50px 15px 15px; }\n\n.ribbon-wrapper-bottom {\n  padding: 15px 15px 50px 50px; }\n\n.ribbon-wrapper-right-bottom {\n  padding: 15px 50px 50px 15px; }\n\n.ribbon-content {\n  margin-bottom: 0px; }\n\n.ribbon {\n  padding: 0 20px;\n  height: 30px;\n  line-height: 30px;\n  clear: left;\n  position: absolute;\n  top: 12px;\n  left: -2px;\n  color: #ffffff; }\n\n.ribbon-bookmark:before {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  display: block;\n  width: 0;\n  height: 0;\n  content: '';\n  border: 15px solid #263238;\n  border-right: 10px solid transparent; }\n\n.ribbon-right {\n  left: auto;\n  right: -2px; }\n\n.ribbon-bookmark.ribbon-right:before {\n  right: 100%;\n  left: auto;\n  border-right: 15px solid #263238;\n  border-left: 10px solid transparent; }\n\n.ribbon-vertical-l,\n.ribbon-vertical-r {\n  clear: none;\n  padding: 0 5px;\n  height: 70px;\n  width: 30px;\n  line-height: 70px;\n  text-align: center;\n  left: 12px;\n  top: -2px; }\n\n.ribbon-vertical-r {\n  left: auto;\n  right: 12px; }\n\n.ribbon-bookmark.ribbon-vertical-l:before,\n.ribbon-bookmark.ribbon-vertical-r:before {\n  top: 100%;\n  left: 0;\n  margin-top: -14px;\n  border-right: 15px solid #263238;\n  border-bottom: 10px solid transparent; }\n\n.ribbon-badge {\n  top: 15px;\n  overflow: hidden;\n  left: -90px;\n  width: 100%;\n  text-align: center;\n  -webkit-transform: rotate(-45deg);\n  -ms-transform: rotate(-45deg);\n  -o-transform: rotate(-45deg);\n  transform: rotate(-45deg); }\n\n.ribbon-badge.ribbon-right {\n  left: auto;\n  right: -90px;\n  -webkit-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg); }\n\n.ribbon-badge.ribbon-bottom {\n  top: auto;\n  bottom: 15px;\n  -webkit-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg); }\n\n.ribbon-badge.ribbon-right.ribbon-bottom {\n  -webkit-transform: rotate(-45deg);\n  -ms-transform: rotate(-45deg);\n  -o-transform: rotate(-45deg);\n  transform: rotate(-45deg); }\n\n.ribbon-corner {\n  top: 0;\n  left: 0;\n  background-color: transparent !important;\n  padding: 6px 0 0 10px; }\n\n.ribbon-corner i {\n  position: relative; }\n\n.ribbon-corner:before {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 0;\n  height: 0;\n  content: '';\n  border: 30px solid transparent;\n  border-top-color: #009efb;\n  border-left-color: #009efb; }\n\n.ribbon-corner.ribbon-right:before {\n  right: 0;\n  left: auto;\n  border-right-color: #526069;\n  border-left-color: transparent; }\n\n.ribbon-corner.ribbon-right {\n  right: 0;\n  left: auto;\n  padding: 6px 10px 0 0; }\n\n.ribbon-corner.ribbon-bottom:before {\n  top: auto;\n  bottom: 0;\n  border-top-color: transparent;\n  border-bottom-color: #526069; }\n\n.ribbon-corner.ribbon-bottom {\n  bottom: 0;\n  top: auto;\n  padding: 0 10px 6px 10px; }\n\n.ribbon-custom {\n  background: #009efb; }\n\n.ribbon-bookmark.ribbon-right.ribbon-custom:before {\n  border-right-color: #009efb;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-custom:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-custom:before {\n  border-right-color: #009efb;\n  border-bottom-color: transparent; }\n\n.ribbon-primary {\n  background: #7460ee; }\n\n.ribbon-bookmark.ribbon-primary:before {\n  border-color: #7460ee;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-primary:before {\n  border-right-color: #7460ee;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-primary:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-primary:before {\n  border-right-color: #7460ee;\n  border-bottom-color: transparent; }\n\n.ribbon-primary.ribbon-corner:before {\n  border-top-color: #7460ee;\n  border-left-color: #7460ee; }\n\n.ribbon-primary.ribbon-corner.ribbon-right:before {\n  border-right-color: #7460ee;\n  border-left-color: transparent; }\n\n.ribbon-primary.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #7460ee; }\n\n.ribbon-success {\n  background: #26c6da; }\n\n.ribbon-bookmark.ribbon-success:before {\n  border-color: #26c6da;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-success:before {\n  border-right-color: #26c6da;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-success:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-success:before {\n  border-right-color: #26c6da;\n  border-bottom-color: transparent; }\n\n.ribbon-success.ribbon-corner:before {\n  border-top-color: #26c6da;\n  border-left-color: #26c6da; }\n\n.ribbon-success.ribbon-corner.ribbon-right:before {\n  border-right-color: #26c6da;\n  border-left-color: transparent; }\n\n.ribbon-success.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #26c6da; }\n\n.ribbon-info {\n  background: #1e88e5; }\n\n.ribbon-bookmark.ribbon-info:before {\n  border-color: #1e88e5;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-info:before {\n  border-right-color: #1e88e5;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-info:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-info:before {\n  border-right-color: #1e88e5;\n  border-bottom-color: transparent; }\n\n.ribbon-info.ribbon-corner:before {\n  border-top-color: #1e88e5;\n  border-left-color: #1e88e5; }\n\n.ribbon-info.ribbon-corner.ribbon-right:before {\n  border-right-color: #1e88e5;\n  border-left-color: transparent; }\n\n.ribbon-info.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #1e88e5; }\n\n.ribbon-warning {\n  background: #ffb22b; }\n\n.ribbon-bookmark.ribbon-warning:before {\n  border-color: #ffb22b;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-warning:before {\n  border-right-color: #ffb22b;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-warning:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-warning:before {\n  border-right-color: #ffb22b;\n  border-bottom-color: transparent; }\n\n.ribbon-warning.ribbon-corner:before {\n  border-top-color: #ffb22b;\n  border-left-color: #ffb22b; }\n\n.ribbon-warning.ribbon-corner.ribbon-right:before {\n  border-right-color: #ffb22b;\n  border-left-color: transparent; }\n\n.ribbon-warning.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #ffb22b; }\n\n.ribbon-danger {\n  background: #fc4b6c; }\n\n.ribbon-bookmark.ribbon-danger:before {\n  border-color: #fc4b6c;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-danger:before {\n  border-right-color: #fc4b6c;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-danger:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-danger:before {\n  border-right-color: #fc4b6c;\n  border-bottom-color: transparent; }\n\n.ribbon-danger.ribbon-corner:before {\n  border-top-color: #fc4b6c;\n  border-left-color: #fc4b6c; }\n\n.ribbon-danger.ribbon-corner.ribbon-right:before {\n  border-right-color: #fc4b6c;\n  border-left-color: transparent; }\n\n.ribbon-danger.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #fc4b6c; }\n\n.ribbon-default {\n  background: #263238; }\n\n.ribbon-bookmark.ribbon-default:before {\n  border-color: #263238;\n  border-right-color: transparent; }\n\n.ribbon-bookmark.ribbon-right.ribbon-default:before {\n  border-right-color: #263238;\n  border-left-color: transparent; }\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-default:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-default:before {\n  border-right-color: #263238;\n  border-bottom-color: transparent; }\n\n.ribbon-default.ribbon-corner:before {\n  border-top-color: #263238;\n  border-left-color: #263238; }\n\n.ribbon-default.ribbon-corner.ribbon-right:before {\n  border-right-color: #263238;\n  border-left-color: transparent; }\n\n.ribbon-default.ribbon-corner.ribbon-bottom:before {\n  border-top-color: transparent;\n  border-bottom-color: #263238; }\n\n/*******************\nsession ideal timeout page\n******************/\n#idletimeout {\n  background: #009efb;\n  border: 3px solid #009efb;\n  color: #fff;\n  font-family: arial, sans-serif;\n  text-align: center;\n  font-size: 12px;\n  padding: 10px;\n  position: relative;\n  top: 0px;\n  left: 0;\n  right: 0;\n  z-index: 100000;\n  display: none; }\n\n#idletimeout a {\n  color: #ffffff;\n  font-weight: bold; }\n\n#idletimeout span {\n  font-weight: bold; }\n\n/*******************\nStylish tooltip\n******************/\n.mytooltip:hover .tooltip-content2, .mytooltip:hover .tooltip-content2 i {\n  opacity: 1;\n  font-size: 18px;\n  pointer-events: auto;\n  -webkit-transform: translate3d(0, 0, 0) scale3d(1, 1, 1);\n  transform: translate3d(0, 0, 0) scale3d(1, 1, 1); }\n\n.mytooltip:hover .tooltip-content4, .mytooltip:hover .tooltip-text2 {\n  pointer-events: auto;\n  opacity: 1;\n  -webkit-transform: translate3d(0, 0, 0);\n  transform: translate3d(0, 0, 0); }\n\n.mytooltip {\n  display: inline;\n  position: relative;\n  z-index: 9999; }\n  .mytooltip:hover .tooltip-item::after {\n    pointer-events: auto; }\n  .mytooltip:hover .tooltip-content {\n    pointer-events: auto;\n    opacity: 1;\n    -webkit-transform: translate3d(0, 0, 0) rotate3d(0, 0, 0, 0);\n    transform: translate3d(0, 0, 0) rotate3d(0, 0, 0, 0); }\n  .mytooltip:hover .tooltip-content3 {\n    opacity: 1;\n    pointer-events: auto;\n    -webkit-transform: scale3d(1, 1, 1);\n    transform: scale3d(1, 1, 1); }\n  .mytooltip:hover .tooltip-item2 {\n    color: #ffffff;\n    -webkit-transform: translate3d(0, -0.5em, 0);\n    transform: translate3d(0, -0.5em, 0); }\n  .mytooltip:hover .tooltip-content5 {\n    opacity: 1;\n    pointer-events: auto;\n    -webkit-transition-delay: 0s;\n    -o-transition-delay: 0s;\n    transition-delay: 0s; }\n  .mytooltip:hover .tooltip-text3 {\n    -webkit-transition-delay: 0s;\n    -o-transition-delay: 0s;\n    transition-delay: 0s;\n    -webkit-transform: scale3d(1, 1, 1);\n    transform: scale3d(1, 1, 1); }\n  .mytooltip:hover .tooltip-inner2 {\n    -webkit-transition-delay: 0.3s;\n    -o-transition-delay: 0.3s;\n    transition-delay: 0.3s;\n    -webkit-transform: translate3d(0, 0, 0);\n    transform: translate3d(0, 0, 0); }\n\n.tooltip-item {\n  background: rgba(0, 0, 0, 0.1);\n  cursor: pointer;\n  display: inline-block;\n  font-weight: 500;\n  padding: 0 10px; }\n\n.tooltip-item::after {\n  content: '';\n  position: absolute;\n  width: 360px;\n  height: 20px;\n  bottom: 100%;\n  left: 50%;\n  pointer-events: none;\n  -webkit-transform: translateX(-50%);\n  -ms-transform: translateX(-50%);\n  transform: translateX(-50%); }\n\n.tooltip-content {\n  position: absolute;\n  z-index: 9999;\n  width: 360px;\n  left: 50%;\n  margin: 0 0 20px -180px;\n  bottom: 100%;\n  text-align: left;\n  font-size: 14px;\n  line-height: 30px;\n  -webkit-box-shadow: -5px -5px 15px rgba(48, 54, 61, 0.2);\n  box-shadow: -5px -5px 15px rgba(48, 54, 61, 0.2);\n  background: #2b2b2b;\n  opacity: 0;\n  cursor: default;\n  pointer-events: none; }\n  .tooltip-content img {\n    position: relative;\n    height: 140px;\n    display: block;\n    float: left;\n    margin-right: 1em; }\n\n.tooltip-effect-5 .tooltip-content {\n  width: 180px;\n  margin-left: -90px;\n  -webkit-transform-origin: 50% calc(106%);\n  -ms-transform-origin: 50% calc(106%);\n  transform-origin: 50% calc(106%);\n  -webkit-transform: rotate3d(0, 0, 1, 15deg);\n  transform: rotate3d(0, 0, 1, 15deg);\n  -webkit-transition: opacity 0.2s, -webkit-transform 0.2s;\n  transition: opacity 0.2s, -webkit-transform 0.2s;\n  -o-transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s, -webkit-transform 0.2s;\n  -webkit-transition-timing-function: ease, cubic-bezier(0.17, 0.67, 0.4, 1.39);\n  -o-transition-timing-function: ease, cubic-bezier(0.17, 0.67, 0.4, 1.39);\n  transition-timing-function: ease, cubic-bezier(0.17, 0.67, 0.4, 1.39); }\n\n.tooltip-effect-5 .tooltip-text {\n  padding: 1.4em; }\n\n.tooltip-content::after {\n  content: '';\n  top: 100%;\n  left: 50%;\n  border: solid transparent;\n  height: 0;\n  width: 0;\n  position: absolute;\n  pointer-events: none;\n  border-color: transparent;\n  border-top-color: #2a3035;\n  border-width: 10px;\n  margin-left: -10px; }\n\n.tooltip-text {\n  font-size: 14px;\n  line-height: 24px;\n  display: block;\n  padding: 1.31em 1.21em 1.21em 0;\n  color: #ffffff; }\n\n.tooltip-content2 {\n  position: absolute;\n  z-index: 9999;\n  width: 80px;\n  height: 80px;\n  padding-top: 25px;\n  left: 50%;\n  margin-left: -40px;\n  bottom: 100%;\n  border-radius: 50%;\n  text-align: center;\n  background: #009efb;\n  color: #ffffff;\n  opacity: 0;\n  margin-bottom: 20px;\n  cursor: default;\n  pointer-events: none; }\n  .tooltip-content2 i {\n    opacity: 0; }\n\n.tooltip-effect-6 .tooltip-content2 {\n  -webkit-transform: translate3d(0, 10px, 0) rotate3d(1, 1, 1, 45deg);\n  transform: translate3d(0, 10px, 0) rotate3d(1, 1, 1, 45deg);\n  -webkit-transform-origin: 50% 100%;\n  -ms-transform-origin: 50% 100%;\n  transform-origin: 50% 100%;\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n  .tooltip-effect-6 .tooltip-content2 i {\n    -webkit-transform: scale3d(0, 0, 1);\n    transform: scale3d(0, 0, 1);\n    -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n    transition: opacity 0.3s, -webkit-transform 0.3s;\n    -o-transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-effect-6:hover .tooltip-content2 i {\n  -webkit-transform: rotate3d(1, 1, 1, 0);\n  transform: rotate3d(1, 1, 1, 0); }\n\n.tooltip-content2::after {\n  content: '';\n  position: absolute;\n  top: 100%;\n  left: 50%;\n  margin: -7px 0 0 -15px;\n  width: 30px;\n  height: 20px;\n  background: url(../../assets/images/tooltip/tooltip1.svg) no-repeat center center;\n  background-size: 100%; }\n\n.tooltip-content3 {\n  position: absolute;\n  background: url(../../assets/images/tooltip/shape1.svg) no-repeat center bottom;\n  background-size: 100% 100%;\n  z-index: 9999;\n  width: 200px;\n  bottom: 100%;\n  left: 50%;\n  margin-left: -100px;\n  padding: 50px 30px;\n  text-align: center;\n  color: #ffffff;\n  opacity: 0;\n  cursor: default;\n  font-size: 14;\n  line-height: 27px;\n  pointer-events: none;\n  -webkit-transform: scale3d(0.1, 0.2, 1);\n  transform: scale3d(0.1, 0.2, 1);\n  -webkit-transform-origin: 50% 120%;\n  -ms-transform-origin: 50% 120%;\n  transform-origin: 50% 120%;\n  -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;\n  transition: opacity 0.4s, -webkit-transform 0.4s;\n  -o-transition: opacity 0.4s, transform 0.4s;\n  transition: opacity 0.4s, transform 0.4s;\n  transition: opacity 0.4s, transform 0.4s, -webkit-transform 0.4s;\n  -webkit-transition-timing-function: ease, cubic-bezier(0.6, 0, 0.4, 1);\n  -o-transition-timing-function: ease, cubic-bezier(0.6, 0, 0.4, 1);\n  transition-timing-function: ease, cubic-bezier(0.6, 0, 0.4, 1); }\n\n.tooltip-content3::after {\n  content: '';\n  position: absolute;\n  width: 16px;\n  height: 16px;\n  left: 50%;\n  margin-left: -8px;\n  top: 100%;\n  background: #00aeef;\n  -webkit-transform: translate3d(0, -60%, 0) rotate3d(0, 0, 1, 45deg);\n  transform: translate3d(0, -60%, 0) rotate3d(0, 0, 1, 45deg); }\n\n.tooltip-item2 {\n  color: #00aeef;\n  cursor: pointer;\n  z-index: 100;\n  position: relative;\n  display: inline-block;\n  font-weight: 500;\n  -webkit-transition: background-color 0.3s, color 0.3s, -webkit-transform 0.3s;\n  transition: background-color 0.3s, color 0.3s, -webkit-transform 0.3s;\n  -o-transition: background-color 0.3s, color 0.3s, transform 0.3s;\n  transition: background-color 0.3s, color 0.3s, transform 0.3s;\n  transition: background-color 0.3s, color 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-content4 {\n  position: absolute;\n  z-index: 99;\n  width: 360px;\n  left: 50%;\n  margin-left: -180px;\n  bottom: -5px;\n  text-align: left;\n  background: #00aeef;\n  opacity: 0;\n  font-size: 14px;\n  line-height: 27px;\n  padding: 1.5em;\n  color: #ffffff;\n  border-bottom: 55px solid #2b2b2b;\n  cursor: default;\n  pointer-events: none;\n  border-radius: 5px;\n  -webkit-transform: translate3d(0, -0.5em, 0);\n  transform: translate3d(0, -0.5em, 0);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n  .tooltip-content4 a {\n    color: #2b2b2b; }\n\n.tooltip-text2 {\n  opacity: 0;\n  -webkit-transform: translate3d(0, 1.5em, 0);\n  transform: translate3d(0, 1.5em, 0);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-content5 {\n  position: absolute;\n  z-index: 9999;\n  width: 300px;\n  left: 50%;\n  bottom: 100%;\n  font-size: 20px;\n  line-height: 1.4;\n  text-align: center;\n  font-weight: 400;\n  color: #ffffff;\n  background: transparent;\n  opacity: 0;\n  margin: 0 0 20px -150px;\n  cursor: default;\n  pointer-events: none;\n  -webkit-transition: opacity 0.3s 0.3s;\n  -o-transition: opacity 0.3s 0.3s;\n  transition: opacity 0.3s 0.3s; }\n  .tooltip-content5 span {\n    display: block; }\n\n.tooltip-text3 {\n  border-bottom: 10px solid #009efb;\n  overflow: hidden;\n  -webkit-transform: scale3d(0, 1, 1);\n  transform: scale3d(0, 1, 1);\n  -webkit-transition: -webkit-transform 0.3s 0.3s;\n  transition: -webkit-transform 0.3s 0.3s;\n  -o-transition: transform 0.3s 0.3s;\n  transition: transform 0.3s 0.3s;\n  transition: transform 0.3s 0.3s, -webkit-transform 0.3s 0.3s; }\n\n.tooltip-inner2 {\n  background: #2b2b2b;\n  padding: 40px;\n  -webkit-transform: translate3d(0, 100%, 0);\n  transform: translate3d(0, 100%, 0);\n  -webkit-transition: -webkit-transform 0.3s;\n  transition: -webkit-transform 0.3s;\n  -o-transition: transform 0.3s;\n  transition: transform 0.3s;\n  transition: transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-content5::after {\n  content: '';\n  bottom: -20px;\n  left: 50%;\n  border: solid transparent;\n  height: 0;\n  width: 0;\n  position: absolute;\n  pointer-events: none;\n  border-color: transparent;\n  border-top-color: #009efb;\n  border-width: 10px;\n  margin-left: -10px; }\n\n.tooltip-effect-1 .tooltip-content {\n  -webkit-transform: translate3d(0, -10px, 0);\n  transform: translate3d(0, -10px, 0);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s;\n  color: #ffffff; }\n\n.tooltip-effect-2 .tooltip-content {\n  -webkit-transform-origin: 50% calc(110%);\n  -ms-transform-origin: 50% calc(110%);\n  transform-origin: 50% calc(110%);\n  -webkit-transform: perspective(1000px) rotate3d(1, 0, 0, 45deg);\n  transform: perspective(1000px) rotate3d(1, 0, 0, 45deg);\n  -webkit-transition: opacity 0.2s, -webkit-transform 0.2s;\n  transition: opacity 0.2s, -webkit-transform 0.2s;\n  -o-transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s, -webkit-transform 0.2s; }\n\n.tooltip-effect-3 .tooltip-content {\n  -webkit-transform: translate3d(0, 10px, 0) rotate3d(1, 1, 0, 25deg);\n  transform: translate3d(0, 10px, 0) rotate3d(1, 1, 0, 25deg);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-effect-4 .tooltip-content {\n  -webkit-transform-origin: 50% 100%;\n  -ms-transform-origin: 50% 100%;\n  transform-origin: 50% 100%;\n  -webkit-transform: scale3d(0.7, 0.3, 1);\n  transform: scale3d(0.7, 0.3, 1);\n  -webkit-transition: opacity 0.2s, -webkit-transform 0.2s;\n  transition: opacity 0.2s, -webkit-transform 0.2s;\n  -o-transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s;\n  transition: opacity 0.2s, transform 0.2s, -webkit-transform 0.2s; }\n\n.tooltip.tooltip-effect-2:hover .tooltip-content {\n  -webkit-transform: perspective(1000px) rotate3d(1, 0, 0, 0deg);\n  transform: perspective(1000px) rotate3d(1, 0, 0, 0deg); }\n\na.mytooltip {\n  font-weight: 500;\n  color: #009efb; }\n\n.tooltip-effect-7 .tooltip-content2 {\n  -webkit-transform: translate3d(0, 10px, 0);\n  transform: translate3d(0, 10px, 0);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n  .tooltip-effect-7 .tooltip-content2 i {\n    -webkit-transform: translate3d(0, 15px, 0);\n    transform: translate3d(0, 15px, 0);\n    -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n    transition: opacity 0.3s, -webkit-transform 0.3s;\n    -o-transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-effect-8 .tooltip-content2 {\n  -webkit-transform: translate3d(0, 10px, 0) rotate3d(0, 1, 0, 90deg);\n  transform: translate3d(0, 10px, 0) rotate3d(0, 1, 0, 90deg);\n  -webkit-transform-origin: 50% 100%;\n  -ms-transform-origin: 50% 100%;\n  transform-origin: 50% 100%;\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n  .tooltip-effect-8 .tooltip-content2 i {\n    -webkit-transform: scale3d(0, 0, 1);\n    transform: scale3d(0, 0, 1);\n    -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n    transition: opacity 0.3s, -webkit-transform 0.3s;\n    -o-transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n.tooltip-effect-9 .tooltip-content2 {\n  -webkit-transform: translate3d(0, -20px, 0);\n  transform: translate3d(0, -20px, 0);\n  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n  transition: opacity 0.3s, -webkit-transform 0.3s;\n  -o-transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s;\n  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n  .tooltip-effect-9 .tooltip-content2 i {\n    -webkit-transform: translate3d(0, 20px, 0);\n    transform: translate3d(0, 20px, 0);\n    -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;\n    transition: opacity 0.3s, -webkit-transform 0.3s;\n    -o-transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s;\n    transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s; }\n\n/*******************\nError Page\n******************/\n.error-box {\n  height: 100%;\n  position: fixed;\n  background: #fff;\n  width: 100%; }\n  .error-box .footer {\n    width: 100%;\n    left: 0px;\n    right: 0px; }\n\n.error-body {\n  padding-top: 5%; }\n  .error-body h1 {\n    font-size: 210px;\n    font-weight: 900;\n    line-height: 210px; }\n\n/*******************\ngoogle map Page\n******************/\n.gmaps,\n.gmaps-panaroma {\n  height: 300px; }\n\n.gmaps,\n.gmaps-panaroma {\n  height: 300px;\n  background: #f2f4f8;\n  border-radius: 3px; }\n\n.gmaps-overlay {\n  display: block;\n  text-align: center;\n  color: #ffffff;\n  font-size: 16px;\n  line-height: 40px;\n  background: #7460ee;\n  border-radius: 4px;\n  padding: 10px 20px; }\n\n.gmaps-overlay_arrow {\n  left: 50%;\n  margin-left: -16px;\n  width: 0;\n  height: 0;\n  position: absolute; }\n\n.gmaps-overlay_arrow.above {\n  bottom: -15px;\n  border-left: 16px solid transparent;\n  border-right: 16px solid transparent;\n  border-top: 16px solid #7460ee; }\n\n.gmaps-overlay_arrow.below {\n  top: -15px;\n  border-left: 16px solid transparent;\n  border-right: 16px solid transparent;\n  border-bottom: 16px solid #7460ee; }\n\n/*******************\nvector map Page\n******************/\n.jvectormap-zoomin,\n.jvectormap-zoomout {\n  width: 10px;\n  height: 10px;\n  line-height: 10px; }\n\n.jvectormap-zoomout {\n  top: 40px; }\n\n/*******************\nSeach listing Page\n******************/\n.search-listing {\n  padding: 0px;\n  margin: 0px; }\n  .search-listing li {\n    list-style: none;\n    padding: 15px 0;\n    border-bottom: 1px solid rgba(120, 130, 140, 0.13); }\n    .search-listing li h3 {\n      margin: 0px;\n      font-size: 18px; }\n      .search-listing li h3 a {\n        color: #1e88e5; }\n        .search-listing li h3 a:hover {\n          text-decoration: underline; }\n    .search-listing li a {\n      color: #26c6da; }\n\n/*******************\nLogin register and recover password Page\n******************/\n.login-register {\n  background-size: cover;\n  background-repeat: no-repeat;\n  background-position: center center;\n  height: 100%;\n  width: 100%;\n  padding: 10% 0;\n  position: fixed; }\n\n.login-box {\n  width: 400px;\n  margin: 0 auto; }\n  .login-box .footer {\n    width: 100%;\n    left: 0px;\n    right: 0px; }\n  .login-box .social {\n    display: block;\n    margin-bottom: 30px; }\n\n#recoverform {\n  display: none; }\n\n.login-sidebar {\n  padding: 0px;\n  margin-top: 0px; }\n  .login-sidebar .login-box {\n    right: 0px;\n    position: absolute;\n    height: 100%; }\n\n/*******************\nFAQs Page\n******************/\n.minimal-faq .card {\n  border: 0px; }\n  .minimal-faq .card .card-header {\n    background: #ffffff;\n    padding: 20px 0;\n    margin-top: 10px; }\n  .minimal-faq .card .card-block {\n    padding: 15px 0px; }\n\n/*******************\nPricing Page\n******************/\n.pricing-box {\n  position: relative;\n  text-align: center;\n  margin-top: 30px; }\n\n.featured-plan {\n  margin-top: 0px; }\n  .featured-plan .pricing-body {\n    padding: 60px 0;\n    background: #ebf3f5;\n    border: 1px solid #ddd; }\n  .featured-plan .price-table-content .price-row {\n    border-top: 1px solid rgba(120, 130, 140, 0.13); }\n\n.pricing-body {\n  border-radius: 0px;\n  border-top: 1px solid rgba(120, 130, 140, 0.13);\n  border-bottom: 5px solid rgba(120, 130, 140, 0.13);\n  vertical-align: middle;\n  padding: 30px 0;\n  position: relative; }\n\n.pricing-body h2 {\n  position: relative;\n  font-size: 56px;\n  margin: 20px 0 10px;\n  font-weight: 500; }\n  .pricing-body h2 span {\n    position: absolute;\n    font-size: 15px;\n    top: -10px;\n    margin-left: -10px; }\n\n.price-table-content .price-row {\n  padding: 20px 0;\n  border-top: 1px solid rgba(120, 130, 140, 0.13); }\n\n.pricing-plan {\n  padding: 0 15px; }\n  .pricing-plan .no-padding {\n    padding: 0px; }\n\n.price-lable {\n  position: absolute;\n  top: -10px;\n  padding: 5px 10px;\n  margin: 0 auto;\n  display: inline-block;\n  width: 100px;\n  left: 0px;\n  right: 0px; }\n\n/*******************\nchat application Page\n******************/\n.chat-main-box {\n  position: relative;\n  overflow: hidden; }\n  .chat-main-box .chat-left-aside {\n    position: relative;\n    width: 250px;\n    float: left;\n    z-index: 9;\n    top: 0px;\n    border-right: 1px solid rgba(120, 130, 140, 0.13); }\n    .chat-main-box .chat-left-aside .open-panel {\n      display: none;\n      cursor: pointer;\n      position: absolute;\n      left: -webkit-calc(100% - 1px);\n      top: 50%;\n      z-index: 100;\n      background-color: #fff;\n      -webkit-box-shadow: 1px 0 3px rgba(0, 0, 0, 0.2);\n      box-shadow: 1px 0 3px rgba(0, 0, 0, 0.2);\n      border-radius: 0 100px 100px 0;\n      line-height: 1;\n      padding: 15px 8px 15px 4px; }\n    .chat-main-box .chat-left-aside .chat-left-inner {\n      position: relative; }\n      .chat-main-box .chat-left-aside .chat-left-inner .form-control {\n        height: 60px; }\n      .chat-main-box .chat-left-aside .chat-left-inner .style-none {\n        padding: 0px; }\n        .chat-main-box .chat-left-aside .chat-left-inner .style-none li {\n          list-style: none;\n          overflow: hidden; }\n          .chat-main-box .chat-left-aside .chat-left-inner .style-none li a {\n            padding: 20px; }\n            .chat-main-box .chat-left-aside .chat-left-inner .style-none li a:hover, .chat-main-box .chat-left-aside .chat-left-inner .style-none li a.active {\n              background: #ebf3f5; }\n  .chat-main-box .chat-right-aside {\n    width: calc(100% - 250px);\n    float: left; }\n    .chat-main-box .chat-right-aside .chat-list {\n      max-height: none;\n      height: 100%;\n      padding-top: 40px; }\n      .chat-main-box .chat-right-aside .chat-list .chat-text {\n        border-radius: 6px; }\n    .chat-main-box .chat-right-aside .send-chat-box {\n      position: relative; }\n      .chat-main-box .chat-right-aside .send-chat-box .form-control {\n        border: none;\n        border-top: 1px solid rgba(120, 130, 140, 0.13);\n        resize: none;\n        height: 80px;\n        padding-right: 180px; }\n        .chat-main-box .chat-right-aside .send-chat-box .form-control:focus {\n          border-color: rgba(120, 130, 140, 0.13); }\n      .chat-main-box .chat-right-aside .send-chat-box .custom-send {\n        position: absolute;\n        right: 20px;\n        bottom: 10px; }\n        .chat-main-box .chat-right-aside .send-chat-box .custom-send .cst-icon {\n          color: #67757c;\n          margin-right: 10px; }\n\n/*******************\nEmail inbox Page\n******************/\n.inbox-panel .list-group .list-group-item {\n  border: 0px;\n  border-radius: 0px;\n  border-left: 3px solid transparent; }\n  .inbox-panel .list-group .list-group-item a {\n    color: #67757c; }\n  .inbox-panel .list-group .list-group-item.active, .inbox-panel .list-group .list-group-item:hover {\n    background: #f2f4f8;\n    border-left: 3px solid #009efb; }\n\n.inbox-center .unread td {\n  font-weight: 400; }\n\n.inbox-center td {\n  vertical-align: middle;\n  white-space: nowrap; }\n\n.inbox-center a {\n  color: #67757c;\n  padding: 2px 0 3px 0;\n  overflow: hidden;\n  vertical-align: middle;\n  -o-text-overflow: ellipsis;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n  display: inline-block; }\n\n.inbox-center .checkbox {\n  margin-top: -13px;\n  height: 20px; }\n\n/*******************\nContact app Page\n******************/\n/*left-aside-column*/\n.contact-page-aside {\n  position: relative; }\n\n.left-aside {\n  position: absolute;\n  border-right: 1px solid rgba(120, 130, 140, 0.13);\n  padding: 20px;\n  width: 250px;\n  height: 100%; }\n\n.right-aside {\n  padding: 20px;\n  margin-left: 250px; }\n\n.contact-list td {\n  vertical-align: middle;\n  padding: 25px 10px; }\n  .contact-list td img {\n    width: 30px; }\n\n.list-style-none {\n  margin: 0px;\n  padding: 0px; }\n  .list-style-none li {\n    list-style: none;\n    margin: 0px; }\n    .list-style-none li.box-label a {\n      font-weight: 500; }\n    .list-style-none li.divider {\n      margin: 10px 0;\n      height: 1px;\n      background: rgba(120, 130, 140, 0.13); }\n    .list-style-none li a {\n      padding: 15px 10px;\n      display: block;\n      color: #67757c; }\n      .list-style-none li a:hover {\n        color: #009efb; }\n      .list-style-none li a span {\n        float: right; }\n\n.slimScrollBar {\n  z-index: 10 !important; }\n\n.carousel-item-next,\n.carousel-item-prev,\n.carousel-item.active {\n  display: block; }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*******************\nMain sidebar\n******************/\n.left-sidebar {\n  position: absolute;\n  width: 240px;\n  height: 100%;\n  top: 0px;\n  z-index: 20;\n  padding-top: 70px;\n  background: #fff;\n  -webkit-box-shadow: 1px 0px 20px rgba(0, 0, 0, 0.08);\n  box-shadow: 1px 0px 20px rgba(0, 0, 0, 0.08); }\n\n.fix-sidebar .left-sidebar {\n  position: fixed; }\n\n/*******************\nuse profile section\n******************/\n.user-profile {\n  position: relative;\n  background-size: cover; }\n  .user-profile .profile-img {\n    width: 50px;\n    margin-left: 30px;\n    padding: 35px 0;\n    border-radius: 100%; }\n    .user-profile .profile-img::before {\n      -webkit-animation: 2.5s blow 0s linear infinite;\n      animation: 2.5s blow 0s linear infinite;\n      position: absolute;\n      content: '';\n      width: 50px;\n      height: 50px;\n      top: 35px;\n      margin: 0 auto;\n      border-radius: 50%;\n      z-index: 0; }\n\n@-webkit-keyframes blow {\n  0% {\n    -webkit-box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); }\n  50% {\n    -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); }\n  100% {\n    -webkit-box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n    opacity: 0;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); } }\n\n@keyframes blow {\n  0% {\n    -webkit-box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); }\n  50% {\n    -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); }\n  100% {\n    -webkit-box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n    opacity: 0;\n    -webkit-transform: scale3d(1, 1, 0.5);\n    transform: scale3d(1, 1, 0.5); } }\n    .user-profile .profile-img img {\n      width: 100%;\n      border-radius: 100%; }\n  .user-profile .profile-text {\n    padding: 5px 0px;\n    position: relative; }\n    .user-profile .profile-text > a {\n      color: #ffffff !important;\n      width: 100%;\n      padding: 6px 30px;\n      background: rgba(0, 0, 0, 0.5);\n      display: block; }\n      .user-profile .profile-text > a:after {\n        position: absolute;\n        right: 20px;\n        top: 20px; }\n  .user-profile .dropdown-menu {\n    left: 0px;\n    right: 0px;\n    width: 180px;\n    margin: 0 auto; }\n\n/*******************\nsidebar footer\n******************/\n.sidebar-footer {\n  position: fixed;\n  z-index: 10;\n  bottom: 0px;\n  left: 0px;\n  -webkit-transition: 0.2s ease-out;\n  -o-transition: 0.2s ease-out;\n  transition: 0.2s ease-out;\n  width: 240px;\n  background: #fff;\n  border-top: 1px solid rgba(120, 130, 140, 0.13); }\n  .sidebar-footer a {\n    padding: 15px;\n    width: 33.333337%;\n    float: left;\n    text-align: center;\n    font-size: 18px; }\n\n/*******************\nsidebar navigation\n******************/\n.scroll-sidebar {\n  padding-bottom: 60px; }\n\n.collapse.in {\n  display: block; }\n\n.sidebar-nav {\n  background: #fff;\n  padding: 15px; }\n  .sidebar-nav ul {\n    margin: 0px;\n    padding: 0px; }\n    .sidebar-nav ul li {\n      list-style: none; }\n      .sidebar-nav ul li a {\n        color: #607d8b;\n        padding: 8px 35px 8px 15px;\n        display: block;\n        font-size: 15px;\n        border-radius: 4px;\n        white-space: nowrap; }\n        .sidebar-nav ul li a.active, .sidebar-nav ul li a:hover {\n          color: #26c6da; }\n        .sidebar-nav ul li a.active {\n          font-weight: 500;\n          color: #263238; }\n      .sidebar-nav ul li ul {\n        padding-left: 5px;\n        padding-top: 10px; }\n        .sidebar-nav ul li ul li a {\n          padding: 10px 35px 10px 15px; }\n        .sidebar-nav ul li ul ul {\n          padding-left: 15px; }\n      .sidebar-nav ul li.nav-small-cap {\n        font-size: 12px;\n        margin-bottom: 0px;\n        padding: 14px 14px 14px 20px;\n        color: #263238;\n        font-weight: 500; }\n      .sidebar-nav ul li.nav-devider {\n        height: 1px;\n        background: rgba(120, 130, 140, 0.13);\n        display: block;\n        margin: 20px 0; }\n  .sidebar-nav > ul > li {\n    margin-bottom: 10px; }\n    .sidebar-nav > ul > li.active > a {\n      color: #ffffff;\n      font-weight: 500;\n      -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);\n      box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); }\n      .sidebar-nav > ul > li.active > a i {\n        color: #26c6da; }\n  .sidebar-nav > ul > li > a.active i, .sidebar-nav > ul > li > a:hover i {\n    color: #26c6da; }\n  .sidebar-nav > ul > li > a i {\n    width: 27px;\n    height: 27px;\n    font-size: 21px;\n    display: inline-block;\n    vertical-align: middle;\n    color: #99abb4; }\n  .sidebar-nav > ul > li > a .label {\n    float: right;\n    margin-top: 6px; }\n  .sidebar-nav > ul > li > a.active {\n    font-weight: 400;\n    background: #ffffff;\n    color: #26c6da; }\n\n.sidebar-nav .has-arrow {\n  position: relative; }\n  .sidebar-nav .has-arrow::after {\n    position: absolute;\n    content: '';\n    width: .55em;\n    height: .55em;\n    border-width: 1px 0 0 1px;\n    border-style: solid;\n    border-color: #607d8b;\n    right: 1em;\n    -webkit-transform: rotate(-45deg) translate(0, -50%);\n    -ms-transform: rotate(-45deg) translate(0, -50%);\n    -o-transform: rotate(-45deg) translate(0, -50%);\n    transform: rotate(-45deg) translate(0, -50%);\n    -webkit-transform-origin: top;\n    -ms-transform-origin: top;\n    -o-transform-origin: top;\n    transform-origin: top;\n    top: 47%;\n    -webkit-transition: all .3s ease-out;\n    -o-transition: all .3s ease-out;\n    transition: all .3s ease-out; }\n\n.sidebar-nav .active > .has-arrow::after,\n.sidebar-nav li > .has-arrow.active::after,\n.sidebar-nav .has-arrow[aria-expanded=\"true\"]::after {\n  -webkit-transform: rotate(-135deg) translate(0, -50%);\n  -ms-transform: rotate(-135deg) translate(0, -50%);\n  -o-transform: rotate(-135deg) translate(0, -50%);\n  top: 45%;\n  width: .58em;\n  transform: rotate(-135deg) translate(0, -50%); }\n\n/****************\nWhen click on sidebar toggler and also for tablet\n*****************/\n@media (min-width: 768px) {\n  .mini-sidebar .sidebar-nav #sidebarnav li {\n    position: relative; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li > ul {\n    position: absolute;\n    left: 60px;\n    top: 45px;\n    width: 200px;\n    z-index: 1001;\n    background: #f2f6f8;\n    display: none;\n    padding-left: 1px; }\n  .mini-sidebar .sidebar-nav {\n    padding: 5px; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul {\n    height: auto !important;\n    overflow: auto; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul,\n  .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul.collapse {\n    display: block; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li > a.has-arrow:after {\n    display: none; }\n  .mini-sidebar .left-sidebar {\n    width: 60px; }\n  .mini-sidebar .user-profile {\n    padding-bottom: 15px;\n    width: 60px;\n    margin-bottom: 7px; }\n    .mini-sidebar .user-profile .profile-img {\n      padding: 15px 0 0 0;\n      margin: 0px 0 0 6px; }\n      .mini-sidebar .user-profile .profile-img:before {\n        top: 15px; }\n  .mini-sidebar .scroll-sidebar {\n    padding-bottom: 0px;\n    position: absolute; }\n  .mini-sidebar .hide-menu,\n  .mini-sidebar .nav-small-cap,\n  .mini-sidebar .sidebar-footer,\n  .mini-sidebar .user-profile .profile-text {\n    display: none; }\n  .mini-sidebar .nav-devider {\n    width: 50px; }\n  .mini-sidebar .sidebar-nav {\n    background: transparent; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li > a {\n    padding: 9px 15px;\n    width: 50px; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li:hover > a {\n    width: 260px;\n    background: #26c6da;\n    color: #ffffff;\n    border-color: #009efb; }\n    .mini-sidebar .sidebar-nav #sidebarnav > li:hover > a i {\n      color: #ffffff; }\n    .mini-sidebar .sidebar-nav #sidebarnav > li:hover > a .hide-menu {\n      display: inline; }\n  .mini-sidebar .sidebar-nav #sidebarnav > li.active > a {\n    border-color: transparent; }\n    .mini-sidebar .sidebar-nav #sidebarnav > li.active > a.active {\n      border-color: #009efb; } }\n\n@media (max-width: 767px) {\n  .mini-sidebar .left-sidebar {\n    position: fixed; }\n  .mini-sidebar .left-sidebar, .mini-sidebar .sidebar-footer {\n    left: -240px; }\n  .mini-sidebar.show-sidebar .left-sidebar, .mini-sidebar.show-sidebar .sidebar-footer {\n    left: 0px; } }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*******************\n/*User mail widgets*/\n/*******************/\n.topbar .top-navbar .mailbox {\n  width: 300px; }\n  .topbar .top-navbar .mailbox ul {\n    padding: 0px; }\n    .topbar .top-navbar .mailbox ul li {\n      list-style: none; }\n\n.mailbox ul li .drop-title {\n  font-weight: 500;\n  padding: 11px 20px 15px;\n  border-bottom: 1px solid rgba(120, 130, 140, 0.13); }\n\n.mailbox ul li .nav-link {\n  border-top: 1px solid rgba(120, 130, 140, 0.13);\n  padding-top: 15px; }\n\n.mailbox .message-center {\n  height: 200px;\n  overflow: auto;\n  position: relative; }\n  .mailbox .message-center a {\n    border-bottom: 1px solid rgba(120, 130, 140, 0.13);\n    display: block;\n    text-decoration: none;\n    padding: 9px 15px; }\n    .mailbox .message-center a:hover {\n      background: #f2f4f8; }\n    .mailbox .message-center a div {\n      white-space: normal; }\n    .mailbox .message-center a .user-img {\n      width: 40px;\n      position: relative;\n      display: inline-block;\n      margin: 0 10px 15px 0; }\n      .mailbox .message-center a .user-img img {\n        width: 100%; }\n      .mailbox .message-center a .user-img .profile-status {\n        border: 2px solid #ffffff;\n        border-radius: 50%;\n        display: inline-block;\n        height: 10px;\n        left: 30px;\n        position: absolute;\n        top: 1px;\n        width: 10px; }\n      .mailbox .message-center a .user-img .online {\n        background: #26c6da; }\n      .mailbox .message-center a .user-img .busy {\n        background: #fc4b6c; }\n      .mailbox .message-center a .user-img .away {\n        background: #ffb22b; }\n      .mailbox .message-center a .user-img .offline {\n        background: #ffb22b; }\n    .mailbox .message-center a .mail-contnet {\n      display: inline-block;\n      width: 75%;\n      vertical-align: middle; }\n      .mailbox .message-center a .mail-contnet h5 {\n        margin: 5px 0px 0; }\n      .mailbox .message-center a .mail-contnet .mail-desc,\n      .mailbox .message-center a .mail-contnet .time {\n        font-size: 12px;\n        display: block;\n        margin: 1px 0;\n        -o-text-overflow: ellipsis;\n        text-overflow: ellipsis;\n        overflow: hidden;\n        color: #67757c;\n        white-space: nowrap; }\n\n/*******************\n/*Analytic info sparkline chart page*/\n/*******************/\n.analytics-info li span {\n  font-size: 24px;\n  vertical-align: middle; }\n\n/*******************\n/*States row*/\n/*******************/\n.stats-row {\n  margin-bottom: 20px; }\n  .stats-row .stat-item {\n    display: inline-block;\n    padding-right: 15px; }\n    .stats-row .stat-item + .stat-item {\n      padding-left: 15px;\n      border-left: 1px solid rgba(120, 130, 140, 0.13); }\n\n/*******************/\n/*Dashboard1 Weather*/\n/*******************/\n.city-weather-days {\n  margin: 0px; }\n  .city-weather-days li {\n    text-align: center;\n    padding: 15px 0; }\n    .city-weather-days li span {\n      display: block;\n      padding: 10px 0 0;\n      color: #99abb4; }\n    .city-weather-days li i {\n      display: block;\n      font-size: 20px;\n      color: #009efb; }\n    .city-weather-days li h3 {\n      font-weight: 300;\n      margin-top: 5px; }\n\n/*******************/\n/*Comment widgets*/\n/*******************/\n.comment-widgets {\n  position: relative;\n  margin-bottom: 10px; }\n  .comment-widgets .comment-row {\n    border-left: 3px solid #ffffff;\n    padding: 15px; }\n    .comment-widgets .comment-row:hover, .comment-widgets .comment-row.active {\n      border-color: #009efb; }\n\n.comment-text {\n  padding: 15px 15px 15px 20px; }\n  .comment-text:hover .comment-footer .action-icons,\n  .comment-text.active .comment-footer .action-icons {\n    visibility: visible; }\n  .comment-text p {\n    max-height: 50px;\n    overflow: hidden; }\n\n.comment-footer .action-icons {\n  visibility: hidden; }\n  .comment-footer .action-icons a {\n    padding-left: 15px;\n    vertical-align: middle;\n    color: #99abb4; }\n    .comment-footer .action-icons a:hover, .comment-footer .action-icons a.active {\n      color: #1e88e5; }\n\n/*******************/\n/*To do widgets*/\n/*******************/\n.todo-list li {\n  border: 0px;\n  margin-bottom: 0px;\n  padding: 20px 15px 15px 0px; }\n  .todo-list li .checkbox {\n    width: 100%; }\n    .todo-list li .checkbox label {\n      font-weight: 400;\n      color: #455a64; }\n  .todo-list li:last-child {\n    border-bottom: 0px; }\n  .todo-list li .assignedto {\n    padding: 0px 0 0 27px;\n    margin: 0px; }\n    .todo-list li .assignedto li {\n      list-style: none;\n      padding: 0px;\n      display: inline-block;\n      border: 0px;\n      margin-right: 2px; }\n      .todo-list li .assignedto li img {\n        width: 30px;\n        border-radius: 100%; }\n  .todo-list li .item-date {\n    padding-left: 25px;\n    font-size: 12px;\n    display: inline-block; }\n\n.list-task .task-done span {\n  text-decoration: line-through; }\n\n/*******************/\n/*Chat widget*/\n/*******************/\n.chat-list {\n  margin: 0px;\n  padding: 0px; }\n  .chat-list li {\n    list-style: none;\n    margin-top: 30px; }\n    .chat-list li .chat-img {\n      display: inline-block;\n      width: 45px;\n      vertical-align: top; }\n      .chat-list li .chat-img img {\n        width: 45px;\n        border-radius: 100%; }\n    .chat-list li .chat-content {\n      width: calc(100% - 140px);\n      display: inline-block;\n      padding-left: 15px; }\n      .chat-list li .chat-content h5 {\n        color: #99abb4; }\n      .chat-list li .chat-content .box {\n        display: inline-block;\n        margin-bottom: 10px;\n        color: #263238; }\n    .chat-list li .chat-time {\n      display: inline-block;\n      text-align: right;\n      width: 80px;\n      font-size: 13px;\n      color: #99abb4; }\n    .chat-list li.odd .chat-content {\n      text-align: right;\n      width: calc(100% - 90px); }\n    .chat-list li.odd .box {\n      clear: both; }\n    .chat-list li.odd + .odd {\n      margin-top: 0px; }\n    .chat-list li.reverse {\n      text-align: right; }\n      .chat-list li.reverse .chat-time {\n        text-align: left; }\n      .chat-list li.reverse .chat-content {\n        padding-left: 0px;\n        padding-right: 15px; }\n\n/*******************/\n/*Chat widget*/\n/*******************/\n.message-box ul li .drop-title {\n  font-weight: 500;\n  padding: 11px 20px 15px;\n  border-bottom: 1px solid rgba(120, 130, 140, 0.13); }\n\n.message-box ul li .nav-link {\n  border-top: 1px solid rgba(120, 130, 140, 0.13);\n  padding-top: 15px; }\n\n.message-box .message-widget {\n  position: relative; }\n  .message-box .message-widget a {\n    border-bottom: 1px solid rgba(120, 130, 140, 0.13);\n    display: block;\n    text-decoration: none;\n    padding: 9px 15px; }\n    .message-box .message-widget a:hover {\n      background: #f2f4f8; }\n    .message-box .message-widget a:last-child {\n      border-bottom: 0px; }\n    .message-box .message-widget a div {\n      white-space: normal; }\n    .message-box .message-widget a .user-img {\n      width: 45px;\n      position: relative;\n      display: inline-block;\n      margin: 0 10px 15px 0; }\n      .message-box .message-widget a .user-img img {\n        width: 100%; }\n      .message-box .message-widget a .user-img .profile-status {\n        border: 2px solid #ffffff;\n        border-radius: 50%;\n        display: inline-block;\n        height: 10px;\n        left: 33px;\n        position: absolute;\n        top: -1px;\n        width: 10px; }\n      .message-box .message-widget a .user-img .online {\n        background: #26c6da; }\n      .message-box .message-widget a .user-img .busy {\n        background: #fc4b6c; }\n      .message-box .message-widget a .user-img .away {\n        background: #ffb22b; }\n      .message-box .message-widget a .user-img .offline {\n        background: #ffb22b; }\n    .message-box .message-widget a .mail-contnet {\n      display: inline-block;\n      width: 75%;\n      vertical-align: middle; }\n      .message-box .message-widget a .mail-contnet h5 {\n        margin: 5px 0px 0; }\n      .message-box .message-widget a .mail-contnet .mail-desc,\n      .message-box .message-widget a .mail-contnet .time {\n        font-size: 12px;\n        display: block;\n        margin: 1px 0;\n        -o-text-overflow: ellipsis;\n        text-overflow: ellipsis;\n        overflow: hidden;\n        color: #67757c;\n        white-space: nowrap; }\n\n/*******************/\n/*Calendar widget*/\n/*******************/\n.calendar {\n  float: left;\n  margin-bottom: 0px; }\n\n.fc-view {\n  margin-top: 30px; }\n\n.none-border .modal-footer {\n  border-top: none; }\n\n.fc-toolbar {\n  margin-bottom: 5px;\n  margin-top: 15px; }\n  .fc-toolbar h2 {\n    font-size: 18px;\n    font-weight: 500;\n    line-height: 30px;\n    text-transform: uppercase; }\n\n.fc-day {\n  background: #ffffff; }\n\n.fc-toolbar .fc-state-active,\n.fc-toolbar .ui-state-active,\n.fc-toolbar button:focus,\n.fc-toolbar button:hover,\n.fc-toolbar .ui-state-hover {\n  z-index: 0; }\n\n.fc-widget-header {\n  border: 0px !important; }\n\n.fc-widget-content {\n  border-color: rgba(120, 130, 140, 0.13) !important; }\n\n.fc th.fc-widget-header {\n  color: #67757c;\n  font-size: 13px;\n  font-weight: 300;\n  line-height: 20px;\n  padding: 7px 0px;\n  text-transform: uppercase; }\n\n.fc th.fc-sun,\n.fc th.fc-tue,\n.fc th.fc-thu,\n.fc th.fc-sat {\n  background: #f2f7f8; }\n\n.fc th.fc-mon,\n.fc th.fc-wed,\n.fc th.fc-fri {\n  background: #f2f7f8; }\n\n.fc-view {\n  margin-top: 0px; }\n\n.fc-toolbar {\n  margin: 0px;\n  padding: 24px 0px; }\n\n.fc-button {\n  background: #ffffff;\n  border: 1px solid rgba(120, 130, 140, 0.13);\n  color: #67757c;\n  text-transform: capitalize; }\n  .fc-button:hover {\n    background: #f2f4f8;\n    opacity: 0.8; }\n\n.fc-text-arrow {\n  font-family: inherit;\n  font-size: 16px; }\n\n.fc-state-hover {\n  background: #F5F5F5; }\n\n.fc-unthemed .fc-today {\n  border: 1px solid #fc4b6c;\n  background: #f2f4f8 !important; }\n\n.fc-state-highlight {\n  background: #f0f0f0; }\n\n.fc-cell-overlay {\n  background: #f0f0f0; }\n\n.fc-unthemed .fc-today {\n  background: #ffffff; }\n\n.fc-event {\n  border-radius: 0px;\n  border: none;\n  cursor: move;\n  color: #ffffff !important;\n  font-size: 13px;\n  margin: 1px -1px 0 -1px;\n  padding: 5px 5px;\n  text-align: center;\n  background: #1e88e5; }\n\n.calendar-event {\n  cursor: move;\n  margin: 10px 5px 0 0;\n  padding: 6px 10px;\n  display: inline-block;\n  color: #ffffff;\n  min-width: 140px;\n  text-align: center;\n  background: #1e88e5; }\n  .calendar-event a {\n    float: right;\n    opacity: 0.6;\n    font-size: 10px;\n    margin: 4px 0 0 10px;\n    color: #ffffff; }\n\n.fc-basic-view td.fc-week-number span {\n  padding-right: 5px; }\n\n.fc-basic-view .fc-day-number {\n  padding: 10px 15px;\n  display: inline-block; }\n\n/*******************/\n/*Steam line widget*/\n/*******************/\n.steamline {\n  position: relative;\n  border-left: 1px solid rgba(120, 130, 140, 0.13);\n  margin-left: 20px; }\n  .steamline .sl-left {\n    float: left;\n    margin-left: -20px;\n    z-index: 1;\n    width: 40px;\n    line-height: 40px;\n    text-align: center;\n    height: 40px;\n    border-radius: 100%;\n    color: #ffffff;\n    background: #263238;\n    margin-right: 15px; }\n    .steamline .sl-left img {\n      max-width: 40px; }\n\n.steamline .sl-right {\n  padding-left: 50px; }\n  .steamline .sl-right .desc,\n  .steamline .sl-right .inline-photos {\n    margin-bottom: 30px; }\n\n.steamline .sl-item {\n  border-bottom: 1px solid rgba(120, 130, 140, 0.13);\n  margin: 20px 0; }\n\n.sl-date {\n  font-size: 10px;\n  color: #99abb4; }\n\n.time-item {\n  border-color: rgba(120, 130, 140, 0.13);\n  padding-bottom: 1px;\n  position: relative; }\n  .time-item:before {\n    content: \" \";\n    display: table; }\n  .time-item:after {\n    background-color: #ffffff;\n    border-color: rgba(120, 130, 140, 0.13);\n    border-radius: 10px;\n    border-style: solid;\n    border-width: 2px;\n    bottom: 0;\n    content: '';\n    height: 14px;\n    left: 0;\n    margin-left: -8px;\n    position: absolute;\n    top: 5px;\n    width: 14px; }\n\n.time-item-item:after {\n  content: \" \";\n  display: table; }\n\n.item-info {\n  margin-bottom: 15px;\n  margin-left: 15px; }\n  .item-info p {\n    margin-bottom: 10px !important; }\n\n/*******************/\n/*Feed widget*/\n/*******************/\n.feeds {\n  margin: 0px;\n  padding: 0px; }\n  .feeds li {\n    list-style: none;\n    padding: 10px;\n    display: block; }\n    .feeds li:hover {\n      background: #ebf3f5; }\n    .feeds li > div {\n      width: 40px;\n      height: 40px;\n      margin-right: 5px;\n      display: inline-block;\n      text-align: center;\n      vertical-align: middle;\n      border-radius: 100%; }\n      .feeds li > div i {\n        line-height: 40px; }\n    .feeds li span {\n      float: right;\n      width: auto;\n      font-size: 12px; }\n\n/*******************/\n/*Vertical carousel*/\n/*******************/\n.vert .carousel-item-next.carousel-item-left,\n.vert .carousel-item-prev.carousel-item-right {\n  -webkit-transform: translate3d(0, 0, 0);\n  transform: translate3d(0, 0, 0); }\n\n.vert .carousel-item-next,\n.vert .active.carousel-item-right {\n  -webkit-transform: translate3d(0, 100%, 0);\n  transform: translate3d(0, 100% 0); }\n\n.vert .carousel-item-prev,\n.vert .active.carousel-item-left {\n  -webkit-transform: translate3d(0, -100%, 0);\n  transform: translate3d(0, -100%, 0); }\n\n/*******************/\n/*social-widgets*/\n/*******************/\n.social-widget .soc-header {\n  padding: 15px;\n  text-align: center;\n  font-size: 36px;\n  color: #fff; }\n  .social-widget .soc-header.box-facebook {\n    background: #3b5998; }\n  .social-widget .soc-header.box-twitter {\n    background: #00aced; }\n  .social-widget .soc-header.box-google {\n    background: #f86c6b; }\n  .social-widget .soc-header.box-linkedin {\n    background: #4875b4; }\n\n.social-widget .soc-content {\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  text-align: center; }\n  .social-widget .soc-content div {\n    padding: 10px; }\n    .social-widget .soc-content div h3 {\n      margin-bottom: 0px; }\n\n/*******************/\n/*Guage chart*/\n/*******************/\n.gaugejs-box {\n  position: relative;\n  margin: 0 auto; }\n\n.gaugejs-box canvas.gaugejs {\n  width: 100% !important;\n  height: auto !important; }\n\n/*******************/\n/*social-profile-first*/\n/*******************/\n.social-profile-first {\n  text-align: center;\n  padding-top: 22%;\n  margin-bottom: 96px; }\n  .social-profile-first.bg-over {\n    background: rgba(56, 83, 161, 0.7); }\n  .social-profile-first .middle {\n    vertical-align: middle; }\n\n/*******************/\n/*country-state*/\n/*******************/\n.country-state {\n  list-style: none;\n  margin: 0;\n  padding: 0 0 0 10px; }\n  .country-state li {\n    margin-top: 30px;\n    margin-bottom: 10px; }\n  .country-state h2 {\n    margin-bottom: 0px;\n    font-weight: 400; }\n\n/*******************/\n/*profile timeline widget*/\n/*******************/\n.profiletimeline {\n  position: relative;\n  margin-left: 70px;\n  margin-right: 10px; }\n  .profiletimeline .sl-left {\n    float: left;\n    margin-left: -60px;\n    z-index: 1;\n    margin-right: 15px; }\n    .profiletimeline .sl-left img {\n      max-width: 40px; }\n\n.profiletimeline .sl-item {\n  margin-top: 8px;\n  margin-bottom: 30px; }\n\n.profiletimeline .sl-date {\n  font-size: 12px;\n  color: #99abb4; }\n\n.profiletimeline .time-item {\n  border-color: rgba(120, 130, 140, 0.13);\n  padding-bottom: 1px;\n  position: relative; }\n  .profiletimeline .time-item:before {\n    content: \" \";\n    display: table; }\n  .profiletimeline .time-item:after {\n    background-color: #ffffff;\n    border-color: rgba(120, 130, 140, 0.13);\n    border-radius: 10px;\n    border-style: solid;\n    border-width: 2px;\n    bottom: 0;\n    content: '';\n    height: 14px;\n    left: 0;\n    margin-left: -8px;\n    position: absolute;\n    top: 5px;\n    width: 14px; }\n\n.profiletimeline .time-item-item:after {\n  content: \" \";\n  display: table; }\n\n.profiletimeline .item-info {\n  margin-bottom: 15px;\n  margin-left: 15px; }\n  .profiletimeline .item-info p {\n    margin-bottom: 10px !important; }\n\n/*Blog widgets*/\n.blog-widget {\n  margin-top: 30px; }\n  .blog-widget .blog-image img {\n    border-radius: 4px;\n    margin-top: -45px;\n    margin-bottom: 20px;\n    -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);\n    box-shadow: 0 0 15px rgba(0, 0, 0, 0.2); }\n\n/*Weather smal;*/\n.weather-small h1 {\n  line-height: 30px; }\n\n.weather-small sup {\n  font-size: 60%; }\n\n/*little-profile*/\n.little-profile .pro-img {\n  margin-top: -80px;\n  margin-bottom: 20px; }\n  .little-profile .pro-img img {\n    width: 128px;\n    height: 128px;\n    -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);\n    box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);\n    border-radius: 100%; }\n\n.contact-box {\n  position: relative; }\n  .contact-box .add-ct-btn {\n    position: absolute;\n    right: 4px;\n    top: -46px; }\n  .contact-box .contact-widget > a {\n    padding: 15px 10px; }\n    .contact-box .contact-widget > a .user-img {\n      margin-bottom: 0px !important; }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n@media (min-width: 1600px) {\n  .col-xlg-1, .col-xlg-10, .col-xlg-11, .col-xlg-12, .col-xlg-2, .col-xlg-3, .col-xlg-4, .col-xlg-5, .col-xlg-6, .col-xlg-7, .col-xlg-8, .col-xlg-9 {\n    float: left; }\n  .col-xlg-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n    -ms-flex: 0 0 100%;\n    flex: 0 0 100%;\n    max-width: 100%; }\n  .col-xlg-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.66666667%;\n    -ms-flex: 0 0 91.66666667%;\n    flex: 0 0 91.66666667%;\n    max-width: 91.66666667%; }\n  .col-xlg-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.33333333%;\n    -ms-flex: 0 0 83.33333333%;\n    flex: 0 0 83.33333333%;\n    max-width: 83.33333333%; }\n  .col-xlg-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n    -ms-flex: 0 0 75%;\n    flex: 0 0 75%;\n    max-width: 75%; }\n  .col-xlg-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.66666667%;\n    -ms-flex: 0 0 66.66666667%;\n    flex: 0 0 66.66666667%;\n    max-width: 66.66666667%; }\n  .col-xlg-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.33333333%;\n    -ms-flex: 0 0 58.33333333%;\n    flex: 0 0 58.33333333%;\n    max-width: 58.33333333%; }\n  .col-xlg-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n    -ms-flex: 0 0 50%;\n    flex: 0 0 50%;\n    max-width: 50%; }\n  .col-xlg-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.66666667%;\n    -ms-flex: 0 0 41.66666667%;\n    flex: 0 0 41.66666667%;\n    max-width: 41.66666667%; }\n  .col-xlg-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.33333333%;\n    -ms-flex: 0 0 33.33333333%;\n    flex: 0 0 33.33333333%;\n    max-width: 33.33333333%; }\n  .col-xlg-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n    -ms-flex: 0 0 25%;\n    flex: 0 0 25%;\n    max-width: 25%; }\n  .col-xlg-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.66666667%;\n    -ms-flex: 0 0 16.66666667%;\n    flex: 0 0 16.66666667%;\n    max-width: 16.66666667%; }\n  .col-xlg-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.33333333%;\n    -ms-flex: 0 0 8.33333333%;\n    flex: 0 0 8.33333333%;\n    max-width: 8.33333333%; }\n  .col-xlg-pull-12 {\n    right: 100%; }\n  .col-xlg-pull-11 {\n    right: 91.66666667%; }\n  .col-xlg-pull-10 {\n    right: 83.33333333%; }\n  .col-xlg-pull-9 {\n    right: 75%; }\n  .col-xlg-pull-8 {\n    right: 66.66666667%; }\n  .col-xlg-pull-7 {\n    right: 58.33333333%; }\n  .col-xlg-pull-6 {\n    right: 50%; }\n  .col-xlg-pull-5 {\n    right: 41.66666667%; }\n  .col-xlg-pull-4 {\n    right: 33.33333333%; }\n  .col-xlg-pull-3 {\n    right: 25%; }\n  .col-xlg-pull-2 {\n    right: 16.66666667%; }\n  .col-xlg-pull-1 {\n    right: 8.33333333%; }\n  .col-xlg-pull-0 {\n    right: auto; }\n  .col-xlg-push-12 {\n    left: 100%; }\n  .col-xlg-push-11 {\n    left: 91.66666667%; }\n  .col-xlg-push-10 {\n    left: 83.33333333%; }\n  .col-xlg-push-9 {\n    left: 75%; }\n  .col-xlg-push-8 {\n    left: 66.66666667%; }\n  .col-xlg-push-7 {\n    left: 58.33333333%; }\n  .col-xlg-push-6 {\n    left: 50%; }\n  .col-xlg-push-5 {\n    left: 41.66666667%; }\n  .col-xlg-push-4 {\n    left: 33.33333333%; }\n  .col-xlg-push-3 {\n    left: 25%; }\n  .col-xlg-push-2 {\n    left: 16.66666667%; }\n  .col-xlg-push-1 {\n    left: 8.33333333%; }\n  .col-xlg-push-0 {\n    left: auto; }\n  .offset-xlg-12 {\n    margin-left: 100%; }\n  .offset-xlg-11 {\n    margin-left: 91.66666667%; }\n  .offset-xlg-10 {\n    margin-left: 83.33333333%; }\n  .offset-xlg-9 {\n    margin-left: 75%; }\n  .offset-xlg-8 {\n    margin-left: 66.66666667%; }\n  .offset-xlg-7 {\n    margin-left: 58.33333333%; }\n  .offset-xlg-6 {\n    margin-left: 50%; }\n  .offset-xlg-5 {\n    margin-left: 41.66666667%; }\n  .offset-xlg-4 {\n    margin-left: 33.33333333%; }\n  .offset-xlg-3 {\n    margin-left: 25%; }\n  .offset-xlg-2 {\n    margin-left: 16.66666667%; }\n  .offset-xlg-1 {\n    margin-left: 8.33333333%; }\n  .offset-xlg-0 {\n    margin-left: 0; } }\n\n.col-xlg-1, .col-xlg-10, .col-xlg-11, .col-xlg-12, .col-xlg-2, .col-xlg-3, .col-xlg-4, .col-xlg-5, .col-xlg-6, .col-xlg-7, .col-xlg-8, .col-xlg-9 {\n  position: relative;\n  min-height: 1px;\n  padding-right: 15px;\n  padding-left: 15px; }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*============================================================== \n For Laptop & above all (1650px) \n ============================================================== */\n@media (min-width: 1650px) {\n  .widget-app-columns {\n    -webkit-column-count: 3;\n    -moz-column-count: 3;\n    column-count: 3; }\n  .campaign {\n    height: 365px !important; } }\n\n/*============================================================== \n For Laptop & above all (1370px) \n ============================================================== */\n@media (max-width: 1370px) {\n  .widget-app-columns {\n    -webkit-column-count: 2;\n    -moz-column-count: 2;\n    column-count: 2; } }\n\n/*-- ============================================================== \n Small Desktop & above all (1024px) \n ============================================================== */\n@media (min-width: 1024px) {\n  .page-wrapper {\n    margin-left: 240px; }\n  .footer {\n    left: 240px; } }\n\n@media (max-width: 1023px) {\n  .page-wrapper {\n    margin-left: 60px;\n    -webkit-transition: 0.2s ease-in;\n    -o-transition: 0.2s ease-in;\n    transition: 0.2s ease-in; }\n  .footer {\n    left: 60px; }\n  .widget-app-columns {\n    -webkit-column-count: 1;\n    -moz-column-count: 1;\n    column-count: 1; }\n  .inbox-center a {\n    width: 200px; } }\n\n/*-- ============================================================== \n Ipad & above all(768px) \n ============================================================== */\n@media (min-width: 768px) {\n  .navbar-header {\n    width: 240px;\n    -webkit-flex-shrink: 0;\n    -ms-flex-negative: 0;\n    flex-shrink: 0; }\n    .navbar-header .navbar-brand {\n      padding-top: 0px; }\n  .material-icon-list-demo .icons div {\n    width: 33%;\n    padding: 15px;\n    display: inline-block;\n    line-height: 40px; }\n  .mini-sidebar .page-wrapper {\n    margin-left: 60px; }\n  .mini-sidebar .footer {\n    left: 60px; }\n  .flex-wrap {\n    -ms-flex-wrap: nowrap !important;\n    flex-wrap: nowrap !important;\n    -webkit-flex-wrap: nowrap !important; } }\n\n/*-- ============================================================== \n Phone and below ipad(767px) \n ============================================================== */\n@media (max-width: 767px) {\n  /*Header*/\n  .topbar {\n    position: fixed;\n    width: 100%; }\n    .topbar .top-navbar {\n      padding-right: 15px;\n      -webkit-box-orient: horizontal;\n      -webkit-box-direction: normal;\n      -webkit-flex-direction: row;\n      -ms-flex-direction: row;\n      flex-direction: row;\n      -webkit-flex-wrap: nowrap;\n      -ms-flex-wrap: nowrap;\n      flex-wrap: nowrap;\n      -webkit-align-items: center; }\n      .topbar .top-navbar .navbar-collapse {\n        display: -webkit-box;\n        display: -webkit-flex;\n        display: -ms-flexbox;\n        display: flex;\n        width: 100%; }\n      .topbar .top-navbar .navbar-nav {\n        -webkit-box-orient: horizontal;\n        -webkit-box-direction: normal;\n        -webkit-flex-direction: row;\n        -ms-flex-direction: row;\n        flex-direction: row; }\n        .topbar .top-navbar .navbar-nav > .nav-item.show {\n          position: static; }\n          .topbar .top-navbar .navbar-nav > .nav-item.show .dropdown-menu {\n            width: 100%;\n            margin-top: 0px; }\n        .topbar .top-navbar .navbar-nav > .nav-item > .nav-link {\n          padding-left: .50rem;\n          padding-right: .50rem; }\n        .topbar .top-navbar .navbar-nav .dropdown-menu {\n          position: absolute; }\n  .mega-dropdown .dropdown-menu {\n    height: 480px;\n    overflow: auto; }\n  /*Sidebar and wrapper*/\n  .mini-sidebar .page-wrapper {\n    margin-left: 0px;\n    padding-top: 70px; }\n  .comment-text .comment-footer .action-icons {\n    display: block;\n    padding: 10px 0; }\n  .vtabs .tabs-vertical {\n    width: auto; }\n  /*Footer*/\n  .footer {\n    left: 0px; }\n  .material-icon-list-demo .icons div {\n    width: 100%; }\n  .error-page .footer {\n    position: fixed;\n    bottom: 0px;\n    z-index: 10; }\n  .error-box {\n    position: relative;\n    padding-bottom: 60px; }\n  .error-body {\n    padding-top: 10%; }\n    .error-body h1 {\n      font-size: 100px;\n      font-weight: 600;\n      line-height: 100px; }\n  .login-register {\n    position: relative;\n    overflow: hidden; }\n  .login-box {\n    width: 90%; }\n  .login-sidebar {\n    padding: 10% 0; }\n    .login-sidebar .login-box {\n      position: relative; }\n  /*This is for chat page*/\n  .chat-main-box .chat-left-aside {\n    left: -250px;\n    position: absolute;\n    -webkit-transition: 0.5s ease-in;\n    -o-transition: 0.5s ease-in;\n    transition: 0.5s ease-in;\n    background: #ffffff; }\n    .chat-main-box .chat-left-aside.open-pnl {\n      left: 0px; }\n    .chat-main-box .chat-left-aside .open-panel {\n      display: block; }\n  .chat-main-box .chat-right-aside {\n    width: 100%; }\n  /*Timeline*/\n  ul.timeline:before {\n    left: 40px; }\n  ul.timeline > li > .timeline-panel {\n    width: \"calc(100% - 90px)\";\n    width: \"calc(100% - 90px)\";\n    width: \"calc(100% - 90px)\"; }\n  ul.timeline > li > .timeline-badge {\n    top: 16px;\n    left: 15px;\n    margin-left: 0; }\n  ul.timeline > li > .timeline-panel {\n    float: right; }\n  ul.timeline > li > .timeline-panel:before {\n    right: auto;\n    left: -15px;\n    border-right-width: 15px;\n    border-left-width: 0; }\n  ul.timeline > li > .timeline-panel:after {\n    right: auto;\n    left: -14px;\n    border-right-width: 14px;\n    border-left-width: 0; }\n  /*Contact app page*/\n  .left-aside {\n    width: 100%;\n    position: relative;\n    border: 0px; }\n  .right-aside {\n    margin-left: 0px; }\n  .flex-wrap {\n    -ms-flex-wrap: wrap !important;\n    flex-wrap: wrap !important;\n    -webkit-flex-wrap: wrap !important; }\n  .chat-list li .chat-content {\n    width: calc(100% - 80px); } }\n\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*Theme Colors*/\n/*bootstrap Color*/\n/*Light colors*/\n/*Normal Color*/\n/*Extra Variable*/\n/*Preloader*/\n.preloader {\n  width: 100%;\n  height: 100%;\n  top: 0px;\n  position: fixed;\n  z-index: 99999;\n  background: #fff; }\n  .preloader .cssload-speeding-wheel {\n    position: absolute;\n    top: calc(50% - 3.5px);\n    left: calc(50% - 3.5px); }\n\n/* Radio Buttons\n   ========================================================================== */\n[type=\"radio\"]:not(:checked),\n[type=\"radio\"]:checked {\n  position: absolute;\n  left: -9999px;\n  opacity: 0; }\n\n[type=\"radio\"]:not(:checked) + label,\n[type=\"radio\"]:checked + label {\n  position: relative;\n  padding-left: 35px;\n  cursor: pointer;\n  display: inline-block;\n  height: 25px;\n  line-height: 25px;\n  font-size: 1rem;\n  -webkit-transition: .28s ease;\n  -o-transition: .28s ease;\n  transition: .28s ease;\n  /* webkit (konqueror) browsers */\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none; }\n\n[type=\"radio\"] + label:before,\n[type=\"radio\"] + label:after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 4px;\n  width: 16px;\n  height: 16px;\n  z-index: 0;\n  -webkit-transition: .28s ease;\n  -o-transition: .28s ease;\n  transition: .28s ease; }\n\n/* Unchecked styles */\n[type=\"radio\"]:not(:checked) + label:before,\n[type=\"radio\"]:not(:checked) + label:after,\n[type=\"radio\"]:checked + label:before,\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:before,\n[type=\"radio\"].with-gap:checked + label:after {\n  border-radius: 50%; }\n\n[type=\"radio\"]:not(:checked) + label:before,\n[type=\"radio\"]:not(:checked) + label:after {\n  border: 2px solid #5a5a5a; }\n\n[type=\"radio\"]:not(:checked) + label:after {\n  z-index: -1;\n  -webkit-transform: scale(0);\n  -ms-transform: scale(0);\n  transform: scale(0); }\n\n/* Checked styles */\n[type=\"radio\"]:checked + label:before {\n  border: 2px solid transparent;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:before,\n[type=\"radio\"].with-gap:checked + label:after {\n  border: 2px solid #26a69a; }\n\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:after {\n  background-color: #26a69a;\n  z-index: 0; }\n\n[type=\"radio\"]:checked + label:after {\n  -webkit-transform: scale(1.02);\n  -ms-transform: scale(1.02);\n  transform: scale(1.02); }\n\n/* Radio With gap */\n[type=\"radio\"].with-gap:checked + label:after {\n  -webkit-transform: scale(0.5);\n  -ms-transform: scale(0.5);\n  transform: scale(0.5); }\n\n/* Focused styles */\n[type=\"radio\"].tabbed:focus + label:before {\n  -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n  box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n/* Disabled Radio With gap */\n[type=\"radio\"].with-gap:disabled:checked + label:before {\n  border: 2px solid rgba(0, 0, 0, 0.26);\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap:disabled:checked + label:after {\n  border: none;\n  background-color: rgba(0, 0, 0, 0.26); }\n\n/* Disabled style */\n[type=\"radio\"]:disabled:not(:checked) + label:before,\n[type=\"radio\"]:disabled:checked + label:before {\n  background-color: transparent;\n  border-color: rgba(0, 0, 0, 0.26);\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"]:disabled + label {\n  color: rgba(0, 0, 0, 0.26); }\n\n[type=\"radio\"]:disabled:not(:checked) + label:before {\n  border-color: rgba(0, 0, 0, 0.26); }\n\n[type=\"radio\"]:disabled:checked + label:after {\n  background-color: rgba(0, 0, 0, 0.26);\n  border-color: #BDBDBD; }\n\n/* Checkboxes\n   ========================================================================== */\n/* CUSTOM CSS CHECKBOXES */\nform p {\n  margin-bottom: 10px;\n  text-align: left; }\n\nform p:last-child {\n  margin-bottom: 0; }\n\n/* Remove default checkbox */\n[type=\"checkbox\"]:not(:checked),\n[type=\"checkbox\"]:checked {\n  position: absolute;\n  left: -9999px;\n  opacity: 0; }\n\n[type=\"checkbox\"] {\n  /* checkbox aspect */ }\n\n[type=\"checkbox\"] + label {\n  position: relative;\n  padding-left: 35px;\n  cursor: pointer;\n  display: inline-block;\n  height: 25px;\n  line-height: 25px;\n  font-size: 1rem;\n  -webkit-user-select: none;\n  /* webkit (safari, chrome) browsers */\n  -moz-user-select: none;\n  /* mozilla browsers */\n  -khtml-user-select: none;\n  /* webkit (konqueror) browsers */\n  -ms-user-select: none;\n  /* IE10+ */ }\n\n[type=\"checkbox\"] + label:before,\n[type=\"checkbox\"]:not(.filled-in) + label:after {\n  content: '';\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 18px;\n  height: 18px;\n  z-index: 0;\n  border: 2px solid #5a5a5a;\n  border-radius: 1px;\n  margin-top: 2px;\n  -webkit-transition: .2s;\n  -o-transition: .2s;\n  transition: .2s; }\n\n[type=\"checkbox\"]:not(.filled-in) + label:after {\n  border: 0;\n  -webkit-transform: scale(0);\n  -ms-transform: scale(0);\n  transform: scale(0); }\n\n[type=\"checkbox\"]:not(:checked):disabled + label:before {\n  border: none;\n  background-color: rgba(0, 0, 0, 0.26); }\n\n[type=\"checkbox\"].tabbed:focus + label:after {\n  -webkit-transform: scale(1);\n  -ms-transform: scale(1);\n  transform: scale(1);\n  border: 0;\n  border-radius: 50%;\n  -webkit-box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n  box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n  background-color: rgba(0, 0, 0, 0.1); }\n\n[type=\"checkbox\"]:checked + label:before {\n  top: -4px;\n  left: -5px;\n  width: 12px;\n  height: 22px;\n  border-top: 2px solid transparent;\n  border-left: 2px solid transparent;\n  border-right: 2px solid #26a69a;\n  border-bottom: 2px solid #26a69a;\n  -webkit-transform: rotate(40deg);\n  -ms-transform: rotate(40deg);\n  transform: rotate(40deg);\n  -webkit-backface-visibility: hidden;\n  backface-visibility: hidden;\n  -webkit-transform-origin: 100% 100%;\n  -ms-transform-origin: 100% 100%;\n  transform-origin: 100% 100%; }\n\n[type=\"checkbox\"]:checked:disabled + label:before {\n  border-right: 2px solid rgba(0, 0, 0, 0.26);\n  border-bottom: 2px solid rgba(0, 0, 0, 0.26); }\n\n/* Indeterminate checkbox */\n[type=\"checkbox\"]:indeterminate + label:before {\n  top: -11px;\n  left: -12px;\n  width: 10px;\n  height: 22px;\n  border-top: none;\n  border-left: none;\n  border-right: 2px solid #26a69a;\n  border-bottom: none;\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n  -webkit-backface-visibility: hidden;\n  backface-visibility: hidden;\n  -webkit-transform-origin: 100% 100%;\n  -ms-transform-origin: 100% 100%;\n  transform-origin: 100% 100%; }\n\n[type=\"checkbox\"]:indeterminate:disabled + label:before {\n  border-right: 2px solid rgba(0, 0, 0, 0.26);\n  background-color: transparent; }\n\n[type=\"checkbox\"].filled-in + label:after {\n  border-radius: 2px; }\n\n[type=\"checkbox\"].filled-in + label:before,\n[type=\"checkbox\"].filled-in + label:after {\n  content: '';\n  left: 0;\n  position: absolute;\n  /* .1s delay is for check animation */\n  -webkit-transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;\n  -o-transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;\n  transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;\n  z-index: 1; }\n\n[type=\"checkbox\"].filled-in:not(:checked) + label:before {\n  width: 0;\n  height: 0;\n  border: 3px solid transparent;\n  left: 6px;\n  top: 10px;\n  -webkit-transform: rotateZ(37deg);\n  -ms-transform: rotate(37deg);\n  transform: rotateZ(37deg);\n  -webkit-transform-origin: 20% 40%;\n  -ms-transform-origin: 100% 100%;\n  transform-origin: 100% 100%; }\n\n[type=\"checkbox\"].filled-in:not(:checked) + label:after {\n  height: 20px;\n  width: 20px;\n  background-color: transparent;\n  border: 2px solid #5a5a5a;\n  top: 0px;\n  z-index: 0; }\n\n[type=\"checkbox\"].filled-in:checked + label:before {\n  top: 0;\n  left: 1px;\n  width: 8px;\n  height: 13px;\n  border-top: 2px solid transparent;\n  border-left: 2px solid transparent;\n  border-right: 2px solid #fff;\n  border-bottom: 2px solid #fff;\n  -webkit-transform: rotateZ(37deg);\n  -ms-transform: rotate(37deg);\n  transform: rotateZ(37deg);\n  -webkit-transform-origin: 100% 100%;\n  -ms-transform-origin: 100% 100%;\n  transform-origin: 100% 100%; }\n\n[type=\"checkbox\"].filled-in:checked + label:after {\n  top: 0;\n  width: 20px;\n  height: 20px;\n  border: 2px solid #26a69a;\n  background-color: #26a69a;\n  z-index: 0; }\n\n[type=\"checkbox\"].filled-in.tabbed:focus + label:after {\n  border-radius: 2px;\n  border-color: #5a5a5a;\n  background-color: rgba(0, 0, 0, 0.1); }\n\n[type=\"checkbox\"].filled-in.tabbed:checked:focus + label:after {\n  border-radius: 2px;\n  background-color: #26a69a;\n  border-color: #26a69a; }\n\n[type=\"checkbox\"].filled-in:disabled:not(:checked) + label:before {\n  background-color: transparent;\n  border: 2px solid transparent; }\n\n[type=\"checkbox\"].filled-in:disabled:not(:checked) + label:after {\n  border-color: transparent;\n  background-color: #BDBDBD; }\n\n[type=\"checkbox\"].filled-in:disabled:checked + label:before {\n  background-color: transparent; }\n\n[type=\"checkbox\"].filled-in:disabled:checked + label:after {\n  background-color: #BDBDBD;\n  border-color: #BDBDBD; }\n\n/* Switch\n   ========================================================================== */\n.switch,\n.switch * {\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -khtml-user-select: none;\n  -ms-user-select: none; }\n\n.switch label {\n  cursor: pointer; }\n\n.switch label input[type=checkbox] {\n  opacity: 0;\n  width: 0;\n  height: 0; }\n\n.switch label input[type=checkbox]:checked + .lever {\n  background-color: #84c7c1; }\n\n.switch label input[type=checkbox]:checked + .lever:after {\n  background-color: #26a69a;\n  left: 24px; }\n\n.switch label .lever {\n  content: \"\";\n  display: inline-block;\n  position: relative;\n  width: 40px;\n  height: 15px;\n  background-color: #818181;\n  border-radius: 15px;\n  margin-right: 10px;\n  -webkit-transition: background 0.3s ease;\n  -o-transition: background 0.3s ease;\n  transition: background 0.3s ease;\n  vertical-align: middle;\n  margin: 0 16px; }\n\n.switch label .lever:after {\n  content: \"\";\n  position: absolute;\n  display: inline-block;\n  width: 21px;\n  height: 21px;\n  background-color: #F1F1F1;\n  border-radius: 21px;\n  -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4);\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4);\n  left: -5px;\n  top: -3px;\n  -webkit-transition: left 0.3s ease, background .3s ease, -webkit-box-shadow 0.1s ease;\n  transition: left 0.3s ease, background .3s ease, -webkit-box-shadow 0.1s ease;\n  -o-transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease;\n  transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease;\n  transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease, -webkit-box-shadow 0.1s ease; }\n\ninput[type=checkbox]:checked:not(:disabled) ~ .lever:active::after,\ninput[type=checkbox]:checked:not(:disabled).tabbed:focus ~ .lever::after {\n  -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(38, 166, 154, 0.1);\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(38, 166, 154, 0.1); }\n\ninput[type=checkbox]:not(:disabled) ~ .lever:active:after,\ninput[type=checkbox]:not(:disabled).tabbed:focus ~ .lever::after {\n  -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 0, 0, 0.08);\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 0, 0, 0.08); }\n\n.switch input[type=checkbox][disabled] + .lever {\n  cursor: default; }\n\n.switch label input[type=checkbox][disabled] + .lever:after,\n.switch label input[type=checkbox][disabled]:checked + .lever:after {\n  background-color: #BDBDBD; }\n\n.scale-up {\n  -webkit-transition: all 0.3s ease;\n  -o-transition: all 0.3s ease;\n  transition: all 0.3s ease;\n  -webkit-transform: scale(0);\n  -ms-transform: scale(0);\n  transform: scale(0);\n  display: inline-block;\n  -webkit-transform-origin: right 0px;\n  -ms-transform-origin: right 0px;\n  transform-origin: right 0px; }\n\n.scale-up-left {\n  -webkit-transition: all 0.3s ease;\n  -o-transition: all 0.3s ease;\n  transition: all 0.3s ease;\n  -webkit-transform: scale(0);\n  -ms-transform: scale(0);\n  transform: scale(0);\n  display: inline-block;\n  -webkit-transform-origin: left 0px;\n  -ms-transform-origin: left 0px;\n  transform-origin: left 0px; }\n\n.show > .scale-up {\n  -webkit-transform: scale(1);\n  -ms-transform: scale(1);\n  transform: scale(1);\n  -webkit-transform-origin: right 0px;\n  -ms-transform-origin: right 0px;\n  transform-origin: right 0px; }\n\n.show > .scale-up-left {\n  -webkit-transform: scale(1);\n  -ms-transform: scale(1);\n  transform: scale(1);\n  -webkit-transform-origin: left 0px;\n  -ms-transform-origin: left 0px;\n  transform-origin: left 0px; }\n\n/*panels*/\n.card {\n  -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1);\n  box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1);\n  border-radius: 4px; }\n\n.well, pre {\n  -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1);\n  box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1); }\n\n.page-titles .justify-content-end:last-child .d-flex {\n  margin-right: 10px; }\n\n.btn-circle.right-side-toggle {\n  position: fixed;\n  bottom: 20px;\n  right: 20px;\n  padding: 25px; }\n\n/*Radio button*/\n@-webkit-keyframes ripple {\n  0% {\n    -webkit-box-shadow: 0px 0px 0px 1px transparent;\n    box-shadow: 0px 0px 0px 1px transparent; }\n  50% {\n    -webkit-box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0.1);\n    box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0.1); }\n  100% {\n    -webkit-box-shadow: 0px 0px 0px 15px transparent;\n    box-shadow: 0px 0px 0px 15px transparent; } }\n@keyframes ripple {\n  0% {\n    -webkit-box-shadow: 0px 0px 0px 1px transparent;\n    box-shadow: 0px 0px 0px 1px transparent; }\n  50% {\n    -webkit-box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0.1);\n    box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0.1); }\n  100% {\n    -webkit-box-shadow: 0px 0px 0px 15px transparent;\n    box-shadow: 0px 0px 0px 15px transparent; } }\n\n/*Bootstrap Select*/\n.bootstrap-select.btn-group .dropdown-menu {\n  margin-top: -40px;\n  -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1);\n  box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1); }\n\n.demo-checkbox label, .demo-radio-button label {\n  min-width: 200px;\n  margin-bottom: 20px; }\n\n.demo-swtich .demo-switch-title, .demo-swtich .switch {\n  width: 150px;\n  margin-bottom: 10px;\n  display: inline-block; }\n\n[type=\"checkbox\"] + label {\n  padding-left: 26px;\n  height: 25px;\n  line-height: 21px;\n  font-weight: normal; }\n\n[type=\"checkbox\"]:checked + label:before {\n  top: -4px;\n  left: -2px;\n  width: 11px;\n  height: 19px; }\n\n[type=\"checkbox\"]:checked.chk-col-red + label:before {\n  border-right: 2px solid #fb3a3a;\n  border-bottom: 2px solid #fb3a3a; }\n\n[type=\"checkbox\"]:checked.chk-col-pink + label:before {\n  border-right: 2px solid #E91E63;\n  border-bottom: 2px solid #E91E63; }\n\n[type=\"checkbox\"]:checked.chk-col-purple + label:before {\n  border-right: 2px solid #7460ee;\n  border-bottom: 2px solid #7460ee; }\n\n[type=\"checkbox\"]:checked.chk-col-deep-purple + label:before {\n  border-right: 2px solid #673AB7;\n  border-bottom: 2px solid #673AB7; }\n\n[type=\"checkbox\"]:checked.chk-col-indigo + label:before {\n  border-right: 2px solid #3F51B5;\n  border-bottom: 2px solid #3F51B5; }\n\n[type=\"checkbox\"]:checked.chk-col-blue + label:before {\n  border-right: 2px solid #02bec9;\n  border-bottom: 2px solid #02bec9; }\n\n[type=\"checkbox\"]:checked.chk-col-light-blue + label:before {\n  border-right: 2px solid #03A9F4;\n  border-bottom: 2px solid #03A9F4; }\n\n[type=\"checkbox\"]:checked.chk-col-cyan + label:before {\n  border-right: 2px solid #00BCD4;\n  border-bottom: 2px solid #00BCD4; }\n\n[type=\"checkbox\"]:checked.chk-col-teal + label:before {\n  border-right: 2px solid #009688;\n  border-bottom: 2px solid #009688; }\n\n[type=\"checkbox\"]:checked.chk-col-green + label:before {\n  border-right: 2px solid #26c6da;\n  border-bottom: 2px solid #26c6da; }\n\n[type=\"checkbox\"]:checked.chk-col-light-green + label:before {\n  border-right: 2px solid #8BC34A;\n  border-bottom: 2px solid #8BC34A; }\n\n[type=\"checkbox\"]:checked.chk-col-lime + label:before {\n  border-right: 2px solid #CDDC39;\n  border-bottom: 2px solid #CDDC39; }\n\n[type=\"checkbox\"]:checked.chk-col-yellow + label:before {\n  border-right: 2px solid #ffe821;\n  border-bottom: 2px solid #ffe821; }\n\n[type=\"checkbox\"]:checked.chk-col-amber + label:before {\n  border-right: 2px solid #FFC107;\n  border-bottom: 2px solid #FFC107; }\n\n[type=\"checkbox\"]:checked.chk-col-orange + label:before {\n  border-right: 2px solid #FF9800;\n  border-bottom: 2px solid #FF9800; }\n\n[type=\"checkbox\"]:checked.chk-col-deep-orange + label:before {\n  border-right: 2px solid #FF5722;\n  border-bottom: 2px solid #FF5722; }\n\n[type=\"checkbox\"]:checked.chk-col-brown + label:before {\n  border-right: 2px solid #795548;\n  border-bottom: 2px solid #795548; }\n\n[type=\"checkbox\"]:checked.chk-col-grey + label:before {\n  border-right: 2px solid #9E9E9E;\n  border-bottom: 2px solid #9E9E9E; }\n\n[type=\"checkbox\"]:checked.chk-col-blue-grey + label:before {\n  border-right: 2px solid #607D8B;\n  border-bottom: 2px solid #607D8B; }\n\n[type=\"checkbox\"]:checked.chk-col-black + label:before {\n  border-right: 2px solid #000000;\n  border-bottom: 2px solid #000000; }\n\n[type=\"checkbox\"]:checked.chk-col-white + label:before {\n  border-right: 2px solid #ffffff;\n  border-bottom: 2px solid #ffffff; }\n\n[type=\"checkbox\"].filled-in:checked + label:after {\n  top: 0;\n  width: 20px;\n  height: 20px;\n  border: 2px solid #26a69a;\n  background-color: #26a69a;\n  z-index: 0; }\n\n[type=\"checkbox\"].filled-in:checked + label:before {\n  border-right: 2px solid #fff !important;\n  border-bottom: 2px solid #fff !important; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-red + label:after {\n  border: 2px solid #fb3a3a;\n  background-color: #fb3a3a; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-pink + label:after {\n  border: 2px solid #E91E63;\n  background-color: #E91E63; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-purple + label:after {\n  border: 2px solid #7460ee;\n  background-color: #7460ee; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-deep-purple + label:after {\n  border: 2px solid #673AB7;\n  background-color: #673AB7; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-indigo + label:after {\n  border: 2px solid #3F51B5;\n  background-color: #3F51B5; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-blue + label:after {\n  border: 2px solid #02bec9;\n  background-color: #02bec9; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-light-blue + label:after {\n  border: 2px solid #03A9F4;\n  background-color: #03A9F4; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-cyan + label:after {\n  border: 2px solid #00BCD4;\n  background-color: #00BCD4; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-teal + label:after {\n  border: 2px solid #009688;\n  background-color: #009688; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-green + label:after {\n  border: 2px solid #26c6da;\n  background-color: #26c6da; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-light-green + label:after {\n  border: 2px solid #8BC34A;\n  background-color: #8BC34A; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-lime + label:after {\n  border: 2px solid #CDDC39;\n  background-color: #CDDC39; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-yellow + label:after {\n  border: 2px solid #ffe821;\n  background-color: #ffe821; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-amber + label:after {\n  border: 2px solid #FFC107;\n  background-color: #FFC107; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-orange + label:after {\n  border: 2px solid #FF9800;\n  background-color: #FF9800; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-deep-orange + label:after {\n  border: 2px solid #FF5722;\n  background-color: #FF5722; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-brown + label:after {\n  border: 2px solid #795548;\n  background-color: #795548; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-grey + label:after {\n  border: 2px solid #9E9E9E;\n  background-color: #9E9E9E; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-blue-grey + label:after {\n  border: 2px solid #607D8B;\n  background-color: #607D8B; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-black + label:after {\n  border: 2px solid #000000;\n  background-color: #000000; }\n\n[type=\"checkbox\"].filled-in:checked.chk-col-white + label:after {\n  border: 2px solid #ffffff;\n  background-color: #ffffff; }\n\n[type=\"radio\"]:not(:checked) + label {\n  padding-left: 26px;\n  height: 25px;\n  line-height: 25px;\n  font-weight: normal; }\n\n[type=\"radio\"]:checked + label {\n  padding-left: 26px;\n  height: 25px;\n  line-height: 25px;\n  font-weight: normal; }\n\n[type=\"radio\"].radio-col-red:checked + label:after {\n  background-color: #fb3a3a;\n  border-color: #fb3a3a;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-pink:checked + label:after {\n  background-color: #E91E63;\n  border-color: #E91E63;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-purple:checked + label:after {\n  background-color: #7460ee;\n  border-color: #7460ee;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-deep-purple:checked + label:after {\n  background-color: #673AB7;\n  border-color: #673AB7;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-indigo:checked + label:after {\n  background-color: #3F51B5;\n  border-color: #3F51B5;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-blue:checked + label:after {\n  background-color: #02bec9;\n  border-color: #02bec9;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-light-blue:checked + label:after {\n  background-color: #03A9F4;\n  border-color: #03A9F4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-cyan:checked + label:after {\n  background-color: #00BCD4;\n  border-color: #00BCD4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-teal:checked + label:after {\n  background-color: #009688;\n  border-color: #009688;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-green:checked + label:after {\n  background-color: #26c6da;\n  border-color: #26c6da;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-light-green:checked + label:after {\n  background-color: #8BC34A;\n  border-color: #8BC34A;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-lime:checked + label:after {\n  background-color: #CDDC39;\n  border-color: #CDDC39;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-yellow:checked + label:after {\n  background-color: #ffe821;\n  border-color: #ffe821;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-amber:checked + label:after {\n  background-color: #FFC107;\n  border-color: #FFC107;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-orange:checked + label:after {\n  background-color: #FF9800;\n  border-color: #FF9800;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-deep-orange:checked + label:after {\n  background-color: #FF5722;\n  border-color: #FF5722;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-brown:checked + label:after {\n  background-color: #795548;\n  border-color: #795548;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-grey:checked + label:after {\n  background-color: #9E9E9E;\n  border-color: #9E9E9E;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-blue-grey:checked + label:after {\n  background-color: #607D8B;\n  border-color: #607D8B;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-black:checked + label:after {\n  background-color: #000000;\n  border-color: #000000;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].radio-col-white:checked + label:after {\n  background-color: #ffffff;\n  border-color: #ffffff;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-red:checked + label:before {\n  border: 2px solid #fb3a3a;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-red:checked + label:after {\n  background-color: #fb3a3a;\n  border: 2px solid #fb3a3a;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-pink:checked + label:before {\n  border: 2px solid #E91E63;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-pink:checked + label:after {\n  background-color: #E91E63;\n  border: 2px solid #E91E63;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-purple:checked + label:before {\n  border: 2px solid #7460ee;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-purple:checked + label:after {\n  background-color: #7460ee;\n  border: 2px solid #7460ee;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-deep-purple:checked + label:before {\n  border: 2px solid #673AB7;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-deep-purple:checked + label:after {\n  background-color: #673AB7;\n  border: 2px solid #673AB7;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-indigo:checked + label:before {\n  border: 2px solid #3F51B5;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-indigo:checked + label:after {\n  background-color: #3F51B5;\n  border: 2px solid #3F51B5;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-blue:checked + label:before {\n  border: 2px solid #02bec9;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-blue:checked + label:after {\n  background-color: #02bec9;\n  border: 2px solid #02bec9;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-light-blue:checked + label:before {\n  border: 2px solid #03A9F4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-light-blue:checked + label:after {\n  background-color: #03A9F4;\n  border: 2px solid #03A9F4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-cyan:checked + label:before {\n  border: 2px solid #00BCD4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-cyan:checked + label:after {\n  background-color: #00BCD4;\n  border: 2px solid #00BCD4;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-teal:checked + label:before {\n  border: 2px solid #009688;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-teal:checked + label:after {\n  background-color: #009688;\n  border: 2px solid #009688;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-green:checked + label:before {\n  border: 2px solid #26c6da;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-green:checked + label:after {\n  background-color: #26c6da;\n  border: 2px solid #26c6da;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-light-green:checked + label:before {\n  border: 2px solid #8BC34A;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-light-green:checked + label:after {\n  background-color: #8BC34A;\n  border: 2px solid #8BC34A;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-lime:checked + label:before {\n  border: 2px solid #CDDC39;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-lime:checked + label:after {\n  background-color: #CDDC39;\n  border: 2px solid #CDDC39;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-yellow:checked + label:before {\n  border: 2px solid #ffe821;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-yellow:checked + label:after {\n  background-color: #ffe821;\n  border: 2px solid #ffe821;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-amber:checked + label:before {\n  border: 2px solid #FFC107;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-amber:checked + label:after {\n  background-color: #FFC107;\n  border: 2px solid #FFC107;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-orange:checked + label:before {\n  border: 2px solid #FF9800;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-orange:checked + label:after {\n  background-color: #FF9800;\n  border: 2px solid #FF9800;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-deep-orange:checked + label:before {\n  border: 2px solid #FF5722;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-deep-orange:checked + label:after {\n  background-color: #FF5722;\n  border: 2px solid #FF5722;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-brown:checked + label:before {\n  border: 2px solid #795548;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-brown:checked + label:after {\n  background-color: #795548;\n  border: 2px solid #795548;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-grey:checked + label:before {\n  border: 2px solid #9E9E9E;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-grey:checked + label:after {\n  background-color: #9E9E9E;\n  border: 2px solid #9E9E9E;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-blue-grey:checked + label:before {\n  border: 2px solid #607D8B;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-blue-grey:checked + label:after {\n  background-color: #607D8B;\n  border: 2px solid #607D8B;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-black:checked + label:before {\n  border: 2px solid #000000;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-black:checked + label:after {\n  background-color: #000000;\n  border: 2px solid #000000;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-white:checked + label:before {\n  border: 2px solid #ffffff;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n[type=\"radio\"].with-gap.radio-col-white:checked + label:after {\n  background-color: #ffffff;\n  border: 2px solid #ffffff;\n  -webkit-animation: ripple 0.2s linear forwards;\n  animation: ripple 0.2s linear forwards; }\n\n.switch label {\n  font-weight: normal;\n  font-size: 13px; }\n  .switch label .lever {\n    margin: 0 14px; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-red:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(251, 58, 58, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(251, 58, 58, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-red {\n    background-color: rgba(251, 58, 58, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-red:after {\n      background-color: #fb3a3a; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-pink:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(233, 30, 99, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(233, 30, 99, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-pink {\n    background-color: rgba(233, 30, 99, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-pink:after {\n      background-color: #E91E63; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-purple:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(116, 96, 238, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(116, 96, 238, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-purple {\n    background-color: rgba(116, 96, 238, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-purple:after {\n      background-color: #7460ee; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-deep-purple:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(103, 58, 183, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(103, 58, 183, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-deep-purple {\n    background-color: rgba(103, 58, 183, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-deep-purple:after {\n      background-color: #673AB7; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-indigo:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(63, 81, 181, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(63, 81, 181, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-indigo {\n    background-color: rgba(63, 81, 181, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-indigo:after {\n      background-color: #3F51B5; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-blue:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(2, 190, 201, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(2, 190, 201, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-blue {\n    background-color: rgba(2, 190, 201, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-blue:after {\n      background-color: #02bec9; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-light-blue:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(3, 169, 244, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(3, 169, 244, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-light-blue {\n    background-color: rgba(3, 169, 244, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-light-blue:after {\n      background-color: #03A9F4; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-cyan:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 188, 212, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 188, 212, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-cyan {\n    background-color: rgba(0, 188, 212, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-cyan:after {\n      background-color: #00BCD4; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-teal:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 150, 136, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 150, 136, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-teal {\n    background-color: rgba(0, 150, 136, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-teal:after {\n      background-color: #009688; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-green:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(38, 198, 218, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(38, 198, 218, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-green {\n    background-color: rgba(38, 198, 218, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-green:after {\n      background-color: #26c6da; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-light-green:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(139, 195, 74, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(139, 195, 74, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-light-green {\n    background-color: rgba(139, 195, 74, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-light-green:after {\n      background-color: #8BC34A; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-lime:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(205, 220, 57, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(205, 220, 57, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-lime {\n    background-color: rgba(205, 220, 57, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-lime:after {\n      background-color: #CDDC39; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-yellow:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 232, 33, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 232, 33, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-yellow {\n    background-color: rgba(255, 232, 33, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-yellow:after {\n      background-color: #ffe821; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-amber:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 193, 7, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 193, 7, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-amber {\n    background-color: rgba(255, 193, 7, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-amber:after {\n      background-color: #FFC107; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-orange:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 152, 0, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 152, 0, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-orange {\n    background-color: rgba(255, 152, 0, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-orange:after {\n      background-color: #FF9800; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-deep-orange:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 87, 34, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 87, 34, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-deep-orange {\n    background-color: rgba(255, 87, 34, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-deep-orange:after {\n      background-color: #FF5722; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-brown:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(121, 85, 72, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(121, 85, 72, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-brown {\n    background-color: rgba(121, 85, 72, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-brown:after {\n      background-color: #795548; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-grey:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(158, 158, 158, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(158, 158, 158, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-grey {\n    background-color: rgba(158, 158, 158, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-grey:after {\n      background-color: #9E9E9E; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-blue-grey:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(96, 125, 139, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(96, 125, 139, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-blue-grey {\n    background-color: rgba(96, 125, 139, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-blue-grey:after {\n      background-color: #607D8B; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-black:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 0, 0, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 0, 0, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-black {\n    background-color: rgba(0, 0, 0, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-black:after {\n      background-color: #000000; }\n  .switch label input[type=checkbox]:checked:not(:disabled) ~ .lever.switch-col-white:active:after {\n    -webkit-box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 255, 255, 0.1);\n    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(255, 255, 255, 0.1); }\n  .switch label input[type=checkbox]:checked + .lever.switch-col-white {\n    background-color: rgba(255, 255, 255, 0.5); }\n    .switch label input[type=checkbox]:checked + .lever.switch-col-white:after {\n      background-color: #ffffff; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/js/custom.js",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: js\n*/\n$(function() {\n    \"use strict\";\n    $(function() {\n        $(\".preloader\").fadeOut();\n    });\n\n    // ============================================================== \n    // This is for the top header part and sidebar part\n    // ==============================================================  \n    var set = function() {\n        var width = (window.innerWidth > 0) ? window.innerWidth : this.screen.width;\n        var topOffset = 70;\n        if (width < 1170) {\n            $(\"body\").addClass(\"mini-sidebar\");\n            $('.navbar-brand span').hide();\n            $(\".scroll-sidebar, .slimScrollDiv\").css(\"overflow-x\", \"visible\").parent().css(\"overflow\", \"visible\");\n            $(\".sidebartoggler i\").addClass(\"ti-menu\");\n        } else {\n            $(\"body\").removeClass(\"mini-sidebar\");\n            $('.navbar-brand span').show();\n            //$(\".sidebartoggler i\").removeClass(\"ti-menu\");\n        }\n\n        var height = ((window.innerHeight > 0) ? window.innerHeight : this.screen.height) - 1;\n        height = height - topOffset;\n        if (height < 1) height = 1;\n        if (height > topOffset) {\n            $(\".page-wrapper\").css(\"min-height\", (height) + \"px\");\n        }\n    };\n    $(window).ready(set);\n    $(window).on(\"resize\", set);\n\n    // topbar stickey on scroll\n    $(\".fix-header .topbar\").stick_in_parent({});\n\n    // this is for close icon when navigation open in mobile view\n    $(\".nav-toggler\").click(function() {\n        $(\"body\").toggleClass(\"show-sidebar\");\n        $(\".nav-toggler i\").toggleClass(\"ti-menu\");\n        $(\".nav-toggler i\").addClass(\"ti-close\");\n    });\n    $(\".sidebartoggler\").on('click', function() {\n        //$(\".sidebartoggler i\").toggleClass(\"ti-menu\");\n    });\n    $(\".search-box a, .search-box .app-search .srh-btn\").on('click', function() {\n        $(\".app-search\").toggle(200);\n    });\n\n    // ============================================================== \n    // Auto select left navbar\n    // ============================================================== \n    $(function() {\n        var url = window.location;\n        var element = $('ul#sidebarnav a').filter(function() {\n            return this.href == url;\n        }).addClass('active').parent().addClass('active');\n        while (true) {\n            if (element.is('li')) {\n                element = element.parent().addClass('in').parent().addClass('active');\n            } else {\n                break;\n            }\n        }\n    });\n    // ============================================================== \n    //tooltip\n    // ============================================================== \n    $(function() {\n            $('[data-toggle=\"tooltip\"]').tooltip()\n        })\n        // ============================================================== \n        // Sidebarmenu\n        // ============================================================== \n    $(function() {\n        $('#sidebarnav').metisMenu();\n    });\n    // ============================================================== \n    // Slimscrollbars\n    // ============================================================== \n    $('.scroll-sidebar').slimScroll({\n        position: 'left',\n        size: \"5px\",\n        height: '100%',\n        color: '#dcdcdc'\n    });\n    // ============================================================== \n    // Resize all elements\n    // ============================================================== \n    $(\"body\").trigger(\"resize\");\n});\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/js/dashboard1.js",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: js\n*/\n$(function() {\n    \"use strict\";\n    // ============================================================== \n    // Sales overview\n    // ============================================================== \n    var chart2 = new Chartist.Bar('.amp-pxl', {\n        labels: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],\n        series: [\n            [9, 5, 3, 7, 5, 10, 3],\n            [6, 3, 9, 5, 4, 6, 4]\n        ]\n    }, {\n        axisX: {\n            // On the x-axis start means top and end means bottom\n            position: 'end',\n            showGrid: false\n        },\n        axisY: {\n            // On the y-axis start means left and end means right\n            position: 'start'\n        },\n        high: '12',\n        low: '0',\n        plugins: [\n            Chartist.plugins.tooltip()\n        ]\n    });\n\n    var chart = [chart2];\n\n    // ============================================================== \n    // This is for the animation\n    // ==============================================================\n\n    for (var i = 0; i < chart.length; i++) {\n        chart[i].on('draw', function(data) {\n            if (data.type === 'line' || data.type === 'area') {\n                data.element.animate({\n                    d: {\n                        begin: 500 * data.index,\n                        dur: 500,\n                        from: data.path.clone().scale(1, 0).translate(0, data.chartRect.height()).stringify(),\n                        to: data.path.clone().stringify(),\n                        easing: Chartist.Svg.Easing.easeInOutElastic\n                    }\n                });\n            }\n            if (data.type === 'bar') {\n                data.element.animate({\n                    y2: {\n                        dur: 500,\n                        from: data.y1,\n                        to: data.y2,\n                        easing: Chartist.Svg.Easing.easeInOutElastic\n                    },\n                    opacity: {\n                        dur: 500,\n                        from: 0,\n                        to: 1,\n                        easing: Chartist.Svg.Easing.easeInOutElastic\n                    }\n                });\n            }\n        });\n    }\n\n    // ============================================================== \n    // Our visitor\n    // ============================================================== \n\n    var chart = c3.generate({\n        bindto: '#visitor',\n        data: {\n            columns: [\n                ['Other', 30],\n                ['Desktop', 10],\n                ['Tablet', 40],\n                ['Mobile', 50],\n            ],\n\n            type: 'donut',\n            onclick: function(d, i) { console.log(\"onclick\", d, i); },\n            onmouseover: function(d, i) { console.log(\"onmouseover\", d, i); },\n            onmouseout: function(d, i) { console.log(\"onmouseout\", d, i); }\n        },\n        donut: {\n            label: {\n                show: false\n            },\n            title: \"Our visitor\",\n            width: 20,\n\n        },\n\n        legend: {\n            hide: true\n                //or hide: 'data1'\n                //or hide: ['data1', 'data2']\n        },\n        color: {\n            pattern: ['#eceff1', '#745af2', '#26c6da', '#1e88e5']\n        }\n    });\n\n\n\n\n\n});\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/js/jquery.slimscroll.js",
    "content": "!function(e){e.fn.extend({slimScroll:function(i){var o={width:\"auto\",height:\"250px\",size:\"7px\",color:\"#000\",position:\"right\",distance:\"1px\",start:\"top\",opacity:.4,alwaysVisible:!1,disableFadeOut:!1,railVisible:!1,railColor:\"#333\",railOpacity:.2,railDraggable:!0,railClass:\"slimScrollRail\",barClass:\"slimScrollBar\",wrapperClass:\"slimScrollDiv\",allowPageScroll:!1,wheelStep:20,touchScrollStep:200,borderRadius:\"7px\",railBorderRadius:\"7px\"},s=e.extend(o,i);return this.each(function(){function o(t){if(h){var t=t||window.event,i=0;t.wheelDelta&&(i=-t.wheelDelta/120),t.detail&&(i=t.detail/3);var o=t.target||t.srcTarget||t.srcElement;e(o).closest(\".\"+s.wrapperClass).is(x.parent())&&r(i,!0),t.preventDefault&&!y&&t.preventDefault(),y||(t.returnValue=!1)}}function r(e,t,i){y=!1;var o=e,r=x.outerHeight()-R.outerHeight();if(t&&(o=parseInt(R.css(\"top\"))+e*parseInt(s.wheelStep)/100*R.outerHeight(),o=Math.min(Math.max(o,0),r),o=e>0?Math.ceil(o):Math.floor(o),R.css({top:o+\"px\"})),v=parseInt(R.css(\"top\"))/(x.outerHeight()-R.outerHeight()),o=v*(x[0].scrollHeight-x.outerHeight()),i){o=e;var a=o/x[0].scrollHeight*x.outerHeight();a=Math.min(Math.max(a,0),r),R.css({top:a+\"px\"})}x.scrollTop(o),x.trigger(\"slimscrolling\",~~o),n(),c()}function a(e){window.addEventListener?(e.addEventListener(\"DOMMouseScroll\",o,!1),e.addEventListener(\"mousewheel\",o,!1)):document.attachEvent(\"onmousewheel\",o)}function l(){f=Math.max(x.outerHeight()/x[0].scrollHeight*x.outerHeight(),m),R.css({height:f+\"px\"});var e=f==x.outerHeight()?\"none\":\"block\";R.css({display:e})}function n(){if(l(),clearTimeout(p),v==~~v){if(y=s.allowPageScroll,b!=v){var e=0==~~v?\"top\":\"bottom\";x.trigger(\"slimscroll\",e)}}else y=!1;return b=v,f>=x.outerHeight()?void(y=!0):(R.stop(!0,!0).fadeIn(\"fast\"),void(s.railVisible&&E.stop(!0,!0).fadeIn(\"fast\")))}function c(){s.alwaysVisible||(p=setTimeout(function(){s.disableFadeOut&&h||u||d||(R.fadeOut(\"slow\"),E.fadeOut(\"slow\"))},1e3))}var h,u,d,p,g,f,v,b,w=\"<div></div>\",m=30,y=!1,x=e(this);if(x.parent().hasClass(s.wrapperClass)){var C=x.scrollTop();if(R=x.closest(\".\"+s.barClass),E=x.closest(\".\"+s.railClass),l(),e.isPlainObject(i)){if(\"height\"in i&&\"auto\"==i.height){x.parent().css(\"height\",\"auto\"),x.css(\"height\",\"auto\");var H=x.parent().parent().height();x.parent().css(\"height\",H),x.css(\"height\",H)}if(\"scrollTo\"in i)C=parseInt(s.scrollTo);else if(\"scrollBy\"in i)C+=parseInt(s.scrollBy);else if(\"destroy\"in i)return R.remove(),E.remove(),void x.unwrap();r(C,!1,!0)}}else if(!(e.isPlainObject(i)&&\"destroy\"in i)){s.height=\"auto\"==s.height?x.parent().height():s.height;var S=e(w).addClass(s.wrapperClass).css({position:\"relative\",overflow:\"hidden\",width:s.width,height:s.height});x.css({overflow:\"hidden\",width:s.width,height:s.height});var E=e(w).addClass(s.railClass).css({width:s.size,height:\"100%\",position:\"absolute\",top:0,display:s.alwaysVisible&&s.railVisible?\"block\":\"none\",\"border-radius\":s.railBorderRadius,background:s.railColor,opacity:s.railOpacity,zIndex:90}),R=e(w).addClass(s.barClass).css({background:s.color,width:s.size,position:\"absolute\",top:0,opacity:s.opacity,display:s.alwaysVisible?\"block\":\"none\",\"border-radius\":s.borderRadius,BorderRadius:s.borderRadius,MozBorderRadius:s.borderRadius,WebkitBorderRadius:s.borderRadius,zIndex:99}),D=\"right\"==s.position?{right:s.distance}:{left:s.distance};E.css(D),R.css(D),x.wrap(S),x.parent().append(R),x.parent().append(E),s.railDraggable&&R.bind(\"mousedown\",function(i){var o=e(document);return d=!0,t=parseFloat(R.css(\"top\")),pageY=i.pageY,o.bind(\"mousemove.slimscroll\",function(e){currTop=t+e.pageY-pageY,R.css(\"top\",currTop),r(0,R.position().top,!1)}),o.bind(\"mouseup.slimscroll\",function(e){d=!1,c(),o.unbind(\".slimscroll\")}),!1}).bind(\"selectstart.slimscroll\",function(e){return e.stopPropagation(),e.preventDefault(),!1}),E.hover(function(){n()},function(){c()}),R.hover(function(){u=!0},function(){u=!1}),x.hover(function(){h=!0,n(),c()},function(){h=!1,c()}),x.bind(\"touchstart\",function(e,t){e.originalEvent.touches.length&&(g=e.originalEvent.touches[0].pageY)}),x.bind(\"touchmove\",function(e){if(y||e.originalEvent.preventDefault(),e.originalEvent.touches.length){var t=(g-e.originalEvent.touches[0].pageY)/s.touchScrollStep;r(t,!0),g=e.originalEvent.touches[0].pageY}}),l(),\"bottom\"===s.start?(R.css({top:x.outerHeight()-R.outerHeight()}),r(0,!0)):\"top\"!==s.start&&(r(e(s.start).position().top,null,!0),s.alwaysVisible||R.hide()),a(this)}}),this}}),e.fn.extend({slimscroll:e.fn.slimScroll})}(jQuery);"
  },
  {
    "path": "src/main/resources/static/dashboard/html/js/sidebarmenu.js",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: js\n*/\n(function (global, factory) {\n  if (typeof define === \"function\" && define.amd) {\n    define(['jquery'], factory);\n  } else if (typeof exports !== \"undefined\") {\n    factory(require('jquery'));\n  } else {\n    var mod = {\n      exports: {}\n    };\n    factory(global.jquery);\n    global.metisMenu = mod.exports;\n  }\n})(this, function (_jquery) {\n  'use strict';\n\n  var _jquery2 = _interopRequireDefault(_jquery);\n\n  function _interopRequireDefault(obj) {\n    return obj && obj.__esModule ? obj : {\n      default: obj\n    };\n  }\n\n  var _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n    return typeof obj;\n  } : function (obj) {\n    return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n  };\n\n  function _classCallCheck(instance, Constructor) {\n    if (!(instance instanceof Constructor)) {\n      throw new TypeError(\"Cannot call a class as a function\");\n    }\n  }\n\n  var Util = function ($) {\n    var transition = false;\n\n    var TransitionEndEvent = {\n      WebkitTransition: 'webkitTransitionEnd',\n      MozTransition: 'transitionend',\n      OTransition: 'oTransitionEnd otransitionend',\n      transition: 'transitionend'\n    };\n\n    function getSpecialTransitionEndEvent() {\n      return {\n        bindType: transition.end,\n        delegateType: transition.end,\n        handle: function handle(event) {\n          if ($(event.target).is(this)) {\n            return event.handleObj.handler.apply(this, arguments);\n          }\n          return undefined;\n        }\n      };\n    }\n\n    function transitionEndTest() {\n      if (window.QUnit) {\n        return false;\n      }\n\n      var el = document.createElement('mm');\n\n      for (var name in TransitionEndEvent) {\n        if (el.style[name] !== undefined) {\n          return {\n            end: TransitionEndEvent[name]\n          };\n        }\n      }\n\n      return false;\n    }\n\n    function transitionEndEmulator(duration) {\n      var _this2 = this;\n\n      var called = false;\n\n      $(this).one(Util.TRANSITION_END, function () {\n        called = true;\n      });\n\n      setTimeout(function () {\n        if (!called) {\n          Util.triggerTransitionEnd(_this2);\n        }\n      }, duration);\n\n      return this;\n    }\n\n    function setTransitionEndSupport() {\n      transition = transitionEndTest();\n      $.fn.emulateTransitionEnd = transitionEndEmulator;\n\n      if (Util.supportsTransitionEnd()) {\n        $.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();\n      }\n    }\n\n    var Util = {\n      TRANSITION_END: 'mmTransitionEnd',\n\n      triggerTransitionEnd: function triggerTransitionEnd(element) {\n        $(element).trigger(transition.end);\n      },\n      supportsTransitionEnd: function supportsTransitionEnd() {\n        return Boolean(transition);\n      }\n    };\n\n    setTransitionEndSupport();\n\n    return Util;\n  }(jQuery);\n\n  var MetisMenu = function ($) {\n\n    var NAME = 'metisMenu';\n    var DATA_KEY = 'metisMenu';\n    var EVENT_KEY = '.' + DATA_KEY;\n    var DATA_API_KEY = '.data-api';\n    var JQUERY_NO_CONFLICT = $.fn[NAME];\n    var TRANSITION_DURATION = 350;\n\n    var Default = {\n      toggle: true,\n      preventDefault: true,\n      activeClass: 'active',\n      collapseClass: 'collapse',\n      collapseInClass: 'in',\n      collapsingClass: 'collapsing',\n      triggerElement: 'a',\n      parentTrigger: 'li',\n      subMenu: 'ul'\n    };\n\n    var Event = {\n      SHOW: 'show' + EVENT_KEY,\n      SHOWN: 'shown' + EVENT_KEY,\n      HIDE: 'hide' + EVENT_KEY,\n      HIDDEN: 'hidden' + EVENT_KEY,\n      CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY\n    };\n\n    var MetisMenu = function () {\n      function MetisMenu(element, config) {\n        _classCallCheck(this, MetisMenu);\n\n        this._element = element;\n        this._config = this._getConfig(config);\n        this._transitioning = null;\n\n        this.init();\n      }\n\n      MetisMenu.prototype.init = function init() {\n        var self = this;\n        $(this._element).find(this._config.parentTrigger + '.' + this._config.activeClass).has(this._config.subMenu).children(this._config.subMenu).attr('aria-expanded', true).addClass(this._config.collapseClass + ' ' + this._config.collapseInClass);\n\n        $(this._element).find(this._config.parentTrigger).not('.' + this._config.activeClass).has(this._config.subMenu).children(this._config.subMenu).attr('aria-expanded', false).addClass(this._config.collapseClass);\n\n        $(this._element).find(this._config.parentTrigger).has(this._config.subMenu).children(this._config.triggerElement).on(Event.CLICK_DATA_API, function (e) {\n          var _this = $(this);\n          var _parent = _this.parent(self._config.parentTrigger);\n          var _siblings = _parent.siblings(self._config.parentTrigger).children(self._config.triggerElement);\n          var _list = _parent.children(self._config.subMenu);\n          if (self._config.preventDefault) {\n            e.preventDefault();\n          }\n          if (_this.attr('aria-disabled') === 'true') {\n            return;\n          }\n          if (_parent.hasClass(self._config.activeClass)) {\n            _this.attr('aria-expanded', false);\n            self._hide(_list);\n          } else {\n            self._show(_list);\n            _this.attr('aria-expanded', true);\n            if (self._config.toggle) {\n              _siblings.attr('aria-expanded', false);\n            }\n          }\n\n          if (self._config.onTransitionStart) {\n            self._config.onTransitionStart(e);\n          }\n        });\n      };\n\n      MetisMenu.prototype._show = function _show(element) {\n        if (this._transitioning || $(element).hasClass(this._config.collapsingClass)) {\n          return;\n        }\n        var _this = this;\n        var _el = $(element);\n\n        var startEvent = $.Event(Event.SHOW);\n        _el.trigger(startEvent);\n\n        if (startEvent.isDefaultPrevented()) {\n          return;\n        }\n\n        _el.parent(this._config.parentTrigger).addClass(this._config.activeClass);\n\n        if (this._config.toggle) {\n          this._hide(_el.parent(this._config.parentTrigger).siblings().children(this._config.subMenu + '.' + this._config.collapseInClass).attr('aria-expanded', false));\n        }\n\n        _el.removeClass(this._config.collapseClass).addClass(this._config.collapsingClass).height(0);\n\n        this.setTransitioning(true);\n\n        var complete = function complete() {\n\n          _el.removeClass(_this._config.collapsingClass).addClass(_this._config.collapseClass + ' ' + _this._config.collapseInClass).height('').attr('aria-expanded', true);\n\n          _this.setTransitioning(false);\n\n          _el.trigger(Event.SHOWN);\n        };\n\n        if (!Util.supportsTransitionEnd()) {\n          complete();\n          return;\n        }\n\n        _el.height(_el[0].scrollHeight).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n      };\n\n      MetisMenu.prototype._hide = function _hide(element) {\n\n        if (this._transitioning || !$(element).hasClass(this._config.collapseInClass)) {\n          return;\n        }\n        var _this = this;\n        var _el = $(element);\n\n        var startEvent = $.Event(Event.HIDE);\n        _el.trigger(startEvent);\n\n        if (startEvent.isDefaultPrevented()) {\n          return;\n        }\n\n        _el.parent(this._config.parentTrigger).removeClass(this._config.activeClass);\n        _el.height(_el.height())[0].offsetHeight;\n\n        _el.addClass(this._config.collapsingClass).removeClass(this._config.collapseClass).removeClass(this._config.collapseInClass);\n\n        this.setTransitioning(true);\n\n        var complete = function complete() {\n          if (_this._transitioning && _this._config.onTransitionEnd) {\n            _this._config.onTransitionEnd();\n          }\n\n          _this.setTransitioning(false);\n          _el.trigger(Event.HIDDEN);\n\n          _el.removeClass(_this._config.collapsingClass).addClass(_this._config.collapseClass).attr('aria-expanded', false);\n        };\n\n        if (!Util.supportsTransitionEnd()) {\n          complete();\n          return;\n        }\n\n        _el.height() == 0 || _el.css('display') == 'none' ? complete() : _el.height(0).one(Util.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);\n      };\n\n      MetisMenu.prototype.setTransitioning = function setTransitioning(isTransitioning) {\n        this._transitioning = isTransitioning;\n      };\n\n      MetisMenu.prototype.dispose = function dispose() {\n        $.removeData(this._element, DATA_KEY);\n\n        $(this._element).find(this._config.parentTrigger).has(this._config.subMenu).children(this._config.triggerElement).off('click');\n\n        this._transitioning = null;\n        this._config = null;\n        this._element = null;\n      };\n\n      MetisMenu.prototype._getConfig = function _getConfig(config) {\n        config = $.extend({}, Default, config);\n        return config;\n      };\n\n      MetisMenu._jQueryInterface = function _jQueryInterface(config) {\n        return this.each(function () {\n          var $this = $(this);\n          var data = $this.data(DATA_KEY);\n          var _config = $.extend({}, Default, $this.data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config);\n\n          if (!data && /dispose/.test(config)) {\n            this.dispose();\n          }\n\n          if (!data) {\n            data = new MetisMenu(this, _config);\n            $this.data(DATA_KEY, data);\n          }\n\n          if (typeof config === 'string') {\n            if (data[config] === undefined) {\n              throw new Error('No method named \"' + config + '\"');\n            }\n            data[config]();\n          }\n        });\n      };\n\n      return MetisMenu;\n    }();\n\n    /**\n     * ------------------------------------------------------------------------\n     * jQuery\n     * ------------------------------------------------------------------------\n     */\n\n    $.fn[NAME] = MetisMenu._jQueryInterface;\n    $.fn[NAME].Constructor = MetisMenu;\n    $.fn[NAME].noConflict = function () {\n      $.fn[NAME] = JQUERY_NO_CONFLICT;\n      return MetisMenu._jQueryInterface;\n    };\n    return MetisMenu;\n  }(jQuery);\n});"
  },
  {
    "path": "src/main/resources/static/dashboard/html/js/waves.js",
    "content": "!function(t){\"use strict\";function e(t){return null!==t&&t===t.window}function n(t){return e(t)?t:9===t.nodeType&&t.defaultView}function a(t){var e,a,i={top:0,left:0},o=t&&t.ownerDocument;return e=o.documentElement,\"undefined\"!=typeof t.getBoundingClientRect&&(i=t.getBoundingClientRect()),a=n(o),{top:i.top+a.pageYOffset-e.clientTop,left:i.left+a.pageXOffset-e.clientLeft}}function i(t){var e=\"\";for(var n in t)t.hasOwnProperty(n)&&(e+=n+\":\"+t[n]+\";\");return e}function o(t){if(d.allowEvent(t)===!1)return null;for(var e=null,n=t.target||t.srcElement;null!==n.parentElement;){if(!(n instanceof SVGElement||-1===n.className.indexOf(\"waves-effect\"))){e=n;break}if(n.classList.contains(\"waves-effect\")){e=n;break}n=n.parentElement}return e}function r(e){var n=o(e);null!==n&&(c.show(e,n),\"ontouchstart\"in t&&(n.addEventListener(\"touchend\",c.hide,!1),n.addEventListener(\"touchcancel\",c.hide,!1)),n.addEventListener(\"mouseup\",c.hide,!1),n.addEventListener(\"mouseleave\",c.hide,!1))}var s=s||{},u=document.querySelectorAll.bind(document),c={duration:750,show:function(t,e){if(2===t.button)return!1;var n=e||this,o=document.createElement(\"div\");o.className=\"waves-ripple\",n.appendChild(o);var r=a(n),s=t.pageY-r.top,u=t.pageX-r.left,d=\"scale(\"+n.clientWidth/100*10+\")\";\"touches\"in t&&(s=t.touches[0].pageY-r.top,u=t.touches[0].pageX-r.left),o.setAttribute(\"data-hold\",Date.now()),o.setAttribute(\"data-scale\",d),o.setAttribute(\"data-x\",u),o.setAttribute(\"data-y\",s);var l={top:s+\"px\",left:u+\"px\"};o.className=o.className+\" waves-notransition\",o.setAttribute(\"style\",i(l)),o.className=o.className.replace(\"waves-notransition\",\"\"),l[\"-webkit-transform\"]=d,l[\"-moz-transform\"]=d,l[\"-ms-transform\"]=d,l[\"-o-transform\"]=d,l.transform=d,l.opacity=\"1\",l[\"-webkit-transition-duration\"]=c.duration+\"ms\",l[\"-moz-transition-duration\"]=c.duration+\"ms\",l[\"-o-transition-duration\"]=c.duration+\"ms\",l[\"transition-duration\"]=c.duration+\"ms\",l[\"-webkit-transition-timing-function\"]=\"cubic-bezier(0.250, 0.460, 0.450, 0.940)\",l[\"-moz-transition-timing-function\"]=\"cubic-bezier(0.250, 0.460, 0.450, 0.940)\",l[\"-o-transition-timing-function\"]=\"cubic-bezier(0.250, 0.460, 0.450, 0.940)\",l[\"transition-timing-function\"]=\"cubic-bezier(0.250, 0.460, 0.450, 0.940)\",o.setAttribute(\"style\",i(l))},hide:function(t){d.touchup(t);var e=this,n=(1.4*e.clientWidth,null),a=e.getElementsByClassName(\"waves-ripple\");if(!(a.length>0))return!1;n=a[a.length-1];var o=n.getAttribute(\"data-x\"),r=n.getAttribute(\"data-y\"),s=n.getAttribute(\"data-scale\"),u=Date.now()-Number(n.getAttribute(\"data-hold\")),l=350-u;0>l&&(l=0),setTimeout(function(){var t={top:r+\"px\",left:o+\"px\",opacity:\"0\",\"-webkit-transition-duration\":c.duration+\"ms\",\"-moz-transition-duration\":c.duration+\"ms\",\"-o-transition-duration\":c.duration+\"ms\",\"transition-duration\":c.duration+\"ms\",\"-webkit-transform\":s,\"-moz-transform\":s,\"-ms-transform\":s,\"-o-transform\":s,transform:s};n.setAttribute(\"style\",i(t)),setTimeout(function(){try{e.removeChild(n)}catch(t){return!1}},c.duration)},l)},wrapInput:function(t){for(var e=0;e<t.length;e++){var n=t[e];if(\"input\"===n.tagName.toLowerCase()){var a=n.parentNode;if(\"i\"===a.tagName.toLowerCase()&&-1!==a.className.indexOf(\"waves-effect\"))continue;var i=document.createElement(\"i\");i.className=n.className+\" waves-input-wrapper\";var o=n.getAttribute(\"style\");o||(o=\"\"),i.setAttribute(\"style\",o),n.className=\"waves-button-input\",n.removeAttribute(\"style\"),a.replaceChild(i,n),i.appendChild(n)}}}},d={touches:0,allowEvent:function(t){var e=!0;return\"touchstart\"===t.type?d.touches+=1:\"touchend\"===t.type||\"touchcancel\"===t.type?setTimeout(function(){d.touches>0&&(d.touches-=1)},500):\"mousedown\"===t.type&&d.touches>0&&(e=!1),e},touchup:function(t){d.allowEvent(t)}};s.displayEffect=function(e){e=e||{},\"duration\"in e&&(c.duration=e.duration),c.wrapInput(u(\".waves-effect\")),\"ontouchstart\"in t&&document.body.addEventListener(\"touchstart\",r,!1),document.body.addEventListener(\"mousedown\",r,!1)},s.attach=function(e){\"input\"===e.tagName.toLowerCase()&&(c.wrapInput([e]),e=e.parentElement),\"ontouchstart\"in t&&e.addEventListener(\"touchstart\",r,!1),e.addEventListener(\"mousedown\",r,!1)},t.Waves=s,document.addEventListener(\"DOMContentLoaded\",function(){s.displayEffect()},!1)}(window);"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/app.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/**\n * Table Of Content\n *\n * \t1. Globals\n *\t2. Headers\n *\t3. Navigations\n *\t4. Banners\n *\t5. Footers\n *\t6. Posts\n *\t7. Widgets\n *\t8. Custom Templates\n */\n/******************* \nGlobal Styles \n*******************/\n\n* {\n    outline: none;\n}\n\nbody {\n    background: $sidebar;\n    font-family: $bodyfont;\n    margin: 0;\n    overflow-x: hidden;\n    color: $bodytext;\n    font-weight: 300;\n}\n\nhtml {\n    position: relative;\n    min-height: 100%;\n    background: $white;\n}\na:hover, a:focus{\n    text-decoration: none;\n}\na.link{\n    color:$headingtext;\n    &:hover, &:focus{\n        color:$themecolor;\n    }\n}\n.img-responsive{\n    width: 100%;\n    height: auto;\n    display: inline-block;\n}\n.img-rounded{\n    border-radius: $radius;\n}\nhtml body .mdi:before, html body .mdi-set{\n    line-height: initial;\n}\n/*******************\nHeadings\n*******************/\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n    color: $headingtext;\n    font-family: $headingfont;\n    font-weight: 400;\n}\n\nh1 {\n    line-height: 40px;\n    font-size: 36px\n}\n\nh2 {\n    line-height: 36px;\n    font-size: 24px\n}\n\nh3 {\n    line-height: 30px;\n    font-size: 21px\n}\n\nh4 {\n    line-height: 22px;\n    font-size: 18px\n}\n\nh5 {\n    line-height: 18px;\n    font-size: 16px;\n    font-weight: 400;\n}\n\nh6 {\n    line-height: 16px;\n    font-size: 14px;\n    font-weight: 400;\n}\n.display-5{\n    font-size:3rem;\n}\n.display-6{\n    font-size:36px;\n}\n.box{\n    border-radius: $radius;\n    padding: 10px;\n}\nhtml body {\n.dl{\n    display: inline-block;\n}\n.db{\n    display: block;\n}\n}    \n.no-wrap{\n    td, th{\n        white-space: nowrap;\n    }\n}\n/*******************\nBlockquote\n*******************/\n\nhtml body blockquote {\n    border-left: 5px solid $themecolor;\n    border: 1px solid $border;\n    padding: 15px;\n}\n\n.clear {\n    clear: both;\n}\nol li{\n    margin: 5px 0;\n}\n\n/*******************\nPaddings\n*******************/\nhtml body {\n.p-0 {\n    padding: 0px;\n}\n\n.p-10 {\n    padding: 10px;\n}\n\n.p-20 {\n    padding: 20px;\n}\n\n.p-30 {\n    padding: 30px;\n}\n\n.p-l-0 {\n    padding-left: 0px;\n}\n\n.p-l-10 {\n    padding-left: 10px;\n}\n\n.p-l-20 {\n    padding-left: 20px;\n}\n\n.p-r-0 {\n    padding-right: 0px;\n}\n\n.p-r-10 {\n    padding-right: 10px;\n}\n\n.p-r-20 {\n    padding-right: 20px;\n}\n\n.p-r-30 {\n    padding-right: 30px;\n}\n\n.p-r-40 {\n    padding-right: 40px;\n}\n\n.p-t-0 {\n    padding-top: 0px;\n}\n\n.p-t-10 {\n    padding-top: 10px;\n}\n\n.p-t-20 {\n    padding-top: 20px;\n}\n\n.p-t-30 {\n    padding-top: 30px;\n}\n\n.p-b-0 {\n    padding-bottom: 0px;\n}\n\n.p-b-5 {\n    padding-bottom: 5px;\n}\n\n.p-b-10 {\n    padding-bottom: 10px;\n}\n\n.p-b-20 {\n    padding-bottom: 20px;\n}\n\n.p-b-30 {\n    padding-bottom: 30px;\n}\n\n.p-b-40 {\n    padding-bottom: 40px;\n}\n}\n\n/*******************\nMargin\n*******************/\nhtml body {\n.m-0 {\n    margin: 0px;\n}\n\n.m-l-5 {\n    margin-left: 5px;\n}\n\n.m-l-10 {\n    margin-left: 10px;\n}\n\n.m-l-15 {\n    margin-left: 15px;\n}\n\n.m-l-20 {\n    margin-left: 20px;\n}\n\n.m-l-30 {\n    margin-left: 30px;\n}\n\n.m-l-40 {\n    margin-left: 40px;\n}\n\n.m-r-5 {\n    margin-right: 5px;\n}\n\n.m-r-10 {\n    margin-right: 10px;\n}\n\n.m-r-15 {\n    margin-right: 15px;\n}\n\n.m-r-20 {\n    margin-right: 20px;\n}\n\n.m-r-30 {\n    margin-right: 30px;\n}\n\n.m-r-40 {\n    margin-right: 40px;\n}\n\n.m-t-0 {\n    margin-top: 0px;\n}\n\n.m-t-5 {\n    margin-top: 5px;\n}\n\n.m-t-10 {\n    margin-top: 10px;\n}\n\n.m-t-15 {\n    margin-top: 15px;\n}\n\n.m-t-20 {\n    margin-top: 20px;\n}\n\n.m-t-30 {\n    margin-top: 30px;\n}\n\n.m-t-40 {\n    margin-top: 40px;\n}\n\n.m-b-0 {\n    margin-bottom: 0px;\n}\n\n.m-b-5 {\n    margin-bottom: 5px;\n}\n\n.m-b-10 {\n    margin-bottom: 10px;\n}\n\n.m-b-15 {\n    margin-bottom: 15px;\n}\n\n.m-b-20 {\n    margin-bottom: 20px;\n}\n\n.m-b-30 {\n    margin-bottom: 30px ;\n}\n\n.m-b-40 {\n    margin-bottom: 40px;\n}\n}\n\n/*******************\nvertical alignment\n*******************/\nhtml body {\n.vt {\n    vertical-align: top;\n}\n\n.vm {\n    vertical-align: middle;\n}\n\n.vb {\n    vertical-align: bottom; \n}\n}    \n/*******************\nOpacity\n*******************/\n.op-5{\n    opacity: 0.5;\n}\n/*******************\nfont weight\n*******************/\nhtml body {\n.font-bold {\n    font-weight: 700;\n}\n\n.font-normal {\n    font-weight: normal;\n}\n\n.font-light {\n    font-weight: 300;\n}\n.font-medium {\n    font-weight: 500;\n}\n.font-16 {\n    font-size: 16px;\n}\n.font-14 {\n    font-size: 14px;\n}\n.font-10 {\n    font-size: 10px;\n}\n.font-18 {\n    font-size: 18px;\n}\n.font-20 {\n    font-size: 20px;\n    }\n}\n/*******************\nBorder\n*******************/\nhtml body {\n.b-0{\n    border:none;\n}\n.b-r{\n    border-right:1px solid $border;\n}\n.b-l{\n    border-left:1px solid $border;\n}\n.b-b{\n    border-bottom:1px solid $border;\n}\n.b-t{\n    border-top:1px solid $border;\n}\n.b-all{\n    border:1px solid $border;\n}\n}\n/*******************\nThumb size\n*******************/\n\n.thumb-sm {\n    height: 32px;\n    width: 32px;\n}\n\n.thumb-md {\n    height: 48px;\n    width: 48px;\n}\n\n.thumb-lg {\n    height: 88px;\n    width: 88px;\n}\n.hide{\n    display: none;\n}\n.img-circle{\n    border-radius: 100%;\n}\n.radius{\n    border-radius: $radius;\n}\n/*******************\nText Colors\n*******************/\n.text-white {\n    color: $white!important;\n}\n\n.text-danger {\n    color: $danger!important;\n}\n\n.text-muted {\n    color: $muted!important;\n}\n\n.text-warning {\n    color: $warning!important;\n}\n\n.text-success {\n    color: $success!important;\n}\n\n.text-info {\n    color: $info!important;\n}\n\n.text-inverse {\n    color: $inverse!important;\n}\nhtml body {\n.text-blue {\n    color: $blue;\n}\n\n.text-purple {\n    color: $purple;\n}\n\n.text-primary {\n    color: $primary;\n}\n\n.text-megna {\n    color: $megna;\n}\n\n.text-dark {\n    color: $bodytext;\n}\n.text-themecolor {\n    color: $themecolor;\n}\n    }\n/*******************\nBackground Colors\n*******************/\n\n.bg-primary {\n    background-color: $primary !important;\n}\n\n.bg-success {\n    background-color: $success !important;\n}\n\n.bg-info {\n    background-color: $info !important;\n}\n\n.bg-warning {\n    background-color: $warning !important;\n}\n\n.bg-danger {\n    background-color: $danger !important;\n}\nhtml body {\n.bg-megna {\n    background-color: $megna;\n}\n.bg-theme {\n    background-color: $themecolor;\n}\n\n.bg-inverse {\n    background-color: $inverse;\n}\n\n.bg-purple {\n    background-color: $purple;\n}\n\n.bg-light-primary {\n    background-color: $light-primary;\n}\n\n.bg-light-success {\n    background-color: $light-success;\n}\n\n.bg-light-info {\n    background-color: $light-info;\n}\n.bg-light-extra {\n    background-color: $extra-light;\n}\n\n.bg-light-warning {\n    background-color: $light-warning;\n}\n\n.bg-light-danger {\n    background-color: $light-danger;\n}\n\n.bg-light-inverse {\n    background-color: $light-inverse;\n}\n.bg-light {\n    background-color: $light;\n}\n.bg-white {\n    background-color: $white;\n}\n    }\n/*******************\nRounds\n*******************/\n.round{\n    line-height:48px;\n    color: $white;\n    width: 45px;\n    height: 45px;\n    display: inline-block;\n    font-weight: 400;\n    text-align: center;\n    border-radius: 100%;\n    background: $info;\n    img{\n        border-radius: 100%;\n    }\n}\n.round-lg{\n    line-height:65px;\n    width: 60px;\n    height: 60px;\n    font-size:30px;\n}\n.round.round-info{\n    background: $info;\n}\n.round.round-warning{\n    background: $warning;\n}\n.round.round-danger{\n    background: $danger;\n}\n.round.round-success{\n    background: $success;\n}\n.round.round-primary{\n    background: $primary;\n}\n/*******************\nLabels\n*******************/\n\n.label {\n    padding: 3px 10px;\n    line-height: 13px;\n    color: $white;\n    font-weight: 400;\n    border-radius: $radius;\n    font-size: 75%;\n}\n\n.label-rounded {\n    border-radius: 60px;\n}\n\n.label-custom {\n    background-color: $megna;\n}\n\n.label-success {\n    background-color: $success;\n}\n\n.label-info {\n    background-color: $info;\n}\n\n.label-warning {\n    background-color: $warning;\n}\n\n.label-danger {\n    background-color: $danger;\n}\n\n.label-megna {\n    background-color: $megna;\n}\n\n.label-primary {\n    background-color: $primary;\n}\n\n.label-purple {\n    background-color: $purple;\n}\n\n.label-red {\n    background-color: $red;\n}\n\n.label-inverse {\n    background-color: $inverse;\n}\n\n.label-default {\n    background-color: $light;\n}\n\n.label-white {\n    background-color: $white;\n}\n\n\n.label-light-success {\n    background-color: $light-success;\n    color:$success;\n}\n\n.label-light-info {\n    background-color: $light-info;\n    color:$info;\n}\n\n.label-light-warning {\n    background-color: $light-warning;\n    color:$warning;\n}\n\n.label-light-danger {\n    background-color: $light-danger;\n    color:$danger;\n}\n\n.label-light-megna {\n    background-color: $light-megna;\n    color:$megna;\n}\n\n.label-light-primary {\n    background-color: $light-primary;\n    color:$primary;\n}\n\n.label-light-inverse {\n    background-color: $light-inverse;\n    color:$inverse;\n}\n\n/*******************\nPagination\n*******************/\n\n.pagination > li:first-child > a,\n.pagination > li:first-child > span {\n    border-bottom-left-radius: $radius;\n    border-top-left-radius: $radius;\n}\n\n.pagination > li:last-child > a,\n.pagination > li:last-child > span {\n    border-bottom-right-radius: $radius;\n    border-top-right-radius: $radius;\n}\n\n.pagination > li > a,\n.pagination > li > span {\n    color: $dark;\n}\n\n.pagination > li > a:hover,\n.pagination > li > span:hover,\n.pagination > li > a:focus,\n.pagination > li > span:focus {\n    background-color: $light;\n}\n\n.pagination-split li {\n    margin-left: 5px;\n    display: inline-block;\n    float: $lft;\n}\n\n.pagination-split li:first-child {\n    margin-left: 0;\n}\n\n.pagination-split li a {\n    -moz-border-radius: $radius;\n    -webkit-border-radius: $radius;\n    border-radius: $radius;\n}\n\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n    background-color: $themecolor;\n    border-color: $themecolor;\n}\n\n.pager li > a,\n.pager li > span {\n    -moz-border-radius: $radius;\n    -webkit-border-radius: $radius;\n    border-radius: $radius;\n    color: $dark;\n}\n\n\n/*******************\nTable Cell\n*******************/\n\n.table-box {\n    display: table;\n    width: 100%;\n}\n.table.no-border{\n    tbody{\n        td{\n            border:0px;\n        }\n    }\n}\n.cell {\n    display: table-cell;\n    vertical-align: middle;\n}\n.table td, .table th{\n    border-color:$table-border; \n}\n.table thead th, .table th{\n    font-weight:500;\n}\n.table-hover tbody tr:hover{\n    background:$light;\n}\n\n.v-middle{\n    td, th{\n        vertical-align:middle;\n    }\n}\n\n/*******************\nWave Effects\n*******************/\n\n.waves-effect {\n    position: relative;\n    cursor: pointer;\n    display: inline-block;\n    overflow: hidden;\n    -webkit-user-select: none;\n    -moz-user-select: none;\n    -ms-user-select: none;\n    user-select: none;\n    -webkit-tap-highlight-color: transparent;\n    vertical-align: middle;\n    z-index: 1;\n    will-change: opacity, transform;\n    -webkit-transition: all 0.1s ease-out;\n    -moz-transition: all 0.1s ease-out;\n    -o-transition: all 0.1s ease-out;\n    -ms-transition: all 0.1s ease-out;\n    transition: all 0.1s ease-out;\n    .waves-ripple {\n        position: absolute;\n        border-radius: 50%;\n        width: 20px;\n        height: 20px;\n        margin-top: -10px;\n        margin-left: -10px;\n        opacity: 0;\n        background: rgba(0, 0, 0, 0.2);\n        -webkit-transition: all 0.7s ease-out;\n        -moz-transition: all 0.7s ease-out;\n        -o-transition: all 0.7s ease-out;\n        -ms-transition: all 0.7s ease-out;\n        transition: all 0.7s ease-out;\n        -webkit-transition-property: -webkit-transform, opacity;\n        -moz-transition-property: -moz-transform, opacity;\n        -o-transition-property: -o-transform, opacity;\n        transition-property: transform, opacity;\n        -webkit-transform: scale(0);\n        -moz-transform: scale(0);\n        -ms-transform: scale(0);\n        -o-transform: scale(0);\n        transform: scale(0);\n        pointer-events: none;\n    }\n}\n\n.waves-effect.waves-light {\n    .waves-ripple {\n        background-color: rgba(255, 255, 255, 0.45);\n    }\n}\n\n.waves-effect.waves-red {\n    .waves-ripple {\n        background-color: rgba(244, 67, 54, 0.7);\n    }\n}\n\n.waves-effect.waves-yellow {\n    .waves-ripple {\n        background-color: rgba(255, 235, 59, 0.7);\n    }\n}\n\n.waves-effect.waves-orange {\n    .waves-ripple {\n        background-color: rgba(255, 152, 0, 0.7);\n    }\n}\n\n.waves-effect.waves-purple {\n    .waves-ripple {\n        background-color: rgba(156, 39, 176, 0.7);\n    }\n}\n\n.waves-effect.waves-green {\n    .waves-ripple {\n        background-color: rgba(76, 175, 80, 0.7);\n    }\n}\n\n.waves-effect.waves-teal {\n    .waves-ripple {\n        background-color: rgba(0, 150, 136, 0.7);\n    }\n}\n\nhtml body .waves-notransition {\n    -webkit-transition: none;\n    -moz-transition: none;\n    -o-transition: none;\n    -ms-transition: none;\n    transition: none;\n}\n\n.waves-circle {\n    -webkit-transform: translateZ(0);\n    -moz-transform: translateZ(0);\n    -ms-transform: translateZ(0);\n    -o-transform: translateZ(0);\n    transform: translateZ(0);\n    text-align: center;\n    width: 2.5em;\n    height: 2.5em;\n    line-height: 2.5em;\n    border-radius: 50%;\n    -webkit-mask-image: none;\n}\n\n.waves-input-wrapper {\n    border-radius: 0.2em;\n    vertical-align: bottom;\n    .waves-button-input {\n        position: relative;\n        top: 0;\n        left: 0;\n        z-index: 1;\n    }\n}\n\n.waves-block {\n    display: block;\n}\n\n/*Badge*/\n.badge{\n    font-weight: 400;\n}\n.badge-xs {\n    font-size: 9px;\n}\n\n.badge-xs,\n.badge-sm {\n    -webkit-transform: translate(0, -2px);\n    -ms-transform: translate(0, -2px);\n    -o-transform: translate(0, -2px);\n    transform: translate(0, -2px);\n}\n.badge-success {\n    background-color: $success;\n}\n\n.badge-info {\n    background-color: $info;\n}\n.badge-primary {\n    background-color: $primary;\n}\n.badge-warning {\n    background-color: $warning;\n}\n\n.badge-danger {\n    background-color: $danger;\n}\n\n.badge-purple {\n    background-color: $purple;\n}\n\n.badge-red {\n    background-color: $red;\n}\n\n.badge-inverse {\n    background-color: $inverse;\n}\n\n\n/*******************\nButtons\n******************/\n.btn{\n    padding: 7px 12px;\n    font-size: 14px;\n    cursor: pointer;\n    \n}\n.btn-group{\n    label{\n       color:$white!important;\n       margin-bottom: 0px;\n        &.btn-secondary{\n            color:$bodytext!important;\n        }\n     }\n}    \n.btn-lg{\n    padding:.75rem 1.5rem;\n    font-size: 1.25rem;\n}\n.btn-md{\n    padding:12px 55px;\n    font-size: 16px;\n}\n.btn-circle{\n    border-radius: 100%;\n    width: 40px;\n    height: 40px;\n    padding: 10px;\n    \n}\n.btn-circle.btn-sm{\n    width: 35px;\n    height: 35px;\n    padding:8px 10px;\n    font-size:14px;\n}\n.btn-circle.btn-lg{\n    width: 50px;\n    height: 50px;\n    padding:14px 15px;\n    font-size:18px;\n}\n.btn-circle.btn-xl{\n    width: 70px;\n    height: 70px;\n    padding:14px 15px;\n    font-size:24px;\n}\n.btn-sm{\n    padding:.25rem .5rem;\n    font-size: 12px;\n}\n.btn-xs{\n    padding:.25rem .5rem;\n    font-size: 10px;\n}\n.button-list button, .button-list a {\n    margin: 5px 12px 5px 0;\n}\n.btn-outline {\n    color: inherit;\n    background-color: transparent;\n    transition: all .5s;\n}\n\n.btn-rounded {\n    border-radius: 60px;\n    padding: 7px 18px;\n    \n    &.btn-lg{\n        padding: .75rem 1.5rem;\n    }\n    &.btn-sm{\n        padding: .25rem .5rem;\n        font-size:12px;\n    }\n    &.btn-xs{\n        padding:.25rem .5rem;\n        font-size:10px;\n    }\n    &.btn-md{\n        padding:12px 35px;\n        font-size: 16px;\n    }\n}\n\n.btn-secondary,\n.btn-secondary.disabled {\n    box-shadow: $default-shadow;\n    transition: 0.2s ease-in;\n    &:hover{\n        box-shadow: $default-shadow-hover;\n        \n    }\n    &.active, &:focus{\n        box-shadow: $default-shadow-hover;\n    }\n}\n\n.btn-primary,\n.btn-primary.disabled {\n    background: $primary;\n    border: 1px solid $primary;\n    box-shadow: $primary-shadow;\n    transition: 0.2s ease-in;\n    &:hover{\n        background: $primary;\n        box-shadow: $primary-shadow-hover;\n        border: 1px solid $primary;\n    }\n    &.active, &:focus{\n        background: $primary-dark;\n        box-shadow: $primary-shadow-hover;\n    }\n}\n.btn-themecolor,\n.btn-themecolor.disabled {\n    background: $themecolor;\n    color:$white;\n    border: 1px solid $themecolor;\n    &:hover{\n        background: $themecolor;\n        opacity: 0.7;\n        border: 1px solid $themecolor;\n    }\n    &.active, &:focus{\n        background: $themecolor-dark;\n    }\n    \n}\n.btn-success,\n.btn-success.disabled {\n    background: $success;\n    border: 1px solid $success;\n    box-shadow: $success-shadow;\n    transition: 0.2s ease-in;\n    &:hover{\n        background: $success;\n        box-shadow: $success-shadow-hover;\n        border: 1px solid $success;\n    }\n    &.active, &:focus{\n        background: $success-dark;\n        box-shadow: $success-shadow-hover;\n    }\n}\n\n.btn-info,\n.btn-info.disabled {\n    background: $info;\n    border: 1px solid $info;\n    box-shadow: $info-shadow;\n    transition: 0.2s ease-in;\n    &:hover{\n        background: $info;\n        border: 1px solid $info;\n        box-shadow: $info-shadow-hover;\n    }\n    &.active, &:focus{\n        background: $info-dark;\n        box-shadow: $info-shadow-hover;\n    }\n}\n\n.btn-warning,\n.btn-warning.disabled {\n    background: $warning;\n    box-shadow: $warning-shadow;\n    border: 1px solid $warning;\n    transition: 0.2s ease-in;\n    &:hover{\n        background: $warning;\n        box-shadow: $warning-shadow-hover;\n        border: 1px solid $warning;\n    }\n    &.active, &:focus{\n        background: $warning-dark;\n        box-shadow: $warning-shadow-hover;\n    }\n}\n\n.btn-danger,\n.btn-danger.disabled {\n    background: $danger;\n    border: 1px solid $danger;\n    box-shadow: $danger-shadow;\n    transition: 0.2s ease-in;\n    &:hover{\n        background: $danger;\n        box-shadow: $danger-shadow-hover;\n        border: 1px solid $danger;\n    }\n    &.active, &:focus{\n        background: $danger-dark;\n        box-shadow: $danger-shadow-hover;\n    }\n}\n.btn-inverse,\n.btn-inverse.disabled {\n    background: $inverse;\n    border: 1px solid $inverse;\n     color: $white;\n    &:hover{\n        background: $inverse;\n        opacity: 0.7;\n        color: $white;\n        border: 1px solid $inverse;\n    }\n    &.active, &:focus{\n        background: $inverse-dark;\n        color: $white;\n    }\n}\n.btn-red,\n.btn-red.disabled {\n    background: $red;\n    border: 1px solid $red;\n    color: $white;\n    &:hover {\n        opacity: 0.7;\n        border: 1px solid $red;\n        background: $red;\n    }\n    &.active, &:focus{\n        background: $danger-dark;\n    }\n}\n\n.btn-outline-secondary {\n    background-color: $white;\n    box-shadow: $default-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        box-shadow: $default-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $default-shadow-hover;\n    }\n}\n\n.btn-outline-primary {\n    color: $primary;\n    background-color: $white;\n    border-color:$primary;\n    box-shadow: $primary-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $primary;\n        box-shadow: $primary-shadow-hover;\n        color: $white;\n        border-color:$primary;\n    }\n    &.active, &:focus{\n        box-shadow: $primary-shadow-hover;\n    }\n}\n\n.btn-outline-success {\n    color: $success;\n    background-color: transparent;\n    border-color:$success;\n    box-shadow: $success-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $success;\n        border-color:$success;\n        color: $white;\n        box-shadow: $success-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $success-shadow-hover;\n    }\n}\n\n.btn-outline-info {\n    color: $info;\n    background-color: transparent;\n    border-color:$info;\n    box-shadow: $info-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $info;\n        border-color:$info;\n        color: $white;\n        box-shadow: $info-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $info-shadow-hover;\n    }\n}\n\n.btn-outline-warning {\n    color: $warning;\n    background-color: transparent;\n    border-color:$warning;\n    box-shadow: $warning-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $warning;\n        border-color:$warning;\n        color: $white;\n        box-shadow: $warning-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $warning-shadow-hover;\n    }\n}\n\n.btn-outline-danger {\n    color: $danger;\n    background-color: transparent;\n    border-color:$danger;\n    box-shadow: $danger-shadow;\n    transition: 0.2s ease-in;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $danger;\n        border-color:$danger;\n        color: $white;\n        box-shadow: $danger-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $danger-shadow-hover;\n    }\n}\n.btn-outline-red {\n    color: $red;\n    background-color: transparent;\n    border-color:$red;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $red;\n        border-color:$red;\n        color: $white;\n        box-shadow: $danger-shadow-hover;\n    }\n    &.active, &:focus{\n        box-shadow: $danger-shadow-hover;\n    }\n}\n.btn-outline-inverse {\n    color: $inverse;\n    background-color: transparent;\n    border-color:$inverse;\n    &:hover,\n    &:focus,\n    &.focus {\n        background: $inverse;\n        border-color:$inverse;\n        color: $white;\n    }\n}\n.btn-primary.active.focus,\n.btn-primary.active:focus,\n.btn-primary.active:hover,\n.btn-primary.focus:active,\n.btn-primary:active:focus,\n.btn-primary:active:hover,\n.open > .dropdown-toggle.btn-primary.focus,\n.open > .dropdown-toggle.btn-primary:focus,\n.open > .dropdown-toggle.btn-primary:hover,\n.btn-primary.focus,\n.btn-primary:focus {\n    background-color: $primary-dark ;\n    border: 1px solid $primary-dark;\n}\n\n.btn-success.active.focus,\n.btn-success.active:focus,\n.btn-success.active:hover,\n.btn-success.focus:active,\n.btn-success:active:focus,\n.btn-success:active:hover,\n.open > .dropdown-toggle.btn-success.focus,\n.open > .dropdown-toggle.btn-success:focus,\n.open > .dropdown-toggle.btn-success:hover,\n.btn-success.focus,\n.btn-success:focus {\n    background-color: $success-dark;\n    border: 1px solid $success-dark;\n}\n\n.btn-info.active.focus,\n.btn-info.active:focus,\n.btn-info.active:hover,\n.btn-info.focus:active,\n.btn-info:active:focus,\n.btn-info:active:hover,\n.open > .dropdown-toggle.btn-info.focus,\n.open > .dropdown-toggle.btn-info:focus,\n.open > .dropdown-toggle.btn-info:hover,\n.btn-info.focus,\n.btn-info:focus {\n    background-color: $info-dark;\n    border: 1px solid $info-dark;\n}\n\n.btn-warning.active.focus,\n.btn-warning.active:focus,\n.btn-warning.active:hover,\n.btn-warning.focus:active,\n.btn-warning:active:focus,\n.btn-warning:active:hover,\n.open > .dropdown-toggle.btn-warning.focus,\n.open > .dropdown-toggle.btn-warning:focus,\n.open > .dropdown-toggle.btn-warning:hover,\n.btn-warning.focus,\n.btn-warning:focus {\n    background-color: $warning-dark;\n    border: 1px solid $warning-dark;\n}\n\n.btn-danger.active.focus,\n.btn-danger.active:focus,\n.btn-danger.active:hover,\n.btn-danger.focus:active,\n.btn-danger:active:focus,\n.btn-danger:active:hover,\n.open > .dropdown-toggle.btn-danger.focus,\n.open > .dropdown-toggle.btn-danger:focus,\n.open > .dropdown-toggle.btn-danger:hover,\n.btn-danger.focus,\n.btn-danger:focus {\n    background-color: $danger-dark;\n    border: 1px solid $danger-dark;\n}\n\n.btn-inverse:hover,\n.btn-inverse:focus,\n.btn-inverse:active,\n.btn-inverse.active,\n.btn-inverse.focus,\n.btn-inverse:active,\n.btn-inverse:focus,\n.btn-inverse:hover,\n.open > .dropdown-toggle.btn-inverse {\n    background-color: $inverse-dark;\n    border: 1px solid $inverse-dark;\n   \n}\n\n.btn-red:hover,\n.btn-red:focus,\n.btn-red:active,\n.btn-red.active,\n.btn-red.focus,\n.btn-red:active,\n.btn-red:focus,\n.btn-red:hover,\n.open > .dropdown-toggle.btn-red {\n    background-color: $red-dark;\n    border: 1px solid $red-dark;\n    color: $white;\n}\n\n.button-box .btn {\n    margin: 0 8px 8px 0px;\n}\n\n\n\n.btn-label {\n    background: rgba(0, 0, 0, 0.05);\n    display: inline-block;\n    margin: -6px 12px -6px -14px;\n    padding: 7px 15px;\n}\n\n.btn-facebook {\n    color: $white;\n    background-color: #3b5998;\n}\n\n.btn-twitter {\n    color: $white;\n    background-color: #55acee;\n}\n\n.btn-linkedin {\n    color: $white;\n    background-color: #007bb6;\n}\n\n.btn-dribbble {\n    color: $white;\n    background-color: #ea4c89;\n}\n\n.btn-googleplus {\n    color: $white;\n    background-color: #dd4b39;\n}\n\n.btn-instagram {\n    color: $white;\n    background-color: #3f729b;\n}\n\n.btn-pinterest {\n    color: $white;\n    background-color: #cb2027;\n}\n\n.btn-dropbox {\n    color: $white;\n    background-color: #007ee5;\n}\n\n.btn-flickr {\n    color: $white;\n    background-color: #ff0084;\n}\n\n.btn-tumblr {\n    color: $white;\n    background-color: #32506d;\n}\n\n.btn-skype {\n    color: $white;\n    background-color: #00aff0;\n}\n\n.btn-youtube {\n    color: $white;\n    background-color: #bb0000;\n}\n\n.btn-github {\n    color: $white;\n    background-color: #171515;\n}\n\n\n/*******************\nNotify\n*******************/\n\n.notify {\n    position: relative;\n    top: -25px;\n    right:-7px;\n    .heartbit {\n        position: absolute;\n        top: -20px;\n        right: -4px;\n        height: 25px;\n        width: 25px;\n        z-index: 10;\n        border: 5px solid $danger;\n        border-radius: 70px;\n        -moz-animation: heartbit 1s ease-out;\n        -moz-animation-iteration-count: infinite;\n        -o-animation: heartbit 1s ease-out;\n        -o-animation-iteration-count: infinite;\n        -webkit-animation: heartbit 1s ease-out;\n        -webkit-animation-iteration-count: infinite;\n        animation-iteration-count: infinite;\n    }\n    .point {\n        width: 6px;\n        height: 6px;\n        -webkit-border-radius: 30px;\n        -moz-border-radius: 30px;\n        border-radius: 30px;\n        background-color: $danger;\n        position: absolute;\n        right: 6px;\n        top: -10px;\n    }\n}\n\n@-moz-keyframes heartbit {\n    0% {\n        -moz-transform: scale(0);\n        opacity: 0.0;\n    }\n    25% {\n        -moz-transform: scale(0.1);\n        opacity: 0.1;\n    }\n    50% {\n        -moz-transform: scale(0.5);\n        opacity: 0.3;\n    }\n    75% {\n        -moz-transform: scale(0.8);\n        opacity: 0.5;\n    }\n    100% {\n        -moz-transform: scale(1);\n        opacity: 0.0;\n    }\n}\n\n@-webkit-keyframes heartbit {\n    0% {\n        -webkit-transform: scale(0);\n        opacity: 0.0;\n    }\n    25% {\n        -webkit-transform: scale(0.1);\n        opacity: 0.1;\n    }\n    50% {\n        -webkit-transform: scale(0.5);\n        opacity: 0.3;\n    }\n    75% {\n        -webkit-transform: scale(0.8);\n        opacity: 0.5;\n    }\n    100% {\n        -webkit-transform: scale(1);\n        opacity: 0.0;\n    }\n}\n\n\n/*******************\nCheckbox\n*******************/\n\n.checkbox {\n    padding-left: 20px;\n    label {\n        display: block;\n        padding-left: 5px;\n        position: relative;\n        &::before {\n            -o-transition: 0.3s ease-in-out;\n            -webkit-transition: 0.3s ease-in-out;\n            background-color: $white;\n            border-radius: 1px;\n            border: 1px solid $border;\n            content: \"\";\n            display: inline-block;\n            height: 17px;\n            left: 0;\n            top:3px;\n            margin-left: -20px;\n            position: absolute;\n            transition: 0.3s ease-in-out;\n            width: 17px;\n            outline: none;\n        }\n        &::after {\n            color: $dark;\n            display: inline-block;\n            font-size: 11px;\n            height: 16px;\n            left: 0;\n            margin-left: -20px;\n            padding-left: 3px;\n            padding-top: 1px;\n            position: absolute;\n            top: 3px;\n            width: 16px;\n        }\n    }\n    input[type=\"checkbox\"] {\n        cursor: pointer;\n        opacity: 0;\n        z-index: 1;\n        position: absolute;\n        left: 0px;\n        outline: none;\n        &:disabled + label {\n            opacity: 0.65;\n        }\n    }\n    input[type=\"checkbox\"]:focus + label {\n        &::before {\n            outline-offset: -2px;\n            outline: none;\n            \n        }\n    }\n    input[type=\"checkbox\"]:checked + label {\n        &::after {\n            content: \"\\f00c\";\n            font-family: 'FontAwesome';\n        }\n    }\n    input[type=\"checkbox\"]:disabled + label {\n        &::before {\n            background-color: $light;\n            cursor: not-allowed;\n        }\n    }\n}\n\n.checkbox.checkbox-circle {\n    label {\n        &::before {\n            border-radius: 50%;\n        }\n    }\n}\n\n.checkbox.checkbox-inline {\n    margin-top: 0;\n}\n\n.checkbox.checkbox-single {\n    label {\n        height: 17px;\n    }\n}\n\n.checkbox-primary {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $primary;\n            border-color: $primary;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-danger {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $danger;\n            border-color: $danger;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-info {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $info;\n            border-color: $info;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-warning {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $warning;\n            border-color: $warning;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-success {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $success;\n            border-color: $success;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-purple {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $purple;\n            border-color: $purple;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-red {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $danger;\n            border-color: $danger;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n.checkbox-inverse {\n    input[type=\"checkbox\"]:checked + label {\n        &::before {\n            background-color: $inverse;\n            border-color: $inverse;\n        }\n        &::after {\n            color: $white;\n        }\n    }\n}\n\n\n/*******************\nRadios \n*******************/\n\n.radio {\n    padding-left: 20px;\n    label {\n        display: inline-block;\n        padding-left: 5px;\n        position: relative;\n        &::before {\n            -o-transition: border 0.5s ease-in-out;\n            -webkit-transition: border 0.5s ease-in-out;\n            background-color: $white;\n            border-radius: 50%;\n            border: 1px solid $border;\n            content: \"\";\n            display: inline-block;\n            height: 17px;\n            left: 0;\n            margin-left: -20px;\n            \n            position: absolute;\n            transition: border 0.5s ease-in-out;\n            width: 17px;\n            outline: none;\n        }\n        &::after {\n            -moz-transition: -moz-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n            -ms-transform: scale(0, 0);\n            -o-transform: scale(0, 0);\n            -o-transition: -o-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n            -webkit-transform: scale(0, 0);\n            -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n            background-color: $dark;\n            border-radius: 50%;\n            content: \" \";\n            display: inline-block;\n            height: 7px;\n            left: 5px;\n            margin-left: -20px;\n            position: absolute;\n            top: 5px;\n            transform: scale(0, 0);\n            transition: transform 0.3s cubic-bezier(0.8, -0.33, 0.2, 1.33);\n            width: 7px;\n        }\n    }\n    input[type=\"radio\"] {\n        cursor: pointer;\n        opacity: 0;\n        z-index: 1;\n        outline: none;\n        &:disabled + label {\n            opacity: 0.65;\n        }\n    }\n    input[type=\"radio\"]:focus + label {\n        &::before {\n            outline-offset: -2px;\n            outline: none;\n            \n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::after {\n            -ms-transform: scale(1, 1);\n            -o-transform: scale(1, 1);\n            -webkit-transform: scale(1, 1);\n            transform: scale(1, 1);\n        }\n    }\n    input[type=\"radio\"]:disabled + label {\n        &::before {\n            cursor: not-allowed;\n        }\n    }\n}\n\n.radio.radio-inline {\n    margin-top: 0;\n}\n\n.radio.radio-single {\n    label {\n        height: 17px;\n    }\n}\n\n.radio-primary {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $primary;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $primary;\n        }\n        &::after {\n            background-color: $primary;\n        }\n    }\n}\n\n.radio-danger {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $danger;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $danger;\n        }\n        &::after {\n            background-color: $danger;\n        }\n    }\n}\n\n.radio-info {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $info;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $info;\n        }\n        &::after {\n            background-color: $info;\n        }\n    }\n}\n\n.radio-warning {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $warning;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $warning;\n        }\n        &::after {\n            background-color: $warning;\n        }\n    }\n}\n\n.radio-success {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $success;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $success;\n        }\n        &::after {\n            background-color: $success;\n        }\n    }\n}\n\n.radio-purple {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $purple;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $purple;\n        }\n        &::after {\n            background-color: $purple;\n        }\n    }\n}\n\n.radio-red {\n    input[type=\"radio\"] + label {\n        &::after {\n            background-color: $danger;\n        }\n    }\n    input[type=\"radio\"]:checked + label {\n        &::before {\n            border-color: $danger;\n        }\n        &::after {\n            background-color: $danger;\n        }\n    }\n}\n\n.checkbox label, .radio label {\n    cursor:pointer;\n}\n/*******************\nFile Upload \n******************/\n\n.fileupload {\n    overflow: hidden;\n    position: relative;\n    input.upload {\n        cursor: pointer;\n        filter: alpha(opacity=0);\n        font-size: 20px;\n        margin: 0;\n        opacity: 0;\n        padding: 0;\n        position: absolute;\n        right: 0;\n        top: 0;\n    }\n}\n/*******************\nMegamenu\n******************/\n.mega-dropdown{\n    position: static;\n    width: 100%;\n    .dropdown-menu{\n        width: 100%;\n        padding: 30px;\n        margin-top: 0px;\n        \n    }\n    ul{ padding: 0px;\n        \n        li{\n            list-style: none;\n        }\n    }\n    .carousel-item .container{\n        padding: 0px;\n    }\n    .nav-accordion{\n        .card{margin-bottom: 1px;}\n        .card-header{\n            background: $white;\n            h5{\n                margin: 0px;\n                a{\n                    text-decoration: none;\n                    color:$bodytext;\n                }\n            }\n        }\n    }\n}\n/*******************\nList-style-none\n******************/\nul.list-style-none{\n    margin: 0px;\n    padding: 0px;\n    li{\n        list-style: none;\n        a{\n            color:$bodytext;\n            padding: 8px 0px;\n            display: block;\n            text-decoration: none;\n            &:hover{\n                color:$themecolor;\n            }\n        }\n    }\n}\n/*******************\ndropdown-item\n******************/\n.dropdown-item{\n    padding:8px 1rem;\n    color:$bodytext;\n}\n/*******************\nCustom-select\n******************/\n.custom-select{\n    background: url(../../assets/images/custom-select.png) right .75rem center no-repeat;\n}\n/*******************\ntextarea\n******************/\ntextarea{\n    resize: none; \n}\n/*******************\nForm-control\n******************/\n.form-control{\n    color: $bodytext;\n    min-height: 38px;\n    display: initial;\n}\n.form-control-sm{\n    min-height: 20px;\n}\n.form-control:disabled, .form-control[readonly]{\n    opacity: 0.7;\n}\n.custom-control-input:focus~.custom-control-indicator{\n    box-shadow: none;\n}\n.custom-control-input:checked~.custom-control-indicator{\n    background-color: $success;\n}\nform label{\n    font-weight: 400;\n}\n.form-group{\n    margin-bottom: 25px;\n}\n.form-horizontal label{\n    margin-bottom: 0px;\n    \n}\n.form-control-static{\n    padding-top: 0px;\n}\n.form-bordered .form-group {\n    border-bottom: 1px solid $border;\n    padding-bottom: 20px;\n}\n/*******************\nLayouts\n******************/\n\n/*Card-noborders*/\n.card-no-border{\n    .card{\n        border-color:$card-brd;\n        border-radius: $radius;\n        box-shadow: 0px 5px 20px rgba(0,0,0,0.05);\n    }\n    .sidebar-footer{\n        background:$sidebar-alt;\n\n    }\n    \n    .sidebar-nav>ul>li>a.active{\n        background:$white;\n    }\n}\n.card-no-border .shadow-none{\n    box-shadow: none;\n}\n.card-outline-danger, .card-outline-info, .card-outline-warning, .card-outline-success, .card-outline-primary{\n    background: $white;\n}\n.card-fullscreen{\n    position: fixed;\n    top:0px;\n    left:0px;\n    width: 100%;\n    height: 100%;\n    z-index: 9999;\n    overflow: auto;\n}\n.card .card-header{\n    background: $white;\n    border-bottom: 0px;\n}\n/*******************/\n/*widgets -app*/\n/*******************/\n.css-bar:after{\n    z-index:1;\n}\n.css-bar > i{\n    z-index:10;\n}\n\n/*******************/\n/*single column*/\n/*******************/\n.single-column{\n    .left-sidebar{\n        display: none;\n    }\n    .page-wrapper{\n        margin-left: 0px;\n    }\n}\n\n.fix-width{\n    width: 100%;\n    max-width: 1170px;\n    margin: 0 auto;\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/colors/blue.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n\n@import '../variable';\n$themecolor: #1e88e5;\n$themecolor-dark: #028ee1;\n$topbar: #1e88e5;\n$themecolor-alt: #26c6da;\n\n/*******************\n/*Top bar\n*******************/\n\n.topbar {\n    background: $topbar;\n    .navbar-header {\n        background: rgba(0, 0, 0, 0.05);\n    }\n    .top-navbar .navbar-header .navbar-brand .dark-logo {\n        display: none;\n    }\n    .top-navbar .navbar-header .navbar-brand .light-logo {\n        display: inline-block;\n        color: rgba(255, 255, 255, 0.8);\n    }\n    .navbar-light .navbar-nav .nav-item > {\n        a.nav-link {\n            color: $white!important;\n            &:hover,\n            &:focus {\n                color: rgba(255, 255, 255, 0.8)!important;\n            }\n        }\n    }\n}\n\n\n/*******************\n/*General Elements\n*******************/\n\na.link {\n    &:hover,\n    &:focus {\n        color: $themecolor!important;\n    }\n}\n\n.bg-theme {\n    background-color: $themecolor !important;\n}\n\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n    background-color: $themecolor;\n    border-color: $themecolor;\n}\n\n.right-sidebar {\n    .rpanel-title {\n        background: $themecolor;\n    }\n}\n\n.stylish-table {\n    tbody tr {\n        &:hover,\n        &.active {\n            border-left: 4px solid $themecolor;\n        }\n    }\n}\n\n.text-themecolor {\n    color: $themecolor!important;\n}\n\n.profile-tab,\n.customtab {\n    li {\n        a.nav-link {\n            &.active {\n                border-bottom: 2px solid $themecolor;\n                color: $themecolor;\n            }\n            &:hover {\n                color: $themecolor;\n            }\n        }\n    }\n}\n\n\n/*******************\n/*Buttons\n*******************/\n\n.btn-themecolor,\n.btn-themecolor.disabled {\n    background: $themecolor;\n    color: $white;\n    border: 1px solid $themecolor;\n    &:hover {\n        background: $themecolor;\n        opacity: 0.7;\n        border: 1px solid $themecolor;\n    }\n    &.active,\n    &:focus {\n        background: $themecolor-dark;\n    }\n}\n\n\n/*******************\n/*sidebar navigation\n*******************/\n\n.sidebar-nav {\n    background: $sidebar;\n    ul {\n        li {\n            a {\n                color: $sidebar-text;\n                &.active,\n                &:hover {\n                    color: $themecolor-alt;\n                }\n                &.active {\n                    color: $dark;\n                }\n            }\n            &.nav-small-cap {\n                color: $muted;\n            }\n        }\n    }\n    > ul > li {\n        &.active > a,\n        &.active:hover > a {\n            color: $white;\n            background: $themecolor-alt;\n            i {\n                color: $white;\n            }\n            &:after {\n                border-color: $white;\n            }\n        }\n    }\n    > ul > li > a {\n        &.active,\n        &:hover {\n            i {\n                color: $themecolor-alt;\n            }\n        }\n        i {\n            color: $sidebar-icons;\n        }\n        &.active {\n            font-weight: 400;\n            background: $white;\n            color: $themecolor;\n        }\n    }\n}\n\n.card-no-border {\n    .sidebar-nav {\n        > ul > li >a {\n            &.active {\n                color: $white;\n                background: $themecolor-alt;\n                i {\n                    color: $white;\n                }\n                &:after {\n                    border-color: $white;\n                }\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/grid.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n@media (min-width:1600px) {\n  .col-xlg-1,.col-xlg-10,.col-xlg-11,.col-xlg-12,.col-xlg-2,.col-xlg-3,.col-xlg-4,.col-xlg-5,.col-xlg-6,.col-xlg-7,.col-xlg-8,.col-xlg-9 {\n    float: left;\n  }\n\n  .col-xlg-12 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 100%;\n    -ms-flex: 0 0 100%;\n    flex: 0 0 100%;\n    max-width: 100%;  \n  }\n\n  .col-xlg-11 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 91.66666667%;\n    -ms-flex: 0 0 91.66666667%;\n    flex: 0 0 91.66666667%;\n    max-width: 91.66666667%;  \n  }\n\n  .col-xlg-10 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 83.33333333%;\n    -ms-flex: 0 0 83.33333333%;\n    flex: 0 0 83.33333333%;\n    max-width: 83.33333333%;    \n  }\n\n  .col-xlg-9 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 75%;\n    -ms-flex: 0 0 75%;\n    flex: 0 0 75%;\n    max-width: 75%;    \n  }\n\n  .col-xlg-8 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 66.66666667%;\n    -ms-flex: 0 0 66.66666667%;\n    flex: 0 0 66.66666667%;\n    max-width: 66.66666667%;   \n  }\n\n  .col-xlg-7 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 58.33333333%;\n    -ms-flex: 0 0 58.33333333%;\n    flex: 0 0 58.33333333%;\n    max-width: 58.33333333%;   \n  }\n\n  .col-xlg-6 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 50%;\n    -ms-flex: 0 0 50%;\n    flex: 0 0 50%;\n    max-width: 50%;  \n  }\n\n  .col-xlg-5 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 41.66666667%;\n    -ms-flex: 0 0 41.66666667%;\n    flex: 0 0 41.66666667%;\n    max-width: 41.66666667%;    \n  }\n\n  .col-xlg-4 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 33.33333333%;\n    -ms-flex: 0 0 33.33333333%;\n    flex: 0 0 33.33333333%;\n    max-width: 33.33333333%;  \n  }\n\n  .col-xlg-3 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 25%;\n    -ms-flex: 0 0 25%;\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n\n  .col-xlg-2 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 16.66666667%;\n    -ms-flex: 0 0 16.66666667%;\n    flex: 0 0 16.66666667%;\n    max-width: 16.66666667%;  \n  }\n\n  .col-xlg-1 {\n    -webkit-box-flex: 0;\n    -webkit-flex: 0 0 8.33333333%;\n    -ms-flex: 0 0 8.33333333%;\n    flex: 0 0 8.33333333%;\n    max-width: 8.33333333%;  \n  }\n\n  .col-xlg-pull-12 {\n    right: 100%;\n  }\n\n  .col-xlg-pull-11 {\n    right: 91.66666667%;\n  }\n\n  .col-xlg-pull-10 {\n    right: 83.33333333%;\n  }\n\n  .col-xlg-pull-9 {\n    right: 75%;\n  }\n\n  .col-xlg-pull-8 {\n    right: 66.66666667%;\n  }\n\n  .col-xlg-pull-7 {\n    right: 58.33333333%;\n  }\n\n  .col-xlg-pull-6 {\n    right: 50%;\n  }\n\n  .col-xlg-pull-5 {\n    right: 41.66666667%;\n  }\n\n  .col-xlg-pull-4 {\n    right: 33.33333333%;\n  }\n\n  .col-xlg-pull-3 {\n    right: 25%;\n  }\n\n  .col-xlg-pull-2 {\n    right: 16.66666667%;\n  }\n\n  .col-xlg-pull-1 {\n    right: 8.33333333%;\n  }\n\n  .col-xlg-pull-0 {\n    right: auto;\n  }\n\n  .col-xlg-push-12 {\n    left: 100%;\n  }\n\n  .col-xlg-push-11 {\n    left: 91.66666667%;\n  }\n\n  .col-xlg-push-10 {\n    left: 83.33333333%;\n  }\n\n  .col-xlg-push-9 {\n    left: 75%;\n  }\n\n  .col-xlg-push-8 {\n    left: 66.66666667%;\n  }\n\n  .col-xlg-push-7 {\n    left: 58.33333333%;\n  }\n\n  .col-xlg-push-6 {\n    left: 50%;\n  }\n\n  .col-xlg-push-5 {\n    left: 41.66666667%;\n  }\n\n  .col-xlg-push-4 {\n    left: 33.33333333%;\n  }\n\n  .col-xlg-push-3 {\n    left: 25%;\n  }\n\n  .col-xlg-push-2 {\n    left: 16.66666667%;\n  }\n\n  .col-xlg-push-1 {\n    left: 8.33333333%;\n  }\n\n  .col-xlg-push-0 {\n    left: auto;\n  }\n\n  .offset-xlg-12 {\n    margin-left: 100%;\n  }\n\n  .offset-xlg-11 {\n    margin-left: 91.66666667%;\n  }\n\n  .offset-xlg-10 {\n    margin-left: 83.33333333%;\n  }\n\n  .offset-xlg-9 {\n    margin-left: 75%;\n  }\n\n  .offset-xlg-8 {\n    margin-left: 66.66666667%;\n  }\n\n  .offset-xlg-7 {\n    margin-left: 58.33333333%;\n  }\n\n  .offset-xlg-6 {\n    margin-left: 50%;\n  }\n\n  .offset-xlg-5 {\n    margin-left: 41.66666667%;\n  }\n\n  .offset-xlg-4 {\n    margin-left: 33.33333333%;\n  }\n\n  .offset-xlg-3 {\n    margin-left: 25%;\n  }\n\n  .offset-xlg-2 {\n    margin-left: 16.66666667%;\n  }\n\n  .offset-xlg-1 {\n    margin-left: 8.33333333%;\n  }\n\n  .offset-xlg-0 {\n    margin-left: 0;\n  }\n}\n\n.col-xlg-1,.col-xlg-10,.col-xlg-11,.col-xlg-12,.col-xlg-2,.col-xlg-3,.col-xlg-4,.col-xlg-5,.col-xlg-6,.col-xlg-7,.col-xlg-8,.col-xlg-9 {\n  position: relative;\n  min-height: 1px;\n  padding-right: 15px;\n  padding-left: 15px;\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/css/font-awesome.css",
    "content": "/*!\n *  Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n/* FONT PATH\n * -------------------------- */\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('..//fonts/fontawesome-webfont.eot?v=4.7.0');\n  src: url('..//fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'), url('..//fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'), url('..//fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'), url('..//fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'), url('..//fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.fa {\n  display: inline-block;\n  font: normal normal normal 14px/1 FontAwesome;\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n/* makes the font 33% larger relative to the icon container */\n.fa-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.fa-2x {\n  font-size: 2em;\n}\n.fa-3x {\n  font-size: 3em;\n}\n.fa-4x {\n  font-size: 4em;\n}\n.fa-5x {\n  font-size: 5em;\n}\n.fa-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.fa-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.fa-ul > li {\n  position: relative;\n}\n.fa-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.fa-li.fa-lg {\n  left: -1.85714286em;\n}\n.fa-border {\n  padding: .2em .25em .15em;\n  border: solid 0.08em #eeeeee;\n  border-radius: .1em;\n}\n.fa-pull-left {\n  float: left;\n}\n.fa-pull-right {\n  float: right;\n}\n.fa.fa-pull-left {\n  margin-right: .3em;\n}\n.fa.fa-pull-right {\n  margin-left: .3em;\n}\n/* Deprecated as of 4.4.0 */\n.pull-right {\n  float: right;\n}\n.pull-left {\n  float: left;\n}\n.fa.pull-left {\n  margin-right: .3em;\n}\n.fa.pull-right {\n  margin-left: .3em;\n}\n.fa-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n  animation: fa-spin 2s infinite linear;\n}\n.fa-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n  animation: fa-spin 1s infinite steps(8);\n}\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n.fa-rotate-90 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)\";\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.fa-rotate-180 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)\";\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.fa-rotate-270 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)\";\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.fa-flip-horizontal {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)\";\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.fa-flip-vertical {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)\";\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n:root .fa-rotate-90,\n:root .fa-rotate-180,\n:root .fa-rotate-270,\n:root .fa-flip-horizontal,\n:root .fa-flip-vertical {\n  filter: none;\n}\n.fa-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.fa-stack-1x,\n.fa-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.fa-stack-1x {\n  line-height: inherit;\n}\n.fa-stack-2x {\n  font-size: 2em;\n}\n.fa-inverse {\n  color: #ffffff;\n}\n/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.fa-glass:before {\n  content: \"\\f000\";\n}\n.fa-music:before {\n  content: \"\\f001\";\n}\n.fa-search:before {\n  content: \"\\f002\";\n}\n.fa-envelope-o:before {\n  content: \"\\f003\";\n}\n.fa-heart:before {\n  content: \"\\f004\";\n}\n.fa-star:before {\n  content: \"\\f005\";\n}\n.fa-star-o:before {\n  content: \"\\f006\";\n}\n.fa-user:before {\n  content: \"\\f007\";\n}\n.fa-film:before {\n  content: \"\\f008\";\n}\n.fa-th-large:before {\n  content: \"\\f009\";\n}\n.fa-th:before {\n  content: \"\\f00a\";\n}\n.fa-th-list:before {\n  content: \"\\f00b\";\n}\n.fa-check:before {\n  content: \"\\f00c\";\n}\n.fa-remove:before,\n.fa-close:before,\n.fa-times:before {\n  content: \"\\f00d\";\n}\n.fa-search-plus:before {\n  content: \"\\f00e\";\n}\n.fa-search-minus:before {\n  content: \"\\f010\";\n}\n.fa-power-off:before {\n  content: \"\\f011\";\n}\n.fa-signal:before {\n  content: \"\\f012\";\n}\n.fa-gear:before,\n.fa-cog:before {\n  content: \"\\f013\";\n}\n.fa-trash-o:before {\n  content: \"\\f014\";\n}\n.fa-home:before {\n  content: \"\\f015\";\n}\n.fa-file-o:before {\n  content: \"\\f016\";\n}\n.fa-clock-o:before {\n  content: \"\\f017\";\n}\n.fa-road:before {\n  content: \"\\f018\";\n}\n.fa-download:before {\n  content: \"\\f019\";\n}\n.fa-arrow-circle-o-down:before {\n  content: \"\\f01a\";\n}\n.fa-arrow-circle-o-up:before {\n  content: \"\\f01b\";\n}\n.fa-inbox:before {\n  content: \"\\f01c\";\n}\n.fa-play-circle-o:before {\n  content: \"\\f01d\";\n}\n.fa-rotate-right:before,\n.fa-repeat:before {\n  content: \"\\f01e\";\n}\n.fa-refresh:before {\n  content: \"\\f021\";\n}\n.fa-list-alt:before {\n  content: \"\\f022\";\n}\n.fa-lock:before {\n  content: \"\\f023\";\n}\n.fa-flag:before {\n  content: \"\\f024\";\n}\n.fa-headphones:before {\n  content: \"\\f025\";\n}\n.fa-volume-off:before {\n  content: \"\\f026\";\n}\n.fa-volume-down:before {\n  content: \"\\f027\";\n}\n.fa-volume-up:before {\n  content: \"\\f028\";\n}\n.fa-qrcode:before {\n  content: \"\\f029\";\n}\n.fa-barcode:before {\n  content: \"\\f02a\";\n}\n.fa-tag:before {\n  content: \"\\f02b\";\n}\n.fa-tags:before {\n  content: \"\\f02c\";\n}\n.fa-book:before {\n  content: \"\\f02d\";\n}\n.fa-bookmark:before {\n  content: \"\\f02e\";\n}\n.fa-print:before {\n  content: \"\\f02f\";\n}\n.fa-camera:before {\n  content: \"\\f030\";\n}\n.fa-font:before {\n  content: \"\\f031\";\n}\n.fa-bold:before {\n  content: \"\\f032\";\n}\n.fa-italic:before {\n  content: \"\\f033\";\n}\n.fa-text-height:before {\n  content: \"\\f034\";\n}\n.fa-text-width:before {\n  content: \"\\f035\";\n}\n.fa-align-left:before {\n  content: \"\\f036\";\n}\n.fa-align-center:before {\n  content: \"\\f037\";\n}\n.fa-align-right:before {\n  content: \"\\f038\";\n}\n.fa-align-justify:before {\n  content: \"\\f039\";\n}\n.fa-list:before {\n  content: \"\\f03a\";\n}\n.fa-dedent:before,\n.fa-outdent:before {\n  content: \"\\f03b\";\n}\n.fa-indent:before {\n  content: \"\\f03c\";\n}\n.fa-video-camera:before {\n  content: \"\\f03d\";\n}\n.fa-photo:before,\n.fa-image:before,\n.fa-picture-o:before {\n  content: \"\\f03e\";\n}\n.fa-pencil:before {\n  content: \"\\f040\";\n}\n.fa-map-marker:before {\n  content: \"\\f041\";\n}\n.fa-adjust:before {\n  content: \"\\f042\";\n}\n.fa-tint:before {\n  content: \"\\f043\";\n}\n.fa-edit:before,\n.fa-pencil-square-o:before {\n  content: \"\\f044\";\n}\n.fa-share-square-o:before {\n  content: \"\\f045\";\n}\n.fa-check-square-o:before {\n  content: \"\\f046\";\n}\n.fa-arrows:before {\n  content: \"\\f047\";\n}\n.fa-step-backward:before {\n  content: \"\\f048\";\n}\n.fa-fast-backward:before {\n  content: \"\\f049\";\n}\n.fa-backward:before {\n  content: \"\\f04a\";\n}\n.fa-play:before {\n  content: \"\\f04b\";\n}\n.fa-pause:before {\n  content: \"\\f04c\";\n}\n.fa-stop:before {\n  content: \"\\f04d\";\n}\n.fa-forward:before {\n  content: \"\\f04e\";\n}\n.fa-fast-forward:before {\n  content: \"\\f050\";\n}\n.fa-step-forward:before {\n  content: \"\\f051\";\n}\n.fa-eject:before {\n  content: \"\\f052\";\n}\n.fa-chevron-left:before {\n  content: \"\\f053\";\n}\n.fa-chevron-right:before {\n  content: \"\\f054\";\n}\n.fa-plus-circle:before {\n  content: \"\\f055\";\n}\n.fa-minus-circle:before {\n  content: \"\\f056\";\n}\n.fa-times-circle:before {\n  content: \"\\f057\";\n}\n.fa-check-circle:before {\n  content: \"\\f058\";\n}\n.fa-question-circle:before {\n  content: \"\\f059\";\n}\n.fa-info-circle:before {\n  content: \"\\f05a\";\n}\n.fa-crosshairs:before {\n  content: \"\\f05b\";\n}\n.fa-times-circle-o:before {\n  content: \"\\f05c\";\n}\n.fa-check-circle-o:before {\n  content: \"\\f05d\";\n}\n.fa-ban:before {\n  content: \"\\f05e\";\n}\n.fa-arrow-left:before {\n  content: \"\\f060\";\n}\n.fa-arrow-right:before {\n  content: \"\\f061\";\n}\n.fa-arrow-up:before {\n  content: \"\\f062\";\n}\n.fa-arrow-down:before {\n  content: \"\\f063\";\n}\n.fa-mail-forward:before,\n.fa-share:before {\n  content: \"\\f064\";\n}\n.fa-expand:before {\n  content: \"\\f065\";\n}\n.fa-compress:before {\n  content: \"\\f066\";\n}\n.fa-plus:before {\n  content: \"\\f067\";\n}\n.fa-minus:before {\n  content: \"\\f068\";\n}\n.fa-asterisk:before {\n  content: \"\\f069\";\n}\n.fa-exclamation-circle:before {\n  content: \"\\f06a\";\n}\n.fa-gift:before {\n  content: \"\\f06b\";\n}\n.fa-leaf:before {\n  content: \"\\f06c\";\n}\n.fa-fire:before {\n  content: \"\\f06d\";\n}\n.fa-eye:before {\n  content: \"\\f06e\";\n}\n.fa-eye-slash:before {\n  content: \"\\f070\";\n}\n.fa-warning:before,\n.fa-exclamation-triangle:before {\n  content: \"\\f071\";\n}\n.fa-plane:before {\n  content: \"\\f072\";\n}\n.fa-calendar:before {\n  content: \"\\f073\";\n}\n.fa-random:before {\n  content: \"\\f074\";\n}\n.fa-comment:before {\n  content: \"\\f075\";\n}\n.fa-magnet:before {\n  content: \"\\f076\";\n}\n.fa-chevron-up:before {\n  content: \"\\f077\";\n}\n.fa-chevron-down:before {\n  content: \"\\f078\";\n}\n.fa-retweet:before {\n  content: \"\\f079\";\n}\n.fa-shopping-cart:before {\n  content: \"\\f07a\";\n}\n.fa-folder:before {\n  content: \"\\f07b\";\n}\n.fa-folder-open:before {\n  content: \"\\f07c\";\n}\n.fa-arrows-v:before {\n  content: \"\\f07d\";\n}\n.fa-arrows-h:before {\n  content: \"\\f07e\";\n}\n.fa-bar-chart-o:before,\n.fa-bar-chart:before {\n  content: \"\\f080\";\n}\n.fa-twitter-square:before {\n  content: \"\\f081\";\n}\n.fa-facebook-square:before {\n  content: \"\\f082\";\n}\n.fa-camera-retro:before {\n  content: \"\\f083\";\n}\n.fa-key:before {\n  content: \"\\f084\";\n}\n.fa-gears:before,\n.fa-cogs:before {\n  content: \"\\f085\";\n}\n.fa-comments:before {\n  content: \"\\f086\";\n}\n.fa-thumbs-o-up:before {\n  content: \"\\f087\";\n}\n.fa-thumbs-o-down:before {\n  content: \"\\f088\";\n}\n.fa-star-half:before {\n  content: \"\\f089\";\n}\n.fa-heart-o:before {\n  content: \"\\f08a\";\n}\n.fa-sign-out:before {\n  content: \"\\f08b\";\n}\n.fa-linkedin-square:before {\n  content: \"\\f08c\";\n}\n.fa-thumb-tack:before {\n  content: \"\\f08d\";\n}\n.fa-external-link:before {\n  content: \"\\f08e\";\n}\n.fa-sign-in:before {\n  content: \"\\f090\";\n}\n.fa-trophy:before {\n  content: \"\\f091\";\n}\n.fa-github-square:before {\n  content: \"\\f092\";\n}\n.fa-upload:before {\n  content: \"\\f093\";\n}\n.fa-lemon-o:before {\n  content: \"\\f094\";\n}\n.fa-phone:before {\n  content: \"\\f095\";\n}\n.fa-square-o:before {\n  content: \"\\f096\";\n}\n.fa-bookmark-o:before {\n  content: \"\\f097\";\n}\n.fa-phone-square:before {\n  content: \"\\f098\";\n}\n.fa-twitter:before {\n  content: \"\\f099\";\n}\n.fa-facebook-f:before,\n.fa-facebook:before {\n  content: \"\\f09a\";\n}\n.fa-github:before {\n  content: \"\\f09b\";\n}\n.fa-unlock:before {\n  content: \"\\f09c\";\n}\n.fa-credit-card:before {\n  content: \"\\f09d\";\n}\n.fa-feed:before,\n.fa-rss:before {\n  content: \"\\f09e\";\n}\n.fa-hdd-o:before {\n  content: \"\\f0a0\";\n}\n.fa-bullhorn:before {\n  content: \"\\f0a1\";\n}\n.fa-bell:before {\n  content: \"\\f0f3\";\n}\n.fa-certificate:before {\n  content: \"\\f0a3\";\n}\n.fa-hand-o-right:before {\n  content: \"\\f0a4\";\n}\n.fa-hand-o-left:before {\n  content: \"\\f0a5\";\n}\n.fa-hand-o-up:before {\n  content: \"\\f0a6\";\n}\n.fa-hand-o-down:before {\n  content: \"\\f0a7\";\n}\n.fa-arrow-circle-left:before {\n  content: \"\\f0a8\";\n}\n.fa-arrow-circle-right:before {\n  content: \"\\f0a9\";\n}\n.fa-arrow-circle-up:before {\n  content: \"\\f0aa\";\n}\n.fa-arrow-circle-down:before {\n  content: \"\\f0ab\";\n}\n.fa-globe:before {\n  content: \"\\f0ac\";\n}\n.fa-wrench:before {\n  content: \"\\f0ad\";\n}\n.fa-tasks:before {\n  content: \"\\f0ae\";\n}\n.fa-filter:before {\n  content: \"\\f0b0\";\n}\n.fa-briefcase:before {\n  content: \"\\f0b1\";\n}\n.fa-arrows-alt:before {\n  content: \"\\f0b2\";\n}\n.fa-group:before,\n.fa-users:before {\n  content: \"\\f0c0\";\n}\n.fa-chain:before,\n.fa-link:before {\n  content: \"\\f0c1\";\n}\n.fa-cloud:before {\n  content: \"\\f0c2\";\n}\n.fa-flask:before {\n  content: \"\\f0c3\";\n}\n.fa-cut:before,\n.fa-scissors:before {\n  content: \"\\f0c4\";\n}\n.fa-copy:before,\n.fa-files-o:before {\n  content: \"\\f0c5\";\n}\n.fa-paperclip:before {\n  content: \"\\f0c6\";\n}\n.fa-save:before,\n.fa-floppy-o:before {\n  content: \"\\f0c7\";\n}\n.fa-square:before {\n  content: \"\\f0c8\";\n}\n.fa-navicon:before,\n.fa-reorder:before,\n.fa-bars:before {\n  content: \"\\f0c9\";\n}\n.fa-list-ul:before {\n  content: \"\\f0ca\";\n}\n.fa-list-ol:before {\n  content: \"\\f0cb\";\n}\n.fa-strikethrough:before {\n  content: \"\\f0cc\";\n}\n.fa-underline:before {\n  content: \"\\f0cd\";\n}\n.fa-table:before {\n  content: \"\\f0ce\";\n}\n.fa-magic:before {\n  content: \"\\f0d0\";\n}\n.fa-truck:before {\n  content: \"\\f0d1\";\n}\n.fa-pinterest:before {\n  content: \"\\f0d2\";\n}\n.fa-pinterest-square:before {\n  content: \"\\f0d3\";\n}\n.fa-google-plus-square:before {\n  content: \"\\f0d4\";\n}\n.fa-google-plus:before {\n  content: \"\\f0d5\";\n}\n.fa-money:before {\n  content: \"\\f0d6\";\n}\n.fa-caret-down:before {\n  content: \"\\f0d7\";\n}\n.fa-caret-up:before {\n  content: \"\\f0d8\";\n}\n.fa-caret-left:before {\n  content: \"\\f0d9\";\n}\n.fa-caret-right:before {\n  content: \"\\f0da\";\n}\n.fa-columns:before {\n  content: \"\\f0db\";\n}\n.fa-unsorted:before,\n.fa-sort:before {\n  content: \"\\f0dc\";\n}\n.fa-sort-down:before,\n.fa-sort-desc:before {\n  content: \"\\f0dd\";\n}\n.fa-sort-up:before,\n.fa-sort-asc:before {\n  content: \"\\f0de\";\n}\n.fa-envelope:before {\n  content: \"\\f0e0\";\n}\n.fa-linkedin:before {\n  content: \"\\f0e1\";\n}\n.fa-rotate-left:before,\n.fa-undo:before {\n  content: \"\\f0e2\";\n}\n.fa-legal:before,\n.fa-gavel:before {\n  content: \"\\f0e3\";\n}\n.fa-dashboard:before,\n.fa-tachometer:before {\n  content: \"\\f0e4\";\n}\n.fa-comment-o:before {\n  content: \"\\f0e5\";\n}\n.fa-comments-o:before {\n  content: \"\\f0e6\";\n}\n.fa-flash:before,\n.fa-bolt:before {\n  content: \"\\f0e7\";\n}\n.fa-sitemap:before {\n  content: \"\\f0e8\";\n}\n.fa-umbrella:before {\n  content: \"\\f0e9\";\n}\n.fa-paste:before,\n.fa-clipboard:before {\n  content: \"\\f0ea\";\n}\n.fa-lightbulb-o:before {\n  content: \"\\f0eb\";\n}\n.fa-exchange:before {\n  content: \"\\f0ec\";\n}\n.fa-cloud-download:before {\n  content: \"\\f0ed\";\n}\n.fa-cloud-upload:before {\n  content: \"\\f0ee\";\n}\n.fa-user-md:before {\n  content: \"\\f0f0\";\n}\n.fa-stethoscope:before {\n  content: \"\\f0f1\";\n}\n.fa-suitcase:before {\n  content: \"\\f0f2\";\n}\n.fa-bell-o:before {\n  content: \"\\f0a2\";\n}\n.fa-coffee:before {\n  content: \"\\f0f4\";\n}\n.fa-cutlery:before {\n  content: \"\\f0f5\";\n}\n.fa-file-text-o:before {\n  content: \"\\f0f6\";\n}\n.fa-building-o:before {\n  content: \"\\f0f7\";\n}\n.fa-hospital-o:before {\n  content: \"\\f0f8\";\n}\n.fa-ambulance:before {\n  content: \"\\f0f9\";\n}\n.fa-medkit:before {\n  content: \"\\f0fa\";\n}\n.fa-fighter-jet:before {\n  content: \"\\f0fb\";\n}\n.fa-beer:before {\n  content: \"\\f0fc\";\n}\n.fa-h-square:before {\n  content: \"\\f0fd\";\n}\n.fa-plus-square:before {\n  content: \"\\f0fe\";\n}\n.fa-angle-double-left:before {\n  content: \"\\f100\";\n}\n.fa-angle-double-right:before {\n  content: \"\\f101\";\n}\n.fa-angle-double-up:before {\n  content: \"\\f102\";\n}\n.fa-angle-double-down:before {\n  content: \"\\f103\";\n}\n.fa-angle-left:before {\n  content: \"\\f104\";\n}\n.fa-angle-right:before {\n  content: \"\\f105\";\n}\n.fa-angle-up:before {\n  content: \"\\f106\";\n}\n.fa-angle-down:before {\n  content: \"\\f107\";\n}\n.fa-desktop:before {\n  content: \"\\f108\";\n}\n.fa-laptop:before {\n  content: \"\\f109\";\n}\n.fa-tablet:before {\n  content: \"\\f10a\";\n}\n.fa-mobile-phone:before,\n.fa-mobile:before {\n  content: \"\\f10b\";\n}\n.fa-circle-o:before {\n  content: \"\\f10c\";\n}\n.fa-quote-left:before {\n  content: \"\\f10d\";\n}\n.fa-quote-right:before {\n  content: \"\\f10e\";\n}\n.fa-spinner:before {\n  content: \"\\f110\";\n}\n.fa-circle:before {\n  content: \"\\f111\";\n}\n.fa-mail-reply:before,\n.fa-reply:before {\n  content: \"\\f112\";\n}\n.fa-github-alt:before {\n  content: \"\\f113\";\n}\n.fa-folder-o:before {\n  content: \"\\f114\";\n}\n.fa-folder-open-o:before {\n  content: \"\\f115\";\n}\n.fa-smile-o:before {\n  content: \"\\f118\";\n}\n.fa-frown-o:before {\n  content: \"\\f119\";\n}\n.fa-meh-o:before {\n  content: \"\\f11a\";\n}\n.fa-gamepad:before {\n  content: \"\\f11b\";\n}\n.fa-keyboard-o:before {\n  content: \"\\f11c\";\n}\n.fa-flag-o:before {\n  content: \"\\f11d\";\n}\n.fa-flag-checkered:before {\n  content: \"\\f11e\";\n}\n.fa-terminal:before {\n  content: \"\\f120\";\n}\n.fa-code:before {\n  content: \"\\f121\";\n}\n.fa-mail-reply-all:before,\n.fa-reply-all:before {\n  content: \"\\f122\";\n}\n.fa-star-half-empty:before,\n.fa-star-half-full:before,\n.fa-star-half-o:before {\n  content: \"\\f123\";\n}\n.fa-location-arrow:before {\n  content: \"\\f124\";\n}\n.fa-crop:before {\n  content: \"\\f125\";\n}\n.fa-code-fork:before {\n  content: \"\\f126\";\n}\n.fa-unlink:before,\n.fa-chain-broken:before {\n  content: \"\\f127\";\n}\n.fa-question:before {\n  content: \"\\f128\";\n}\n.fa-info:before {\n  content: \"\\f129\";\n}\n.fa-exclamation:before {\n  content: \"\\f12a\";\n}\n.fa-superscript:before {\n  content: \"\\f12b\";\n}\n.fa-subscript:before {\n  content: \"\\f12c\";\n}\n.fa-eraser:before {\n  content: \"\\f12d\";\n}\n.fa-puzzle-piece:before {\n  content: \"\\f12e\";\n}\n.fa-microphone:before {\n  content: \"\\f130\";\n}\n.fa-microphone-slash:before {\n  content: \"\\f131\";\n}\n.fa-shield:before {\n  content: \"\\f132\";\n}\n.fa-calendar-o:before {\n  content: \"\\f133\";\n}\n.fa-fire-extinguisher:before {\n  content: \"\\f134\";\n}\n.fa-rocket:before {\n  content: \"\\f135\";\n}\n.fa-maxcdn:before {\n  content: \"\\f136\";\n}\n.fa-chevron-circle-left:before {\n  content: \"\\f137\";\n}\n.fa-chevron-circle-right:before {\n  content: \"\\f138\";\n}\n.fa-chevron-circle-up:before {\n  content: \"\\f139\";\n}\n.fa-chevron-circle-down:before {\n  content: \"\\f13a\";\n}\n.fa-html5:before {\n  content: \"\\f13b\";\n}\n.fa-css3:before {\n  content: \"\\f13c\";\n}\n.fa-anchor:before {\n  content: \"\\f13d\";\n}\n.fa-unlock-alt:before {\n  content: \"\\f13e\";\n}\n.fa-bullseye:before {\n  content: \"\\f140\";\n}\n.fa-ellipsis-h:before {\n  content: \"\\f141\";\n}\n.fa-ellipsis-v:before {\n  content: \"\\f142\";\n}\n.fa-rss-square:before {\n  content: \"\\f143\";\n}\n.fa-play-circle:before {\n  content: \"\\f144\";\n}\n.fa-ticket:before {\n  content: \"\\f145\";\n}\n.fa-minus-square:before {\n  content: \"\\f146\";\n}\n.fa-minus-square-o:before {\n  content: \"\\f147\";\n}\n.fa-level-up:before {\n  content: \"\\f148\";\n}\n.fa-level-down:before {\n  content: \"\\f149\";\n}\n.fa-check-square:before {\n  content: \"\\f14a\";\n}\n.fa-pencil-square:before {\n  content: \"\\f14b\";\n}\n.fa-external-link-square:before {\n  content: \"\\f14c\";\n}\n.fa-share-square:before {\n  content: \"\\f14d\";\n}\n.fa-compass:before {\n  content: \"\\f14e\";\n}\n.fa-toggle-down:before,\n.fa-caret-square-o-down:before {\n  content: \"\\f150\";\n}\n.fa-toggle-up:before,\n.fa-caret-square-o-up:before {\n  content: \"\\f151\";\n}\n.fa-toggle-right:before,\n.fa-caret-square-o-right:before {\n  content: \"\\f152\";\n}\n.fa-euro:before,\n.fa-eur:before {\n  content: \"\\f153\";\n}\n.fa-gbp:before {\n  content: \"\\f154\";\n}\n.fa-dollar:before,\n.fa-usd:before {\n  content: \"\\f155\";\n}\n.fa-rupee:before,\n.fa-inr:before {\n  content: \"\\f156\";\n}\n.fa-cny:before,\n.fa-rmb:before,\n.fa-yen:before,\n.fa-jpy:before {\n  content: \"\\f157\";\n}\n.fa-ruble:before,\n.fa-rouble:before,\n.fa-rub:before {\n  content: \"\\f158\";\n}\n.fa-won:before,\n.fa-krw:before {\n  content: \"\\f159\";\n}\n.fa-bitcoin:before,\n.fa-btc:before {\n  content: \"\\f15a\";\n}\n.fa-file:before {\n  content: \"\\f15b\";\n}\n.fa-file-text:before {\n  content: \"\\f15c\";\n}\n.fa-sort-alpha-asc:before {\n  content: \"\\f15d\";\n}\n.fa-sort-alpha-desc:before {\n  content: \"\\f15e\";\n}\n.fa-sort-amount-asc:before {\n  content: \"\\f160\";\n}\n.fa-sort-amount-desc:before {\n  content: \"\\f161\";\n}\n.fa-sort-numeric-asc:before {\n  content: \"\\f162\";\n}\n.fa-sort-numeric-desc:before {\n  content: \"\\f163\";\n}\n.fa-thumbs-up:before {\n  content: \"\\f164\";\n}\n.fa-thumbs-down:before {\n  content: \"\\f165\";\n}\n.fa-youtube-square:before {\n  content: \"\\f166\";\n}\n.fa-youtube:before {\n  content: \"\\f167\";\n}\n.fa-xing:before {\n  content: \"\\f168\";\n}\n.fa-xing-square:before {\n  content: \"\\f169\";\n}\n.fa-youtube-play:before {\n  content: \"\\f16a\";\n}\n.fa-dropbox:before {\n  content: \"\\f16b\";\n}\n.fa-stack-overflow:before {\n  content: \"\\f16c\";\n}\n.fa-instagram:before {\n  content: \"\\f16d\";\n}\n.fa-flickr:before {\n  content: \"\\f16e\";\n}\n.fa-adn:before {\n  content: \"\\f170\";\n}\n.fa-bitbucket:before {\n  content: \"\\f171\";\n}\n.fa-bitbucket-square:before {\n  content: \"\\f172\";\n}\n.fa-tumblr:before {\n  content: \"\\f173\";\n}\n.fa-tumblr-square:before {\n  content: \"\\f174\";\n}\n.fa-long-arrow-down:before {\n  content: \"\\f175\";\n}\n.fa-long-arrow-up:before {\n  content: \"\\f176\";\n}\n.fa-long-arrow-left:before {\n  content: \"\\f177\";\n}\n.fa-long-arrow-right:before {\n  content: \"\\f178\";\n}\n.fa-apple:before {\n  content: \"\\f179\";\n}\n.fa-windows:before {\n  content: \"\\f17a\";\n}\n.fa-android:before {\n  content: \"\\f17b\";\n}\n.fa-linux:before {\n  content: \"\\f17c\";\n}\n.fa-dribbble:before {\n  content: \"\\f17d\";\n}\n.fa-skype:before {\n  content: \"\\f17e\";\n}\n.fa-foursquare:before {\n  content: \"\\f180\";\n}\n.fa-trello:before {\n  content: \"\\f181\";\n}\n.fa-female:before {\n  content: \"\\f182\";\n}\n.fa-male:before {\n  content: \"\\f183\";\n}\n.fa-gittip:before,\n.fa-gratipay:before {\n  content: \"\\f184\";\n}\n.fa-sun-o:before {\n  content: \"\\f185\";\n}\n.fa-moon-o:before {\n  content: \"\\f186\";\n}\n.fa-archive:before {\n  content: \"\\f187\";\n}\n.fa-bug:before {\n  content: \"\\f188\";\n}\n.fa-vk:before {\n  content: \"\\f189\";\n}\n.fa-weibo:before {\n  content: \"\\f18a\";\n}\n.fa-renren:before {\n  content: \"\\f18b\";\n}\n.fa-pagelines:before {\n  content: \"\\f18c\";\n}\n.fa-stack-exchange:before {\n  content: \"\\f18d\";\n}\n.fa-arrow-circle-o-right:before {\n  content: \"\\f18e\";\n}\n.fa-arrow-circle-o-left:before {\n  content: \"\\f190\";\n}\n.fa-toggle-left:before,\n.fa-caret-square-o-left:before {\n  content: \"\\f191\";\n}\n.fa-dot-circle-o:before {\n  content: \"\\f192\";\n}\n.fa-wheelchair:before {\n  content: \"\\f193\";\n}\n.fa-vimeo-square:before {\n  content: \"\\f194\";\n}\n.fa-turkish-lira:before,\n.fa-try:before {\n  content: \"\\f195\";\n}\n.fa-plus-square-o:before {\n  content: \"\\f196\";\n}\n.fa-space-shuttle:before {\n  content: \"\\f197\";\n}\n.fa-slack:before {\n  content: \"\\f198\";\n}\n.fa-envelope-square:before {\n  content: \"\\f199\";\n}\n.fa-wordpress:before {\n  content: \"\\f19a\";\n}\n.fa-openid:before {\n  content: \"\\f19b\";\n}\n.fa-institution:before,\n.fa-bank:before,\n.fa-university:before {\n  content: \"\\f19c\";\n}\n.fa-mortar-board:before,\n.fa-graduation-cap:before {\n  content: \"\\f19d\";\n}\n.fa-yahoo:before {\n  content: \"\\f19e\";\n}\n.fa-google:before {\n  content: \"\\f1a0\";\n}\n.fa-reddit:before {\n  content: \"\\f1a1\";\n}\n.fa-reddit-square:before {\n  content: \"\\f1a2\";\n}\n.fa-stumbleupon-circle:before {\n  content: \"\\f1a3\";\n}\n.fa-stumbleupon:before {\n  content: \"\\f1a4\";\n}\n.fa-delicious:before {\n  content: \"\\f1a5\";\n}\n.fa-digg:before {\n  content: \"\\f1a6\";\n}\n.fa-pied-piper-pp:before {\n  content: \"\\f1a7\";\n}\n.fa-pied-piper-alt:before {\n  content: \"\\f1a8\";\n}\n.fa-drupal:before {\n  content: \"\\f1a9\";\n}\n.fa-joomla:before {\n  content: \"\\f1aa\";\n}\n.fa-language:before {\n  content: \"\\f1ab\";\n}\n.fa-fax:before {\n  content: \"\\f1ac\";\n}\n.fa-building:before {\n  content: \"\\f1ad\";\n}\n.fa-child:before {\n  content: \"\\f1ae\";\n}\n.fa-paw:before {\n  content: \"\\f1b0\";\n}\n.fa-spoon:before {\n  content: \"\\f1b1\";\n}\n.fa-cube:before {\n  content: \"\\f1b2\";\n}\n.fa-cubes:before {\n  content: \"\\f1b3\";\n}\n.fa-behance:before {\n  content: \"\\f1b4\";\n}\n.fa-behance-square:before {\n  content: \"\\f1b5\";\n}\n.fa-steam:before {\n  content: \"\\f1b6\";\n}\n.fa-steam-square:before {\n  content: \"\\f1b7\";\n}\n.fa-recycle:before {\n  content: \"\\f1b8\";\n}\n.fa-automobile:before,\n.fa-car:before {\n  content: \"\\f1b9\";\n}\n.fa-cab:before,\n.fa-taxi:before {\n  content: \"\\f1ba\";\n}\n.fa-tree:before {\n  content: \"\\f1bb\";\n}\n.fa-spotify:before {\n  content: \"\\f1bc\";\n}\n.fa-deviantart:before {\n  content: \"\\f1bd\";\n}\n.fa-soundcloud:before {\n  content: \"\\f1be\";\n}\n.fa-database:before {\n  content: \"\\f1c0\";\n}\n.fa-file-pdf-o:before {\n  content: \"\\f1c1\";\n}\n.fa-file-word-o:before {\n  content: \"\\f1c2\";\n}\n.fa-file-excel-o:before {\n  content: \"\\f1c3\";\n}\n.fa-file-powerpoint-o:before {\n  content: \"\\f1c4\";\n}\n.fa-file-photo-o:before,\n.fa-file-picture-o:before,\n.fa-file-image-o:before {\n  content: \"\\f1c5\";\n}\n.fa-file-zip-o:before,\n.fa-file-archive-o:before {\n  content: \"\\f1c6\";\n}\n.fa-file-sound-o:before,\n.fa-file-audio-o:before {\n  content: \"\\f1c7\";\n}\n.fa-file-movie-o:before,\n.fa-file-video-o:before {\n  content: \"\\f1c8\";\n}\n.fa-file-code-o:before {\n  content: \"\\f1c9\";\n}\n.fa-vine:before {\n  content: \"\\f1ca\";\n}\n.fa-codepen:before {\n  content: \"\\f1cb\";\n}\n.fa-jsfiddle:before {\n  content: \"\\f1cc\";\n}\n.fa-life-bouy:before,\n.fa-life-buoy:before,\n.fa-life-saver:before,\n.fa-support:before,\n.fa-life-ring:before {\n  content: \"\\f1cd\";\n}\n.fa-circle-o-notch:before {\n  content: \"\\f1ce\";\n}\n.fa-ra:before,\n.fa-resistance:before,\n.fa-rebel:before {\n  content: \"\\f1d0\";\n}\n.fa-ge:before,\n.fa-empire:before {\n  content: \"\\f1d1\";\n}\n.fa-git-square:before {\n  content: \"\\f1d2\";\n}\n.fa-git:before {\n  content: \"\\f1d3\";\n}\n.fa-y-combinator-square:before,\n.fa-yc-square:before,\n.fa-hacker-news:before {\n  content: \"\\f1d4\";\n}\n.fa-tencent-weibo:before {\n  content: \"\\f1d5\";\n}\n.fa-qq:before {\n  content: \"\\f1d6\";\n}\n.fa-wechat:before,\n.fa-weixin:before {\n  content: \"\\f1d7\";\n}\n.fa-send:before,\n.fa-paper-plane:before {\n  content: \"\\f1d8\";\n}\n.fa-send-o:before,\n.fa-paper-plane-o:before {\n  content: \"\\f1d9\";\n}\n.fa-history:before {\n  content: \"\\f1da\";\n}\n.fa-circle-thin:before {\n  content: \"\\f1db\";\n}\n.fa-header:before {\n  content: \"\\f1dc\";\n}\n.fa-paragraph:before {\n  content: \"\\f1dd\";\n}\n.fa-sliders:before {\n  content: \"\\f1de\";\n}\n.fa-share-alt:before {\n  content: \"\\f1e0\";\n}\n.fa-share-alt-square:before {\n  content: \"\\f1e1\";\n}\n.fa-bomb:before {\n  content: \"\\f1e2\";\n}\n.fa-soccer-ball-o:before,\n.fa-futbol-o:before {\n  content: \"\\f1e3\";\n}\n.fa-tty:before {\n  content: \"\\f1e4\";\n}\n.fa-binoculars:before {\n  content: \"\\f1e5\";\n}\n.fa-plug:before {\n  content: \"\\f1e6\";\n}\n.fa-slideshare:before {\n  content: \"\\f1e7\";\n}\n.fa-twitch:before {\n  content: \"\\f1e8\";\n}\n.fa-yelp:before {\n  content: \"\\f1e9\";\n}\n.fa-newspaper-o:before {\n  content: \"\\f1ea\";\n}\n.fa-wifi:before {\n  content: \"\\f1eb\";\n}\n.fa-calculator:before {\n  content: \"\\f1ec\";\n}\n.fa-paypal:before {\n  content: \"\\f1ed\";\n}\n.fa-google-wallet:before {\n  content: \"\\f1ee\";\n}\n.fa-cc-visa:before {\n  content: \"\\f1f0\";\n}\n.fa-cc-mastercard:before {\n  content: \"\\f1f1\";\n}\n.fa-cc-discover:before {\n  content: \"\\f1f2\";\n}\n.fa-cc-amex:before {\n  content: \"\\f1f3\";\n}\n.fa-cc-paypal:before {\n  content: \"\\f1f4\";\n}\n.fa-cc-stripe:before {\n  content: \"\\f1f5\";\n}\n.fa-bell-slash:before {\n  content: \"\\f1f6\";\n}\n.fa-bell-slash-o:before {\n  content: \"\\f1f7\";\n}\n.fa-trash:before {\n  content: \"\\f1f8\";\n}\n.fa-copyright:before {\n  content: \"\\f1f9\";\n}\n.fa-at:before {\n  content: \"\\f1fa\";\n}\n.fa-eyedropper:before {\n  content: \"\\f1fb\";\n}\n.fa-paint-brush:before {\n  content: \"\\f1fc\";\n}\n.fa-birthday-cake:before {\n  content: \"\\f1fd\";\n}\n.fa-area-chart:before {\n  content: \"\\f1fe\";\n}\n.fa-pie-chart:before {\n  content: \"\\f200\";\n}\n.fa-line-chart:before {\n  content: \"\\f201\";\n}\n.fa-lastfm:before {\n  content: \"\\f202\";\n}\n.fa-lastfm-square:before {\n  content: \"\\f203\";\n}\n.fa-toggle-off:before {\n  content: \"\\f204\";\n}\n.fa-toggle-on:before {\n  content: \"\\f205\";\n}\n.fa-bicycle:before {\n  content: \"\\f206\";\n}\n.fa-bus:before {\n  content: \"\\f207\";\n}\n.fa-ioxhost:before {\n  content: \"\\f208\";\n}\n.fa-angellist:before {\n  content: \"\\f209\";\n}\n.fa-cc:before {\n  content: \"\\f20a\";\n}\n.fa-shekel:before,\n.fa-sheqel:before,\n.fa-ils:before {\n  content: \"\\f20b\";\n}\n.fa-meanpath:before {\n  content: \"\\f20c\";\n}\n.fa-buysellads:before {\n  content: \"\\f20d\";\n}\n.fa-connectdevelop:before {\n  content: \"\\f20e\";\n}\n.fa-dashcube:before {\n  content: \"\\f210\";\n}\n.fa-forumbee:before {\n  content: \"\\f211\";\n}\n.fa-leanpub:before {\n  content: \"\\f212\";\n}\n.fa-sellsy:before {\n  content: \"\\f213\";\n}\n.fa-shirtsinbulk:before {\n  content: \"\\f214\";\n}\n.fa-simplybuilt:before {\n  content: \"\\f215\";\n}\n.fa-skyatlas:before {\n  content: \"\\f216\";\n}\n.fa-cart-plus:before {\n  content: \"\\f217\";\n}\n.fa-cart-arrow-down:before {\n  content: \"\\f218\";\n}\n.fa-diamond:before {\n  content: \"\\f219\";\n}\n.fa-ship:before {\n  content: \"\\f21a\";\n}\n.fa-user-secret:before {\n  content: \"\\f21b\";\n}\n.fa-motorcycle:before {\n  content: \"\\f21c\";\n}\n.fa-street-view:before {\n  content: \"\\f21d\";\n}\n.fa-heartbeat:before {\n  content: \"\\f21e\";\n}\n.fa-venus:before {\n  content: \"\\f221\";\n}\n.fa-mars:before {\n  content: \"\\f222\";\n}\n.fa-mercury:before {\n  content: \"\\f223\";\n}\n.fa-intersex:before,\n.fa-transgender:before {\n  content: \"\\f224\";\n}\n.fa-transgender-alt:before {\n  content: \"\\f225\";\n}\n.fa-venus-double:before {\n  content: \"\\f226\";\n}\n.fa-mars-double:before {\n  content: \"\\f227\";\n}\n.fa-venus-mars:before {\n  content: \"\\f228\";\n}\n.fa-mars-stroke:before {\n  content: \"\\f229\";\n}\n.fa-mars-stroke-v:before {\n  content: \"\\f22a\";\n}\n.fa-mars-stroke-h:before {\n  content: \"\\f22b\";\n}\n.fa-neuter:before {\n  content: \"\\f22c\";\n}\n.fa-genderless:before {\n  content: \"\\f22d\";\n}\n.fa-facebook-official:before {\n  content: \"\\f230\";\n}\n.fa-pinterest-p:before {\n  content: \"\\f231\";\n}\n.fa-whatsapp:before {\n  content: \"\\f232\";\n}\n.fa-server:before {\n  content: \"\\f233\";\n}\n.fa-user-plus:before {\n  content: \"\\f234\";\n}\n.fa-user-times:before {\n  content: \"\\f235\";\n}\n.fa-hotel:before,\n.fa-bed:before {\n  content: \"\\f236\";\n}\n.fa-viacoin:before {\n  content: \"\\f237\";\n}\n.fa-train:before {\n  content: \"\\f238\";\n}\n.fa-subway:before {\n  content: \"\\f239\";\n}\n.fa-medium:before {\n  content: \"\\f23a\";\n}\n.fa-yc:before,\n.fa-y-combinator:before {\n  content: \"\\f23b\";\n}\n.fa-optin-monster:before {\n  content: \"\\f23c\";\n}\n.fa-opencart:before {\n  content: \"\\f23d\";\n}\n.fa-expeditedssl:before {\n  content: \"\\f23e\";\n}\n.fa-battery-4:before,\n.fa-battery:before,\n.fa-battery-full:before {\n  content: \"\\f240\";\n}\n.fa-battery-3:before,\n.fa-battery-three-quarters:before {\n  content: \"\\f241\";\n}\n.fa-battery-2:before,\n.fa-battery-half:before {\n  content: \"\\f242\";\n}\n.fa-battery-1:before,\n.fa-battery-quarter:before {\n  content: \"\\f243\";\n}\n.fa-battery-0:before,\n.fa-battery-empty:before {\n  content: \"\\f244\";\n}\n.fa-mouse-pointer:before {\n  content: \"\\f245\";\n}\n.fa-i-cursor:before {\n  content: \"\\f246\";\n}\n.fa-object-group:before {\n  content: \"\\f247\";\n}\n.fa-object-ungroup:before {\n  content: \"\\f248\";\n}\n.fa-sticky-note:before {\n  content: \"\\f249\";\n}\n.fa-sticky-note-o:before {\n  content: \"\\f24a\";\n}\n.fa-cc-jcb:before {\n  content: \"\\f24b\";\n}\n.fa-cc-diners-club:before {\n  content: \"\\f24c\";\n}\n.fa-clone:before {\n  content: \"\\f24d\";\n}\n.fa-balance-scale:before {\n  content: \"\\f24e\";\n}\n.fa-hourglass-o:before {\n  content: \"\\f250\";\n}\n.fa-hourglass-1:before,\n.fa-hourglass-start:before {\n  content: \"\\f251\";\n}\n.fa-hourglass-2:before,\n.fa-hourglass-half:before {\n  content: \"\\f252\";\n}\n.fa-hourglass-3:before,\n.fa-hourglass-end:before {\n  content: \"\\f253\";\n}\n.fa-hourglass:before {\n  content: \"\\f254\";\n}\n.fa-hand-grab-o:before,\n.fa-hand-rock-o:before {\n  content: \"\\f255\";\n}\n.fa-hand-stop-o:before,\n.fa-hand-paper-o:before {\n  content: \"\\f256\";\n}\n.fa-hand-scissors-o:before {\n  content: \"\\f257\";\n}\n.fa-hand-lizard-o:before {\n  content: \"\\f258\";\n}\n.fa-hand-spock-o:before {\n  content: \"\\f259\";\n}\n.fa-hand-pointer-o:before {\n  content: \"\\f25a\";\n}\n.fa-hand-peace-o:before {\n  content: \"\\f25b\";\n}\n.fa-trademark:before {\n  content: \"\\f25c\";\n}\n.fa-registered:before {\n  content: \"\\f25d\";\n}\n.fa-creative-commons:before {\n  content: \"\\f25e\";\n}\n.fa-gg:before {\n  content: \"\\f260\";\n}\n.fa-gg-circle:before {\n  content: \"\\f261\";\n}\n.fa-tripadvisor:before {\n  content: \"\\f262\";\n}\n.fa-odnoklassniki:before {\n  content: \"\\f263\";\n}\n.fa-odnoklassniki-square:before {\n  content: \"\\f264\";\n}\n.fa-get-pocket:before {\n  content: \"\\f265\";\n}\n.fa-wikipedia-w:before {\n  content: \"\\f266\";\n}\n.fa-safari:before {\n  content: \"\\f267\";\n}\n.fa-chrome:before {\n  content: \"\\f268\";\n}\n.fa-firefox:before {\n  content: \"\\f269\";\n}\n.fa-opera:before {\n  content: \"\\f26a\";\n}\n.fa-internet-explorer:before {\n  content: \"\\f26b\";\n}\n.fa-tv:before,\n.fa-television:before {\n  content: \"\\f26c\";\n}\n.fa-contao:before {\n  content: \"\\f26d\";\n}\n.fa-500px:before {\n  content: \"\\f26e\";\n}\n.fa-amazon:before {\n  content: \"\\f270\";\n}\n.fa-calendar-plus-o:before {\n  content: \"\\f271\";\n}\n.fa-calendar-minus-o:before {\n  content: \"\\f272\";\n}\n.fa-calendar-times-o:before {\n  content: \"\\f273\";\n}\n.fa-calendar-check-o:before {\n  content: \"\\f274\";\n}\n.fa-industry:before {\n  content: \"\\f275\";\n}\n.fa-map-pin:before {\n  content: \"\\f276\";\n}\n.fa-map-signs:before {\n  content: \"\\f277\";\n}\n.fa-map-o:before {\n  content: \"\\f278\";\n}\n.fa-map:before {\n  content: \"\\f279\";\n}\n.fa-commenting:before {\n  content: \"\\f27a\";\n}\n.fa-commenting-o:before {\n  content: \"\\f27b\";\n}\n.fa-houzz:before {\n  content: \"\\f27c\";\n}\n.fa-vimeo:before {\n  content: \"\\f27d\";\n}\n.fa-black-tie:before {\n  content: \"\\f27e\";\n}\n.fa-fonticons:before {\n  content: \"\\f280\";\n}\n.fa-reddit-alien:before {\n  content: \"\\f281\";\n}\n.fa-edge:before {\n  content: \"\\f282\";\n}\n.fa-credit-card-alt:before {\n  content: \"\\f283\";\n}\n.fa-codiepie:before {\n  content: \"\\f284\";\n}\n.fa-modx:before {\n  content: \"\\f285\";\n}\n.fa-fort-awesome:before {\n  content: \"\\f286\";\n}\n.fa-usb:before {\n  content: \"\\f287\";\n}\n.fa-product-hunt:before {\n  content: \"\\f288\";\n}\n.fa-mixcloud:before {\n  content: \"\\f289\";\n}\n.fa-scribd:before {\n  content: \"\\f28a\";\n}\n.fa-pause-circle:before {\n  content: \"\\f28b\";\n}\n.fa-pause-circle-o:before {\n  content: \"\\f28c\";\n}\n.fa-stop-circle:before {\n  content: \"\\f28d\";\n}\n.fa-stop-circle-o:before {\n  content: \"\\f28e\";\n}\n.fa-shopping-bag:before {\n  content: \"\\f290\";\n}\n.fa-shopping-basket:before {\n  content: \"\\f291\";\n}\n.fa-hashtag:before {\n  content: \"\\f292\";\n}\n.fa-bluetooth:before {\n  content: \"\\f293\";\n}\n.fa-bluetooth-b:before {\n  content: \"\\f294\";\n}\n.fa-percent:before {\n  content: \"\\f295\";\n}\n.fa-gitlab:before {\n  content: \"\\f296\";\n}\n.fa-wpbeginner:before {\n  content: \"\\f297\";\n}\n.fa-wpforms:before {\n  content: \"\\f298\";\n}\n.fa-envira:before {\n  content: \"\\f299\";\n}\n.fa-universal-access:before {\n  content: \"\\f29a\";\n}\n.fa-wheelchair-alt:before {\n  content: \"\\f29b\";\n}\n.fa-question-circle-o:before {\n  content: \"\\f29c\";\n}\n.fa-blind:before {\n  content: \"\\f29d\";\n}\n.fa-audio-description:before {\n  content: \"\\f29e\";\n}\n.fa-volume-control-phone:before {\n  content: \"\\f2a0\";\n}\n.fa-braille:before {\n  content: \"\\f2a1\";\n}\n.fa-assistive-listening-systems:before {\n  content: \"\\f2a2\";\n}\n.fa-asl-interpreting:before,\n.fa-american-sign-language-interpreting:before {\n  content: \"\\f2a3\";\n}\n.fa-deafness:before,\n.fa-hard-of-hearing:before,\n.fa-deaf:before {\n  content: \"\\f2a4\";\n}\n.fa-glide:before {\n  content: \"\\f2a5\";\n}\n.fa-glide-g:before {\n  content: \"\\f2a6\";\n}\n.fa-signing:before,\n.fa-sign-language:before {\n  content: \"\\f2a7\";\n}\n.fa-low-vision:before {\n  content: \"\\f2a8\";\n}\n.fa-viadeo:before {\n  content: \"\\f2a9\";\n}\n.fa-viadeo-square:before {\n  content: \"\\f2aa\";\n}\n.fa-snapchat:before {\n  content: \"\\f2ab\";\n}\n.fa-snapchat-ghost:before {\n  content: \"\\f2ac\";\n}\n.fa-snapchat-square:before {\n  content: \"\\f2ad\";\n}\n.fa-pied-piper:before {\n  content: \"\\f2ae\";\n}\n.fa-first-order:before {\n  content: \"\\f2b0\";\n}\n.fa-yoast:before {\n  content: \"\\f2b1\";\n}\n.fa-themeisle:before {\n  content: \"\\f2b2\";\n}\n.fa-google-plus-circle:before,\n.fa-google-plus-official:before {\n  content: \"\\f2b3\";\n}\n.fa-fa:before,\n.fa-font-awesome:before {\n  content: \"\\f2b4\";\n}\n.fa-handshake-o:before {\n  content: \"\\f2b5\";\n}\n.fa-envelope-open:before {\n  content: \"\\f2b6\";\n}\n.fa-envelope-open-o:before {\n  content: \"\\f2b7\";\n}\n.fa-linode:before {\n  content: \"\\f2b8\";\n}\n.fa-address-book:before {\n  content: \"\\f2b9\";\n}\n.fa-address-book-o:before {\n  content: \"\\f2ba\";\n}\n.fa-vcard:before,\n.fa-address-card:before {\n  content: \"\\f2bb\";\n}\n.fa-vcard-o:before,\n.fa-address-card-o:before {\n  content: \"\\f2bc\";\n}\n.fa-user-circle:before {\n  content: \"\\f2bd\";\n}\n.fa-user-circle-o:before {\n  content: \"\\f2be\";\n}\n.fa-user-o:before {\n  content: \"\\f2c0\";\n}\n.fa-id-badge:before {\n  content: \"\\f2c1\";\n}\n.fa-drivers-license:before,\n.fa-id-card:before {\n  content: \"\\f2c2\";\n}\n.fa-drivers-license-o:before,\n.fa-id-card-o:before {\n  content: \"\\f2c3\";\n}\n.fa-quora:before {\n  content: \"\\f2c4\";\n}\n.fa-free-code-camp:before {\n  content: \"\\f2c5\";\n}\n.fa-telegram:before {\n  content: \"\\f2c6\";\n}\n.fa-thermometer-4:before,\n.fa-thermometer:before,\n.fa-thermometer-full:before {\n  content: \"\\f2c7\";\n}\n.fa-thermometer-3:before,\n.fa-thermometer-three-quarters:before {\n  content: \"\\f2c8\";\n}\n.fa-thermometer-2:before,\n.fa-thermometer-half:before {\n  content: \"\\f2c9\";\n}\n.fa-thermometer-1:before,\n.fa-thermometer-quarter:before {\n  content: \"\\f2ca\";\n}\n.fa-thermometer-0:before,\n.fa-thermometer-empty:before {\n  content: \"\\f2cb\";\n}\n.fa-shower:before {\n  content: \"\\f2cc\";\n}\n.fa-bathtub:before,\n.fa-s15:before,\n.fa-bath:before {\n  content: \"\\f2cd\";\n}\n.fa-podcast:before {\n  content: \"\\f2ce\";\n}\n.fa-window-maximize:before {\n  content: \"\\f2d0\";\n}\n.fa-window-minimize:before {\n  content: \"\\f2d1\";\n}\n.fa-window-restore:before {\n  content: \"\\f2d2\";\n}\n.fa-times-rectangle:before,\n.fa-window-close:before {\n  content: \"\\f2d3\";\n}\n.fa-times-rectangle-o:before,\n.fa-window-close-o:before {\n  content: \"\\f2d4\";\n}\n.fa-bandcamp:before {\n  content: \"\\f2d5\";\n}\n.fa-grav:before {\n  content: \"\\f2d6\";\n}\n.fa-etsy:before {\n  content: \"\\f2d7\";\n}\n.fa-imdb:before {\n  content: \"\\f2d8\";\n}\n.fa-ravelry:before {\n  content: \"\\f2d9\";\n}\n.fa-eercast:before {\n  content: \"\\f2da\";\n}\n.fa-microchip:before {\n  content: \"\\f2db\";\n}\n.fa-snowflake-o:before {\n  content: \"\\f2dc\";\n}\n.fa-superpowers:before {\n  content: \"\\f2dd\";\n}\n.fa-wpexplorer:before {\n  content: \"\\f2de\";\n}\n.fa-meetup:before {\n  content: \"\\f2e0\";\n}\n.sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  margin: -1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  border: 0;\n}\n.sr-only-focusable:active,\n.sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/animated.less",
    "content": "// Animated Icons\n// --------------------------\n\n.@{fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n.@{fa-css-prefix}-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n          animation: fa-spin 1s infinite steps(8);\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/bordered-pulled.less",
    "content": "// Bordered & Pulled\n// -------------------------\n\n.@{fa-css-prefix}-border {\n  padding: .2em .25em .15em;\n  border: solid .08em @fa-border-color;\n  border-radius: .1em;\n}\n\n.@{fa-css-prefix}-pull-left { float: left; }\n.@{fa-css-prefix}-pull-right { float: right; }\n\n.@{fa-css-prefix} {\n  &.@{fa-css-prefix}-pull-left { margin-right: .3em; }\n  &.@{fa-css-prefix}-pull-right { margin-left: .3em; }\n}\n\n/* Deprecated as of 4.4.0 */\n.pull-right { float: right; }\n.pull-left { float: left; }\n\n.@{fa-css-prefix} {\n  &.pull-left { margin-right: .3em; }\n  &.pull-right { margin-left: .3em; }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/core.less",
    "content": "// Base Class Definition\n// -------------------------\n\n.@{fa-css-prefix} {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/@fa-line-height-base FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/fixed-width.less",
    "content": "// Fixed Width Icons\n// -------------------------\n.@{fa-css-prefix}-fw {\n  width: (18em / 14);\n  text-align: center;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/font-awesome.less",
    "content": "/*!\n *  Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n\n@import \"variables.less\";\n@import \"mixins.less\";\n@import \"path.less\";\n@import \"core.less\";\n@import \"larger.less\";\n@import \"fixed-width.less\";\n@import \"list.less\";\n@import \"bordered-pulled.less\";\n@import \"animated.less\";\n@import \"rotated-flipped.less\";\n@import \"stacked.less\";\n@import \"icons.less\";\n@import \"screen-reader.less\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/icons.less",
    "content": "/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n\n.@{fa-css-prefix}-glass:before { content: @fa-var-glass; }\n.@{fa-css-prefix}-music:before { content: @fa-var-music; }\n.@{fa-css-prefix}-search:before { content: @fa-var-search; }\n.@{fa-css-prefix}-envelope-o:before { content: @fa-var-envelope-o; }\n.@{fa-css-prefix}-heart:before { content: @fa-var-heart; }\n.@{fa-css-prefix}-star:before { content: @fa-var-star; }\n.@{fa-css-prefix}-star-o:before { content: @fa-var-star-o; }\n.@{fa-css-prefix}-user:before { content: @fa-var-user; }\n.@{fa-css-prefix}-film:before { content: @fa-var-film; }\n.@{fa-css-prefix}-th-large:before { content: @fa-var-th-large; }\n.@{fa-css-prefix}-th:before { content: @fa-var-th; }\n.@{fa-css-prefix}-th-list:before { content: @fa-var-th-list; }\n.@{fa-css-prefix}-check:before { content: @fa-var-check; }\n.@{fa-css-prefix}-remove:before,\n.@{fa-css-prefix}-close:before,\n.@{fa-css-prefix}-times:before { content: @fa-var-times; }\n.@{fa-css-prefix}-search-plus:before { content: @fa-var-search-plus; }\n.@{fa-css-prefix}-search-minus:before { content: @fa-var-search-minus; }\n.@{fa-css-prefix}-power-off:before { content: @fa-var-power-off; }\n.@{fa-css-prefix}-signal:before { content: @fa-var-signal; }\n.@{fa-css-prefix}-gear:before,\n.@{fa-css-prefix}-cog:before { content: @fa-var-cog; }\n.@{fa-css-prefix}-trash-o:before { content: @fa-var-trash-o; }\n.@{fa-css-prefix}-home:before { content: @fa-var-home; }\n.@{fa-css-prefix}-file-o:before { content: @fa-var-file-o; }\n.@{fa-css-prefix}-clock-o:before { content: @fa-var-clock-o; }\n.@{fa-css-prefix}-road:before { content: @fa-var-road; }\n.@{fa-css-prefix}-download:before { content: @fa-var-download; }\n.@{fa-css-prefix}-arrow-circle-o-down:before { content: @fa-var-arrow-circle-o-down; }\n.@{fa-css-prefix}-arrow-circle-o-up:before { content: @fa-var-arrow-circle-o-up; }\n.@{fa-css-prefix}-inbox:before { content: @fa-var-inbox; }\n.@{fa-css-prefix}-play-circle-o:before { content: @fa-var-play-circle-o; }\n.@{fa-css-prefix}-rotate-right:before,\n.@{fa-css-prefix}-repeat:before { content: @fa-var-repeat; }\n.@{fa-css-prefix}-refresh:before { content: @fa-var-refresh; }\n.@{fa-css-prefix}-list-alt:before { content: @fa-var-list-alt; }\n.@{fa-css-prefix}-lock:before { content: @fa-var-lock; }\n.@{fa-css-prefix}-flag:before { content: @fa-var-flag; }\n.@{fa-css-prefix}-headphones:before { content: @fa-var-headphones; }\n.@{fa-css-prefix}-volume-off:before { content: @fa-var-volume-off; }\n.@{fa-css-prefix}-volume-down:before { content: @fa-var-volume-down; }\n.@{fa-css-prefix}-volume-up:before { content: @fa-var-volume-up; }\n.@{fa-css-prefix}-qrcode:before { content: @fa-var-qrcode; }\n.@{fa-css-prefix}-barcode:before { content: @fa-var-barcode; }\n.@{fa-css-prefix}-tag:before { content: @fa-var-tag; }\n.@{fa-css-prefix}-tags:before { content: @fa-var-tags; }\n.@{fa-css-prefix}-book:before { content: @fa-var-book; }\n.@{fa-css-prefix}-bookmark:before { content: @fa-var-bookmark; }\n.@{fa-css-prefix}-print:before { content: @fa-var-print; }\n.@{fa-css-prefix}-camera:before { content: @fa-var-camera; }\n.@{fa-css-prefix}-font:before { content: @fa-var-font; }\n.@{fa-css-prefix}-bold:before { content: @fa-var-bold; }\n.@{fa-css-prefix}-italic:before { content: @fa-var-italic; }\n.@{fa-css-prefix}-text-height:before { content: @fa-var-text-height; }\n.@{fa-css-prefix}-text-width:before { content: @fa-var-text-width; }\n.@{fa-css-prefix}-align-left:before { content: @fa-var-align-left; }\n.@{fa-css-prefix}-align-center:before { content: @fa-var-align-center; }\n.@{fa-css-prefix}-align-right:before { content: @fa-var-align-right; }\n.@{fa-css-prefix}-align-justify:before { content: @fa-var-align-justify; }\n.@{fa-css-prefix}-list:before { content: @fa-var-list; }\n.@{fa-css-prefix}-dedent:before,\n.@{fa-css-prefix}-outdent:before { content: @fa-var-outdent; }\n.@{fa-css-prefix}-indent:before { content: @fa-var-indent; }\n.@{fa-css-prefix}-video-camera:before { content: @fa-var-video-camera; }\n.@{fa-css-prefix}-photo:before,\n.@{fa-css-prefix}-image:before,\n.@{fa-css-prefix}-picture-o:before { content: @fa-var-picture-o; }\n.@{fa-css-prefix}-pencil:before { content: @fa-var-pencil; }\n.@{fa-css-prefix}-map-marker:before { content: @fa-var-map-marker; }\n.@{fa-css-prefix}-adjust:before { content: @fa-var-adjust; }\n.@{fa-css-prefix}-tint:before { content: @fa-var-tint; }\n.@{fa-css-prefix}-edit:before,\n.@{fa-css-prefix}-pencil-square-o:before { content: @fa-var-pencil-square-o; }\n.@{fa-css-prefix}-share-square-o:before { content: @fa-var-share-square-o; }\n.@{fa-css-prefix}-check-square-o:before { content: @fa-var-check-square-o; }\n.@{fa-css-prefix}-arrows:before { content: @fa-var-arrows; }\n.@{fa-css-prefix}-step-backward:before { content: @fa-var-step-backward; }\n.@{fa-css-prefix}-fast-backward:before { content: @fa-var-fast-backward; }\n.@{fa-css-prefix}-backward:before { content: @fa-var-backward; }\n.@{fa-css-prefix}-play:before { content: @fa-var-play; }\n.@{fa-css-prefix}-pause:before { content: @fa-var-pause; }\n.@{fa-css-prefix}-stop:before { content: @fa-var-stop; }\n.@{fa-css-prefix}-forward:before { content: @fa-var-forward; }\n.@{fa-css-prefix}-fast-forward:before { content: @fa-var-fast-forward; }\n.@{fa-css-prefix}-step-forward:before { content: @fa-var-step-forward; }\n.@{fa-css-prefix}-eject:before { content: @fa-var-eject; }\n.@{fa-css-prefix}-chevron-left:before { content: @fa-var-chevron-left; }\n.@{fa-css-prefix}-chevron-right:before { content: @fa-var-chevron-right; }\n.@{fa-css-prefix}-plus-circle:before { content: @fa-var-plus-circle; }\n.@{fa-css-prefix}-minus-circle:before { content: @fa-var-minus-circle; }\n.@{fa-css-prefix}-times-circle:before { content: @fa-var-times-circle; }\n.@{fa-css-prefix}-check-circle:before { content: @fa-var-check-circle; }\n.@{fa-css-prefix}-question-circle:before { content: @fa-var-question-circle; }\n.@{fa-css-prefix}-info-circle:before { content: @fa-var-info-circle; }\n.@{fa-css-prefix}-crosshairs:before { content: @fa-var-crosshairs; }\n.@{fa-css-prefix}-times-circle-o:before { content: @fa-var-times-circle-o; }\n.@{fa-css-prefix}-check-circle-o:before { content: @fa-var-check-circle-o; }\n.@{fa-css-prefix}-ban:before { content: @fa-var-ban; }\n.@{fa-css-prefix}-arrow-left:before { content: @fa-var-arrow-left; }\n.@{fa-css-prefix}-arrow-right:before { content: @fa-var-arrow-right; }\n.@{fa-css-prefix}-arrow-up:before { content: @fa-var-arrow-up; }\n.@{fa-css-prefix}-arrow-down:before { content: @fa-var-arrow-down; }\n.@{fa-css-prefix}-mail-forward:before,\n.@{fa-css-prefix}-share:before { content: @fa-var-share; }\n.@{fa-css-prefix}-expand:before { content: @fa-var-expand; }\n.@{fa-css-prefix}-compress:before { content: @fa-var-compress; }\n.@{fa-css-prefix}-plus:before { content: @fa-var-plus; }\n.@{fa-css-prefix}-minus:before { content: @fa-var-minus; }\n.@{fa-css-prefix}-asterisk:before { content: @fa-var-asterisk; }\n.@{fa-css-prefix}-exclamation-circle:before { content: @fa-var-exclamation-circle; }\n.@{fa-css-prefix}-gift:before { content: @fa-var-gift; }\n.@{fa-css-prefix}-leaf:before { content: @fa-var-leaf; }\n.@{fa-css-prefix}-fire:before { content: @fa-var-fire; }\n.@{fa-css-prefix}-eye:before { content: @fa-var-eye; }\n.@{fa-css-prefix}-eye-slash:before { content: @fa-var-eye-slash; }\n.@{fa-css-prefix}-warning:before,\n.@{fa-css-prefix}-exclamation-triangle:before { content: @fa-var-exclamation-triangle; }\n.@{fa-css-prefix}-plane:before { content: @fa-var-plane; }\n.@{fa-css-prefix}-calendar:before { content: @fa-var-calendar; }\n.@{fa-css-prefix}-random:before { content: @fa-var-random; }\n.@{fa-css-prefix}-comment:before { content: @fa-var-comment; }\n.@{fa-css-prefix}-magnet:before { content: @fa-var-magnet; }\n.@{fa-css-prefix}-chevron-up:before { content: @fa-var-chevron-up; }\n.@{fa-css-prefix}-chevron-down:before { content: @fa-var-chevron-down; }\n.@{fa-css-prefix}-retweet:before { content: @fa-var-retweet; }\n.@{fa-css-prefix}-shopping-cart:before { content: @fa-var-shopping-cart; }\n.@{fa-css-prefix}-folder:before { content: @fa-var-folder; }\n.@{fa-css-prefix}-folder-open:before { content: @fa-var-folder-open; }\n.@{fa-css-prefix}-arrows-v:before { content: @fa-var-arrows-v; }\n.@{fa-css-prefix}-arrows-h:before { content: @fa-var-arrows-h; }\n.@{fa-css-prefix}-bar-chart-o:before,\n.@{fa-css-prefix}-bar-chart:before { content: @fa-var-bar-chart; }\n.@{fa-css-prefix}-twitter-square:before { content: @fa-var-twitter-square; }\n.@{fa-css-prefix}-facebook-square:before { content: @fa-var-facebook-square; }\n.@{fa-css-prefix}-camera-retro:before { content: @fa-var-camera-retro; }\n.@{fa-css-prefix}-key:before { content: @fa-var-key; }\n.@{fa-css-prefix}-gears:before,\n.@{fa-css-prefix}-cogs:before { content: @fa-var-cogs; }\n.@{fa-css-prefix}-comments:before { content: @fa-var-comments; }\n.@{fa-css-prefix}-thumbs-o-up:before { content: @fa-var-thumbs-o-up; }\n.@{fa-css-prefix}-thumbs-o-down:before { content: @fa-var-thumbs-o-down; }\n.@{fa-css-prefix}-star-half:before { content: @fa-var-star-half; }\n.@{fa-css-prefix}-heart-o:before { content: @fa-var-heart-o; }\n.@{fa-css-prefix}-sign-out:before { content: @fa-var-sign-out; }\n.@{fa-css-prefix}-linkedin-square:before { content: @fa-var-linkedin-square; }\n.@{fa-css-prefix}-thumb-tack:before { content: @fa-var-thumb-tack; }\n.@{fa-css-prefix}-external-link:before { content: @fa-var-external-link; }\n.@{fa-css-prefix}-sign-in:before { content: @fa-var-sign-in; }\n.@{fa-css-prefix}-trophy:before { content: @fa-var-trophy; }\n.@{fa-css-prefix}-github-square:before { content: @fa-var-github-square; }\n.@{fa-css-prefix}-upload:before { content: @fa-var-upload; }\n.@{fa-css-prefix}-lemon-o:before { content: @fa-var-lemon-o; }\n.@{fa-css-prefix}-phone:before { content: @fa-var-phone; }\n.@{fa-css-prefix}-square-o:before { content: @fa-var-square-o; }\n.@{fa-css-prefix}-bookmark-o:before { content: @fa-var-bookmark-o; }\n.@{fa-css-prefix}-phone-square:before { content: @fa-var-phone-square; }\n.@{fa-css-prefix}-twitter:before { content: @fa-var-twitter; }\n.@{fa-css-prefix}-facebook-f:before,\n.@{fa-css-prefix}-facebook:before { content: @fa-var-facebook; }\n.@{fa-css-prefix}-github:before { content: @fa-var-github; }\n.@{fa-css-prefix}-unlock:before { content: @fa-var-unlock; }\n.@{fa-css-prefix}-credit-card:before { content: @fa-var-credit-card; }\n.@{fa-css-prefix}-feed:before,\n.@{fa-css-prefix}-rss:before { content: @fa-var-rss; }\n.@{fa-css-prefix}-hdd-o:before { content: @fa-var-hdd-o; }\n.@{fa-css-prefix}-bullhorn:before { content: @fa-var-bullhorn; }\n.@{fa-css-prefix}-bell:before { content: @fa-var-bell; }\n.@{fa-css-prefix}-certificate:before { content: @fa-var-certificate; }\n.@{fa-css-prefix}-hand-o-right:before { content: @fa-var-hand-o-right; }\n.@{fa-css-prefix}-hand-o-left:before { content: @fa-var-hand-o-left; }\n.@{fa-css-prefix}-hand-o-up:before { content: @fa-var-hand-o-up; }\n.@{fa-css-prefix}-hand-o-down:before { content: @fa-var-hand-o-down; }\n.@{fa-css-prefix}-arrow-circle-left:before { content: @fa-var-arrow-circle-left; }\n.@{fa-css-prefix}-arrow-circle-right:before { content: @fa-var-arrow-circle-right; }\n.@{fa-css-prefix}-arrow-circle-up:before { content: @fa-var-arrow-circle-up; }\n.@{fa-css-prefix}-arrow-circle-down:before { content: @fa-var-arrow-circle-down; }\n.@{fa-css-prefix}-globe:before { content: @fa-var-globe; }\n.@{fa-css-prefix}-wrench:before { content: @fa-var-wrench; }\n.@{fa-css-prefix}-tasks:before { content: @fa-var-tasks; }\n.@{fa-css-prefix}-filter:before { content: @fa-var-filter; }\n.@{fa-css-prefix}-briefcase:before { content: @fa-var-briefcase; }\n.@{fa-css-prefix}-arrows-alt:before { content: @fa-var-arrows-alt; }\n.@{fa-css-prefix}-group:before,\n.@{fa-css-prefix}-users:before { content: @fa-var-users; }\n.@{fa-css-prefix}-chain:before,\n.@{fa-css-prefix}-link:before { content: @fa-var-link; }\n.@{fa-css-prefix}-cloud:before { content: @fa-var-cloud; }\n.@{fa-css-prefix}-flask:before { content: @fa-var-flask; }\n.@{fa-css-prefix}-cut:before,\n.@{fa-css-prefix}-scissors:before { content: @fa-var-scissors; }\n.@{fa-css-prefix}-copy:before,\n.@{fa-css-prefix}-files-o:before { content: @fa-var-files-o; }\n.@{fa-css-prefix}-paperclip:before { content: @fa-var-paperclip; }\n.@{fa-css-prefix}-save:before,\n.@{fa-css-prefix}-floppy-o:before { content: @fa-var-floppy-o; }\n.@{fa-css-prefix}-square:before { content: @fa-var-square; }\n.@{fa-css-prefix}-navicon:before,\n.@{fa-css-prefix}-reorder:before,\n.@{fa-css-prefix}-bars:before { content: @fa-var-bars; }\n.@{fa-css-prefix}-list-ul:before { content: @fa-var-list-ul; }\n.@{fa-css-prefix}-list-ol:before { content: @fa-var-list-ol; }\n.@{fa-css-prefix}-strikethrough:before { content: @fa-var-strikethrough; }\n.@{fa-css-prefix}-underline:before { content: @fa-var-underline; }\n.@{fa-css-prefix}-table:before { content: @fa-var-table; }\n.@{fa-css-prefix}-magic:before { content: @fa-var-magic; }\n.@{fa-css-prefix}-truck:before { content: @fa-var-truck; }\n.@{fa-css-prefix}-pinterest:before { content: @fa-var-pinterest; }\n.@{fa-css-prefix}-pinterest-square:before { content: @fa-var-pinterest-square; }\n.@{fa-css-prefix}-google-plus-square:before { content: @fa-var-google-plus-square; }\n.@{fa-css-prefix}-google-plus:before { content: @fa-var-google-plus; }\n.@{fa-css-prefix}-money:before { content: @fa-var-money; }\n.@{fa-css-prefix}-caret-down:before { content: @fa-var-caret-down; }\n.@{fa-css-prefix}-caret-up:before { content: @fa-var-caret-up; }\n.@{fa-css-prefix}-caret-left:before { content: @fa-var-caret-left; }\n.@{fa-css-prefix}-caret-right:before { content: @fa-var-caret-right; }\n.@{fa-css-prefix}-columns:before { content: @fa-var-columns; }\n.@{fa-css-prefix}-unsorted:before,\n.@{fa-css-prefix}-sort:before { content: @fa-var-sort; }\n.@{fa-css-prefix}-sort-down:before,\n.@{fa-css-prefix}-sort-desc:before { content: @fa-var-sort-desc; }\n.@{fa-css-prefix}-sort-up:before,\n.@{fa-css-prefix}-sort-asc:before { content: @fa-var-sort-asc; }\n.@{fa-css-prefix}-envelope:before { content: @fa-var-envelope; }\n.@{fa-css-prefix}-linkedin:before { content: @fa-var-linkedin; }\n.@{fa-css-prefix}-rotate-left:before,\n.@{fa-css-prefix}-undo:before { content: @fa-var-undo; }\n.@{fa-css-prefix}-legal:before,\n.@{fa-css-prefix}-gavel:before { content: @fa-var-gavel; }\n.@{fa-css-prefix}-dashboard:before,\n.@{fa-css-prefix}-tachometer:before { content: @fa-var-tachometer; }\n.@{fa-css-prefix}-comment-o:before { content: @fa-var-comment-o; }\n.@{fa-css-prefix}-comments-o:before { content: @fa-var-comments-o; }\n.@{fa-css-prefix}-flash:before,\n.@{fa-css-prefix}-bolt:before { content: @fa-var-bolt; }\n.@{fa-css-prefix}-sitemap:before { content: @fa-var-sitemap; }\n.@{fa-css-prefix}-umbrella:before { content: @fa-var-umbrella; }\n.@{fa-css-prefix}-paste:before,\n.@{fa-css-prefix}-clipboard:before { content: @fa-var-clipboard; }\n.@{fa-css-prefix}-lightbulb-o:before { content: @fa-var-lightbulb-o; }\n.@{fa-css-prefix}-exchange:before { content: @fa-var-exchange; }\n.@{fa-css-prefix}-cloud-download:before { content: @fa-var-cloud-download; }\n.@{fa-css-prefix}-cloud-upload:before { content: @fa-var-cloud-upload; }\n.@{fa-css-prefix}-user-md:before { content: @fa-var-user-md; }\n.@{fa-css-prefix}-stethoscope:before { content: @fa-var-stethoscope; }\n.@{fa-css-prefix}-suitcase:before { content: @fa-var-suitcase; }\n.@{fa-css-prefix}-bell-o:before { content: @fa-var-bell-o; }\n.@{fa-css-prefix}-coffee:before { content: @fa-var-coffee; }\n.@{fa-css-prefix}-cutlery:before { content: @fa-var-cutlery; }\n.@{fa-css-prefix}-file-text-o:before { content: @fa-var-file-text-o; }\n.@{fa-css-prefix}-building-o:before { content: @fa-var-building-o; }\n.@{fa-css-prefix}-hospital-o:before { content: @fa-var-hospital-o; }\n.@{fa-css-prefix}-ambulance:before { content: @fa-var-ambulance; }\n.@{fa-css-prefix}-medkit:before { content: @fa-var-medkit; }\n.@{fa-css-prefix}-fighter-jet:before { content: @fa-var-fighter-jet; }\n.@{fa-css-prefix}-beer:before { content: @fa-var-beer; }\n.@{fa-css-prefix}-h-square:before { content: @fa-var-h-square; }\n.@{fa-css-prefix}-plus-square:before { content: @fa-var-plus-square; }\n.@{fa-css-prefix}-angle-double-left:before { content: @fa-var-angle-double-left; }\n.@{fa-css-prefix}-angle-double-right:before { content: @fa-var-angle-double-right; }\n.@{fa-css-prefix}-angle-double-up:before { content: @fa-var-angle-double-up; }\n.@{fa-css-prefix}-angle-double-down:before { content: @fa-var-angle-double-down; }\n.@{fa-css-prefix}-angle-left:before { content: @fa-var-angle-left; }\n.@{fa-css-prefix}-angle-right:before { content: @fa-var-angle-right; }\n.@{fa-css-prefix}-angle-up:before { content: @fa-var-angle-up; }\n.@{fa-css-prefix}-angle-down:before { content: @fa-var-angle-down; }\n.@{fa-css-prefix}-desktop:before { content: @fa-var-desktop; }\n.@{fa-css-prefix}-laptop:before { content: @fa-var-laptop; }\n.@{fa-css-prefix}-tablet:before { content: @fa-var-tablet; }\n.@{fa-css-prefix}-mobile-phone:before,\n.@{fa-css-prefix}-mobile:before { content: @fa-var-mobile; }\n.@{fa-css-prefix}-circle-o:before { content: @fa-var-circle-o; }\n.@{fa-css-prefix}-quote-left:before { content: @fa-var-quote-left; }\n.@{fa-css-prefix}-quote-right:before { content: @fa-var-quote-right; }\n.@{fa-css-prefix}-spinner:before { content: @fa-var-spinner; }\n.@{fa-css-prefix}-circle:before { content: @fa-var-circle; }\n.@{fa-css-prefix}-mail-reply:before,\n.@{fa-css-prefix}-reply:before { content: @fa-var-reply; }\n.@{fa-css-prefix}-github-alt:before { content: @fa-var-github-alt; }\n.@{fa-css-prefix}-folder-o:before { content: @fa-var-folder-o; }\n.@{fa-css-prefix}-folder-open-o:before { content: @fa-var-folder-open-o; }\n.@{fa-css-prefix}-smile-o:before { content: @fa-var-smile-o; }\n.@{fa-css-prefix}-frown-o:before { content: @fa-var-frown-o; }\n.@{fa-css-prefix}-meh-o:before { content: @fa-var-meh-o; }\n.@{fa-css-prefix}-gamepad:before { content: @fa-var-gamepad; }\n.@{fa-css-prefix}-keyboard-o:before { content: @fa-var-keyboard-o; }\n.@{fa-css-prefix}-flag-o:before { content: @fa-var-flag-o; }\n.@{fa-css-prefix}-flag-checkered:before { content: @fa-var-flag-checkered; }\n.@{fa-css-prefix}-terminal:before { content: @fa-var-terminal; }\n.@{fa-css-prefix}-code:before { content: @fa-var-code; }\n.@{fa-css-prefix}-mail-reply-all:before,\n.@{fa-css-prefix}-reply-all:before { content: @fa-var-reply-all; }\n.@{fa-css-prefix}-star-half-empty:before,\n.@{fa-css-prefix}-star-half-full:before,\n.@{fa-css-prefix}-star-half-o:before { content: @fa-var-star-half-o; }\n.@{fa-css-prefix}-location-arrow:before { content: @fa-var-location-arrow; }\n.@{fa-css-prefix}-crop:before { content: @fa-var-crop; }\n.@{fa-css-prefix}-code-fork:before { content: @fa-var-code-fork; }\n.@{fa-css-prefix}-unlink:before,\n.@{fa-css-prefix}-chain-broken:before { content: @fa-var-chain-broken; }\n.@{fa-css-prefix}-question:before { content: @fa-var-question; }\n.@{fa-css-prefix}-info:before { content: @fa-var-info; }\n.@{fa-css-prefix}-exclamation:before { content: @fa-var-exclamation; }\n.@{fa-css-prefix}-superscript:before { content: @fa-var-superscript; }\n.@{fa-css-prefix}-subscript:before { content: @fa-var-subscript; }\n.@{fa-css-prefix}-eraser:before { content: @fa-var-eraser; }\n.@{fa-css-prefix}-puzzle-piece:before { content: @fa-var-puzzle-piece; }\n.@{fa-css-prefix}-microphone:before { content: @fa-var-microphone; }\n.@{fa-css-prefix}-microphone-slash:before { content: @fa-var-microphone-slash; }\n.@{fa-css-prefix}-shield:before { content: @fa-var-shield; }\n.@{fa-css-prefix}-calendar-o:before { content: @fa-var-calendar-o; }\n.@{fa-css-prefix}-fire-extinguisher:before { content: @fa-var-fire-extinguisher; }\n.@{fa-css-prefix}-rocket:before { content: @fa-var-rocket; }\n.@{fa-css-prefix}-maxcdn:before { content: @fa-var-maxcdn; }\n.@{fa-css-prefix}-chevron-circle-left:before { content: @fa-var-chevron-circle-left; }\n.@{fa-css-prefix}-chevron-circle-right:before { content: @fa-var-chevron-circle-right; }\n.@{fa-css-prefix}-chevron-circle-up:before { content: @fa-var-chevron-circle-up; }\n.@{fa-css-prefix}-chevron-circle-down:before { content: @fa-var-chevron-circle-down; }\n.@{fa-css-prefix}-html5:before { content: @fa-var-html5; }\n.@{fa-css-prefix}-css3:before { content: @fa-var-css3; }\n.@{fa-css-prefix}-anchor:before { content: @fa-var-anchor; }\n.@{fa-css-prefix}-unlock-alt:before { content: @fa-var-unlock-alt; }\n.@{fa-css-prefix}-bullseye:before { content: @fa-var-bullseye; }\n.@{fa-css-prefix}-ellipsis-h:before { content: @fa-var-ellipsis-h; }\n.@{fa-css-prefix}-ellipsis-v:before { content: @fa-var-ellipsis-v; }\n.@{fa-css-prefix}-rss-square:before { content: @fa-var-rss-square; }\n.@{fa-css-prefix}-play-circle:before { content: @fa-var-play-circle; }\n.@{fa-css-prefix}-ticket:before { content: @fa-var-ticket; }\n.@{fa-css-prefix}-minus-square:before { content: @fa-var-minus-square; }\n.@{fa-css-prefix}-minus-square-o:before { content: @fa-var-minus-square-o; }\n.@{fa-css-prefix}-level-up:before { content: @fa-var-level-up; }\n.@{fa-css-prefix}-level-down:before { content: @fa-var-level-down; }\n.@{fa-css-prefix}-check-square:before { content: @fa-var-check-square; }\n.@{fa-css-prefix}-pencil-square:before { content: @fa-var-pencil-square; }\n.@{fa-css-prefix}-external-link-square:before { content: @fa-var-external-link-square; }\n.@{fa-css-prefix}-share-square:before { content: @fa-var-share-square; }\n.@{fa-css-prefix}-compass:before { content: @fa-var-compass; }\n.@{fa-css-prefix}-toggle-down:before,\n.@{fa-css-prefix}-caret-square-o-down:before { content: @fa-var-caret-square-o-down; }\n.@{fa-css-prefix}-toggle-up:before,\n.@{fa-css-prefix}-caret-square-o-up:before { content: @fa-var-caret-square-o-up; }\n.@{fa-css-prefix}-toggle-right:before,\n.@{fa-css-prefix}-caret-square-o-right:before { content: @fa-var-caret-square-o-right; }\n.@{fa-css-prefix}-euro:before,\n.@{fa-css-prefix}-eur:before { content: @fa-var-eur; }\n.@{fa-css-prefix}-gbp:before { content: @fa-var-gbp; }\n.@{fa-css-prefix}-dollar:before,\n.@{fa-css-prefix}-usd:before { content: @fa-var-usd; }\n.@{fa-css-prefix}-rupee:before,\n.@{fa-css-prefix}-inr:before { content: @fa-var-inr; }\n.@{fa-css-prefix}-cny:before,\n.@{fa-css-prefix}-rmb:before,\n.@{fa-css-prefix}-yen:before,\n.@{fa-css-prefix}-jpy:before { content: @fa-var-jpy; }\n.@{fa-css-prefix}-ruble:before,\n.@{fa-css-prefix}-rouble:before,\n.@{fa-css-prefix}-rub:before { content: @fa-var-rub; }\n.@{fa-css-prefix}-won:before,\n.@{fa-css-prefix}-krw:before { content: @fa-var-krw; }\n.@{fa-css-prefix}-bitcoin:before,\n.@{fa-css-prefix}-btc:before { content: @fa-var-btc; }\n.@{fa-css-prefix}-file:before { content: @fa-var-file; }\n.@{fa-css-prefix}-file-text:before { content: @fa-var-file-text; }\n.@{fa-css-prefix}-sort-alpha-asc:before { content: @fa-var-sort-alpha-asc; }\n.@{fa-css-prefix}-sort-alpha-desc:before { content: @fa-var-sort-alpha-desc; }\n.@{fa-css-prefix}-sort-amount-asc:before { content: @fa-var-sort-amount-asc; }\n.@{fa-css-prefix}-sort-amount-desc:before { content: @fa-var-sort-amount-desc; }\n.@{fa-css-prefix}-sort-numeric-asc:before { content: @fa-var-sort-numeric-asc; }\n.@{fa-css-prefix}-sort-numeric-desc:before { content: @fa-var-sort-numeric-desc; }\n.@{fa-css-prefix}-thumbs-up:before { content: @fa-var-thumbs-up; }\n.@{fa-css-prefix}-thumbs-down:before { content: @fa-var-thumbs-down; }\n.@{fa-css-prefix}-youtube-square:before { content: @fa-var-youtube-square; }\n.@{fa-css-prefix}-youtube:before { content: @fa-var-youtube; }\n.@{fa-css-prefix}-xing:before { content: @fa-var-xing; }\n.@{fa-css-prefix}-xing-square:before { content: @fa-var-xing-square; }\n.@{fa-css-prefix}-youtube-play:before { content: @fa-var-youtube-play; }\n.@{fa-css-prefix}-dropbox:before { content: @fa-var-dropbox; }\n.@{fa-css-prefix}-stack-overflow:before { content: @fa-var-stack-overflow; }\n.@{fa-css-prefix}-instagram:before { content: @fa-var-instagram; }\n.@{fa-css-prefix}-flickr:before { content: @fa-var-flickr; }\n.@{fa-css-prefix}-adn:before { content: @fa-var-adn; }\n.@{fa-css-prefix}-bitbucket:before { content: @fa-var-bitbucket; }\n.@{fa-css-prefix}-bitbucket-square:before { content: @fa-var-bitbucket-square; }\n.@{fa-css-prefix}-tumblr:before { content: @fa-var-tumblr; }\n.@{fa-css-prefix}-tumblr-square:before { content: @fa-var-tumblr-square; }\n.@{fa-css-prefix}-long-arrow-down:before { content: @fa-var-long-arrow-down; }\n.@{fa-css-prefix}-long-arrow-up:before { content: @fa-var-long-arrow-up; }\n.@{fa-css-prefix}-long-arrow-left:before { content: @fa-var-long-arrow-left; }\n.@{fa-css-prefix}-long-arrow-right:before { content: @fa-var-long-arrow-right; }\n.@{fa-css-prefix}-apple:before { content: @fa-var-apple; }\n.@{fa-css-prefix}-windows:before { content: @fa-var-windows; }\n.@{fa-css-prefix}-android:before { content: @fa-var-android; }\n.@{fa-css-prefix}-linux:before { content: @fa-var-linux; }\n.@{fa-css-prefix}-dribbble:before { content: @fa-var-dribbble; }\n.@{fa-css-prefix}-skype:before { content: @fa-var-skype; }\n.@{fa-css-prefix}-foursquare:before { content: @fa-var-foursquare; }\n.@{fa-css-prefix}-trello:before { content: @fa-var-trello; }\n.@{fa-css-prefix}-female:before { content: @fa-var-female; }\n.@{fa-css-prefix}-male:before { content: @fa-var-male; }\n.@{fa-css-prefix}-gittip:before,\n.@{fa-css-prefix}-gratipay:before { content: @fa-var-gratipay; }\n.@{fa-css-prefix}-sun-o:before { content: @fa-var-sun-o; }\n.@{fa-css-prefix}-moon-o:before { content: @fa-var-moon-o; }\n.@{fa-css-prefix}-archive:before { content: @fa-var-archive; }\n.@{fa-css-prefix}-bug:before { content: @fa-var-bug; }\n.@{fa-css-prefix}-vk:before { content: @fa-var-vk; }\n.@{fa-css-prefix}-weibo:before { content: @fa-var-weibo; }\n.@{fa-css-prefix}-renren:before { content: @fa-var-renren; }\n.@{fa-css-prefix}-pagelines:before { content: @fa-var-pagelines; }\n.@{fa-css-prefix}-stack-exchange:before { content: @fa-var-stack-exchange; }\n.@{fa-css-prefix}-arrow-circle-o-right:before { content: @fa-var-arrow-circle-o-right; }\n.@{fa-css-prefix}-arrow-circle-o-left:before { content: @fa-var-arrow-circle-o-left; }\n.@{fa-css-prefix}-toggle-left:before,\n.@{fa-css-prefix}-caret-square-o-left:before { content: @fa-var-caret-square-o-left; }\n.@{fa-css-prefix}-dot-circle-o:before { content: @fa-var-dot-circle-o; }\n.@{fa-css-prefix}-wheelchair:before { content: @fa-var-wheelchair; }\n.@{fa-css-prefix}-vimeo-square:before { content: @fa-var-vimeo-square; }\n.@{fa-css-prefix}-turkish-lira:before,\n.@{fa-css-prefix}-try:before { content: @fa-var-try; }\n.@{fa-css-prefix}-plus-square-o:before { content: @fa-var-plus-square-o; }\n.@{fa-css-prefix}-space-shuttle:before { content: @fa-var-space-shuttle; }\n.@{fa-css-prefix}-slack:before { content: @fa-var-slack; }\n.@{fa-css-prefix}-envelope-square:before { content: @fa-var-envelope-square; }\n.@{fa-css-prefix}-wordpress:before { content: @fa-var-wordpress; }\n.@{fa-css-prefix}-openid:before { content: @fa-var-openid; }\n.@{fa-css-prefix}-institution:before,\n.@{fa-css-prefix}-bank:before,\n.@{fa-css-prefix}-university:before { content: @fa-var-university; }\n.@{fa-css-prefix}-mortar-board:before,\n.@{fa-css-prefix}-graduation-cap:before { content: @fa-var-graduation-cap; }\n.@{fa-css-prefix}-yahoo:before { content: @fa-var-yahoo; }\n.@{fa-css-prefix}-google:before { content: @fa-var-google; }\n.@{fa-css-prefix}-reddit:before { content: @fa-var-reddit; }\n.@{fa-css-prefix}-reddit-square:before { content: @fa-var-reddit-square; }\n.@{fa-css-prefix}-stumbleupon-circle:before { content: @fa-var-stumbleupon-circle; }\n.@{fa-css-prefix}-stumbleupon:before { content: @fa-var-stumbleupon; }\n.@{fa-css-prefix}-delicious:before { content: @fa-var-delicious; }\n.@{fa-css-prefix}-digg:before { content: @fa-var-digg; }\n.@{fa-css-prefix}-pied-piper-pp:before { content: @fa-var-pied-piper-pp; }\n.@{fa-css-prefix}-pied-piper-alt:before { content: @fa-var-pied-piper-alt; }\n.@{fa-css-prefix}-drupal:before { content: @fa-var-drupal; }\n.@{fa-css-prefix}-joomla:before { content: @fa-var-joomla; }\n.@{fa-css-prefix}-language:before { content: @fa-var-language; }\n.@{fa-css-prefix}-fax:before { content: @fa-var-fax; }\n.@{fa-css-prefix}-building:before { content: @fa-var-building; }\n.@{fa-css-prefix}-child:before { content: @fa-var-child; }\n.@{fa-css-prefix}-paw:before { content: @fa-var-paw; }\n.@{fa-css-prefix}-spoon:before { content: @fa-var-spoon; }\n.@{fa-css-prefix}-cube:before { content: @fa-var-cube; }\n.@{fa-css-prefix}-cubes:before { content: @fa-var-cubes; }\n.@{fa-css-prefix}-behance:before { content: @fa-var-behance; }\n.@{fa-css-prefix}-behance-square:before { content: @fa-var-behance-square; }\n.@{fa-css-prefix}-steam:before { content: @fa-var-steam; }\n.@{fa-css-prefix}-steam-square:before { content: @fa-var-steam-square; }\n.@{fa-css-prefix}-recycle:before { content: @fa-var-recycle; }\n.@{fa-css-prefix}-automobile:before,\n.@{fa-css-prefix}-car:before { content: @fa-var-car; }\n.@{fa-css-prefix}-cab:before,\n.@{fa-css-prefix}-taxi:before { content: @fa-var-taxi; }\n.@{fa-css-prefix}-tree:before { content: @fa-var-tree; }\n.@{fa-css-prefix}-spotify:before { content: @fa-var-spotify; }\n.@{fa-css-prefix}-deviantart:before { content: @fa-var-deviantart; }\n.@{fa-css-prefix}-soundcloud:before { content: @fa-var-soundcloud; }\n.@{fa-css-prefix}-database:before { content: @fa-var-database; }\n.@{fa-css-prefix}-file-pdf-o:before { content: @fa-var-file-pdf-o; }\n.@{fa-css-prefix}-file-word-o:before { content: @fa-var-file-word-o; }\n.@{fa-css-prefix}-file-excel-o:before { content: @fa-var-file-excel-o; }\n.@{fa-css-prefix}-file-powerpoint-o:before { content: @fa-var-file-powerpoint-o; }\n.@{fa-css-prefix}-file-photo-o:before,\n.@{fa-css-prefix}-file-picture-o:before,\n.@{fa-css-prefix}-file-image-o:before { content: @fa-var-file-image-o; }\n.@{fa-css-prefix}-file-zip-o:before,\n.@{fa-css-prefix}-file-archive-o:before { content: @fa-var-file-archive-o; }\n.@{fa-css-prefix}-file-sound-o:before,\n.@{fa-css-prefix}-file-audio-o:before { content: @fa-var-file-audio-o; }\n.@{fa-css-prefix}-file-movie-o:before,\n.@{fa-css-prefix}-file-video-o:before { content: @fa-var-file-video-o; }\n.@{fa-css-prefix}-file-code-o:before { content: @fa-var-file-code-o; }\n.@{fa-css-prefix}-vine:before { content: @fa-var-vine; }\n.@{fa-css-prefix}-codepen:before { content: @fa-var-codepen; }\n.@{fa-css-prefix}-jsfiddle:before { content: @fa-var-jsfiddle; }\n.@{fa-css-prefix}-life-bouy:before,\n.@{fa-css-prefix}-life-buoy:before,\n.@{fa-css-prefix}-life-saver:before,\n.@{fa-css-prefix}-support:before,\n.@{fa-css-prefix}-life-ring:before { content: @fa-var-life-ring; }\n.@{fa-css-prefix}-circle-o-notch:before { content: @fa-var-circle-o-notch; }\n.@{fa-css-prefix}-ra:before,\n.@{fa-css-prefix}-resistance:before,\n.@{fa-css-prefix}-rebel:before { content: @fa-var-rebel; }\n.@{fa-css-prefix}-ge:before,\n.@{fa-css-prefix}-empire:before { content: @fa-var-empire; }\n.@{fa-css-prefix}-git-square:before { content: @fa-var-git-square; }\n.@{fa-css-prefix}-git:before { content: @fa-var-git; }\n.@{fa-css-prefix}-y-combinator-square:before,\n.@{fa-css-prefix}-yc-square:before,\n.@{fa-css-prefix}-hacker-news:before { content: @fa-var-hacker-news; }\n.@{fa-css-prefix}-tencent-weibo:before { content: @fa-var-tencent-weibo; }\n.@{fa-css-prefix}-qq:before { content: @fa-var-qq; }\n.@{fa-css-prefix}-wechat:before,\n.@{fa-css-prefix}-weixin:before { content: @fa-var-weixin; }\n.@{fa-css-prefix}-send:before,\n.@{fa-css-prefix}-paper-plane:before { content: @fa-var-paper-plane; }\n.@{fa-css-prefix}-send-o:before,\n.@{fa-css-prefix}-paper-plane-o:before { content: @fa-var-paper-plane-o; }\n.@{fa-css-prefix}-history:before { content: @fa-var-history; }\n.@{fa-css-prefix}-circle-thin:before { content: @fa-var-circle-thin; }\n.@{fa-css-prefix}-header:before { content: @fa-var-header; }\n.@{fa-css-prefix}-paragraph:before { content: @fa-var-paragraph; }\n.@{fa-css-prefix}-sliders:before { content: @fa-var-sliders; }\n.@{fa-css-prefix}-share-alt:before { content: @fa-var-share-alt; }\n.@{fa-css-prefix}-share-alt-square:before { content: @fa-var-share-alt-square; }\n.@{fa-css-prefix}-bomb:before { content: @fa-var-bomb; }\n.@{fa-css-prefix}-soccer-ball-o:before,\n.@{fa-css-prefix}-futbol-o:before { content: @fa-var-futbol-o; }\n.@{fa-css-prefix}-tty:before { content: @fa-var-tty; }\n.@{fa-css-prefix}-binoculars:before { content: @fa-var-binoculars; }\n.@{fa-css-prefix}-plug:before { content: @fa-var-plug; }\n.@{fa-css-prefix}-slideshare:before { content: @fa-var-slideshare; }\n.@{fa-css-prefix}-twitch:before { content: @fa-var-twitch; }\n.@{fa-css-prefix}-yelp:before { content: @fa-var-yelp; }\n.@{fa-css-prefix}-newspaper-o:before { content: @fa-var-newspaper-o; }\n.@{fa-css-prefix}-wifi:before { content: @fa-var-wifi; }\n.@{fa-css-prefix}-calculator:before { content: @fa-var-calculator; }\n.@{fa-css-prefix}-paypal:before { content: @fa-var-paypal; }\n.@{fa-css-prefix}-google-wallet:before { content: @fa-var-google-wallet; }\n.@{fa-css-prefix}-cc-visa:before { content: @fa-var-cc-visa; }\n.@{fa-css-prefix}-cc-mastercard:before { content: @fa-var-cc-mastercard; }\n.@{fa-css-prefix}-cc-discover:before { content: @fa-var-cc-discover; }\n.@{fa-css-prefix}-cc-amex:before { content: @fa-var-cc-amex; }\n.@{fa-css-prefix}-cc-paypal:before { content: @fa-var-cc-paypal; }\n.@{fa-css-prefix}-cc-stripe:before { content: @fa-var-cc-stripe; }\n.@{fa-css-prefix}-bell-slash:before { content: @fa-var-bell-slash; }\n.@{fa-css-prefix}-bell-slash-o:before { content: @fa-var-bell-slash-o; }\n.@{fa-css-prefix}-trash:before { content: @fa-var-trash; }\n.@{fa-css-prefix}-copyright:before { content: @fa-var-copyright; }\n.@{fa-css-prefix}-at:before { content: @fa-var-at; }\n.@{fa-css-prefix}-eyedropper:before { content: @fa-var-eyedropper; }\n.@{fa-css-prefix}-paint-brush:before { content: @fa-var-paint-brush; }\n.@{fa-css-prefix}-birthday-cake:before { content: @fa-var-birthday-cake; }\n.@{fa-css-prefix}-area-chart:before { content: @fa-var-area-chart; }\n.@{fa-css-prefix}-pie-chart:before { content: @fa-var-pie-chart; }\n.@{fa-css-prefix}-line-chart:before { content: @fa-var-line-chart; }\n.@{fa-css-prefix}-lastfm:before { content: @fa-var-lastfm; }\n.@{fa-css-prefix}-lastfm-square:before { content: @fa-var-lastfm-square; }\n.@{fa-css-prefix}-toggle-off:before { content: @fa-var-toggle-off; }\n.@{fa-css-prefix}-toggle-on:before { content: @fa-var-toggle-on; }\n.@{fa-css-prefix}-bicycle:before { content: @fa-var-bicycle; }\n.@{fa-css-prefix}-bus:before { content: @fa-var-bus; }\n.@{fa-css-prefix}-ioxhost:before { content: @fa-var-ioxhost; }\n.@{fa-css-prefix}-angellist:before { content: @fa-var-angellist; }\n.@{fa-css-prefix}-cc:before { content: @fa-var-cc; }\n.@{fa-css-prefix}-shekel:before,\n.@{fa-css-prefix}-sheqel:before,\n.@{fa-css-prefix}-ils:before { content: @fa-var-ils; }\n.@{fa-css-prefix}-meanpath:before { content: @fa-var-meanpath; }\n.@{fa-css-prefix}-buysellads:before { content: @fa-var-buysellads; }\n.@{fa-css-prefix}-connectdevelop:before { content: @fa-var-connectdevelop; }\n.@{fa-css-prefix}-dashcube:before { content: @fa-var-dashcube; }\n.@{fa-css-prefix}-forumbee:before { content: @fa-var-forumbee; }\n.@{fa-css-prefix}-leanpub:before { content: @fa-var-leanpub; }\n.@{fa-css-prefix}-sellsy:before { content: @fa-var-sellsy; }\n.@{fa-css-prefix}-shirtsinbulk:before { content: @fa-var-shirtsinbulk; }\n.@{fa-css-prefix}-simplybuilt:before { content: @fa-var-simplybuilt; }\n.@{fa-css-prefix}-skyatlas:before { content: @fa-var-skyatlas; }\n.@{fa-css-prefix}-cart-plus:before { content: @fa-var-cart-plus; }\n.@{fa-css-prefix}-cart-arrow-down:before { content: @fa-var-cart-arrow-down; }\n.@{fa-css-prefix}-diamond:before { content: @fa-var-diamond; }\n.@{fa-css-prefix}-ship:before { content: @fa-var-ship; }\n.@{fa-css-prefix}-user-secret:before { content: @fa-var-user-secret; }\n.@{fa-css-prefix}-motorcycle:before { content: @fa-var-motorcycle; }\n.@{fa-css-prefix}-street-view:before { content: @fa-var-street-view; }\n.@{fa-css-prefix}-heartbeat:before { content: @fa-var-heartbeat; }\n.@{fa-css-prefix}-venus:before { content: @fa-var-venus; }\n.@{fa-css-prefix}-mars:before { content: @fa-var-mars; }\n.@{fa-css-prefix}-mercury:before { content: @fa-var-mercury; }\n.@{fa-css-prefix}-intersex:before,\n.@{fa-css-prefix}-transgender:before { content: @fa-var-transgender; }\n.@{fa-css-prefix}-transgender-alt:before { content: @fa-var-transgender-alt; }\n.@{fa-css-prefix}-venus-double:before { content: @fa-var-venus-double; }\n.@{fa-css-prefix}-mars-double:before { content: @fa-var-mars-double; }\n.@{fa-css-prefix}-venus-mars:before { content: @fa-var-venus-mars; }\n.@{fa-css-prefix}-mars-stroke:before { content: @fa-var-mars-stroke; }\n.@{fa-css-prefix}-mars-stroke-v:before { content: @fa-var-mars-stroke-v; }\n.@{fa-css-prefix}-mars-stroke-h:before { content: @fa-var-mars-stroke-h; }\n.@{fa-css-prefix}-neuter:before { content: @fa-var-neuter; }\n.@{fa-css-prefix}-genderless:before { content: @fa-var-genderless; }\n.@{fa-css-prefix}-facebook-official:before { content: @fa-var-facebook-official; }\n.@{fa-css-prefix}-pinterest-p:before { content: @fa-var-pinterest-p; }\n.@{fa-css-prefix}-whatsapp:before { content: @fa-var-whatsapp; }\n.@{fa-css-prefix}-server:before { content: @fa-var-server; }\n.@{fa-css-prefix}-user-plus:before { content: @fa-var-user-plus; }\n.@{fa-css-prefix}-user-times:before { content: @fa-var-user-times; }\n.@{fa-css-prefix}-hotel:before,\n.@{fa-css-prefix}-bed:before { content: @fa-var-bed; }\n.@{fa-css-prefix}-viacoin:before { content: @fa-var-viacoin; }\n.@{fa-css-prefix}-train:before { content: @fa-var-train; }\n.@{fa-css-prefix}-subway:before { content: @fa-var-subway; }\n.@{fa-css-prefix}-medium:before { content: @fa-var-medium; }\n.@{fa-css-prefix}-yc:before,\n.@{fa-css-prefix}-y-combinator:before { content: @fa-var-y-combinator; }\n.@{fa-css-prefix}-optin-monster:before { content: @fa-var-optin-monster; }\n.@{fa-css-prefix}-opencart:before { content: @fa-var-opencart; }\n.@{fa-css-prefix}-expeditedssl:before { content: @fa-var-expeditedssl; }\n.@{fa-css-prefix}-battery-4:before,\n.@{fa-css-prefix}-battery:before,\n.@{fa-css-prefix}-battery-full:before { content: @fa-var-battery-full; }\n.@{fa-css-prefix}-battery-3:before,\n.@{fa-css-prefix}-battery-three-quarters:before { content: @fa-var-battery-three-quarters; }\n.@{fa-css-prefix}-battery-2:before,\n.@{fa-css-prefix}-battery-half:before { content: @fa-var-battery-half; }\n.@{fa-css-prefix}-battery-1:before,\n.@{fa-css-prefix}-battery-quarter:before { content: @fa-var-battery-quarter; }\n.@{fa-css-prefix}-battery-0:before,\n.@{fa-css-prefix}-battery-empty:before { content: @fa-var-battery-empty; }\n.@{fa-css-prefix}-mouse-pointer:before { content: @fa-var-mouse-pointer; }\n.@{fa-css-prefix}-i-cursor:before { content: @fa-var-i-cursor; }\n.@{fa-css-prefix}-object-group:before { content: @fa-var-object-group; }\n.@{fa-css-prefix}-object-ungroup:before { content: @fa-var-object-ungroup; }\n.@{fa-css-prefix}-sticky-note:before { content: @fa-var-sticky-note; }\n.@{fa-css-prefix}-sticky-note-o:before { content: @fa-var-sticky-note-o; }\n.@{fa-css-prefix}-cc-jcb:before { content: @fa-var-cc-jcb; }\n.@{fa-css-prefix}-cc-diners-club:before { content: @fa-var-cc-diners-club; }\n.@{fa-css-prefix}-clone:before { content: @fa-var-clone; }\n.@{fa-css-prefix}-balance-scale:before { content: @fa-var-balance-scale; }\n.@{fa-css-prefix}-hourglass-o:before { content: @fa-var-hourglass-o; }\n.@{fa-css-prefix}-hourglass-1:before,\n.@{fa-css-prefix}-hourglass-start:before { content: @fa-var-hourglass-start; }\n.@{fa-css-prefix}-hourglass-2:before,\n.@{fa-css-prefix}-hourglass-half:before { content: @fa-var-hourglass-half; }\n.@{fa-css-prefix}-hourglass-3:before,\n.@{fa-css-prefix}-hourglass-end:before { content: @fa-var-hourglass-end; }\n.@{fa-css-prefix}-hourglass:before { content: @fa-var-hourglass; }\n.@{fa-css-prefix}-hand-grab-o:before,\n.@{fa-css-prefix}-hand-rock-o:before { content: @fa-var-hand-rock-o; }\n.@{fa-css-prefix}-hand-stop-o:before,\n.@{fa-css-prefix}-hand-paper-o:before { content: @fa-var-hand-paper-o; }\n.@{fa-css-prefix}-hand-scissors-o:before { content: @fa-var-hand-scissors-o; }\n.@{fa-css-prefix}-hand-lizard-o:before { content: @fa-var-hand-lizard-o; }\n.@{fa-css-prefix}-hand-spock-o:before { content: @fa-var-hand-spock-o; }\n.@{fa-css-prefix}-hand-pointer-o:before { content: @fa-var-hand-pointer-o; }\n.@{fa-css-prefix}-hand-peace-o:before { content: @fa-var-hand-peace-o; }\n.@{fa-css-prefix}-trademark:before { content: @fa-var-trademark; }\n.@{fa-css-prefix}-registered:before { content: @fa-var-registered; }\n.@{fa-css-prefix}-creative-commons:before { content: @fa-var-creative-commons; }\n.@{fa-css-prefix}-gg:before { content: @fa-var-gg; }\n.@{fa-css-prefix}-gg-circle:before { content: @fa-var-gg-circle; }\n.@{fa-css-prefix}-tripadvisor:before { content: @fa-var-tripadvisor; }\n.@{fa-css-prefix}-odnoklassniki:before { content: @fa-var-odnoklassniki; }\n.@{fa-css-prefix}-odnoklassniki-square:before { content: @fa-var-odnoklassniki-square; }\n.@{fa-css-prefix}-get-pocket:before { content: @fa-var-get-pocket; }\n.@{fa-css-prefix}-wikipedia-w:before { content: @fa-var-wikipedia-w; }\n.@{fa-css-prefix}-safari:before { content: @fa-var-safari; }\n.@{fa-css-prefix}-chrome:before { content: @fa-var-chrome; }\n.@{fa-css-prefix}-firefox:before { content: @fa-var-firefox; }\n.@{fa-css-prefix}-opera:before { content: @fa-var-opera; }\n.@{fa-css-prefix}-internet-explorer:before { content: @fa-var-internet-explorer; }\n.@{fa-css-prefix}-tv:before,\n.@{fa-css-prefix}-television:before { content: @fa-var-television; }\n.@{fa-css-prefix}-contao:before { content: @fa-var-contao; }\n.@{fa-css-prefix}-500px:before { content: @fa-var-500px; }\n.@{fa-css-prefix}-amazon:before { content: @fa-var-amazon; }\n.@{fa-css-prefix}-calendar-plus-o:before { content: @fa-var-calendar-plus-o; }\n.@{fa-css-prefix}-calendar-minus-o:before { content: @fa-var-calendar-minus-o; }\n.@{fa-css-prefix}-calendar-times-o:before { content: @fa-var-calendar-times-o; }\n.@{fa-css-prefix}-calendar-check-o:before { content: @fa-var-calendar-check-o; }\n.@{fa-css-prefix}-industry:before { content: @fa-var-industry; }\n.@{fa-css-prefix}-map-pin:before { content: @fa-var-map-pin; }\n.@{fa-css-prefix}-map-signs:before { content: @fa-var-map-signs; }\n.@{fa-css-prefix}-map-o:before { content: @fa-var-map-o; }\n.@{fa-css-prefix}-map:before { content: @fa-var-map; }\n.@{fa-css-prefix}-commenting:before { content: @fa-var-commenting; }\n.@{fa-css-prefix}-commenting-o:before { content: @fa-var-commenting-o; }\n.@{fa-css-prefix}-houzz:before { content: @fa-var-houzz; }\n.@{fa-css-prefix}-vimeo:before { content: @fa-var-vimeo; }\n.@{fa-css-prefix}-black-tie:before { content: @fa-var-black-tie; }\n.@{fa-css-prefix}-fonticons:before { content: @fa-var-fonticons; }\n.@{fa-css-prefix}-reddit-alien:before { content: @fa-var-reddit-alien; }\n.@{fa-css-prefix}-edge:before { content: @fa-var-edge; }\n.@{fa-css-prefix}-credit-card-alt:before { content: @fa-var-credit-card-alt; }\n.@{fa-css-prefix}-codiepie:before { content: @fa-var-codiepie; }\n.@{fa-css-prefix}-modx:before { content: @fa-var-modx; }\n.@{fa-css-prefix}-fort-awesome:before { content: @fa-var-fort-awesome; }\n.@{fa-css-prefix}-usb:before { content: @fa-var-usb; }\n.@{fa-css-prefix}-product-hunt:before { content: @fa-var-product-hunt; }\n.@{fa-css-prefix}-mixcloud:before { content: @fa-var-mixcloud; }\n.@{fa-css-prefix}-scribd:before { content: @fa-var-scribd; }\n.@{fa-css-prefix}-pause-circle:before { content: @fa-var-pause-circle; }\n.@{fa-css-prefix}-pause-circle-o:before { content: @fa-var-pause-circle-o; }\n.@{fa-css-prefix}-stop-circle:before { content: @fa-var-stop-circle; }\n.@{fa-css-prefix}-stop-circle-o:before { content: @fa-var-stop-circle-o; }\n.@{fa-css-prefix}-shopping-bag:before { content: @fa-var-shopping-bag; }\n.@{fa-css-prefix}-shopping-basket:before { content: @fa-var-shopping-basket; }\n.@{fa-css-prefix}-hashtag:before { content: @fa-var-hashtag; }\n.@{fa-css-prefix}-bluetooth:before { content: @fa-var-bluetooth; }\n.@{fa-css-prefix}-bluetooth-b:before { content: @fa-var-bluetooth-b; }\n.@{fa-css-prefix}-percent:before { content: @fa-var-percent; }\n.@{fa-css-prefix}-gitlab:before { content: @fa-var-gitlab; }\n.@{fa-css-prefix}-wpbeginner:before { content: @fa-var-wpbeginner; }\n.@{fa-css-prefix}-wpforms:before { content: @fa-var-wpforms; }\n.@{fa-css-prefix}-envira:before { content: @fa-var-envira; }\n.@{fa-css-prefix}-universal-access:before { content: @fa-var-universal-access; }\n.@{fa-css-prefix}-wheelchair-alt:before { content: @fa-var-wheelchair-alt; }\n.@{fa-css-prefix}-question-circle-o:before { content: @fa-var-question-circle-o; }\n.@{fa-css-prefix}-blind:before { content: @fa-var-blind; }\n.@{fa-css-prefix}-audio-description:before { content: @fa-var-audio-description; }\n.@{fa-css-prefix}-volume-control-phone:before { content: @fa-var-volume-control-phone; }\n.@{fa-css-prefix}-braille:before { content: @fa-var-braille; }\n.@{fa-css-prefix}-assistive-listening-systems:before { content: @fa-var-assistive-listening-systems; }\n.@{fa-css-prefix}-asl-interpreting:before,\n.@{fa-css-prefix}-american-sign-language-interpreting:before { content: @fa-var-american-sign-language-interpreting; }\n.@{fa-css-prefix}-deafness:before,\n.@{fa-css-prefix}-hard-of-hearing:before,\n.@{fa-css-prefix}-deaf:before { content: @fa-var-deaf; }\n.@{fa-css-prefix}-glide:before { content: @fa-var-glide; }\n.@{fa-css-prefix}-glide-g:before { content: @fa-var-glide-g; }\n.@{fa-css-prefix}-signing:before,\n.@{fa-css-prefix}-sign-language:before { content: @fa-var-sign-language; }\n.@{fa-css-prefix}-low-vision:before { content: @fa-var-low-vision; }\n.@{fa-css-prefix}-viadeo:before { content: @fa-var-viadeo; }\n.@{fa-css-prefix}-viadeo-square:before { content: @fa-var-viadeo-square; }\n.@{fa-css-prefix}-snapchat:before { content: @fa-var-snapchat; }\n.@{fa-css-prefix}-snapchat-ghost:before { content: @fa-var-snapchat-ghost; }\n.@{fa-css-prefix}-snapchat-square:before { content: @fa-var-snapchat-square; }\n.@{fa-css-prefix}-pied-piper:before { content: @fa-var-pied-piper; }\n.@{fa-css-prefix}-first-order:before { content: @fa-var-first-order; }\n.@{fa-css-prefix}-yoast:before { content: @fa-var-yoast; }\n.@{fa-css-prefix}-themeisle:before { content: @fa-var-themeisle; }\n.@{fa-css-prefix}-google-plus-circle:before,\n.@{fa-css-prefix}-google-plus-official:before { content: @fa-var-google-plus-official; }\n.@{fa-css-prefix}-fa:before,\n.@{fa-css-prefix}-font-awesome:before { content: @fa-var-font-awesome; }\n.@{fa-css-prefix}-handshake-o:before { content: @fa-var-handshake-o; }\n.@{fa-css-prefix}-envelope-open:before { content: @fa-var-envelope-open; }\n.@{fa-css-prefix}-envelope-open-o:before { content: @fa-var-envelope-open-o; }\n.@{fa-css-prefix}-linode:before { content: @fa-var-linode; }\n.@{fa-css-prefix}-address-book:before { content: @fa-var-address-book; }\n.@{fa-css-prefix}-address-book-o:before { content: @fa-var-address-book-o; }\n.@{fa-css-prefix}-vcard:before,\n.@{fa-css-prefix}-address-card:before { content: @fa-var-address-card; }\n.@{fa-css-prefix}-vcard-o:before,\n.@{fa-css-prefix}-address-card-o:before { content: @fa-var-address-card-o; }\n.@{fa-css-prefix}-user-circle:before { content: @fa-var-user-circle; }\n.@{fa-css-prefix}-user-circle-o:before { content: @fa-var-user-circle-o; }\n.@{fa-css-prefix}-user-o:before { content: @fa-var-user-o; }\n.@{fa-css-prefix}-id-badge:before { content: @fa-var-id-badge; }\n.@{fa-css-prefix}-drivers-license:before,\n.@{fa-css-prefix}-id-card:before { content: @fa-var-id-card; }\n.@{fa-css-prefix}-drivers-license-o:before,\n.@{fa-css-prefix}-id-card-o:before { content: @fa-var-id-card-o; }\n.@{fa-css-prefix}-quora:before { content: @fa-var-quora; }\n.@{fa-css-prefix}-free-code-camp:before { content: @fa-var-free-code-camp; }\n.@{fa-css-prefix}-telegram:before { content: @fa-var-telegram; }\n.@{fa-css-prefix}-thermometer-4:before,\n.@{fa-css-prefix}-thermometer:before,\n.@{fa-css-prefix}-thermometer-full:before { content: @fa-var-thermometer-full; }\n.@{fa-css-prefix}-thermometer-3:before,\n.@{fa-css-prefix}-thermometer-three-quarters:before { content: @fa-var-thermometer-three-quarters; }\n.@{fa-css-prefix}-thermometer-2:before,\n.@{fa-css-prefix}-thermometer-half:before { content: @fa-var-thermometer-half; }\n.@{fa-css-prefix}-thermometer-1:before,\n.@{fa-css-prefix}-thermometer-quarter:before { content: @fa-var-thermometer-quarter; }\n.@{fa-css-prefix}-thermometer-0:before,\n.@{fa-css-prefix}-thermometer-empty:before { content: @fa-var-thermometer-empty; }\n.@{fa-css-prefix}-shower:before { content: @fa-var-shower; }\n.@{fa-css-prefix}-bathtub:before,\n.@{fa-css-prefix}-s15:before,\n.@{fa-css-prefix}-bath:before { content: @fa-var-bath; }\n.@{fa-css-prefix}-podcast:before { content: @fa-var-podcast; }\n.@{fa-css-prefix}-window-maximize:before { content: @fa-var-window-maximize; }\n.@{fa-css-prefix}-window-minimize:before { content: @fa-var-window-minimize; }\n.@{fa-css-prefix}-window-restore:before { content: @fa-var-window-restore; }\n.@{fa-css-prefix}-times-rectangle:before,\n.@{fa-css-prefix}-window-close:before { content: @fa-var-window-close; }\n.@{fa-css-prefix}-times-rectangle-o:before,\n.@{fa-css-prefix}-window-close-o:before { content: @fa-var-window-close-o; }\n.@{fa-css-prefix}-bandcamp:before { content: @fa-var-bandcamp; }\n.@{fa-css-prefix}-grav:before { content: @fa-var-grav; }\n.@{fa-css-prefix}-etsy:before { content: @fa-var-etsy; }\n.@{fa-css-prefix}-imdb:before { content: @fa-var-imdb; }\n.@{fa-css-prefix}-ravelry:before { content: @fa-var-ravelry; }\n.@{fa-css-prefix}-eercast:before { content: @fa-var-eercast; }\n.@{fa-css-prefix}-microchip:before { content: @fa-var-microchip; }\n.@{fa-css-prefix}-snowflake-o:before { content: @fa-var-snowflake-o; }\n.@{fa-css-prefix}-superpowers:before { content: @fa-var-superpowers; }\n.@{fa-css-prefix}-wpexplorer:before { content: @fa-var-wpexplorer; }\n.@{fa-css-prefix}-meetup:before { content: @fa-var-meetup; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/larger.less",
    "content": "// Icon Sizes\n// -------------------------\n\n/* makes the font 33% larger relative to the icon container */\n.@{fa-css-prefix}-lg {\n  font-size: (4em / 3);\n  line-height: (3em / 4);\n  vertical-align: -15%;\n}\n.@{fa-css-prefix}-2x { font-size: 2em; }\n.@{fa-css-prefix}-3x { font-size: 3em; }\n.@{fa-css-prefix}-4x { font-size: 4em; }\n.@{fa-css-prefix}-5x { font-size: 5em; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/list.less",
    "content": "// List Icons\n// -------------------------\n\n.@{fa-css-prefix}-ul {\n  padding-left: 0;\n  margin-left: @fa-li-width;\n  list-style-type: none;\n  > li { position: relative; }\n}\n.@{fa-css-prefix}-li {\n  position: absolute;\n  left: -@fa-li-width;\n  width: @fa-li-width;\n  top: (2em / 14);\n  text-align: center;\n  &.@{fa-css-prefix}-lg {\n    left: (-@fa-li-width + (4em / 14));\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/mixins.less",
    "content": "// Mixins\n// --------------------------\n\n.fa-icon() {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/@fa-line-height-base FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n\n.fa-icon-rotate(@degrees, @rotation) {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=@{rotation})\";\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n\n.fa-icon-flip(@horiz, @vert, @rotation) {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=@{rotation}, mirror=1)\";\n  -webkit-transform: scale(@horiz, @vert);\n      -ms-transform: scale(@horiz, @vert);\n          transform: scale(@horiz, @vert);\n}\n\n\n// Only display content to screen readers. A la Bootstrap 4.\n//\n// See: http://a11yproject.com/posts/how-to-hide-content/\n\n.sr-only() {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  margin: -1px;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  border: 0;\n}\n\n// Use in conjunction with .sr-only to only display content when it's focused.\n//\n// Useful for \"Skip to main content\" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1\n//\n// Credit: HTML5 Boilerplate\n\n.sr-only-focusable() {\n  &:active,\n  &:focus {\n    position: static;\n    width: auto;\n    height: auto;\n    margin: 0;\n    overflow: visible;\n    clip: auto;\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/path.less",
    "content": "/* FONT PATH\n * -------------------------- */\n\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?v=@{fa-version}');\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?#iefix&v=@{fa-version}') format('embedded-opentype'),\n    url('@{fa-font-path}/fontawesome-webfont.woff2?v=@{fa-version}') format('woff2'),\n    url('@{fa-font-path}/fontawesome-webfont.woff?v=@{fa-version}') format('woff'),\n    url('@{fa-font-path}/fontawesome-webfont.ttf?v=@{fa-version}') format('truetype'),\n    url('@{fa-font-path}/fontawesome-webfont.svg?v=@{fa-version}#fontawesomeregular') format('svg');\n  // src: url('@{fa-font-path}/FontAwesome.otf') format('opentype'); // used when developing fonts\n  font-weight: normal;\n  font-style: normal;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/rotated-flipped.less",
    "content": "// Rotated & Flipped Icons\n// -------------------------\n\n.@{fa-css-prefix}-rotate-90  { .fa-icon-rotate(90deg, 1);  }\n.@{fa-css-prefix}-rotate-180 { .fa-icon-rotate(180deg, 2); }\n.@{fa-css-prefix}-rotate-270 { .fa-icon-rotate(270deg, 3); }\n\n.@{fa-css-prefix}-flip-horizontal { .fa-icon-flip(-1, 1, 0); }\n.@{fa-css-prefix}-flip-vertical   { .fa-icon-flip(1, -1, 2); }\n\n// Hook for IE8-9\n// -------------------------\n\n:root .@{fa-css-prefix}-rotate-90,\n:root .@{fa-css-prefix}-rotate-180,\n:root .@{fa-css-prefix}-rotate-270,\n:root .@{fa-css-prefix}-flip-horizontal,\n:root .@{fa-css-prefix}-flip-vertical {\n  filter: none;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/screen-reader.less",
    "content": "// Screen Readers\n// -------------------------\n\n.sr-only { .sr-only(); }\n.sr-only-focusable { .sr-only-focusable(); }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/stacked.less",
    "content": "// Stacked Icons\n// -------------------------\n\n.@{fa-css-prefix}-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.@{fa-css-prefix}-stack-1x, .@{fa-css-prefix}-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.@{fa-css-prefix}-stack-1x { line-height: inherit; }\n.@{fa-css-prefix}-stack-2x { font-size: 2em; }\n.@{fa-css-prefix}-inverse { color: @fa-inverse; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/less/variables.less",
    "content": "// Variables\n// --------------------------\n\n@fa-font-path:        \"../fonts\";\n@fa-font-size-base:   14px;\n@fa-line-height-base: 1;\n//@fa-font-path:        \"//netdna.bootstrapcdn.com/font-awesome/4.7.0/fonts\"; // for referencing Bootstrap CDN font files directly\n@fa-css-prefix:       fa;\n@fa-version:          \"4.7.0\";\n@fa-border-color:     #eee;\n@fa-inverse:          #fff;\n@fa-li-width:         (30em / 14);\n\n@fa-var-500px: \"\\f26e\";\n@fa-var-address-book: \"\\f2b9\";\n@fa-var-address-book-o: \"\\f2ba\";\n@fa-var-address-card: \"\\f2bb\";\n@fa-var-address-card-o: \"\\f2bc\";\n@fa-var-adjust: \"\\f042\";\n@fa-var-adn: \"\\f170\";\n@fa-var-align-center: \"\\f037\";\n@fa-var-align-justify: \"\\f039\";\n@fa-var-align-left: \"\\f036\";\n@fa-var-align-right: \"\\f038\";\n@fa-var-amazon: \"\\f270\";\n@fa-var-ambulance: \"\\f0f9\";\n@fa-var-american-sign-language-interpreting: \"\\f2a3\";\n@fa-var-anchor: \"\\f13d\";\n@fa-var-android: \"\\f17b\";\n@fa-var-angellist: \"\\f209\";\n@fa-var-angle-double-down: \"\\f103\";\n@fa-var-angle-double-left: \"\\f100\";\n@fa-var-angle-double-right: \"\\f101\";\n@fa-var-angle-double-up: \"\\f102\";\n@fa-var-angle-down: \"\\f107\";\n@fa-var-angle-left: \"\\f104\";\n@fa-var-angle-right: \"\\f105\";\n@fa-var-angle-up: \"\\f106\";\n@fa-var-apple: \"\\f179\";\n@fa-var-archive: \"\\f187\";\n@fa-var-area-chart: \"\\f1fe\";\n@fa-var-arrow-circle-down: \"\\f0ab\";\n@fa-var-arrow-circle-left: \"\\f0a8\";\n@fa-var-arrow-circle-o-down: \"\\f01a\";\n@fa-var-arrow-circle-o-left: \"\\f190\";\n@fa-var-arrow-circle-o-right: \"\\f18e\";\n@fa-var-arrow-circle-o-up: \"\\f01b\";\n@fa-var-arrow-circle-right: \"\\f0a9\";\n@fa-var-arrow-circle-up: \"\\f0aa\";\n@fa-var-arrow-down: \"\\f063\";\n@fa-var-arrow-left: \"\\f060\";\n@fa-var-arrow-right: \"\\f061\";\n@fa-var-arrow-up: \"\\f062\";\n@fa-var-arrows: \"\\f047\";\n@fa-var-arrows-alt: \"\\f0b2\";\n@fa-var-arrows-h: \"\\f07e\";\n@fa-var-arrows-v: \"\\f07d\";\n@fa-var-asl-interpreting: \"\\f2a3\";\n@fa-var-assistive-listening-systems: \"\\f2a2\";\n@fa-var-asterisk: \"\\f069\";\n@fa-var-at: \"\\f1fa\";\n@fa-var-audio-description: \"\\f29e\";\n@fa-var-automobile: \"\\f1b9\";\n@fa-var-backward: \"\\f04a\";\n@fa-var-balance-scale: \"\\f24e\";\n@fa-var-ban: \"\\f05e\";\n@fa-var-bandcamp: \"\\f2d5\";\n@fa-var-bank: \"\\f19c\";\n@fa-var-bar-chart: \"\\f080\";\n@fa-var-bar-chart-o: \"\\f080\";\n@fa-var-barcode: \"\\f02a\";\n@fa-var-bars: \"\\f0c9\";\n@fa-var-bath: \"\\f2cd\";\n@fa-var-bathtub: \"\\f2cd\";\n@fa-var-battery: \"\\f240\";\n@fa-var-battery-0: \"\\f244\";\n@fa-var-battery-1: \"\\f243\";\n@fa-var-battery-2: \"\\f242\";\n@fa-var-battery-3: \"\\f241\";\n@fa-var-battery-4: \"\\f240\";\n@fa-var-battery-empty: \"\\f244\";\n@fa-var-battery-full: \"\\f240\";\n@fa-var-battery-half: \"\\f242\";\n@fa-var-battery-quarter: \"\\f243\";\n@fa-var-battery-three-quarters: \"\\f241\";\n@fa-var-bed: \"\\f236\";\n@fa-var-beer: \"\\f0fc\";\n@fa-var-behance: \"\\f1b4\";\n@fa-var-behance-square: \"\\f1b5\";\n@fa-var-bell: \"\\f0f3\";\n@fa-var-bell-o: \"\\f0a2\";\n@fa-var-bell-slash: \"\\f1f6\";\n@fa-var-bell-slash-o: \"\\f1f7\";\n@fa-var-bicycle: \"\\f206\";\n@fa-var-binoculars: \"\\f1e5\";\n@fa-var-birthday-cake: \"\\f1fd\";\n@fa-var-bitbucket: \"\\f171\";\n@fa-var-bitbucket-square: \"\\f172\";\n@fa-var-bitcoin: \"\\f15a\";\n@fa-var-black-tie: \"\\f27e\";\n@fa-var-blind: \"\\f29d\";\n@fa-var-bluetooth: \"\\f293\";\n@fa-var-bluetooth-b: \"\\f294\";\n@fa-var-bold: \"\\f032\";\n@fa-var-bolt: \"\\f0e7\";\n@fa-var-bomb: \"\\f1e2\";\n@fa-var-book: \"\\f02d\";\n@fa-var-bookmark: \"\\f02e\";\n@fa-var-bookmark-o: \"\\f097\";\n@fa-var-braille: \"\\f2a1\";\n@fa-var-briefcase: \"\\f0b1\";\n@fa-var-btc: \"\\f15a\";\n@fa-var-bug: \"\\f188\";\n@fa-var-building: \"\\f1ad\";\n@fa-var-building-o: \"\\f0f7\";\n@fa-var-bullhorn: \"\\f0a1\";\n@fa-var-bullseye: \"\\f140\";\n@fa-var-bus: \"\\f207\";\n@fa-var-buysellads: \"\\f20d\";\n@fa-var-cab: \"\\f1ba\";\n@fa-var-calculator: \"\\f1ec\";\n@fa-var-calendar: \"\\f073\";\n@fa-var-calendar-check-o: \"\\f274\";\n@fa-var-calendar-minus-o: \"\\f272\";\n@fa-var-calendar-o: \"\\f133\";\n@fa-var-calendar-plus-o: \"\\f271\";\n@fa-var-calendar-times-o: \"\\f273\";\n@fa-var-camera: \"\\f030\";\n@fa-var-camera-retro: \"\\f083\";\n@fa-var-car: \"\\f1b9\";\n@fa-var-caret-down: \"\\f0d7\";\n@fa-var-caret-left: \"\\f0d9\";\n@fa-var-caret-right: \"\\f0da\";\n@fa-var-caret-square-o-down: \"\\f150\";\n@fa-var-caret-square-o-left: \"\\f191\";\n@fa-var-caret-square-o-right: \"\\f152\";\n@fa-var-caret-square-o-up: \"\\f151\";\n@fa-var-caret-up: \"\\f0d8\";\n@fa-var-cart-arrow-down: \"\\f218\";\n@fa-var-cart-plus: \"\\f217\";\n@fa-var-cc: \"\\f20a\";\n@fa-var-cc-amex: \"\\f1f3\";\n@fa-var-cc-diners-club: \"\\f24c\";\n@fa-var-cc-discover: \"\\f1f2\";\n@fa-var-cc-jcb: \"\\f24b\";\n@fa-var-cc-mastercard: \"\\f1f1\";\n@fa-var-cc-paypal: \"\\f1f4\";\n@fa-var-cc-stripe: \"\\f1f5\";\n@fa-var-cc-visa: \"\\f1f0\";\n@fa-var-certificate: \"\\f0a3\";\n@fa-var-chain: \"\\f0c1\";\n@fa-var-chain-broken: \"\\f127\";\n@fa-var-check: \"\\f00c\";\n@fa-var-check-circle: \"\\f058\";\n@fa-var-check-circle-o: \"\\f05d\";\n@fa-var-check-square: \"\\f14a\";\n@fa-var-check-square-o: \"\\f046\";\n@fa-var-chevron-circle-down: \"\\f13a\";\n@fa-var-chevron-circle-left: \"\\f137\";\n@fa-var-chevron-circle-right: \"\\f138\";\n@fa-var-chevron-circle-up: \"\\f139\";\n@fa-var-chevron-down: \"\\f078\";\n@fa-var-chevron-left: \"\\f053\";\n@fa-var-chevron-right: \"\\f054\";\n@fa-var-chevron-up: \"\\f077\";\n@fa-var-child: \"\\f1ae\";\n@fa-var-chrome: \"\\f268\";\n@fa-var-circle: \"\\f111\";\n@fa-var-circle-o: \"\\f10c\";\n@fa-var-circle-o-notch: \"\\f1ce\";\n@fa-var-circle-thin: \"\\f1db\";\n@fa-var-clipboard: \"\\f0ea\";\n@fa-var-clock-o: \"\\f017\";\n@fa-var-clone: \"\\f24d\";\n@fa-var-close: \"\\f00d\";\n@fa-var-cloud: \"\\f0c2\";\n@fa-var-cloud-download: \"\\f0ed\";\n@fa-var-cloud-upload: \"\\f0ee\";\n@fa-var-cny: \"\\f157\";\n@fa-var-code: \"\\f121\";\n@fa-var-code-fork: \"\\f126\";\n@fa-var-codepen: \"\\f1cb\";\n@fa-var-codiepie: \"\\f284\";\n@fa-var-coffee: \"\\f0f4\";\n@fa-var-cog: \"\\f013\";\n@fa-var-cogs: \"\\f085\";\n@fa-var-columns: \"\\f0db\";\n@fa-var-comment: \"\\f075\";\n@fa-var-comment-o: \"\\f0e5\";\n@fa-var-commenting: \"\\f27a\";\n@fa-var-commenting-o: \"\\f27b\";\n@fa-var-comments: \"\\f086\";\n@fa-var-comments-o: \"\\f0e6\";\n@fa-var-compass: \"\\f14e\";\n@fa-var-compress: \"\\f066\";\n@fa-var-connectdevelop: \"\\f20e\";\n@fa-var-contao: \"\\f26d\";\n@fa-var-copy: \"\\f0c5\";\n@fa-var-copyright: \"\\f1f9\";\n@fa-var-creative-commons: \"\\f25e\";\n@fa-var-credit-card: \"\\f09d\";\n@fa-var-credit-card-alt: \"\\f283\";\n@fa-var-crop: \"\\f125\";\n@fa-var-crosshairs: \"\\f05b\";\n@fa-var-css3: \"\\f13c\";\n@fa-var-cube: \"\\f1b2\";\n@fa-var-cubes: \"\\f1b3\";\n@fa-var-cut: \"\\f0c4\";\n@fa-var-cutlery: \"\\f0f5\";\n@fa-var-dashboard: \"\\f0e4\";\n@fa-var-dashcube: \"\\f210\";\n@fa-var-database: \"\\f1c0\";\n@fa-var-deaf: \"\\f2a4\";\n@fa-var-deafness: \"\\f2a4\";\n@fa-var-dedent: \"\\f03b\";\n@fa-var-delicious: \"\\f1a5\";\n@fa-var-desktop: \"\\f108\";\n@fa-var-deviantart: \"\\f1bd\";\n@fa-var-diamond: \"\\f219\";\n@fa-var-digg: \"\\f1a6\";\n@fa-var-dollar: \"\\f155\";\n@fa-var-dot-circle-o: \"\\f192\";\n@fa-var-download: \"\\f019\";\n@fa-var-dribbble: \"\\f17d\";\n@fa-var-drivers-license: \"\\f2c2\";\n@fa-var-drivers-license-o: \"\\f2c3\";\n@fa-var-dropbox: \"\\f16b\";\n@fa-var-drupal: \"\\f1a9\";\n@fa-var-edge: \"\\f282\";\n@fa-var-edit: \"\\f044\";\n@fa-var-eercast: \"\\f2da\";\n@fa-var-eject: \"\\f052\";\n@fa-var-ellipsis-h: \"\\f141\";\n@fa-var-ellipsis-v: \"\\f142\";\n@fa-var-empire: \"\\f1d1\";\n@fa-var-envelope: \"\\f0e0\";\n@fa-var-envelope-o: \"\\f003\";\n@fa-var-envelope-open: \"\\f2b6\";\n@fa-var-envelope-open-o: \"\\f2b7\";\n@fa-var-envelope-square: \"\\f199\";\n@fa-var-envira: \"\\f299\";\n@fa-var-eraser: \"\\f12d\";\n@fa-var-etsy: \"\\f2d7\";\n@fa-var-eur: \"\\f153\";\n@fa-var-euro: \"\\f153\";\n@fa-var-exchange: \"\\f0ec\";\n@fa-var-exclamation: \"\\f12a\";\n@fa-var-exclamation-circle: \"\\f06a\";\n@fa-var-exclamation-triangle: \"\\f071\";\n@fa-var-expand: \"\\f065\";\n@fa-var-expeditedssl: \"\\f23e\";\n@fa-var-external-link: \"\\f08e\";\n@fa-var-external-link-square: \"\\f14c\";\n@fa-var-eye: \"\\f06e\";\n@fa-var-eye-slash: \"\\f070\";\n@fa-var-eyedropper: \"\\f1fb\";\n@fa-var-fa: \"\\f2b4\";\n@fa-var-facebook: \"\\f09a\";\n@fa-var-facebook-f: \"\\f09a\";\n@fa-var-facebook-official: \"\\f230\";\n@fa-var-facebook-square: \"\\f082\";\n@fa-var-fast-backward: \"\\f049\";\n@fa-var-fast-forward: \"\\f050\";\n@fa-var-fax: \"\\f1ac\";\n@fa-var-feed: \"\\f09e\";\n@fa-var-female: \"\\f182\";\n@fa-var-fighter-jet: \"\\f0fb\";\n@fa-var-file: \"\\f15b\";\n@fa-var-file-archive-o: \"\\f1c6\";\n@fa-var-file-audio-o: \"\\f1c7\";\n@fa-var-file-code-o: \"\\f1c9\";\n@fa-var-file-excel-o: \"\\f1c3\";\n@fa-var-file-image-o: \"\\f1c5\";\n@fa-var-file-movie-o: \"\\f1c8\";\n@fa-var-file-o: \"\\f016\";\n@fa-var-file-pdf-o: \"\\f1c1\";\n@fa-var-file-photo-o: \"\\f1c5\";\n@fa-var-file-picture-o: \"\\f1c5\";\n@fa-var-file-powerpoint-o: \"\\f1c4\";\n@fa-var-file-sound-o: \"\\f1c7\";\n@fa-var-file-text: \"\\f15c\";\n@fa-var-file-text-o: \"\\f0f6\";\n@fa-var-file-video-o: \"\\f1c8\";\n@fa-var-file-word-o: \"\\f1c2\";\n@fa-var-file-zip-o: \"\\f1c6\";\n@fa-var-files-o: \"\\f0c5\";\n@fa-var-film: \"\\f008\";\n@fa-var-filter: \"\\f0b0\";\n@fa-var-fire: \"\\f06d\";\n@fa-var-fire-extinguisher: \"\\f134\";\n@fa-var-firefox: \"\\f269\";\n@fa-var-first-order: \"\\f2b0\";\n@fa-var-flag: \"\\f024\";\n@fa-var-flag-checkered: \"\\f11e\";\n@fa-var-flag-o: \"\\f11d\";\n@fa-var-flash: \"\\f0e7\";\n@fa-var-flask: \"\\f0c3\";\n@fa-var-flickr: \"\\f16e\";\n@fa-var-floppy-o: \"\\f0c7\";\n@fa-var-folder: \"\\f07b\";\n@fa-var-folder-o: \"\\f114\";\n@fa-var-folder-open: \"\\f07c\";\n@fa-var-folder-open-o: \"\\f115\";\n@fa-var-font: \"\\f031\";\n@fa-var-font-awesome: \"\\f2b4\";\n@fa-var-fonticons: \"\\f280\";\n@fa-var-fort-awesome: \"\\f286\";\n@fa-var-forumbee: \"\\f211\";\n@fa-var-forward: \"\\f04e\";\n@fa-var-foursquare: \"\\f180\";\n@fa-var-free-code-camp: \"\\f2c5\";\n@fa-var-frown-o: \"\\f119\";\n@fa-var-futbol-o: \"\\f1e3\";\n@fa-var-gamepad: \"\\f11b\";\n@fa-var-gavel: \"\\f0e3\";\n@fa-var-gbp: \"\\f154\";\n@fa-var-ge: \"\\f1d1\";\n@fa-var-gear: \"\\f013\";\n@fa-var-gears: \"\\f085\";\n@fa-var-genderless: \"\\f22d\";\n@fa-var-get-pocket: \"\\f265\";\n@fa-var-gg: \"\\f260\";\n@fa-var-gg-circle: \"\\f261\";\n@fa-var-gift: \"\\f06b\";\n@fa-var-git: \"\\f1d3\";\n@fa-var-git-square: \"\\f1d2\";\n@fa-var-github: \"\\f09b\";\n@fa-var-github-alt: \"\\f113\";\n@fa-var-github-square: \"\\f092\";\n@fa-var-gitlab: \"\\f296\";\n@fa-var-gittip: \"\\f184\";\n@fa-var-glass: \"\\f000\";\n@fa-var-glide: \"\\f2a5\";\n@fa-var-glide-g: \"\\f2a6\";\n@fa-var-globe: \"\\f0ac\";\n@fa-var-google: \"\\f1a0\";\n@fa-var-google-plus: \"\\f0d5\";\n@fa-var-google-plus-circle: \"\\f2b3\";\n@fa-var-google-plus-official: \"\\f2b3\";\n@fa-var-google-plus-square: \"\\f0d4\";\n@fa-var-google-wallet: \"\\f1ee\";\n@fa-var-graduation-cap: \"\\f19d\";\n@fa-var-gratipay: \"\\f184\";\n@fa-var-grav: \"\\f2d6\";\n@fa-var-group: \"\\f0c0\";\n@fa-var-h-square: \"\\f0fd\";\n@fa-var-hacker-news: \"\\f1d4\";\n@fa-var-hand-grab-o: \"\\f255\";\n@fa-var-hand-lizard-o: \"\\f258\";\n@fa-var-hand-o-down: \"\\f0a7\";\n@fa-var-hand-o-left: \"\\f0a5\";\n@fa-var-hand-o-right: \"\\f0a4\";\n@fa-var-hand-o-up: \"\\f0a6\";\n@fa-var-hand-paper-o: \"\\f256\";\n@fa-var-hand-peace-o: \"\\f25b\";\n@fa-var-hand-pointer-o: \"\\f25a\";\n@fa-var-hand-rock-o: \"\\f255\";\n@fa-var-hand-scissors-o: \"\\f257\";\n@fa-var-hand-spock-o: \"\\f259\";\n@fa-var-hand-stop-o: \"\\f256\";\n@fa-var-handshake-o: \"\\f2b5\";\n@fa-var-hard-of-hearing: \"\\f2a4\";\n@fa-var-hashtag: \"\\f292\";\n@fa-var-hdd-o: \"\\f0a0\";\n@fa-var-header: \"\\f1dc\";\n@fa-var-headphones: \"\\f025\";\n@fa-var-heart: \"\\f004\";\n@fa-var-heart-o: \"\\f08a\";\n@fa-var-heartbeat: \"\\f21e\";\n@fa-var-history: \"\\f1da\";\n@fa-var-home: \"\\f015\";\n@fa-var-hospital-o: \"\\f0f8\";\n@fa-var-hotel: \"\\f236\";\n@fa-var-hourglass: \"\\f254\";\n@fa-var-hourglass-1: \"\\f251\";\n@fa-var-hourglass-2: \"\\f252\";\n@fa-var-hourglass-3: \"\\f253\";\n@fa-var-hourglass-end: \"\\f253\";\n@fa-var-hourglass-half: \"\\f252\";\n@fa-var-hourglass-o: \"\\f250\";\n@fa-var-hourglass-start: \"\\f251\";\n@fa-var-houzz: \"\\f27c\";\n@fa-var-html5: \"\\f13b\";\n@fa-var-i-cursor: \"\\f246\";\n@fa-var-id-badge: \"\\f2c1\";\n@fa-var-id-card: \"\\f2c2\";\n@fa-var-id-card-o: \"\\f2c3\";\n@fa-var-ils: \"\\f20b\";\n@fa-var-image: \"\\f03e\";\n@fa-var-imdb: \"\\f2d8\";\n@fa-var-inbox: \"\\f01c\";\n@fa-var-indent: \"\\f03c\";\n@fa-var-industry: \"\\f275\";\n@fa-var-info: \"\\f129\";\n@fa-var-info-circle: \"\\f05a\";\n@fa-var-inr: \"\\f156\";\n@fa-var-instagram: \"\\f16d\";\n@fa-var-institution: \"\\f19c\";\n@fa-var-internet-explorer: \"\\f26b\";\n@fa-var-intersex: \"\\f224\";\n@fa-var-ioxhost: \"\\f208\";\n@fa-var-italic: \"\\f033\";\n@fa-var-joomla: \"\\f1aa\";\n@fa-var-jpy: \"\\f157\";\n@fa-var-jsfiddle: \"\\f1cc\";\n@fa-var-key: \"\\f084\";\n@fa-var-keyboard-o: \"\\f11c\";\n@fa-var-krw: \"\\f159\";\n@fa-var-language: \"\\f1ab\";\n@fa-var-laptop: \"\\f109\";\n@fa-var-lastfm: \"\\f202\";\n@fa-var-lastfm-square: \"\\f203\";\n@fa-var-leaf: \"\\f06c\";\n@fa-var-leanpub: \"\\f212\";\n@fa-var-legal: \"\\f0e3\";\n@fa-var-lemon-o: \"\\f094\";\n@fa-var-level-down: \"\\f149\";\n@fa-var-level-up: \"\\f148\";\n@fa-var-life-bouy: \"\\f1cd\";\n@fa-var-life-buoy: \"\\f1cd\";\n@fa-var-life-ring: \"\\f1cd\";\n@fa-var-life-saver: \"\\f1cd\";\n@fa-var-lightbulb-o: \"\\f0eb\";\n@fa-var-line-chart: \"\\f201\";\n@fa-var-link: \"\\f0c1\";\n@fa-var-linkedin: \"\\f0e1\";\n@fa-var-linkedin-square: \"\\f08c\";\n@fa-var-linode: \"\\f2b8\";\n@fa-var-linux: \"\\f17c\";\n@fa-var-list: \"\\f03a\";\n@fa-var-list-alt: \"\\f022\";\n@fa-var-list-ol: \"\\f0cb\";\n@fa-var-list-ul: \"\\f0ca\";\n@fa-var-location-arrow: \"\\f124\";\n@fa-var-lock: \"\\f023\";\n@fa-var-long-arrow-down: \"\\f175\";\n@fa-var-long-arrow-left: \"\\f177\";\n@fa-var-long-arrow-right: \"\\f178\";\n@fa-var-long-arrow-up: \"\\f176\";\n@fa-var-low-vision: \"\\f2a8\";\n@fa-var-magic: \"\\f0d0\";\n@fa-var-magnet: \"\\f076\";\n@fa-var-mail-forward: \"\\f064\";\n@fa-var-mail-reply: \"\\f112\";\n@fa-var-mail-reply-all: \"\\f122\";\n@fa-var-male: \"\\f183\";\n@fa-var-map: \"\\f279\";\n@fa-var-map-marker: \"\\f041\";\n@fa-var-map-o: \"\\f278\";\n@fa-var-map-pin: \"\\f276\";\n@fa-var-map-signs: \"\\f277\";\n@fa-var-mars: \"\\f222\";\n@fa-var-mars-double: \"\\f227\";\n@fa-var-mars-stroke: \"\\f229\";\n@fa-var-mars-stroke-h: \"\\f22b\";\n@fa-var-mars-stroke-v: \"\\f22a\";\n@fa-var-maxcdn: \"\\f136\";\n@fa-var-meanpath: \"\\f20c\";\n@fa-var-medium: \"\\f23a\";\n@fa-var-medkit: \"\\f0fa\";\n@fa-var-meetup: \"\\f2e0\";\n@fa-var-meh-o: \"\\f11a\";\n@fa-var-mercury: \"\\f223\";\n@fa-var-microchip: \"\\f2db\";\n@fa-var-microphone: \"\\f130\";\n@fa-var-microphone-slash: \"\\f131\";\n@fa-var-minus: \"\\f068\";\n@fa-var-minus-circle: \"\\f056\";\n@fa-var-minus-square: \"\\f146\";\n@fa-var-minus-square-o: \"\\f147\";\n@fa-var-mixcloud: \"\\f289\";\n@fa-var-mobile: \"\\f10b\";\n@fa-var-mobile-phone: \"\\f10b\";\n@fa-var-modx: \"\\f285\";\n@fa-var-money: \"\\f0d6\";\n@fa-var-moon-o: \"\\f186\";\n@fa-var-mortar-board: \"\\f19d\";\n@fa-var-motorcycle: \"\\f21c\";\n@fa-var-mouse-pointer: \"\\f245\";\n@fa-var-music: \"\\f001\";\n@fa-var-navicon: \"\\f0c9\";\n@fa-var-neuter: \"\\f22c\";\n@fa-var-newspaper-o: \"\\f1ea\";\n@fa-var-object-group: \"\\f247\";\n@fa-var-object-ungroup: \"\\f248\";\n@fa-var-odnoklassniki: \"\\f263\";\n@fa-var-odnoklassniki-square: \"\\f264\";\n@fa-var-opencart: \"\\f23d\";\n@fa-var-openid: \"\\f19b\";\n@fa-var-opera: \"\\f26a\";\n@fa-var-optin-monster: \"\\f23c\";\n@fa-var-outdent: \"\\f03b\";\n@fa-var-pagelines: \"\\f18c\";\n@fa-var-paint-brush: \"\\f1fc\";\n@fa-var-paper-plane: \"\\f1d8\";\n@fa-var-paper-plane-o: \"\\f1d9\";\n@fa-var-paperclip: \"\\f0c6\";\n@fa-var-paragraph: \"\\f1dd\";\n@fa-var-paste: \"\\f0ea\";\n@fa-var-pause: \"\\f04c\";\n@fa-var-pause-circle: \"\\f28b\";\n@fa-var-pause-circle-o: \"\\f28c\";\n@fa-var-paw: \"\\f1b0\";\n@fa-var-paypal: \"\\f1ed\";\n@fa-var-pencil: \"\\f040\";\n@fa-var-pencil-square: \"\\f14b\";\n@fa-var-pencil-square-o: \"\\f044\";\n@fa-var-percent: \"\\f295\";\n@fa-var-phone: \"\\f095\";\n@fa-var-phone-square: \"\\f098\";\n@fa-var-photo: \"\\f03e\";\n@fa-var-picture-o: \"\\f03e\";\n@fa-var-pie-chart: \"\\f200\";\n@fa-var-pied-piper: \"\\f2ae\";\n@fa-var-pied-piper-alt: \"\\f1a8\";\n@fa-var-pied-piper-pp: \"\\f1a7\";\n@fa-var-pinterest: \"\\f0d2\";\n@fa-var-pinterest-p: \"\\f231\";\n@fa-var-pinterest-square: \"\\f0d3\";\n@fa-var-plane: \"\\f072\";\n@fa-var-play: \"\\f04b\";\n@fa-var-play-circle: \"\\f144\";\n@fa-var-play-circle-o: \"\\f01d\";\n@fa-var-plug: \"\\f1e6\";\n@fa-var-plus: \"\\f067\";\n@fa-var-plus-circle: \"\\f055\";\n@fa-var-plus-square: \"\\f0fe\";\n@fa-var-plus-square-o: \"\\f196\";\n@fa-var-podcast: \"\\f2ce\";\n@fa-var-power-off: \"\\f011\";\n@fa-var-print: \"\\f02f\";\n@fa-var-product-hunt: \"\\f288\";\n@fa-var-puzzle-piece: \"\\f12e\";\n@fa-var-qq: \"\\f1d6\";\n@fa-var-qrcode: \"\\f029\";\n@fa-var-question: \"\\f128\";\n@fa-var-question-circle: \"\\f059\";\n@fa-var-question-circle-o: \"\\f29c\";\n@fa-var-quora: \"\\f2c4\";\n@fa-var-quote-left: \"\\f10d\";\n@fa-var-quote-right: \"\\f10e\";\n@fa-var-ra: \"\\f1d0\";\n@fa-var-random: \"\\f074\";\n@fa-var-ravelry: \"\\f2d9\";\n@fa-var-rebel: \"\\f1d0\";\n@fa-var-recycle: \"\\f1b8\";\n@fa-var-reddit: \"\\f1a1\";\n@fa-var-reddit-alien: \"\\f281\";\n@fa-var-reddit-square: \"\\f1a2\";\n@fa-var-refresh: \"\\f021\";\n@fa-var-registered: \"\\f25d\";\n@fa-var-remove: \"\\f00d\";\n@fa-var-renren: \"\\f18b\";\n@fa-var-reorder: \"\\f0c9\";\n@fa-var-repeat: \"\\f01e\";\n@fa-var-reply: \"\\f112\";\n@fa-var-reply-all: \"\\f122\";\n@fa-var-resistance: \"\\f1d0\";\n@fa-var-retweet: \"\\f079\";\n@fa-var-rmb: \"\\f157\";\n@fa-var-road: \"\\f018\";\n@fa-var-rocket: \"\\f135\";\n@fa-var-rotate-left: \"\\f0e2\";\n@fa-var-rotate-right: \"\\f01e\";\n@fa-var-rouble: \"\\f158\";\n@fa-var-rss: \"\\f09e\";\n@fa-var-rss-square: \"\\f143\";\n@fa-var-rub: \"\\f158\";\n@fa-var-ruble: \"\\f158\";\n@fa-var-rupee: \"\\f156\";\n@fa-var-s15: \"\\f2cd\";\n@fa-var-safari: \"\\f267\";\n@fa-var-save: \"\\f0c7\";\n@fa-var-scissors: \"\\f0c4\";\n@fa-var-scribd: \"\\f28a\";\n@fa-var-search: \"\\f002\";\n@fa-var-search-minus: \"\\f010\";\n@fa-var-search-plus: \"\\f00e\";\n@fa-var-sellsy: \"\\f213\";\n@fa-var-send: \"\\f1d8\";\n@fa-var-send-o: \"\\f1d9\";\n@fa-var-server: \"\\f233\";\n@fa-var-share: \"\\f064\";\n@fa-var-share-alt: \"\\f1e0\";\n@fa-var-share-alt-square: \"\\f1e1\";\n@fa-var-share-square: \"\\f14d\";\n@fa-var-share-square-o: \"\\f045\";\n@fa-var-shekel: \"\\f20b\";\n@fa-var-sheqel: \"\\f20b\";\n@fa-var-shield: \"\\f132\";\n@fa-var-ship: \"\\f21a\";\n@fa-var-shirtsinbulk: \"\\f214\";\n@fa-var-shopping-bag: \"\\f290\";\n@fa-var-shopping-basket: \"\\f291\";\n@fa-var-shopping-cart: \"\\f07a\";\n@fa-var-shower: \"\\f2cc\";\n@fa-var-sign-in: \"\\f090\";\n@fa-var-sign-language: \"\\f2a7\";\n@fa-var-sign-out: \"\\f08b\";\n@fa-var-signal: \"\\f012\";\n@fa-var-signing: \"\\f2a7\";\n@fa-var-simplybuilt: \"\\f215\";\n@fa-var-sitemap: \"\\f0e8\";\n@fa-var-skyatlas: \"\\f216\";\n@fa-var-skype: \"\\f17e\";\n@fa-var-slack: \"\\f198\";\n@fa-var-sliders: \"\\f1de\";\n@fa-var-slideshare: \"\\f1e7\";\n@fa-var-smile-o: \"\\f118\";\n@fa-var-snapchat: \"\\f2ab\";\n@fa-var-snapchat-ghost: \"\\f2ac\";\n@fa-var-snapchat-square: \"\\f2ad\";\n@fa-var-snowflake-o: \"\\f2dc\";\n@fa-var-soccer-ball-o: \"\\f1e3\";\n@fa-var-sort: \"\\f0dc\";\n@fa-var-sort-alpha-asc: \"\\f15d\";\n@fa-var-sort-alpha-desc: \"\\f15e\";\n@fa-var-sort-amount-asc: \"\\f160\";\n@fa-var-sort-amount-desc: \"\\f161\";\n@fa-var-sort-asc: \"\\f0de\";\n@fa-var-sort-desc: \"\\f0dd\";\n@fa-var-sort-down: \"\\f0dd\";\n@fa-var-sort-numeric-asc: \"\\f162\";\n@fa-var-sort-numeric-desc: \"\\f163\";\n@fa-var-sort-up: \"\\f0de\";\n@fa-var-soundcloud: \"\\f1be\";\n@fa-var-space-shuttle: \"\\f197\";\n@fa-var-spinner: \"\\f110\";\n@fa-var-spoon: \"\\f1b1\";\n@fa-var-spotify: \"\\f1bc\";\n@fa-var-square: \"\\f0c8\";\n@fa-var-square-o: \"\\f096\";\n@fa-var-stack-exchange: \"\\f18d\";\n@fa-var-stack-overflow: \"\\f16c\";\n@fa-var-star: \"\\f005\";\n@fa-var-star-half: \"\\f089\";\n@fa-var-star-half-empty: \"\\f123\";\n@fa-var-star-half-full: \"\\f123\";\n@fa-var-star-half-o: \"\\f123\";\n@fa-var-star-o: \"\\f006\";\n@fa-var-steam: \"\\f1b6\";\n@fa-var-steam-square: \"\\f1b7\";\n@fa-var-step-backward: \"\\f048\";\n@fa-var-step-forward: \"\\f051\";\n@fa-var-stethoscope: \"\\f0f1\";\n@fa-var-sticky-note: \"\\f249\";\n@fa-var-sticky-note-o: \"\\f24a\";\n@fa-var-stop: \"\\f04d\";\n@fa-var-stop-circle: \"\\f28d\";\n@fa-var-stop-circle-o: \"\\f28e\";\n@fa-var-street-view: \"\\f21d\";\n@fa-var-strikethrough: \"\\f0cc\";\n@fa-var-stumbleupon: \"\\f1a4\";\n@fa-var-stumbleupon-circle: \"\\f1a3\";\n@fa-var-subscript: \"\\f12c\";\n@fa-var-subway: \"\\f239\";\n@fa-var-suitcase: \"\\f0f2\";\n@fa-var-sun-o: \"\\f185\";\n@fa-var-superpowers: \"\\f2dd\";\n@fa-var-superscript: \"\\f12b\";\n@fa-var-support: \"\\f1cd\";\n@fa-var-table: \"\\f0ce\";\n@fa-var-tablet: \"\\f10a\";\n@fa-var-tachometer: \"\\f0e4\";\n@fa-var-tag: \"\\f02b\";\n@fa-var-tags: \"\\f02c\";\n@fa-var-tasks: \"\\f0ae\";\n@fa-var-taxi: \"\\f1ba\";\n@fa-var-telegram: \"\\f2c6\";\n@fa-var-television: \"\\f26c\";\n@fa-var-tencent-weibo: \"\\f1d5\";\n@fa-var-terminal: \"\\f120\";\n@fa-var-text-height: \"\\f034\";\n@fa-var-text-width: \"\\f035\";\n@fa-var-th: \"\\f00a\";\n@fa-var-th-large: \"\\f009\";\n@fa-var-th-list: \"\\f00b\";\n@fa-var-themeisle: \"\\f2b2\";\n@fa-var-thermometer: \"\\f2c7\";\n@fa-var-thermometer-0: \"\\f2cb\";\n@fa-var-thermometer-1: \"\\f2ca\";\n@fa-var-thermometer-2: \"\\f2c9\";\n@fa-var-thermometer-3: \"\\f2c8\";\n@fa-var-thermometer-4: \"\\f2c7\";\n@fa-var-thermometer-empty: \"\\f2cb\";\n@fa-var-thermometer-full: \"\\f2c7\";\n@fa-var-thermometer-half: \"\\f2c9\";\n@fa-var-thermometer-quarter: \"\\f2ca\";\n@fa-var-thermometer-three-quarters: \"\\f2c8\";\n@fa-var-thumb-tack: \"\\f08d\";\n@fa-var-thumbs-down: \"\\f165\";\n@fa-var-thumbs-o-down: \"\\f088\";\n@fa-var-thumbs-o-up: \"\\f087\";\n@fa-var-thumbs-up: \"\\f164\";\n@fa-var-ticket: \"\\f145\";\n@fa-var-times: \"\\f00d\";\n@fa-var-times-circle: \"\\f057\";\n@fa-var-times-circle-o: \"\\f05c\";\n@fa-var-times-rectangle: \"\\f2d3\";\n@fa-var-times-rectangle-o: \"\\f2d4\";\n@fa-var-tint: \"\\f043\";\n@fa-var-toggle-down: \"\\f150\";\n@fa-var-toggle-left: \"\\f191\";\n@fa-var-toggle-off: \"\\f204\";\n@fa-var-toggle-on: \"\\f205\";\n@fa-var-toggle-right: \"\\f152\";\n@fa-var-toggle-up: \"\\f151\";\n@fa-var-trademark: \"\\f25c\";\n@fa-var-train: \"\\f238\";\n@fa-var-transgender: \"\\f224\";\n@fa-var-transgender-alt: \"\\f225\";\n@fa-var-trash: \"\\f1f8\";\n@fa-var-trash-o: \"\\f014\";\n@fa-var-tree: \"\\f1bb\";\n@fa-var-trello: \"\\f181\";\n@fa-var-tripadvisor: \"\\f262\";\n@fa-var-trophy: \"\\f091\";\n@fa-var-truck: \"\\f0d1\";\n@fa-var-try: \"\\f195\";\n@fa-var-tty: \"\\f1e4\";\n@fa-var-tumblr: \"\\f173\";\n@fa-var-tumblr-square: \"\\f174\";\n@fa-var-turkish-lira: \"\\f195\";\n@fa-var-tv: \"\\f26c\";\n@fa-var-twitch: \"\\f1e8\";\n@fa-var-twitter: \"\\f099\";\n@fa-var-twitter-square: \"\\f081\";\n@fa-var-umbrella: \"\\f0e9\";\n@fa-var-underline: \"\\f0cd\";\n@fa-var-undo: \"\\f0e2\";\n@fa-var-universal-access: \"\\f29a\";\n@fa-var-university: \"\\f19c\";\n@fa-var-unlink: \"\\f127\";\n@fa-var-unlock: \"\\f09c\";\n@fa-var-unlock-alt: \"\\f13e\";\n@fa-var-unsorted: \"\\f0dc\";\n@fa-var-upload: \"\\f093\";\n@fa-var-usb: \"\\f287\";\n@fa-var-usd: \"\\f155\";\n@fa-var-user: \"\\f007\";\n@fa-var-user-circle: \"\\f2bd\";\n@fa-var-user-circle-o: \"\\f2be\";\n@fa-var-user-md: \"\\f0f0\";\n@fa-var-user-o: \"\\f2c0\";\n@fa-var-user-plus: \"\\f234\";\n@fa-var-user-secret: \"\\f21b\";\n@fa-var-user-times: \"\\f235\";\n@fa-var-users: \"\\f0c0\";\n@fa-var-vcard: \"\\f2bb\";\n@fa-var-vcard-o: \"\\f2bc\";\n@fa-var-venus: \"\\f221\";\n@fa-var-venus-double: \"\\f226\";\n@fa-var-venus-mars: \"\\f228\";\n@fa-var-viacoin: \"\\f237\";\n@fa-var-viadeo: \"\\f2a9\";\n@fa-var-viadeo-square: \"\\f2aa\";\n@fa-var-video-camera: \"\\f03d\";\n@fa-var-vimeo: \"\\f27d\";\n@fa-var-vimeo-square: \"\\f194\";\n@fa-var-vine: \"\\f1ca\";\n@fa-var-vk: \"\\f189\";\n@fa-var-volume-control-phone: \"\\f2a0\";\n@fa-var-volume-down: \"\\f027\";\n@fa-var-volume-off: \"\\f026\";\n@fa-var-volume-up: \"\\f028\";\n@fa-var-warning: \"\\f071\";\n@fa-var-wechat: \"\\f1d7\";\n@fa-var-weibo: \"\\f18a\";\n@fa-var-weixin: \"\\f1d7\";\n@fa-var-whatsapp: \"\\f232\";\n@fa-var-wheelchair: \"\\f193\";\n@fa-var-wheelchair-alt: \"\\f29b\";\n@fa-var-wifi: \"\\f1eb\";\n@fa-var-wikipedia-w: \"\\f266\";\n@fa-var-window-close: \"\\f2d3\";\n@fa-var-window-close-o: \"\\f2d4\";\n@fa-var-window-maximize: \"\\f2d0\";\n@fa-var-window-minimize: \"\\f2d1\";\n@fa-var-window-restore: \"\\f2d2\";\n@fa-var-windows: \"\\f17a\";\n@fa-var-won: \"\\f159\";\n@fa-var-wordpress: \"\\f19a\";\n@fa-var-wpbeginner: \"\\f297\";\n@fa-var-wpexplorer: \"\\f2de\";\n@fa-var-wpforms: \"\\f298\";\n@fa-var-wrench: \"\\f0ad\";\n@fa-var-xing: \"\\f168\";\n@fa-var-xing-square: \"\\f169\";\n@fa-var-y-combinator: \"\\f23b\";\n@fa-var-y-combinator-square: \"\\f1d4\";\n@fa-var-yahoo: \"\\f19e\";\n@fa-var-yc: \"\\f23b\";\n@fa-var-yc-square: \"\\f1d4\";\n@fa-var-yelp: \"\\f1e9\";\n@fa-var-yen: \"\\f157\";\n@fa-var-yoast: \"\\f2b1\";\n@fa-var-youtube: \"\\f167\";\n@fa-var-youtube-play: \"\\f16a\";\n@fa-var-youtube-square: \"\\f166\";\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/.bower.json",
    "content": "{\n  \"name\": \"font-awesome\",\n  \"description\": \"Font Awesome\",\n  \"version\": \"4.2.0\",\n  \"keywords\": [],\n  \"homepage\": \"http://fontawesome.io\",\n  \"dependencies\": {},\n  \"devDependencies\": {},\n  \"license\": [\n    \"OFL-1.1\",\n    \"MIT\",\n    \"CC-BY-3.0\"\n  ],\n  \"main\": [\n    \"./css/font-awesome.css\",\n    \".//fonts/*\"\n  ],\n  \"ignore\": [\n    \"*/.*\",\n    \"*.json\",\n    \"src\",\n    \"*.yml\",\n    \"Gemfile\",\n    \"Gemfile.lock\",\n    \"*.md\"\n  ],\n  \"_release\": \"4.2.0\",\n  \"_resolution\": {\n    \"type\": \"version\",\n    \"tag\": \"v4.2.0\",\n    \"commit\": \"0b924144a95a54fa738d0450ff66c1dabd11ae74\"\n  },\n  \"_source\": \"git://github.com/FortAwesome/Font-Awesome.git\",\n  \"_target\": \"~4.2.0\",\n  \"_originalSource\": \"font-awesome\"\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/.gitignore",
    "content": "*.pyc\n*.egg-info\n*.db\n*.db.old\n*.swp\n*.db-journal\n\n.coverage\n.DS_Store\n.installed.cfg\n_gh_pages/*\n\n.idea/*\n.svn/*\nsrc/website/static/*\nsrc/website/media/*\n\nbin\ncfcache\ndevelop-eggs\ndist\ndownloads\neggs\nparts\ntmp\n.sass-cache\nnode_modules\n\nsrc/website/settingslocal.py\nstunnel.log\n\n.ruby-version\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/.npmignore",
    "content": "*.pyc\n*.egg-info\n*.db\n*.db.old\n*.swp\n*.db-journal\n\n.coverage\n.DS_Store\n.installed.cfg\n_gh_pages/*\n\n.idea/*\n.svn/*\nsrc/website/static/*\nsrc/website/media/*\n\nbin\ncfcache\ndevelop-eggs\ndist\ndownloads\neggs\nparts\ntmp\n.sass-cache\nnode_modules\n\nsrc/website/settingslocal.py\nstunnel.log\n\n.ruby-version\n\n# don't need these in the npm package.\nsrc/\n_config.yml\nbower.json\ncomponent.json\ncomposer.json\nCONTRIBUTING.md\nGemfile\nGemfile.lock\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/HELP-US-OUT.txt",
    "content": "I hope you love Font Awesome. If you've found it useful, please do me a favor and check out my latest project,\nFonticons (https://fonticons.com). It makes it easy to put the perfect icons on your website. Choose from our awesome,\ncomprehensive icon sets or copy and paste your own.\n\nPlease. Check it out.\n\n-Dave Gandy\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/bower.json",
    "content": "{\n  \"name\": \"font-awesome\",\n  \"description\": \"Font Awesome\",\n  \"version\": \"4.2.0\",\n  \"keywords\": [],\n  \"homepage\": \"http://fontawesome.io\",\n  \"dependencies\": {},\n  \"devDependencies\": {},\n  \"license\": [\"OFL-1.1\", \"MIT\", \"CC-BY-3.0\"],\n  \"main\": [\n    \"./css/font-awesome.css\",\n    \".//fonts/*\"\n  ],\n  \"ignore\": [\n    \"*/.*\",\n    \"*.json\",\n    \"src\",\n    \"*.yml\",\n    \"Gemfile\",\n    \"Gemfile.lock\",\n    \"*.md\"\n  ]\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/css/font-awesome.css",
    "content": "/*!\n *  Font Awesome 4.5.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n/* FONT PATH\n * -------------------------- */\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('..//fonts/fontawesome-webfont.eot?v=4.5.0');\n  src: url('..//fonts/fontawesome-webfont.eot?#iefix&v=4.5.0') format('embedded-opentype'), url('..//fonts/fontawesome-webfont.woff2?v=4.5.0') format('woff2'), url('..//fonts/fontawesome-webfont.woff?v=4.5.0') format('woff'), url('..//fonts/fontawesome-webfont.ttf?v=4.5.0') format('truetype'), url('..//fonts/fontawesome-webfont.svg?v=4.5.0#fontawesomeregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.fa {\n  display: inline-block;\n  font: normal normal normal 14px/1 FontAwesome;\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n/* makes the font 33% larger relative to the icon container */\n.fa-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.fa-2x {\n  font-size: 2em;\n}\n.fa-3x {\n  font-size: 3em;\n}\n.fa-4x {\n  font-size: 4em;\n}\n.fa-5x {\n  font-size: 5em;\n}\n.fa-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.fa-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.fa-ul > li {\n  position: relative;\n}\n.fa-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.fa-li.fa-lg {\n  left: -1.85714286em;\n}\n.fa-border {\n  padding: .2em .25em .15em;\n  border: solid 0.08em #eeeeee;\n  border-radius: .1em;\n}\n.fa-pull-left {\n  float: left;\n}\n.fa-pull-right {\n  float: right;\n}\n.fa.fa-pull-left {\n  margin-right: .3em;\n}\n.fa.fa-pull-right {\n  margin-left: .3em;\n}\n/* Deprecated as of 4.4.0 */\n.pull-right {\n  float: right;\n}\n.pull-left {\n  float: left;\n}\n.fa.pull-left {\n  margin-right: .3em;\n}\n.fa.pull-right {\n  margin-left: .3em;\n}\n.fa-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n  animation: fa-spin 2s infinite linear;\n}\n.fa-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n  animation: fa-spin 1s infinite steps(8);\n}\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n.fa-rotate-90 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.fa-rotate-180 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.fa-rotate-270 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.fa-flip-horizontal {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.fa-flip-vertical {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n:root .fa-rotate-90,\n:root .fa-rotate-180,\n:root .fa-rotate-270,\n:root .fa-flip-horizontal,\n:root .fa-flip-vertical {\n  filter: none;\n}\n.fa-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.fa-stack-1x,\n.fa-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.fa-stack-1x {\n  line-height: inherit;\n}\n.fa-stack-2x {\n  font-size: 2em;\n}\n.fa-inverse {\n  color: #ffffff;\n}\n/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.fa-glass:before {\n  content: \"\\f000\";\n}\n.fa-music:before {\n  content: \"\\f001\";\n}\n.fa-search:before {\n  content: \"\\f002\";\n}\n.fa-envelope-o:before {\n  content: \"\\f003\";\n}\n.fa-heart:before {\n  content: \"\\f004\";\n}\n.fa-star:before {\n  content: \"\\f005\";\n}\n.fa-star-o:before {\n  content: \"\\f006\";\n}\n.fa-user:before {\n  content: \"\\f007\";\n}\n.fa-film:before {\n  content: \"\\f008\";\n}\n.fa-th-large:before {\n  content: \"\\f009\";\n}\n.fa-th:before {\n  content: \"\\f00a\";\n}\n.fa-th-list:before {\n  content: \"\\f00b\";\n}\n.fa-check:before {\n  content: \"\\f00c\";\n}\n.fa-remove:before,\n.fa-close:before,\n.fa-times:before {\n  content: \"\\f00d\";\n}\n.fa-search-plus:before {\n  content: \"\\f00e\";\n}\n.fa-search-minus:before {\n  content: \"\\f010\";\n}\n.fa-power-off:before {\n  content: \"\\f011\";\n}\n.fa-signal:before {\n  content: \"\\f012\";\n}\n.fa-gear:before,\n.fa-cog:before {\n  content: \"\\f013\";\n}\n.fa-trash-o:before {\n  content: \"\\f014\";\n}\n.fa-home:before {\n  content: \"\\f015\";\n}\n.fa-file-o:before {\n  content: \"\\f016\";\n}\n.fa-clock-o:before {\n  content: \"\\f017\";\n}\n.fa-road:before {\n  content: \"\\f018\";\n}\n.fa-download:before {\n  content: \"\\f019\";\n}\n.fa-arrow-circle-o-down:before {\n  content: \"\\f01a\";\n}\n.fa-arrow-circle-o-up:before {\n  content: \"\\f01b\";\n}\n.fa-inbox:before {\n  content: \"\\f01c\";\n}\n.fa-play-circle-o:before {\n  content: \"\\f01d\";\n}\n.fa-rotate-right:before,\n.fa-repeat:before {\n  content: \"\\f01e\";\n}\n.fa-refresh:before {\n  content: \"\\f021\";\n}\n.fa-list-alt:before {\n  content: \"\\f022\";\n}\n.fa-lock:before {\n  content: \"\\f023\";\n}\n.fa-flag:before {\n  content: \"\\f024\";\n}\n.fa-headphones:before {\n  content: \"\\f025\";\n}\n.fa-volume-off:before {\n  content: \"\\f026\";\n}\n.fa-volume-down:before {\n  content: \"\\f027\";\n}\n.fa-volume-up:before {\n  content: \"\\f028\";\n}\n.fa-qrcode:before {\n  content: \"\\f029\";\n}\n.fa-barcode:before {\n  content: \"\\f02a\";\n}\n.fa-tag:before {\n  content: \"\\f02b\";\n}\n.fa-tags:before {\n  content: \"\\f02c\";\n}\n.fa-book:before {\n  content: \"\\f02d\";\n}\n.fa-bookmark:before {\n  content: \"\\f02e\";\n}\n.fa-print:before {\n  content: \"\\f02f\";\n}\n.fa-camera:before {\n  content: \"\\f030\";\n}\n.fa-font:before {\n  content: \"\\f031\";\n}\n.fa-bold:before {\n  content: \"\\f032\";\n}\n.fa-italic:before {\n  content: \"\\f033\";\n}\n.fa-text-height:before {\n  content: \"\\f034\";\n}\n.fa-text-width:before {\n  content: \"\\f035\";\n}\n.fa-align-left:before {\n  content: \"\\f036\";\n}\n.fa-align-center:before {\n  content: \"\\f037\";\n}\n.fa-align-right:before {\n  content: \"\\f038\";\n}\n.fa-align-justify:before {\n  content: \"\\f039\";\n}\n.fa-list:before {\n  content: \"\\f03a\";\n}\n.fa-dedent:before,\n.fa-outdent:before {\n  content: \"\\f03b\";\n}\n.fa-indent:before {\n  content: \"\\f03c\";\n}\n.fa-video-camera:before {\n  content: \"\\f03d\";\n}\n.fa-photo:before,\n.fa-image:before,\n.fa-picture-o:before {\n  content: \"\\f03e\";\n}\n.fa-pencil:before {\n  content: \"\\f040\";\n}\n.fa-map-marker:before {\n  content: \"\\f041\";\n}\n.fa-adjust:before {\n  content: \"\\f042\";\n}\n.fa-tint:before {\n  content: \"\\f043\";\n}\n.fa-edit:before,\n.fa-pencil-square-o:before {\n  content: \"\\f044\";\n}\n.fa-share-square-o:before {\n  content: \"\\f045\";\n}\n.fa-check-square-o:before {\n  content: \"\\f046\";\n}\n.fa-arrows:before {\n  content: \"\\f047\";\n}\n.fa-step-backward:before {\n  content: \"\\f048\";\n}\n.fa-fast-backward:before {\n  content: \"\\f049\";\n}\n.fa-backward:before {\n  content: \"\\f04a\";\n}\n.fa-play:before {\n  content: \"\\f04b\";\n}\n.fa-pause:before {\n  content: \"\\f04c\";\n}\n.fa-stop:before {\n  content: \"\\f04d\";\n}\n.fa-forward:before {\n  content: \"\\f04e\";\n}\n.fa-fast-forward:before {\n  content: \"\\f050\";\n}\n.fa-step-forward:before {\n  content: \"\\f051\";\n}\n.fa-eject:before {\n  content: \"\\f052\";\n}\n.fa-chevron-left:before {\n  content: \"\\f053\";\n}\n.fa-chevron-right:before {\n  content: \"\\f054\";\n}\n.fa-plus-circle:before {\n  content: \"\\f055\";\n}\n.fa-minus-circle:before {\n  content: \"\\f056\";\n}\n.fa-times-circle:before {\n  content: \"\\f057\";\n}\n.fa-check-circle:before {\n  content: \"\\f058\";\n}\n.fa-question-circle:before {\n  content: \"\\f059\";\n}\n.fa-info-circle:before {\n  content: \"\\f05a\";\n}\n.fa-crosshairs:before {\n  content: \"\\f05b\";\n}\n.fa-times-circle-o:before {\n  content: \"\\f05c\";\n}\n.fa-check-circle-o:before {\n  content: \"\\f05d\";\n}\n.fa-ban:before {\n  content: \"\\f05e\";\n}\n.fa-arrow-left:before {\n  content: \"\\f060\";\n}\n.fa-arrow-right:before {\n  content: \"\\f061\";\n}\n.fa-arrow-up:before {\n  content: \"\\f062\";\n}\n.fa-arrow-down:before {\n  content: \"\\f063\";\n}\n.fa-mail-forward:before,\n.fa-share:before {\n  content: \"\\f064\";\n}\n.fa-expand:before {\n  content: \"\\f065\";\n}\n.fa-compress:before {\n  content: \"\\f066\";\n}\n.fa-plus:before {\n  content: \"\\f067\";\n}\n.fa-minus:before {\n  content: \"\\f068\";\n}\n.fa-asterisk:before {\n  content: \"\\f069\";\n}\n.fa-exclamation-circle:before {\n  content: \"\\f06a\";\n}\n.fa-gift:before {\n  content: \"\\f06b\";\n}\n.fa-leaf:before {\n  content: \"\\f06c\";\n}\n.fa-fire:before {\n  content: \"\\f06d\";\n}\n.fa-eye:before {\n  content: \"\\f06e\";\n}\n.fa-eye-slash:before {\n  content: \"\\f070\";\n}\n.fa-warning:before,\n.fa-exclamation-triangle:before {\n  content: \"\\f071\";\n}\n.fa-plane:before {\n  content: \"\\f072\";\n}\n.fa-calendar:before {\n  content: \"\\f073\";\n}\n.fa-random:before {\n  content: \"\\f074\";\n}\n.fa-comment:before {\n  content: \"\\f075\";\n}\n.fa-magnet:before {\n  content: \"\\f076\";\n}\n.fa-chevron-up:before {\n  content: \"\\f077\";\n}\n.fa-chevron-down:before {\n  content: \"\\f078\";\n}\n.fa-retweet:before {\n  content: \"\\f079\";\n}\n.fa-shopping-cart:before {\n  content: \"\\f07a\";\n}\n.fa-folder:before {\n  content: \"\\f07b\";\n}\n.fa-folder-open:before {\n  content: \"\\f07c\";\n}\n.fa-arrows-v:before {\n  content: \"\\f07d\";\n}\n.fa-arrows-h:before {\n  content: \"\\f07e\";\n}\n.fa-bar-chart-o:before,\n.fa-bar-chart:before {\n  content: \"\\f080\";\n}\n.fa-twitter-square:before {\n  content: \"\\f081\";\n}\n.fa-facebook-square:before {\n  content: \"\\f082\";\n}\n.fa-camera-retro:before {\n  content: \"\\f083\";\n}\n.fa-key:before {\n  content: \"\\f084\";\n}\n.fa-gears:before,\n.fa-cogs:before {\n  content: \"\\f085\";\n}\n.fa-comments:before {\n  content: \"\\f086\";\n}\n.fa-thumbs-o-up:before {\n  content: \"\\f087\";\n}\n.fa-thumbs-o-down:before {\n  content: \"\\f088\";\n}\n.fa-star-half:before {\n  content: \"\\f089\";\n}\n.fa-heart-o:before {\n  content: \"\\f08a\";\n}\n.fa-sign-out:before {\n  content: \"\\f08b\";\n}\n.fa-linkedin-square:before {\n  content: \"\\f08c\";\n}\n.fa-thumb-tack:before {\n  content: \"\\f08d\";\n}\n.fa-external-link:before {\n  content: \"\\f08e\";\n}\n.fa-sign-in:before {\n  content: \"\\f090\";\n}\n.fa-trophy:before {\n  content: \"\\f091\";\n}\n.fa-github-square:before {\n  content: \"\\f092\";\n}\n.fa-upload:before {\n  content: \"\\f093\";\n}\n.fa-lemon-o:before {\n  content: \"\\f094\";\n}\n.fa-phone:before {\n  content: \"\\f095\";\n}\n.fa-square-o:before {\n  content: \"\\f096\";\n}\n.fa-bookmark-o:before {\n  content: \"\\f097\";\n}\n.fa-phone-square:before {\n  content: \"\\f098\";\n}\n.fa-twitter:before {\n  content: \"\\f099\";\n}\n.fa-facebook-f:before,\n.fa-facebook:before {\n  content: \"\\f09a\";\n}\n.fa-github:before {\n  content: \"\\f09b\";\n}\n.fa-unlock:before {\n  content: \"\\f09c\";\n}\n.fa-credit-card:before {\n  content: \"\\f09d\";\n}\n.fa-feed:before,\n.fa-rss:before {\n  content: \"\\f09e\";\n}\n.fa-hdd-o:before {\n  content: \"\\f0a0\";\n}\n.fa-bullhorn:before {\n  content: \"\\f0a1\";\n}\n.fa-bell:before {\n  content: \"\\f0f3\";\n}\n.fa-certificate:before {\n  content: \"\\f0a3\";\n}\n.fa-hand-o-right:before {\n  content: \"\\f0a4\";\n}\n.fa-hand-o-left:before {\n  content: \"\\f0a5\";\n}\n.fa-hand-o-up:before {\n  content: \"\\f0a6\";\n}\n.fa-hand-o-down:before {\n  content: \"\\f0a7\";\n}\n.fa-arrow-circle-left:before {\n  content: \"\\f0a8\";\n}\n.fa-arrow-circle-right:before {\n  content: \"\\f0a9\";\n}\n.fa-arrow-circle-up:before {\n  content: \"\\f0aa\";\n}\n.fa-arrow-circle-down:before {\n  content: \"\\f0ab\";\n}\n.fa-globe:before {\n  content: \"\\f0ac\";\n}\n.fa-wrench:before {\n  content: \"\\f0ad\";\n}\n.fa-tasks:before {\n  content: \"\\f0ae\";\n}\n.fa-filter:before {\n  content: \"\\f0b0\";\n}\n.fa-briefcase:before {\n  content: \"\\f0b1\";\n}\n.fa-arrows-alt:before {\n  content: \"\\f0b2\";\n}\n.fa-group:before,\n.fa-users:before {\n  content: \"\\f0c0\";\n}\n.fa-chain:before,\n.fa-link:before {\n  content: \"\\f0c1\";\n}\n.fa-cloud:before {\n  content: \"\\f0c2\";\n}\n.fa-flask:before {\n  content: \"\\f0c3\";\n}\n.fa-cut:before,\n.fa-scissors:before {\n  content: \"\\f0c4\";\n}\n.fa-copy:before,\n.fa-files-o:before {\n  content: \"\\f0c5\";\n}\n.fa-paperclip:before {\n  content: \"\\f0c6\";\n}\n.fa-save:before,\n.fa-floppy-o:before {\n  content: \"\\f0c7\";\n}\n.fa-square:before {\n  content: \"\\f0c8\";\n}\n.fa-navicon:before,\n.fa-reorder:before,\n.fa-bars:before {\n  content: \"\\f0c9\";\n}\n.fa-list-ul:before {\n  content: \"\\f0ca\";\n}\n.fa-list-ol:before {\n  content: \"\\f0cb\";\n}\n.fa-strikethrough:before {\n  content: \"\\f0cc\";\n}\n.fa-underline:before {\n  content: \"\\f0cd\";\n}\n.fa-table:before {\n  content: \"\\f0ce\";\n}\n.fa-magic:before {\n  content: \"\\f0d0\";\n}\n.fa-truck:before {\n  content: \"\\f0d1\";\n}\n.fa-pinterest:before {\n  content: \"\\f0d2\";\n}\n.fa-pinterest-square:before {\n  content: \"\\f0d3\";\n}\n.fa-google-plus-square:before {\n  content: \"\\f0d4\";\n}\n.fa-google-plus:before {\n  content: \"\\f0d5\";\n}\n.fa-money:before {\n  content: \"\\f0d6\";\n}\n.fa-caret-down:before {\n  content: \"\\f0d7\";\n}\n.fa-caret-up:before {\n  content: \"\\f0d8\";\n}\n.fa-caret-left:before {\n  content: \"\\f0d9\";\n}\n.fa-caret-right:before {\n  content: \"\\f0da\";\n}\n.fa-columns:before {\n  content: \"\\f0db\";\n}\n.fa-unsorted:before,\n.fa-sort:before {\n  content: \"\\f0dc\";\n}\n.fa-sort-down:before,\n.fa-sort-desc:before {\n  content: \"\\f0dd\";\n}\n.fa-sort-up:before,\n.fa-sort-asc:before {\n  content: \"\\f0de\";\n}\n.fa-envelope:before {\n  content: \"\\f0e0\";\n}\n.fa-linkedin:before {\n  content: \"\\f0e1\";\n}\n.fa-rotate-left:before,\n.fa-undo:before {\n  content: \"\\f0e2\";\n}\n.fa-legal:before,\n.fa-gavel:before {\n  content: \"\\f0e3\";\n}\n.fa-dashboard:before,\n.fa-tachometer:before {\n  content: \"\\f0e4\";\n}\n.fa-comment-o:before {\n  content: \"\\f0e5\";\n}\n.fa-comments-o:before {\n  content: \"\\f0e6\";\n}\n.fa-flash:before,\n.fa-bolt:before {\n  content: \"\\f0e7\";\n}\n.fa-sitemap:before {\n  content: \"\\f0e8\";\n}\n.fa-umbrella:before {\n  content: \"\\f0e9\";\n}\n.fa-paste:before,\n.fa-clipboard:before {\n  content: \"\\f0ea\";\n}\n.fa-lightbulb-o:before {\n  content: \"\\f0eb\";\n}\n.fa-exchange:before {\n  content: \"\\f0ec\";\n}\n.fa-cloud-download:before {\n  content: \"\\f0ed\";\n}\n.fa-cloud-upload:before {\n  content: \"\\f0ee\";\n}\n.fa-user-md:before {\n  content: \"\\f0f0\";\n}\n.fa-stethoscope:before {\n  content: \"\\f0f1\";\n}\n.fa-suitcase:before {\n  content: \"\\f0f2\";\n}\n.fa-bell-o:before {\n  content: \"\\f0a2\";\n}\n.fa-coffee:before {\n  content: \"\\f0f4\";\n}\n.fa-cutlery:before {\n  content: \"\\f0f5\";\n}\n.fa-file-text-o:before {\n  content: \"\\f0f6\";\n}\n.fa-building-o:before {\n  content: \"\\f0f7\";\n}\n.fa-hospital-o:before {\n  content: \"\\f0f8\";\n}\n.fa-ambulance:before {\n  content: \"\\f0f9\";\n}\n.fa-medkit:before {\n  content: \"\\f0fa\";\n}\n.fa-fighter-jet:before {\n  content: \"\\f0fb\";\n}\n.fa-beer:before {\n  content: \"\\f0fc\";\n}\n.fa-h-square:before {\n  content: \"\\f0fd\";\n}\n.fa-plus-square:before {\n  content: \"\\f0fe\";\n}\n.fa-angle-double-left:before {\n  content: \"\\f100\";\n}\n.fa-angle-double-right:before {\n  content: \"\\f101\";\n}\n.fa-angle-double-up:before {\n  content: \"\\f102\";\n}\n.fa-angle-double-down:before {\n  content: \"\\f103\";\n}\n.fa-angle-left:before {\n  content: \"\\f104\";\n}\n.fa-angle-right:before {\n  content: \"\\f105\";\n}\n.fa-angle-up:before {\n  content: \"\\f106\";\n}\n.fa-angle-down:before {\n  content: \"\\f107\";\n}\n.fa-desktop:before {\n  content: \"\\f108\";\n}\n.fa-laptop:before {\n  content: \"\\f109\";\n}\n.fa-tablet:before {\n  content: \"\\f10a\";\n}\n.fa-mobile-phone:before,\n.fa-mobile:before {\n  content: \"\\f10b\";\n}\n.fa-circle-o:before {\n  content: \"\\f10c\";\n}\n.fa-quote-left:before {\n  content: \"\\f10d\";\n}\n.fa-quote-right:before {\n  content: \"\\f10e\";\n}\n.fa-spinner:before {\n  content: \"\\f110\";\n}\n.fa-circle:before {\n  content: \"\\f111\";\n}\n.fa-mail-reply:before,\n.fa-reply:before {\n  content: \"\\f112\";\n}\n.fa-github-alt:before {\n  content: \"\\f113\";\n}\n.fa-folder-o:before {\n  content: \"\\f114\";\n}\n.fa-folder-open-o:before {\n  content: \"\\f115\";\n}\n.fa-smile-o:before {\n  content: \"\\f118\";\n}\n.fa-frown-o:before {\n  content: \"\\f119\";\n}\n.fa-meh-o:before {\n  content: \"\\f11a\";\n}\n.fa-gamepad:before {\n  content: \"\\f11b\";\n}\n.fa-keyboard-o:before {\n  content: \"\\f11c\";\n}\n.fa-flag-o:before {\n  content: \"\\f11d\";\n}\n.fa-flag-checkered:before {\n  content: \"\\f11e\";\n}\n.fa-terminal:before {\n  content: \"\\f120\";\n}\n.fa-code:before {\n  content: \"\\f121\";\n}\n.fa-mail-reply-all:before,\n.fa-reply-all:before {\n  content: \"\\f122\";\n}\n.fa-star-half-empty:before,\n.fa-star-half-full:before,\n.fa-star-half-o:before {\n  content: \"\\f123\";\n}\n.fa-location-arrow:before {\n  content: \"\\f124\";\n}\n.fa-crop:before {\n  content: \"\\f125\";\n}\n.fa-code-fork:before {\n  content: \"\\f126\";\n}\n.fa-unlink:before,\n.fa-chain-broken:before {\n  content: \"\\f127\";\n}\n.fa-question:before {\n  content: \"\\f128\";\n}\n.fa-info:before {\n  content: \"\\f129\";\n}\n.fa-exclamation:before {\n  content: \"\\f12a\";\n}\n.fa-superscript:before {\n  content: \"\\f12b\";\n}\n.fa-subscript:before {\n  content: \"\\f12c\";\n}\n.fa-eraser:before {\n  content: \"\\f12d\";\n}\n.fa-puzzle-piece:before {\n  content: \"\\f12e\";\n}\n.fa-microphone:before {\n  content: \"\\f130\";\n}\n.fa-microphone-slash:before {\n  content: \"\\f131\";\n}\n.fa-shield:before {\n  content: \"\\f132\";\n}\n.fa-calendar-o:before {\n  content: \"\\f133\";\n}\n.fa-fire-extinguisher:before {\n  content: \"\\f134\";\n}\n.fa-rocket:before {\n  content: \"\\f135\";\n}\n.fa-maxcdn:before {\n  content: \"\\f136\";\n}\n.fa-chevron-circle-left:before {\n  content: \"\\f137\";\n}\n.fa-chevron-circle-right:before {\n  content: \"\\f138\";\n}\n.fa-chevron-circle-up:before {\n  content: \"\\f139\";\n}\n.fa-chevron-circle-down:before {\n  content: \"\\f13a\";\n}\n.fa-html5:before {\n  content: \"\\f13b\";\n}\n.fa-css3:before {\n  content: \"\\f13c\";\n}\n.fa-anchor:before {\n  content: \"\\f13d\";\n}\n.fa-unlock-alt:before {\n  content: \"\\f13e\";\n}\n.fa-bullseye:before {\n  content: \"\\f140\";\n}\n.fa-ellipsis-h:before {\n  content: \"\\f141\";\n}\n.fa-ellipsis-v:before {\n  content: \"\\f142\";\n}\n.fa-rss-square:before {\n  content: \"\\f143\";\n}\n.fa-play-circle:before {\n  content: \"\\f144\";\n}\n.fa-ticket:before {\n  content: \"\\f145\";\n}\n.fa-minus-square:before {\n  content: \"\\f146\";\n}\n.fa-minus-square-o:before {\n  content: \"\\f147\";\n}\n.fa-level-up:before {\n  content: \"\\f148\";\n}\n.fa-level-down:before {\n  content: \"\\f149\";\n}\n.fa-check-square:before {\n  content: \"\\f14a\";\n}\n.fa-pencil-square:before {\n  content: \"\\f14b\";\n}\n.fa-external-link-square:before {\n  content: \"\\f14c\";\n}\n.fa-share-square:before {\n  content: \"\\f14d\";\n}\n.fa-compass:before {\n  content: \"\\f14e\";\n}\n.fa-toggle-down:before,\n.fa-caret-square-o-down:before {\n  content: \"\\f150\";\n}\n.fa-toggle-up:before,\n.fa-caret-square-o-up:before {\n  content: \"\\f151\";\n}\n.fa-toggle-right:before,\n.fa-caret-square-o-right:before {\n  content: \"\\f152\";\n}\n.fa-euro:before,\n.fa-eur:before {\n  content: \"\\f153\";\n}\n.fa-gbp:before {\n  content: \"\\f154\";\n}\n.fa-dollar:before,\n.fa-usd:before {\n  content: \"\\f155\";\n}\n.fa-rupee:before,\n.fa-inr:before {\n  content: \"\\f156\";\n}\n.fa-cny:before,\n.fa-rmb:before,\n.fa-yen:before,\n.fa-jpy:before {\n  content: \"\\f157\";\n}\n.fa-ruble:before,\n.fa-rouble:before,\n.fa-rub:before {\n  content: \"\\f158\";\n}\n.fa-won:before,\n.fa-krw:before {\n  content: \"\\f159\";\n}\n.fa-bitcoin:before,\n.fa-btc:before {\n  content: \"\\f15a\";\n}\n.fa-file:before {\n  content: \"\\f15b\";\n}\n.fa-file-text:before {\n  content: \"\\f15c\";\n}\n.fa-sort-alpha-asc:before {\n  content: \"\\f15d\";\n}\n.fa-sort-alpha-desc:before {\n  content: \"\\f15e\";\n}\n.fa-sort-amount-asc:before {\n  content: \"\\f160\";\n}\n.fa-sort-amount-desc:before {\n  content: \"\\f161\";\n}\n.fa-sort-numeric-asc:before {\n  content: \"\\f162\";\n}\n.fa-sort-numeric-desc:before {\n  content: \"\\f163\";\n}\n.fa-thumbs-up:before {\n  content: \"\\f164\";\n}\n.fa-thumbs-down:before {\n  content: \"\\f165\";\n}\n.fa-youtube-square:before {\n  content: \"\\f166\";\n}\n.fa-youtube:before {\n  content: \"\\f167\";\n}\n.fa-xing:before {\n  content: \"\\f168\";\n}\n.fa-xing-square:before {\n  content: \"\\f169\";\n}\n.fa-youtube-play:before {\n  content: \"\\f16a\";\n}\n.fa-dropbox:before {\n  content: \"\\f16b\";\n}\n.fa-stack-overflow:before {\n  content: \"\\f16c\";\n}\n.fa-instagram:before {\n  content: \"\\f16d\";\n}\n.fa-flickr:before {\n  content: \"\\f16e\";\n}\n.fa-adn:before {\n  content: \"\\f170\";\n}\n.fa-bitbucket:before {\n  content: \"\\f171\";\n}\n.fa-bitbucket-square:before {\n  content: \"\\f172\";\n}\n.fa-tumblr:before {\n  content: \"\\f173\";\n}\n.fa-tumblr-square:before {\n  content: \"\\f174\";\n}\n.fa-long-arrow-down:before {\n  content: \"\\f175\";\n}\n.fa-long-arrow-up:before {\n  content: \"\\f176\";\n}\n.fa-long-arrow-left:before {\n  content: \"\\f177\";\n}\n.fa-long-arrow-right:before {\n  content: \"\\f178\";\n}\n.fa-apple:before {\n  content: \"\\f179\";\n}\n.fa-windows:before {\n  content: \"\\f17a\";\n}\n.fa-android:before {\n  content: \"\\f17b\";\n}\n.fa-linux:before {\n  content: \"\\f17c\";\n}\n.fa-dribbble:before {\n  content: \"\\f17d\";\n}\n.fa-skype:before {\n  content: \"\\f17e\";\n}\n.fa-foursquare:before {\n  content: \"\\f180\";\n}\n.fa-trello:before {\n  content: \"\\f181\";\n}\n.fa-female:before {\n  content: \"\\f182\";\n}\n.fa-male:before {\n  content: \"\\f183\";\n}\n.fa-gittip:before,\n.fa-gratipay:before {\n  content: \"\\f184\";\n}\n.fa-sun-o:before {\n  content: \"\\f185\";\n}\n.fa-moon-o:before {\n  content: \"\\f186\";\n}\n.fa-archive:before {\n  content: \"\\f187\";\n}\n.fa-bug:before {\n  content: \"\\f188\";\n}\n.fa-vk:before {\n  content: \"\\f189\";\n}\n.fa-weibo:before {\n  content: \"\\f18a\";\n}\n.fa-renren:before {\n  content: \"\\f18b\";\n}\n.fa-pagelines:before {\n  content: \"\\f18c\";\n}\n.fa-stack-exchange:before {\n  content: \"\\f18d\";\n}\n.fa-arrow-circle-o-right:before {\n  content: \"\\f18e\";\n}\n.fa-arrow-circle-o-left:before {\n  content: \"\\f190\";\n}\n.fa-toggle-left:before,\n.fa-caret-square-o-left:before {\n  content: \"\\f191\";\n}\n.fa-dot-circle-o:before {\n  content: \"\\f192\";\n}\n.fa-wheelchair:before {\n  content: \"\\f193\";\n}\n.fa-vimeo-square:before {\n  content: \"\\f194\";\n}\n.fa-turkish-lira:before,\n.fa-try:before {\n  content: \"\\f195\";\n}\n.fa-plus-square-o:before {\n  content: \"\\f196\";\n}\n.fa-space-shuttle:before {\n  content: \"\\f197\";\n}\n.fa-slack:before {\n  content: \"\\f198\";\n}\n.fa-envelope-square:before {\n  content: \"\\f199\";\n}\n.fa-wordpress:before {\n  content: \"\\f19a\";\n}\n.fa-openid:before {\n  content: \"\\f19b\";\n}\n.fa-institution:before,\n.fa-bank:before,\n.fa-university:before {\n  content: \"\\f19c\";\n}\n.fa-mortar-board:before,\n.fa-graduation-cap:before {\n  content: \"\\f19d\";\n}\n.fa-yahoo:before {\n  content: \"\\f19e\";\n}\n.fa-google:before {\n  content: \"\\f1a0\";\n}\n.fa-reddit:before {\n  content: \"\\f1a1\";\n}\n.fa-reddit-square:before {\n  content: \"\\f1a2\";\n}\n.fa-stumbleupon-circle:before {\n  content: \"\\f1a3\";\n}\n.fa-stumbleupon:before {\n  content: \"\\f1a4\";\n}\n.fa-delicious:before {\n  content: \"\\f1a5\";\n}\n.fa-digg:before {\n  content: \"\\f1a6\";\n}\n.fa-pied-piper:before {\n  content: \"\\f1a7\";\n}\n.fa-pied-piper-alt:before {\n  content: \"\\f1a8\";\n}\n.fa-drupal:before {\n  content: \"\\f1a9\";\n}\n.fa-joomla:before {\n  content: \"\\f1aa\";\n}\n.fa-language:before {\n  content: \"\\f1ab\";\n}\n.fa-fax:before {\n  content: \"\\f1ac\";\n}\n.fa-building:before {\n  content: \"\\f1ad\";\n}\n.fa-child:before {\n  content: \"\\f1ae\";\n}\n.fa-paw:before {\n  content: \"\\f1b0\";\n}\n.fa-spoon:before {\n  content: \"\\f1b1\";\n}\n.fa-cube:before {\n  content: \"\\f1b2\";\n}\n.fa-cubes:before {\n  content: \"\\f1b3\";\n}\n.fa-behance:before {\n  content: \"\\f1b4\";\n}\n.fa-behance-square:before {\n  content: \"\\f1b5\";\n}\n.fa-steam:before {\n  content: \"\\f1b6\";\n}\n.fa-steam-square:before {\n  content: \"\\f1b7\";\n}\n.fa-recycle:before {\n  content: \"\\f1b8\";\n}\n.fa-automobile:before,\n.fa-car:before {\n  content: \"\\f1b9\";\n}\n.fa-cab:before,\n.fa-taxi:before {\n  content: \"\\f1ba\";\n}\n.fa-tree:before {\n  content: \"\\f1bb\";\n}\n.fa-spotify:before {\n  content: \"\\f1bc\";\n}\n.fa-deviantart:before {\n  content: \"\\f1bd\";\n}\n.fa-soundcloud:before {\n  content: \"\\f1be\";\n}\n.fa-database:before {\n  content: \"\\f1c0\";\n}\n.fa-file-pdf-o:before {\n  content: \"\\f1c1\";\n}\n.fa-file-word-o:before {\n  content: \"\\f1c2\";\n}\n.fa-file-excel-o:before {\n  content: \"\\f1c3\";\n}\n.fa-file-powerpoint-o:before {\n  content: \"\\f1c4\";\n}\n.fa-file-photo-o:before,\n.fa-file-picture-o:before,\n.fa-file-image-o:before {\n  content: \"\\f1c5\";\n}\n.fa-file-zip-o:before,\n.fa-file-archive-o:before {\n  content: \"\\f1c6\";\n}\n.fa-file-sound-o:before,\n.fa-file-audio-o:before {\n  content: \"\\f1c7\";\n}\n.fa-file-movie-o:before,\n.fa-file-video-o:before {\n  content: \"\\f1c8\";\n}\n.fa-file-code-o:before {\n  content: \"\\f1c9\";\n}\n.fa-vine:before {\n  content: \"\\f1ca\";\n}\n.fa-codepen:before {\n  content: \"\\f1cb\";\n}\n.fa-jsfiddle:before {\n  content: \"\\f1cc\";\n}\n.fa-life-bouy:before,\n.fa-life-buoy:before,\n.fa-life-saver:before,\n.fa-support:before,\n.fa-life-ring:before {\n  content: \"\\f1cd\";\n}\n.fa-circle-o-notch:before {\n  content: \"\\f1ce\";\n}\n.fa-ra:before,\n.fa-rebel:before {\n  content: \"\\f1d0\";\n}\n.fa-ge:before,\n.fa-empire:before {\n  content: \"\\f1d1\";\n}\n.fa-git-square:before {\n  content: \"\\f1d2\";\n}\n.fa-git:before {\n  content: \"\\f1d3\";\n}\n.fa-y-combinator-square:before,\n.fa-yc-square:before,\n.fa-hacker-news:before {\n  content: \"\\f1d4\";\n}\n.fa-tencent-weibo:before {\n  content: \"\\f1d5\";\n}\n.fa-qq:before {\n  content: \"\\f1d6\";\n}\n.fa-wechat:before,\n.fa-weixin:before {\n  content: \"\\f1d7\";\n}\n.fa-send:before,\n.fa-paper-plane:before {\n  content: \"\\f1d8\";\n}\n.fa-send-o:before,\n.fa-paper-plane-o:before {\n  content: \"\\f1d9\";\n}\n.fa-history:before {\n  content: \"\\f1da\";\n}\n.fa-circle-thin:before {\n  content: \"\\f1db\";\n}\n.fa-header:before {\n  content: \"\\f1dc\";\n}\n.fa-paragraph:before {\n  content: \"\\f1dd\";\n}\n.fa-sliders:before {\n  content: \"\\f1de\";\n}\n.fa-share-alt:before {\n  content: \"\\f1e0\";\n}\n.fa-share-alt-square:before {\n  content: \"\\f1e1\";\n}\n.fa-bomb:before {\n  content: \"\\f1e2\";\n}\n.fa-soccer-ball-o:before,\n.fa-futbol-o:before {\n  content: \"\\f1e3\";\n}\n.fa-tty:before {\n  content: \"\\f1e4\";\n}\n.fa-binoculars:before {\n  content: \"\\f1e5\";\n}\n.fa-plug:before {\n  content: \"\\f1e6\";\n}\n.fa-slideshare:before {\n  content: \"\\f1e7\";\n}\n.fa-twitch:before {\n  content: \"\\f1e8\";\n}\n.fa-yelp:before {\n  content: \"\\f1e9\";\n}\n.fa-newspaper-o:before {\n  content: \"\\f1ea\";\n}\n.fa-wifi:before {\n  content: \"\\f1eb\";\n}\n.fa-calculator:before {\n  content: \"\\f1ec\";\n}\n.fa-paypal:before {\n  content: \"\\f1ed\";\n}\n.fa-google-wallet:before {\n  content: \"\\f1ee\";\n}\n.fa-cc-visa:before {\n  content: \"\\f1f0\";\n}\n.fa-cc-mastercard:before {\n  content: \"\\f1f1\";\n}\n.fa-cc-discover:before {\n  content: \"\\f1f2\";\n}\n.fa-cc-amex:before {\n  content: \"\\f1f3\";\n}\n.fa-cc-paypal:before {\n  content: \"\\f1f4\";\n}\n.fa-cc-stripe:before {\n  content: \"\\f1f5\";\n}\n.fa-bell-slash:before {\n  content: \"\\f1f6\";\n}\n.fa-bell-slash-o:before {\n  content: \"\\f1f7\";\n}\n.fa-trash:before {\n  content: \"\\f1f8\";\n}\n.fa-copyright:before {\n  content: \"\\f1f9\";\n}\n.fa-at:before {\n  content: \"\\f1fa\";\n}\n.fa-eyedropper:before {\n  content: \"\\f1fb\";\n}\n.fa-paint-brush:before {\n  content: \"\\f1fc\";\n}\n.fa-birthday-cake:before {\n  content: \"\\f1fd\";\n}\n.fa-area-chart:before {\n  content: \"\\f1fe\";\n}\n.fa-pie-chart:before {\n  content: \"\\f200\";\n}\n.fa-line-chart:before {\n  content: \"\\f201\";\n}\n.fa-lastfm:before {\n  content: \"\\f202\";\n}\n.fa-lastfm-square:before {\n  content: \"\\f203\";\n}\n.fa-toggle-off:before {\n  content: \"\\f204\";\n}\n.fa-toggle-on:before {\n  content: \"\\f205\";\n}\n.fa-bicycle:before {\n  content: \"\\f206\";\n}\n.fa-bus:before {\n  content: \"\\f207\";\n}\n.fa-ioxhost:before {\n  content: \"\\f208\";\n}\n.fa-angellist:before {\n  content: \"\\f209\";\n}\n.fa-cc:before {\n  content: \"\\f20a\";\n}\n.fa-shekel:before,\n.fa-sheqel:before,\n.fa-ils:before {\n  content: \"\\f20b\";\n}\n.fa-meanpath:before {\n  content: \"\\f20c\";\n}\n.fa-buysellads:before {\n  content: \"\\f20d\";\n}\n.fa-connectdevelop:before {\n  content: \"\\f20e\";\n}\n.fa-dashcube:before {\n  content: \"\\f210\";\n}\n.fa-forumbee:before {\n  content: \"\\f211\";\n}\n.fa-leanpub:before {\n  content: \"\\f212\";\n}\n.fa-sellsy:before {\n  content: \"\\f213\";\n}\n.fa-shirtsinbulk:before {\n  content: \"\\f214\";\n}\n.fa-simplybuilt:before {\n  content: \"\\f215\";\n}\n.fa-skyatlas:before {\n  content: \"\\f216\";\n}\n.fa-cart-plus:before {\n  content: \"\\f217\";\n}\n.fa-cart-arrow-down:before {\n  content: \"\\f218\";\n}\n.fa-diamond:before {\n  content: \"\\f219\";\n}\n.fa-ship:before {\n  content: \"\\f21a\";\n}\n.fa-user-secret:before {\n  content: \"\\f21b\";\n}\n.fa-motorcycle:before {\n  content: \"\\f21c\";\n}\n.fa-street-view:before {\n  content: \"\\f21d\";\n}\n.fa-heartbeat:before {\n  content: \"\\f21e\";\n}\n.fa-venus:before {\n  content: \"\\f221\";\n}\n.fa-mars:before {\n  content: \"\\f222\";\n}\n.fa-mercury:before {\n  content: \"\\f223\";\n}\n.fa-intersex:before,\n.fa-transgender:before {\n  content: \"\\f224\";\n}\n.fa-transgender-alt:before {\n  content: \"\\f225\";\n}\n.fa-venus-double:before {\n  content: \"\\f226\";\n}\n.fa-mars-double:before {\n  content: \"\\f227\";\n}\n.fa-venus-mars:before {\n  content: \"\\f228\";\n}\n.fa-mars-stroke:before {\n  content: \"\\f229\";\n}\n.fa-mars-stroke-v:before {\n  content: \"\\f22a\";\n}\n.fa-mars-stroke-h:before {\n  content: \"\\f22b\";\n}\n.fa-neuter:before {\n  content: \"\\f22c\";\n}\n.fa-genderless:before {\n  content: \"\\f22d\";\n}\n.fa-facebook-official:before {\n  content: \"\\f230\";\n}\n.fa-pinterest-p:before {\n  content: \"\\f231\";\n}\n.fa-whatsapp:before {\n  content: \"\\f232\";\n}\n.fa-server:before {\n  content: \"\\f233\";\n}\n.fa-user-plus:before {\n  content: \"\\f234\";\n}\n.fa-user-times:before {\n  content: \"\\f235\";\n}\n.fa-hotel:before,\n.fa-bed:before {\n  content: \"\\f236\";\n}\n.fa-viacoin:before {\n  content: \"\\f237\";\n}\n.fa-train:before {\n  content: \"\\f238\";\n}\n.fa-subway:before {\n  content: \"\\f239\";\n}\n.fa-medium:before {\n  content: \"\\f23a\";\n}\n.fa-yc:before,\n.fa-y-combinator:before {\n  content: \"\\f23b\";\n}\n.fa-optin-monster:before {\n  content: \"\\f23c\";\n}\n.fa-opencart:before {\n  content: \"\\f23d\";\n}\n.fa-expeditedssl:before {\n  content: \"\\f23e\";\n}\n.fa-battery-4:before,\n.fa-battery-full:before {\n  content: \"\\f240\";\n}\n.fa-battery-3:before,\n.fa-battery-three-quarters:before {\n  content: \"\\f241\";\n}\n.fa-battery-2:before,\n.fa-battery-half:before {\n  content: \"\\f242\";\n}\n.fa-battery-1:before,\n.fa-battery-quarter:before {\n  content: \"\\f243\";\n}\n.fa-battery-0:before,\n.fa-battery-empty:before {\n  content: \"\\f244\";\n}\n.fa-mouse-pointer:before {\n  content: \"\\f245\";\n}\n.fa-i-cursor:before {\n  content: \"\\f246\";\n}\n.fa-object-group:before {\n  content: \"\\f247\";\n}\n.fa-object-ungroup:before {\n  content: \"\\f248\";\n}\n.fa-sticky-note:before {\n  content: \"\\f249\";\n}\n.fa-sticky-note-o:before {\n  content: \"\\f24a\";\n}\n.fa-cc-jcb:before {\n  content: \"\\f24b\";\n}\n.fa-cc-diners-club:before {\n  content: \"\\f24c\";\n}\n.fa-clone:before {\n  content: \"\\f24d\";\n}\n.fa-balance-scale:before {\n  content: \"\\f24e\";\n}\n.fa-hourglass-o:before {\n  content: \"\\f250\";\n}\n.fa-hourglass-1:before,\n.fa-hourglass-start:before {\n  content: \"\\f251\";\n}\n.fa-hourglass-2:before,\n.fa-hourglass-half:before {\n  content: \"\\f252\";\n}\n.fa-hourglass-3:before,\n.fa-hourglass-end:before {\n  content: \"\\f253\";\n}\n.fa-hourglass:before {\n  content: \"\\f254\";\n}\n.fa-hand-grab-o:before,\n.fa-hand-rock-o:before {\n  content: \"\\f255\";\n}\n.fa-hand-stop-o:before,\n.fa-hand-paper-o:before {\n  content: \"\\f256\";\n}\n.fa-hand-scissors-o:before {\n  content: \"\\f257\";\n}\n.fa-hand-lizard-o:before {\n  content: \"\\f258\";\n}\n.fa-hand-spock-o:before {\n  content: \"\\f259\";\n}\n.fa-hand-pointer-o:before {\n  content: \"\\f25a\";\n}\n.fa-hand-peace-o:before {\n  content: \"\\f25b\";\n}\n.fa-trademark:before {\n  content: \"\\f25c\";\n}\n.fa-registered:before {\n  content: \"\\f25d\";\n}\n.fa-creative-commons:before {\n  content: \"\\f25e\";\n}\n.fa-gg:before {\n  content: \"\\f260\";\n}\n.fa-gg-circle:before {\n  content: \"\\f261\";\n}\n.fa-tripadvisor:before {\n  content: \"\\f262\";\n}\n.fa-odnoklassniki:before {\n  content: \"\\f263\";\n}\n.fa-odnoklassniki-square:before {\n  content: \"\\f264\";\n}\n.fa-get-pocket:before {\n  content: \"\\f265\";\n}\n.fa-wikipedia-w:before {\n  content: \"\\f266\";\n}\n.fa-safari:before {\n  content: \"\\f267\";\n}\n.fa-chrome:before {\n  content: \"\\f268\";\n}\n.fa-firefox:before {\n  content: \"\\f269\";\n}\n.fa-opera:before {\n  content: \"\\f26a\";\n}\n.fa-internet-explorer:before {\n  content: \"\\f26b\";\n}\n.fa-tv:before,\n.fa-television:before {\n  content: \"\\f26c\";\n}\n.fa-contao:before {\n  content: \"\\f26d\";\n}\n.fa-500px:before {\n  content: \"\\f26e\";\n}\n.fa-amazon:before {\n  content: \"\\f270\";\n}\n.fa-calendar-plus-o:before {\n  content: \"\\f271\";\n}\n.fa-calendar-minus-o:before {\n  content: \"\\f272\";\n}\n.fa-calendar-times-o:before {\n  content: \"\\f273\";\n}\n.fa-calendar-check-o:before {\n  content: \"\\f274\";\n}\n.fa-industry:before {\n  content: \"\\f275\";\n}\n.fa-map-pin:before {\n  content: \"\\f276\";\n}\n.fa-map-signs:before {\n  content: \"\\f277\";\n}\n.fa-map-o:before {\n  content: \"\\f278\";\n}\n.fa-map:before {\n  content: \"\\f279\";\n}\n.fa-commenting:before {\n  content: \"\\f27a\";\n}\n.fa-commenting-o:before {\n  content: \"\\f27b\";\n}\n.fa-houzz:before {\n  content: \"\\f27c\";\n}\n.fa-vimeo:before {\n  content: \"\\f27d\";\n}\n.fa-black-tie:before {\n  content: \"\\f27e\";\n}\n.fa-fonticons:before {\n  content: \"\\f280\";\n}\n.fa-reddit-alien:before {\n  content: \"\\f281\";\n}\n.fa-edge:before {\n  content: \"\\f282\";\n}\n.fa-credit-card-alt:before {\n  content: \"\\f283\";\n}\n.fa-codiepie:before {\n  content: \"\\f284\";\n}\n.fa-modx:before {\n  content: \"\\f285\";\n}\n.fa-fort-awesome:before {\n  content: \"\\f286\";\n}\n.fa-usb:before {\n  content: \"\\f287\";\n}\n.fa-product-hunt:before {\n  content: \"\\f288\";\n}\n.fa-mixcloud:before {\n  content: \"\\f289\";\n}\n.fa-scribd:before {\n  content: \"\\f28a\";\n}\n.fa-pause-circle:before {\n  content: \"\\f28b\";\n}\n.fa-pause-circle-o:before {\n  content: \"\\f28c\";\n}\n.fa-stop-circle:before {\n  content: \"\\f28d\";\n}\n.fa-stop-circle-o:before {\n  content: \"\\f28e\";\n}\n.fa-shopping-bag:before {\n  content: \"\\f290\";\n}\n.fa-shopping-basket:before {\n  content: \"\\f291\";\n}\n.fa-hashtag:before {\n  content: \"\\f292\";\n}\n.fa-bluetooth:before {\n  content: \"\\f293\";\n}\n.fa-bluetooth-b:before {\n  content: \"\\f294\";\n}\n.fa-percent:before {\n  content: \"\\f295\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/animated.less",
    "content": "// Animated Icons\n// --------------------------\n\n.@{fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n.@{fa-css-prefix}-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n          animation: fa-spin 1s infinite steps(8);\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/bordered-pulled.less",
    "content": "// Bordered & Pulled\n// -------------------------\n\n.@{fa-css-prefix}-border {\n  padding: .2em .25em .15em;\n  border: solid .08em @fa-border-color;\n  border-radius: .1em;\n}\n\n.@{fa-css-prefix}-pull-left { float: left; }\n.@{fa-css-prefix}-pull-right { float: right; }\n\n.@{fa-css-prefix} {\n  &.@{fa-css-prefix}-pull-left { margin-right: .3em; }\n  &.@{fa-css-prefix}-pull-right { margin-left: .3em; }\n}\n\n/* Deprecated as of 4.4.0 */\n.pull-right { float: right; }\n.pull-left { float: left; }\n\n.@{fa-css-prefix} {\n  &.pull-left { margin-right: .3em; }\n  &.pull-right { margin-left: .3em; }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/core.less",
    "content": "// Base Class Definition\n// -------------------------\n\n.@{fa-css-prefix} {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/@fa-line-height-base FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/extras.less",
    "content": "// Extras\n// --------------------------\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/fixed-width.less",
    "content": "// Fixed Width Icons\n// -------------------------\n.@{fa-css-prefix}-fw {\n  width: (18em / 14);\n  text-align: center;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/font-awesome.less",
    "content": "/*!\n *  Font Awesome 4.5.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n\n@import \"variables.less\";\n@import \"mixins.less\";\n@import \"path.less\";\n@import \"core.less\";\n@import \"larger.less\";\n@import \"fixed-width.less\";\n@import \"list.less\";\n@import \"bordered-pulled.less\";\n@import \"animated.less\";\n@import \"rotated-flipped.less\";\n@import \"stacked.less\";\n@import \"icons.less\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/icons.less",
    "content": "/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n\n.@{fa-css-prefix}-glass:before { content: @fa-var-glass; }\n.@{fa-css-prefix}-music:before { content: @fa-var-music; }\n.@{fa-css-prefix}-search:before { content: @fa-var-search; }\n.@{fa-css-prefix}-envelope-o:before { content: @fa-var-envelope-o; }\n.@{fa-css-prefix}-heart:before { content: @fa-var-heart; }\n.@{fa-css-prefix}-star:before { content: @fa-var-star; }\n.@{fa-css-prefix}-star-o:before { content: @fa-var-star-o; }\n.@{fa-css-prefix}-user:before { content: @fa-var-user; }\n.@{fa-css-prefix}-film:before { content: @fa-var-film; }\n.@{fa-css-prefix}-th-large:before { content: @fa-var-th-large; }\n.@{fa-css-prefix}-th:before { content: @fa-var-th; }\n.@{fa-css-prefix}-th-list:before { content: @fa-var-th-list; }\n.@{fa-css-prefix}-check:before { content: @fa-var-check; }\n.@{fa-css-prefix}-remove:before,\n.@{fa-css-prefix}-close:before,\n.@{fa-css-prefix}-times:before { content: @fa-var-times; }\n.@{fa-css-prefix}-search-plus:before { content: @fa-var-search-plus; }\n.@{fa-css-prefix}-search-minus:before { content: @fa-var-search-minus; }\n.@{fa-css-prefix}-power-off:before { content: @fa-var-power-off; }\n.@{fa-css-prefix}-signal:before { content: @fa-var-signal; }\n.@{fa-css-prefix}-gear:before,\n.@{fa-css-prefix}-cog:before { content: @fa-var-cog; }\n.@{fa-css-prefix}-trash-o:before { content: @fa-var-trash-o; }\n.@{fa-css-prefix}-home:before { content: @fa-var-home; }\n.@{fa-css-prefix}-file-o:before { content: @fa-var-file-o; }\n.@{fa-css-prefix}-clock-o:before { content: @fa-var-clock-o; }\n.@{fa-css-prefix}-road:before { content: @fa-var-road; }\n.@{fa-css-prefix}-download:before { content: @fa-var-download; }\n.@{fa-css-prefix}-arrow-circle-o-down:before { content: @fa-var-arrow-circle-o-down; }\n.@{fa-css-prefix}-arrow-circle-o-up:before { content: @fa-var-arrow-circle-o-up; }\n.@{fa-css-prefix}-inbox:before { content: @fa-var-inbox; }\n.@{fa-css-prefix}-play-circle-o:before { content: @fa-var-play-circle-o; }\n.@{fa-css-prefix}-rotate-right:before,\n.@{fa-css-prefix}-repeat:before { content: @fa-var-repeat; }\n.@{fa-css-prefix}-refresh:before { content: @fa-var-refresh; }\n.@{fa-css-prefix}-list-alt:before { content: @fa-var-list-alt; }\n.@{fa-css-prefix}-lock:before { content: @fa-var-lock; }\n.@{fa-css-prefix}-flag:before { content: @fa-var-flag; }\n.@{fa-css-prefix}-headphones:before { content: @fa-var-headphones; }\n.@{fa-css-prefix}-volume-off:before { content: @fa-var-volume-off; }\n.@{fa-css-prefix}-volume-down:before { content: @fa-var-volume-down; }\n.@{fa-css-prefix}-volume-up:before { content: @fa-var-volume-up; }\n.@{fa-css-prefix}-qrcode:before { content: @fa-var-qrcode; }\n.@{fa-css-prefix}-barcode:before { content: @fa-var-barcode; }\n.@{fa-css-prefix}-tag:before { content: @fa-var-tag; }\n.@{fa-css-prefix}-tags:before { content: @fa-var-tags; }\n.@{fa-css-prefix}-book:before { content: @fa-var-book; }\n.@{fa-css-prefix}-bookmark:before { content: @fa-var-bookmark; }\n.@{fa-css-prefix}-print:before { content: @fa-var-print; }\n.@{fa-css-prefix}-camera:before { content: @fa-var-camera; }\n.@{fa-css-prefix}-font:before { content: @fa-var-font; }\n.@{fa-css-prefix}-bold:before { content: @fa-var-bold; }\n.@{fa-css-prefix}-italic:before { content: @fa-var-italic; }\n.@{fa-css-prefix}-text-height:before { content: @fa-var-text-height; }\n.@{fa-css-prefix}-text-width:before { content: @fa-var-text-width; }\n.@{fa-css-prefix}-align-left:before { content: @fa-var-align-left; }\n.@{fa-css-prefix}-align-center:before { content: @fa-var-align-center; }\n.@{fa-css-prefix}-align-right:before { content: @fa-var-align-right; }\n.@{fa-css-prefix}-align-justify:before { content: @fa-var-align-justify; }\n.@{fa-css-prefix}-list:before { content: @fa-var-list; }\n.@{fa-css-prefix}-dedent:before,\n.@{fa-css-prefix}-outdent:before { content: @fa-var-outdent; }\n.@{fa-css-prefix}-indent:before { content: @fa-var-indent; }\n.@{fa-css-prefix}-video-camera:before { content: @fa-var-video-camera; }\n.@{fa-css-prefix}-photo:before,\n.@{fa-css-prefix}-image:before,\n.@{fa-css-prefix}-picture-o:before { content: @fa-var-picture-o; }\n.@{fa-css-prefix}-pencil:before { content: @fa-var-pencil; }\n.@{fa-css-prefix}-map-marker:before { content: @fa-var-map-marker; }\n.@{fa-css-prefix}-adjust:before { content: @fa-var-adjust; }\n.@{fa-css-prefix}-tint:before { content: @fa-var-tint; }\n.@{fa-css-prefix}-edit:before,\n.@{fa-css-prefix}-pencil-square-o:before { content: @fa-var-pencil-square-o; }\n.@{fa-css-prefix}-share-square-o:before { content: @fa-var-share-square-o; }\n.@{fa-css-prefix}-check-square-o:before { content: @fa-var-check-square-o; }\n.@{fa-css-prefix}-arrows:before { content: @fa-var-arrows; }\n.@{fa-css-prefix}-step-backward:before { content: @fa-var-step-backward; }\n.@{fa-css-prefix}-fast-backward:before { content: @fa-var-fast-backward; }\n.@{fa-css-prefix}-backward:before { content: @fa-var-backward; }\n.@{fa-css-prefix}-play:before { content: @fa-var-play; }\n.@{fa-css-prefix}-pause:before { content: @fa-var-pause; }\n.@{fa-css-prefix}-stop:before { content: @fa-var-stop; }\n.@{fa-css-prefix}-forward:before { content: @fa-var-forward; }\n.@{fa-css-prefix}-fast-forward:before { content: @fa-var-fast-forward; }\n.@{fa-css-prefix}-step-forward:before { content: @fa-var-step-forward; }\n.@{fa-css-prefix}-eject:before { content: @fa-var-eject; }\n.@{fa-css-prefix}-chevron-left:before { content: @fa-var-chevron-left; }\n.@{fa-css-prefix}-chevron-right:before { content: @fa-var-chevron-right; }\n.@{fa-css-prefix}-plus-circle:before { content: @fa-var-plus-circle; }\n.@{fa-css-prefix}-minus-circle:before { content: @fa-var-minus-circle; }\n.@{fa-css-prefix}-times-circle:before { content: @fa-var-times-circle; }\n.@{fa-css-prefix}-check-circle:before { content: @fa-var-check-circle; }\n.@{fa-css-prefix}-question-circle:before { content: @fa-var-question-circle; }\n.@{fa-css-prefix}-info-circle:before { content: @fa-var-info-circle; }\n.@{fa-css-prefix}-crosshairs:before { content: @fa-var-crosshairs; }\n.@{fa-css-prefix}-times-circle-o:before { content: @fa-var-times-circle-o; }\n.@{fa-css-prefix}-check-circle-o:before { content: @fa-var-check-circle-o; }\n.@{fa-css-prefix}-ban:before { content: @fa-var-ban; }\n.@{fa-css-prefix}-arrow-left:before { content: @fa-var-arrow-left; }\n.@{fa-css-prefix}-arrow-right:before { content: @fa-var-arrow-right; }\n.@{fa-css-prefix}-arrow-up:before { content: @fa-var-arrow-up; }\n.@{fa-css-prefix}-arrow-down:before { content: @fa-var-arrow-down; }\n.@{fa-css-prefix}-mail-forward:before,\n.@{fa-css-prefix}-share:before { content: @fa-var-share; }\n.@{fa-css-prefix}-expand:before { content: @fa-var-expand; }\n.@{fa-css-prefix}-compress:before { content: @fa-var-compress; }\n.@{fa-css-prefix}-plus:before { content: @fa-var-plus; }\n.@{fa-css-prefix}-minus:before { content: @fa-var-minus; }\n.@{fa-css-prefix}-asterisk:before { content: @fa-var-asterisk; }\n.@{fa-css-prefix}-exclamation-circle:before { content: @fa-var-exclamation-circle; }\n.@{fa-css-prefix}-gift:before { content: @fa-var-gift; }\n.@{fa-css-prefix}-leaf:before { content: @fa-var-leaf; }\n.@{fa-css-prefix}-fire:before { content: @fa-var-fire; }\n.@{fa-css-prefix}-eye:before { content: @fa-var-eye; }\n.@{fa-css-prefix}-eye-slash:before { content: @fa-var-eye-slash; }\n.@{fa-css-prefix}-warning:before,\n.@{fa-css-prefix}-exclamation-triangle:before { content: @fa-var-exclamation-triangle; }\n.@{fa-css-prefix}-plane:before { content: @fa-var-plane; }\n.@{fa-css-prefix}-calendar:before { content: @fa-var-calendar; }\n.@{fa-css-prefix}-random:before { content: @fa-var-random; }\n.@{fa-css-prefix}-comment:before { content: @fa-var-comment; }\n.@{fa-css-prefix}-magnet:before { content: @fa-var-magnet; }\n.@{fa-css-prefix}-chevron-up:before { content: @fa-var-chevron-up; }\n.@{fa-css-prefix}-chevron-down:before { content: @fa-var-chevron-down; }\n.@{fa-css-prefix}-retweet:before { content: @fa-var-retweet; }\n.@{fa-css-prefix}-shopping-cart:before { content: @fa-var-shopping-cart; }\n.@{fa-css-prefix}-folder:before { content: @fa-var-folder; }\n.@{fa-css-prefix}-folder-open:before { content: @fa-var-folder-open; }\n.@{fa-css-prefix}-arrows-v:before { content: @fa-var-arrows-v; }\n.@{fa-css-prefix}-arrows-h:before { content: @fa-var-arrows-h; }\n.@{fa-css-prefix}-bar-chart-o:before,\n.@{fa-css-prefix}-bar-chart:before { content: @fa-var-bar-chart; }\n.@{fa-css-prefix}-twitter-square:before { content: @fa-var-twitter-square; }\n.@{fa-css-prefix}-facebook-square:before { content: @fa-var-facebook-square; }\n.@{fa-css-prefix}-camera-retro:before { content: @fa-var-camera-retro; }\n.@{fa-css-prefix}-key:before { content: @fa-var-key; }\n.@{fa-css-prefix}-gears:before,\n.@{fa-css-prefix}-cogs:before { content: @fa-var-cogs; }\n.@{fa-css-prefix}-comments:before { content: @fa-var-comments; }\n.@{fa-css-prefix}-thumbs-o-up:before { content: @fa-var-thumbs-o-up; }\n.@{fa-css-prefix}-thumbs-o-down:before { content: @fa-var-thumbs-o-down; }\n.@{fa-css-prefix}-star-half:before { content: @fa-var-star-half; }\n.@{fa-css-prefix}-heart-o:before { content: @fa-var-heart-o; }\n.@{fa-css-prefix}-sign-out:before { content: @fa-var-sign-out; }\n.@{fa-css-prefix}-linkedin-square:before { content: @fa-var-linkedin-square; }\n.@{fa-css-prefix}-thumb-tack:before { content: @fa-var-thumb-tack; }\n.@{fa-css-prefix}-external-link:before { content: @fa-var-external-link; }\n.@{fa-css-prefix}-sign-in:before { content: @fa-var-sign-in; }\n.@{fa-css-prefix}-trophy:before { content: @fa-var-trophy; }\n.@{fa-css-prefix}-github-square:before { content: @fa-var-github-square; }\n.@{fa-css-prefix}-upload:before { content: @fa-var-upload; }\n.@{fa-css-prefix}-lemon-o:before { content: @fa-var-lemon-o; }\n.@{fa-css-prefix}-phone:before { content: @fa-var-phone; }\n.@{fa-css-prefix}-square-o:before { content: @fa-var-square-o; }\n.@{fa-css-prefix}-bookmark-o:before { content: @fa-var-bookmark-o; }\n.@{fa-css-prefix}-phone-square:before { content: @fa-var-phone-square; }\n.@{fa-css-prefix}-twitter:before { content: @fa-var-twitter; }\n.@{fa-css-prefix}-facebook-f:before,\n.@{fa-css-prefix}-facebook:before { content: @fa-var-facebook; }\n.@{fa-css-prefix}-github:before { content: @fa-var-github; }\n.@{fa-css-prefix}-unlock:before { content: @fa-var-unlock; }\n.@{fa-css-prefix}-credit-card:before { content: @fa-var-credit-card; }\n.@{fa-css-prefix}-feed:before,\n.@{fa-css-prefix}-rss:before { content: @fa-var-rss; }\n.@{fa-css-prefix}-hdd-o:before { content: @fa-var-hdd-o; }\n.@{fa-css-prefix}-bullhorn:before { content: @fa-var-bullhorn; }\n.@{fa-css-prefix}-bell:before { content: @fa-var-bell; }\n.@{fa-css-prefix}-certificate:before { content: @fa-var-certificate; }\n.@{fa-css-prefix}-hand-o-right:before { content: @fa-var-hand-o-right; }\n.@{fa-css-prefix}-hand-o-left:before { content: @fa-var-hand-o-left; }\n.@{fa-css-prefix}-hand-o-up:before { content: @fa-var-hand-o-up; }\n.@{fa-css-prefix}-hand-o-down:before { content: @fa-var-hand-o-down; }\n.@{fa-css-prefix}-arrow-circle-left:before { content: @fa-var-arrow-circle-left; }\n.@{fa-css-prefix}-arrow-circle-right:before { content: @fa-var-arrow-circle-right; }\n.@{fa-css-prefix}-arrow-circle-up:before { content: @fa-var-arrow-circle-up; }\n.@{fa-css-prefix}-arrow-circle-down:before { content: @fa-var-arrow-circle-down; }\n.@{fa-css-prefix}-globe:before { content: @fa-var-globe; }\n.@{fa-css-prefix}-wrench:before { content: @fa-var-wrench; }\n.@{fa-css-prefix}-tasks:before { content: @fa-var-tasks; }\n.@{fa-css-prefix}-filter:before { content: @fa-var-filter; }\n.@{fa-css-prefix}-briefcase:before { content: @fa-var-briefcase; }\n.@{fa-css-prefix}-arrows-alt:before { content: @fa-var-arrows-alt; }\n.@{fa-css-prefix}-group:before,\n.@{fa-css-prefix}-users:before { content: @fa-var-users; }\n.@{fa-css-prefix}-chain:before,\n.@{fa-css-prefix}-link:before { content: @fa-var-link; }\n.@{fa-css-prefix}-cloud:before { content: @fa-var-cloud; }\n.@{fa-css-prefix}-flask:before { content: @fa-var-flask; }\n.@{fa-css-prefix}-cut:before,\n.@{fa-css-prefix}-scissors:before { content: @fa-var-scissors; }\n.@{fa-css-prefix}-copy:before,\n.@{fa-css-prefix}-files-o:before { content: @fa-var-files-o; }\n.@{fa-css-prefix}-paperclip:before { content: @fa-var-paperclip; }\n.@{fa-css-prefix}-save:before,\n.@{fa-css-prefix}-floppy-o:before { content: @fa-var-floppy-o; }\n.@{fa-css-prefix}-square:before { content: @fa-var-square; }\n.@{fa-css-prefix}-navicon:before,\n.@{fa-css-prefix}-reorder:before,\n.@{fa-css-prefix}-bars:before { content: @fa-var-bars; }\n.@{fa-css-prefix}-list-ul:before { content: @fa-var-list-ul; }\n.@{fa-css-prefix}-list-ol:before { content: @fa-var-list-ol; }\n.@{fa-css-prefix}-strikethrough:before { content: @fa-var-strikethrough; }\n.@{fa-css-prefix}-underline:before { content: @fa-var-underline; }\n.@{fa-css-prefix}-table:before { content: @fa-var-table; }\n.@{fa-css-prefix}-magic:before { content: @fa-var-magic; }\n.@{fa-css-prefix}-truck:before { content: @fa-var-truck; }\n.@{fa-css-prefix}-pinterest:before { content: @fa-var-pinterest; }\n.@{fa-css-prefix}-pinterest-square:before { content: @fa-var-pinterest-square; }\n.@{fa-css-prefix}-google-plus-square:before { content: @fa-var-google-plus-square; }\n.@{fa-css-prefix}-google-plus:before { content: @fa-var-google-plus; }\n.@{fa-css-prefix}-money:before { content: @fa-var-money; }\n.@{fa-css-prefix}-caret-down:before { content: @fa-var-caret-down; }\n.@{fa-css-prefix}-caret-up:before { content: @fa-var-caret-up; }\n.@{fa-css-prefix}-caret-left:before { content: @fa-var-caret-left; }\n.@{fa-css-prefix}-caret-right:before { content: @fa-var-caret-right; }\n.@{fa-css-prefix}-columns:before { content: @fa-var-columns; }\n.@{fa-css-prefix}-unsorted:before,\n.@{fa-css-prefix}-sort:before { content: @fa-var-sort; }\n.@{fa-css-prefix}-sort-down:before,\n.@{fa-css-prefix}-sort-desc:before { content: @fa-var-sort-desc; }\n.@{fa-css-prefix}-sort-up:before,\n.@{fa-css-prefix}-sort-asc:before { content: @fa-var-sort-asc; }\n.@{fa-css-prefix}-envelope:before { content: @fa-var-envelope; }\n.@{fa-css-prefix}-linkedin:before { content: @fa-var-linkedin; }\n.@{fa-css-prefix}-rotate-left:before,\n.@{fa-css-prefix}-undo:before { content: @fa-var-undo; }\n.@{fa-css-prefix}-legal:before,\n.@{fa-css-prefix}-gavel:before { content: @fa-var-gavel; }\n.@{fa-css-prefix}-dashboard:before,\n.@{fa-css-prefix}-tachometer:before { content: @fa-var-tachometer; }\n.@{fa-css-prefix}-comment-o:before { content: @fa-var-comment-o; }\n.@{fa-css-prefix}-comments-o:before { content: @fa-var-comments-o; }\n.@{fa-css-prefix}-flash:before,\n.@{fa-css-prefix}-bolt:before { content: @fa-var-bolt; }\n.@{fa-css-prefix}-sitemap:before { content: @fa-var-sitemap; }\n.@{fa-css-prefix}-umbrella:before { content: @fa-var-umbrella; }\n.@{fa-css-prefix}-paste:before,\n.@{fa-css-prefix}-clipboard:before { content: @fa-var-clipboard; }\n.@{fa-css-prefix}-lightbulb-o:before { content: @fa-var-lightbulb-o; }\n.@{fa-css-prefix}-exchange:before { content: @fa-var-exchange; }\n.@{fa-css-prefix}-cloud-download:before { content: @fa-var-cloud-download; }\n.@{fa-css-prefix}-cloud-upload:before { content: @fa-var-cloud-upload; }\n.@{fa-css-prefix}-user-md:before { content: @fa-var-user-md; }\n.@{fa-css-prefix}-stethoscope:before { content: @fa-var-stethoscope; }\n.@{fa-css-prefix}-suitcase:before { content: @fa-var-suitcase; }\n.@{fa-css-prefix}-bell-o:before { content: @fa-var-bell-o; }\n.@{fa-css-prefix}-coffee:before { content: @fa-var-coffee; }\n.@{fa-css-prefix}-cutlery:before { content: @fa-var-cutlery; }\n.@{fa-css-prefix}-file-text-o:before { content: @fa-var-file-text-o; }\n.@{fa-css-prefix}-building-o:before { content: @fa-var-building-o; }\n.@{fa-css-prefix}-hospital-o:before { content: @fa-var-hospital-o; }\n.@{fa-css-prefix}-ambulance:before { content: @fa-var-ambulance; }\n.@{fa-css-prefix}-medkit:before { content: @fa-var-medkit; }\n.@{fa-css-prefix}-fighter-jet:before { content: @fa-var-fighter-jet; }\n.@{fa-css-prefix}-beer:before { content: @fa-var-beer; }\n.@{fa-css-prefix}-h-square:before { content: @fa-var-h-square; }\n.@{fa-css-prefix}-plus-square:before { content: @fa-var-plus-square; }\n.@{fa-css-prefix}-angle-double-left:before { content: @fa-var-angle-double-left; }\n.@{fa-css-prefix}-angle-double-right:before { content: @fa-var-angle-double-right; }\n.@{fa-css-prefix}-angle-double-up:before { content: @fa-var-angle-double-up; }\n.@{fa-css-prefix}-angle-double-down:before { content: @fa-var-angle-double-down; }\n.@{fa-css-prefix}-angle-left:before { content: @fa-var-angle-left; }\n.@{fa-css-prefix}-angle-right:before { content: @fa-var-angle-right; }\n.@{fa-css-prefix}-angle-up:before { content: @fa-var-angle-up; }\n.@{fa-css-prefix}-angle-down:before { content: @fa-var-angle-down; }\n.@{fa-css-prefix}-desktop:before { content: @fa-var-desktop; }\n.@{fa-css-prefix}-laptop:before { content: @fa-var-laptop; }\n.@{fa-css-prefix}-tablet:before { content: @fa-var-tablet; }\n.@{fa-css-prefix}-mobile-phone:before,\n.@{fa-css-prefix}-mobile:before { content: @fa-var-mobile; }\n.@{fa-css-prefix}-circle-o:before { content: @fa-var-circle-o; }\n.@{fa-css-prefix}-quote-left:before { content: @fa-var-quote-left; }\n.@{fa-css-prefix}-quote-right:before { content: @fa-var-quote-right; }\n.@{fa-css-prefix}-spinner:before { content: @fa-var-spinner; }\n.@{fa-css-prefix}-circle:before { content: @fa-var-circle; }\n.@{fa-css-prefix}-mail-reply:before,\n.@{fa-css-prefix}-reply:before { content: @fa-var-reply; }\n.@{fa-css-prefix}-github-alt:before { content: @fa-var-github-alt; }\n.@{fa-css-prefix}-folder-o:before { content: @fa-var-folder-o; }\n.@{fa-css-prefix}-folder-open-o:before { content: @fa-var-folder-open-o; }\n.@{fa-css-prefix}-smile-o:before { content: @fa-var-smile-o; }\n.@{fa-css-prefix}-frown-o:before { content: @fa-var-frown-o; }\n.@{fa-css-prefix}-meh-o:before { content: @fa-var-meh-o; }\n.@{fa-css-prefix}-gamepad:before { content: @fa-var-gamepad; }\n.@{fa-css-prefix}-keyboard-o:before { content: @fa-var-keyboard-o; }\n.@{fa-css-prefix}-flag-o:before { content: @fa-var-flag-o; }\n.@{fa-css-prefix}-flag-checkered:before { content: @fa-var-flag-checkered; }\n.@{fa-css-prefix}-terminal:before { content: @fa-var-terminal; }\n.@{fa-css-prefix}-code:before { content: @fa-var-code; }\n.@{fa-css-prefix}-mail-reply-all:before,\n.@{fa-css-prefix}-reply-all:before { content: @fa-var-reply-all; }\n.@{fa-css-prefix}-star-half-empty:before,\n.@{fa-css-prefix}-star-half-full:before,\n.@{fa-css-prefix}-star-half-o:before { content: @fa-var-star-half-o; }\n.@{fa-css-prefix}-location-arrow:before { content: @fa-var-location-arrow; }\n.@{fa-css-prefix}-crop:before { content: @fa-var-crop; }\n.@{fa-css-prefix}-code-fork:before { content: @fa-var-code-fork; }\n.@{fa-css-prefix}-unlink:before,\n.@{fa-css-prefix}-chain-broken:before { content: @fa-var-chain-broken; }\n.@{fa-css-prefix}-question:before { content: @fa-var-question; }\n.@{fa-css-prefix}-info:before { content: @fa-var-info; }\n.@{fa-css-prefix}-exclamation:before { content: @fa-var-exclamation; }\n.@{fa-css-prefix}-superscript:before { content: @fa-var-superscript; }\n.@{fa-css-prefix}-subscript:before { content: @fa-var-subscript; }\n.@{fa-css-prefix}-eraser:before { content: @fa-var-eraser; }\n.@{fa-css-prefix}-puzzle-piece:before { content: @fa-var-puzzle-piece; }\n.@{fa-css-prefix}-microphone:before { content: @fa-var-microphone; }\n.@{fa-css-prefix}-microphone-slash:before { content: @fa-var-microphone-slash; }\n.@{fa-css-prefix}-shield:before { content: @fa-var-shield; }\n.@{fa-css-prefix}-calendar-o:before { content: @fa-var-calendar-o; }\n.@{fa-css-prefix}-fire-extinguisher:before { content: @fa-var-fire-extinguisher; }\n.@{fa-css-prefix}-rocket:before { content: @fa-var-rocket; }\n.@{fa-css-prefix}-maxcdn:before { content: @fa-var-maxcdn; }\n.@{fa-css-prefix}-chevron-circle-left:before { content: @fa-var-chevron-circle-left; }\n.@{fa-css-prefix}-chevron-circle-right:before { content: @fa-var-chevron-circle-right; }\n.@{fa-css-prefix}-chevron-circle-up:before { content: @fa-var-chevron-circle-up; }\n.@{fa-css-prefix}-chevron-circle-down:before { content: @fa-var-chevron-circle-down; }\n.@{fa-css-prefix}-html5:before { content: @fa-var-html5; }\n.@{fa-css-prefix}-css3:before { content: @fa-var-css3; }\n.@{fa-css-prefix}-anchor:before { content: @fa-var-anchor; }\n.@{fa-css-prefix}-unlock-alt:before { content: @fa-var-unlock-alt; }\n.@{fa-css-prefix}-bullseye:before { content: @fa-var-bullseye; }\n.@{fa-css-prefix}-ellipsis-h:before { content: @fa-var-ellipsis-h; }\n.@{fa-css-prefix}-ellipsis-v:before { content: @fa-var-ellipsis-v; }\n.@{fa-css-prefix}-rss-square:before { content: @fa-var-rss-square; }\n.@{fa-css-prefix}-play-circle:before { content: @fa-var-play-circle; }\n.@{fa-css-prefix}-ticket:before { content: @fa-var-ticket; }\n.@{fa-css-prefix}-minus-square:before { content: @fa-var-minus-square; }\n.@{fa-css-prefix}-minus-square-o:before { content: @fa-var-minus-square-o; }\n.@{fa-css-prefix}-level-up:before { content: @fa-var-level-up; }\n.@{fa-css-prefix}-level-down:before { content: @fa-var-level-down; }\n.@{fa-css-prefix}-check-square:before { content: @fa-var-check-square; }\n.@{fa-css-prefix}-pencil-square:before { content: @fa-var-pencil-square; }\n.@{fa-css-prefix}-external-link-square:before { content: @fa-var-external-link-square; }\n.@{fa-css-prefix}-share-square:before { content: @fa-var-share-square; }\n.@{fa-css-prefix}-compass:before { content: @fa-var-compass; }\n.@{fa-css-prefix}-toggle-down:before,\n.@{fa-css-prefix}-caret-square-o-down:before { content: @fa-var-caret-square-o-down; }\n.@{fa-css-prefix}-toggle-up:before,\n.@{fa-css-prefix}-caret-square-o-up:before { content: @fa-var-caret-square-o-up; }\n.@{fa-css-prefix}-toggle-right:before,\n.@{fa-css-prefix}-caret-square-o-right:before { content: @fa-var-caret-square-o-right; }\n.@{fa-css-prefix}-euro:before,\n.@{fa-css-prefix}-eur:before { content: @fa-var-eur; }\n.@{fa-css-prefix}-gbp:before { content: @fa-var-gbp; }\n.@{fa-css-prefix}-dollar:before,\n.@{fa-css-prefix}-usd:before { content: @fa-var-usd; }\n.@{fa-css-prefix}-rupee:before,\n.@{fa-css-prefix}-inr:before { content: @fa-var-inr; }\n.@{fa-css-prefix}-cny:before,\n.@{fa-css-prefix}-rmb:before,\n.@{fa-css-prefix}-yen:before,\n.@{fa-css-prefix}-jpy:before { content: @fa-var-jpy; }\n.@{fa-css-prefix}-ruble:before,\n.@{fa-css-prefix}-rouble:before,\n.@{fa-css-prefix}-rub:before { content: @fa-var-rub; }\n.@{fa-css-prefix}-won:before,\n.@{fa-css-prefix}-krw:before { content: @fa-var-krw; }\n.@{fa-css-prefix}-bitcoin:before,\n.@{fa-css-prefix}-btc:before { content: @fa-var-btc; }\n.@{fa-css-prefix}-file:before { content: @fa-var-file; }\n.@{fa-css-prefix}-file-text:before { content: @fa-var-file-text; }\n.@{fa-css-prefix}-sort-alpha-asc:before { content: @fa-var-sort-alpha-asc; }\n.@{fa-css-prefix}-sort-alpha-desc:before { content: @fa-var-sort-alpha-desc; }\n.@{fa-css-prefix}-sort-amount-asc:before { content: @fa-var-sort-amount-asc; }\n.@{fa-css-prefix}-sort-amount-desc:before { content: @fa-var-sort-amount-desc; }\n.@{fa-css-prefix}-sort-numeric-asc:before { content: @fa-var-sort-numeric-asc; }\n.@{fa-css-prefix}-sort-numeric-desc:before { content: @fa-var-sort-numeric-desc; }\n.@{fa-css-prefix}-thumbs-up:before { content: @fa-var-thumbs-up; }\n.@{fa-css-prefix}-thumbs-down:before { content: @fa-var-thumbs-down; }\n.@{fa-css-prefix}-youtube-square:before { content: @fa-var-youtube-square; }\n.@{fa-css-prefix}-youtube:before { content: @fa-var-youtube; }\n.@{fa-css-prefix}-xing:before { content: @fa-var-xing; }\n.@{fa-css-prefix}-xing-square:before { content: @fa-var-xing-square; }\n.@{fa-css-prefix}-youtube-play:before { content: @fa-var-youtube-play; }\n.@{fa-css-prefix}-dropbox:before { content: @fa-var-dropbox; }\n.@{fa-css-prefix}-stack-overflow:before { content: @fa-var-stack-overflow; }\n.@{fa-css-prefix}-instagram:before { content: @fa-var-instagram; }\n.@{fa-css-prefix}-flickr:before { content: @fa-var-flickr; }\n.@{fa-css-prefix}-adn:before { content: @fa-var-adn; }\n.@{fa-css-prefix}-bitbucket:before { content: @fa-var-bitbucket; }\n.@{fa-css-prefix}-bitbucket-square:before { content: @fa-var-bitbucket-square; }\n.@{fa-css-prefix}-tumblr:before { content: @fa-var-tumblr; }\n.@{fa-css-prefix}-tumblr-square:before { content: @fa-var-tumblr-square; }\n.@{fa-css-prefix}-long-arrow-down:before { content: @fa-var-long-arrow-down; }\n.@{fa-css-prefix}-long-arrow-up:before { content: @fa-var-long-arrow-up; }\n.@{fa-css-prefix}-long-arrow-left:before { content: @fa-var-long-arrow-left; }\n.@{fa-css-prefix}-long-arrow-right:before { content: @fa-var-long-arrow-right; }\n.@{fa-css-prefix}-apple:before { content: @fa-var-apple; }\n.@{fa-css-prefix}-windows:before { content: @fa-var-windows; }\n.@{fa-css-prefix}-android:before { content: @fa-var-android; }\n.@{fa-css-prefix}-linux:before { content: @fa-var-linux; }\n.@{fa-css-prefix}-dribbble:before { content: @fa-var-dribbble; }\n.@{fa-css-prefix}-skype:before { content: @fa-var-skype; }\n.@{fa-css-prefix}-foursquare:before { content: @fa-var-foursquare; }\n.@{fa-css-prefix}-trello:before { content: @fa-var-trello; }\n.@{fa-css-prefix}-female:before { content: @fa-var-female; }\n.@{fa-css-prefix}-male:before { content: @fa-var-male; }\n.@{fa-css-prefix}-gittip:before,\n.@{fa-css-prefix}-gratipay:before { content: @fa-var-gratipay; }\n.@{fa-css-prefix}-sun-o:before { content: @fa-var-sun-o; }\n.@{fa-css-prefix}-moon-o:before { content: @fa-var-moon-o; }\n.@{fa-css-prefix}-archive:before { content: @fa-var-archive; }\n.@{fa-css-prefix}-bug:before { content: @fa-var-bug; }\n.@{fa-css-prefix}-vk:before { content: @fa-var-vk; }\n.@{fa-css-prefix}-weibo:before { content: @fa-var-weibo; }\n.@{fa-css-prefix}-renren:before { content: @fa-var-renren; }\n.@{fa-css-prefix}-pagelines:before { content: @fa-var-pagelines; }\n.@{fa-css-prefix}-stack-exchange:before { content: @fa-var-stack-exchange; }\n.@{fa-css-prefix}-arrow-circle-o-right:before { content: @fa-var-arrow-circle-o-right; }\n.@{fa-css-prefix}-arrow-circle-o-left:before { content: @fa-var-arrow-circle-o-left; }\n.@{fa-css-prefix}-toggle-left:before,\n.@{fa-css-prefix}-caret-square-o-left:before { content: @fa-var-caret-square-o-left; }\n.@{fa-css-prefix}-dot-circle-o:before { content: @fa-var-dot-circle-o; }\n.@{fa-css-prefix}-wheelchair:before { content: @fa-var-wheelchair; }\n.@{fa-css-prefix}-vimeo-square:before { content: @fa-var-vimeo-square; }\n.@{fa-css-prefix}-turkish-lira:before,\n.@{fa-css-prefix}-try:before { content: @fa-var-try; }\n.@{fa-css-prefix}-plus-square-o:before { content: @fa-var-plus-square-o; }\n.@{fa-css-prefix}-space-shuttle:before { content: @fa-var-space-shuttle; }\n.@{fa-css-prefix}-slack:before { content: @fa-var-slack; }\n.@{fa-css-prefix}-envelope-square:before { content: @fa-var-envelope-square; }\n.@{fa-css-prefix}-wordpress:before { content: @fa-var-wordpress; }\n.@{fa-css-prefix}-openid:before { content: @fa-var-openid; }\n.@{fa-css-prefix}-institution:before,\n.@{fa-css-prefix}-bank:before,\n.@{fa-css-prefix}-university:before { content: @fa-var-university; }\n.@{fa-css-prefix}-mortar-board:before,\n.@{fa-css-prefix}-graduation-cap:before { content: @fa-var-graduation-cap; }\n.@{fa-css-prefix}-yahoo:before { content: @fa-var-yahoo; }\n.@{fa-css-prefix}-google:before { content: @fa-var-google; }\n.@{fa-css-prefix}-reddit:before { content: @fa-var-reddit; }\n.@{fa-css-prefix}-reddit-square:before { content: @fa-var-reddit-square; }\n.@{fa-css-prefix}-stumbleupon-circle:before { content: @fa-var-stumbleupon-circle; }\n.@{fa-css-prefix}-stumbleupon:before { content: @fa-var-stumbleupon; }\n.@{fa-css-prefix}-delicious:before { content: @fa-var-delicious; }\n.@{fa-css-prefix}-digg:before { content: @fa-var-digg; }\n.@{fa-css-prefix}-pied-piper:before { content: @fa-var-pied-piper; }\n.@{fa-css-prefix}-pied-piper-alt:before { content: @fa-var-pied-piper-alt; }\n.@{fa-css-prefix}-drupal:before { content: @fa-var-drupal; }\n.@{fa-css-prefix}-joomla:before { content: @fa-var-joomla; }\n.@{fa-css-prefix}-language:before { content: @fa-var-language; }\n.@{fa-css-prefix}-fax:before { content: @fa-var-fax; }\n.@{fa-css-prefix}-building:before { content: @fa-var-building; }\n.@{fa-css-prefix}-child:before { content: @fa-var-child; }\n.@{fa-css-prefix}-paw:before { content: @fa-var-paw; }\n.@{fa-css-prefix}-spoon:before { content: @fa-var-spoon; }\n.@{fa-css-prefix}-cube:before { content: @fa-var-cube; }\n.@{fa-css-prefix}-cubes:before { content: @fa-var-cubes; }\n.@{fa-css-prefix}-behance:before { content: @fa-var-behance; }\n.@{fa-css-prefix}-behance-square:before { content: @fa-var-behance-square; }\n.@{fa-css-prefix}-steam:before { content: @fa-var-steam; }\n.@{fa-css-prefix}-steam-square:before { content: @fa-var-steam-square; }\n.@{fa-css-prefix}-recycle:before { content: @fa-var-recycle; }\n.@{fa-css-prefix}-automobile:before,\n.@{fa-css-prefix}-car:before { content: @fa-var-car; }\n.@{fa-css-prefix}-cab:before,\n.@{fa-css-prefix}-taxi:before { content: @fa-var-taxi; }\n.@{fa-css-prefix}-tree:before { content: @fa-var-tree; }\n.@{fa-css-prefix}-spotify:before { content: @fa-var-spotify; }\n.@{fa-css-prefix}-deviantart:before { content: @fa-var-deviantart; }\n.@{fa-css-prefix}-soundcloud:before { content: @fa-var-soundcloud; }\n.@{fa-css-prefix}-database:before { content: @fa-var-database; }\n.@{fa-css-prefix}-file-pdf-o:before { content: @fa-var-file-pdf-o; }\n.@{fa-css-prefix}-file-word-o:before { content: @fa-var-file-word-o; }\n.@{fa-css-prefix}-file-excel-o:before { content: @fa-var-file-excel-o; }\n.@{fa-css-prefix}-file-powerpoint-o:before { content: @fa-var-file-powerpoint-o; }\n.@{fa-css-prefix}-file-photo-o:before,\n.@{fa-css-prefix}-file-picture-o:before,\n.@{fa-css-prefix}-file-image-o:before { content: @fa-var-file-image-o; }\n.@{fa-css-prefix}-file-zip-o:before,\n.@{fa-css-prefix}-file-archive-o:before { content: @fa-var-file-archive-o; }\n.@{fa-css-prefix}-file-sound-o:before,\n.@{fa-css-prefix}-file-audio-o:before { content: @fa-var-file-audio-o; }\n.@{fa-css-prefix}-file-movie-o:before,\n.@{fa-css-prefix}-file-video-o:before { content: @fa-var-file-video-o; }\n.@{fa-css-prefix}-file-code-o:before { content: @fa-var-file-code-o; }\n.@{fa-css-prefix}-vine:before { content: @fa-var-vine; }\n.@{fa-css-prefix}-codepen:before { content: @fa-var-codepen; }\n.@{fa-css-prefix}-jsfiddle:before { content: @fa-var-jsfiddle; }\n.@{fa-css-prefix}-life-bouy:before,\n.@{fa-css-prefix}-life-buoy:before,\n.@{fa-css-prefix}-life-saver:before,\n.@{fa-css-prefix}-support:before,\n.@{fa-css-prefix}-life-ring:before { content: @fa-var-life-ring; }\n.@{fa-css-prefix}-circle-o-notch:before { content: @fa-var-circle-o-notch; }\n.@{fa-css-prefix}-ra:before,\n.@{fa-css-prefix}-rebel:before { content: @fa-var-rebel; }\n.@{fa-css-prefix}-ge:before,\n.@{fa-css-prefix}-empire:before { content: @fa-var-empire; }\n.@{fa-css-prefix}-git-square:before { content: @fa-var-git-square; }\n.@{fa-css-prefix}-git:before { content: @fa-var-git; }\n.@{fa-css-prefix}-y-combinator-square:before,\n.@{fa-css-prefix}-yc-square:before,\n.@{fa-css-prefix}-hacker-news:before { content: @fa-var-hacker-news; }\n.@{fa-css-prefix}-tencent-weibo:before { content: @fa-var-tencent-weibo; }\n.@{fa-css-prefix}-qq:before { content: @fa-var-qq; }\n.@{fa-css-prefix}-wechat:before,\n.@{fa-css-prefix}-weixin:before { content: @fa-var-weixin; }\n.@{fa-css-prefix}-send:before,\n.@{fa-css-prefix}-paper-plane:before { content: @fa-var-paper-plane; }\n.@{fa-css-prefix}-send-o:before,\n.@{fa-css-prefix}-paper-plane-o:before { content: @fa-var-paper-plane-o; }\n.@{fa-css-prefix}-history:before { content: @fa-var-history; }\n.@{fa-css-prefix}-circle-thin:before { content: @fa-var-circle-thin; }\n.@{fa-css-prefix}-header:before { content: @fa-var-header; }\n.@{fa-css-prefix}-paragraph:before { content: @fa-var-paragraph; }\n.@{fa-css-prefix}-sliders:before { content: @fa-var-sliders; }\n.@{fa-css-prefix}-share-alt:before { content: @fa-var-share-alt; }\n.@{fa-css-prefix}-share-alt-square:before { content: @fa-var-share-alt-square; }\n.@{fa-css-prefix}-bomb:before { content: @fa-var-bomb; }\n.@{fa-css-prefix}-soccer-ball-o:before,\n.@{fa-css-prefix}-futbol-o:before { content: @fa-var-futbol-o; }\n.@{fa-css-prefix}-tty:before { content: @fa-var-tty; }\n.@{fa-css-prefix}-binoculars:before { content: @fa-var-binoculars; }\n.@{fa-css-prefix}-plug:before { content: @fa-var-plug; }\n.@{fa-css-prefix}-slideshare:before { content: @fa-var-slideshare; }\n.@{fa-css-prefix}-twitch:before { content: @fa-var-twitch; }\n.@{fa-css-prefix}-yelp:before { content: @fa-var-yelp; }\n.@{fa-css-prefix}-newspaper-o:before { content: @fa-var-newspaper-o; }\n.@{fa-css-prefix}-wifi:before { content: @fa-var-wifi; }\n.@{fa-css-prefix}-calculator:before { content: @fa-var-calculator; }\n.@{fa-css-prefix}-paypal:before { content: @fa-var-paypal; }\n.@{fa-css-prefix}-google-wallet:before { content: @fa-var-google-wallet; }\n.@{fa-css-prefix}-cc-visa:before { content: @fa-var-cc-visa; }\n.@{fa-css-prefix}-cc-mastercard:before { content: @fa-var-cc-mastercard; }\n.@{fa-css-prefix}-cc-discover:before { content: @fa-var-cc-discover; }\n.@{fa-css-prefix}-cc-amex:before { content: @fa-var-cc-amex; }\n.@{fa-css-prefix}-cc-paypal:before { content: @fa-var-cc-paypal; }\n.@{fa-css-prefix}-cc-stripe:before { content: @fa-var-cc-stripe; }\n.@{fa-css-prefix}-bell-slash:before { content: @fa-var-bell-slash; }\n.@{fa-css-prefix}-bell-slash-o:before { content: @fa-var-bell-slash-o; }\n.@{fa-css-prefix}-trash:before { content: @fa-var-trash; }\n.@{fa-css-prefix}-copyright:before { content: @fa-var-copyright; }\n.@{fa-css-prefix}-at:before { content: @fa-var-at; }\n.@{fa-css-prefix}-eyedropper:before { content: @fa-var-eyedropper; }\n.@{fa-css-prefix}-paint-brush:before { content: @fa-var-paint-brush; }\n.@{fa-css-prefix}-birthday-cake:before { content: @fa-var-birthday-cake; }\n.@{fa-css-prefix}-area-chart:before { content: @fa-var-area-chart; }\n.@{fa-css-prefix}-pie-chart:before { content: @fa-var-pie-chart; }\n.@{fa-css-prefix}-line-chart:before { content: @fa-var-line-chart; }\n.@{fa-css-prefix}-lastfm:before { content: @fa-var-lastfm; }\n.@{fa-css-prefix}-lastfm-square:before { content: @fa-var-lastfm-square; }\n.@{fa-css-prefix}-toggle-off:before { content: @fa-var-toggle-off; }\n.@{fa-css-prefix}-toggle-on:before { content: @fa-var-toggle-on; }\n.@{fa-css-prefix}-bicycle:before { content: @fa-var-bicycle; }\n.@{fa-css-prefix}-bus:before { content: @fa-var-bus; }\n.@{fa-css-prefix}-ioxhost:before { content: @fa-var-ioxhost; }\n.@{fa-css-prefix}-angellist:before { content: @fa-var-angellist; }\n.@{fa-css-prefix}-cc:before { content: @fa-var-cc; }\n.@{fa-css-prefix}-shekel:before,\n.@{fa-css-prefix}-sheqel:before,\n.@{fa-css-prefix}-ils:before { content: @fa-var-ils; }\n.@{fa-css-prefix}-meanpath:before { content: @fa-var-meanpath; }\n.@{fa-css-prefix}-buysellads:before { content: @fa-var-buysellads; }\n.@{fa-css-prefix}-connectdevelop:before { content: @fa-var-connectdevelop; }\n.@{fa-css-prefix}-dashcube:before { content: @fa-var-dashcube; }\n.@{fa-css-prefix}-forumbee:before { content: @fa-var-forumbee; }\n.@{fa-css-prefix}-leanpub:before { content: @fa-var-leanpub; }\n.@{fa-css-prefix}-sellsy:before { content: @fa-var-sellsy; }\n.@{fa-css-prefix}-shirtsinbulk:before { content: @fa-var-shirtsinbulk; }\n.@{fa-css-prefix}-simplybuilt:before { content: @fa-var-simplybuilt; }\n.@{fa-css-prefix}-skyatlas:before { content: @fa-var-skyatlas; }\n.@{fa-css-prefix}-cart-plus:before { content: @fa-var-cart-plus; }\n.@{fa-css-prefix}-cart-arrow-down:before { content: @fa-var-cart-arrow-down; }\n.@{fa-css-prefix}-diamond:before { content: @fa-var-diamond; }\n.@{fa-css-prefix}-ship:before { content: @fa-var-ship; }\n.@{fa-css-prefix}-user-secret:before { content: @fa-var-user-secret; }\n.@{fa-css-prefix}-motorcycle:before { content: @fa-var-motorcycle; }\n.@{fa-css-prefix}-street-view:before { content: @fa-var-street-view; }\n.@{fa-css-prefix}-heartbeat:before { content: @fa-var-heartbeat; }\n.@{fa-css-prefix}-venus:before { content: @fa-var-venus; }\n.@{fa-css-prefix}-mars:before { content: @fa-var-mars; }\n.@{fa-css-prefix}-mercury:before { content: @fa-var-mercury; }\n.@{fa-css-prefix}-intersex:before,\n.@{fa-css-prefix}-transgender:before { content: @fa-var-transgender; }\n.@{fa-css-prefix}-transgender-alt:before { content: @fa-var-transgender-alt; }\n.@{fa-css-prefix}-venus-double:before { content: @fa-var-venus-double; }\n.@{fa-css-prefix}-mars-double:before { content: @fa-var-mars-double; }\n.@{fa-css-prefix}-venus-mars:before { content: @fa-var-venus-mars; }\n.@{fa-css-prefix}-mars-stroke:before { content: @fa-var-mars-stroke; }\n.@{fa-css-prefix}-mars-stroke-v:before { content: @fa-var-mars-stroke-v; }\n.@{fa-css-prefix}-mars-stroke-h:before { content: @fa-var-mars-stroke-h; }\n.@{fa-css-prefix}-neuter:before { content: @fa-var-neuter; }\n.@{fa-css-prefix}-genderless:before { content: @fa-var-genderless; }\n.@{fa-css-prefix}-facebook-official:before { content: @fa-var-facebook-official; }\n.@{fa-css-prefix}-pinterest-p:before { content: @fa-var-pinterest-p; }\n.@{fa-css-prefix}-whatsapp:before { content: @fa-var-whatsapp; }\n.@{fa-css-prefix}-server:before { content: @fa-var-server; }\n.@{fa-css-prefix}-user-plus:before { content: @fa-var-user-plus; }\n.@{fa-css-prefix}-user-times:before { content: @fa-var-user-times; }\n.@{fa-css-prefix}-hotel:before,\n.@{fa-css-prefix}-bed:before { content: @fa-var-bed; }\n.@{fa-css-prefix}-viacoin:before { content: @fa-var-viacoin; }\n.@{fa-css-prefix}-train:before { content: @fa-var-train; }\n.@{fa-css-prefix}-subway:before { content: @fa-var-subway; }\n.@{fa-css-prefix}-medium:before { content: @fa-var-medium; }\n.@{fa-css-prefix}-yc:before,\n.@{fa-css-prefix}-y-combinator:before { content: @fa-var-y-combinator; }\n.@{fa-css-prefix}-optin-monster:before { content: @fa-var-optin-monster; }\n.@{fa-css-prefix}-opencart:before { content: @fa-var-opencart; }\n.@{fa-css-prefix}-expeditedssl:before { content: @fa-var-expeditedssl; }\n.@{fa-css-prefix}-battery-4:before,\n.@{fa-css-prefix}-battery-full:before { content: @fa-var-battery-full; }\n.@{fa-css-prefix}-battery-3:before,\n.@{fa-css-prefix}-battery-three-quarters:before { content: @fa-var-battery-three-quarters; }\n.@{fa-css-prefix}-battery-2:before,\n.@{fa-css-prefix}-battery-half:before { content: @fa-var-battery-half; }\n.@{fa-css-prefix}-battery-1:before,\n.@{fa-css-prefix}-battery-quarter:before { content: @fa-var-battery-quarter; }\n.@{fa-css-prefix}-battery-0:before,\n.@{fa-css-prefix}-battery-empty:before { content: @fa-var-battery-empty; }\n.@{fa-css-prefix}-mouse-pointer:before { content: @fa-var-mouse-pointer; }\n.@{fa-css-prefix}-i-cursor:before { content: @fa-var-i-cursor; }\n.@{fa-css-prefix}-object-group:before { content: @fa-var-object-group; }\n.@{fa-css-prefix}-object-ungroup:before { content: @fa-var-object-ungroup; }\n.@{fa-css-prefix}-sticky-note:before { content: @fa-var-sticky-note; }\n.@{fa-css-prefix}-sticky-note-o:before { content: @fa-var-sticky-note-o; }\n.@{fa-css-prefix}-cc-jcb:before { content: @fa-var-cc-jcb; }\n.@{fa-css-prefix}-cc-diners-club:before { content: @fa-var-cc-diners-club; }\n.@{fa-css-prefix}-clone:before { content: @fa-var-clone; }\n.@{fa-css-prefix}-balance-scale:before { content: @fa-var-balance-scale; }\n.@{fa-css-prefix}-hourglass-o:before { content: @fa-var-hourglass-o; }\n.@{fa-css-prefix}-hourglass-1:before,\n.@{fa-css-prefix}-hourglass-start:before { content: @fa-var-hourglass-start; }\n.@{fa-css-prefix}-hourglass-2:before,\n.@{fa-css-prefix}-hourglass-half:before { content: @fa-var-hourglass-half; }\n.@{fa-css-prefix}-hourglass-3:before,\n.@{fa-css-prefix}-hourglass-end:before { content: @fa-var-hourglass-end; }\n.@{fa-css-prefix}-hourglass:before { content: @fa-var-hourglass; }\n.@{fa-css-prefix}-hand-grab-o:before,\n.@{fa-css-prefix}-hand-rock-o:before { content: @fa-var-hand-rock-o; }\n.@{fa-css-prefix}-hand-stop-o:before,\n.@{fa-css-prefix}-hand-paper-o:before { content: @fa-var-hand-paper-o; }\n.@{fa-css-prefix}-hand-scissors-o:before { content: @fa-var-hand-scissors-o; }\n.@{fa-css-prefix}-hand-lizard-o:before { content: @fa-var-hand-lizard-o; }\n.@{fa-css-prefix}-hand-spock-o:before { content: @fa-var-hand-spock-o; }\n.@{fa-css-prefix}-hand-pointer-o:before { content: @fa-var-hand-pointer-o; }\n.@{fa-css-prefix}-hand-peace-o:before { content: @fa-var-hand-peace-o; }\n.@{fa-css-prefix}-trademark:before { content: @fa-var-trademark; }\n.@{fa-css-prefix}-registered:before { content: @fa-var-registered; }\n.@{fa-css-prefix}-creative-commons:before { content: @fa-var-creative-commons; }\n.@{fa-css-prefix}-gg:before { content: @fa-var-gg; }\n.@{fa-css-prefix}-gg-circle:before { content: @fa-var-gg-circle; }\n.@{fa-css-prefix}-tripadvisor:before { content: @fa-var-tripadvisor; }\n.@{fa-css-prefix}-odnoklassniki:before { content: @fa-var-odnoklassniki; }\n.@{fa-css-prefix}-odnoklassniki-square:before { content: @fa-var-odnoklassniki-square; }\n.@{fa-css-prefix}-get-pocket:before { content: @fa-var-get-pocket; }\n.@{fa-css-prefix}-wikipedia-w:before { content: @fa-var-wikipedia-w; }\n.@{fa-css-prefix}-safari:before { content: @fa-var-safari; }\n.@{fa-css-prefix}-chrome:before { content: @fa-var-chrome; }\n.@{fa-css-prefix}-firefox:before { content: @fa-var-firefox; }\n.@{fa-css-prefix}-opera:before { content: @fa-var-opera; }\n.@{fa-css-prefix}-internet-explorer:before { content: @fa-var-internet-explorer; }\n.@{fa-css-prefix}-tv:before,\n.@{fa-css-prefix}-television:before { content: @fa-var-television; }\n.@{fa-css-prefix}-contao:before { content: @fa-var-contao; }\n.@{fa-css-prefix}-500px:before { content: @fa-var-500px; }\n.@{fa-css-prefix}-amazon:before { content: @fa-var-amazon; }\n.@{fa-css-prefix}-calendar-plus-o:before { content: @fa-var-calendar-plus-o; }\n.@{fa-css-prefix}-calendar-minus-o:before { content: @fa-var-calendar-minus-o; }\n.@{fa-css-prefix}-calendar-times-o:before { content: @fa-var-calendar-times-o; }\n.@{fa-css-prefix}-calendar-check-o:before { content: @fa-var-calendar-check-o; }\n.@{fa-css-prefix}-industry:before { content: @fa-var-industry; }\n.@{fa-css-prefix}-map-pin:before { content: @fa-var-map-pin; }\n.@{fa-css-prefix}-map-signs:before { content: @fa-var-map-signs; }\n.@{fa-css-prefix}-map-o:before { content: @fa-var-map-o; }\n.@{fa-css-prefix}-map:before { content: @fa-var-map; }\n.@{fa-css-prefix}-commenting:before { content: @fa-var-commenting; }\n.@{fa-css-prefix}-commenting-o:before { content: @fa-var-commenting-o; }\n.@{fa-css-prefix}-houzz:before { content: @fa-var-houzz; }\n.@{fa-css-prefix}-vimeo:before { content: @fa-var-vimeo; }\n.@{fa-css-prefix}-black-tie:before { content: @fa-var-black-tie; }\n.@{fa-css-prefix}-fonticons:before { content: @fa-var-fonticons; }\n.@{fa-css-prefix}-reddit-alien:before { content: @fa-var-reddit-alien; }\n.@{fa-css-prefix}-edge:before { content: @fa-var-edge; }\n.@{fa-css-prefix}-credit-card-alt:before { content: @fa-var-credit-card-alt; }\n.@{fa-css-prefix}-codiepie:before { content: @fa-var-codiepie; }\n.@{fa-css-prefix}-modx:before { content: @fa-var-modx; }\n.@{fa-css-prefix}-fort-awesome:before { content: @fa-var-fort-awesome; }\n.@{fa-css-prefix}-usb:before { content: @fa-var-usb; }\n.@{fa-css-prefix}-product-hunt:before { content: @fa-var-product-hunt; }\n.@{fa-css-prefix}-mixcloud:before { content: @fa-var-mixcloud; }\n.@{fa-css-prefix}-scribd:before { content: @fa-var-scribd; }\n.@{fa-css-prefix}-pause-circle:before { content: @fa-var-pause-circle; }\n.@{fa-css-prefix}-pause-circle-o:before { content: @fa-var-pause-circle-o; }\n.@{fa-css-prefix}-stop-circle:before { content: @fa-var-stop-circle; }\n.@{fa-css-prefix}-stop-circle-o:before { content: @fa-var-stop-circle-o; }\n.@{fa-css-prefix}-shopping-bag:before { content: @fa-var-shopping-bag; }\n.@{fa-css-prefix}-shopping-basket:before { content: @fa-var-shopping-basket; }\n.@{fa-css-prefix}-hashtag:before { content: @fa-var-hashtag; }\n.@{fa-css-prefix}-bluetooth:before { content: @fa-var-bluetooth; }\n.@{fa-css-prefix}-bluetooth-b:before { content: @fa-var-bluetooth-b; }\n.@{fa-css-prefix}-percent:before { content: @fa-var-percent; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/larger.less",
    "content": "// Icon Sizes\n// -------------------------\n\n/* makes the font 33% larger relative to the icon container */\n.@{fa-css-prefix}-lg {\n  font-size: (4em / 3);\n  line-height: (3em / 4);\n  vertical-align: -15%;\n}\n.@{fa-css-prefix}-2x { font-size: 2em; }\n.@{fa-css-prefix}-3x { font-size: 3em; }\n.@{fa-css-prefix}-4x { font-size: 4em; }\n.@{fa-css-prefix}-5x { font-size: 5em; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/list.less",
    "content": "// List Icons\n// -------------------------\n\n.@{fa-css-prefix}-ul {\n  padding-left: 0;\n  margin-left: @fa-li-width;\n  list-style-type: none;\n  > li { position: relative; }\n}\n.@{fa-css-prefix}-li {\n  position: absolute;\n  left: -@fa-li-width;\n  width: @fa-li-width;\n  top: (2em / 14);\n  text-align: center;\n  &.@{fa-css-prefix}-lg {\n    left: (-@fa-li-width + (4em / 14));\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/mixins.less",
    "content": "// Mixins\n// --------------------------\n\n.fa-icon() {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/@fa-line-height-base FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n\n.fa-icon-rotate(@degrees, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation);\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n\n.fa-icon-flip(@horiz, @vert, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation, mirror=1);\n  -webkit-transform: scale(@horiz, @vert);\n      -ms-transform: scale(@horiz, @vert);\n          transform: scale(@horiz, @vert);\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/path.less",
    "content": "/* FONT PATH\n * -------------------------- */\n\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('../less/icons/font-awesome/fonts/fontawesome-webfont.eot?v=@{fa-version}');\n  src: url('../less/icons/font-awesome/fonts/fontawesome-webfont.eot?#iefix&v=@{fa-version}') format('embedded-opentype'),\n    url('../less/icons/font-awesome/fonts/fontawesome-webfont.woff2?v=@{fa-version}') format('woff2'),\n    url('../less/icons/font-awesome/fonts/fontawesome-webfont.woff?v=@{fa-version}') format('woff'),\n    url('../less/icons/font-awesome/fonts/fontawesome-webfont.ttf?v=@{fa-version}') format('truetype'),\n    url('../less/icons/font-awesome/fonts/fontawesome-webfont.svg?v=@{fa-version}#fontawesomeregular') format('svg');\n//  src: url('../less/icons/font-awesome/fonts/FontAwesome.otf') format('opentype'); // used when developing fonts\n  font-weight: normal;\n  font-style: normal;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/rotated-flipped.less",
    "content": "// Rotated & Flipped Icons\n// -------------------------\n\n.@{fa-css-prefix}-rotate-90  { .fa-icon-rotate(90deg, 1);  }\n.@{fa-css-prefix}-rotate-180 { .fa-icon-rotate(180deg, 2); }\n.@{fa-css-prefix}-rotate-270 { .fa-icon-rotate(270deg, 3); }\n\n.@{fa-css-prefix}-flip-horizontal { .fa-icon-flip(-1, 1, 0); }\n.@{fa-css-prefix}-flip-vertical   { .fa-icon-flip(1, -1, 2); }\n\n// Hook for IE8-9\n// -------------------------\n\n:root .@{fa-css-prefix}-rotate-90,\n:root .@{fa-css-prefix}-rotate-180,\n:root .@{fa-css-prefix}-rotate-270,\n:root .@{fa-css-prefix}-flip-horizontal,\n:root .@{fa-css-prefix}-flip-vertical {\n  filter: none;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/spinning.less",
    "content": "// Spinning Icons\n// --------------------------\n\n.@{fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/stacked.less",
    "content": "// Stacked Icons\n// -------------------------\n\n.@{fa-css-prefix}-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.@{fa-css-prefix}-stack-1x, .@{fa-css-prefix}-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.@{fa-css-prefix}-stack-1x { line-height: inherit; }\n.@{fa-css-prefix}-stack-2x { font-size: 2em; }\n.@{fa-css-prefix}-inverse { color: @fa-inverse; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/less/variables.less",
    "content": "// Variables\n// --------------------------\n\n@fa-font-path:        \"../fonts\";\n@fa-font-size-base:   14px;\n@fa-line-height-base: 1;\n//@fa-font-path:        \"//netdna.bootstrapcdn.com/font-awesome/4.5.0/fonts\"; // for referencing Bootstrap CDN font files directly\n@fa-css-prefix:       fa;\n@fa-version:          \"4.5.0\";\n@fa-border-color:     #eee;\n@fa-inverse:          #fff;\n@fa-li-width:         (30em / 14);\n\n@fa-var-500px: \"\\f26e\";\n@fa-var-adjust: \"\\f042\";\n@fa-var-adn: \"\\f170\";\n@fa-var-align-center: \"\\f037\";\n@fa-var-align-justify: \"\\f039\";\n@fa-var-align-left: \"\\f036\";\n@fa-var-align-right: \"\\f038\";\n@fa-var-amazon: \"\\f270\";\n@fa-var-ambulance: \"\\f0f9\";\n@fa-var-anchor: \"\\f13d\";\n@fa-var-android: \"\\f17b\";\n@fa-var-angellist: \"\\f209\";\n@fa-var-angle-double-down: \"\\f103\";\n@fa-var-angle-double-left: \"\\f100\";\n@fa-var-angle-double-right: \"\\f101\";\n@fa-var-angle-double-up: \"\\f102\";\n@fa-var-angle-down: \"\\f107\";\n@fa-var-angle-left: \"\\f104\";\n@fa-var-angle-right: \"\\f105\";\n@fa-var-angle-up: \"\\f106\";\n@fa-var-apple: \"\\f179\";\n@fa-var-archive: \"\\f187\";\n@fa-var-area-chart: \"\\f1fe\";\n@fa-var-arrow-circle-down: \"\\f0ab\";\n@fa-var-arrow-circle-left: \"\\f0a8\";\n@fa-var-arrow-circle-o-down: \"\\f01a\";\n@fa-var-arrow-circle-o-left: \"\\f190\";\n@fa-var-arrow-circle-o-right: \"\\f18e\";\n@fa-var-arrow-circle-o-up: \"\\f01b\";\n@fa-var-arrow-circle-right: \"\\f0a9\";\n@fa-var-arrow-circle-up: \"\\f0aa\";\n@fa-var-arrow-down: \"\\f063\";\n@fa-var-arrow-left: \"\\f060\";\n@fa-var-arrow-right: \"\\f061\";\n@fa-var-arrow-up: \"\\f062\";\n@fa-var-arrows: \"\\f047\";\n@fa-var-arrows-alt: \"\\f0b2\";\n@fa-var-arrows-h: \"\\f07e\";\n@fa-var-arrows-v: \"\\f07d\";\n@fa-var-asterisk: \"\\f069\";\n@fa-var-at: \"\\f1fa\";\n@fa-var-automobile: \"\\f1b9\";\n@fa-var-backward: \"\\f04a\";\n@fa-var-balance-scale: \"\\f24e\";\n@fa-var-ban: \"\\f05e\";\n@fa-var-bank: \"\\f19c\";\n@fa-var-bar-chart: \"\\f080\";\n@fa-var-bar-chart-o: \"\\f080\";\n@fa-var-barcode: \"\\f02a\";\n@fa-var-bars: \"\\f0c9\";\n@fa-var-battery-0: \"\\f244\";\n@fa-var-battery-1: \"\\f243\";\n@fa-var-battery-2: \"\\f242\";\n@fa-var-battery-3: \"\\f241\";\n@fa-var-battery-4: \"\\f240\";\n@fa-var-battery-empty: \"\\f244\";\n@fa-var-battery-full: \"\\f240\";\n@fa-var-battery-half: \"\\f242\";\n@fa-var-battery-quarter: \"\\f243\";\n@fa-var-battery-three-quarters: \"\\f241\";\n@fa-var-bed: \"\\f236\";\n@fa-var-beer: \"\\f0fc\";\n@fa-var-behance: \"\\f1b4\";\n@fa-var-behance-square: \"\\f1b5\";\n@fa-var-bell: \"\\f0f3\";\n@fa-var-bell-o: \"\\f0a2\";\n@fa-var-bell-slash: \"\\f1f6\";\n@fa-var-bell-slash-o: \"\\f1f7\";\n@fa-var-bicycle: \"\\f206\";\n@fa-var-binoculars: \"\\f1e5\";\n@fa-var-birthday-cake: \"\\f1fd\";\n@fa-var-bitbucket: \"\\f171\";\n@fa-var-bitbucket-square: \"\\f172\";\n@fa-var-bitcoin: \"\\f15a\";\n@fa-var-black-tie: \"\\f27e\";\n@fa-var-bluetooth: \"\\f293\";\n@fa-var-bluetooth-b: \"\\f294\";\n@fa-var-bold: \"\\f032\";\n@fa-var-bolt: \"\\f0e7\";\n@fa-var-bomb: \"\\f1e2\";\n@fa-var-book: \"\\f02d\";\n@fa-var-bookmark: \"\\f02e\";\n@fa-var-bookmark-o: \"\\f097\";\n@fa-var-briefcase: \"\\f0b1\";\n@fa-var-btc: \"\\f15a\";\n@fa-var-bug: \"\\f188\";\n@fa-var-building: \"\\f1ad\";\n@fa-var-building-o: \"\\f0f7\";\n@fa-var-bullhorn: \"\\f0a1\";\n@fa-var-bullseye: \"\\f140\";\n@fa-var-bus: \"\\f207\";\n@fa-var-buysellads: \"\\f20d\";\n@fa-var-cab: \"\\f1ba\";\n@fa-var-calculator: \"\\f1ec\";\n@fa-var-calendar: \"\\f073\";\n@fa-var-calendar-check-o: \"\\f274\";\n@fa-var-calendar-minus-o: \"\\f272\";\n@fa-var-calendar-o: \"\\f133\";\n@fa-var-calendar-plus-o: \"\\f271\";\n@fa-var-calendar-times-o: \"\\f273\";\n@fa-var-camera: \"\\f030\";\n@fa-var-camera-retro: \"\\f083\";\n@fa-var-car: \"\\f1b9\";\n@fa-var-caret-down: \"\\f0d7\";\n@fa-var-caret-left: \"\\f0d9\";\n@fa-var-caret-right: \"\\f0da\";\n@fa-var-caret-square-o-down: \"\\f150\";\n@fa-var-caret-square-o-left: \"\\f191\";\n@fa-var-caret-square-o-right: \"\\f152\";\n@fa-var-caret-square-o-up: \"\\f151\";\n@fa-var-caret-up: \"\\f0d8\";\n@fa-var-cart-arrow-down: \"\\f218\";\n@fa-var-cart-plus: \"\\f217\";\n@fa-var-cc: \"\\f20a\";\n@fa-var-cc-amex: \"\\f1f3\";\n@fa-var-cc-diners-club: \"\\f24c\";\n@fa-var-cc-discover: \"\\f1f2\";\n@fa-var-cc-jcb: \"\\f24b\";\n@fa-var-cc-mastercard: \"\\f1f1\";\n@fa-var-cc-paypal: \"\\f1f4\";\n@fa-var-cc-stripe: \"\\f1f5\";\n@fa-var-cc-visa: \"\\f1f0\";\n@fa-var-certificate: \"\\f0a3\";\n@fa-var-chain: \"\\f0c1\";\n@fa-var-chain-broken: \"\\f127\";\n@fa-var-check: \"\\f00c\";\n@fa-var-check-circle: \"\\f058\";\n@fa-var-check-circle-o: \"\\f05d\";\n@fa-var-check-square: \"\\f14a\";\n@fa-var-check-square-o: \"\\f046\";\n@fa-var-chevron-circle-down: \"\\f13a\";\n@fa-var-chevron-circle-left: \"\\f137\";\n@fa-var-chevron-circle-right: \"\\f138\";\n@fa-var-chevron-circle-up: \"\\f139\";\n@fa-var-chevron-down: \"\\f078\";\n@fa-var-chevron-left: \"\\f053\";\n@fa-var-chevron-right: \"\\f054\";\n@fa-var-chevron-up: \"\\f077\";\n@fa-var-child: \"\\f1ae\";\n@fa-var-chrome: \"\\f268\";\n@fa-var-circle: \"\\f111\";\n@fa-var-circle-o: \"\\f10c\";\n@fa-var-circle-o-notch: \"\\f1ce\";\n@fa-var-circle-thin: \"\\f1db\";\n@fa-var-clipboard: \"\\f0ea\";\n@fa-var-clock-o: \"\\f017\";\n@fa-var-clone: \"\\f24d\";\n@fa-var-close: \"\\f00d\";\n@fa-var-cloud: \"\\f0c2\";\n@fa-var-cloud-download: \"\\f0ed\";\n@fa-var-cloud-upload: \"\\f0ee\";\n@fa-var-cny: \"\\f157\";\n@fa-var-code: \"\\f121\";\n@fa-var-code-fork: \"\\f126\";\n@fa-var-codepen: \"\\f1cb\";\n@fa-var-codiepie: \"\\f284\";\n@fa-var-coffee: \"\\f0f4\";\n@fa-var-cog: \"\\f013\";\n@fa-var-cogs: \"\\f085\";\n@fa-var-columns: \"\\f0db\";\n@fa-var-comment: \"\\f075\";\n@fa-var-comment-o: \"\\f0e5\";\n@fa-var-commenting: \"\\f27a\";\n@fa-var-commenting-o: \"\\f27b\";\n@fa-var-comments: \"\\f086\";\n@fa-var-comments-o: \"\\f0e6\";\n@fa-var-compass: \"\\f14e\";\n@fa-var-compress: \"\\f066\";\n@fa-var-connectdevelop: \"\\f20e\";\n@fa-var-contao: \"\\f26d\";\n@fa-var-copy: \"\\f0c5\";\n@fa-var-copyright: \"\\f1f9\";\n@fa-var-creative-commons: \"\\f25e\";\n@fa-var-credit-card: \"\\f09d\";\n@fa-var-credit-card-alt: \"\\f283\";\n@fa-var-crop: \"\\f125\";\n@fa-var-crosshairs: \"\\f05b\";\n@fa-var-css3: \"\\f13c\";\n@fa-var-cube: \"\\f1b2\";\n@fa-var-cubes: \"\\f1b3\";\n@fa-var-cut: \"\\f0c4\";\n@fa-var-cutlery: \"\\f0f5\";\n@fa-var-dashboard: \"\\f0e4\";\n@fa-var-dashcube: \"\\f210\";\n@fa-var-database: \"\\f1c0\";\n@fa-var-dedent: \"\\f03b\";\n@fa-var-delicious: \"\\f1a5\";\n@fa-var-desktop: \"\\f108\";\n@fa-var-deviantart: \"\\f1bd\";\n@fa-var-diamond: \"\\f219\";\n@fa-var-digg: \"\\f1a6\";\n@fa-var-dollar: \"\\f155\";\n@fa-var-dot-circle-o: \"\\f192\";\n@fa-var-download: \"\\f019\";\n@fa-var-dribbble: \"\\f17d\";\n@fa-var-dropbox: \"\\f16b\";\n@fa-var-drupal: \"\\f1a9\";\n@fa-var-edge: \"\\f282\";\n@fa-var-edit: \"\\f044\";\n@fa-var-eject: \"\\f052\";\n@fa-var-ellipsis-h: \"\\f141\";\n@fa-var-ellipsis-v: \"\\f142\";\n@fa-var-empire: \"\\f1d1\";\n@fa-var-envelope: \"\\f0e0\";\n@fa-var-envelope-o: \"\\f003\";\n@fa-var-envelope-square: \"\\f199\";\n@fa-var-eraser: \"\\f12d\";\n@fa-var-eur: \"\\f153\";\n@fa-var-euro: \"\\f153\";\n@fa-var-exchange: \"\\f0ec\";\n@fa-var-exclamation: \"\\f12a\";\n@fa-var-exclamation-circle: \"\\f06a\";\n@fa-var-exclamation-triangle: \"\\f071\";\n@fa-var-expand: \"\\f065\";\n@fa-var-expeditedssl: \"\\f23e\";\n@fa-var-external-link: \"\\f08e\";\n@fa-var-external-link-square: \"\\f14c\";\n@fa-var-eye: \"\\f06e\";\n@fa-var-eye-slash: \"\\f070\";\n@fa-var-eyedropper: \"\\f1fb\";\n@fa-var-facebook: \"\\f09a\";\n@fa-var-facebook-f: \"\\f09a\";\n@fa-var-facebook-official: \"\\f230\";\n@fa-var-facebook-square: \"\\f082\";\n@fa-var-fast-backward: \"\\f049\";\n@fa-var-fast-forward: \"\\f050\";\n@fa-var-fax: \"\\f1ac\";\n@fa-var-feed: \"\\f09e\";\n@fa-var-female: \"\\f182\";\n@fa-var-fighter-jet: \"\\f0fb\";\n@fa-var-file: \"\\f15b\";\n@fa-var-file-archive-o: \"\\f1c6\";\n@fa-var-file-audio-o: \"\\f1c7\";\n@fa-var-file-code-o: \"\\f1c9\";\n@fa-var-file-excel-o: \"\\f1c3\";\n@fa-var-file-image-o: \"\\f1c5\";\n@fa-var-file-movie-o: \"\\f1c8\";\n@fa-var-file-o: \"\\f016\";\n@fa-var-file-pdf-o: \"\\f1c1\";\n@fa-var-file-photo-o: \"\\f1c5\";\n@fa-var-file-picture-o: \"\\f1c5\";\n@fa-var-file-powerpoint-o: \"\\f1c4\";\n@fa-var-file-sound-o: \"\\f1c7\";\n@fa-var-file-text: \"\\f15c\";\n@fa-var-file-text-o: \"\\f0f6\";\n@fa-var-file-video-o: \"\\f1c8\";\n@fa-var-file-word-o: \"\\f1c2\";\n@fa-var-file-zip-o: \"\\f1c6\";\n@fa-var-files-o: \"\\f0c5\";\n@fa-var-film: \"\\f008\";\n@fa-var-filter: \"\\f0b0\";\n@fa-var-fire: \"\\f06d\";\n@fa-var-fire-extinguisher: \"\\f134\";\n@fa-var-firefox: \"\\f269\";\n@fa-var-flag: \"\\f024\";\n@fa-var-flag-checkered: \"\\f11e\";\n@fa-var-flag-o: \"\\f11d\";\n@fa-var-flash: \"\\f0e7\";\n@fa-var-flask: \"\\f0c3\";\n@fa-var-flickr: \"\\f16e\";\n@fa-var-floppy-o: \"\\f0c7\";\n@fa-var-folder: \"\\f07b\";\n@fa-var-folder-o: \"\\f114\";\n@fa-var-folder-open: \"\\f07c\";\n@fa-var-folder-open-o: \"\\f115\";\n@fa-var-font: \"\\f031\";\n@fa-var-fonticons: \"\\f280\";\n@fa-var-fort-awesome: \"\\f286\";\n@fa-var-forumbee: \"\\f211\";\n@fa-var-forward: \"\\f04e\";\n@fa-var-foursquare: \"\\f180\";\n@fa-var-frown-o: \"\\f119\";\n@fa-var-futbol-o: \"\\f1e3\";\n@fa-var-gamepad: \"\\f11b\";\n@fa-var-gavel: \"\\f0e3\";\n@fa-var-gbp: \"\\f154\";\n@fa-var-ge: \"\\f1d1\";\n@fa-var-gear: \"\\f013\";\n@fa-var-gears: \"\\f085\";\n@fa-var-genderless: \"\\f22d\";\n@fa-var-get-pocket: \"\\f265\";\n@fa-var-gg: \"\\f260\";\n@fa-var-gg-circle: \"\\f261\";\n@fa-var-gift: \"\\f06b\";\n@fa-var-git: \"\\f1d3\";\n@fa-var-git-square: \"\\f1d2\";\n@fa-var-github: \"\\f09b\";\n@fa-var-github-alt: \"\\f113\";\n@fa-var-github-square: \"\\f092\";\n@fa-var-gittip: \"\\f184\";\n@fa-var-glass: \"\\f000\";\n@fa-var-globe: \"\\f0ac\";\n@fa-var-google: \"\\f1a0\";\n@fa-var-google-plus: \"\\f0d5\";\n@fa-var-google-plus-square: \"\\f0d4\";\n@fa-var-google-wallet: \"\\f1ee\";\n@fa-var-graduation-cap: \"\\f19d\";\n@fa-var-gratipay: \"\\f184\";\n@fa-var-group: \"\\f0c0\";\n@fa-var-h-square: \"\\f0fd\";\n@fa-var-hacker-news: \"\\f1d4\";\n@fa-var-hand-grab-o: \"\\f255\";\n@fa-var-hand-lizard-o: \"\\f258\";\n@fa-var-hand-o-down: \"\\f0a7\";\n@fa-var-hand-o-left: \"\\f0a5\";\n@fa-var-hand-o-right: \"\\f0a4\";\n@fa-var-hand-o-up: \"\\f0a6\";\n@fa-var-hand-paper-o: \"\\f256\";\n@fa-var-hand-peace-o: \"\\f25b\";\n@fa-var-hand-pointer-o: \"\\f25a\";\n@fa-var-hand-rock-o: \"\\f255\";\n@fa-var-hand-scissors-o: \"\\f257\";\n@fa-var-hand-spock-o: \"\\f259\";\n@fa-var-hand-stop-o: \"\\f256\";\n@fa-var-hashtag: \"\\f292\";\n@fa-var-hdd-o: \"\\f0a0\";\n@fa-var-header: \"\\f1dc\";\n@fa-var-headphones: \"\\f025\";\n@fa-var-heart: \"\\f004\";\n@fa-var-heart-o: \"\\f08a\";\n@fa-var-heartbeat: \"\\f21e\";\n@fa-var-history: \"\\f1da\";\n@fa-var-home: \"\\f015\";\n@fa-var-hospital-o: \"\\f0f8\";\n@fa-var-hotel: \"\\f236\";\n@fa-var-hourglass: \"\\f254\";\n@fa-var-hourglass-1: \"\\f251\";\n@fa-var-hourglass-2: \"\\f252\";\n@fa-var-hourglass-3: \"\\f253\";\n@fa-var-hourglass-end: \"\\f253\";\n@fa-var-hourglass-half: \"\\f252\";\n@fa-var-hourglass-o: \"\\f250\";\n@fa-var-hourglass-start: \"\\f251\";\n@fa-var-houzz: \"\\f27c\";\n@fa-var-html5: \"\\f13b\";\n@fa-var-i-cursor: \"\\f246\";\n@fa-var-ils: \"\\f20b\";\n@fa-var-image: \"\\f03e\";\n@fa-var-inbox: \"\\f01c\";\n@fa-var-indent: \"\\f03c\";\n@fa-var-industry: \"\\f275\";\n@fa-var-info: \"\\f129\";\n@fa-var-info-circle: \"\\f05a\";\n@fa-var-inr: \"\\f156\";\n@fa-var-instagram: \"\\f16d\";\n@fa-var-institution: \"\\f19c\";\n@fa-var-internet-explorer: \"\\f26b\";\n@fa-var-intersex: \"\\f224\";\n@fa-var-ioxhost: \"\\f208\";\n@fa-var-italic: \"\\f033\";\n@fa-var-joomla: \"\\f1aa\";\n@fa-var-jpy: \"\\f157\";\n@fa-var-jsfiddle: \"\\f1cc\";\n@fa-var-key: \"\\f084\";\n@fa-var-keyboard-o: \"\\f11c\";\n@fa-var-krw: \"\\f159\";\n@fa-var-language: \"\\f1ab\";\n@fa-var-laptop: \"\\f109\";\n@fa-var-lastfm: \"\\f202\";\n@fa-var-lastfm-square: \"\\f203\";\n@fa-var-leaf: \"\\f06c\";\n@fa-var-leanpub: \"\\f212\";\n@fa-var-legal: \"\\f0e3\";\n@fa-var-lemon-o: \"\\f094\";\n@fa-var-level-down: \"\\f149\";\n@fa-var-level-up: \"\\f148\";\n@fa-var-life-bouy: \"\\f1cd\";\n@fa-var-life-buoy: \"\\f1cd\";\n@fa-var-life-ring: \"\\f1cd\";\n@fa-var-life-saver: \"\\f1cd\";\n@fa-var-lightbulb-o: \"\\f0eb\";\n@fa-var-line-chart: \"\\f201\";\n@fa-var-link: \"\\f0c1\";\n@fa-var-linkedin: \"\\f0e1\";\n@fa-var-linkedin-square: \"\\f08c\";\n@fa-var-linux: \"\\f17c\";\n@fa-var-list: \"\\f03a\";\n@fa-var-list-alt: \"\\f022\";\n@fa-var-list-ol: \"\\f0cb\";\n@fa-var-list-ul: \"\\f0ca\";\n@fa-var-location-arrow: \"\\f124\";\n@fa-var-lock: \"\\f023\";\n@fa-var-long-arrow-down: \"\\f175\";\n@fa-var-long-arrow-left: \"\\f177\";\n@fa-var-long-arrow-right: \"\\f178\";\n@fa-var-long-arrow-up: \"\\f176\";\n@fa-var-magic: \"\\f0d0\";\n@fa-var-magnet: \"\\f076\";\n@fa-var-mail-forward: \"\\f064\";\n@fa-var-mail-reply: \"\\f112\";\n@fa-var-mail-reply-all: \"\\f122\";\n@fa-var-male: \"\\f183\";\n@fa-var-map: \"\\f279\";\n@fa-var-map-marker: \"\\f041\";\n@fa-var-map-o: \"\\f278\";\n@fa-var-map-pin: \"\\f276\";\n@fa-var-map-signs: \"\\f277\";\n@fa-var-mars: \"\\f222\";\n@fa-var-mars-double: \"\\f227\";\n@fa-var-mars-stroke: \"\\f229\";\n@fa-var-mars-stroke-h: \"\\f22b\";\n@fa-var-mars-stroke-v: \"\\f22a\";\n@fa-var-maxcdn: \"\\f136\";\n@fa-var-meanpath: \"\\f20c\";\n@fa-var-medium: \"\\f23a\";\n@fa-var-medkit: \"\\f0fa\";\n@fa-var-meh-o: \"\\f11a\";\n@fa-var-mercury: \"\\f223\";\n@fa-var-microphone: \"\\f130\";\n@fa-var-microphone-slash: \"\\f131\";\n@fa-var-minus: \"\\f068\";\n@fa-var-minus-circle: \"\\f056\";\n@fa-var-minus-square: \"\\f146\";\n@fa-var-minus-square-o: \"\\f147\";\n@fa-var-mixcloud: \"\\f289\";\n@fa-var-mobile: \"\\f10b\";\n@fa-var-mobile-phone: \"\\f10b\";\n@fa-var-modx: \"\\f285\";\n@fa-var-money: \"\\f0d6\";\n@fa-var-moon-o: \"\\f186\";\n@fa-var-mortar-board: \"\\f19d\";\n@fa-var-motorcycle: \"\\f21c\";\n@fa-var-mouse-pointer: \"\\f245\";\n@fa-var-music: \"\\f001\";\n@fa-var-navicon: \"\\f0c9\";\n@fa-var-neuter: \"\\f22c\";\n@fa-var-newspaper-o: \"\\f1ea\";\n@fa-var-object-group: \"\\f247\";\n@fa-var-object-ungroup: \"\\f248\";\n@fa-var-odnoklassniki: \"\\f263\";\n@fa-var-odnoklassniki-square: \"\\f264\";\n@fa-var-opencart: \"\\f23d\";\n@fa-var-openid: \"\\f19b\";\n@fa-var-opera: \"\\f26a\";\n@fa-var-optin-monster: \"\\f23c\";\n@fa-var-outdent: \"\\f03b\";\n@fa-var-pagelines: \"\\f18c\";\n@fa-var-paint-brush: \"\\f1fc\";\n@fa-var-paper-plane: \"\\f1d8\";\n@fa-var-paper-plane-o: \"\\f1d9\";\n@fa-var-paperclip: \"\\f0c6\";\n@fa-var-paragraph: \"\\f1dd\";\n@fa-var-paste: \"\\f0ea\";\n@fa-var-pause: \"\\f04c\";\n@fa-var-pause-circle: \"\\f28b\";\n@fa-var-pause-circle-o: \"\\f28c\";\n@fa-var-paw: \"\\f1b0\";\n@fa-var-paypal: \"\\f1ed\";\n@fa-var-pencil: \"\\f040\";\n@fa-var-pencil-square: \"\\f14b\";\n@fa-var-pencil-square-o: \"\\f044\";\n@fa-var-percent: \"\\f295\";\n@fa-var-phone: \"\\f095\";\n@fa-var-phone-square: \"\\f098\";\n@fa-var-photo: \"\\f03e\";\n@fa-var-picture-o: \"\\f03e\";\n@fa-var-pie-chart: \"\\f200\";\n@fa-var-pied-piper: \"\\f1a7\";\n@fa-var-pied-piper-alt: \"\\f1a8\";\n@fa-var-pinterest: \"\\f0d2\";\n@fa-var-pinterest-p: \"\\f231\";\n@fa-var-pinterest-square: \"\\f0d3\";\n@fa-var-plane: \"\\f072\";\n@fa-var-play: \"\\f04b\";\n@fa-var-play-circle: \"\\f144\";\n@fa-var-play-circle-o: \"\\f01d\";\n@fa-var-plug: \"\\f1e6\";\n@fa-var-plus: \"\\f067\";\n@fa-var-plus-circle: \"\\f055\";\n@fa-var-plus-square: \"\\f0fe\";\n@fa-var-plus-square-o: \"\\f196\";\n@fa-var-power-off: \"\\f011\";\n@fa-var-print: \"\\f02f\";\n@fa-var-product-hunt: \"\\f288\";\n@fa-var-puzzle-piece: \"\\f12e\";\n@fa-var-qq: \"\\f1d6\";\n@fa-var-qrcode: \"\\f029\";\n@fa-var-question: \"\\f128\";\n@fa-var-question-circle: \"\\f059\";\n@fa-var-quote-left: \"\\f10d\";\n@fa-var-quote-right: \"\\f10e\";\n@fa-var-ra: \"\\f1d0\";\n@fa-var-random: \"\\f074\";\n@fa-var-rebel: \"\\f1d0\";\n@fa-var-recycle: \"\\f1b8\";\n@fa-var-reddit: \"\\f1a1\";\n@fa-var-reddit-alien: \"\\f281\";\n@fa-var-reddit-square: \"\\f1a2\";\n@fa-var-refresh: \"\\f021\";\n@fa-var-registered: \"\\f25d\";\n@fa-var-remove: \"\\f00d\";\n@fa-var-renren: \"\\f18b\";\n@fa-var-reorder: \"\\f0c9\";\n@fa-var-repeat: \"\\f01e\";\n@fa-var-reply: \"\\f112\";\n@fa-var-reply-all: \"\\f122\";\n@fa-var-retweet: \"\\f079\";\n@fa-var-rmb: \"\\f157\";\n@fa-var-road: \"\\f018\";\n@fa-var-rocket: \"\\f135\";\n@fa-var-rotate-left: \"\\f0e2\";\n@fa-var-rotate-right: \"\\f01e\";\n@fa-var-rouble: \"\\f158\";\n@fa-var-rss: \"\\f09e\";\n@fa-var-rss-square: \"\\f143\";\n@fa-var-rub: \"\\f158\";\n@fa-var-ruble: \"\\f158\";\n@fa-var-rupee: \"\\f156\";\n@fa-var-safari: \"\\f267\";\n@fa-var-save: \"\\f0c7\";\n@fa-var-scissors: \"\\f0c4\";\n@fa-var-scribd: \"\\f28a\";\n@fa-var-search: \"\\f002\";\n@fa-var-search-minus: \"\\f010\";\n@fa-var-search-plus: \"\\f00e\";\n@fa-var-sellsy: \"\\f213\";\n@fa-var-send: \"\\f1d8\";\n@fa-var-send-o: \"\\f1d9\";\n@fa-var-server: \"\\f233\";\n@fa-var-share: \"\\f064\";\n@fa-var-share-alt: \"\\f1e0\";\n@fa-var-share-alt-square: \"\\f1e1\";\n@fa-var-share-square: \"\\f14d\";\n@fa-var-share-square-o: \"\\f045\";\n@fa-var-shekel: \"\\f20b\";\n@fa-var-sheqel: \"\\f20b\";\n@fa-var-shield: \"\\f132\";\n@fa-var-ship: \"\\f21a\";\n@fa-var-shirtsinbulk: \"\\f214\";\n@fa-var-shopping-bag: \"\\f290\";\n@fa-var-shopping-basket: \"\\f291\";\n@fa-var-shopping-cart: \"\\f07a\";\n@fa-var-sign-in: \"\\f090\";\n@fa-var-sign-out: \"\\f08b\";\n@fa-var-signal: \"\\f012\";\n@fa-var-simplybuilt: \"\\f215\";\n@fa-var-sitemap: \"\\f0e8\";\n@fa-var-skyatlas: \"\\f216\";\n@fa-var-skype: \"\\f17e\";\n@fa-var-slack: \"\\f198\";\n@fa-var-sliders: \"\\f1de\";\n@fa-var-slideshare: \"\\f1e7\";\n@fa-var-smile-o: \"\\f118\";\n@fa-var-soccer-ball-o: \"\\f1e3\";\n@fa-var-sort: \"\\f0dc\";\n@fa-var-sort-alpha-asc: \"\\f15d\";\n@fa-var-sort-alpha-desc: \"\\f15e\";\n@fa-var-sort-amount-asc: \"\\f160\";\n@fa-var-sort-amount-desc: \"\\f161\";\n@fa-var-sort-asc: \"\\f0de\";\n@fa-var-sort-desc: \"\\f0dd\";\n@fa-var-sort-down: \"\\f0dd\";\n@fa-var-sort-numeric-asc: \"\\f162\";\n@fa-var-sort-numeric-desc: \"\\f163\";\n@fa-var-sort-up: \"\\f0de\";\n@fa-var-soundcloud: \"\\f1be\";\n@fa-var-space-shuttle: \"\\f197\";\n@fa-var-spinner: \"\\f110\";\n@fa-var-spoon: \"\\f1b1\";\n@fa-var-spotify: \"\\f1bc\";\n@fa-var-square: \"\\f0c8\";\n@fa-var-square-o: \"\\f096\";\n@fa-var-stack-exchange: \"\\f18d\";\n@fa-var-stack-overflow: \"\\f16c\";\n@fa-var-star: \"\\f005\";\n@fa-var-star-half: \"\\f089\";\n@fa-var-star-half-empty: \"\\f123\";\n@fa-var-star-half-full: \"\\f123\";\n@fa-var-star-half-o: \"\\f123\";\n@fa-var-star-o: \"\\f006\";\n@fa-var-steam: \"\\f1b6\";\n@fa-var-steam-square: \"\\f1b7\";\n@fa-var-step-backward: \"\\f048\";\n@fa-var-step-forward: \"\\f051\";\n@fa-var-stethoscope: \"\\f0f1\";\n@fa-var-sticky-note: \"\\f249\";\n@fa-var-sticky-note-o: \"\\f24a\";\n@fa-var-stop: \"\\f04d\";\n@fa-var-stop-circle: \"\\f28d\";\n@fa-var-stop-circle-o: \"\\f28e\";\n@fa-var-street-view: \"\\f21d\";\n@fa-var-strikethrough: \"\\f0cc\";\n@fa-var-stumbleupon: \"\\f1a4\";\n@fa-var-stumbleupon-circle: \"\\f1a3\";\n@fa-var-subscript: \"\\f12c\";\n@fa-var-subway: \"\\f239\";\n@fa-var-suitcase: \"\\f0f2\";\n@fa-var-sun-o: \"\\f185\";\n@fa-var-superscript: \"\\f12b\";\n@fa-var-support: \"\\f1cd\";\n@fa-var-table: \"\\f0ce\";\n@fa-var-tablet: \"\\f10a\";\n@fa-var-tachometer: \"\\f0e4\";\n@fa-var-tag: \"\\f02b\";\n@fa-var-tags: \"\\f02c\";\n@fa-var-tasks: \"\\f0ae\";\n@fa-var-taxi: \"\\f1ba\";\n@fa-var-television: \"\\f26c\";\n@fa-var-tencent-weibo: \"\\f1d5\";\n@fa-var-terminal: \"\\f120\";\n@fa-var-text-height: \"\\f034\";\n@fa-var-text-width: \"\\f035\";\n@fa-var-th: \"\\f00a\";\n@fa-var-th-large: \"\\f009\";\n@fa-var-th-list: \"\\f00b\";\n@fa-var-thumb-tack: \"\\f08d\";\n@fa-var-thumbs-down: \"\\f165\";\n@fa-var-thumbs-o-down: \"\\f088\";\n@fa-var-thumbs-o-up: \"\\f087\";\n@fa-var-thumbs-up: \"\\f164\";\n@fa-var-ticket: \"\\f145\";\n@fa-var-times: \"\\f00d\";\n@fa-var-times-circle: \"\\f057\";\n@fa-var-times-circle-o: \"\\f05c\";\n@fa-var-tint: \"\\f043\";\n@fa-var-toggle-down: \"\\f150\";\n@fa-var-toggle-left: \"\\f191\";\n@fa-var-toggle-off: \"\\f204\";\n@fa-var-toggle-on: \"\\f205\";\n@fa-var-toggle-right: \"\\f152\";\n@fa-var-toggle-up: \"\\f151\";\n@fa-var-trademark: \"\\f25c\";\n@fa-var-train: \"\\f238\";\n@fa-var-transgender: \"\\f224\";\n@fa-var-transgender-alt: \"\\f225\";\n@fa-var-trash: \"\\f1f8\";\n@fa-var-trash-o: \"\\f014\";\n@fa-var-tree: \"\\f1bb\";\n@fa-var-trello: \"\\f181\";\n@fa-var-tripadvisor: \"\\f262\";\n@fa-var-trophy: \"\\f091\";\n@fa-var-truck: \"\\f0d1\";\n@fa-var-try: \"\\f195\";\n@fa-var-tty: \"\\f1e4\";\n@fa-var-tumblr: \"\\f173\";\n@fa-var-tumblr-square: \"\\f174\";\n@fa-var-turkish-lira: \"\\f195\";\n@fa-var-tv: \"\\f26c\";\n@fa-var-twitch: \"\\f1e8\";\n@fa-var-twitter: \"\\f099\";\n@fa-var-twitter-square: \"\\f081\";\n@fa-var-umbrella: \"\\f0e9\";\n@fa-var-underline: \"\\f0cd\";\n@fa-var-undo: \"\\f0e2\";\n@fa-var-university: \"\\f19c\";\n@fa-var-unlink: \"\\f127\";\n@fa-var-unlock: \"\\f09c\";\n@fa-var-unlock-alt: \"\\f13e\";\n@fa-var-unsorted: \"\\f0dc\";\n@fa-var-upload: \"\\f093\";\n@fa-var-usb: \"\\f287\";\n@fa-var-usd: \"\\f155\";\n@fa-var-user: \"\\f007\";\n@fa-var-user-md: \"\\f0f0\";\n@fa-var-user-plus: \"\\f234\";\n@fa-var-user-secret: \"\\f21b\";\n@fa-var-user-times: \"\\f235\";\n@fa-var-users: \"\\f0c0\";\n@fa-var-venus: \"\\f221\";\n@fa-var-venus-double: \"\\f226\";\n@fa-var-venus-mars: \"\\f228\";\n@fa-var-viacoin: \"\\f237\";\n@fa-var-video-camera: \"\\f03d\";\n@fa-var-vimeo: \"\\f27d\";\n@fa-var-vimeo-square: \"\\f194\";\n@fa-var-vine: \"\\f1ca\";\n@fa-var-vk: \"\\f189\";\n@fa-var-volume-down: \"\\f027\";\n@fa-var-volume-off: \"\\f026\";\n@fa-var-volume-up: \"\\f028\";\n@fa-var-warning: \"\\f071\";\n@fa-var-wechat: \"\\f1d7\";\n@fa-var-weibo: \"\\f18a\";\n@fa-var-weixin: \"\\f1d7\";\n@fa-var-whatsapp: \"\\f232\";\n@fa-var-wheelchair: \"\\f193\";\n@fa-var-wifi: \"\\f1eb\";\n@fa-var-wikipedia-w: \"\\f266\";\n@fa-var-windows: \"\\f17a\";\n@fa-var-won: \"\\f159\";\n@fa-var-wordpress: \"\\f19a\";\n@fa-var-wrench: \"\\f0ad\";\n@fa-var-xing: \"\\f168\";\n@fa-var-xing-square: \"\\f169\";\n@fa-var-y-combinator: \"\\f23b\";\n@fa-var-y-combinator-square: \"\\f1d4\";\n@fa-var-yahoo: \"\\f19e\";\n@fa-var-yc: \"\\f23b\";\n@fa-var-yc-square: \"\\f1d4\";\n@fa-var-yelp: \"\\f1e9\";\n@fa-var-yen: \"\\f157\";\n@fa-var-youtube: \"\\f167\";\n@fa-var-youtube-play: \"\\f16a\";\n@fa-var-youtube-square: \"\\f166\";\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_animated.scss",
    "content": "// Spinning Icons\n// --------------------------\n\n.#{$fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n.#{$fa-css-prefix}-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n          animation: fa-spin 1s infinite steps(8);\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_bordered-pulled.scss",
    "content": "// Bordered & Pulled\n// -------------------------\n\n.#{$fa-css-prefix}-border {\n  padding: .2em .25em .15em;\n  border: solid .08em $fa-border-color;\n  border-radius: .1em;\n}\n\n.#{$fa-css-prefix}-pull-left { float: left; }\n.#{$fa-css-prefix}-pull-right { float: right; }\n\n.#{$fa-css-prefix} {\n  &.#{$fa-css-prefix}-pull-left { margin-right: .3em; }\n  &.#{$fa-css-prefix}-pull-right { margin-left: .3em; }\n}\n\n/* Deprecated as of 4.4.0 */\n.pull-right { float: right; }\n.pull-left { float: left; }\n\n.#{$fa-css-prefix} {\n  &.pull-left { margin-right: .3em; }\n  &.pull-right { margin-left: .3em; }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_core.scss",
    "content": "// Base Class Definition\n// -------------------------\n\n.#{$fa-css-prefix} {\n  display: inline-block;\n  font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_extras.scss",
    "content": "/* EXTRAS\n * -------------------------- */\n\n/* Stacked and layered icon */\n\n/* Animated rotating icon */\n.#{$fa-css-prefix}-spin {\n  -webkit-animation: spin 2s infinite linear;\n  -moz-animation: spin 2s infinite linear;\n  -o-animation: spin 2s infinite linear;\n  animation: spin 2s infinite linear;\n}\n\n@-moz-keyframes spin {\n  0% { -moz-transform: rotate(0deg); }\n  100% { -moz-transform: rotate(359deg); }\n}\n@-webkit-keyframes spin {\n  0% { -webkit-transform: rotate(0deg); }\n  100% { -webkit-transform: rotate(359deg); }\n}\n@-o-keyframes spin {\n  0% { -o-transform: rotate(0deg); }\n  100% { -o-transform: rotate(359deg); }\n}\n@-ms-keyframes spin {\n  0% { -ms-transform: rotate(0deg); }\n  100% { -ms-transform: rotate(359deg); }\n}\n@keyframes spin {\n  0% { transform: rotate(0deg); }\n  100% { transform: rotate(359deg); }\n}\n\n\n// Icon rotations & flipping\n// -------------------------\n\n.#{$fa-css-prefix}-rotate-90  { @include fa-icon-rotate(90deg, 1);  }\n.#{$fa-css-prefix}-rotate-180 { @include fa-icon-rotate(180deg, 2); }\n.#{$fa-css-prefix}-rotate-270 { @include fa-icon-rotate(270deg, 3); }\n\n.#{$fa-css-prefix}-flip-horizontal { @include fa-icon-flip(-1, 1, 0); }\n.#{$fa-css-prefix}-flip-vertical   { @include fa-icon-flip(1, -1, 2); }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_fixed-width.scss",
    "content": "// Fixed Width Icons\n// -------------------------\n.#{$fa-css-prefix}-fw {\n  width: (18em / 14);\n  text-align: center;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_icons.scss",
    "content": "/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n\n.#{$fa-css-prefix}-glass:before { content: $fa-var-glass; }\n.#{$fa-css-prefix}-music:before { content: $fa-var-music; }\n.#{$fa-css-prefix}-search:before { content: $fa-var-search; }\n.#{$fa-css-prefix}-envelope-o:before { content: $fa-var-envelope-o; }\n.#{$fa-css-prefix}-heart:before { content: $fa-var-heart; }\n.#{$fa-css-prefix}-star:before { content: $fa-var-star; }\n.#{$fa-css-prefix}-star-o:before { content: $fa-var-star-o; }\n.#{$fa-css-prefix}-user:before { content: $fa-var-user; }\n.#{$fa-css-prefix}-film:before { content: $fa-var-film; }\n.#{$fa-css-prefix}-th-large:before { content: $fa-var-th-large; }\n.#{$fa-css-prefix}-th:before { content: $fa-var-th; }\n.#{$fa-css-prefix}-th-list:before { content: $fa-var-th-list; }\n.#{$fa-css-prefix}-check:before { content: $fa-var-check; }\n.#{$fa-css-prefix}-remove:before,\n.#{$fa-css-prefix}-close:before,\n.#{$fa-css-prefix}-times:before { content: $fa-var-times; }\n.#{$fa-css-prefix}-search-plus:before { content: $fa-var-search-plus; }\n.#{$fa-css-prefix}-search-minus:before { content: $fa-var-search-minus; }\n.#{$fa-css-prefix}-power-off:before { content: $fa-var-power-off; }\n.#{$fa-css-prefix}-signal:before { content: $fa-var-signal; }\n.#{$fa-css-prefix}-gear:before,\n.#{$fa-css-prefix}-cog:before { content: $fa-var-cog; }\n.#{$fa-css-prefix}-trash-o:before { content: $fa-var-trash-o; }\n.#{$fa-css-prefix}-home:before { content: $fa-var-home; }\n.#{$fa-css-prefix}-file-o:before { content: $fa-var-file-o; }\n.#{$fa-css-prefix}-clock-o:before { content: $fa-var-clock-o; }\n.#{$fa-css-prefix}-road:before { content: $fa-var-road; }\n.#{$fa-css-prefix}-download:before { content: $fa-var-download; }\n.#{$fa-css-prefix}-arrow-circle-o-down:before { content: $fa-var-arrow-circle-o-down; }\n.#{$fa-css-prefix}-arrow-circle-o-up:before { content: $fa-var-arrow-circle-o-up; }\n.#{$fa-css-prefix}-inbox:before { content: $fa-var-inbox; }\n.#{$fa-css-prefix}-play-circle-o:before { content: $fa-var-play-circle-o; }\n.#{$fa-css-prefix}-rotate-right:before,\n.#{$fa-css-prefix}-repeat:before { content: $fa-var-repeat; }\n.#{$fa-css-prefix}-refresh:before { content: $fa-var-refresh; }\n.#{$fa-css-prefix}-list-alt:before { content: $fa-var-list-alt; }\n.#{$fa-css-prefix}-lock:before { content: $fa-var-lock; }\n.#{$fa-css-prefix}-flag:before { content: $fa-var-flag; }\n.#{$fa-css-prefix}-headphones:before { content: $fa-var-headphones; }\n.#{$fa-css-prefix}-volume-off:before { content: $fa-var-volume-off; }\n.#{$fa-css-prefix}-volume-down:before { content: $fa-var-volume-down; }\n.#{$fa-css-prefix}-volume-up:before { content: $fa-var-volume-up; }\n.#{$fa-css-prefix}-qrcode:before { content: $fa-var-qrcode; }\n.#{$fa-css-prefix}-barcode:before { content: $fa-var-barcode; }\n.#{$fa-css-prefix}-tag:before { content: $fa-var-tag; }\n.#{$fa-css-prefix}-tags:before { content: $fa-var-tags; }\n.#{$fa-css-prefix}-book:before { content: $fa-var-book; }\n.#{$fa-css-prefix}-bookmark:before { content: $fa-var-bookmark; }\n.#{$fa-css-prefix}-print:before { content: $fa-var-print; }\n.#{$fa-css-prefix}-camera:before { content: $fa-var-camera; }\n.#{$fa-css-prefix}-font:before { content: $fa-var-font; }\n.#{$fa-css-prefix}-bold:before { content: $fa-var-bold; }\n.#{$fa-css-prefix}-italic:before { content: $fa-var-italic; }\n.#{$fa-css-prefix}-text-height:before { content: $fa-var-text-height; }\n.#{$fa-css-prefix}-text-width:before { content: $fa-var-text-width; }\n.#{$fa-css-prefix}-align-left:before { content: $fa-var-align-left; }\n.#{$fa-css-prefix}-align-center:before { content: $fa-var-align-center; }\n.#{$fa-css-prefix}-align-right:before { content: $fa-var-align-right; }\n.#{$fa-css-prefix}-align-justify:before { content: $fa-var-align-justify; }\n.#{$fa-css-prefix}-list:before { content: $fa-var-list; }\n.#{$fa-css-prefix}-dedent:before,\n.#{$fa-css-prefix}-outdent:before { content: $fa-var-outdent; }\n.#{$fa-css-prefix}-indent:before { content: $fa-var-indent; }\n.#{$fa-css-prefix}-video-camera:before { content: $fa-var-video-camera; }\n.#{$fa-css-prefix}-photo:before,\n.#{$fa-css-prefix}-image:before,\n.#{$fa-css-prefix}-picture-o:before { content: $fa-var-picture-o; }\n.#{$fa-css-prefix}-pencil:before { content: $fa-var-pencil; }\n.#{$fa-css-prefix}-map-marker:before { content: $fa-var-map-marker; }\n.#{$fa-css-prefix}-adjust:before { content: $fa-var-adjust; }\n.#{$fa-css-prefix}-tint:before { content: $fa-var-tint; }\n.#{$fa-css-prefix}-edit:before,\n.#{$fa-css-prefix}-pencil-square-o:before { content: $fa-var-pencil-square-o; }\n.#{$fa-css-prefix}-share-square-o:before { content: $fa-var-share-square-o; }\n.#{$fa-css-prefix}-check-square-o:before { content: $fa-var-check-square-o; }\n.#{$fa-css-prefix}-arrows:before { content: $fa-var-arrows; }\n.#{$fa-css-prefix}-step-backward:before { content: $fa-var-step-backward; }\n.#{$fa-css-prefix}-fast-backward:before { content: $fa-var-fast-backward; }\n.#{$fa-css-prefix}-backward:before { content: $fa-var-backward; }\n.#{$fa-css-prefix}-play:before { content: $fa-var-play; }\n.#{$fa-css-prefix}-pause:before { content: $fa-var-pause; }\n.#{$fa-css-prefix}-stop:before { content: $fa-var-stop; }\n.#{$fa-css-prefix}-forward:before { content: $fa-var-forward; }\n.#{$fa-css-prefix}-fast-forward:before { content: $fa-var-fast-forward; }\n.#{$fa-css-prefix}-step-forward:before { content: $fa-var-step-forward; }\n.#{$fa-css-prefix}-eject:before { content: $fa-var-eject; }\n.#{$fa-css-prefix}-chevron-left:before { content: $fa-var-chevron-left; }\n.#{$fa-css-prefix}-chevron-right:before { content: $fa-var-chevron-right; }\n.#{$fa-css-prefix}-plus-circle:before { content: $fa-var-plus-circle; }\n.#{$fa-css-prefix}-minus-circle:before { content: $fa-var-minus-circle; }\n.#{$fa-css-prefix}-times-circle:before { content: $fa-var-times-circle; }\n.#{$fa-css-prefix}-check-circle:before { content: $fa-var-check-circle; }\n.#{$fa-css-prefix}-question-circle:before { content: $fa-var-question-circle; }\n.#{$fa-css-prefix}-info-circle:before { content: $fa-var-info-circle; }\n.#{$fa-css-prefix}-crosshairs:before { content: $fa-var-crosshairs; }\n.#{$fa-css-prefix}-times-circle-o:before { content: $fa-var-times-circle-o; }\n.#{$fa-css-prefix}-check-circle-o:before { content: $fa-var-check-circle-o; }\n.#{$fa-css-prefix}-ban:before { content: $fa-var-ban; }\n.#{$fa-css-prefix}-arrow-left:before { content: $fa-var-arrow-left; }\n.#{$fa-css-prefix}-arrow-right:before { content: $fa-var-arrow-right; }\n.#{$fa-css-prefix}-arrow-up:before { content: $fa-var-arrow-up; }\n.#{$fa-css-prefix}-arrow-down:before { content: $fa-var-arrow-down; }\n.#{$fa-css-prefix}-mail-forward:before,\n.#{$fa-css-prefix}-share:before { content: $fa-var-share; }\n.#{$fa-css-prefix}-expand:before { content: $fa-var-expand; }\n.#{$fa-css-prefix}-compress:before { content: $fa-var-compress; }\n.#{$fa-css-prefix}-plus:before { content: $fa-var-plus; }\n.#{$fa-css-prefix}-minus:before { content: $fa-var-minus; }\n.#{$fa-css-prefix}-asterisk:before { content: $fa-var-asterisk; }\n.#{$fa-css-prefix}-exclamation-circle:before { content: $fa-var-exclamation-circle; }\n.#{$fa-css-prefix}-gift:before { content: $fa-var-gift; }\n.#{$fa-css-prefix}-leaf:before { content: $fa-var-leaf; }\n.#{$fa-css-prefix}-fire:before { content: $fa-var-fire; }\n.#{$fa-css-prefix}-eye:before { content: $fa-var-eye; }\n.#{$fa-css-prefix}-eye-slash:before { content: $fa-var-eye-slash; }\n.#{$fa-css-prefix}-warning:before,\n.#{$fa-css-prefix}-exclamation-triangle:before { content: $fa-var-exclamation-triangle; }\n.#{$fa-css-prefix}-plane:before { content: $fa-var-plane; }\n.#{$fa-css-prefix}-calendar:before { content: $fa-var-calendar; }\n.#{$fa-css-prefix}-random:before { content: $fa-var-random; }\n.#{$fa-css-prefix}-comment:before { content: $fa-var-comment; }\n.#{$fa-css-prefix}-magnet:before { content: $fa-var-magnet; }\n.#{$fa-css-prefix}-chevron-up:before { content: $fa-var-chevron-up; }\n.#{$fa-css-prefix}-chevron-down:before { content: $fa-var-chevron-down; }\n.#{$fa-css-prefix}-retweet:before { content: $fa-var-retweet; }\n.#{$fa-css-prefix}-shopping-cart:before { content: $fa-var-shopping-cart; }\n.#{$fa-css-prefix}-folder:before { content: $fa-var-folder; }\n.#{$fa-css-prefix}-folder-open:before { content: $fa-var-folder-open; }\n.#{$fa-css-prefix}-arrows-v:before { content: $fa-var-arrows-v; }\n.#{$fa-css-prefix}-arrows-h:before { content: $fa-var-arrows-h; }\n.#{$fa-css-prefix}-bar-chart-o:before,\n.#{$fa-css-prefix}-bar-chart:before { content: $fa-var-bar-chart; }\n.#{$fa-css-prefix}-twitter-square:before { content: $fa-var-twitter-square; }\n.#{$fa-css-prefix}-facebook-square:before { content: $fa-var-facebook-square; }\n.#{$fa-css-prefix}-camera-retro:before { content: $fa-var-camera-retro; }\n.#{$fa-css-prefix}-key:before { content: $fa-var-key; }\n.#{$fa-css-prefix}-gears:before,\n.#{$fa-css-prefix}-cogs:before { content: $fa-var-cogs; }\n.#{$fa-css-prefix}-comments:before { content: $fa-var-comments; }\n.#{$fa-css-prefix}-thumbs-o-up:before { content: $fa-var-thumbs-o-up; }\n.#{$fa-css-prefix}-thumbs-o-down:before { content: $fa-var-thumbs-o-down; }\n.#{$fa-css-prefix}-star-half:before { content: $fa-var-star-half; }\n.#{$fa-css-prefix}-heart-o:before { content: $fa-var-heart-o; }\n.#{$fa-css-prefix}-sign-out:before { content: $fa-var-sign-out; }\n.#{$fa-css-prefix}-linkedin-square:before { content: $fa-var-linkedin-square; }\n.#{$fa-css-prefix}-thumb-tack:before { content: $fa-var-thumb-tack; }\n.#{$fa-css-prefix}-external-link:before { content: $fa-var-external-link; }\n.#{$fa-css-prefix}-sign-in:before { content: $fa-var-sign-in; }\n.#{$fa-css-prefix}-trophy:before { content: $fa-var-trophy; }\n.#{$fa-css-prefix}-github-square:before { content: $fa-var-github-square; }\n.#{$fa-css-prefix}-upload:before { content: $fa-var-upload; }\n.#{$fa-css-prefix}-lemon-o:before { content: $fa-var-lemon-o; }\n.#{$fa-css-prefix}-phone:before { content: $fa-var-phone; }\n.#{$fa-css-prefix}-square-o:before { content: $fa-var-square-o; }\n.#{$fa-css-prefix}-bookmark-o:before { content: $fa-var-bookmark-o; }\n.#{$fa-css-prefix}-phone-square:before { content: $fa-var-phone-square; }\n.#{$fa-css-prefix}-twitter:before { content: $fa-var-twitter; }\n.#{$fa-css-prefix}-facebook-f:before,\n.#{$fa-css-prefix}-facebook:before { content: $fa-var-facebook; }\n.#{$fa-css-prefix}-github:before { content: $fa-var-github; }\n.#{$fa-css-prefix}-unlock:before { content: $fa-var-unlock; }\n.#{$fa-css-prefix}-credit-card:before { content: $fa-var-credit-card; }\n.#{$fa-css-prefix}-feed:before,\n.#{$fa-css-prefix}-rss:before { content: $fa-var-rss; }\n.#{$fa-css-prefix}-hdd-o:before { content: $fa-var-hdd-o; }\n.#{$fa-css-prefix}-bullhorn:before { content: $fa-var-bullhorn; }\n.#{$fa-css-prefix}-bell:before { content: $fa-var-bell; }\n.#{$fa-css-prefix}-certificate:before { content: $fa-var-certificate; }\n.#{$fa-css-prefix}-hand-o-right:before { content: $fa-var-hand-o-right; }\n.#{$fa-css-prefix}-hand-o-left:before { content: $fa-var-hand-o-left; }\n.#{$fa-css-prefix}-hand-o-up:before { content: $fa-var-hand-o-up; }\n.#{$fa-css-prefix}-hand-o-down:before { content: $fa-var-hand-o-down; }\n.#{$fa-css-prefix}-arrow-circle-left:before { content: $fa-var-arrow-circle-left; }\n.#{$fa-css-prefix}-arrow-circle-right:before { content: $fa-var-arrow-circle-right; }\n.#{$fa-css-prefix}-arrow-circle-up:before { content: $fa-var-arrow-circle-up; }\n.#{$fa-css-prefix}-arrow-circle-down:before { content: $fa-var-arrow-circle-down; }\n.#{$fa-css-prefix}-globe:before { content: $fa-var-globe; }\n.#{$fa-css-prefix}-wrench:before { content: $fa-var-wrench; }\n.#{$fa-css-prefix}-tasks:before { content: $fa-var-tasks; }\n.#{$fa-css-prefix}-filter:before { content: $fa-var-filter; }\n.#{$fa-css-prefix}-briefcase:before { content: $fa-var-briefcase; }\n.#{$fa-css-prefix}-arrows-alt:before { content: $fa-var-arrows-alt; }\n.#{$fa-css-prefix}-group:before,\n.#{$fa-css-prefix}-users:before { content: $fa-var-users; }\n.#{$fa-css-prefix}-chain:before,\n.#{$fa-css-prefix}-link:before { content: $fa-var-link; }\n.#{$fa-css-prefix}-cloud:before { content: $fa-var-cloud; }\n.#{$fa-css-prefix}-flask:before { content: $fa-var-flask; }\n.#{$fa-css-prefix}-cut:before,\n.#{$fa-css-prefix}-scissors:before { content: $fa-var-scissors; }\n.#{$fa-css-prefix}-copy:before,\n.#{$fa-css-prefix}-files-o:before { content: $fa-var-files-o; }\n.#{$fa-css-prefix}-paperclip:before { content: $fa-var-paperclip; }\n.#{$fa-css-prefix}-save:before,\n.#{$fa-css-prefix}-floppy-o:before { content: $fa-var-floppy-o; }\n.#{$fa-css-prefix}-square:before { content: $fa-var-square; }\n.#{$fa-css-prefix}-navicon:before,\n.#{$fa-css-prefix}-reorder:before,\n.#{$fa-css-prefix}-bars:before { content: $fa-var-bars; }\n.#{$fa-css-prefix}-list-ul:before { content: $fa-var-list-ul; }\n.#{$fa-css-prefix}-list-ol:before { content: $fa-var-list-ol; }\n.#{$fa-css-prefix}-strikethrough:before { content: $fa-var-strikethrough; }\n.#{$fa-css-prefix}-underline:before { content: $fa-var-underline; }\n.#{$fa-css-prefix}-table:before { content: $fa-var-table; }\n.#{$fa-css-prefix}-magic:before { content: $fa-var-magic; }\n.#{$fa-css-prefix}-truck:before { content: $fa-var-truck; }\n.#{$fa-css-prefix}-pinterest:before { content: $fa-var-pinterest; }\n.#{$fa-css-prefix}-pinterest-square:before { content: $fa-var-pinterest-square; }\n.#{$fa-css-prefix}-google-plus-square:before { content: $fa-var-google-plus-square; }\n.#{$fa-css-prefix}-google-plus:before { content: $fa-var-google-plus; }\n.#{$fa-css-prefix}-money:before { content: $fa-var-money; }\n.#{$fa-css-prefix}-caret-down:before { content: $fa-var-caret-down; }\n.#{$fa-css-prefix}-caret-up:before { content: $fa-var-caret-up; }\n.#{$fa-css-prefix}-caret-left:before { content: $fa-var-caret-left; }\n.#{$fa-css-prefix}-caret-right:before { content: $fa-var-caret-right; }\n.#{$fa-css-prefix}-columns:before { content: $fa-var-columns; }\n.#{$fa-css-prefix}-unsorted:before,\n.#{$fa-css-prefix}-sort:before { content: $fa-var-sort; }\n.#{$fa-css-prefix}-sort-down:before,\n.#{$fa-css-prefix}-sort-desc:before { content: $fa-var-sort-desc; }\n.#{$fa-css-prefix}-sort-up:before,\n.#{$fa-css-prefix}-sort-asc:before { content: $fa-var-sort-asc; }\n.#{$fa-css-prefix}-envelope:before { content: $fa-var-envelope; }\n.#{$fa-css-prefix}-linkedin:before { content: $fa-var-linkedin; }\n.#{$fa-css-prefix}-rotate-left:before,\n.#{$fa-css-prefix}-undo:before { content: $fa-var-undo; }\n.#{$fa-css-prefix}-legal:before,\n.#{$fa-css-prefix}-gavel:before { content: $fa-var-gavel; }\n.#{$fa-css-prefix}-dashboard:before,\n.#{$fa-css-prefix}-tachometer:before { content: $fa-var-tachometer; }\n.#{$fa-css-prefix}-comment-o:before { content: $fa-var-comment-o; }\n.#{$fa-css-prefix}-comments-o:before { content: $fa-var-comments-o; }\n.#{$fa-css-prefix}-flash:before,\n.#{$fa-css-prefix}-bolt:before { content: $fa-var-bolt; }\n.#{$fa-css-prefix}-sitemap:before { content: $fa-var-sitemap; }\n.#{$fa-css-prefix}-umbrella:before { content: $fa-var-umbrella; }\n.#{$fa-css-prefix}-paste:before,\n.#{$fa-css-prefix}-clipboard:before { content: $fa-var-clipboard; }\n.#{$fa-css-prefix}-lightbulb-o:before { content: $fa-var-lightbulb-o; }\n.#{$fa-css-prefix}-exchange:before { content: $fa-var-exchange; }\n.#{$fa-css-prefix}-cloud-download:before { content: $fa-var-cloud-download; }\n.#{$fa-css-prefix}-cloud-upload:before { content: $fa-var-cloud-upload; }\n.#{$fa-css-prefix}-user-md:before { content: $fa-var-user-md; }\n.#{$fa-css-prefix}-stethoscope:before { content: $fa-var-stethoscope; }\n.#{$fa-css-prefix}-suitcase:before { content: $fa-var-suitcase; }\n.#{$fa-css-prefix}-bell-o:before { content: $fa-var-bell-o; }\n.#{$fa-css-prefix}-coffee:before { content: $fa-var-coffee; }\n.#{$fa-css-prefix}-cutlery:before { content: $fa-var-cutlery; }\n.#{$fa-css-prefix}-file-text-o:before { content: $fa-var-file-text-o; }\n.#{$fa-css-prefix}-building-o:before { content: $fa-var-building-o; }\n.#{$fa-css-prefix}-hospital-o:before { content: $fa-var-hospital-o; }\n.#{$fa-css-prefix}-ambulance:before { content: $fa-var-ambulance; }\n.#{$fa-css-prefix}-medkit:before { content: $fa-var-medkit; }\n.#{$fa-css-prefix}-fighter-jet:before { content: $fa-var-fighter-jet; }\n.#{$fa-css-prefix}-beer:before { content: $fa-var-beer; }\n.#{$fa-css-prefix}-h-square:before { content: $fa-var-h-square; }\n.#{$fa-css-prefix}-plus-square:before { content: $fa-var-plus-square; }\n.#{$fa-css-prefix}-angle-double-left:before { content: $fa-var-angle-double-left; }\n.#{$fa-css-prefix}-angle-double-right:before { content: $fa-var-angle-double-right; }\n.#{$fa-css-prefix}-angle-double-up:before { content: $fa-var-angle-double-up; }\n.#{$fa-css-prefix}-angle-double-down:before { content: $fa-var-angle-double-down; }\n.#{$fa-css-prefix}-angle-left:before { content: $fa-var-angle-left; }\n.#{$fa-css-prefix}-angle-right:before { content: $fa-var-angle-right; }\n.#{$fa-css-prefix}-angle-up:before { content: $fa-var-angle-up; }\n.#{$fa-css-prefix}-angle-down:before { content: $fa-var-angle-down; }\n.#{$fa-css-prefix}-desktop:before { content: $fa-var-desktop; }\n.#{$fa-css-prefix}-laptop:before { content: $fa-var-laptop; }\n.#{$fa-css-prefix}-tablet:before { content: $fa-var-tablet; }\n.#{$fa-css-prefix}-mobile-phone:before,\n.#{$fa-css-prefix}-mobile:before { content: $fa-var-mobile; }\n.#{$fa-css-prefix}-circle-o:before { content: $fa-var-circle-o; }\n.#{$fa-css-prefix}-quote-left:before { content: $fa-var-quote-left; }\n.#{$fa-css-prefix}-quote-right:before { content: $fa-var-quote-right; }\n.#{$fa-css-prefix}-spinner:before { content: $fa-var-spinner; }\n.#{$fa-css-prefix}-circle:before { content: $fa-var-circle; }\n.#{$fa-css-prefix}-mail-reply:before,\n.#{$fa-css-prefix}-reply:before { content: $fa-var-reply; }\n.#{$fa-css-prefix}-github-alt:before { content: $fa-var-github-alt; }\n.#{$fa-css-prefix}-folder-o:before { content: $fa-var-folder-o; }\n.#{$fa-css-prefix}-folder-open-o:before { content: $fa-var-folder-open-o; }\n.#{$fa-css-prefix}-smile-o:before { content: $fa-var-smile-o; }\n.#{$fa-css-prefix}-frown-o:before { content: $fa-var-frown-o; }\n.#{$fa-css-prefix}-meh-o:before { content: $fa-var-meh-o; }\n.#{$fa-css-prefix}-gamepad:before { content: $fa-var-gamepad; }\n.#{$fa-css-prefix}-keyboard-o:before { content: $fa-var-keyboard-o; }\n.#{$fa-css-prefix}-flag-o:before { content: $fa-var-flag-o; }\n.#{$fa-css-prefix}-flag-checkered:before { content: $fa-var-flag-checkered; }\n.#{$fa-css-prefix}-terminal:before { content: $fa-var-terminal; }\n.#{$fa-css-prefix}-code:before { content: $fa-var-code; }\n.#{$fa-css-prefix}-mail-reply-all:before,\n.#{$fa-css-prefix}-reply-all:before { content: $fa-var-reply-all; }\n.#{$fa-css-prefix}-star-half-empty:before,\n.#{$fa-css-prefix}-star-half-full:before,\n.#{$fa-css-prefix}-star-half-o:before { content: $fa-var-star-half-o; }\n.#{$fa-css-prefix}-location-arrow:before { content: $fa-var-location-arrow; }\n.#{$fa-css-prefix}-crop:before { content: $fa-var-crop; }\n.#{$fa-css-prefix}-code-fork:before { content: $fa-var-code-fork; }\n.#{$fa-css-prefix}-unlink:before,\n.#{$fa-css-prefix}-chain-broken:before { content: $fa-var-chain-broken; }\n.#{$fa-css-prefix}-question:before { content: $fa-var-question; }\n.#{$fa-css-prefix}-info:before { content: $fa-var-info; }\n.#{$fa-css-prefix}-exclamation:before { content: $fa-var-exclamation; }\n.#{$fa-css-prefix}-superscript:before { content: $fa-var-superscript; }\n.#{$fa-css-prefix}-subscript:before { content: $fa-var-subscript; }\n.#{$fa-css-prefix}-eraser:before { content: $fa-var-eraser; }\n.#{$fa-css-prefix}-puzzle-piece:before { content: $fa-var-puzzle-piece; }\n.#{$fa-css-prefix}-microphone:before { content: $fa-var-microphone; }\n.#{$fa-css-prefix}-microphone-slash:before { content: $fa-var-microphone-slash; }\n.#{$fa-css-prefix}-shield:before { content: $fa-var-shield; }\n.#{$fa-css-prefix}-calendar-o:before { content: $fa-var-calendar-o; }\n.#{$fa-css-prefix}-fire-extinguisher:before { content: $fa-var-fire-extinguisher; }\n.#{$fa-css-prefix}-rocket:before { content: $fa-var-rocket; }\n.#{$fa-css-prefix}-maxcdn:before { content: $fa-var-maxcdn; }\n.#{$fa-css-prefix}-chevron-circle-left:before { content: $fa-var-chevron-circle-left; }\n.#{$fa-css-prefix}-chevron-circle-right:before { content: $fa-var-chevron-circle-right; }\n.#{$fa-css-prefix}-chevron-circle-up:before { content: $fa-var-chevron-circle-up; }\n.#{$fa-css-prefix}-chevron-circle-down:before { content: $fa-var-chevron-circle-down; }\n.#{$fa-css-prefix}-html5:before { content: $fa-var-html5; }\n.#{$fa-css-prefix}-css3:before { content: $fa-var-css3; }\n.#{$fa-css-prefix}-anchor:before { content: $fa-var-anchor; }\n.#{$fa-css-prefix}-unlock-alt:before { content: $fa-var-unlock-alt; }\n.#{$fa-css-prefix}-bullseye:before { content: $fa-var-bullseye; }\n.#{$fa-css-prefix}-ellipsis-h:before { content: $fa-var-ellipsis-h; }\n.#{$fa-css-prefix}-ellipsis-v:before { content: $fa-var-ellipsis-v; }\n.#{$fa-css-prefix}-rss-square:before { content: $fa-var-rss-square; }\n.#{$fa-css-prefix}-play-circle:before { content: $fa-var-play-circle; }\n.#{$fa-css-prefix}-ticket:before { content: $fa-var-ticket; }\n.#{$fa-css-prefix}-minus-square:before { content: $fa-var-minus-square; }\n.#{$fa-css-prefix}-minus-square-o:before { content: $fa-var-minus-square-o; }\n.#{$fa-css-prefix}-level-up:before { content: $fa-var-level-up; }\n.#{$fa-css-prefix}-level-down:before { content: $fa-var-level-down; }\n.#{$fa-css-prefix}-check-square:before { content: $fa-var-check-square; }\n.#{$fa-css-prefix}-pencil-square:before { content: $fa-var-pencil-square; }\n.#{$fa-css-prefix}-external-link-square:before { content: $fa-var-external-link-square; }\n.#{$fa-css-prefix}-share-square:before { content: $fa-var-share-square; }\n.#{$fa-css-prefix}-compass:before { content: $fa-var-compass; }\n.#{$fa-css-prefix}-toggle-down:before,\n.#{$fa-css-prefix}-caret-square-o-down:before { content: $fa-var-caret-square-o-down; }\n.#{$fa-css-prefix}-toggle-up:before,\n.#{$fa-css-prefix}-caret-square-o-up:before { content: $fa-var-caret-square-o-up; }\n.#{$fa-css-prefix}-toggle-right:before,\n.#{$fa-css-prefix}-caret-square-o-right:before { content: $fa-var-caret-square-o-right; }\n.#{$fa-css-prefix}-euro:before,\n.#{$fa-css-prefix}-eur:before { content: $fa-var-eur; }\n.#{$fa-css-prefix}-gbp:before { content: $fa-var-gbp; }\n.#{$fa-css-prefix}-dollar:before,\n.#{$fa-css-prefix}-usd:before { content: $fa-var-usd; }\n.#{$fa-css-prefix}-rupee:before,\n.#{$fa-css-prefix}-inr:before { content: $fa-var-inr; }\n.#{$fa-css-prefix}-cny:before,\n.#{$fa-css-prefix}-rmb:before,\n.#{$fa-css-prefix}-yen:before,\n.#{$fa-css-prefix}-jpy:before { content: $fa-var-jpy; }\n.#{$fa-css-prefix}-ruble:before,\n.#{$fa-css-prefix}-rouble:before,\n.#{$fa-css-prefix}-rub:before { content: $fa-var-rub; }\n.#{$fa-css-prefix}-won:before,\n.#{$fa-css-prefix}-krw:before { content: $fa-var-krw; }\n.#{$fa-css-prefix}-bitcoin:before,\n.#{$fa-css-prefix}-btc:before { content: $fa-var-btc; }\n.#{$fa-css-prefix}-file:before { content: $fa-var-file; }\n.#{$fa-css-prefix}-file-text:before { content: $fa-var-file-text; }\n.#{$fa-css-prefix}-sort-alpha-asc:before { content: $fa-var-sort-alpha-asc; }\n.#{$fa-css-prefix}-sort-alpha-desc:before { content: $fa-var-sort-alpha-desc; }\n.#{$fa-css-prefix}-sort-amount-asc:before { content: $fa-var-sort-amount-asc; }\n.#{$fa-css-prefix}-sort-amount-desc:before { content: $fa-var-sort-amount-desc; }\n.#{$fa-css-prefix}-sort-numeric-asc:before { content: $fa-var-sort-numeric-asc; }\n.#{$fa-css-prefix}-sort-numeric-desc:before { content: $fa-var-sort-numeric-desc; }\n.#{$fa-css-prefix}-thumbs-up:before { content: $fa-var-thumbs-up; }\n.#{$fa-css-prefix}-thumbs-down:before { content: $fa-var-thumbs-down; }\n.#{$fa-css-prefix}-youtube-square:before { content: $fa-var-youtube-square; }\n.#{$fa-css-prefix}-youtube:before { content: $fa-var-youtube; }\n.#{$fa-css-prefix}-xing:before { content: $fa-var-xing; }\n.#{$fa-css-prefix}-xing-square:before { content: $fa-var-xing-square; }\n.#{$fa-css-prefix}-youtube-play:before { content: $fa-var-youtube-play; }\n.#{$fa-css-prefix}-dropbox:before { content: $fa-var-dropbox; }\n.#{$fa-css-prefix}-stack-overflow:before { content: $fa-var-stack-overflow; }\n.#{$fa-css-prefix}-instagram:before { content: $fa-var-instagram; }\n.#{$fa-css-prefix}-flickr:before { content: $fa-var-flickr; }\n.#{$fa-css-prefix}-adn:before { content: $fa-var-adn; }\n.#{$fa-css-prefix}-bitbucket:before { content: $fa-var-bitbucket; }\n.#{$fa-css-prefix}-bitbucket-square:before { content: $fa-var-bitbucket-square; }\n.#{$fa-css-prefix}-tumblr:before { content: $fa-var-tumblr; }\n.#{$fa-css-prefix}-tumblr-square:before { content: $fa-var-tumblr-square; }\n.#{$fa-css-prefix}-long-arrow-down:before { content: $fa-var-long-arrow-down; }\n.#{$fa-css-prefix}-long-arrow-up:before { content: $fa-var-long-arrow-up; }\n.#{$fa-css-prefix}-long-arrow-left:before { content: $fa-var-long-arrow-left; }\n.#{$fa-css-prefix}-long-arrow-right:before { content: $fa-var-long-arrow-right; }\n.#{$fa-css-prefix}-apple:before { content: $fa-var-apple; }\n.#{$fa-css-prefix}-windows:before { content: $fa-var-windows; }\n.#{$fa-css-prefix}-android:before { content: $fa-var-android; }\n.#{$fa-css-prefix}-linux:before { content: $fa-var-linux; }\n.#{$fa-css-prefix}-dribbble:before { content: $fa-var-dribbble; }\n.#{$fa-css-prefix}-skype:before { content: $fa-var-skype; }\n.#{$fa-css-prefix}-foursquare:before { content: $fa-var-foursquare; }\n.#{$fa-css-prefix}-trello:before { content: $fa-var-trello; }\n.#{$fa-css-prefix}-female:before { content: $fa-var-female; }\n.#{$fa-css-prefix}-male:before { content: $fa-var-male; }\n.#{$fa-css-prefix}-gittip:before,\n.#{$fa-css-prefix}-gratipay:before { content: $fa-var-gratipay; }\n.#{$fa-css-prefix}-sun-o:before { content: $fa-var-sun-o; }\n.#{$fa-css-prefix}-moon-o:before { content: $fa-var-moon-o; }\n.#{$fa-css-prefix}-archive:before { content: $fa-var-archive; }\n.#{$fa-css-prefix}-bug:before { content: $fa-var-bug; }\n.#{$fa-css-prefix}-vk:before { content: $fa-var-vk; }\n.#{$fa-css-prefix}-weibo:before { content: $fa-var-weibo; }\n.#{$fa-css-prefix}-renren:before { content: $fa-var-renren; }\n.#{$fa-css-prefix}-pagelines:before { content: $fa-var-pagelines; }\n.#{$fa-css-prefix}-stack-exchange:before { content: $fa-var-stack-exchange; }\n.#{$fa-css-prefix}-arrow-circle-o-right:before { content: $fa-var-arrow-circle-o-right; }\n.#{$fa-css-prefix}-arrow-circle-o-left:before { content: $fa-var-arrow-circle-o-left; }\n.#{$fa-css-prefix}-toggle-left:before,\n.#{$fa-css-prefix}-caret-square-o-left:before { content: $fa-var-caret-square-o-left; }\n.#{$fa-css-prefix}-dot-circle-o:before { content: $fa-var-dot-circle-o; }\n.#{$fa-css-prefix}-wheelchair:before { content: $fa-var-wheelchair; }\n.#{$fa-css-prefix}-vimeo-square:before { content: $fa-var-vimeo-square; }\n.#{$fa-css-prefix}-turkish-lira:before,\n.#{$fa-css-prefix}-try:before { content: $fa-var-try; }\n.#{$fa-css-prefix}-plus-square-o:before { content: $fa-var-plus-square-o; }\n.#{$fa-css-prefix}-space-shuttle:before { content: $fa-var-space-shuttle; }\n.#{$fa-css-prefix}-slack:before { content: $fa-var-slack; }\n.#{$fa-css-prefix}-envelope-square:before { content: $fa-var-envelope-square; }\n.#{$fa-css-prefix}-wordpress:before { content: $fa-var-wordpress; }\n.#{$fa-css-prefix}-openid:before { content: $fa-var-openid; }\n.#{$fa-css-prefix}-institution:before,\n.#{$fa-css-prefix}-bank:before,\n.#{$fa-css-prefix}-university:before { content: $fa-var-university; }\n.#{$fa-css-prefix}-mortar-board:before,\n.#{$fa-css-prefix}-graduation-cap:before { content: $fa-var-graduation-cap; }\n.#{$fa-css-prefix}-yahoo:before { content: $fa-var-yahoo; }\n.#{$fa-css-prefix}-google:before { content: $fa-var-google; }\n.#{$fa-css-prefix}-reddit:before { content: $fa-var-reddit; }\n.#{$fa-css-prefix}-reddit-square:before { content: $fa-var-reddit-square; }\n.#{$fa-css-prefix}-stumbleupon-circle:before { content: $fa-var-stumbleupon-circle; }\n.#{$fa-css-prefix}-stumbleupon:before { content: $fa-var-stumbleupon; }\n.#{$fa-css-prefix}-delicious:before { content: $fa-var-delicious; }\n.#{$fa-css-prefix}-digg:before { content: $fa-var-digg; }\n.#{$fa-css-prefix}-pied-piper:before { content: $fa-var-pied-piper; }\n.#{$fa-css-prefix}-pied-piper-alt:before { content: $fa-var-pied-piper-alt; }\n.#{$fa-css-prefix}-drupal:before { content: $fa-var-drupal; }\n.#{$fa-css-prefix}-joomla:before { content: $fa-var-joomla; }\n.#{$fa-css-prefix}-language:before { content: $fa-var-language; }\n.#{$fa-css-prefix}-fax:before { content: $fa-var-fax; }\n.#{$fa-css-prefix}-building:before { content: $fa-var-building; }\n.#{$fa-css-prefix}-child:before { content: $fa-var-child; }\n.#{$fa-css-prefix}-paw:before { content: $fa-var-paw; }\n.#{$fa-css-prefix}-spoon:before { content: $fa-var-spoon; }\n.#{$fa-css-prefix}-cube:before { content: $fa-var-cube; }\n.#{$fa-css-prefix}-cubes:before { content: $fa-var-cubes; }\n.#{$fa-css-prefix}-behance:before { content: $fa-var-behance; }\n.#{$fa-css-prefix}-behance-square:before { content: $fa-var-behance-square; }\n.#{$fa-css-prefix}-steam:before { content: $fa-var-steam; }\n.#{$fa-css-prefix}-steam-square:before { content: $fa-var-steam-square; }\n.#{$fa-css-prefix}-recycle:before { content: $fa-var-recycle; }\n.#{$fa-css-prefix}-automobile:before,\n.#{$fa-css-prefix}-car:before { content: $fa-var-car; }\n.#{$fa-css-prefix}-cab:before,\n.#{$fa-css-prefix}-taxi:before { content: $fa-var-taxi; }\n.#{$fa-css-prefix}-tree:before { content: $fa-var-tree; }\n.#{$fa-css-prefix}-spotify:before { content: $fa-var-spotify; }\n.#{$fa-css-prefix}-deviantart:before { content: $fa-var-deviantart; }\n.#{$fa-css-prefix}-soundcloud:before { content: $fa-var-soundcloud; }\n.#{$fa-css-prefix}-database:before { content: $fa-var-database; }\n.#{$fa-css-prefix}-file-pdf-o:before { content: $fa-var-file-pdf-o; }\n.#{$fa-css-prefix}-file-word-o:before { content: $fa-var-file-word-o; }\n.#{$fa-css-prefix}-file-excel-o:before { content: $fa-var-file-excel-o; }\n.#{$fa-css-prefix}-file-powerpoint-o:before { content: $fa-var-file-powerpoint-o; }\n.#{$fa-css-prefix}-file-photo-o:before,\n.#{$fa-css-prefix}-file-picture-o:before,\n.#{$fa-css-prefix}-file-image-o:before { content: $fa-var-file-image-o; }\n.#{$fa-css-prefix}-file-zip-o:before,\n.#{$fa-css-prefix}-file-archive-o:before { content: $fa-var-file-archive-o; }\n.#{$fa-css-prefix}-file-sound-o:before,\n.#{$fa-css-prefix}-file-audio-o:before { content: $fa-var-file-audio-o; }\n.#{$fa-css-prefix}-file-movie-o:before,\n.#{$fa-css-prefix}-file-video-o:before { content: $fa-var-file-video-o; }\n.#{$fa-css-prefix}-file-code-o:before { content: $fa-var-file-code-o; }\n.#{$fa-css-prefix}-vine:before { content: $fa-var-vine; }\n.#{$fa-css-prefix}-codepen:before { content: $fa-var-codepen; }\n.#{$fa-css-prefix}-jsfiddle:before { content: $fa-var-jsfiddle; }\n.#{$fa-css-prefix}-life-bouy:before,\n.#{$fa-css-prefix}-life-buoy:before,\n.#{$fa-css-prefix}-life-saver:before,\n.#{$fa-css-prefix}-support:before,\n.#{$fa-css-prefix}-life-ring:before { content: $fa-var-life-ring; }\n.#{$fa-css-prefix}-circle-o-notch:before { content: $fa-var-circle-o-notch; }\n.#{$fa-css-prefix}-ra:before,\n.#{$fa-css-prefix}-rebel:before { content: $fa-var-rebel; }\n.#{$fa-css-prefix}-ge:before,\n.#{$fa-css-prefix}-empire:before { content: $fa-var-empire; }\n.#{$fa-css-prefix}-git-square:before { content: $fa-var-git-square; }\n.#{$fa-css-prefix}-git:before { content: $fa-var-git; }\n.#{$fa-css-prefix}-y-combinator-square:before,\n.#{$fa-css-prefix}-yc-square:before,\n.#{$fa-css-prefix}-hacker-news:before { content: $fa-var-hacker-news; }\n.#{$fa-css-prefix}-tencent-weibo:before { content: $fa-var-tencent-weibo; }\n.#{$fa-css-prefix}-qq:before { content: $fa-var-qq; }\n.#{$fa-css-prefix}-wechat:before,\n.#{$fa-css-prefix}-weixin:before { content: $fa-var-weixin; }\n.#{$fa-css-prefix}-send:before,\n.#{$fa-css-prefix}-paper-plane:before { content: $fa-var-paper-plane; }\n.#{$fa-css-prefix}-send-o:before,\n.#{$fa-css-prefix}-paper-plane-o:before { content: $fa-var-paper-plane-o; }\n.#{$fa-css-prefix}-history:before { content: $fa-var-history; }\n.#{$fa-css-prefix}-circle-thin:before { content: $fa-var-circle-thin; }\n.#{$fa-css-prefix}-header:before { content: $fa-var-header; }\n.#{$fa-css-prefix}-paragraph:before { content: $fa-var-paragraph; }\n.#{$fa-css-prefix}-sliders:before { content: $fa-var-sliders; }\n.#{$fa-css-prefix}-share-alt:before { content: $fa-var-share-alt; }\n.#{$fa-css-prefix}-share-alt-square:before { content: $fa-var-share-alt-square; }\n.#{$fa-css-prefix}-bomb:before { content: $fa-var-bomb; }\n.#{$fa-css-prefix}-soccer-ball-o:before,\n.#{$fa-css-prefix}-futbol-o:before { content: $fa-var-futbol-o; }\n.#{$fa-css-prefix}-tty:before { content: $fa-var-tty; }\n.#{$fa-css-prefix}-binoculars:before { content: $fa-var-binoculars; }\n.#{$fa-css-prefix}-plug:before { content: $fa-var-plug; }\n.#{$fa-css-prefix}-slideshare:before { content: $fa-var-slideshare; }\n.#{$fa-css-prefix}-twitch:before { content: $fa-var-twitch; }\n.#{$fa-css-prefix}-yelp:before { content: $fa-var-yelp; }\n.#{$fa-css-prefix}-newspaper-o:before { content: $fa-var-newspaper-o; }\n.#{$fa-css-prefix}-wifi:before { content: $fa-var-wifi; }\n.#{$fa-css-prefix}-calculator:before { content: $fa-var-calculator; }\n.#{$fa-css-prefix}-paypal:before { content: $fa-var-paypal; }\n.#{$fa-css-prefix}-google-wallet:before { content: $fa-var-google-wallet; }\n.#{$fa-css-prefix}-cc-visa:before { content: $fa-var-cc-visa; }\n.#{$fa-css-prefix}-cc-mastercard:before { content: $fa-var-cc-mastercard; }\n.#{$fa-css-prefix}-cc-discover:before { content: $fa-var-cc-discover; }\n.#{$fa-css-prefix}-cc-amex:before { content: $fa-var-cc-amex; }\n.#{$fa-css-prefix}-cc-paypal:before { content: $fa-var-cc-paypal; }\n.#{$fa-css-prefix}-cc-stripe:before { content: $fa-var-cc-stripe; }\n.#{$fa-css-prefix}-bell-slash:before { content: $fa-var-bell-slash; }\n.#{$fa-css-prefix}-bell-slash-o:before { content: $fa-var-bell-slash-o; }\n.#{$fa-css-prefix}-trash:before { content: $fa-var-trash; }\n.#{$fa-css-prefix}-copyright:before { content: $fa-var-copyright; }\n.#{$fa-css-prefix}-at:before { content: $fa-var-at; }\n.#{$fa-css-prefix}-eyedropper:before { content: $fa-var-eyedropper; }\n.#{$fa-css-prefix}-paint-brush:before { content: $fa-var-paint-brush; }\n.#{$fa-css-prefix}-birthday-cake:before { content: $fa-var-birthday-cake; }\n.#{$fa-css-prefix}-area-chart:before { content: $fa-var-area-chart; }\n.#{$fa-css-prefix}-pie-chart:before { content: $fa-var-pie-chart; }\n.#{$fa-css-prefix}-line-chart:before { content: $fa-var-line-chart; }\n.#{$fa-css-prefix}-lastfm:before { content: $fa-var-lastfm; }\n.#{$fa-css-prefix}-lastfm-square:before { content: $fa-var-lastfm-square; }\n.#{$fa-css-prefix}-toggle-off:before { content: $fa-var-toggle-off; }\n.#{$fa-css-prefix}-toggle-on:before { content: $fa-var-toggle-on; }\n.#{$fa-css-prefix}-bicycle:before { content: $fa-var-bicycle; }\n.#{$fa-css-prefix}-bus:before { content: $fa-var-bus; }\n.#{$fa-css-prefix}-ioxhost:before { content: $fa-var-ioxhost; }\n.#{$fa-css-prefix}-angellist:before { content: $fa-var-angellist; }\n.#{$fa-css-prefix}-cc:before { content: $fa-var-cc; }\n.#{$fa-css-prefix}-shekel:before,\n.#{$fa-css-prefix}-sheqel:before,\n.#{$fa-css-prefix}-ils:before { content: $fa-var-ils; }\n.#{$fa-css-prefix}-meanpath:before { content: $fa-var-meanpath; }\n.#{$fa-css-prefix}-buysellads:before { content: $fa-var-buysellads; }\n.#{$fa-css-prefix}-connectdevelop:before { content: $fa-var-connectdevelop; }\n.#{$fa-css-prefix}-dashcube:before { content: $fa-var-dashcube; }\n.#{$fa-css-prefix}-forumbee:before { content: $fa-var-forumbee; }\n.#{$fa-css-prefix}-leanpub:before { content: $fa-var-leanpub; }\n.#{$fa-css-prefix}-sellsy:before { content: $fa-var-sellsy; }\n.#{$fa-css-prefix}-shirtsinbulk:before { content: $fa-var-shirtsinbulk; }\n.#{$fa-css-prefix}-simplybuilt:before { content: $fa-var-simplybuilt; }\n.#{$fa-css-prefix}-skyatlas:before { content: $fa-var-skyatlas; }\n.#{$fa-css-prefix}-cart-plus:before { content: $fa-var-cart-plus; }\n.#{$fa-css-prefix}-cart-arrow-down:before { content: $fa-var-cart-arrow-down; }\n.#{$fa-css-prefix}-diamond:before { content: $fa-var-diamond; }\n.#{$fa-css-prefix}-ship:before { content: $fa-var-ship; }\n.#{$fa-css-prefix}-user-secret:before { content: $fa-var-user-secret; }\n.#{$fa-css-prefix}-motorcycle:before { content: $fa-var-motorcycle; }\n.#{$fa-css-prefix}-street-view:before { content: $fa-var-street-view; }\n.#{$fa-css-prefix}-heartbeat:before { content: $fa-var-heartbeat; }\n.#{$fa-css-prefix}-venus:before { content: $fa-var-venus; }\n.#{$fa-css-prefix}-mars:before { content: $fa-var-mars; }\n.#{$fa-css-prefix}-mercury:before { content: $fa-var-mercury; }\n.#{$fa-css-prefix}-intersex:before,\n.#{$fa-css-prefix}-transgender:before { content: $fa-var-transgender; }\n.#{$fa-css-prefix}-transgender-alt:before { content: $fa-var-transgender-alt; }\n.#{$fa-css-prefix}-venus-double:before { content: $fa-var-venus-double; }\n.#{$fa-css-prefix}-mars-double:before { content: $fa-var-mars-double; }\n.#{$fa-css-prefix}-venus-mars:before { content: $fa-var-venus-mars; }\n.#{$fa-css-prefix}-mars-stroke:before { content: $fa-var-mars-stroke; }\n.#{$fa-css-prefix}-mars-stroke-v:before { content: $fa-var-mars-stroke-v; }\n.#{$fa-css-prefix}-mars-stroke-h:before { content: $fa-var-mars-stroke-h; }\n.#{$fa-css-prefix}-neuter:before { content: $fa-var-neuter; }\n.#{$fa-css-prefix}-genderless:before { content: $fa-var-genderless; }\n.#{$fa-css-prefix}-facebook-official:before { content: $fa-var-facebook-official; }\n.#{$fa-css-prefix}-pinterest-p:before { content: $fa-var-pinterest-p; }\n.#{$fa-css-prefix}-whatsapp:before { content: $fa-var-whatsapp; }\n.#{$fa-css-prefix}-server:before { content: $fa-var-server; }\n.#{$fa-css-prefix}-user-plus:before { content: $fa-var-user-plus; }\n.#{$fa-css-prefix}-user-times:before { content: $fa-var-user-times; }\n.#{$fa-css-prefix}-hotel:before,\n.#{$fa-css-prefix}-bed:before { content: $fa-var-bed; }\n.#{$fa-css-prefix}-viacoin:before { content: $fa-var-viacoin; }\n.#{$fa-css-prefix}-train:before { content: $fa-var-train; }\n.#{$fa-css-prefix}-subway:before { content: $fa-var-subway; }\n.#{$fa-css-prefix}-medium:before { content: $fa-var-medium; }\n.#{$fa-css-prefix}-yc:before,\n.#{$fa-css-prefix}-y-combinator:before { content: $fa-var-y-combinator; }\n.#{$fa-css-prefix}-optin-monster:before { content: $fa-var-optin-monster; }\n.#{$fa-css-prefix}-opencart:before { content: $fa-var-opencart; }\n.#{$fa-css-prefix}-expeditedssl:before { content: $fa-var-expeditedssl; }\n.#{$fa-css-prefix}-battery-4:before,\n.#{$fa-css-prefix}-battery-full:before { content: $fa-var-battery-full; }\n.#{$fa-css-prefix}-battery-3:before,\n.#{$fa-css-prefix}-battery-three-quarters:before { content: $fa-var-battery-three-quarters; }\n.#{$fa-css-prefix}-battery-2:before,\n.#{$fa-css-prefix}-battery-half:before { content: $fa-var-battery-half; }\n.#{$fa-css-prefix}-battery-1:before,\n.#{$fa-css-prefix}-battery-quarter:before { content: $fa-var-battery-quarter; }\n.#{$fa-css-prefix}-battery-0:before,\n.#{$fa-css-prefix}-battery-empty:before { content: $fa-var-battery-empty; }\n.#{$fa-css-prefix}-mouse-pointer:before { content: $fa-var-mouse-pointer; }\n.#{$fa-css-prefix}-i-cursor:before { content: $fa-var-i-cursor; }\n.#{$fa-css-prefix}-object-group:before { content: $fa-var-object-group; }\n.#{$fa-css-prefix}-object-ungroup:before { content: $fa-var-object-ungroup; }\n.#{$fa-css-prefix}-sticky-note:before { content: $fa-var-sticky-note; }\n.#{$fa-css-prefix}-sticky-note-o:before { content: $fa-var-sticky-note-o; }\n.#{$fa-css-prefix}-cc-jcb:before { content: $fa-var-cc-jcb; }\n.#{$fa-css-prefix}-cc-diners-club:before { content: $fa-var-cc-diners-club; }\n.#{$fa-css-prefix}-clone:before { content: $fa-var-clone; }\n.#{$fa-css-prefix}-balance-scale:before { content: $fa-var-balance-scale; }\n.#{$fa-css-prefix}-hourglass-o:before { content: $fa-var-hourglass-o; }\n.#{$fa-css-prefix}-hourglass-1:before,\n.#{$fa-css-prefix}-hourglass-start:before { content: $fa-var-hourglass-start; }\n.#{$fa-css-prefix}-hourglass-2:before,\n.#{$fa-css-prefix}-hourglass-half:before { content: $fa-var-hourglass-half; }\n.#{$fa-css-prefix}-hourglass-3:before,\n.#{$fa-css-prefix}-hourglass-end:before { content: $fa-var-hourglass-end; }\n.#{$fa-css-prefix}-hourglass:before { content: $fa-var-hourglass; }\n.#{$fa-css-prefix}-hand-grab-o:before,\n.#{$fa-css-prefix}-hand-rock-o:before { content: $fa-var-hand-rock-o; }\n.#{$fa-css-prefix}-hand-stop-o:before,\n.#{$fa-css-prefix}-hand-paper-o:before { content: $fa-var-hand-paper-o; }\n.#{$fa-css-prefix}-hand-scissors-o:before { content: $fa-var-hand-scissors-o; }\n.#{$fa-css-prefix}-hand-lizard-o:before { content: $fa-var-hand-lizard-o; }\n.#{$fa-css-prefix}-hand-spock-o:before { content: $fa-var-hand-spock-o; }\n.#{$fa-css-prefix}-hand-pointer-o:before { content: $fa-var-hand-pointer-o; }\n.#{$fa-css-prefix}-hand-peace-o:before { content: $fa-var-hand-peace-o; }\n.#{$fa-css-prefix}-trademark:before { content: $fa-var-trademark; }\n.#{$fa-css-prefix}-registered:before { content: $fa-var-registered; }\n.#{$fa-css-prefix}-creative-commons:before { content: $fa-var-creative-commons; }\n.#{$fa-css-prefix}-gg:before { content: $fa-var-gg; }\n.#{$fa-css-prefix}-gg-circle:before { content: $fa-var-gg-circle; }\n.#{$fa-css-prefix}-tripadvisor:before { content: $fa-var-tripadvisor; }\n.#{$fa-css-prefix}-odnoklassniki:before { content: $fa-var-odnoklassniki; }\n.#{$fa-css-prefix}-odnoklassniki-square:before { content: $fa-var-odnoklassniki-square; }\n.#{$fa-css-prefix}-get-pocket:before { content: $fa-var-get-pocket; }\n.#{$fa-css-prefix}-wikipedia-w:before { content: $fa-var-wikipedia-w; }\n.#{$fa-css-prefix}-safari:before { content: $fa-var-safari; }\n.#{$fa-css-prefix}-chrome:before { content: $fa-var-chrome; }\n.#{$fa-css-prefix}-firefox:before { content: $fa-var-firefox; }\n.#{$fa-css-prefix}-opera:before { content: $fa-var-opera; }\n.#{$fa-css-prefix}-internet-explorer:before { content: $fa-var-internet-explorer; }\n.#{$fa-css-prefix}-tv:before,\n.#{$fa-css-prefix}-television:before { content: $fa-var-television; }\n.#{$fa-css-prefix}-contao:before { content: $fa-var-contao; }\n.#{$fa-css-prefix}-500px:before { content: $fa-var-500px; }\n.#{$fa-css-prefix}-amazon:before { content: $fa-var-amazon; }\n.#{$fa-css-prefix}-calendar-plus-o:before { content: $fa-var-calendar-plus-o; }\n.#{$fa-css-prefix}-calendar-minus-o:before { content: $fa-var-calendar-minus-o; }\n.#{$fa-css-prefix}-calendar-times-o:before { content: $fa-var-calendar-times-o; }\n.#{$fa-css-prefix}-calendar-check-o:before { content: $fa-var-calendar-check-o; }\n.#{$fa-css-prefix}-industry:before { content: $fa-var-industry; }\n.#{$fa-css-prefix}-map-pin:before { content: $fa-var-map-pin; }\n.#{$fa-css-prefix}-map-signs:before { content: $fa-var-map-signs; }\n.#{$fa-css-prefix}-map-o:before { content: $fa-var-map-o; }\n.#{$fa-css-prefix}-map:before { content: $fa-var-map; }\n.#{$fa-css-prefix}-commenting:before { content: $fa-var-commenting; }\n.#{$fa-css-prefix}-commenting-o:before { content: $fa-var-commenting-o; }\n.#{$fa-css-prefix}-houzz:before { content: $fa-var-houzz; }\n.#{$fa-css-prefix}-vimeo:before { content: $fa-var-vimeo; }\n.#{$fa-css-prefix}-black-tie:before { content: $fa-var-black-tie; }\n.#{$fa-css-prefix}-fonticons:before { content: $fa-var-fonticons; }\n.#{$fa-css-prefix}-reddit-alien:before { content: $fa-var-reddit-alien; }\n.#{$fa-css-prefix}-edge:before { content: $fa-var-edge; }\n.#{$fa-css-prefix}-credit-card-alt:before { content: $fa-var-credit-card-alt; }\n.#{$fa-css-prefix}-codiepie:before { content: $fa-var-codiepie; }\n.#{$fa-css-prefix}-modx:before { content: $fa-var-modx; }\n.#{$fa-css-prefix}-fort-awesome:before { content: $fa-var-fort-awesome; }\n.#{$fa-css-prefix}-usb:before { content: $fa-var-usb; }\n.#{$fa-css-prefix}-product-hunt:before { content: $fa-var-product-hunt; }\n.#{$fa-css-prefix}-mixcloud:before { content: $fa-var-mixcloud; }\n.#{$fa-css-prefix}-scribd:before { content: $fa-var-scribd; }\n.#{$fa-css-prefix}-pause-circle:before { content: $fa-var-pause-circle; }\n.#{$fa-css-prefix}-pause-circle-o:before { content: $fa-var-pause-circle-o; }\n.#{$fa-css-prefix}-stop-circle:before { content: $fa-var-stop-circle; }\n.#{$fa-css-prefix}-stop-circle-o:before { content: $fa-var-stop-circle-o; }\n.#{$fa-css-prefix}-shopping-bag:before { content: $fa-var-shopping-bag; }\n.#{$fa-css-prefix}-shopping-basket:before { content: $fa-var-shopping-basket; }\n.#{$fa-css-prefix}-hashtag:before { content: $fa-var-hashtag; }\n.#{$fa-css-prefix}-bluetooth:before { content: $fa-var-bluetooth; }\n.#{$fa-css-prefix}-bluetooth-b:before { content: $fa-var-bluetooth-b; }\n.#{$fa-css-prefix}-percent:before { content: $fa-var-percent; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_larger.scss",
    "content": "// Icon Sizes\n// -------------------------\n\n/* makes the font 33% larger relative to the icon container */\n.#{$fa-css-prefix}-lg {\n  font-size: (4em / 3);\n  line-height: (3em / 4);\n  vertical-align: -15%;\n}\n.#{$fa-css-prefix}-2x { font-size: 2em; }\n.#{$fa-css-prefix}-3x { font-size: 3em; }\n.#{$fa-css-prefix}-4x { font-size: 4em; }\n.#{$fa-css-prefix}-5x { font-size: 5em; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_list.scss",
    "content": "// List Icons\n// -------------------------\n\n.#{$fa-css-prefix}-ul {\n  padding-left: 0;\n  margin-left: $fa-li-width;\n  list-style-type: none;\n  > li { position: relative; }\n}\n.#{$fa-css-prefix}-li {\n  position: absolute;\n  left: -$fa-li-width;\n  width: $fa-li-width;\n  top: (2em / 14);\n  text-align: center;\n  &.#{$fa-css-prefix}-lg {\n    left: -$fa-li-width + (4em / 14);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_mixins.scss",
    "content": "// Mixins\n// --------------------------\n\n@mixin fa-icon() {\n  display: inline-block;\n  font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n\n@mixin fa-icon-rotate($degrees, $rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});\n  -webkit-transform: rotate($degrees);\n      -ms-transform: rotate($degrees);\n          transform: rotate($degrees);\n}\n\n@mixin fa-icon-flip($horiz, $vert, $rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});\n  -webkit-transform: scale($horiz, $vert);\n      -ms-transform: scale($horiz, $vert);\n          transform: scale($horiz, $vert);\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_path.scss",
    "content": "/* FONT PATH\n * -------------------------- */\n\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('#{$fa-font-path}/fontawesome-webfont.eot?v=#{$fa-version}');\n  src: url('#{$fa-font-path}/fontawesome-webfont.eot?#iefix&v=#{$fa-version}') format('embedded-opentype'),\n    url('#{$fa-font-path}/fontawesome-webfont.woff2?v=#{$fa-version}') format('woff2'),\n    url('#{$fa-font-path}/fontawesome-webfont.woff?v=#{$fa-version}') format('woff'),\n    url('#{$fa-font-path}/fontawesome-webfont.ttf?v=#{$fa-version}') format('truetype'),\n    url('#{$fa-font-path}/fontawesome-webfont.svg?v=#{$fa-version}#fontawesomeregular') format('svg');\n//  src: url('#{$fa-font-path}/FontAwesome.otf') format('opentype'); // used when developing fonts\n  font-weight: normal;\n  font-style: normal;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_rotated-flipped.scss",
    "content": "// Rotated & Flipped Icons\n// -------------------------\n\n.#{$fa-css-prefix}-rotate-90  { @include fa-icon-rotate(90deg, 1);  }\n.#{$fa-css-prefix}-rotate-180 { @include fa-icon-rotate(180deg, 2); }\n.#{$fa-css-prefix}-rotate-270 { @include fa-icon-rotate(270deg, 3); }\n\n.#{$fa-css-prefix}-flip-horizontal { @include fa-icon-flip(-1, 1, 0); }\n.#{$fa-css-prefix}-flip-vertical   { @include fa-icon-flip(1, -1, 2); }\n\n// Hook for IE8-9\n// -------------------------\n\n:root .#{$fa-css-prefix}-rotate-90,\n:root .#{$fa-css-prefix}-rotate-180,\n:root .#{$fa-css-prefix}-rotate-270,\n:root .#{$fa-css-prefix}-flip-horizontal,\n:root .#{$fa-css-prefix}-flip-vertical {\n  filter: none;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_spinning.scss",
    "content": "// Spinning Icons\n// --------------------------\n\n.#{$fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_stacked.scss",
    "content": "// Stacked Icons\n// -------------------------\n\n.#{$fa-css-prefix}-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.#{$fa-css-prefix}-stack-1x, .#{$fa-css-prefix}-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.#{$fa-css-prefix}-stack-1x { line-height: inherit; }\n.#{$fa-css-prefix}-stack-2x { font-size: 2em; }\n.#{$fa-css-prefix}-inverse { color: $fa-inverse; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/_variables.scss",
    "content": "// Variables\n// --------------------------\n\n$fa-font-path:        \"../fonts\" !default;\n$fa-font-size-base:   14px !default;\n$fa-line-height-base: 1 !default;\n//$fa-font-path:        \"//netdna.bootstrapcdn.com/font-awesome/4.5.0/fonts\" !default; // for referencing Bootstrap CDN font files directly\n$fa-css-prefix:       fa !default;\n$fa-version:          \"4.5.0\" !default;\n$fa-border-color:     #eee !default;\n$fa-inverse:          #fff !default;\n$fa-li-width:         (30em / 14) !default;\n\n$fa-var-500px: \"\\f26e\";\n$fa-var-adjust: \"\\f042\";\n$fa-var-adn: \"\\f170\";\n$fa-var-align-center: \"\\f037\";\n$fa-var-align-justify: \"\\f039\";\n$fa-var-align-left: \"\\f036\";\n$fa-var-align-right: \"\\f038\";\n$fa-var-amazon: \"\\f270\";\n$fa-var-ambulance: \"\\f0f9\";\n$fa-var-anchor: \"\\f13d\";\n$fa-var-android: \"\\f17b\";\n$fa-var-angellist: \"\\f209\";\n$fa-var-angle-double-down: \"\\f103\";\n$fa-var-angle-double-left: \"\\f100\";\n$fa-var-angle-double-right: \"\\f101\";\n$fa-var-angle-double-up: \"\\f102\";\n$fa-var-angle-down: \"\\f107\";\n$fa-var-angle-left: \"\\f104\";\n$fa-var-angle-right: \"\\f105\";\n$fa-var-angle-up: \"\\f106\";\n$fa-var-apple: \"\\f179\";\n$fa-var-archive: \"\\f187\";\n$fa-var-area-chart: \"\\f1fe\";\n$fa-var-arrow-circle-down: \"\\f0ab\";\n$fa-var-arrow-circle-left: \"\\f0a8\";\n$fa-var-arrow-circle-o-down: \"\\f01a\";\n$fa-var-arrow-circle-o-left: \"\\f190\";\n$fa-var-arrow-circle-o-right: \"\\f18e\";\n$fa-var-arrow-circle-o-up: \"\\f01b\";\n$fa-var-arrow-circle-right: \"\\f0a9\";\n$fa-var-arrow-circle-up: \"\\f0aa\";\n$fa-var-arrow-down: \"\\f063\";\n$fa-var-arrow-left: \"\\f060\";\n$fa-var-arrow-right: \"\\f061\";\n$fa-var-arrow-up: \"\\f062\";\n$fa-var-arrows: \"\\f047\";\n$fa-var-arrows-alt: \"\\f0b2\";\n$fa-var-arrows-h: \"\\f07e\";\n$fa-var-arrows-v: \"\\f07d\";\n$fa-var-asterisk: \"\\f069\";\n$fa-var-at: \"\\f1fa\";\n$fa-var-automobile: \"\\f1b9\";\n$fa-var-backward: \"\\f04a\";\n$fa-var-balance-scale: \"\\f24e\";\n$fa-var-ban: \"\\f05e\";\n$fa-var-bank: \"\\f19c\";\n$fa-var-bar-chart: \"\\f080\";\n$fa-var-bar-chart-o: \"\\f080\";\n$fa-var-barcode: \"\\f02a\";\n$fa-var-bars: \"\\f0c9\";\n$fa-var-battery-0: \"\\f244\";\n$fa-var-battery-1: \"\\f243\";\n$fa-var-battery-2: \"\\f242\";\n$fa-var-battery-3: \"\\f241\";\n$fa-var-battery-4: \"\\f240\";\n$fa-var-battery-empty: \"\\f244\";\n$fa-var-battery-full: \"\\f240\";\n$fa-var-battery-half: \"\\f242\";\n$fa-var-battery-quarter: \"\\f243\";\n$fa-var-battery-three-quarters: \"\\f241\";\n$fa-var-bed: \"\\f236\";\n$fa-var-beer: \"\\f0fc\";\n$fa-var-behance: \"\\f1b4\";\n$fa-var-behance-square: \"\\f1b5\";\n$fa-var-bell: \"\\f0f3\";\n$fa-var-bell-o: \"\\f0a2\";\n$fa-var-bell-slash: \"\\f1f6\";\n$fa-var-bell-slash-o: \"\\f1f7\";\n$fa-var-bicycle: \"\\f206\";\n$fa-var-binoculars: \"\\f1e5\";\n$fa-var-birthday-cake: \"\\f1fd\";\n$fa-var-bitbucket: \"\\f171\";\n$fa-var-bitbucket-square: \"\\f172\";\n$fa-var-bitcoin: \"\\f15a\";\n$fa-var-black-tie: \"\\f27e\";\n$fa-var-bluetooth: \"\\f293\";\n$fa-var-bluetooth-b: \"\\f294\";\n$fa-var-bold: \"\\f032\";\n$fa-var-bolt: \"\\f0e7\";\n$fa-var-bomb: \"\\f1e2\";\n$fa-var-book: \"\\f02d\";\n$fa-var-bookmark: \"\\f02e\";\n$fa-var-bookmark-o: \"\\f097\";\n$fa-var-briefcase: \"\\f0b1\";\n$fa-var-btc: \"\\f15a\";\n$fa-var-bug: \"\\f188\";\n$fa-var-building: \"\\f1ad\";\n$fa-var-building-o: \"\\f0f7\";\n$fa-var-bullhorn: \"\\f0a1\";\n$fa-var-bullseye: \"\\f140\";\n$fa-var-bus: \"\\f207\";\n$fa-var-buysellads: \"\\f20d\";\n$fa-var-cab: \"\\f1ba\";\n$fa-var-calculator: \"\\f1ec\";\n$fa-var-calendar: \"\\f073\";\n$fa-var-calendar-check-o: \"\\f274\";\n$fa-var-calendar-minus-o: \"\\f272\";\n$fa-var-calendar-o: \"\\f133\";\n$fa-var-calendar-plus-o: \"\\f271\";\n$fa-var-calendar-times-o: \"\\f273\";\n$fa-var-camera: \"\\f030\";\n$fa-var-camera-retro: \"\\f083\";\n$fa-var-car: \"\\f1b9\";\n$fa-var-caret-down: \"\\f0d7\";\n$fa-var-caret-left: \"\\f0d9\";\n$fa-var-caret-right: \"\\f0da\";\n$fa-var-caret-square-o-down: \"\\f150\";\n$fa-var-caret-square-o-left: \"\\f191\";\n$fa-var-caret-square-o-right: \"\\f152\";\n$fa-var-caret-square-o-up: \"\\f151\";\n$fa-var-caret-up: \"\\f0d8\";\n$fa-var-cart-arrow-down: \"\\f218\";\n$fa-var-cart-plus: \"\\f217\";\n$fa-var-cc: \"\\f20a\";\n$fa-var-cc-amex: \"\\f1f3\";\n$fa-var-cc-diners-club: \"\\f24c\";\n$fa-var-cc-discover: \"\\f1f2\";\n$fa-var-cc-jcb: \"\\f24b\";\n$fa-var-cc-mastercard: \"\\f1f1\";\n$fa-var-cc-paypal: \"\\f1f4\";\n$fa-var-cc-stripe: \"\\f1f5\";\n$fa-var-cc-visa: \"\\f1f0\";\n$fa-var-certificate: \"\\f0a3\";\n$fa-var-chain: \"\\f0c1\";\n$fa-var-chain-broken: \"\\f127\";\n$fa-var-check: \"\\f00c\";\n$fa-var-check-circle: \"\\f058\";\n$fa-var-check-circle-o: \"\\f05d\";\n$fa-var-check-square: \"\\f14a\";\n$fa-var-check-square-o: \"\\f046\";\n$fa-var-chevron-circle-down: \"\\f13a\";\n$fa-var-chevron-circle-left: \"\\f137\";\n$fa-var-chevron-circle-right: \"\\f138\";\n$fa-var-chevron-circle-up: \"\\f139\";\n$fa-var-chevron-down: \"\\f078\";\n$fa-var-chevron-left: \"\\f053\";\n$fa-var-chevron-right: \"\\f054\";\n$fa-var-chevron-up: \"\\f077\";\n$fa-var-child: \"\\f1ae\";\n$fa-var-chrome: \"\\f268\";\n$fa-var-circle: \"\\f111\";\n$fa-var-circle-o: \"\\f10c\";\n$fa-var-circle-o-notch: \"\\f1ce\";\n$fa-var-circle-thin: \"\\f1db\";\n$fa-var-clipboard: \"\\f0ea\";\n$fa-var-clock-o: \"\\f017\";\n$fa-var-clone: \"\\f24d\";\n$fa-var-close: \"\\f00d\";\n$fa-var-cloud: \"\\f0c2\";\n$fa-var-cloud-download: \"\\f0ed\";\n$fa-var-cloud-upload: \"\\f0ee\";\n$fa-var-cny: \"\\f157\";\n$fa-var-code: \"\\f121\";\n$fa-var-code-fork: \"\\f126\";\n$fa-var-codepen: \"\\f1cb\";\n$fa-var-codiepie: \"\\f284\";\n$fa-var-coffee: \"\\f0f4\";\n$fa-var-cog: \"\\f013\";\n$fa-var-cogs: \"\\f085\";\n$fa-var-columns: \"\\f0db\";\n$fa-var-comment: \"\\f075\";\n$fa-var-comment-o: \"\\f0e5\";\n$fa-var-commenting: \"\\f27a\";\n$fa-var-commenting-o: \"\\f27b\";\n$fa-var-comments: \"\\f086\";\n$fa-var-comments-o: \"\\f0e6\";\n$fa-var-compass: \"\\f14e\";\n$fa-var-compress: \"\\f066\";\n$fa-var-connectdevelop: \"\\f20e\";\n$fa-var-contao: \"\\f26d\";\n$fa-var-copy: \"\\f0c5\";\n$fa-var-copyright: \"\\f1f9\";\n$fa-var-creative-commons: \"\\f25e\";\n$fa-var-credit-card: \"\\f09d\";\n$fa-var-credit-card-alt: \"\\f283\";\n$fa-var-crop: \"\\f125\";\n$fa-var-crosshairs: \"\\f05b\";\n$fa-var-css3: \"\\f13c\";\n$fa-var-cube: \"\\f1b2\";\n$fa-var-cubes: \"\\f1b3\";\n$fa-var-cut: \"\\f0c4\";\n$fa-var-cutlery: \"\\f0f5\";\n$fa-var-dashboard: \"\\f0e4\";\n$fa-var-dashcube: \"\\f210\";\n$fa-var-database: \"\\f1c0\";\n$fa-var-dedent: \"\\f03b\";\n$fa-var-delicious: \"\\f1a5\";\n$fa-var-desktop: \"\\f108\";\n$fa-var-deviantart: \"\\f1bd\";\n$fa-var-diamond: \"\\f219\";\n$fa-var-digg: \"\\f1a6\";\n$fa-var-dollar: \"\\f155\";\n$fa-var-dot-circle-o: \"\\f192\";\n$fa-var-download: \"\\f019\";\n$fa-var-dribbble: \"\\f17d\";\n$fa-var-dropbox: \"\\f16b\";\n$fa-var-drupal: \"\\f1a9\";\n$fa-var-edge: \"\\f282\";\n$fa-var-edit: \"\\f044\";\n$fa-var-eject: \"\\f052\";\n$fa-var-ellipsis-h: \"\\f141\";\n$fa-var-ellipsis-v: \"\\f142\";\n$fa-var-empire: \"\\f1d1\";\n$fa-var-envelope: \"\\f0e0\";\n$fa-var-envelope-o: \"\\f003\";\n$fa-var-envelope-square: \"\\f199\";\n$fa-var-eraser: \"\\f12d\";\n$fa-var-eur: \"\\f153\";\n$fa-var-euro: \"\\f153\";\n$fa-var-exchange: \"\\f0ec\";\n$fa-var-exclamation: \"\\f12a\";\n$fa-var-exclamation-circle: \"\\f06a\";\n$fa-var-exclamation-triangle: \"\\f071\";\n$fa-var-expand: \"\\f065\";\n$fa-var-expeditedssl: \"\\f23e\";\n$fa-var-external-link: \"\\f08e\";\n$fa-var-external-link-square: \"\\f14c\";\n$fa-var-eye: \"\\f06e\";\n$fa-var-eye-slash: \"\\f070\";\n$fa-var-eyedropper: \"\\f1fb\";\n$fa-var-facebook: \"\\f09a\";\n$fa-var-facebook-f: \"\\f09a\";\n$fa-var-facebook-official: \"\\f230\";\n$fa-var-facebook-square: \"\\f082\";\n$fa-var-fast-backward: \"\\f049\";\n$fa-var-fast-forward: \"\\f050\";\n$fa-var-fax: \"\\f1ac\";\n$fa-var-feed: \"\\f09e\";\n$fa-var-female: \"\\f182\";\n$fa-var-fighter-jet: \"\\f0fb\";\n$fa-var-file: \"\\f15b\";\n$fa-var-file-archive-o: \"\\f1c6\";\n$fa-var-file-audio-o: \"\\f1c7\";\n$fa-var-file-code-o: \"\\f1c9\";\n$fa-var-file-excel-o: \"\\f1c3\";\n$fa-var-file-image-o: \"\\f1c5\";\n$fa-var-file-movie-o: \"\\f1c8\";\n$fa-var-file-o: \"\\f016\";\n$fa-var-file-pdf-o: \"\\f1c1\";\n$fa-var-file-photo-o: \"\\f1c5\";\n$fa-var-file-picture-o: \"\\f1c5\";\n$fa-var-file-powerpoint-o: \"\\f1c4\";\n$fa-var-file-sound-o: \"\\f1c7\";\n$fa-var-file-text: \"\\f15c\";\n$fa-var-file-text-o: \"\\f0f6\";\n$fa-var-file-video-o: \"\\f1c8\";\n$fa-var-file-word-o: \"\\f1c2\";\n$fa-var-file-zip-o: \"\\f1c6\";\n$fa-var-files-o: \"\\f0c5\";\n$fa-var-film: \"\\f008\";\n$fa-var-filter: \"\\f0b0\";\n$fa-var-fire: \"\\f06d\";\n$fa-var-fire-extinguisher: \"\\f134\";\n$fa-var-firefox: \"\\f269\";\n$fa-var-flag: \"\\f024\";\n$fa-var-flag-checkered: \"\\f11e\";\n$fa-var-flag-o: \"\\f11d\";\n$fa-var-flash: \"\\f0e7\";\n$fa-var-flask: \"\\f0c3\";\n$fa-var-flickr: \"\\f16e\";\n$fa-var-floppy-o: \"\\f0c7\";\n$fa-var-folder: \"\\f07b\";\n$fa-var-folder-o: \"\\f114\";\n$fa-var-folder-open: \"\\f07c\";\n$fa-var-folder-open-o: \"\\f115\";\n$fa-var-font: \"\\f031\";\n$fa-var-fonticons: \"\\f280\";\n$fa-var-fort-awesome: \"\\f286\";\n$fa-var-forumbee: \"\\f211\";\n$fa-var-forward: \"\\f04e\";\n$fa-var-foursquare: \"\\f180\";\n$fa-var-frown-o: \"\\f119\";\n$fa-var-futbol-o: \"\\f1e3\";\n$fa-var-gamepad: \"\\f11b\";\n$fa-var-gavel: \"\\f0e3\";\n$fa-var-gbp: \"\\f154\";\n$fa-var-ge: \"\\f1d1\";\n$fa-var-gear: \"\\f013\";\n$fa-var-gears: \"\\f085\";\n$fa-var-genderless: \"\\f22d\";\n$fa-var-get-pocket: \"\\f265\";\n$fa-var-gg: \"\\f260\";\n$fa-var-gg-circle: \"\\f261\";\n$fa-var-gift: \"\\f06b\";\n$fa-var-git: \"\\f1d3\";\n$fa-var-git-square: \"\\f1d2\";\n$fa-var-github: \"\\f09b\";\n$fa-var-github-alt: \"\\f113\";\n$fa-var-github-square: \"\\f092\";\n$fa-var-gittip: \"\\f184\";\n$fa-var-glass: \"\\f000\";\n$fa-var-globe: \"\\f0ac\";\n$fa-var-google: \"\\f1a0\";\n$fa-var-google-plus: \"\\f0d5\";\n$fa-var-google-plus-square: \"\\f0d4\";\n$fa-var-google-wallet: \"\\f1ee\";\n$fa-var-graduation-cap: \"\\f19d\";\n$fa-var-gratipay: \"\\f184\";\n$fa-var-group: \"\\f0c0\";\n$fa-var-h-square: \"\\f0fd\";\n$fa-var-hacker-news: \"\\f1d4\";\n$fa-var-hand-grab-o: \"\\f255\";\n$fa-var-hand-lizard-o: \"\\f258\";\n$fa-var-hand-o-down: \"\\f0a7\";\n$fa-var-hand-o-left: \"\\f0a5\";\n$fa-var-hand-o-right: \"\\f0a4\";\n$fa-var-hand-o-up: \"\\f0a6\";\n$fa-var-hand-paper-o: \"\\f256\";\n$fa-var-hand-peace-o: \"\\f25b\";\n$fa-var-hand-pointer-o: \"\\f25a\";\n$fa-var-hand-rock-o: \"\\f255\";\n$fa-var-hand-scissors-o: \"\\f257\";\n$fa-var-hand-spock-o: \"\\f259\";\n$fa-var-hand-stop-o: \"\\f256\";\n$fa-var-hashtag: \"\\f292\";\n$fa-var-hdd-o: \"\\f0a0\";\n$fa-var-header: \"\\f1dc\";\n$fa-var-headphones: \"\\f025\";\n$fa-var-heart: \"\\f004\";\n$fa-var-heart-o: \"\\f08a\";\n$fa-var-heartbeat: \"\\f21e\";\n$fa-var-history: \"\\f1da\";\n$fa-var-home: \"\\f015\";\n$fa-var-hospital-o: \"\\f0f8\";\n$fa-var-hotel: \"\\f236\";\n$fa-var-hourglass: \"\\f254\";\n$fa-var-hourglass-1: \"\\f251\";\n$fa-var-hourglass-2: \"\\f252\";\n$fa-var-hourglass-3: \"\\f253\";\n$fa-var-hourglass-end: \"\\f253\";\n$fa-var-hourglass-half: \"\\f252\";\n$fa-var-hourglass-o: \"\\f250\";\n$fa-var-hourglass-start: \"\\f251\";\n$fa-var-houzz: \"\\f27c\";\n$fa-var-html5: \"\\f13b\";\n$fa-var-i-cursor: \"\\f246\";\n$fa-var-ils: \"\\f20b\";\n$fa-var-image: \"\\f03e\";\n$fa-var-inbox: \"\\f01c\";\n$fa-var-indent: \"\\f03c\";\n$fa-var-industry: \"\\f275\";\n$fa-var-info: \"\\f129\";\n$fa-var-info-circle: \"\\f05a\";\n$fa-var-inr: \"\\f156\";\n$fa-var-instagram: \"\\f16d\";\n$fa-var-institution: \"\\f19c\";\n$fa-var-internet-explorer: \"\\f26b\";\n$fa-var-intersex: \"\\f224\";\n$fa-var-ioxhost: \"\\f208\";\n$fa-var-italic: \"\\f033\";\n$fa-var-joomla: \"\\f1aa\";\n$fa-var-jpy: \"\\f157\";\n$fa-var-jsfiddle: \"\\f1cc\";\n$fa-var-key: \"\\f084\";\n$fa-var-keyboard-o: \"\\f11c\";\n$fa-var-krw: \"\\f159\";\n$fa-var-language: \"\\f1ab\";\n$fa-var-laptop: \"\\f109\";\n$fa-var-lastfm: \"\\f202\";\n$fa-var-lastfm-square: \"\\f203\";\n$fa-var-leaf: \"\\f06c\";\n$fa-var-leanpub: \"\\f212\";\n$fa-var-legal: \"\\f0e3\";\n$fa-var-lemon-o: \"\\f094\";\n$fa-var-level-down: \"\\f149\";\n$fa-var-level-up: \"\\f148\";\n$fa-var-life-bouy: \"\\f1cd\";\n$fa-var-life-buoy: \"\\f1cd\";\n$fa-var-life-ring: \"\\f1cd\";\n$fa-var-life-saver: \"\\f1cd\";\n$fa-var-lightbulb-o: \"\\f0eb\";\n$fa-var-line-chart: \"\\f201\";\n$fa-var-link: \"\\f0c1\";\n$fa-var-linkedin: \"\\f0e1\";\n$fa-var-linkedin-square: \"\\f08c\";\n$fa-var-linux: \"\\f17c\";\n$fa-var-list: \"\\f03a\";\n$fa-var-list-alt: \"\\f022\";\n$fa-var-list-ol: \"\\f0cb\";\n$fa-var-list-ul: \"\\f0ca\";\n$fa-var-location-arrow: \"\\f124\";\n$fa-var-lock: \"\\f023\";\n$fa-var-long-arrow-down: \"\\f175\";\n$fa-var-long-arrow-left: \"\\f177\";\n$fa-var-long-arrow-right: \"\\f178\";\n$fa-var-long-arrow-up: \"\\f176\";\n$fa-var-magic: \"\\f0d0\";\n$fa-var-magnet: \"\\f076\";\n$fa-var-mail-forward: \"\\f064\";\n$fa-var-mail-reply: \"\\f112\";\n$fa-var-mail-reply-all: \"\\f122\";\n$fa-var-male: \"\\f183\";\n$fa-var-map: \"\\f279\";\n$fa-var-map-marker: \"\\f041\";\n$fa-var-map-o: \"\\f278\";\n$fa-var-map-pin: \"\\f276\";\n$fa-var-map-signs: \"\\f277\";\n$fa-var-mars: \"\\f222\";\n$fa-var-mars-double: \"\\f227\";\n$fa-var-mars-stroke: \"\\f229\";\n$fa-var-mars-stroke-h: \"\\f22b\";\n$fa-var-mars-stroke-v: \"\\f22a\";\n$fa-var-maxcdn: \"\\f136\";\n$fa-var-meanpath: \"\\f20c\";\n$fa-var-medium: \"\\f23a\";\n$fa-var-medkit: \"\\f0fa\";\n$fa-var-meh-o: \"\\f11a\";\n$fa-var-mercury: \"\\f223\";\n$fa-var-microphone: \"\\f130\";\n$fa-var-microphone-slash: \"\\f131\";\n$fa-var-minus: \"\\f068\";\n$fa-var-minus-circle: \"\\f056\";\n$fa-var-minus-square: \"\\f146\";\n$fa-var-minus-square-o: \"\\f147\";\n$fa-var-mixcloud: \"\\f289\";\n$fa-var-mobile: \"\\f10b\";\n$fa-var-mobile-phone: \"\\f10b\";\n$fa-var-modx: \"\\f285\";\n$fa-var-money: \"\\f0d6\";\n$fa-var-moon-o: \"\\f186\";\n$fa-var-mortar-board: \"\\f19d\";\n$fa-var-motorcycle: \"\\f21c\";\n$fa-var-mouse-pointer: \"\\f245\";\n$fa-var-music: \"\\f001\";\n$fa-var-navicon: \"\\f0c9\";\n$fa-var-neuter: \"\\f22c\";\n$fa-var-newspaper-o: \"\\f1ea\";\n$fa-var-object-group: \"\\f247\";\n$fa-var-object-ungroup: \"\\f248\";\n$fa-var-odnoklassniki: \"\\f263\";\n$fa-var-odnoklassniki-square: \"\\f264\";\n$fa-var-opencart: \"\\f23d\";\n$fa-var-openid: \"\\f19b\";\n$fa-var-opera: \"\\f26a\";\n$fa-var-optin-monster: \"\\f23c\";\n$fa-var-outdent: \"\\f03b\";\n$fa-var-pagelines: \"\\f18c\";\n$fa-var-paint-brush: \"\\f1fc\";\n$fa-var-paper-plane: \"\\f1d8\";\n$fa-var-paper-plane-o: \"\\f1d9\";\n$fa-var-paperclip: \"\\f0c6\";\n$fa-var-paragraph: \"\\f1dd\";\n$fa-var-paste: \"\\f0ea\";\n$fa-var-pause: \"\\f04c\";\n$fa-var-pause-circle: \"\\f28b\";\n$fa-var-pause-circle-o: \"\\f28c\";\n$fa-var-paw: \"\\f1b0\";\n$fa-var-paypal: \"\\f1ed\";\n$fa-var-pencil: \"\\f040\";\n$fa-var-pencil-square: \"\\f14b\";\n$fa-var-pencil-square-o: \"\\f044\";\n$fa-var-percent: \"\\f295\";\n$fa-var-phone: \"\\f095\";\n$fa-var-phone-square: \"\\f098\";\n$fa-var-photo: \"\\f03e\";\n$fa-var-picture-o: \"\\f03e\";\n$fa-var-pie-chart: \"\\f200\";\n$fa-var-pied-piper: \"\\f1a7\";\n$fa-var-pied-piper-alt: \"\\f1a8\";\n$fa-var-pinterest: \"\\f0d2\";\n$fa-var-pinterest-p: \"\\f231\";\n$fa-var-pinterest-square: \"\\f0d3\";\n$fa-var-plane: \"\\f072\";\n$fa-var-play: \"\\f04b\";\n$fa-var-play-circle: \"\\f144\";\n$fa-var-play-circle-o: \"\\f01d\";\n$fa-var-plug: \"\\f1e6\";\n$fa-var-plus: \"\\f067\";\n$fa-var-plus-circle: \"\\f055\";\n$fa-var-plus-square: \"\\f0fe\";\n$fa-var-plus-square-o: \"\\f196\";\n$fa-var-power-off: \"\\f011\";\n$fa-var-print: \"\\f02f\";\n$fa-var-product-hunt: \"\\f288\";\n$fa-var-puzzle-piece: \"\\f12e\";\n$fa-var-qq: \"\\f1d6\";\n$fa-var-qrcode: \"\\f029\";\n$fa-var-question: \"\\f128\";\n$fa-var-question-circle: \"\\f059\";\n$fa-var-quote-left: \"\\f10d\";\n$fa-var-quote-right: \"\\f10e\";\n$fa-var-ra: \"\\f1d0\";\n$fa-var-random: \"\\f074\";\n$fa-var-rebel: \"\\f1d0\";\n$fa-var-recycle: \"\\f1b8\";\n$fa-var-reddit: \"\\f1a1\";\n$fa-var-reddit-alien: \"\\f281\";\n$fa-var-reddit-square: \"\\f1a2\";\n$fa-var-refresh: \"\\f021\";\n$fa-var-registered: \"\\f25d\";\n$fa-var-remove: \"\\f00d\";\n$fa-var-renren: \"\\f18b\";\n$fa-var-reorder: \"\\f0c9\";\n$fa-var-repeat: \"\\f01e\";\n$fa-var-reply: \"\\f112\";\n$fa-var-reply-all: \"\\f122\";\n$fa-var-retweet: \"\\f079\";\n$fa-var-rmb: \"\\f157\";\n$fa-var-road: \"\\f018\";\n$fa-var-rocket: \"\\f135\";\n$fa-var-rotate-left: \"\\f0e2\";\n$fa-var-rotate-right: \"\\f01e\";\n$fa-var-rouble: \"\\f158\";\n$fa-var-rss: \"\\f09e\";\n$fa-var-rss-square: \"\\f143\";\n$fa-var-rub: \"\\f158\";\n$fa-var-ruble: \"\\f158\";\n$fa-var-rupee: \"\\f156\";\n$fa-var-safari: \"\\f267\";\n$fa-var-save: \"\\f0c7\";\n$fa-var-scissors: \"\\f0c4\";\n$fa-var-scribd: \"\\f28a\";\n$fa-var-search: \"\\f002\";\n$fa-var-search-minus: \"\\f010\";\n$fa-var-search-plus: \"\\f00e\";\n$fa-var-sellsy: \"\\f213\";\n$fa-var-send: \"\\f1d8\";\n$fa-var-send-o: \"\\f1d9\";\n$fa-var-server: \"\\f233\";\n$fa-var-share: \"\\f064\";\n$fa-var-share-alt: \"\\f1e0\";\n$fa-var-share-alt-square: \"\\f1e1\";\n$fa-var-share-square: \"\\f14d\";\n$fa-var-share-square-o: \"\\f045\";\n$fa-var-shekel: \"\\f20b\";\n$fa-var-sheqel: \"\\f20b\";\n$fa-var-shield: \"\\f132\";\n$fa-var-ship: \"\\f21a\";\n$fa-var-shirtsinbulk: \"\\f214\";\n$fa-var-shopping-bag: \"\\f290\";\n$fa-var-shopping-basket: \"\\f291\";\n$fa-var-shopping-cart: \"\\f07a\";\n$fa-var-sign-in: \"\\f090\";\n$fa-var-sign-out: \"\\f08b\";\n$fa-var-signal: \"\\f012\";\n$fa-var-simplybuilt: \"\\f215\";\n$fa-var-sitemap: \"\\f0e8\";\n$fa-var-skyatlas: \"\\f216\";\n$fa-var-skype: \"\\f17e\";\n$fa-var-slack: \"\\f198\";\n$fa-var-sliders: \"\\f1de\";\n$fa-var-slideshare: \"\\f1e7\";\n$fa-var-smile-o: \"\\f118\";\n$fa-var-soccer-ball-o: \"\\f1e3\";\n$fa-var-sort: \"\\f0dc\";\n$fa-var-sort-alpha-asc: \"\\f15d\";\n$fa-var-sort-alpha-desc: \"\\f15e\";\n$fa-var-sort-amount-asc: \"\\f160\";\n$fa-var-sort-amount-desc: \"\\f161\";\n$fa-var-sort-asc: \"\\f0de\";\n$fa-var-sort-desc: \"\\f0dd\";\n$fa-var-sort-down: \"\\f0dd\";\n$fa-var-sort-numeric-asc: \"\\f162\";\n$fa-var-sort-numeric-desc: \"\\f163\";\n$fa-var-sort-up: \"\\f0de\";\n$fa-var-soundcloud: \"\\f1be\";\n$fa-var-space-shuttle: \"\\f197\";\n$fa-var-spinner: \"\\f110\";\n$fa-var-spoon: \"\\f1b1\";\n$fa-var-spotify: \"\\f1bc\";\n$fa-var-square: \"\\f0c8\";\n$fa-var-square-o: \"\\f096\";\n$fa-var-stack-exchange: \"\\f18d\";\n$fa-var-stack-overflow: \"\\f16c\";\n$fa-var-star: \"\\f005\";\n$fa-var-star-half: \"\\f089\";\n$fa-var-star-half-empty: \"\\f123\";\n$fa-var-star-half-full: \"\\f123\";\n$fa-var-star-half-o: \"\\f123\";\n$fa-var-star-o: \"\\f006\";\n$fa-var-steam: \"\\f1b6\";\n$fa-var-steam-square: \"\\f1b7\";\n$fa-var-step-backward: \"\\f048\";\n$fa-var-step-forward: \"\\f051\";\n$fa-var-stethoscope: \"\\f0f1\";\n$fa-var-sticky-note: \"\\f249\";\n$fa-var-sticky-note-o: \"\\f24a\";\n$fa-var-stop: \"\\f04d\";\n$fa-var-stop-circle: \"\\f28d\";\n$fa-var-stop-circle-o: \"\\f28e\";\n$fa-var-street-view: \"\\f21d\";\n$fa-var-strikethrough: \"\\f0cc\";\n$fa-var-stumbleupon: \"\\f1a4\";\n$fa-var-stumbleupon-circle: \"\\f1a3\";\n$fa-var-subscript: \"\\f12c\";\n$fa-var-subway: \"\\f239\";\n$fa-var-suitcase: \"\\f0f2\";\n$fa-var-sun-o: \"\\f185\";\n$fa-var-superscript: \"\\f12b\";\n$fa-var-support: \"\\f1cd\";\n$fa-var-table: \"\\f0ce\";\n$fa-var-tablet: \"\\f10a\";\n$fa-var-tachometer: \"\\f0e4\";\n$fa-var-tag: \"\\f02b\";\n$fa-var-tags: \"\\f02c\";\n$fa-var-tasks: \"\\f0ae\";\n$fa-var-taxi: \"\\f1ba\";\n$fa-var-television: \"\\f26c\";\n$fa-var-tencent-weibo: \"\\f1d5\";\n$fa-var-terminal: \"\\f120\";\n$fa-var-text-height: \"\\f034\";\n$fa-var-text-width: \"\\f035\";\n$fa-var-th: \"\\f00a\";\n$fa-var-th-large: \"\\f009\";\n$fa-var-th-list: \"\\f00b\";\n$fa-var-thumb-tack: \"\\f08d\";\n$fa-var-thumbs-down: \"\\f165\";\n$fa-var-thumbs-o-down: \"\\f088\";\n$fa-var-thumbs-o-up: \"\\f087\";\n$fa-var-thumbs-up: \"\\f164\";\n$fa-var-ticket: \"\\f145\";\n$fa-var-times: \"\\f00d\";\n$fa-var-times-circle: \"\\f057\";\n$fa-var-times-circle-o: \"\\f05c\";\n$fa-var-tint: \"\\f043\";\n$fa-var-toggle-down: \"\\f150\";\n$fa-var-toggle-left: \"\\f191\";\n$fa-var-toggle-off: \"\\f204\";\n$fa-var-toggle-on: \"\\f205\";\n$fa-var-toggle-right: \"\\f152\";\n$fa-var-toggle-up: \"\\f151\";\n$fa-var-trademark: \"\\f25c\";\n$fa-var-train: \"\\f238\";\n$fa-var-transgender: \"\\f224\";\n$fa-var-transgender-alt: \"\\f225\";\n$fa-var-trash: \"\\f1f8\";\n$fa-var-trash-o: \"\\f014\";\n$fa-var-tree: \"\\f1bb\";\n$fa-var-trello: \"\\f181\";\n$fa-var-tripadvisor: \"\\f262\";\n$fa-var-trophy: \"\\f091\";\n$fa-var-truck: \"\\f0d1\";\n$fa-var-try: \"\\f195\";\n$fa-var-tty: \"\\f1e4\";\n$fa-var-tumblr: \"\\f173\";\n$fa-var-tumblr-square: \"\\f174\";\n$fa-var-turkish-lira: \"\\f195\";\n$fa-var-tv: \"\\f26c\";\n$fa-var-twitch: \"\\f1e8\";\n$fa-var-twitter: \"\\f099\";\n$fa-var-twitter-square: \"\\f081\";\n$fa-var-umbrella: \"\\f0e9\";\n$fa-var-underline: \"\\f0cd\";\n$fa-var-undo: \"\\f0e2\";\n$fa-var-university: \"\\f19c\";\n$fa-var-unlink: \"\\f127\";\n$fa-var-unlock: \"\\f09c\";\n$fa-var-unlock-alt: \"\\f13e\";\n$fa-var-unsorted: \"\\f0dc\";\n$fa-var-upload: \"\\f093\";\n$fa-var-usb: \"\\f287\";\n$fa-var-usd: \"\\f155\";\n$fa-var-user: \"\\f007\";\n$fa-var-user-md: \"\\f0f0\";\n$fa-var-user-plus: \"\\f234\";\n$fa-var-user-secret: \"\\f21b\";\n$fa-var-user-times: \"\\f235\";\n$fa-var-users: \"\\f0c0\";\n$fa-var-venus: \"\\f221\";\n$fa-var-venus-double: \"\\f226\";\n$fa-var-venus-mars: \"\\f228\";\n$fa-var-viacoin: \"\\f237\";\n$fa-var-video-camera: \"\\f03d\";\n$fa-var-vimeo: \"\\f27d\";\n$fa-var-vimeo-square: \"\\f194\";\n$fa-var-vine: \"\\f1ca\";\n$fa-var-vk: \"\\f189\";\n$fa-var-volume-down: \"\\f027\";\n$fa-var-volume-off: \"\\f026\";\n$fa-var-volume-up: \"\\f028\";\n$fa-var-warning: \"\\f071\";\n$fa-var-wechat: \"\\f1d7\";\n$fa-var-weibo: \"\\f18a\";\n$fa-var-weixin: \"\\f1d7\";\n$fa-var-whatsapp: \"\\f232\";\n$fa-var-wheelchair: \"\\f193\";\n$fa-var-wifi: \"\\f1eb\";\n$fa-var-wikipedia-w: \"\\f266\";\n$fa-var-windows: \"\\f17a\";\n$fa-var-won: \"\\f159\";\n$fa-var-wordpress: \"\\f19a\";\n$fa-var-wrench: \"\\f0ad\";\n$fa-var-xing: \"\\f168\";\n$fa-var-xing-square: \"\\f169\";\n$fa-var-y-combinator: \"\\f23b\";\n$fa-var-y-combinator-square: \"\\f1d4\";\n$fa-var-yahoo: \"\\f19e\";\n$fa-var-yc: \"\\f23b\";\n$fa-var-yc-square: \"\\f1d4\";\n$fa-var-yelp: \"\\f1e9\";\n$fa-var-yen: \"\\f157\";\n$fa-var-youtube: \"\\f167\";\n$fa-var-youtube-play: \"\\f16a\";\n$fa-var-youtube-square: \"\\f166\";\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/old/scss/font-awesome.scss",
    "content": "/*!\n *  Font Awesome 4.5.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n\n@import \"variables\";\n@import \"mixins\";\n@import \"path\";\n@import \"core\";\n@import \"larger\";\n@import \"fixed-width\";\n@import \"list\";\n@import \"bordered-pulled\";\n@import \"animated\";\n@import \"rotated-flipped\";\n@import \"stacked\";\n@import \"icons\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_animated.scss",
    "content": "// Spinning Icons\n// --------------------------\n\n.#{$fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n.#{$fa-css-prefix}-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n          animation: fa-spin 1s infinite steps(8);\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_bordered-pulled.scss",
    "content": "// Bordered & Pulled\n// -------------------------\n\n.#{$fa-css-prefix}-border {\n  padding: .2em .25em .15em;\n  border: solid .08em $fa-border-color;\n  border-radius: .1em;\n}\n\n.#{$fa-css-prefix}-pull-left { float: left; }\n.#{$fa-css-prefix}-pull-right { float: right; }\n\n.#{$fa-css-prefix} {\n  &.#{$fa-css-prefix}-pull-left { margin-right: .3em; }\n  &.#{$fa-css-prefix}-pull-right { margin-left: .3em; }\n}\n\n/* Deprecated as of 4.4.0 */\n.pull-right { float: right; }\n.pull-left { float: left; }\n\n.#{$fa-css-prefix} {\n  &.pull-left { margin-right: .3em; }\n  &.pull-right { margin-left: .3em; }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_core.scss",
    "content": "// Base Class Definition\n// -------------------------\n\n.#{$fa-css-prefix} {\n  display: inline-block;\n  font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_fixed-width.scss",
    "content": "// Fixed Width Icons\n// -------------------------\n.#{$fa-css-prefix}-fw {\n  width: (18em / 14);\n  text-align: center;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_icons.scss",
    "content": "/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n\n.#{$fa-css-prefix}-glass:before { content: $fa-var-glass; }\n.#{$fa-css-prefix}-music:before { content: $fa-var-music; }\n.#{$fa-css-prefix}-search:before { content: $fa-var-search; }\n.#{$fa-css-prefix}-envelope-o:before { content: $fa-var-envelope-o; }\n.#{$fa-css-prefix}-heart:before { content: $fa-var-heart; }\n.#{$fa-css-prefix}-star:before { content: $fa-var-star; }\n.#{$fa-css-prefix}-star-o:before { content: $fa-var-star-o; }\n.#{$fa-css-prefix}-user:before { content: $fa-var-user; }\n.#{$fa-css-prefix}-film:before { content: $fa-var-film; }\n.#{$fa-css-prefix}-th-large:before { content: $fa-var-th-large; }\n.#{$fa-css-prefix}-th:before { content: $fa-var-th; }\n.#{$fa-css-prefix}-th-list:before { content: $fa-var-th-list; }\n.#{$fa-css-prefix}-check:before { content: $fa-var-check; }\n.#{$fa-css-prefix}-remove:before,\n.#{$fa-css-prefix}-close:before,\n.#{$fa-css-prefix}-times:before { content: $fa-var-times; }\n.#{$fa-css-prefix}-search-plus:before { content: $fa-var-search-plus; }\n.#{$fa-css-prefix}-search-minus:before { content: $fa-var-search-minus; }\n.#{$fa-css-prefix}-power-off:before { content: $fa-var-power-off; }\n.#{$fa-css-prefix}-signal:before { content: $fa-var-signal; }\n.#{$fa-css-prefix}-gear:before,\n.#{$fa-css-prefix}-cog:before { content: $fa-var-cog; }\n.#{$fa-css-prefix}-trash-o:before { content: $fa-var-trash-o; }\n.#{$fa-css-prefix}-home:before { content: $fa-var-home; }\n.#{$fa-css-prefix}-file-o:before { content: $fa-var-file-o; }\n.#{$fa-css-prefix}-clock-o:before { content: $fa-var-clock-o; }\n.#{$fa-css-prefix}-road:before { content: $fa-var-road; }\n.#{$fa-css-prefix}-download:before { content: $fa-var-download; }\n.#{$fa-css-prefix}-arrow-circle-o-down:before { content: $fa-var-arrow-circle-o-down; }\n.#{$fa-css-prefix}-arrow-circle-o-up:before { content: $fa-var-arrow-circle-o-up; }\n.#{$fa-css-prefix}-inbox:before { content: $fa-var-inbox; }\n.#{$fa-css-prefix}-play-circle-o:before { content: $fa-var-play-circle-o; }\n.#{$fa-css-prefix}-rotate-right:before,\n.#{$fa-css-prefix}-repeat:before { content: $fa-var-repeat; }\n.#{$fa-css-prefix}-refresh:before { content: $fa-var-refresh; }\n.#{$fa-css-prefix}-list-alt:before { content: $fa-var-list-alt; }\n.#{$fa-css-prefix}-lock:before { content: $fa-var-lock; }\n.#{$fa-css-prefix}-flag:before { content: $fa-var-flag; }\n.#{$fa-css-prefix}-headphones:before { content: $fa-var-headphones; }\n.#{$fa-css-prefix}-volume-off:before { content: $fa-var-volume-off; }\n.#{$fa-css-prefix}-volume-down:before { content: $fa-var-volume-down; }\n.#{$fa-css-prefix}-volume-up:before { content: $fa-var-volume-up; }\n.#{$fa-css-prefix}-qrcode:before { content: $fa-var-qrcode; }\n.#{$fa-css-prefix}-barcode:before { content: $fa-var-barcode; }\n.#{$fa-css-prefix}-tag:before { content: $fa-var-tag; }\n.#{$fa-css-prefix}-tags:before { content: $fa-var-tags; }\n.#{$fa-css-prefix}-book:before { content: $fa-var-book; }\n.#{$fa-css-prefix}-bookmark:before { content: $fa-var-bookmark; }\n.#{$fa-css-prefix}-print:before { content: $fa-var-print; }\n.#{$fa-css-prefix}-camera:before { content: $fa-var-camera; }\n.#{$fa-css-prefix}-font:before { content: $fa-var-font; }\n.#{$fa-css-prefix}-bold:before { content: $fa-var-bold; }\n.#{$fa-css-prefix}-italic:before { content: $fa-var-italic; }\n.#{$fa-css-prefix}-text-height:before { content: $fa-var-text-height; }\n.#{$fa-css-prefix}-text-width:before { content: $fa-var-text-width; }\n.#{$fa-css-prefix}-align-left:before { content: $fa-var-align-left; }\n.#{$fa-css-prefix}-align-center:before { content: $fa-var-align-center; }\n.#{$fa-css-prefix}-align-right:before { content: $fa-var-align-right; }\n.#{$fa-css-prefix}-align-justify:before { content: $fa-var-align-justify; }\n.#{$fa-css-prefix}-list:before { content: $fa-var-list; }\n.#{$fa-css-prefix}-dedent:before,\n.#{$fa-css-prefix}-outdent:before { content: $fa-var-outdent; }\n.#{$fa-css-prefix}-indent:before { content: $fa-var-indent; }\n.#{$fa-css-prefix}-video-camera:before { content: $fa-var-video-camera; }\n.#{$fa-css-prefix}-photo:before,\n.#{$fa-css-prefix}-image:before,\n.#{$fa-css-prefix}-picture-o:before { content: $fa-var-picture-o; }\n.#{$fa-css-prefix}-pencil:before { content: $fa-var-pencil; }\n.#{$fa-css-prefix}-map-marker:before { content: $fa-var-map-marker; }\n.#{$fa-css-prefix}-adjust:before { content: $fa-var-adjust; }\n.#{$fa-css-prefix}-tint:before { content: $fa-var-tint; }\n.#{$fa-css-prefix}-edit:before,\n.#{$fa-css-prefix}-pencil-square-o:before { content: $fa-var-pencil-square-o; }\n.#{$fa-css-prefix}-share-square-o:before { content: $fa-var-share-square-o; }\n.#{$fa-css-prefix}-check-square-o:before { content: $fa-var-check-square-o; }\n.#{$fa-css-prefix}-arrows:before { content: $fa-var-arrows; }\n.#{$fa-css-prefix}-step-backward:before { content: $fa-var-step-backward; }\n.#{$fa-css-prefix}-fast-backward:before { content: $fa-var-fast-backward; }\n.#{$fa-css-prefix}-backward:before { content: $fa-var-backward; }\n.#{$fa-css-prefix}-play:before { content: $fa-var-play; }\n.#{$fa-css-prefix}-pause:before { content: $fa-var-pause; }\n.#{$fa-css-prefix}-stop:before { content: $fa-var-stop; }\n.#{$fa-css-prefix}-forward:before { content: $fa-var-forward; }\n.#{$fa-css-prefix}-fast-forward:before { content: $fa-var-fast-forward; }\n.#{$fa-css-prefix}-step-forward:before { content: $fa-var-step-forward; }\n.#{$fa-css-prefix}-eject:before { content: $fa-var-eject; }\n.#{$fa-css-prefix}-chevron-left:before { content: $fa-var-chevron-left; }\n.#{$fa-css-prefix}-chevron-right:before { content: $fa-var-chevron-right; }\n.#{$fa-css-prefix}-plus-circle:before { content: $fa-var-plus-circle; }\n.#{$fa-css-prefix}-minus-circle:before { content: $fa-var-minus-circle; }\n.#{$fa-css-prefix}-times-circle:before { content: $fa-var-times-circle; }\n.#{$fa-css-prefix}-check-circle:before { content: $fa-var-check-circle; }\n.#{$fa-css-prefix}-question-circle:before { content: $fa-var-question-circle; }\n.#{$fa-css-prefix}-info-circle:before { content: $fa-var-info-circle; }\n.#{$fa-css-prefix}-crosshairs:before { content: $fa-var-crosshairs; }\n.#{$fa-css-prefix}-times-circle-o:before { content: $fa-var-times-circle-o; }\n.#{$fa-css-prefix}-check-circle-o:before { content: $fa-var-check-circle-o; }\n.#{$fa-css-prefix}-ban:before { content: $fa-var-ban; }\n.#{$fa-css-prefix}-arrow-left:before { content: $fa-var-arrow-left; }\n.#{$fa-css-prefix}-arrow-right:before { content: $fa-var-arrow-right; }\n.#{$fa-css-prefix}-arrow-up:before { content: $fa-var-arrow-up; }\n.#{$fa-css-prefix}-arrow-down:before { content: $fa-var-arrow-down; }\n.#{$fa-css-prefix}-mail-forward:before,\n.#{$fa-css-prefix}-share:before { content: $fa-var-share; }\n.#{$fa-css-prefix}-expand:before { content: $fa-var-expand; }\n.#{$fa-css-prefix}-compress:before { content: $fa-var-compress; }\n.#{$fa-css-prefix}-plus:before { content: $fa-var-plus; }\n.#{$fa-css-prefix}-minus:before { content: $fa-var-minus; }\n.#{$fa-css-prefix}-asterisk:before { content: $fa-var-asterisk; }\n.#{$fa-css-prefix}-exclamation-circle:before { content: $fa-var-exclamation-circle; }\n.#{$fa-css-prefix}-gift:before { content: $fa-var-gift; }\n.#{$fa-css-prefix}-leaf:before { content: $fa-var-leaf; }\n.#{$fa-css-prefix}-fire:before { content: $fa-var-fire; }\n.#{$fa-css-prefix}-eye:before { content: $fa-var-eye; }\n.#{$fa-css-prefix}-eye-slash:before { content: $fa-var-eye-slash; }\n.#{$fa-css-prefix}-warning:before,\n.#{$fa-css-prefix}-exclamation-triangle:before { content: $fa-var-exclamation-triangle; }\n.#{$fa-css-prefix}-plane:before { content: $fa-var-plane; }\n.#{$fa-css-prefix}-calendar:before { content: $fa-var-calendar; }\n.#{$fa-css-prefix}-random:before { content: $fa-var-random; }\n.#{$fa-css-prefix}-comment:before { content: $fa-var-comment; }\n.#{$fa-css-prefix}-magnet:before { content: $fa-var-magnet; }\n.#{$fa-css-prefix}-chevron-up:before { content: $fa-var-chevron-up; }\n.#{$fa-css-prefix}-chevron-down:before { content: $fa-var-chevron-down; }\n.#{$fa-css-prefix}-retweet:before { content: $fa-var-retweet; }\n.#{$fa-css-prefix}-shopping-cart:before { content: $fa-var-shopping-cart; }\n.#{$fa-css-prefix}-folder:before { content: $fa-var-folder; }\n.#{$fa-css-prefix}-folder-open:before { content: $fa-var-folder-open; }\n.#{$fa-css-prefix}-arrows-v:before { content: $fa-var-arrows-v; }\n.#{$fa-css-prefix}-arrows-h:before { content: $fa-var-arrows-h; }\n.#{$fa-css-prefix}-bar-chart-o:before,\n.#{$fa-css-prefix}-bar-chart:before { content: $fa-var-bar-chart; }\n.#{$fa-css-prefix}-twitter-square:before { content: $fa-var-twitter-square; }\n.#{$fa-css-prefix}-facebook-square:before { content: $fa-var-facebook-square; }\n.#{$fa-css-prefix}-camera-retro:before { content: $fa-var-camera-retro; }\n.#{$fa-css-prefix}-key:before { content: $fa-var-key; }\n.#{$fa-css-prefix}-gears:before,\n.#{$fa-css-prefix}-cogs:before { content: $fa-var-cogs; }\n.#{$fa-css-prefix}-comments:before { content: $fa-var-comments; }\n.#{$fa-css-prefix}-thumbs-o-up:before { content: $fa-var-thumbs-o-up; }\n.#{$fa-css-prefix}-thumbs-o-down:before { content: $fa-var-thumbs-o-down; }\n.#{$fa-css-prefix}-star-half:before { content: $fa-var-star-half; }\n.#{$fa-css-prefix}-heart-o:before { content: $fa-var-heart-o; }\n.#{$fa-css-prefix}-sign-out:before { content: $fa-var-sign-out; }\n.#{$fa-css-prefix}-linkedin-square:before { content: $fa-var-linkedin-square; }\n.#{$fa-css-prefix}-thumb-tack:before { content: $fa-var-thumb-tack; }\n.#{$fa-css-prefix}-external-link:before { content: $fa-var-external-link; }\n.#{$fa-css-prefix}-sign-in:before { content: $fa-var-sign-in; }\n.#{$fa-css-prefix}-trophy:before { content: $fa-var-trophy; }\n.#{$fa-css-prefix}-github-square:before { content: $fa-var-github-square; }\n.#{$fa-css-prefix}-upload:before { content: $fa-var-upload; }\n.#{$fa-css-prefix}-lemon-o:before { content: $fa-var-lemon-o; }\n.#{$fa-css-prefix}-phone:before { content: $fa-var-phone; }\n.#{$fa-css-prefix}-square-o:before { content: $fa-var-square-o; }\n.#{$fa-css-prefix}-bookmark-o:before { content: $fa-var-bookmark-o; }\n.#{$fa-css-prefix}-phone-square:before { content: $fa-var-phone-square; }\n.#{$fa-css-prefix}-twitter:before { content: $fa-var-twitter; }\n.#{$fa-css-prefix}-facebook-f:before,\n.#{$fa-css-prefix}-facebook:before { content: $fa-var-facebook; }\n.#{$fa-css-prefix}-github:before { content: $fa-var-github; }\n.#{$fa-css-prefix}-unlock:before { content: $fa-var-unlock; }\n.#{$fa-css-prefix}-credit-card:before { content: $fa-var-credit-card; }\n.#{$fa-css-prefix}-feed:before,\n.#{$fa-css-prefix}-rss:before { content: $fa-var-rss; }\n.#{$fa-css-prefix}-hdd-o:before { content: $fa-var-hdd-o; }\n.#{$fa-css-prefix}-bullhorn:before { content: $fa-var-bullhorn; }\n.#{$fa-css-prefix}-bell:before { content: $fa-var-bell; }\n.#{$fa-css-prefix}-certificate:before { content: $fa-var-certificate; }\n.#{$fa-css-prefix}-hand-o-right:before { content: $fa-var-hand-o-right; }\n.#{$fa-css-prefix}-hand-o-left:before { content: $fa-var-hand-o-left; }\n.#{$fa-css-prefix}-hand-o-up:before { content: $fa-var-hand-o-up; }\n.#{$fa-css-prefix}-hand-o-down:before { content: $fa-var-hand-o-down; }\n.#{$fa-css-prefix}-arrow-circle-left:before { content: $fa-var-arrow-circle-left; }\n.#{$fa-css-prefix}-arrow-circle-right:before { content: $fa-var-arrow-circle-right; }\n.#{$fa-css-prefix}-arrow-circle-up:before { content: $fa-var-arrow-circle-up; }\n.#{$fa-css-prefix}-arrow-circle-down:before { content: $fa-var-arrow-circle-down; }\n.#{$fa-css-prefix}-globe:before { content: $fa-var-globe; }\n.#{$fa-css-prefix}-wrench:before { content: $fa-var-wrench; }\n.#{$fa-css-prefix}-tasks:before { content: $fa-var-tasks; }\n.#{$fa-css-prefix}-filter:before { content: $fa-var-filter; }\n.#{$fa-css-prefix}-briefcase:before { content: $fa-var-briefcase; }\n.#{$fa-css-prefix}-arrows-alt:before { content: $fa-var-arrows-alt; }\n.#{$fa-css-prefix}-group:before,\n.#{$fa-css-prefix}-users:before { content: $fa-var-users; }\n.#{$fa-css-prefix}-chain:before,\n.#{$fa-css-prefix}-link:before { content: $fa-var-link; }\n.#{$fa-css-prefix}-cloud:before { content: $fa-var-cloud; }\n.#{$fa-css-prefix}-flask:before { content: $fa-var-flask; }\n.#{$fa-css-prefix}-cut:before,\n.#{$fa-css-prefix}-scissors:before { content: $fa-var-scissors; }\n.#{$fa-css-prefix}-copy:before,\n.#{$fa-css-prefix}-files-o:before { content: $fa-var-files-o; }\n.#{$fa-css-prefix}-paperclip:before { content: $fa-var-paperclip; }\n.#{$fa-css-prefix}-save:before,\n.#{$fa-css-prefix}-floppy-o:before { content: $fa-var-floppy-o; }\n.#{$fa-css-prefix}-square:before { content: $fa-var-square; }\n.#{$fa-css-prefix}-navicon:before,\n.#{$fa-css-prefix}-reorder:before,\n.#{$fa-css-prefix}-bars:before { content: $fa-var-bars; }\n.#{$fa-css-prefix}-list-ul:before { content: $fa-var-list-ul; }\n.#{$fa-css-prefix}-list-ol:before { content: $fa-var-list-ol; }\n.#{$fa-css-prefix}-strikethrough:before { content: $fa-var-strikethrough; }\n.#{$fa-css-prefix}-underline:before { content: $fa-var-underline; }\n.#{$fa-css-prefix}-table:before { content: $fa-var-table; }\n.#{$fa-css-prefix}-magic:before { content: $fa-var-magic; }\n.#{$fa-css-prefix}-truck:before { content: $fa-var-truck; }\n.#{$fa-css-prefix}-pinterest:before { content: $fa-var-pinterest; }\n.#{$fa-css-prefix}-pinterest-square:before { content: $fa-var-pinterest-square; }\n.#{$fa-css-prefix}-google-plus-square:before { content: $fa-var-google-plus-square; }\n.#{$fa-css-prefix}-google-plus:before { content: $fa-var-google-plus; }\n.#{$fa-css-prefix}-money:before { content: $fa-var-money; }\n.#{$fa-css-prefix}-caret-down:before { content: $fa-var-caret-down; }\n.#{$fa-css-prefix}-caret-up:before { content: $fa-var-caret-up; }\n.#{$fa-css-prefix}-caret-left:before { content: $fa-var-caret-left; }\n.#{$fa-css-prefix}-caret-right:before { content: $fa-var-caret-right; }\n.#{$fa-css-prefix}-columns:before { content: $fa-var-columns; }\n.#{$fa-css-prefix}-unsorted:before,\n.#{$fa-css-prefix}-sort:before { content: $fa-var-sort; }\n.#{$fa-css-prefix}-sort-down:before,\n.#{$fa-css-prefix}-sort-desc:before { content: $fa-var-sort-desc; }\n.#{$fa-css-prefix}-sort-up:before,\n.#{$fa-css-prefix}-sort-asc:before { content: $fa-var-sort-asc; }\n.#{$fa-css-prefix}-envelope:before { content: $fa-var-envelope; }\n.#{$fa-css-prefix}-linkedin:before { content: $fa-var-linkedin; }\n.#{$fa-css-prefix}-rotate-left:before,\n.#{$fa-css-prefix}-undo:before { content: $fa-var-undo; }\n.#{$fa-css-prefix}-legal:before,\n.#{$fa-css-prefix}-gavel:before { content: $fa-var-gavel; }\n.#{$fa-css-prefix}-dashboard:before,\n.#{$fa-css-prefix}-tachometer:before { content: $fa-var-tachometer; }\n.#{$fa-css-prefix}-comment-o:before { content: $fa-var-comment-o; }\n.#{$fa-css-prefix}-comments-o:before { content: $fa-var-comments-o; }\n.#{$fa-css-prefix}-flash:before,\n.#{$fa-css-prefix}-bolt:before { content: $fa-var-bolt; }\n.#{$fa-css-prefix}-sitemap:before { content: $fa-var-sitemap; }\n.#{$fa-css-prefix}-umbrella:before { content: $fa-var-umbrella; }\n.#{$fa-css-prefix}-paste:before,\n.#{$fa-css-prefix}-clipboard:before { content: $fa-var-clipboard; }\n.#{$fa-css-prefix}-lightbulb-o:before { content: $fa-var-lightbulb-o; }\n.#{$fa-css-prefix}-exchange:before { content: $fa-var-exchange; }\n.#{$fa-css-prefix}-cloud-download:before { content: $fa-var-cloud-download; }\n.#{$fa-css-prefix}-cloud-upload:before { content: $fa-var-cloud-upload; }\n.#{$fa-css-prefix}-user-md:before { content: $fa-var-user-md; }\n.#{$fa-css-prefix}-stethoscope:before { content: $fa-var-stethoscope; }\n.#{$fa-css-prefix}-suitcase:before { content: $fa-var-suitcase; }\n.#{$fa-css-prefix}-bell-o:before { content: $fa-var-bell-o; }\n.#{$fa-css-prefix}-coffee:before { content: $fa-var-coffee; }\n.#{$fa-css-prefix}-cutlery:before { content: $fa-var-cutlery; }\n.#{$fa-css-prefix}-file-text-o:before { content: $fa-var-file-text-o; }\n.#{$fa-css-prefix}-building-o:before { content: $fa-var-building-o; }\n.#{$fa-css-prefix}-hospital-o:before { content: $fa-var-hospital-o; }\n.#{$fa-css-prefix}-ambulance:before { content: $fa-var-ambulance; }\n.#{$fa-css-prefix}-medkit:before { content: $fa-var-medkit; }\n.#{$fa-css-prefix}-fighter-jet:before { content: $fa-var-fighter-jet; }\n.#{$fa-css-prefix}-beer:before { content: $fa-var-beer; }\n.#{$fa-css-prefix}-h-square:before { content: $fa-var-h-square; }\n.#{$fa-css-prefix}-plus-square:before { content: $fa-var-plus-square; }\n.#{$fa-css-prefix}-angle-double-left:before { content: $fa-var-angle-double-left; }\n.#{$fa-css-prefix}-angle-double-right:before { content: $fa-var-angle-double-right; }\n.#{$fa-css-prefix}-angle-double-up:before { content: $fa-var-angle-double-up; }\n.#{$fa-css-prefix}-angle-double-down:before { content: $fa-var-angle-double-down; }\n.#{$fa-css-prefix}-angle-left:before { content: $fa-var-angle-left; }\n.#{$fa-css-prefix}-angle-right:before { content: $fa-var-angle-right; }\n.#{$fa-css-prefix}-angle-up:before { content: $fa-var-angle-up; }\n.#{$fa-css-prefix}-angle-down:before { content: $fa-var-angle-down; }\n.#{$fa-css-prefix}-desktop:before { content: $fa-var-desktop; }\n.#{$fa-css-prefix}-laptop:before { content: $fa-var-laptop; }\n.#{$fa-css-prefix}-tablet:before { content: $fa-var-tablet; }\n.#{$fa-css-prefix}-mobile-phone:before,\n.#{$fa-css-prefix}-mobile:before { content: $fa-var-mobile; }\n.#{$fa-css-prefix}-circle-o:before { content: $fa-var-circle-o; }\n.#{$fa-css-prefix}-quote-left:before { content: $fa-var-quote-left; }\n.#{$fa-css-prefix}-quote-right:before { content: $fa-var-quote-right; }\n.#{$fa-css-prefix}-spinner:before { content: $fa-var-spinner; }\n.#{$fa-css-prefix}-circle:before { content: $fa-var-circle; }\n.#{$fa-css-prefix}-mail-reply:before,\n.#{$fa-css-prefix}-reply:before { content: $fa-var-reply; }\n.#{$fa-css-prefix}-github-alt:before { content: $fa-var-github-alt; }\n.#{$fa-css-prefix}-folder-o:before { content: $fa-var-folder-o; }\n.#{$fa-css-prefix}-folder-open-o:before { content: $fa-var-folder-open-o; }\n.#{$fa-css-prefix}-smile-o:before { content: $fa-var-smile-o; }\n.#{$fa-css-prefix}-frown-o:before { content: $fa-var-frown-o; }\n.#{$fa-css-prefix}-meh-o:before { content: $fa-var-meh-o; }\n.#{$fa-css-prefix}-gamepad:before { content: $fa-var-gamepad; }\n.#{$fa-css-prefix}-keyboard-o:before { content: $fa-var-keyboard-o; }\n.#{$fa-css-prefix}-flag-o:before { content: $fa-var-flag-o; }\n.#{$fa-css-prefix}-flag-checkered:before { content: $fa-var-flag-checkered; }\n.#{$fa-css-prefix}-terminal:before { content: $fa-var-terminal; }\n.#{$fa-css-prefix}-code:before { content: $fa-var-code; }\n.#{$fa-css-prefix}-mail-reply-all:before,\n.#{$fa-css-prefix}-reply-all:before { content: $fa-var-reply-all; }\n.#{$fa-css-prefix}-star-half-empty:before,\n.#{$fa-css-prefix}-star-half-full:before,\n.#{$fa-css-prefix}-star-half-o:before { content: $fa-var-star-half-o; }\n.#{$fa-css-prefix}-location-arrow:before { content: $fa-var-location-arrow; }\n.#{$fa-css-prefix}-crop:before { content: $fa-var-crop; }\n.#{$fa-css-prefix}-code-fork:before { content: $fa-var-code-fork; }\n.#{$fa-css-prefix}-unlink:before,\n.#{$fa-css-prefix}-chain-broken:before { content: $fa-var-chain-broken; }\n.#{$fa-css-prefix}-question:before { content: $fa-var-question; }\n.#{$fa-css-prefix}-info:before { content: $fa-var-info; }\n.#{$fa-css-prefix}-exclamation:before { content: $fa-var-exclamation; }\n.#{$fa-css-prefix}-superscript:before { content: $fa-var-superscript; }\n.#{$fa-css-prefix}-subscript:before { content: $fa-var-subscript; }\n.#{$fa-css-prefix}-eraser:before { content: $fa-var-eraser; }\n.#{$fa-css-prefix}-puzzle-piece:before { content: $fa-var-puzzle-piece; }\n.#{$fa-css-prefix}-microphone:before { content: $fa-var-microphone; }\n.#{$fa-css-prefix}-microphone-slash:before { content: $fa-var-microphone-slash; }\n.#{$fa-css-prefix}-shield:before { content: $fa-var-shield; }\n.#{$fa-css-prefix}-calendar-o:before { content: $fa-var-calendar-o; }\n.#{$fa-css-prefix}-fire-extinguisher:before { content: $fa-var-fire-extinguisher; }\n.#{$fa-css-prefix}-rocket:before { content: $fa-var-rocket; }\n.#{$fa-css-prefix}-maxcdn:before { content: $fa-var-maxcdn; }\n.#{$fa-css-prefix}-chevron-circle-left:before { content: $fa-var-chevron-circle-left; }\n.#{$fa-css-prefix}-chevron-circle-right:before { content: $fa-var-chevron-circle-right; }\n.#{$fa-css-prefix}-chevron-circle-up:before { content: $fa-var-chevron-circle-up; }\n.#{$fa-css-prefix}-chevron-circle-down:before { content: $fa-var-chevron-circle-down; }\n.#{$fa-css-prefix}-html5:before { content: $fa-var-html5; }\n.#{$fa-css-prefix}-css3:before { content: $fa-var-css3; }\n.#{$fa-css-prefix}-anchor:before { content: $fa-var-anchor; }\n.#{$fa-css-prefix}-unlock-alt:before { content: $fa-var-unlock-alt; }\n.#{$fa-css-prefix}-bullseye:before { content: $fa-var-bullseye; }\n.#{$fa-css-prefix}-ellipsis-h:before { content: $fa-var-ellipsis-h; }\n.#{$fa-css-prefix}-ellipsis-v:before { content: $fa-var-ellipsis-v; }\n.#{$fa-css-prefix}-rss-square:before { content: $fa-var-rss-square; }\n.#{$fa-css-prefix}-play-circle:before { content: $fa-var-play-circle; }\n.#{$fa-css-prefix}-ticket:before { content: $fa-var-ticket; }\n.#{$fa-css-prefix}-minus-square:before { content: $fa-var-minus-square; }\n.#{$fa-css-prefix}-minus-square-o:before { content: $fa-var-minus-square-o; }\n.#{$fa-css-prefix}-level-up:before { content: $fa-var-level-up; }\n.#{$fa-css-prefix}-level-down:before { content: $fa-var-level-down; }\n.#{$fa-css-prefix}-check-square:before { content: $fa-var-check-square; }\n.#{$fa-css-prefix}-pencil-square:before { content: $fa-var-pencil-square; }\n.#{$fa-css-prefix}-external-link-square:before { content: $fa-var-external-link-square; }\n.#{$fa-css-prefix}-share-square:before { content: $fa-var-share-square; }\n.#{$fa-css-prefix}-compass:before { content: $fa-var-compass; }\n.#{$fa-css-prefix}-toggle-down:before,\n.#{$fa-css-prefix}-caret-square-o-down:before { content: $fa-var-caret-square-o-down; }\n.#{$fa-css-prefix}-toggle-up:before,\n.#{$fa-css-prefix}-caret-square-o-up:before { content: $fa-var-caret-square-o-up; }\n.#{$fa-css-prefix}-toggle-right:before,\n.#{$fa-css-prefix}-caret-square-o-right:before { content: $fa-var-caret-square-o-right; }\n.#{$fa-css-prefix}-euro:before,\n.#{$fa-css-prefix}-eur:before { content: $fa-var-eur; }\n.#{$fa-css-prefix}-gbp:before { content: $fa-var-gbp; }\n.#{$fa-css-prefix}-dollar:before,\n.#{$fa-css-prefix}-usd:before { content: $fa-var-usd; }\n.#{$fa-css-prefix}-rupee:before,\n.#{$fa-css-prefix}-inr:before { content: $fa-var-inr; }\n.#{$fa-css-prefix}-cny:before,\n.#{$fa-css-prefix}-rmb:before,\n.#{$fa-css-prefix}-yen:before,\n.#{$fa-css-prefix}-jpy:before { content: $fa-var-jpy; }\n.#{$fa-css-prefix}-ruble:before,\n.#{$fa-css-prefix}-rouble:before,\n.#{$fa-css-prefix}-rub:before { content: $fa-var-rub; }\n.#{$fa-css-prefix}-won:before,\n.#{$fa-css-prefix}-krw:before { content: $fa-var-krw; }\n.#{$fa-css-prefix}-bitcoin:before,\n.#{$fa-css-prefix}-btc:before { content: $fa-var-btc; }\n.#{$fa-css-prefix}-file:before { content: $fa-var-file; }\n.#{$fa-css-prefix}-file-text:before { content: $fa-var-file-text; }\n.#{$fa-css-prefix}-sort-alpha-asc:before { content: $fa-var-sort-alpha-asc; }\n.#{$fa-css-prefix}-sort-alpha-desc:before { content: $fa-var-sort-alpha-desc; }\n.#{$fa-css-prefix}-sort-amount-asc:before { content: $fa-var-sort-amount-asc; }\n.#{$fa-css-prefix}-sort-amount-desc:before { content: $fa-var-sort-amount-desc; }\n.#{$fa-css-prefix}-sort-numeric-asc:before { content: $fa-var-sort-numeric-asc; }\n.#{$fa-css-prefix}-sort-numeric-desc:before { content: $fa-var-sort-numeric-desc; }\n.#{$fa-css-prefix}-thumbs-up:before { content: $fa-var-thumbs-up; }\n.#{$fa-css-prefix}-thumbs-down:before { content: $fa-var-thumbs-down; }\n.#{$fa-css-prefix}-youtube-square:before { content: $fa-var-youtube-square; }\n.#{$fa-css-prefix}-youtube:before { content: $fa-var-youtube; }\n.#{$fa-css-prefix}-xing:before { content: $fa-var-xing; }\n.#{$fa-css-prefix}-xing-square:before { content: $fa-var-xing-square; }\n.#{$fa-css-prefix}-youtube-play:before { content: $fa-var-youtube-play; }\n.#{$fa-css-prefix}-dropbox:before { content: $fa-var-dropbox; }\n.#{$fa-css-prefix}-stack-overflow:before { content: $fa-var-stack-overflow; }\n.#{$fa-css-prefix}-instagram:before { content: $fa-var-instagram; }\n.#{$fa-css-prefix}-flickr:before { content: $fa-var-flickr; }\n.#{$fa-css-prefix}-adn:before { content: $fa-var-adn; }\n.#{$fa-css-prefix}-bitbucket:before { content: $fa-var-bitbucket; }\n.#{$fa-css-prefix}-bitbucket-square:before { content: $fa-var-bitbucket-square; }\n.#{$fa-css-prefix}-tumblr:before { content: $fa-var-tumblr; }\n.#{$fa-css-prefix}-tumblr-square:before { content: $fa-var-tumblr-square; }\n.#{$fa-css-prefix}-long-arrow-down:before { content: $fa-var-long-arrow-down; }\n.#{$fa-css-prefix}-long-arrow-up:before { content: $fa-var-long-arrow-up; }\n.#{$fa-css-prefix}-long-arrow-left:before { content: $fa-var-long-arrow-left; }\n.#{$fa-css-prefix}-long-arrow-right:before { content: $fa-var-long-arrow-right; }\n.#{$fa-css-prefix}-apple:before { content: $fa-var-apple; }\n.#{$fa-css-prefix}-windows:before { content: $fa-var-windows; }\n.#{$fa-css-prefix}-android:before { content: $fa-var-android; }\n.#{$fa-css-prefix}-linux:before { content: $fa-var-linux; }\n.#{$fa-css-prefix}-dribbble:before { content: $fa-var-dribbble; }\n.#{$fa-css-prefix}-skype:before { content: $fa-var-skype; }\n.#{$fa-css-prefix}-foursquare:before { content: $fa-var-foursquare; }\n.#{$fa-css-prefix}-trello:before { content: $fa-var-trello; }\n.#{$fa-css-prefix}-female:before { content: $fa-var-female; }\n.#{$fa-css-prefix}-male:before { content: $fa-var-male; }\n.#{$fa-css-prefix}-gittip:before,\n.#{$fa-css-prefix}-gratipay:before { content: $fa-var-gratipay; }\n.#{$fa-css-prefix}-sun-o:before { content: $fa-var-sun-o; }\n.#{$fa-css-prefix}-moon-o:before { content: $fa-var-moon-o; }\n.#{$fa-css-prefix}-archive:before { content: $fa-var-archive; }\n.#{$fa-css-prefix}-bug:before { content: $fa-var-bug; }\n.#{$fa-css-prefix}-vk:before { content: $fa-var-vk; }\n.#{$fa-css-prefix}-weibo:before { content: $fa-var-weibo; }\n.#{$fa-css-prefix}-renren:before { content: $fa-var-renren; }\n.#{$fa-css-prefix}-pagelines:before { content: $fa-var-pagelines; }\n.#{$fa-css-prefix}-stack-exchange:before { content: $fa-var-stack-exchange; }\n.#{$fa-css-prefix}-arrow-circle-o-right:before { content: $fa-var-arrow-circle-o-right; }\n.#{$fa-css-prefix}-arrow-circle-o-left:before { content: $fa-var-arrow-circle-o-left; }\n.#{$fa-css-prefix}-toggle-left:before,\n.#{$fa-css-prefix}-caret-square-o-left:before { content: $fa-var-caret-square-o-left; }\n.#{$fa-css-prefix}-dot-circle-o:before { content: $fa-var-dot-circle-o; }\n.#{$fa-css-prefix}-wheelchair:before { content: $fa-var-wheelchair; }\n.#{$fa-css-prefix}-vimeo-square:before { content: $fa-var-vimeo-square; }\n.#{$fa-css-prefix}-turkish-lira:before,\n.#{$fa-css-prefix}-try:before { content: $fa-var-try; }\n.#{$fa-css-prefix}-plus-square-o:before { content: $fa-var-plus-square-o; }\n.#{$fa-css-prefix}-space-shuttle:before { content: $fa-var-space-shuttle; }\n.#{$fa-css-prefix}-slack:before { content: $fa-var-slack; }\n.#{$fa-css-prefix}-envelope-square:before { content: $fa-var-envelope-square; }\n.#{$fa-css-prefix}-wordpress:before { content: $fa-var-wordpress; }\n.#{$fa-css-prefix}-openid:before { content: $fa-var-openid; }\n.#{$fa-css-prefix}-institution:before,\n.#{$fa-css-prefix}-bank:before,\n.#{$fa-css-prefix}-university:before { content: $fa-var-university; }\n.#{$fa-css-prefix}-mortar-board:before,\n.#{$fa-css-prefix}-graduation-cap:before { content: $fa-var-graduation-cap; }\n.#{$fa-css-prefix}-yahoo:before { content: $fa-var-yahoo; }\n.#{$fa-css-prefix}-google:before { content: $fa-var-google; }\n.#{$fa-css-prefix}-reddit:before { content: $fa-var-reddit; }\n.#{$fa-css-prefix}-reddit-square:before { content: $fa-var-reddit-square; }\n.#{$fa-css-prefix}-stumbleupon-circle:before { content: $fa-var-stumbleupon-circle; }\n.#{$fa-css-prefix}-stumbleupon:before { content: $fa-var-stumbleupon; }\n.#{$fa-css-prefix}-delicious:before { content: $fa-var-delicious; }\n.#{$fa-css-prefix}-digg:before { content: $fa-var-digg; }\n.#{$fa-css-prefix}-pied-piper-pp:before { content: $fa-var-pied-piper-pp; }\n.#{$fa-css-prefix}-pied-piper-alt:before { content: $fa-var-pied-piper-alt; }\n.#{$fa-css-prefix}-drupal:before { content: $fa-var-drupal; }\n.#{$fa-css-prefix}-joomla:before { content: $fa-var-joomla; }\n.#{$fa-css-prefix}-language:before { content: $fa-var-language; }\n.#{$fa-css-prefix}-fax:before { content: $fa-var-fax; }\n.#{$fa-css-prefix}-building:before { content: $fa-var-building; }\n.#{$fa-css-prefix}-child:before { content: $fa-var-child; }\n.#{$fa-css-prefix}-paw:before { content: $fa-var-paw; }\n.#{$fa-css-prefix}-spoon:before { content: $fa-var-spoon; }\n.#{$fa-css-prefix}-cube:before { content: $fa-var-cube; }\n.#{$fa-css-prefix}-cubes:before { content: $fa-var-cubes; }\n.#{$fa-css-prefix}-behance:before { content: $fa-var-behance; }\n.#{$fa-css-prefix}-behance-square:before { content: $fa-var-behance-square; }\n.#{$fa-css-prefix}-steam:before { content: $fa-var-steam; }\n.#{$fa-css-prefix}-steam-square:before { content: $fa-var-steam-square; }\n.#{$fa-css-prefix}-recycle:before { content: $fa-var-recycle; }\n.#{$fa-css-prefix}-automobile:before,\n.#{$fa-css-prefix}-car:before { content: $fa-var-car; }\n.#{$fa-css-prefix}-cab:before,\n.#{$fa-css-prefix}-taxi:before { content: $fa-var-taxi; }\n.#{$fa-css-prefix}-tree:before { content: $fa-var-tree; }\n.#{$fa-css-prefix}-spotify:before { content: $fa-var-spotify; }\n.#{$fa-css-prefix}-deviantart:before { content: $fa-var-deviantart; }\n.#{$fa-css-prefix}-soundcloud:before { content: $fa-var-soundcloud; }\n.#{$fa-css-prefix}-database:before { content: $fa-var-database; }\n.#{$fa-css-prefix}-file-pdf-o:before { content: $fa-var-file-pdf-o; }\n.#{$fa-css-prefix}-file-word-o:before { content: $fa-var-file-word-o; }\n.#{$fa-css-prefix}-file-excel-o:before { content: $fa-var-file-excel-o; }\n.#{$fa-css-prefix}-file-powerpoint-o:before { content: $fa-var-file-powerpoint-o; }\n.#{$fa-css-prefix}-file-photo-o:before,\n.#{$fa-css-prefix}-file-picture-o:before,\n.#{$fa-css-prefix}-file-image-o:before { content: $fa-var-file-image-o; }\n.#{$fa-css-prefix}-file-zip-o:before,\n.#{$fa-css-prefix}-file-archive-o:before { content: $fa-var-file-archive-o; }\n.#{$fa-css-prefix}-file-sound-o:before,\n.#{$fa-css-prefix}-file-audio-o:before { content: $fa-var-file-audio-o; }\n.#{$fa-css-prefix}-file-movie-o:before,\n.#{$fa-css-prefix}-file-video-o:before { content: $fa-var-file-video-o; }\n.#{$fa-css-prefix}-file-code-o:before { content: $fa-var-file-code-o; }\n.#{$fa-css-prefix}-vine:before { content: $fa-var-vine; }\n.#{$fa-css-prefix}-codepen:before { content: $fa-var-codepen; }\n.#{$fa-css-prefix}-jsfiddle:before { content: $fa-var-jsfiddle; }\n.#{$fa-css-prefix}-life-bouy:before,\n.#{$fa-css-prefix}-life-buoy:before,\n.#{$fa-css-prefix}-life-saver:before,\n.#{$fa-css-prefix}-support:before,\n.#{$fa-css-prefix}-life-ring:before { content: $fa-var-life-ring; }\n.#{$fa-css-prefix}-circle-o-notch:before { content: $fa-var-circle-o-notch; }\n.#{$fa-css-prefix}-ra:before,\n.#{$fa-css-prefix}-resistance:before,\n.#{$fa-css-prefix}-rebel:before { content: $fa-var-rebel; }\n.#{$fa-css-prefix}-ge:before,\n.#{$fa-css-prefix}-empire:before { content: $fa-var-empire; }\n.#{$fa-css-prefix}-git-square:before { content: $fa-var-git-square; }\n.#{$fa-css-prefix}-git:before { content: $fa-var-git; }\n.#{$fa-css-prefix}-y-combinator-square:before,\n.#{$fa-css-prefix}-yc-square:before,\n.#{$fa-css-prefix}-hacker-news:before { content: $fa-var-hacker-news; }\n.#{$fa-css-prefix}-tencent-weibo:before { content: $fa-var-tencent-weibo; }\n.#{$fa-css-prefix}-qq:before { content: $fa-var-qq; }\n.#{$fa-css-prefix}-wechat:before,\n.#{$fa-css-prefix}-weixin:before { content: $fa-var-weixin; }\n.#{$fa-css-prefix}-send:before,\n.#{$fa-css-prefix}-paper-plane:before { content: $fa-var-paper-plane; }\n.#{$fa-css-prefix}-send-o:before,\n.#{$fa-css-prefix}-paper-plane-o:before { content: $fa-var-paper-plane-o; }\n.#{$fa-css-prefix}-history:before { content: $fa-var-history; }\n.#{$fa-css-prefix}-circle-thin:before { content: $fa-var-circle-thin; }\n.#{$fa-css-prefix}-header:before { content: $fa-var-header; }\n.#{$fa-css-prefix}-paragraph:before { content: $fa-var-paragraph; }\n.#{$fa-css-prefix}-sliders:before { content: $fa-var-sliders; }\n.#{$fa-css-prefix}-share-alt:before { content: $fa-var-share-alt; }\n.#{$fa-css-prefix}-share-alt-square:before { content: $fa-var-share-alt-square; }\n.#{$fa-css-prefix}-bomb:before { content: $fa-var-bomb; }\n.#{$fa-css-prefix}-soccer-ball-o:before,\n.#{$fa-css-prefix}-futbol-o:before { content: $fa-var-futbol-o; }\n.#{$fa-css-prefix}-tty:before { content: $fa-var-tty; }\n.#{$fa-css-prefix}-binoculars:before { content: $fa-var-binoculars; }\n.#{$fa-css-prefix}-plug:before { content: $fa-var-plug; }\n.#{$fa-css-prefix}-slideshare:before { content: $fa-var-slideshare; }\n.#{$fa-css-prefix}-twitch:before { content: $fa-var-twitch; }\n.#{$fa-css-prefix}-yelp:before { content: $fa-var-yelp; }\n.#{$fa-css-prefix}-newspaper-o:before { content: $fa-var-newspaper-o; }\n.#{$fa-css-prefix}-wifi:before { content: $fa-var-wifi; }\n.#{$fa-css-prefix}-calculator:before { content: $fa-var-calculator; }\n.#{$fa-css-prefix}-paypal:before { content: $fa-var-paypal; }\n.#{$fa-css-prefix}-google-wallet:before { content: $fa-var-google-wallet; }\n.#{$fa-css-prefix}-cc-visa:before { content: $fa-var-cc-visa; }\n.#{$fa-css-prefix}-cc-mastercard:before { content: $fa-var-cc-mastercard; }\n.#{$fa-css-prefix}-cc-discover:before { content: $fa-var-cc-discover; }\n.#{$fa-css-prefix}-cc-amex:before { content: $fa-var-cc-amex; }\n.#{$fa-css-prefix}-cc-paypal:before { content: $fa-var-cc-paypal; }\n.#{$fa-css-prefix}-cc-stripe:before { content: $fa-var-cc-stripe; }\n.#{$fa-css-prefix}-bell-slash:before { content: $fa-var-bell-slash; }\n.#{$fa-css-prefix}-bell-slash-o:before { content: $fa-var-bell-slash-o; }\n.#{$fa-css-prefix}-trash:before { content: $fa-var-trash; }\n.#{$fa-css-prefix}-copyright:before { content: $fa-var-copyright; }\n.#{$fa-css-prefix}-at:before { content: $fa-var-at; }\n.#{$fa-css-prefix}-eyedropper:before { content: $fa-var-eyedropper; }\n.#{$fa-css-prefix}-paint-brush:before { content: $fa-var-paint-brush; }\n.#{$fa-css-prefix}-birthday-cake:before { content: $fa-var-birthday-cake; }\n.#{$fa-css-prefix}-area-chart:before { content: $fa-var-area-chart; }\n.#{$fa-css-prefix}-pie-chart:before { content: $fa-var-pie-chart; }\n.#{$fa-css-prefix}-line-chart:before { content: $fa-var-line-chart; }\n.#{$fa-css-prefix}-lastfm:before { content: $fa-var-lastfm; }\n.#{$fa-css-prefix}-lastfm-square:before { content: $fa-var-lastfm-square; }\n.#{$fa-css-prefix}-toggle-off:before { content: $fa-var-toggle-off; }\n.#{$fa-css-prefix}-toggle-on:before { content: $fa-var-toggle-on; }\n.#{$fa-css-prefix}-bicycle:before { content: $fa-var-bicycle; }\n.#{$fa-css-prefix}-bus:before { content: $fa-var-bus; }\n.#{$fa-css-prefix}-ioxhost:before { content: $fa-var-ioxhost; }\n.#{$fa-css-prefix}-angellist:before { content: $fa-var-angellist; }\n.#{$fa-css-prefix}-cc:before { content: $fa-var-cc; }\n.#{$fa-css-prefix}-shekel:before,\n.#{$fa-css-prefix}-sheqel:before,\n.#{$fa-css-prefix}-ils:before { content: $fa-var-ils; }\n.#{$fa-css-prefix}-meanpath:before { content: $fa-var-meanpath; }\n.#{$fa-css-prefix}-buysellads:before { content: $fa-var-buysellads; }\n.#{$fa-css-prefix}-connectdevelop:before { content: $fa-var-connectdevelop; }\n.#{$fa-css-prefix}-dashcube:before { content: $fa-var-dashcube; }\n.#{$fa-css-prefix}-forumbee:before { content: $fa-var-forumbee; }\n.#{$fa-css-prefix}-leanpub:before { content: $fa-var-leanpub; }\n.#{$fa-css-prefix}-sellsy:before { content: $fa-var-sellsy; }\n.#{$fa-css-prefix}-shirtsinbulk:before { content: $fa-var-shirtsinbulk; }\n.#{$fa-css-prefix}-simplybuilt:before { content: $fa-var-simplybuilt; }\n.#{$fa-css-prefix}-skyatlas:before { content: $fa-var-skyatlas; }\n.#{$fa-css-prefix}-cart-plus:before { content: $fa-var-cart-plus; }\n.#{$fa-css-prefix}-cart-arrow-down:before { content: $fa-var-cart-arrow-down; }\n.#{$fa-css-prefix}-diamond:before { content: $fa-var-diamond; }\n.#{$fa-css-prefix}-ship:before { content: $fa-var-ship; }\n.#{$fa-css-prefix}-user-secret:before { content: $fa-var-user-secret; }\n.#{$fa-css-prefix}-motorcycle:before { content: $fa-var-motorcycle; }\n.#{$fa-css-prefix}-street-view:before { content: $fa-var-street-view; }\n.#{$fa-css-prefix}-heartbeat:before { content: $fa-var-heartbeat; }\n.#{$fa-css-prefix}-venus:before { content: $fa-var-venus; }\n.#{$fa-css-prefix}-mars:before { content: $fa-var-mars; }\n.#{$fa-css-prefix}-mercury:before { content: $fa-var-mercury; }\n.#{$fa-css-prefix}-intersex:before,\n.#{$fa-css-prefix}-transgender:before { content: $fa-var-transgender; }\n.#{$fa-css-prefix}-transgender-alt:before { content: $fa-var-transgender-alt; }\n.#{$fa-css-prefix}-venus-double:before { content: $fa-var-venus-double; }\n.#{$fa-css-prefix}-mars-double:before { content: $fa-var-mars-double; }\n.#{$fa-css-prefix}-venus-mars:before { content: $fa-var-venus-mars; }\n.#{$fa-css-prefix}-mars-stroke:before { content: $fa-var-mars-stroke; }\n.#{$fa-css-prefix}-mars-stroke-v:before { content: $fa-var-mars-stroke-v; }\n.#{$fa-css-prefix}-mars-stroke-h:before { content: $fa-var-mars-stroke-h; }\n.#{$fa-css-prefix}-neuter:before { content: $fa-var-neuter; }\n.#{$fa-css-prefix}-genderless:before { content: $fa-var-genderless; }\n.#{$fa-css-prefix}-facebook-official:before { content: $fa-var-facebook-official; }\n.#{$fa-css-prefix}-pinterest-p:before { content: $fa-var-pinterest-p; }\n.#{$fa-css-prefix}-whatsapp:before { content: $fa-var-whatsapp; }\n.#{$fa-css-prefix}-server:before { content: $fa-var-server; }\n.#{$fa-css-prefix}-user-plus:before { content: $fa-var-user-plus; }\n.#{$fa-css-prefix}-user-times:before { content: $fa-var-user-times; }\n.#{$fa-css-prefix}-hotel:before,\n.#{$fa-css-prefix}-bed:before { content: $fa-var-bed; }\n.#{$fa-css-prefix}-viacoin:before { content: $fa-var-viacoin; }\n.#{$fa-css-prefix}-train:before { content: $fa-var-train; }\n.#{$fa-css-prefix}-subway:before { content: $fa-var-subway; }\n.#{$fa-css-prefix}-medium:before { content: $fa-var-medium; }\n.#{$fa-css-prefix}-yc:before,\n.#{$fa-css-prefix}-y-combinator:before { content: $fa-var-y-combinator; }\n.#{$fa-css-prefix}-optin-monster:before { content: $fa-var-optin-monster; }\n.#{$fa-css-prefix}-opencart:before { content: $fa-var-opencart; }\n.#{$fa-css-prefix}-expeditedssl:before { content: $fa-var-expeditedssl; }\n.#{$fa-css-prefix}-battery-4:before,\n.#{$fa-css-prefix}-battery:before,\n.#{$fa-css-prefix}-battery-full:before { content: $fa-var-battery-full; }\n.#{$fa-css-prefix}-battery-3:before,\n.#{$fa-css-prefix}-battery-three-quarters:before { content: $fa-var-battery-three-quarters; }\n.#{$fa-css-prefix}-battery-2:before,\n.#{$fa-css-prefix}-battery-half:before { content: $fa-var-battery-half; }\n.#{$fa-css-prefix}-battery-1:before,\n.#{$fa-css-prefix}-battery-quarter:before { content: $fa-var-battery-quarter; }\n.#{$fa-css-prefix}-battery-0:before,\n.#{$fa-css-prefix}-battery-empty:before { content: $fa-var-battery-empty; }\n.#{$fa-css-prefix}-mouse-pointer:before { content: $fa-var-mouse-pointer; }\n.#{$fa-css-prefix}-i-cursor:before { content: $fa-var-i-cursor; }\n.#{$fa-css-prefix}-object-group:before { content: $fa-var-object-group; }\n.#{$fa-css-prefix}-object-ungroup:before { content: $fa-var-object-ungroup; }\n.#{$fa-css-prefix}-sticky-note:before { content: $fa-var-sticky-note; }\n.#{$fa-css-prefix}-sticky-note-o:before { content: $fa-var-sticky-note-o; }\n.#{$fa-css-prefix}-cc-jcb:before { content: $fa-var-cc-jcb; }\n.#{$fa-css-prefix}-cc-diners-club:before { content: $fa-var-cc-diners-club; }\n.#{$fa-css-prefix}-clone:before { content: $fa-var-clone; }\n.#{$fa-css-prefix}-balance-scale:before { content: $fa-var-balance-scale; }\n.#{$fa-css-prefix}-hourglass-o:before { content: $fa-var-hourglass-o; }\n.#{$fa-css-prefix}-hourglass-1:before,\n.#{$fa-css-prefix}-hourglass-start:before { content: $fa-var-hourglass-start; }\n.#{$fa-css-prefix}-hourglass-2:before,\n.#{$fa-css-prefix}-hourglass-half:before { content: $fa-var-hourglass-half; }\n.#{$fa-css-prefix}-hourglass-3:before,\n.#{$fa-css-prefix}-hourglass-end:before { content: $fa-var-hourglass-end; }\n.#{$fa-css-prefix}-hourglass:before { content: $fa-var-hourglass; }\n.#{$fa-css-prefix}-hand-grab-o:before,\n.#{$fa-css-prefix}-hand-rock-o:before { content: $fa-var-hand-rock-o; }\n.#{$fa-css-prefix}-hand-stop-o:before,\n.#{$fa-css-prefix}-hand-paper-o:before { content: $fa-var-hand-paper-o; }\n.#{$fa-css-prefix}-hand-scissors-o:before { content: $fa-var-hand-scissors-o; }\n.#{$fa-css-prefix}-hand-lizard-o:before { content: $fa-var-hand-lizard-o; }\n.#{$fa-css-prefix}-hand-spock-o:before { content: $fa-var-hand-spock-o; }\n.#{$fa-css-prefix}-hand-pointer-o:before { content: $fa-var-hand-pointer-o; }\n.#{$fa-css-prefix}-hand-peace-o:before { content: $fa-var-hand-peace-o; }\n.#{$fa-css-prefix}-trademark:before { content: $fa-var-trademark; }\n.#{$fa-css-prefix}-registered:before { content: $fa-var-registered; }\n.#{$fa-css-prefix}-creative-commons:before { content: $fa-var-creative-commons; }\n.#{$fa-css-prefix}-gg:before { content: $fa-var-gg; }\n.#{$fa-css-prefix}-gg-circle:before { content: $fa-var-gg-circle; }\n.#{$fa-css-prefix}-tripadvisor:before { content: $fa-var-tripadvisor; }\n.#{$fa-css-prefix}-odnoklassniki:before { content: $fa-var-odnoklassniki; }\n.#{$fa-css-prefix}-odnoklassniki-square:before { content: $fa-var-odnoklassniki-square; }\n.#{$fa-css-prefix}-get-pocket:before { content: $fa-var-get-pocket; }\n.#{$fa-css-prefix}-wikipedia-w:before { content: $fa-var-wikipedia-w; }\n.#{$fa-css-prefix}-safari:before { content: $fa-var-safari; }\n.#{$fa-css-prefix}-chrome:before { content: $fa-var-chrome; }\n.#{$fa-css-prefix}-firefox:before { content: $fa-var-firefox; }\n.#{$fa-css-prefix}-opera:before { content: $fa-var-opera; }\n.#{$fa-css-prefix}-internet-explorer:before { content: $fa-var-internet-explorer; }\n.#{$fa-css-prefix}-tv:before,\n.#{$fa-css-prefix}-television:before { content: $fa-var-television; }\n.#{$fa-css-prefix}-contao:before { content: $fa-var-contao; }\n.#{$fa-css-prefix}-500px:before { content: $fa-var-500px; }\n.#{$fa-css-prefix}-amazon:before { content: $fa-var-amazon; }\n.#{$fa-css-prefix}-calendar-plus-o:before { content: $fa-var-calendar-plus-o; }\n.#{$fa-css-prefix}-calendar-minus-o:before { content: $fa-var-calendar-minus-o; }\n.#{$fa-css-prefix}-calendar-times-o:before { content: $fa-var-calendar-times-o; }\n.#{$fa-css-prefix}-calendar-check-o:before { content: $fa-var-calendar-check-o; }\n.#{$fa-css-prefix}-industry:before { content: $fa-var-industry; }\n.#{$fa-css-prefix}-map-pin:before { content: $fa-var-map-pin; }\n.#{$fa-css-prefix}-map-signs:before { content: $fa-var-map-signs; }\n.#{$fa-css-prefix}-map-o:before { content: $fa-var-map-o; }\n.#{$fa-css-prefix}-map:before { content: $fa-var-map; }\n.#{$fa-css-prefix}-commenting:before { content: $fa-var-commenting; }\n.#{$fa-css-prefix}-commenting-o:before { content: $fa-var-commenting-o; }\n.#{$fa-css-prefix}-houzz:before { content: $fa-var-houzz; }\n.#{$fa-css-prefix}-vimeo:before { content: $fa-var-vimeo; }\n.#{$fa-css-prefix}-black-tie:before { content: $fa-var-black-tie; }\n.#{$fa-css-prefix}-fonticons:before { content: $fa-var-fonticons; }\n.#{$fa-css-prefix}-reddit-alien:before { content: $fa-var-reddit-alien; }\n.#{$fa-css-prefix}-edge:before { content: $fa-var-edge; }\n.#{$fa-css-prefix}-credit-card-alt:before { content: $fa-var-credit-card-alt; }\n.#{$fa-css-prefix}-codiepie:before { content: $fa-var-codiepie; }\n.#{$fa-css-prefix}-modx:before { content: $fa-var-modx; }\n.#{$fa-css-prefix}-fort-awesome:before { content: $fa-var-fort-awesome; }\n.#{$fa-css-prefix}-usb:before { content: $fa-var-usb; }\n.#{$fa-css-prefix}-product-hunt:before { content: $fa-var-product-hunt; }\n.#{$fa-css-prefix}-mixcloud:before { content: $fa-var-mixcloud; }\n.#{$fa-css-prefix}-scribd:before { content: $fa-var-scribd; }\n.#{$fa-css-prefix}-pause-circle:before { content: $fa-var-pause-circle; }\n.#{$fa-css-prefix}-pause-circle-o:before { content: $fa-var-pause-circle-o; }\n.#{$fa-css-prefix}-stop-circle:before { content: $fa-var-stop-circle; }\n.#{$fa-css-prefix}-stop-circle-o:before { content: $fa-var-stop-circle-o; }\n.#{$fa-css-prefix}-shopping-bag:before { content: $fa-var-shopping-bag; }\n.#{$fa-css-prefix}-shopping-basket:before { content: $fa-var-shopping-basket; }\n.#{$fa-css-prefix}-hashtag:before { content: $fa-var-hashtag; }\n.#{$fa-css-prefix}-bluetooth:before { content: $fa-var-bluetooth; }\n.#{$fa-css-prefix}-bluetooth-b:before { content: $fa-var-bluetooth-b; }\n.#{$fa-css-prefix}-percent:before { content: $fa-var-percent; }\n.#{$fa-css-prefix}-gitlab:before { content: $fa-var-gitlab; }\n.#{$fa-css-prefix}-wpbeginner:before { content: $fa-var-wpbeginner; }\n.#{$fa-css-prefix}-wpforms:before { content: $fa-var-wpforms; }\n.#{$fa-css-prefix}-envira:before { content: $fa-var-envira; }\n.#{$fa-css-prefix}-universal-access:before { content: $fa-var-universal-access; }\n.#{$fa-css-prefix}-wheelchair-alt:before { content: $fa-var-wheelchair-alt; }\n.#{$fa-css-prefix}-question-circle-o:before { content: $fa-var-question-circle-o; }\n.#{$fa-css-prefix}-blind:before { content: $fa-var-blind; }\n.#{$fa-css-prefix}-audio-description:before { content: $fa-var-audio-description; }\n.#{$fa-css-prefix}-volume-control-phone:before { content: $fa-var-volume-control-phone; }\n.#{$fa-css-prefix}-braille:before { content: $fa-var-braille; }\n.#{$fa-css-prefix}-assistive-listening-systems:before { content: $fa-var-assistive-listening-systems; }\n.#{$fa-css-prefix}-asl-interpreting:before,\n.#{$fa-css-prefix}-american-sign-language-interpreting:before { content: $fa-var-american-sign-language-interpreting; }\n.#{$fa-css-prefix}-deafness:before,\n.#{$fa-css-prefix}-hard-of-hearing:before,\n.#{$fa-css-prefix}-deaf:before { content: $fa-var-deaf; }\n.#{$fa-css-prefix}-glide:before { content: $fa-var-glide; }\n.#{$fa-css-prefix}-glide-g:before { content: $fa-var-glide-g; }\n.#{$fa-css-prefix}-signing:before,\n.#{$fa-css-prefix}-sign-language:before { content: $fa-var-sign-language; }\n.#{$fa-css-prefix}-low-vision:before { content: $fa-var-low-vision; }\n.#{$fa-css-prefix}-viadeo:before { content: $fa-var-viadeo; }\n.#{$fa-css-prefix}-viadeo-square:before { content: $fa-var-viadeo-square; }\n.#{$fa-css-prefix}-snapchat:before { content: $fa-var-snapchat; }\n.#{$fa-css-prefix}-snapchat-ghost:before { content: $fa-var-snapchat-ghost; }\n.#{$fa-css-prefix}-snapchat-square:before { content: $fa-var-snapchat-square; }\n.#{$fa-css-prefix}-pied-piper:before { content: $fa-var-pied-piper; }\n.#{$fa-css-prefix}-first-order:before { content: $fa-var-first-order; }\n.#{$fa-css-prefix}-yoast:before { content: $fa-var-yoast; }\n.#{$fa-css-prefix}-themeisle:before { content: $fa-var-themeisle; }\n.#{$fa-css-prefix}-google-plus-circle:before,\n.#{$fa-css-prefix}-google-plus-official:before { content: $fa-var-google-plus-official; }\n.#{$fa-css-prefix}-fa:before,\n.#{$fa-css-prefix}-font-awesome:before { content: $fa-var-font-awesome; }\n.#{$fa-css-prefix}-handshake-o:before { content: $fa-var-handshake-o; }\n.#{$fa-css-prefix}-envelope-open:before { content: $fa-var-envelope-open; }\n.#{$fa-css-prefix}-envelope-open-o:before { content: $fa-var-envelope-open-o; }\n.#{$fa-css-prefix}-linode:before { content: $fa-var-linode; }\n.#{$fa-css-prefix}-address-book:before { content: $fa-var-address-book; }\n.#{$fa-css-prefix}-address-book-o:before { content: $fa-var-address-book-o; }\n.#{$fa-css-prefix}-vcard:before,\n.#{$fa-css-prefix}-address-card:before { content: $fa-var-address-card; }\n.#{$fa-css-prefix}-vcard-o:before,\n.#{$fa-css-prefix}-address-card-o:before { content: $fa-var-address-card-o; }\n.#{$fa-css-prefix}-user-circle:before { content: $fa-var-user-circle; }\n.#{$fa-css-prefix}-user-circle-o:before { content: $fa-var-user-circle-o; }\n.#{$fa-css-prefix}-user-o:before { content: $fa-var-user-o; }\n.#{$fa-css-prefix}-id-badge:before { content: $fa-var-id-badge; }\n.#{$fa-css-prefix}-drivers-license:before,\n.#{$fa-css-prefix}-id-card:before { content: $fa-var-id-card; }\n.#{$fa-css-prefix}-drivers-license-o:before,\n.#{$fa-css-prefix}-id-card-o:before { content: $fa-var-id-card-o; }\n.#{$fa-css-prefix}-quora:before { content: $fa-var-quora; }\n.#{$fa-css-prefix}-free-code-camp:before { content: $fa-var-free-code-camp; }\n.#{$fa-css-prefix}-telegram:before { content: $fa-var-telegram; }\n.#{$fa-css-prefix}-thermometer-4:before,\n.#{$fa-css-prefix}-thermometer:before,\n.#{$fa-css-prefix}-thermometer-full:before { content: $fa-var-thermometer-full; }\n.#{$fa-css-prefix}-thermometer-3:before,\n.#{$fa-css-prefix}-thermometer-three-quarters:before { content: $fa-var-thermometer-three-quarters; }\n.#{$fa-css-prefix}-thermometer-2:before,\n.#{$fa-css-prefix}-thermometer-half:before { content: $fa-var-thermometer-half; }\n.#{$fa-css-prefix}-thermometer-1:before,\n.#{$fa-css-prefix}-thermometer-quarter:before { content: $fa-var-thermometer-quarter; }\n.#{$fa-css-prefix}-thermometer-0:before,\n.#{$fa-css-prefix}-thermometer-empty:before { content: $fa-var-thermometer-empty; }\n.#{$fa-css-prefix}-shower:before { content: $fa-var-shower; }\n.#{$fa-css-prefix}-bathtub:before,\n.#{$fa-css-prefix}-s15:before,\n.#{$fa-css-prefix}-bath:before { content: $fa-var-bath; }\n.#{$fa-css-prefix}-podcast:before { content: $fa-var-podcast; }\n.#{$fa-css-prefix}-window-maximize:before { content: $fa-var-window-maximize; }\n.#{$fa-css-prefix}-window-minimize:before { content: $fa-var-window-minimize; }\n.#{$fa-css-prefix}-window-restore:before { content: $fa-var-window-restore; }\n.#{$fa-css-prefix}-times-rectangle:before,\n.#{$fa-css-prefix}-window-close:before { content: $fa-var-window-close; }\n.#{$fa-css-prefix}-times-rectangle-o:before,\n.#{$fa-css-prefix}-window-close-o:before { content: $fa-var-window-close-o; }\n.#{$fa-css-prefix}-bandcamp:before { content: $fa-var-bandcamp; }\n.#{$fa-css-prefix}-grav:before { content: $fa-var-grav; }\n.#{$fa-css-prefix}-etsy:before { content: $fa-var-etsy; }\n.#{$fa-css-prefix}-imdb:before { content: $fa-var-imdb; }\n.#{$fa-css-prefix}-ravelry:before { content: $fa-var-ravelry; }\n.#{$fa-css-prefix}-eercast:before { content: $fa-var-eercast; }\n.#{$fa-css-prefix}-microchip:before { content: $fa-var-microchip; }\n.#{$fa-css-prefix}-snowflake-o:before { content: $fa-var-snowflake-o; }\n.#{$fa-css-prefix}-superpowers:before { content: $fa-var-superpowers; }\n.#{$fa-css-prefix}-wpexplorer:before { content: $fa-var-wpexplorer; }\n.#{$fa-css-prefix}-meetup:before { content: $fa-var-meetup; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_larger.scss",
    "content": "// Icon Sizes\n// -------------------------\n\n/* makes the font 33% larger relative to the icon container */\n.#{$fa-css-prefix}-lg {\n  font-size: (4em / 3);\n  line-height: (3em / 4);\n  vertical-align: -15%;\n}\n.#{$fa-css-prefix}-2x { font-size: 2em; }\n.#{$fa-css-prefix}-3x { font-size: 3em; }\n.#{$fa-css-prefix}-4x { font-size: 4em; }\n.#{$fa-css-prefix}-5x { font-size: 5em; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_list.scss",
    "content": "// List Icons\n// -------------------------\n\n.#{$fa-css-prefix}-ul {\n  padding-left: 0;\n  margin-left: $fa-li-width;\n  list-style-type: none;\n  > li { position: relative; }\n}\n.#{$fa-css-prefix}-li {\n  position: absolute;\n  left: -$fa-li-width;\n  width: $fa-li-width;\n  top: (2em / 14);\n  text-align: center;\n  &.#{$fa-css-prefix}-lg {\n    left: -$fa-li-width + (4em / 14);\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_mixins.scss",
    "content": "// Mixins\n// --------------------------\n\n@mixin fa-icon() {\n  display: inline-block;\n  font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n\n}\n\n@mixin fa-icon-rotate($degrees, $rotation) {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation})\";\n  -webkit-transform: rotate($degrees);\n      -ms-transform: rotate($degrees);\n          transform: rotate($degrees);\n}\n\n@mixin fa-icon-flip($horiz, $vert, $rotation) {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation}, mirror=1)\";\n  -webkit-transform: scale($horiz, $vert);\n      -ms-transform: scale($horiz, $vert);\n          transform: scale($horiz, $vert);\n}\n\n\n// Only display content to screen readers. A la Bootstrap 4.\n//\n// See: http://a11yproject.com/posts/how-to-hide-content/\n\n@mixin sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  margin: -1px;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  border: 0;\n}\n\n// Use in conjunction with .sr-only to only display content when it's focused.\n//\n// Useful for \"Skip to main content\" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1\n//\n// Credit: HTML5 Boilerplate\n\n@mixin sr-only-focusable {\n  &:active,\n  &:focus {\n    position: static;\n    width: auto;\n    height: auto;\n    margin: 0;\n    overflow: visible;\n    clip: auto;\n  }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_path.scss",
    "content": "/* FONT PATH\n * -------------------------- */\n\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('#{$fa-font-path}/fontawesome-webfont.eot?v=#{$fa-version}');\n  src: url('#{$fa-font-path}/fontawesome-webfont.eot?#iefix&v=#{$fa-version}') format('embedded-opentype'),\n    url('#{$fa-font-path}/fontawesome-webfont.woff2?v=#{$fa-version}') format('woff2'),\n    url('#{$fa-font-path}/fontawesome-webfont.woff?v=#{$fa-version}') format('woff'),\n    url('#{$fa-font-path}/fontawesome-webfont.ttf?v=#{$fa-version}') format('truetype'),\n    url('#{$fa-font-path}/fontawesome-webfont.svg?v=#{$fa-version}#fontawesomeregular') format('svg');\n//  src: url('#{$fa-font-path}/FontAwesome.otf') format('opentype'); // used when developing fonts\n  font-weight: normal;\n  font-style: normal;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_rotated-flipped.scss",
    "content": "// Rotated & Flipped Icons\n// -------------------------\n\n.#{$fa-css-prefix}-rotate-90  { @include fa-icon-rotate(90deg, 1);  }\n.#{$fa-css-prefix}-rotate-180 { @include fa-icon-rotate(180deg, 2); }\n.#{$fa-css-prefix}-rotate-270 { @include fa-icon-rotate(270deg, 3); }\n\n.#{$fa-css-prefix}-flip-horizontal { @include fa-icon-flip(-1, 1, 0); }\n.#{$fa-css-prefix}-flip-vertical   { @include fa-icon-flip(1, -1, 2); }\n\n// Hook for IE8-9\n// -------------------------\n\n:root .#{$fa-css-prefix}-rotate-90,\n:root .#{$fa-css-prefix}-rotate-180,\n:root .#{$fa-css-prefix}-rotate-270,\n:root .#{$fa-css-prefix}-flip-horizontal,\n:root .#{$fa-css-prefix}-flip-vertical {\n  filter: none;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_screen-reader.scss",
    "content": "// Screen Readers\n// -------------------------\n\n.sr-only { @include sr-only(); }\n.sr-only-focusable { @include sr-only-focusable(); }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_stacked.scss",
    "content": "// Stacked Icons\n// -------------------------\n\n.#{$fa-css-prefix}-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.#{$fa-css-prefix}-stack-1x, .#{$fa-css-prefix}-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.#{$fa-css-prefix}-stack-1x { line-height: inherit; }\n.#{$fa-css-prefix}-stack-2x { font-size: 2em; }\n.#{$fa-css-prefix}-inverse { color: $fa-inverse; }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/_variables.scss",
    "content": "// Variables\n// --------------------------\n\n$fa-font-path:        \"../fonts\" !default;\n$fa-font-size-base:   14px !default;\n$fa-line-height-base: 1 !default;\n//$fa-font-path:        \"//netdna.bootstrapcdn.com/font-awesome/4.7.0/fonts\" !default; // for referencing Bootstrap CDN font files directly\n$fa-css-prefix:       fa !default;\n$fa-version:          \"4.7.0\" !default;\n$fa-border-color:     #eee !default;\n$fa-inverse:          #fff !default;\n$fa-li-width:         (30em / 14) !default;\n\n$fa-var-500px: \"\\f26e\";\n$fa-var-address-book: \"\\f2b9\";\n$fa-var-address-book-o: \"\\f2ba\";\n$fa-var-address-card: \"\\f2bb\";\n$fa-var-address-card-o: \"\\f2bc\";\n$fa-var-adjust: \"\\f042\";\n$fa-var-adn: \"\\f170\";\n$fa-var-align-center: \"\\f037\";\n$fa-var-align-justify: \"\\f039\";\n$fa-var-align-left: \"\\f036\";\n$fa-var-align-right: \"\\f038\";\n$fa-var-amazon: \"\\f270\";\n$fa-var-ambulance: \"\\f0f9\";\n$fa-var-american-sign-language-interpreting: \"\\f2a3\";\n$fa-var-anchor: \"\\f13d\";\n$fa-var-android: \"\\f17b\";\n$fa-var-angellist: \"\\f209\";\n$fa-var-angle-double-down: \"\\f103\";\n$fa-var-angle-double-left: \"\\f100\";\n$fa-var-angle-double-right: \"\\f101\";\n$fa-var-angle-double-up: \"\\f102\";\n$fa-var-angle-down: \"\\f107\";\n$fa-var-angle-left: \"\\f104\";\n$fa-var-angle-right: \"\\f105\";\n$fa-var-angle-up: \"\\f106\";\n$fa-var-apple: \"\\f179\";\n$fa-var-archive: \"\\f187\";\n$fa-var-area-chart: \"\\f1fe\";\n$fa-var-arrow-circle-down: \"\\f0ab\";\n$fa-var-arrow-circle-left: \"\\f0a8\";\n$fa-var-arrow-circle-o-down: \"\\f01a\";\n$fa-var-arrow-circle-o-left: \"\\f190\";\n$fa-var-arrow-circle-o-right: \"\\f18e\";\n$fa-var-arrow-circle-o-up: \"\\f01b\";\n$fa-var-arrow-circle-right: \"\\f0a9\";\n$fa-var-arrow-circle-up: \"\\f0aa\";\n$fa-var-arrow-down: \"\\f063\";\n$fa-var-arrow-left: \"\\f060\";\n$fa-var-arrow-right: \"\\f061\";\n$fa-var-arrow-up: \"\\f062\";\n$fa-var-arrows: \"\\f047\";\n$fa-var-arrows-alt: \"\\f0b2\";\n$fa-var-arrows-h: \"\\f07e\";\n$fa-var-arrows-v: \"\\f07d\";\n$fa-var-asl-interpreting: \"\\f2a3\";\n$fa-var-assistive-listening-systems: \"\\f2a2\";\n$fa-var-asterisk: \"\\f069\";\n$fa-var-at: \"\\f1fa\";\n$fa-var-audio-description: \"\\f29e\";\n$fa-var-automobile: \"\\f1b9\";\n$fa-var-backward: \"\\f04a\";\n$fa-var-balance-scale: \"\\f24e\";\n$fa-var-ban: \"\\f05e\";\n$fa-var-bandcamp: \"\\f2d5\";\n$fa-var-bank: \"\\f19c\";\n$fa-var-bar-chart: \"\\f080\";\n$fa-var-bar-chart-o: \"\\f080\";\n$fa-var-barcode: \"\\f02a\";\n$fa-var-bars: \"\\f0c9\";\n$fa-var-bath: \"\\f2cd\";\n$fa-var-bathtub: \"\\f2cd\";\n$fa-var-battery: \"\\f240\";\n$fa-var-battery-0: \"\\f244\";\n$fa-var-battery-1: \"\\f243\";\n$fa-var-battery-2: \"\\f242\";\n$fa-var-battery-3: \"\\f241\";\n$fa-var-battery-4: \"\\f240\";\n$fa-var-battery-empty: \"\\f244\";\n$fa-var-battery-full: \"\\f240\";\n$fa-var-battery-half: \"\\f242\";\n$fa-var-battery-quarter: \"\\f243\";\n$fa-var-battery-three-quarters: \"\\f241\";\n$fa-var-bed: \"\\f236\";\n$fa-var-beer: \"\\f0fc\";\n$fa-var-behance: \"\\f1b4\";\n$fa-var-behance-square: \"\\f1b5\";\n$fa-var-bell: \"\\f0f3\";\n$fa-var-bell-o: \"\\f0a2\";\n$fa-var-bell-slash: \"\\f1f6\";\n$fa-var-bell-slash-o: \"\\f1f7\";\n$fa-var-bicycle: \"\\f206\";\n$fa-var-binoculars: \"\\f1e5\";\n$fa-var-birthday-cake: \"\\f1fd\";\n$fa-var-bitbucket: \"\\f171\";\n$fa-var-bitbucket-square: \"\\f172\";\n$fa-var-bitcoin: \"\\f15a\";\n$fa-var-black-tie: \"\\f27e\";\n$fa-var-blind: \"\\f29d\";\n$fa-var-bluetooth: \"\\f293\";\n$fa-var-bluetooth-b: \"\\f294\";\n$fa-var-bold: \"\\f032\";\n$fa-var-bolt: \"\\f0e7\";\n$fa-var-bomb: \"\\f1e2\";\n$fa-var-book: \"\\f02d\";\n$fa-var-bookmark: \"\\f02e\";\n$fa-var-bookmark-o: \"\\f097\";\n$fa-var-braille: \"\\f2a1\";\n$fa-var-briefcase: \"\\f0b1\";\n$fa-var-btc: \"\\f15a\";\n$fa-var-bug: \"\\f188\";\n$fa-var-building: \"\\f1ad\";\n$fa-var-building-o: \"\\f0f7\";\n$fa-var-bullhorn: \"\\f0a1\";\n$fa-var-bullseye: \"\\f140\";\n$fa-var-bus: \"\\f207\";\n$fa-var-buysellads: \"\\f20d\";\n$fa-var-cab: \"\\f1ba\";\n$fa-var-calculator: \"\\f1ec\";\n$fa-var-calendar: \"\\f073\";\n$fa-var-calendar-check-o: \"\\f274\";\n$fa-var-calendar-minus-o: \"\\f272\";\n$fa-var-calendar-o: \"\\f133\";\n$fa-var-calendar-plus-o: \"\\f271\";\n$fa-var-calendar-times-o: \"\\f273\";\n$fa-var-camera: \"\\f030\";\n$fa-var-camera-retro: \"\\f083\";\n$fa-var-car: \"\\f1b9\";\n$fa-var-caret-down: \"\\f0d7\";\n$fa-var-caret-left: \"\\f0d9\";\n$fa-var-caret-right: \"\\f0da\";\n$fa-var-caret-square-o-down: \"\\f150\";\n$fa-var-caret-square-o-left: \"\\f191\";\n$fa-var-caret-square-o-right: \"\\f152\";\n$fa-var-caret-square-o-up: \"\\f151\";\n$fa-var-caret-up: \"\\f0d8\";\n$fa-var-cart-arrow-down: \"\\f218\";\n$fa-var-cart-plus: \"\\f217\";\n$fa-var-cc: \"\\f20a\";\n$fa-var-cc-amex: \"\\f1f3\";\n$fa-var-cc-diners-club: \"\\f24c\";\n$fa-var-cc-discover: \"\\f1f2\";\n$fa-var-cc-jcb: \"\\f24b\";\n$fa-var-cc-mastercard: \"\\f1f1\";\n$fa-var-cc-paypal: \"\\f1f4\";\n$fa-var-cc-stripe: \"\\f1f5\";\n$fa-var-cc-visa: \"\\f1f0\";\n$fa-var-certificate: \"\\f0a3\";\n$fa-var-chain: \"\\f0c1\";\n$fa-var-chain-broken: \"\\f127\";\n$fa-var-check: \"\\f00c\";\n$fa-var-check-circle: \"\\f058\";\n$fa-var-check-circle-o: \"\\f05d\";\n$fa-var-check-square: \"\\f14a\";\n$fa-var-check-square-o: \"\\f046\";\n$fa-var-chevron-circle-down: \"\\f13a\";\n$fa-var-chevron-circle-left: \"\\f137\";\n$fa-var-chevron-circle-right: \"\\f138\";\n$fa-var-chevron-circle-up: \"\\f139\";\n$fa-var-chevron-down: \"\\f078\";\n$fa-var-chevron-left: \"\\f053\";\n$fa-var-chevron-right: \"\\f054\";\n$fa-var-chevron-up: \"\\f077\";\n$fa-var-child: \"\\f1ae\";\n$fa-var-chrome: \"\\f268\";\n$fa-var-circle: \"\\f111\";\n$fa-var-circle-o: \"\\f10c\";\n$fa-var-circle-o-notch: \"\\f1ce\";\n$fa-var-circle-thin: \"\\f1db\";\n$fa-var-clipboard: \"\\f0ea\";\n$fa-var-clock-o: \"\\f017\";\n$fa-var-clone: \"\\f24d\";\n$fa-var-close: \"\\f00d\";\n$fa-var-cloud: \"\\f0c2\";\n$fa-var-cloud-download: \"\\f0ed\";\n$fa-var-cloud-upload: \"\\f0ee\";\n$fa-var-cny: \"\\f157\";\n$fa-var-code: \"\\f121\";\n$fa-var-code-fork: \"\\f126\";\n$fa-var-codepen: \"\\f1cb\";\n$fa-var-codiepie: \"\\f284\";\n$fa-var-coffee: \"\\f0f4\";\n$fa-var-cog: \"\\f013\";\n$fa-var-cogs: \"\\f085\";\n$fa-var-columns: \"\\f0db\";\n$fa-var-comment: \"\\f075\";\n$fa-var-comment-o: \"\\f0e5\";\n$fa-var-commenting: \"\\f27a\";\n$fa-var-commenting-o: \"\\f27b\";\n$fa-var-comments: \"\\f086\";\n$fa-var-comments-o: \"\\f0e6\";\n$fa-var-compass: \"\\f14e\";\n$fa-var-compress: \"\\f066\";\n$fa-var-connectdevelop: \"\\f20e\";\n$fa-var-contao: \"\\f26d\";\n$fa-var-copy: \"\\f0c5\";\n$fa-var-copyright: \"\\f1f9\";\n$fa-var-creative-commons: \"\\f25e\";\n$fa-var-credit-card: \"\\f09d\";\n$fa-var-credit-card-alt: \"\\f283\";\n$fa-var-crop: \"\\f125\";\n$fa-var-crosshairs: \"\\f05b\";\n$fa-var-css3: \"\\f13c\";\n$fa-var-cube: \"\\f1b2\";\n$fa-var-cubes: \"\\f1b3\";\n$fa-var-cut: \"\\f0c4\";\n$fa-var-cutlery: \"\\f0f5\";\n$fa-var-dashboard: \"\\f0e4\";\n$fa-var-dashcube: \"\\f210\";\n$fa-var-database: \"\\f1c0\";\n$fa-var-deaf: \"\\f2a4\";\n$fa-var-deafness: \"\\f2a4\";\n$fa-var-dedent: \"\\f03b\";\n$fa-var-delicious: \"\\f1a5\";\n$fa-var-desktop: \"\\f108\";\n$fa-var-deviantart: \"\\f1bd\";\n$fa-var-diamond: \"\\f219\";\n$fa-var-digg: \"\\f1a6\";\n$fa-var-dollar: \"\\f155\";\n$fa-var-dot-circle-o: \"\\f192\";\n$fa-var-download: \"\\f019\";\n$fa-var-dribbble: \"\\f17d\";\n$fa-var-drivers-license: \"\\f2c2\";\n$fa-var-drivers-license-o: \"\\f2c3\";\n$fa-var-dropbox: \"\\f16b\";\n$fa-var-drupal: \"\\f1a9\";\n$fa-var-edge: \"\\f282\";\n$fa-var-edit: \"\\f044\";\n$fa-var-eercast: \"\\f2da\";\n$fa-var-eject: \"\\f052\";\n$fa-var-ellipsis-h: \"\\f141\";\n$fa-var-ellipsis-v: \"\\f142\";\n$fa-var-empire: \"\\f1d1\";\n$fa-var-envelope: \"\\f0e0\";\n$fa-var-envelope-o: \"\\f003\";\n$fa-var-envelope-open: \"\\f2b6\";\n$fa-var-envelope-open-o: \"\\f2b7\";\n$fa-var-envelope-square: \"\\f199\";\n$fa-var-envira: \"\\f299\";\n$fa-var-eraser: \"\\f12d\";\n$fa-var-etsy: \"\\f2d7\";\n$fa-var-eur: \"\\f153\";\n$fa-var-euro: \"\\f153\";\n$fa-var-exchange: \"\\f0ec\";\n$fa-var-exclamation: \"\\f12a\";\n$fa-var-exclamation-circle: \"\\f06a\";\n$fa-var-exclamation-triangle: \"\\f071\";\n$fa-var-expand: \"\\f065\";\n$fa-var-expeditedssl: \"\\f23e\";\n$fa-var-external-link: \"\\f08e\";\n$fa-var-external-link-square: \"\\f14c\";\n$fa-var-eye: \"\\f06e\";\n$fa-var-eye-slash: \"\\f070\";\n$fa-var-eyedropper: \"\\f1fb\";\n$fa-var-fa: \"\\f2b4\";\n$fa-var-facebook: \"\\f09a\";\n$fa-var-facebook-f: \"\\f09a\";\n$fa-var-facebook-official: \"\\f230\";\n$fa-var-facebook-square: \"\\f082\";\n$fa-var-fast-backward: \"\\f049\";\n$fa-var-fast-forward: \"\\f050\";\n$fa-var-fax: \"\\f1ac\";\n$fa-var-feed: \"\\f09e\";\n$fa-var-female: \"\\f182\";\n$fa-var-fighter-jet: \"\\f0fb\";\n$fa-var-file: \"\\f15b\";\n$fa-var-file-archive-o: \"\\f1c6\";\n$fa-var-file-audio-o: \"\\f1c7\";\n$fa-var-file-code-o: \"\\f1c9\";\n$fa-var-file-excel-o: \"\\f1c3\";\n$fa-var-file-image-o: \"\\f1c5\";\n$fa-var-file-movie-o: \"\\f1c8\";\n$fa-var-file-o: \"\\f016\";\n$fa-var-file-pdf-o: \"\\f1c1\";\n$fa-var-file-photo-o: \"\\f1c5\";\n$fa-var-file-picture-o: \"\\f1c5\";\n$fa-var-file-powerpoint-o: \"\\f1c4\";\n$fa-var-file-sound-o: \"\\f1c7\";\n$fa-var-file-text: \"\\f15c\";\n$fa-var-file-text-o: \"\\f0f6\";\n$fa-var-file-video-o: \"\\f1c8\";\n$fa-var-file-word-o: \"\\f1c2\";\n$fa-var-file-zip-o: \"\\f1c6\";\n$fa-var-files-o: \"\\f0c5\";\n$fa-var-film: \"\\f008\";\n$fa-var-filter: \"\\f0b0\";\n$fa-var-fire: \"\\f06d\";\n$fa-var-fire-extinguisher: \"\\f134\";\n$fa-var-firefox: \"\\f269\";\n$fa-var-first-order: \"\\f2b0\";\n$fa-var-flag: \"\\f024\";\n$fa-var-flag-checkered: \"\\f11e\";\n$fa-var-flag-o: \"\\f11d\";\n$fa-var-flash: \"\\f0e7\";\n$fa-var-flask: \"\\f0c3\";\n$fa-var-flickr: \"\\f16e\";\n$fa-var-floppy-o: \"\\f0c7\";\n$fa-var-folder: \"\\f07b\";\n$fa-var-folder-o: \"\\f114\";\n$fa-var-folder-open: \"\\f07c\";\n$fa-var-folder-open-o: \"\\f115\";\n$fa-var-font: \"\\f031\";\n$fa-var-font-awesome: \"\\f2b4\";\n$fa-var-fonticons: \"\\f280\";\n$fa-var-fort-awesome: \"\\f286\";\n$fa-var-forumbee: \"\\f211\";\n$fa-var-forward: \"\\f04e\";\n$fa-var-foursquare: \"\\f180\";\n$fa-var-free-code-camp: \"\\f2c5\";\n$fa-var-frown-o: \"\\f119\";\n$fa-var-futbol-o: \"\\f1e3\";\n$fa-var-gamepad: \"\\f11b\";\n$fa-var-gavel: \"\\f0e3\";\n$fa-var-gbp: \"\\f154\";\n$fa-var-ge: \"\\f1d1\";\n$fa-var-gear: \"\\f013\";\n$fa-var-gears: \"\\f085\";\n$fa-var-genderless: \"\\f22d\";\n$fa-var-get-pocket: \"\\f265\";\n$fa-var-gg: \"\\f260\";\n$fa-var-gg-circle: \"\\f261\";\n$fa-var-gift: \"\\f06b\";\n$fa-var-git: \"\\f1d3\";\n$fa-var-git-square: \"\\f1d2\";\n$fa-var-github: \"\\f09b\";\n$fa-var-github-alt: \"\\f113\";\n$fa-var-github-square: \"\\f092\";\n$fa-var-gitlab: \"\\f296\";\n$fa-var-gittip: \"\\f184\";\n$fa-var-glass: \"\\f000\";\n$fa-var-glide: \"\\f2a5\";\n$fa-var-glide-g: \"\\f2a6\";\n$fa-var-globe: \"\\f0ac\";\n$fa-var-google: \"\\f1a0\";\n$fa-var-google-plus: \"\\f0d5\";\n$fa-var-google-plus-circle: \"\\f2b3\";\n$fa-var-google-plus-official: \"\\f2b3\";\n$fa-var-google-plus-square: \"\\f0d4\";\n$fa-var-google-wallet: \"\\f1ee\";\n$fa-var-graduation-cap: \"\\f19d\";\n$fa-var-gratipay: \"\\f184\";\n$fa-var-grav: \"\\f2d6\";\n$fa-var-group: \"\\f0c0\";\n$fa-var-h-square: \"\\f0fd\";\n$fa-var-hacker-news: \"\\f1d4\";\n$fa-var-hand-grab-o: \"\\f255\";\n$fa-var-hand-lizard-o: \"\\f258\";\n$fa-var-hand-o-down: \"\\f0a7\";\n$fa-var-hand-o-left: \"\\f0a5\";\n$fa-var-hand-o-right: \"\\f0a4\";\n$fa-var-hand-o-up: \"\\f0a6\";\n$fa-var-hand-paper-o: \"\\f256\";\n$fa-var-hand-peace-o: \"\\f25b\";\n$fa-var-hand-pointer-o: \"\\f25a\";\n$fa-var-hand-rock-o: \"\\f255\";\n$fa-var-hand-scissors-o: \"\\f257\";\n$fa-var-hand-spock-o: \"\\f259\";\n$fa-var-hand-stop-o: \"\\f256\";\n$fa-var-handshake-o: \"\\f2b5\";\n$fa-var-hard-of-hearing: \"\\f2a4\";\n$fa-var-hashtag: \"\\f292\";\n$fa-var-hdd-o: \"\\f0a0\";\n$fa-var-header: \"\\f1dc\";\n$fa-var-headphones: \"\\f025\";\n$fa-var-heart: \"\\f004\";\n$fa-var-heart-o: \"\\f08a\";\n$fa-var-heartbeat: \"\\f21e\";\n$fa-var-history: \"\\f1da\";\n$fa-var-home: \"\\f015\";\n$fa-var-hospital-o: \"\\f0f8\";\n$fa-var-hotel: \"\\f236\";\n$fa-var-hourglass: \"\\f254\";\n$fa-var-hourglass-1: \"\\f251\";\n$fa-var-hourglass-2: \"\\f252\";\n$fa-var-hourglass-3: \"\\f253\";\n$fa-var-hourglass-end: \"\\f253\";\n$fa-var-hourglass-half: \"\\f252\";\n$fa-var-hourglass-o: \"\\f250\";\n$fa-var-hourglass-start: \"\\f251\";\n$fa-var-houzz: \"\\f27c\";\n$fa-var-html5: \"\\f13b\";\n$fa-var-i-cursor: \"\\f246\";\n$fa-var-id-badge: \"\\f2c1\";\n$fa-var-id-card: \"\\f2c2\";\n$fa-var-id-card-o: \"\\f2c3\";\n$fa-var-ils: \"\\f20b\";\n$fa-var-image: \"\\f03e\";\n$fa-var-imdb: \"\\f2d8\";\n$fa-var-inbox: \"\\f01c\";\n$fa-var-indent: \"\\f03c\";\n$fa-var-industry: \"\\f275\";\n$fa-var-info: \"\\f129\";\n$fa-var-info-circle: \"\\f05a\";\n$fa-var-inr: \"\\f156\";\n$fa-var-instagram: \"\\f16d\";\n$fa-var-institution: \"\\f19c\";\n$fa-var-internet-explorer: \"\\f26b\";\n$fa-var-intersex: \"\\f224\";\n$fa-var-ioxhost: \"\\f208\";\n$fa-var-italic: \"\\f033\";\n$fa-var-joomla: \"\\f1aa\";\n$fa-var-jpy: \"\\f157\";\n$fa-var-jsfiddle: \"\\f1cc\";\n$fa-var-key: \"\\f084\";\n$fa-var-keyboard-o: \"\\f11c\";\n$fa-var-krw: \"\\f159\";\n$fa-var-language: \"\\f1ab\";\n$fa-var-laptop: \"\\f109\";\n$fa-var-lastfm: \"\\f202\";\n$fa-var-lastfm-square: \"\\f203\";\n$fa-var-leaf: \"\\f06c\";\n$fa-var-leanpub: \"\\f212\";\n$fa-var-legal: \"\\f0e3\";\n$fa-var-lemon-o: \"\\f094\";\n$fa-var-level-down: \"\\f149\";\n$fa-var-level-up: \"\\f148\";\n$fa-var-life-bouy: \"\\f1cd\";\n$fa-var-life-buoy: \"\\f1cd\";\n$fa-var-life-ring: \"\\f1cd\";\n$fa-var-life-saver: \"\\f1cd\";\n$fa-var-lightbulb-o: \"\\f0eb\";\n$fa-var-line-chart: \"\\f201\";\n$fa-var-link: \"\\f0c1\";\n$fa-var-linkedin: \"\\f0e1\";\n$fa-var-linkedin-square: \"\\f08c\";\n$fa-var-linode: \"\\f2b8\";\n$fa-var-linux: \"\\f17c\";\n$fa-var-list: \"\\f03a\";\n$fa-var-list-alt: \"\\f022\";\n$fa-var-list-ol: \"\\f0cb\";\n$fa-var-list-ul: \"\\f0ca\";\n$fa-var-location-arrow: \"\\f124\";\n$fa-var-lock: \"\\f023\";\n$fa-var-long-arrow-down: \"\\f175\";\n$fa-var-long-arrow-left: \"\\f177\";\n$fa-var-long-arrow-right: \"\\f178\";\n$fa-var-long-arrow-up: \"\\f176\";\n$fa-var-low-vision: \"\\f2a8\";\n$fa-var-magic: \"\\f0d0\";\n$fa-var-magnet: \"\\f076\";\n$fa-var-mail-forward: \"\\f064\";\n$fa-var-mail-reply: \"\\f112\";\n$fa-var-mail-reply-all: \"\\f122\";\n$fa-var-male: \"\\f183\";\n$fa-var-map: \"\\f279\";\n$fa-var-map-marker: \"\\f041\";\n$fa-var-map-o: \"\\f278\";\n$fa-var-map-pin: \"\\f276\";\n$fa-var-map-signs: \"\\f277\";\n$fa-var-mars: \"\\f222\";\n$fa-var-mars-double: \"\\f227\";\n$fa-var-mars-stroke: \"\\f229\";\n$fa-var-mars-stroke-h: \"\\f22b\";\n$fa-var-mars-stroke-v: \"\\f22a\";\n$fa-var-maxcdn: \"\\f136\";\n$fa-var-meanpath: \"\\f20c\";\n$fa-var-medium: \"\\f23a\";\n$fa-var-medkit: \"\\f0fa\";\n$fa-var-meetup: \"\\f2e0\";\n$fa-var-meh-o: \"\\f11a\";\n$fa-var-mercury: \"\\f223\";\n$fa-var-microchip: \"\\f2db\";\n$fa-var-microphone: \"\\f130\";\n$fa-var-microphone-slash: \"\\f131\";\n$fa-var-minus: \"\\f068\";\n$fa-var-minus-circle: \"\\f056\";\n$fa-var-minus-square: \"\\f146\";\n$fa-var-minus-square-o: \"\\f147\";\n$fa-var-mixcloud: \"\\f289\";\n$fa-var-mobile: \"\\f10b\";\n$fa-var-mobile-phone: \"\\f10b\";\n$fa-var-modx: \"\\f285\";\n$fa-var-money: \"\\f0d6\";\n$fa-var-moon-o: \"\\f186\";\n$fa-var-mortar-board: \"\\f19d\";\n$fa-var-motorcycle: \"\\f21c\";\n$fa-var-mouse-pointer: \"\\f245\";\n$fa-var-music: \"\\f001\";\n$fa-var-navicon: \"\\f0c9\";\n$fa-var-neuter: \"\\f22c\";\n$fa-var-newspaper-o: \"\\f1ea\";\n$fa-var-object-group: \"\\f247\";\n$fa-var-object-ungroup: \"\\f248\";\n$fa-var-odnoklassniki: \"\\f263\";\n$fa-var-odnoklassniki-square: \"\\f264\";\n$fa-var-opencart: \"\\f23d\";\n$fa-var-openid: \"\\f19b\";\n$fa-var-opera: \"\\f26a\";\n$fa-var-optin-monster: \"\\f23c\";\n$fa-var-outdent: \"\\f03b\";\n$fa-var-pagelines: \"\\f18c\";\n$fa-var-paint-brush: \"\\f1fc\";\n$fa-var-paper-plane: \"\\f1d8\";\n$fa-var-paper-plane-o: \"\\f1d9\";\n$fa-var-paperclip: \"\\f0c6\";\n$fa-var-paragraph: \"\\f1dd\";\n$fa-var-paste: \"\\f0ea\";\n$fa-var-pause: \"\\f04c\";\n$fa-var-pause-circle: \"\\f28b\";\n$fa-var-pause-circle-o: \"\\f28c\";\n$fa-var-paw: \"\\f1b0\";\n$fa-var-paypal: \"\\f1ed\";\n$fa-var-pencil: \"\\f040\";\n$fa-var-pencil-square: \"\\f14b\";\n$fa-var-pencil-square-o: \"\\f044\";\n$fa-var-percent: \"\\f295\";\n$fa-var-phone: \"\\f095\";\n$fa-var-phone-square: \"\\f098\";\n$fa-var-photo: \"\\f03e\";\n$fa-var-picture-o: \"\\f03e\";\n$fa-var-pie-chart: \"\\f200\";\n$fa-var-pied-piper: \"\\f2ae\";\n$fa-var-pied-piper-alt: \"\\f1a8\";\n$fa-var-pied-piper-pp: \"\\f1a7\";\n$fa-var-pinterest: \"\\f0d2\";\n$fa-var-pinterest-p: \"\\f231\";\n$fa-var-pinterest-square: \"\\f0d3\";\n$fa-var-plane: \"\\f072\";\n$fa-var-play: \"\\f04b\";\n$fa-var-play-circle: \"\\f144\";\n$fa-var-play-circle-o: \"\\f01d\";\n$fa-var-plug: \"\\f1e6\";\n$fa-var-plus: \"\\f067\";\n$fa-var-plus-circle: \"\\f055\";\n$fa-var-plus-square: \"\\f0fe\";\n$fa-var-plus-square-o: \"\\f196\";\n$fa-var-podcast: \"\\f2ce\";\n$fa-var-power-off: \"\\f011\";\n$fa-var-print: \"\\f02f\";\n$fa-var-product-hunt: \"\\f288\";\n$fa-var-puzzle-piece: \"\\f12e\";\n$fa-var-qq: \"\\f1d6\";\n$fa-var-qrcode: \"\\f029\";\n$fa-var-question: \"\\f128\";\n$fa-var-question-circle: \"\\f059\";\n$fa-var-question-circle-o: \"\\f29c\";\n$fa-var-quora: \"\\f2c4\";\n$fa-var-quote-left: \"\\f10d\";\n$fa-var-quote-right: \"\\f10e\";\n$fa-var-ra: \"\\f1d0\";\n$fa-var-random: \"\\f074\";\n$fa-var-ravelry: \"\\f2d9\";\n$fa-var-rebel: \"\\f1d0\";\n$fa-var-recycle: \"\\f1b8\";\n$fa-var-reddit: \"\\f1a1\";\n$fa-var-reddit-alien: \"\\f281\";\n$fa-var-reddit-square: \"\\f1a2\";\n$fa-var-refresh: \"\\f021\";\n$fa-var-registered: \"\\f25d\";\n$fa-var-remove: \"\\f00d\";\n$fa-var-renren: \"\\f18b\";\n$fa-var-reorder: \"\\f0c9\";\n$fa-var-repeat: \"\\f01e\";\n$fa-var-reply: \"\\f112\";\n$fa-var-reply-all: \"\\f122\";\n$fa-var-resistance: \"\\f1d0\";\n$fa-var-retweet: \"\\f079\";\n$fa-var-rmb: \"\\f157\";\n$fa-var-road: \"\\f018\";\n$fa-var-rocket: \"\\f135\";\n$fa-var-rotate-left: \"\\f0e2\";\n$fa-var-rotate-right: \"\\f01e\";\n$fa-var-rouble: \"\\f158\";\n$fa-var-rss: \"\\f09e\";\n$fa-var-rss-square: \"\\f143\";\n$fa-var-rub: \"\\f158\";\n$fa-var-ruble: \"\\f158\";\n$fa-var-rupee: \"\\f156\";\n$fa-var-s15: \"\\f2cd\";\n$fa-var-safari: \"\\f267\";\n$fa-var-save: \"\\f0c7\";\n$fa-var-scissors: \"\\f0c4\";\n$fa-var-scribd: \"\\f28a\";\n$fa-var-search: \"\\f002\";\n$fa-var-search-minus: \"\\f010\";\n$fa-var-search-plus: \"\\f00e\";\n$fa-var-sellsy: \"\\f213\";\n$fa-var-send: \"\\f1d8\";\n$fa-var-send-o: \"\\f1d9\";\n$fa-var-server: \"\\f233\";\n$fa-var-share: \"\\f064\";\n$fa-var-share-alt: \"\\f1e0\";\n$fa-var-share-alt-square: \"\\f1e1\";\n$fa-var-share-square: \"\\f14d\";\n$fa-var-share-square-o: \"\\f045\";\n$fa-var-shekel: \"\\f20b\";\n$fa-var-sheqel: \"\\f20b\";\n$fa-var-shield: \"\\f132\";\n$fa-var-ship: \"\\f21a\";\n$fa-var-shirtsinbulk: \"\\f214\";\n$fa-var-shopping-bag: \"\\f290\";\n$fa-var-shopping-basket: \"\\f291\";\n$fa-var-shopping-cart: \"\\f07a\";\n$fa-var-shower: \"\\f2cc\";\n$fa-var-sign-in: \"\\f090\";\n$fa-var-sign-language: \"\\f2a7\";\n$fa-var-sign-out: \"\\f08b\";\n$fa-var-signal: \"\\f012\";\n$fa-var-signing: \"\\f2a7\";\n$fa-var-simplybuilt: \"\\f215\";\n$fa-var-sitemap: \"\\f0e8\";\n$fa-var-skyatlas: \"\\f216\";\n$fa-var-skype: \"\\f17e\";\n$fa-var-slack: \"\\f198\";\n$fa-var-sliders: \"\\f1de\";\n$fa-var-slideshare: \"\\f1e7\";\n$fa-var-smile-o: \"\\f118\";\n$fa-var-snapchat: \"\\f2ab\";\n$fa-var-snapchat-ghost: \"\\f2ac\";\n$fa-var-snapchat-square: \"\\f2ad\";\n$fa-var-snowflake-o: \"\\f2dc\";\n$fa-var-soccer-ball-o: \"\\f1e3\";\n$fa-var-sort: \"\\f0dc\";\n$fa-var-sort-alpha-asc: \"\\f15d\";\n$fa-var-sort-alpha-desc: \"\\f15e\";\n$fa-var-sort-amount-asc: \"\\f160\";\n$fa-var-sort-amount-desc: \"\\f161\";\n$fa-var-sort-asc: \"\\f0de\";\n$fa-var-sort-desc: \"\\f0dd\";\n$fa-var-sort-down: \"\\f0dd\";\n$fa-var-sort-numeric-asc: \"\\f162\";\n$fa-var-sort-numeric-desc: \"\\f163\";\n$fa-var-sort-up: \"\\f0de\";\n$fa-var-soundcloud: \"\\f1be\";\n$fa-var-space-shuttle: \"\\f197\";\n$fa-var-spinner: \"\\f110\";\n$fa-var-spoon: \"\\f1b1\";\n$fa-var-spotify: \"\\f1bc\";\n$fa-var-square: \"\\f0c8\";\n$fa-var-square-o: \"\\f096\";\n$fa-var-stack-exchange: \"\\f18d\";\n$fa-var-stack-overflow: \"\\f16c\";\n$fa-var-star: \"\\f005\";\n$fa-var-star-half: \"\\f089\";\n$fa-var-star-half-empty: \"\\f123\";\n$fa-var-star-half-full: \"\\f123\";\n$fa-var-star-half-o: \"\\f123\";\n$fa-var-star-o: \"\\f006\";\n$fa-var-steam: \"\\f1b6\";\n$fa-var-steam-square: \"\\f1b7\";\n$fa-var-step-backward: \"\\f048\";\n$fa-var-step-forward: \"\\f051\";\n$fa-var-stethoscope: \"\\f0f1\";\n$fa-var-sticky-note: \"\\f249\";\n$fa-var-sticky-note-o: \"\\f24a\";\n$fa-var-stop: \"\\f04d\";\n$fa-var-stop-circle: \"\\f28d\";\n$fa-var-stop-circle-o: \"\\f28e\";\n$fa-var-street-view: \"\\f21d\";\n$fa-var-strikethrough: \"\\f0cc\";\n$fa-var-stumbleupon: \"\\f1a4\";\n$fa-var-stumbleupon-circle: \"\\f1a3\";\n$fa-var-subscript: \"\\f12c\";\n$fa-var-subway: \"\\f239\";\n$fa-var-suitcase: \"\\f0f2\";\n$fa-var-sun-o: \"\\f185\";\n$fa-var-superpowers: \"\\f2dd\";\n$fa-var-superscript: \"\\f12b\";\n$fa-var-support: \"\\f1cd\";\n$fa-var-table: \"\\f0ce\";\n$fa-var-tablet: \"\\f10a\";\n$fa-var-tachometer: \"\\f0e4\";\n$fa-var-tag: \"\\f02b\";\n$fa-var-tags: \"\\f02c\";\n$fa-var-tasks: \"\\f0ae\";\n$fa-var-taxi: \"\\f1ba\";\n$fa-var-telegram: \"\\f2c6\";\n$fa-var-television: \"\\f26c\";\n$fa-var-tencent-weibo: \"\\f1d5\";\n$fa-var-terminal: \"\\f120\";\n$fa-var-text-height: \"\\f034\";\n$fa-var-text-width: \"\\f035\";\n$fa-var-th: \"\\f00a\";\n$fa-var-th-large: \"\\f009\";\n$fa-var-th-list: \"\\f00b\";\n$fa-var-themeisle: \"\\f2b2\";\n$fa-var-thermometer: \"\\f2c7\";\n$fa-var-thermometer-0: \"\\f2cb\";\n$fa-var-thermometer-1: \"\\f2ca\";\n$fa-var-thermometer-2: \"\\f2c9\";\n$fa-var-thermometer-3: \"\\f2c8\";\n$fa-var-thermometer-4: \"\\f2c7\";\n$fa-var-thermometer-empty: \"\\f2cb\";\n$fa-var-thermometer-full: \"\\f2c7\";\n$fa-var-thermometer-half: \"\\f2c9\";\n$fa-var-thermometer-quarter: \"\\f2ca\";\n$fa-var-thermometer-three-quarters: \"\\f2c8\";\n$fa-var-thumb-tack: \"\\f08d\";\n$fa-var-thumbs-down: \"\\f165\";\n$fa-var-thumbs-o-down: \"\\f088\";\n$fa-var-thumbs-o-up: \"\\f087\";\n$fa-var-thumbs-up: \"\\f164\";\n$fa-var-ticket: \"\\f145\";\n$fa-var-times: \"\\f00d\";\n$fa-var-times-circle: \"\\f057\";\n$fa-var-times-circle-o: \"\\f05c\";\n$fa-var-times-rectangle: \"\\f2d3\";\n$fa-var-times-rectangle-o: \"\\f2d4\";\n$fa-var-tint: \"\\f043\";\n$fa-var-toggle-down: \"\\f150\";\n$fa-var-toggle-left: \"\\f191\";\n$fa-var-toggle-off: \"\\f204\";\n$fa-var-toggle-on: \"\\f205\";\n$fa-var-toggle-right: \"\\f152\";\n$fa-var-toggle-up: \"\\f151\";\n$fa-var-trademark: \"\\f25c\";\n$fa-var-train: \"\\f238\";\n$fa-var-transgender: \"\\f224\";\n$fa-var-transgender-alt: \"\\f225\";\n$fa-var-trash: \"\\f1f8\";\n$fa-var-trash-o: \"\\f014\";\n$fa-var-tree: \"\\f1bb\";\n$fa-var-trello: \"\\f181\";\n$fa-var-tripadvisor: \"\\f262\";\n$fa-var-trophy: \"\\f091\";\n$fa-var-truck: \"\\f0d1\";\n$fa-var-try: \"\\f195\";\n$fa-var-tty: \"\\f1e4\";\n$fa-var-tumblr: \"\\f173\";\n$fa-var-tumblr-square: \"\\f174\";\n$fa-var-turkish-lira: \"\\f195\";\n$fa-var-tv: \"\\f26c\";\n$fa-var-twitch: \"\\f1e8\";\n$fa-var-twitter: \"\\f099\";\n$fa-var-twitter-square: \"\\f081\";\n$fa-var-umbrella: \"\\f0e9\";\n$fa-var-underline: \"\\f0cd\";\n$fa-var-undo: \"\\f0e2\";\n$fa-var-universal-access: \"\\f29a\";\n$fa-var-university: \"\\f19c\";\n$fa-var-unlink: \"\\f127\";\n$fa-var-unlock: \"\\f09c\";\n$fa-var-unlock-alt: \"\\f13e\";\n$fa-var-unsorted: \"\\f0dc\";\n$fa-var-upload: \"\\f093\";\n$fa-var-usb: \"\\f287\";\n$fa-var-usd: \"\\f155\";\n$fa-var-user: \"\\f007\";\n$fa-var-user-circle: \"\\f2bd\";\n$fa-var-user-circle-o: \"\\f2be\";\n$fa-var-user-md: \"\\f0f0\";\n$fa-var-user-o: \"\\f2c0\";\n$fa-var-user-plus: \"\\f234\";\n$fa-var-user-secret: \"\\f21b\";\n$fa-var-user-times: \"\\f235\";\n$fa-var-users: \"\\f0c0\";\n$fa-var-vcard: \"\\f2bb\";\n$fa-var-vcard-o: \"\\f2bc\";\n$fa-var-venus: \"\\f221\";\n$fa-var-venus-double: \"\\f226\";\n$fa-var-venus-mars: \"\\f228\";\n$fa-var-viacoin: \"\\f237\";\n$fa-var-viadeo: \"\\f2a9\";\n$fa-var-viadeo-square: \"\\f2aa\";\n$fa-var-video-camera: \"\\f03d\";\n$fa-var-vimeo: \"\\f27d\";\n$fa-var-vimeo-square: \"\\f194\";\n$fa-var-vine: \"\\f1ca\";\n$fa-var-vk: \"\\f189\";\n$fa-var-volume-control-phone: \"\\f2a0\";\n$fa-var-volume-down: \"\\f027\";\n$fa-var-volume-off: \"\\f026\";\n$fa-var-volume-up: \"\\f028\";\n$fa-var-warning: \"\\f071\";\n$fa-var-wechat: \"\\f1d7\";\n$fa-var-weibo: \"\\f18a\";\n$fa-var-weixin: \"\\f1d7\";\n$fa-var-whatsapp: \"\\f232\";\n$fa-var-wheelchair: \"\\f193\";\n$fa-var-wheelchair-alt: \"\\f29b\";\n$fa-var-wifi: \"\\f1eb\";\n$fa-var-wikipedia-w: \"\\f266\";\n$fa-var-window-close: \"\\f2d3\";\n$fa-var-window-close-o: \"\\f2d4\";\n$fa-var-window-maximize: \"\\f2d0\";\n$fa-var-window-minimize: \"\\f2d1\";\n$fa-var-window-restore: \"\\f2d2\";\n$fa-var-windows: \"\\f17a\";\n$fa-var-won: \"\\f159\";\n$fa-var-wordpress: \"\\f19a\";\n$fa-var-wpbeginner: \"\\f297\";\n$fa-var-wpexplorer: \"\\f2de\";\n$fa-var-wpforms: \"\\f298\";\n$fa-var-wrench: \"\\f0ad\";\n$fa-var-xing: \"\\f168\";\n$fa-var-xing-square: \"\\f169\";\n$fa-var-y-combinator: \"\\f23b\";\n$fa-var-y-combinator-square: \"\\f1d4\";\n$fa-var-yahoo: \"\\f19e\";\n$fa-var-yc: \"\\f23b\";\n$fa-var-yc-square: \"\\f1d4\";\n$fa-var-yelp: \"\\f1e9\";\n$fa-var-yen: \"\\f157\";\n$fa-var-yoast: \"\\f2b1\";\n$fa-var-youtube: \"\\f167\";\n$fa-var-youtube-play: \"\\f16a\";\n$fa-var-youtube-square: \"\\f166\";\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/font-awesome/scss/font-awesome.scss",
    "content": "/*!\n *  Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n\n@import \"variables\";\n@import \"mixins\";\n@import \"path\";\n@import \"core\";\n@import \"larger\";\n@import \"fixed-width\";\n@import \"list\";\n@import \"bordered-pulled\";\n@import \"animated\";\n@import \"rotated-flipped\";\n@import \"stacked\";\n@import \"icons\";\n@import \"screen-reader\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/linea-icons/linea.css",
    "content": "@charset \"UTF-8\";\n.glyphs.character-mapping {\n  margin: 0 0 20px 0;\n  padding: 20px 0 20px 30px;\n  color: rgba(0,0,0,0.5);\n  border: 1px solid #d8e0e5;\n  -webkit-border-radius: 3px;\n  border-radius: 3px;\n}\n.glyphs.character-mapping li {\n  margin: 0 30px 20px 0;\n  display: inline-block;\n  width: 90px;\n  text-align: center;\n  font-size: 24px;\n  color: ;\n}\n.linea-icon {\n  position: relative;\n}\n.linea-icon svg {\n  fill: #000;\n}\n.glyphs.character-mapping input {\n  margin: 0;\n  padding: 5px 0;\n  line-height: 12px;\n  font-size: 12px;\n  display: block;\n  width: 100%;\n  border: 1px solid #d8e0e5;\n  text-align: center;\n  outline: 0;\n}\n.glyphs.character-mapping input:focus {\n  border: 1px solid #fbde4a;\n  -webkit-box-shadow: inset 0 0 3px #fbde4a;\n  box-shadow: inset 0 0 3px #fbde4a;\n}\n.glyphs.character-mapping input:hover {\n  -webkit-box-shadow: inset 0 0 3px #fbde4a;\n  box-shadow: inset 0 0 3px #fbde4a;\n}\n@font-face {\n  font-family: \"linea-arrows-10\";\n  src: url(\"fonts/linea-arrows-10.eot\");\n  src: url(\"fonts/linea-arrows-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-arrows-10.woff\") format(\"woff\"), url(\"fonts/linea-arrows-10.ttf\") format(\"truetype\"), url(\"fonts/linea-arrows-10.svg#linea-arrows-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-aerrow[data-icon]:before {\n  font-family: \"linea-arrows-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-arrows-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-arrows-anticlockwise:before {\n  content: \"\\e000\";\n}\n.icon-arrows-anticlockwise-dashed:before {\n  content: \"\\e001\";\n}\n.icon-arrows-button-down:before {\n  content: \"\\e002\";\n}\n.icon-arrows-button-off:before {\n  content: \"\\e003\";\n}\n.icon-arrows-button-on:before {\n  content: \"\\e004\";\n}\n.icon-arrows-button-up:before {\n  content: \"\\e005\";\n}\n.icon-arrows-check:before {\n  content: \"\\e006\";\n}\n.icon-arrows-circle-check:before {\n  content: \"\\e007\";\n}\n.icon-arrows-circle-down:before {\n  content: \"\\e008\";\n}\n.icon-arrows-circle-downleft:before {\n  content: \"\\e009\";\n}\n.icon-arrows-circle-downright:before {\n  content: \"\\e00a\";\n}\n.icon-arrows-circle-left:before {\n  content: \"\\e00b\";\n}\n.icon-arrows-circle-minus:before {\n  content: \"\\e00c\";\n}\n.icon-arrows-circle-plus:before {\n  content: \"\\e00d\";\n}\n.icon-arrows-circle-remove:before {\n  content: \"\\e00e\";\n}\n.icon-arrows-circle-right:before {\n  content: \"\\e00f\";\n}\n.icon-arrows-circle-up:before {\n  content: \"\\e010\";\n}\n.icon-arrows-circle-upleft:before {\n  content: \"\\e011\";\n}\n.icon-arrows-circle-upright:before {\n  content: \"\\e012\";\n}\n.icon-arrows-clockwise:before {\n  content: \"\\e013\";\n}\n.icon-arrows-clockwise-dashed:before {\n  content: \"\\e014\";\n}\n.icon-arrows-compress:before {\n  content: \"\\e015\";\n}\n.icon-arrows-deny:before {\n  content: \"\\e016\";\n}\n.icon-arrows-diagonal:before {\n  content: \"\\e017\";\n}\n.icon-arrows-diagonal2:before {\n  content: \"\\e018\";\n}\n.icon-arrows-down:before {\n  content: \"\\e019\";\n}\n.icon-arrows-down-double:before {\n  content: \"\\e01a\";\n}\n.icon-arrows-downleft:before {\n  content: \"\\e01b\";\n}\n.icon-arrows-downright:before {\n  content: \"\\e01c\";\n}\n.icon-arrows-drag-down:before {\n  content: \"\\e01d\";\n}\n.icon-arrows-drag-down-dashed:before {\n  content: \"\\e01e\";\n}\n.icon-arrows-drag-horiz:before {\n  content: \"\\e01f\";\n}\n.icon-arrows-drag-left:before {\n  content: \"\\e020\";\n}\n.icon-arrows-drag-left-dashed:before {\n  content: \"\\e021\";\n}\n.icon-arrows-drag-right:before {\n  content: \"\\e022\";\n}\n.icon-arrows-drag-right-dashed:before {\n  content: \"\\e023\";\n}\n.icon-arrows-drag-up:before {\n  content: \"\\e024\";\n}\n.icon-arrows-drag-up-dashed:before {\n  content: \"\\e025\";\n}\n.icon-arrows-drag-vert:before {\n  content: \"\\e026\";\n}\n.icon-arrows-exclamation:before {\n  content: \"\\e027\";\n}\n.icon-arrows-expand:before {\n  content: \"\\e028\";\n}\n.icon-arrows-expand-diagonal1:before {\n  content: \"\\e029\";\n}\n.icon-arrows-expand-horizontal1:before {\n  content: \"\\e02a\";\n}\n.icon-arrows-expand-vertical1:before {\n  content: \"\\e02b\";\n}\n.icon-arrows-fit-horizontal:before {\n  content: \"\\e02c\";\n}\n.icon-arrows-fit-vertical:before {\n  content: \"\\e02d\";\n}\n.icon-arrows-glide:before {\n  content: \"\\e02e\";\n}\n.icon-arrows-glide-horizontal:before {\n  content: \"\\e02f\";\n}\n.icon-arrows-glide-vertical:before {\n  content: \"\\e030\";\n}\n.icon-arrows-hamburger1:before {\n  content: \"\\e031\";\n}\n.icon-arrows-hamburger-2:before {\n  content: \"\\e032\";\n}\n.icon-arrows-horizontal:before {\n  content: \"\\e033\";\n}\n.icon-arrows-info:before {\n  content: \"\\e034\";\n}\n.icon-arrows-keyboard-alt:before {\n  content: \"\\e035\";\n}\n.icon-arrows-keyboard-cmd:before {\n  content: \"\\e036\";\n}\n.icon-arrows-keyboard-delete:before {\n  content: \"\\e037\";\n}\n.icon-arrows-keyboard-down:before {\n  content: \"\\e038\";\n}\n.icon-arrows-keyboard-left:before {\n  content: \"\\e039\";\n}\n.icon-arrows-keyboard-return:before {\n  content: \"\\e03a\";\n}\n.icon-arrows-keyboard-right:before {\n  content: \"\\e03b\";\n}\n.icon-arrows-keyboard-shift:before {\n  content: \"\\e03c\";\n}\n.icon-arrows-keyboard-tab:before {\n  content: \"\\e03d\";\n}\n.icon-arrows-keyboard-up:before {\n  content: \"\\e03e\";\n}\n.icon-arrows-left:before {\n  content: \"\\e03f\";\n}\n.icon-arrows-left-double-32:before {\n  content: \"\\e040\";\n}\n.icon-arrows-minus:before {\n  content: \"\\e041\";\n}\n.icon-arrows-move:before {\n  content: \"\\e042\";\n}\n.icon-arrows-move2:before {\n  content: \"\\e043\";\n}\n.icon-arrows-move-bottom:before {\n  content: \"\\e044\";\n}\n.icon-arrows-move-left:before {\n  content: \"\\e045\";\n}\n.icon-arrows-move-right:before {\n  content: \"\\e046\";\n}\n.icon-arrows-move-top:before {\n  content: \"\\e047\";\n}\n.icon-arrows-plus:before {\n  content: \"\\e048\";\n}\n.icon-arrows-question:before {\n  content: \"\\e049\";\n}\n.icon-arrows-remove:before {\n  content: \"\\e04a\";\n}\n.icon-arrows-right:before {\n  content: \"\\e04b\";\n}\n.icon-arrows-right-double:before {\n  content: \"\\e04c\";\n}\n.icon-arrows-rotate:before {\n  content: \"\\e04d\";\n}\n.icon-arrows-rotate-anti:before {\n  content: \"\\e04e\";\n}\n.icon-arrows-rotate-anti-dashed:before {\n  content: \"\\e04f\";\n}\n.icon-arrows-rotate-dashed:before {\n  content: \"\\e050\";\n}\n.icon-arrows-shrink:before {\n  content: \"\\e051\";\n}\n.icon-arrows-shrink-diagonal1:before {\n  content: \"\\e052\";\n}\n.icon-arrows-shrink-diagonal2:before {\n  content: \"\\e053\";\n}\n.icon-arrows-shrink-horizonal2:before {\n  content: \"\\e054\";\n}\n.icon-arrows-shrink-horizontal1:before {\n  content: \"\\e055\";\n}\n.icon-arrows-shrink-vertical1:before {\n  content: \"\\e056\";\n}\n.icon-arrows-shrink-vertical2:before {\n  content: \"\\e057\";\n}\n.icon-arrows-sign-down:before {\n  content: \"\\e058\";\n}\n.icon-arrows-sign-left:before {\n  content: \"\\e059\";\n}\n.icon-arrows-sign-right:before {\n  content: \"\\e05a\";\n}\n.icon-arrows-sign-up:before {\n  content: \"\\e05b\";\n}\n.icon-arrows-slide-down1:before {\n  content: \"\\e05c\";\n}\n.icon-arrows-slide-down2:before {\n  content: \"\\e05d\";\n}\n.icon-arrows-slide-left1:before {\n  content: \"\\e05e\";\n}\n.icon-arrows-slide-left2:before {\n  content: \"\\e05f\";\n}\n.icon-arrows-slide-right1:before {\n  content: \"\\e060\";\n}\n.icon-arrows-slide-right2:before {\n  content: \"\\e061\";\n}\n.icon-arrows-slide-up1:before {\n  content: \"\\e062\";\n}\n.icon-arrows-slide-up2:before {\n  content: \"\\e063\";\n}\n.icon-arrows-slim-down:before {\n  content: \"\\e064\";\n}\n.icon-arrows-slim-down-dashed:before {\n  content: \"\\e065\";\n}\n.icon-arrows-slim-left:before {\n  content: \"\\e066\";\n}\n.icon-arrows-slim-left-dashed:before {\n  content: \"\\e067\";\n}\n.icon-arrows-slim-right:before {\n  content: \"\\e068\";\n}\n.icon-arrows-slim-right-dashed:before {\n  content: \"\\e069\";\n}\n.icon-arrows-slim-up:before {\n  content: \"\\e06a\";\n}\n.icon-arrows-slim-up-dashed:before {\n  content: \"\\e06b\";\n}\n.icon-arrows-square-check:before {\n  content: \"\\e06c\";\n}\n.icon-arrows-square-down:before {\n  content: \"\\e06d\";\n}\n.icon-arrows-square-downleft:before {\n  content: \"\\e06e\";\n}\n.icon-arrows-square-downright:before {\n  content: \"\\e06f\";\n}\n.icon-arrows-square-left:before {\n  content: \"\\e070\";\n}\n.icon-arrows-square-minus:before {\n  content: \"\\e071\";\n}\n.icon-arrows-square-plus:before {\n  content: \"\\e072\";\n}\n.icon-arrows-square-remove:before {\n  content: \"\\e073\";\n}\n.icon-arrows-square-right:before {\n  content: \"\\e074\";\n}\n.icon-arrows-square-up:before {\n  content: \"\\e075\";\n}\n.icon-arrows-square-upleft:before {\n  content: \"\\e076\";\n}\n.icon-arrows-square-upright:before {\n  content: \"\\e077\";\n}\n.icon-arrows-squares:before {\n  content: \"\\e078\";\n}\n.icon-arrows-stretch-diagonal1:before {\n  content: \"\\e079\";\n}\n.icon-arrows-stretch-diagonal2:before {\n  content: \"\\e07a\";\n}\n.icon-arrows-stretch-diagonal3:before {\n  content: \"\\e07b\";\n}\n.icon-arrows-stretch-diagonal4:before {\n  content: \"\\e07c\";\n}\n.icon-arrows-stretch-horizontal1:before {\n  content: \"\\e07d\";\n}\n.icon-arrows-stretch-horizontal2:before {\n  content: \"\\e07e\";\n}\n.icon-arrows-stretch-vertical1:before {\n  content: \"\\e07f\";\n}\n.icon-arrows-stretch-vertical2:before {\n  content: \"\\e080\";\n}\n.icon-arrows-switch-horizontal:before {\n  content: \"\\e081\";\n}\n.icon-arrows-switch-vertical:before {\n  content: \"\\e082\";\n}\n.icon-arrows-up:before {\n  content: \"\\e083\";\n}\n.icon-arrows-up-double-33:before {\n  content: \"\\e084\";\n}\n.icon-arrows-upleft:before {\n  content: \"\\e085\";\n}\n.icon-arrows-upright:before {\n  content: \"\\e086\";\n}\n.icon-arrows-vertical:before {\n  content: \"\\e087\";\n}\n@font-face {\n  font-family: \"linea-basic-10\";\n  src: url(\"fonts/linea-basic-10.eot\");\n  src: url(\"fonts/linea-basic-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-basic-10.woff\") format(\"woff\"), url(\"fonts/linea-basic-10.ttf\") format(\"truetype\"), url(\"fonts/linea-basic-10.svg#linea-basic-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-basic[data-icon]:before {\n  font-family: \"linea-basic-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-basic-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-basic-accelerator:before {\n  content: \"a\";\n}\n.icon-basic-alarm:before {\n  content: \"b\";\n}\n.icon-basic-anchor:before {\n  content: \"c\";\n}\n.icon-basic-anticlockwise:before {\n  content: \"d\";\n}\n.icon-basic-archive:before {\n  content: \"e\";\n}\n.icon-basic-archive-full:before {\n  content: \"f\";\n}\n.icon-basic-ban:before {\n  content: \"g\";\n}\n.icon-basic-battery-charge:before {\n  content: \"h\";\n}\n.icon-basic-battery-empty:before {\n  content: \"i\";\n}\n.icon-basic-battery-full:before {\n  content: \"j\";\n}\n.icon-basic-battery-half:before {\n  content: \"k\";\n}\n.icon-basic-bolt:before {\n  content: \"l\";\n}\n.icon-basic-book:before {\n  content: \"m\";\n}\n.icon-basic-book-pen:before {\n  content: \"n\";\n}\n.icon-basic-book-pencil:before {\n  content: \"o\";\n}\n.icon-basic-bookmark:before {\n  content: \"p\";\n}\n.icon-basic-calculator:before {\n  content: \"q\";\n}\n.icon-basic-calendar:before {\n  content: \"r\";\n}\n.icon-basic-cards-diamonds:before {\n  content: \"s\";\n}\n.icon-basic-cards-hearts:before {\n  content: \"t\";\n}\n.icon-basic-case:before {\n  content: \"u\";\n}\n.icon-basic-chronometer:before {\n  content: \"v\";\n}\n.icon-basic-clessidre:before {\n  content: \"w\";\n}\n.icon-basic-clock:before {\n  content: \"x\";\n}\n.icon-basic-clockwise:before {\n  content: \"y\";\n}\n.icon-basic-cloud:before {\n  content: \"z\";\n}\n.icon-basic-clubs:before {\n  content: \"A\";\n}\n.icon-basic-compass:before {\n  content: \"B\";\n}\n.icon-basic-cup:before {\n  content: \"C\";\n}\n.icon-basic-diamonds:before {\n  content: \"D\";\n}\n.icon-basic-display:before {\n  content: \"E\";\n}\n.icon-basic-download:before {\n  content: \"F\";\n}\n.icon-basic-exclamation:before {\n  content: \"G\";\n}\n.icon-basic-eye:before {\n  content: \"H\";\n}\n.icon-basic-eye-closed:before {\n  content: \"I\";\n}\n.icon-basic-female:before {\n  content: \"J\";\n}\n.icon-basic-flag1:before {\n  content: \"K\";\n}\n.icon-basic-flag2:before {\n  content: \"L\";\n}\n.icon-basic-floppydisk:before {\n  content: \"M\";\n}\n.icon-basic-folder:before {\n  content: \"N\";\n}\n.icon-basic-folder-multiple:before {\n  content: \"O\";\n}\n.icon-basic-gear:before {\n  content: \"P\";\n}\n.icon-basic-geolocalize-01:before {\n  content: \"Q\";\n}\n.icon-basic-geolocalize-05:before {\n  content: \"R\";\n}\n.icon-basic-globe:before {\n  content: \"S\";\n}\n.icon-basic-gunsight:before {\n  content: \"T\";\n}\n.icon-basic-hammer:before {\n  content: \"U\";\n}\n.icon-basic-headset:before {\n  content: \"V\";\n}\n.icon-basic-heart:before {\n  content: \"W\";\n}\n.icon-basic-heart-broken:before {\n  content: \"X\";\n}\n.icon-basic-helm:before {\n  content: \"Y\";\n}\n.icon-basic-home:before {\n  content: \"Z\";\n}\n.icon-basic-info:before {\n  content: \"0\";\n}\n.icon-basic-ipod:before {\n  content: \"1\";\n}\n.icon-basic-joypad:before {\n  content: \"2\";\n}\n.icon-basic-key:before {\n  content: \"3\";\n}\n.icon-basic-keyboard:before {\n  content: \"4\";\n}\n.icon-basic-laptop:before {\n  content: \"5\";\n}\n.icon-basic-life-buoy:before {\n  content: \"6\";\n}\n.icon-basic-lightbulb:before {\n  content: \"7\";\n}\n.icon-basic-link:before {\n  content: \"8\";\n}\n.icon-basic-lock:before {\n  content: \"9\";\n}\n.icon-basic-lock-open:before {\n  content: \"!\";\n}\n.icon-basic-magic-mouse:before {\n  content: \"\\\"\";\n}\n.icon-basic-magnifier:before {\n  content: \"#\";\n}\n.icon-basic-magnifier-minus:before {\n  content: \"$\";\n}\n.icon-basic-magnifier-plus:before {\n  content: \"%\";\n}\n.icon-basic-mail:before {\n  content: \"&\";\n}\n.icon-basic-mail-multiple:before {\n  content: \"'\";\n}\n.icon-basic-mail-open:before {\n  content: \"(\";\n}\n.icon-basic-mail-open-text:before {\n  content: \")\";\n}\n.icon-basic-male:before {\n  content: \"*\";\n}\n.icon-basic-map:before {\n  content: \"+\";\n}\n.icon-basic-message:before {\n  content: \",\";\n}\n.icon-basic-message-multiple:before {\n  content: \"-\";\n}\n.icon-basic-message-txt:before {\n  content: \".\";\n}\n.icon-basic-mixer2:before {\n  content: \"/\";\n}\n.icon-basic-mouse:before {\n  content: \":\";\n}\n.icon-basic-notebook:before {\n  content: \";\";\n}\n.icon-basic-notebook-pen:before {\n  content: \"<\";\n}\n.icon-basic-notebook-pencil:before {\n  content: \"=\";\n}\n.icon-basic-paperplane:before {\n  content: \">\";\n}\n.icon-basic-pencil-ruler:before {\n  content: \"?\";\n}\n.icon-basic-pencil-ruler-pen:before {\n  content: \"@\";\n}\n.icon-basic-photo:before {\n  content: \"[\";\n}\n.icon-basic-picture:before {\n  content: \"]\";\n}\n.icon-basic-picture-multiple:before {\n  content: \"^\";\n}\n.icon-basic-pin1:before {\n  content: \"_\";\n}\n.icon-basic-pin2:before {\n  content: \"`\";\n}\n.icon-basic-postcard:before {\n  content: \"{\";\n}\n.icon-basic-postcard-multiple:before {\n  content: \"|\";\n}\n.icon-basic-printer:before {\n  content: \"}\";\n}\n.icon-basic-question:before {\n  content: \"~\";\n}\n.icon-basic-rss:before {\n  content: \"\";\n}\n.icon-basic-server:before {\n  content: \"\\e000\";\n}\n.icon-basic-server2:before {\n  content: \"\\e001\";\n}\n.icon-basic-server-cloud:before {\n  content: \"\\e002\";\n}\n.icon-basic-server-download:before {\n  content: \"\\e003\";\n}\n.icon-basic-server-upload:before {\n  content: \"\\e004\";\n}\n.icon-basic-settings:before {\n  content: \"\\e005\";\n}\n.icon-basic-share:before {\n  content: \"\\e006\";\n}\n.icon-basic-sheet:before {\n  content: \"\\e007\";\n}\n.icon-basic-sheet-multiple:before {\n  content: \"\\e008\";\n}\n.icon-basic-sheet-pen:before {\n  content: \"\\e009\";\n}\n.icon-basic-sheet-pencil:before {\n  content: \"\\e00a\";\n}\n.icon-basic-sheet-txt:before {\n  content: \"\\e00b\";\n}\n.icon-basic-signs:before {\n  content: \"\\e00c\";\n}\n.icon-basic-smartphone:before {\n  content: \"\\e00d\";\n}\n.icon-basic-spades:before {\n  content: \"\\e00e\";\n}\n.icon-basic-spread:before {\n  content: \"\\e00f\";\n}\n.icon-basic-spread-bookmark:before {\n  content: \"\\e010\";\n}\n.icon-basic-spread-text:before {\n  content: \"\\e011\";\n}\n.icon-basic-spread-text-bookmark:before {\n  content: \"\\e012\";\n}\n.icon-basic-star:before {\n  content: \"\\e013\";\n}\n.icon-basic-tablet:before {\n  content: \"\\e014\";\n}\n.icon-basic-target:before {\n  content: \"\\e015\";\n}\n.icon-basic-todo:before {\n  content: \"\\e016\";\n}\n.icon-basic-todo-pen:before {\n  content: \"\\e017\";\n}\n.icon-basic-todo-pencil:before {\n  content: \"\\e018\";\n}\n.icon-basic-todo-txt:before {\n  content: \"\\e019\";\n}\n.icon-basic-todolist-pen:before {\n  content: \"\\e01a\";\n}\n.icon-basic-todolist-pencil:before {\n  content: \"\\e01b\";\n}\n.icon-basic-trashcan:before {\n  content: \"\\e01c\";\n}\n.icon-basic-trashcan-full:before {\n  content: \"\\e01d\";\n}\n.icon-basic-trashcan-refresh:before {\n  content: \"\\e01e\";\n}\n.icon-basic-trashcan-remove:before {\n  content: \"\\e01f\";\n}\n.icon-basic-upload:before {\n  content: \"\\e020\";\n}\n.icon-basic-usb:before {\n  content: \"\\e021\";\n}\n.icon-basic-video:before {\n  content: \"\\e022\";\n}\n.icon-basic-watch:before {\n  content: \"\\e023\";\n}\n.icon-basic-webpage:before {\n  content: \"\\e024\";\n}\n.icon-basic-webpage-img-txt:before {\n  content: \"\\e025\";\n}\n.icon-basic-webpage-multiple:before {\n  content: \"\\e026\";\n}\n.icon-basic-webpage-txt:before {\n  content: \"\\e027\";\n}\n.icon-basic-world:before {\n  content: \"\\e028\";\n}\n@font-face {\n  font-family: \"linea-basic-elaboration-10\";\n  src: url(\"fonts/linea-basic-elaboration-10.eot\");\n  src: url(\"fonts/linea-basic-elaboration-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-basic-elaboration-10.woff\") format(\"woff\"), url(\"fonts/linea-basic-elaboration-10.ttf\") format(\"truetype\"), url(\"fonts/linea-basic-elaboration-10.svg#linea-basic-elaboration-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-elaborate[data-icon]:before {\n  font-family: \"linea-basic-elaboration-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-basic-elaboration-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-basic-elaboration-bookmark-checck:before {\n  content: \"a\";\n}\n.icon-basic-elaboration-bookmark-minus:before {\n  content: \"b\";\n}\n.icon-basic-elaboration-bookmark-plus:before {\n  content: \"c\";\n}\n.icon-basic-elaboration-bookmark-remove:before {\n  content: \"d\";\n}\n.icon-basic-elaboration-briefcase-check:before {\n  content: \"e\";\n}\n.icon-basic-elaboration-briefcase-download:before {\n  content: \"f\";\n}\n.icon-basic-elaboration-briefcase-flagged:before {\n  content: \"g\";\n}\n.icon-basic-elaboration-briefcase-minus:before {\n  content: \"h\";\n}\n.icon-basic-elaboration-briefcase-plus:before {\n  content: \"i\";\n}\n.icon-basic-elaboration-briefcase-refresh:before {\n  content: \"j\";\n}\n.icon-basic-elaboration-briefcase-remove:before {\n  content: \"k\";\n}\n.icon-basic-elaboration-briefcase-search:before {\n  content: \"l\";\n}\n.icon-basic-elaboration-briefcase-star:before {\n  content: \"m\";\n}\n.icon-basic-elaboration-briefcase-upload:before {\n  content: \"n\";\n}\n.icon-basic-elaboration-browser-check:before {\n  content: \"o\";\n}\n.icon-basic-elaboration-browser-download:before {\n  content: \"p\";\n}\n.icon-basic-elaboration-browser-minus:before {\n  content: \"q\";\n}\n.icon-basic-elaboration-browser-plus:before {\n  content: \"r\";\n}\n.icon-basic-elaboration-browser-refresh:before {\n  content: \"s\";\n}\n.icon-basic-elaboration-browser-remove:before {\n  content: \"t\";\n}\n.icon-basic-elaboration-browser-search:before {\n  content: \"u\";\n}\n.icon-basic-elaboration-browser-star:before {\n  content: \"v\";\n}\n.icon-basic-elaboration-browser-upload:before {\n  content: \"w\";\n}\n.icon-basic-elaboration-calendar-check:before {\n  content: \"x\";\n}\n.icon-basic-elaboration-calendar-cloud:before {\n  content: \"y\";\n}\n.icon-basic-elaboration-calendar-download:before {\n  content: \"z\";\n}\n.icon-basic-elaboration-calendar-empty:before {\n  content: \"A\";\n}\n.icon-basic-elaboration-calendar-flagged:before {\n  content: \"B\";\n}\n.icon-basic-elaboration-calendar-heart:before {\n  content: \"C\";\n}\n.icon-basic-elaboration-calendar-minus:before {\n  content: \"D\";\n}\n.icon-basic-elaboration-calendar-next:before {\n  content: \"E\";\n}\n.icon-basic-elaboration-calendar-noaccess:before {\n  content: \"F\";\n}\n.icon-basic-elaboration-calendar-pencil:before {\n  content: \"G\";\n}\n.icon-basic-elaboration-calendar-plus:before {\n  content: \"H\";\n}\n.icon-basic-elaboration-calendar-previous:before {\n  content: \"I\";\n}\n.icon-basic-elaboration-calendar-refresh:before {\n  content: \"J\";\n}\n.icon-basic-elaboration-calendar-remove:before {\n  content: \"K\";\n}\n.icon-basic-elaboration-calendar-search:before {\n  content: \"L\";\n}\n.icon-basic-elaboration-calendar-star:before {\n  content: \"M\";\n}\n.icon-basic-elaboration-calendar-upload:before {\n  content: \"N\";\n}\n.icon-basic-elaboration-cloud-check:before {\n  content: \"O\";\n}\n.icon-basic-elaboration-cloud-download:before {\n  content: \"P\";\n}\n.icon-basic-elaboration-cloud-minus:before {\n  content: \"Q\";\n}\n.icon-basic-elaboration-cloud-noaccess:before {\n  content: \"R\";\n}\n.icon-basic-elaboration-cloud-plus:before {\n  content: \"S\";\n}\n.icon-basic-elaboration-cloud-refresh:before {\n  content: \"T\";\n}\n.icon-basic-elaboration-cloud-remove:before {\n  content: \"U\";\n}\n.icon-basic-elaboration-cloud-search:before {\n  content: \"V\";\n}\n.icon-basic-elaboration-cloud-upload:before {\n  content: \"W\";\n}\n.icon-basic-elaboration-document-check:before {\n  content: \"X\";\n}\n.icon-basic-elaboration-document-cloud:before {\n  content: \"Y\";\n}\n.icon-basic-elaboration-document-download:before {\n  content: \"Z\";\n}\n.icon-basic-elaboration-document-flagged:before {\n  content: \"0\";\n}\n.icon-basic-elaboration-document-graph:before {\n  content: \"1\";\n}\n.icon-basic-elaboration-document-heart:before {\n  content: \"2\";\n}\n.icon-basic-elaboration-document-minus:before {\n  content: \"3\";\n}\n.icon-basic-elaboration-document-next:before {\n  content: \"4\";\n}\n.icon-basic-elaboration-document-noaccess:before {\n  content: \"5\";\n}\n.icon-basic-elaboration-document-note:before {\n  content: \"6\";\n}\n.icon-basic-elaboration-document-pencil:before {\n  content: \"7\";\n}\n.icon-basic-elaboration-document-picture:before {\n  content: \"8\";\n}\n.icon-basic-elaboration-document-plus:before {\n  content: \"9\";\n}\n.icon-basic-elaboration-document-previous:before {\n  content: \"!\";\n}\n.icon-basic-elaboration-document-refresh:before {\n  content: \"\\\"\";\n}\n.icon-basic-elaboration-document-remove:before {\n  content: \"#\";\n}\n.icon-basic-elaboration-document-search:before {\n  content: \"$\";\n}\n.icon-basic-elaboration-document-star:before {\n  content: \"%\";\n}\n.icon-basic-elaboration-document-upload:before {\n  content: \"&\";\n}\n.icon-basic-elaboration-folder-check:before {\n  content: \"'\";\n}\n.icon-basic-elaboration-folder-cloud:before {\n  content: \"(\";\n}\n.icon-basic-elaboration-folder-document:before {\n  content: \")\";\n}\n.icon-basic-elaboration-folder-download:before {\n  content: \"*\";\n}\n.icon-basic-elaboration-folder-flagged:before {\n  content: \"+\";\n}\n.icon-basic-elaboration-folder-graph:before {\n  content: \",\";\n}\n.icon-basic-elaboration-folder-heart:before {\n  content: \"-\";\n}\n.icon-basic-elaboration-folder-minus:before {\n  content: \".\";\n}\n.icon-basic-elaboration-folder-next:before {\n  content: \"/\";\n}\n.icon-basic-elaboration-folder-noaccess:before {\n  content: \":\";\n}\n.icon-basic-elaboration-folder-note:before {\n  content: \";\";\n}\n.icon-basic-elaboration-folder-pencil:before {\n  content: \"<\";\n}\n.icon-basic-elaboration-folder-picture:before {\n  content: \"=\";\n}\n.icon-basic-elaboration-folder-plus:before {\n  content: \">\";\n}\n.icon-basic-elaboration-folder-previous:before {\n  content: \"?\";\n}\n.icon-basic-elaboration-folder-refresh:before {\n  content: \"@\";\n}\n.icon-basic-elaboration-folder-remove:before {\n  content: \"[\";\n}\n.icon-basic-elaboration-folder-search:before {\n  content: \"]\";\n}\n.icon-basic-elaboration-folder-star:before {\n  content: \"^\";\n}\n.icon-basic-elaboration-folder-upload:before {\n  content: \"_\";\n}\n.icon-basic-elaboration-mail-check:before {\n  content: \"`\";\n}\n.icon-basic-elaboration-mail-cloud:before {\n  content: \"{\";\n}\n.icon-basic-elaboration-mail-document:before {\n  content: \"|\";\n}\n.icon-basic-elaboration-mail-download:before {\n  content: \"}\";\n}\n.icon-basic-elaboration-mail-flagged:before {\n  content: \"~\";\n}\n.icon-basic-elaboration-mail-heart:before {\n  content: \"\";\n}\n.icon-basic-elaboration-mail-next:before {\n  content: \"\\e000\";\n}\n.icon-basic-elaboration-mail-noaccess:before {\n  content: \"\\e001\";\n}\n.icon-basic-elaboration-mail-note:before {\n  content: \"\\e002\";\n}\n.icon-basic-elaboration-mail-pencil:before {\n  content: \"\\e003\";\n}\n.icon-basic-elaboration-mail-picture:before {\n  content: \"\\e004\";\n}\n.icon-basic-elaboration-mail-previous:before {\n  content: \"\\e005\";\n}\n.icon-basic-elaboration-mail-refresh:before {\n  content: \"\\e006\";\n}\n.icon-basic-elaboration-mail-remove:before {\n  content: \"\\e007\";\n}\n.icon-basic-elaboration-mail-search:before {\n  content: \"\\e008\";\n}\n.icon-basic-elaboration-mail-star:before {\n  content: \"\\e009\";\n}\n.icon-basic-elaboration-mail-upload:before {\n  content: \"\\e00a\";\n}\n.icon-basic-elaboration-message-check:before {\n  content: \"\\e00b\";\n}\n.icon-basic-elaboration-message-dots:before {\n  content: \"\\e00c\";\n}\n.icon-basic-elaboration-message-happy:before {\n  content: \"\\e00d\";\n}\n.icon-basic-elaboration-message-heart:before {\n  content: \"\\e00e\";\n}\n.icon-basic-elaboration-message-minus:before {\n  content: \"\\e00f\";\n}\n.icon-basic-elaboration-message-note:before {\n  content: \"\\e010\";\n}\n.icon-basic-elaboration-message-plus:before {\n  content: \"\\e011\";\n}\n.icon-basic-elaboration-message-refresh:before {\n  content: \"\\e012\";\n}\n.icon-basic-elaboration-message-remove:before {\n  content: \"\\e013\";\n}\n.icon-basic-elaboration-message-sad:before {\n  content: \"\\e014\";\n}\n.icon-basic-elaboration-smartphone-cloud:before {\n  content: \"\\e015\";\n}\n.icon-basic-elaboration-smartphone-heart:before {\n  content: \"\\e016\";\n}\n.icon-basic-elaboration-smartphone-noaccess:before {\n  content: \"\\e017\";\n}\n.icon-basic-elaboration-smartphone-note:before {\n  content: \"\\e018\";\n}\n.icon-basic-elaboration-smartphone-pencil:before {\n  content: \"\\e019\";\n}\n.icon-basic-elaboration-smartphone-picture:before {\n  content: \"\\e01a\";\n}\n.icon-basic-elaboration-smartphone-refresh:before {\n  content: \"\\e01b\";\n}\n.icon-basic-elaboration-smartphone-search:before {\n  content: \"\\e01c\";\n}\n.icon-basic-elaboration-tablet-cloud:before {\n  content: \"\\e01d\";\n}\n.icon-basic-elaboration-tablet-heart:before {\n  content: \"\\e01e\";\n}\n.icon-basic-elaboration-tablet-noaccess:before {\n  content: \"\\e01f\";\n}\n.icon-basic-elaboration-tablet-note:before {\n  content: \"\\e020\";\n}\n.icon-basic-elaboration-tablet-pencil:before {\n  content: \"\\e021\";\n}\n.icon-basic-elaboration-tablet-picture:before {\n  content: \"\\e022\";\n}\n.icon-basic-elaboration-tablet-refresh:before {\n  content: \"\\e023\";\n}\n.icon-basic-elaboration-tablet-search:before {\n  content: \"\\e024\";\n}\n.icon-basic-elaboration-todolist-2:before {\n  content: \"\\e025\";\n}\n.icon-basic-elaboration-todolist-check:before {\n  content: \"\\e026\";\n}\n.icon-basic-elaboration-todolist-cloud:before {\n  content: \"\\e027\";\n}\n.icon-basic-elaboration-todolist-download:before {\n  content: \"\\e028\";\n}\n.icon-basic-elaboration-todolist-flagged:before {\n  content: \"\\e029\";\n}\n.icon-basic-elaboration-todolist-minus:before {\n  content: \"\\e02a\";\n}\n.icon-basic-elaboration-todolist-noaccess:before {\n  content: \"\\e02b\";\n}\n.icon-basic-elaboration-todolist-pencil:before {\n  content: \"\\e02c\";\n}\n.icon-basic-elaboration-todolist-plus:before {\n  content: \"\\e02d\";\n}\n.icon-basic-elaboration-todolist-refresh:before {\n  content: \"\\e02e\";\n}\n.icon-basic-elaboration-todolist-remove:before {\n  content: \"\\e02f\";\n}\n.icon-basic-elaboration-todolist-search:before {\n  content: \"\\e030\";\n}\n.icon-basic-elaboration-todolist-star:before {\n  content: \"\\e031\";\n}\n.icon-basic-elaboration-todolist-upload:before {\n  content: \"\\e032\";\n}\n@font-face {\n  font-family: \"linea-ecommerce-10\";\n  src: url(\"fonts/linea-ecommerce-10.eot\");\n  src: url(\"fonts/linea-ecommerce-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-ecommerce-10.woff\") format(\"woff\"), url(\"fonts/linea-ecommerce-10.ttf\") format(\"truetype\"), url(\"fonts/linea-ecommerce-10.svg#linea-ecommerce-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-ecommerce[data-icon]:before {\n  font-family: \"linea-ecommerce-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-ecommerce-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-ecommerce-bag:before {\n  content: \"a\";\n}\n.icon-ecommerce-bag-check:before {\n  content: \"b\";\n}\n.icon-ecommerce-bag-cloud:before {\n  content: \"c\";\n}\n.icon-ecommerce-bag-download:before {\n  content: \"d\";\n}\n.icon-ecommerce-bag-minus:before {\n  content: \"e\";\n}\n.icon-ecommerce-bag-plus:before {\n  content: \"f\";\n}\n.icon-ecommerce-bag-refresh:before {\n  content: \"g\";\n}\n.icon-ecommerce-bag-remove:before {\n  content: \"h\";\n}\n.icon-ecommerce-bag-search:before {\n  content: \"i\";\n}\n.icon-ecommerce-bag-upload:before {\n  content: \"j\";\n}\n.icon-ecommerce-banknote:before {\n  content: \"k\";\n}\n.icon-ecommerce-banknotes:before {\n  content: \"l\";\n}\n.icon-ecommerce-basket:before {\n  content: \"m\";\n}\n.icon-ecommerce-basket-check:before {\n  content: \"n\";\n}\n.icon-ecommerce-basket-cloud:before {\n  content: \"o\";\n}\n.icon-ecommerce-basket-download:before {\n  content: \"p\";\n}\n.icon-ecommerce-basket-minus:before {\n  content: \"q\";\n}\n.icon-ecommerce-basket-plus:before {\n  content: \"r\";\n}\n.icon-ecommerce-basket-refresh:before {\n  content: \"s\";\n}\n.icon-ecommerce-basket-remove:before {\n  content: \"t\";\n}\n.icon-ecommerce-basket-search:before {\n  content: \"u\";\n}\n.icon-ecommerce-basket-upload:before {\n  content: \"v\";\n}\n.icon-ecommerce-bath:before {\n  content: \"w\";\n}\n.icon-ecommerce-cart:before {\n  content: \"x\";\n}\n.icon-ecommerce-cart-check:before {\n  content: \"y\";\n}\n.icon-ecommerce-cart-cloud:before {\n  content: \"z\";\n}\n.icon-ecommerce-cart-content:before {\n  content: \"A\";\n}\n.icon-ecommerce-cart-download:before {\n  content: \"B\";\n}\n.icon-ecommerce-cart-minus:before {\n  content: \"C\";\n}\n.icon-ecommerce-cart-plus:before {\n  content: \"D\";\n}\n.icon-ecommerce-cart-refresh:before {\n  content: \"E\";\n}\n.icon-ecommerce-cart-remove:before {\n  content: \"F\";\n}\n.icon-ecommerce-cart-search:before {\n  content: \"G\";\n}\n.icon-ecommerce-cart-upload:before {\n  content: \"H\";\n}\n.icon-ecommerce-cent:before {\n  content: \"I\";\n}\n.icon-ecommerce-colon:before {\n  content: \"J\";\n}\n.icon-ecommerce-creditcard:before {\n  content: \"K\";\n}\n.icon-ecommerce-diamond:before {\n  content: \"L\";\n}\n.icon-ecommerce-dollar:before {\n  content: \"M\";\n}\n.icon-ecommerce-euro:before {\n  content: \"N\";\n}\n.icon-ecommerce-franc:before {\n  content: \"O\";\n}\n.icon-ecommerce-gift:before {\n  content: \"P\";\n}\n.icon-ecommerce-graph1:before {\n  content: \"Q\";\n}\n.icon-ecommerce-graph2:before {\n  content: \"R\";\n}\n.icon-ecommerce-graph3:before {\n  content: \"S\";\n}\n.icon-ecommerce-graph-decrease:before {\n  content: \"T\";\n}\n.icon-ecommerce-graph-increase:before {\n  content: \"U\";\n}\n.icon-ecommerce-guarani:before {\n  content: \"V\";\n}\n.icon-ecommerce-kips:before {\n  content: \"W\";\n}\n.icon-ecommerce-lira:before {\n  content: \"X\";\n}\n.icon-ecommerce-megaphone:before {\n  content: \"Y\";\n}\n.icon-ecommerce-money:before {\n  content: \"Z\";\n}\n.icon-ecommerce-naira:before {\n  content: \"0\";\n}\n.icon-ecommerce-pesos:before {\n  content: \"1\";\n}\n.icon-ecommerce-pound:before {\n  content: \"2\";\n}\n.icon-ecommerce-receipt:before {\n  content: \"3\";\n}\n.icon-ecommerce-receipt-bath:before {\n  content: \"4\";\n}\n.icon-ecommerce-receipt-cent:before {\n  content: \"5\";\n}\n.icon-ecommerce-receipt-dollar:before {\n  content: \"6\";\n}\n.icon-ecommerce-receipt-euro:before {\n  content: \"7\";\n}\n.icon-ecommerce-receipt-franc:before {\n  content: \"8\";\n}\n.icon-ecommerce-receipt-guarani:before {\n  content: \"9\";\n}\n.icon-ecommerce-receipt-kips:before {\n  content: \"!\";\n}\n.icon-ecommerce-receipt-lira:before {\n  content: \"\\\"\";\n}\n.icon-ecommerce-receipt-naira:before {\n  content: \"#\";\n}\n.icon-ecommerce-receipt-pesos:before {\n  content: \"$\";\n}\n.icon-ecommerce-receipt-pound:before {\n  content: \"%\";\n}\n.icon-ecommerce-receipt-rublo:before {\n  content: \"&\";\n}\n.icon-ecommerce-receipt-rupee:before {\n  content: \"'\";\n}\n.icon-ecommerce-receipt-tugrik:before {\n  content: \"(\";\n}\n.icon-ecommerce-receipt-won:before {\n  content: \")\";\n}\n.icon-ecommerce-receipt-yen:before {\n  content: \"*\";\n}\n.icon-ecommerce-receipt-yen2:before {\n  content: \"+\";\n}\n.icon-ecommerce-recept-colon:before {\n  content: \",\";\n}\n.icon-ecommerce-rublo:before {\n  content: \"-\";\n}\n.icon-ecommerce-rupee:before {\n  content: \".\";\n}\n.icon-ecommerce-safe:before {\n  content: \"/\";\n}\n.icon-ecommerce-sale:before {\n  content: \":\";\n}\n.icon-ecommerce-sales:before {\n  content: \";\";\n}\n.icon-ecommerce-ticket:before {\n  content: \"<\";\n}\n.icon-ecommerce-tugriks:before {\n  content: \"=\";\n}\n.icon-ecommerce-wallet:before {\n  content: \">\";\n}\n.icon-ecommerce-won:before {\n  content: \"?\";\n}\n.icon-ecommerce-yen:before {\n  content: \"@\";\n}\n.icon-ecommerce-yen2:before {\n  content: \"[\";\n}\n@font-face {\n  font-family: \"linea-music-10\";\n  src: url(\"fonts/linea-music-10.eot\");\n  src: url(\"fonts/linea-music-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-music-10.woff\") format(\"woff\"), url(\"fonts/linea-music-10.ttf\") format(\"truetype\"), url(\"fonts/linea-music-10.svg#linea-music-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-music[data-icon]:before {\n  font-family: \"linea-music-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-music-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-music-beginning-button:before {\n  content: \"a\";\n}\n.icon-music-bell:before {\n  content: \"b\";\n}\n.icon-music-cd:before {\n  content: \"c\";\n}\n.icon-music-diapason:before {\n  content: \"d\";\n}\n.icon-music-eject-button:before {\n  content: \"e\";\n}\n.icon-music-end-button:before {\n  content: \"f\";\n}\n.icon-music-fastforward-button:before {\n  content: \"g\";\n}\n.icon-music-headphones:before {\n  content: \"h\";\n}\n.icon-music-ipod:before {\n  content: \"i\";\n}\n.icon-music-loudspeaker:before {\n  content: \"j\";\n}\n.icon-music-microphone:before {\n  content: \"k\";\n}\n.icon-music-microphone-old:before {\n  content: \"l\";\n}\n.icon-music-mixer:before {\n  content: \"m\";\n}\n.icon-music-mute:before {\n  content: \"n\";\n}\n.icon-music-note-multiple:before {\n  content: \"o\";\n}\n.icon-music-note-single:before {\n  content: \"p\";\n}\n.icon-music-pause-button:before {\n  content: \"q\";\n}\n.icon-music-play-button:before {\n  content: \"r\";\n}\n.icon-music-playlist:before {\n  content: \"s\";\n}\n.icon-music-radio-ghettoblaster:before {\n  content: \"t\";\n}\n.icon-music-radio-portable:before {\n  content: \"u\";\n}\n.icon-music-record:before {\n  content: \"v\";\n}\n.icon-music-recordplayer:before {\n  content: \"w\";\n}\n.icon-music-repeat-button:before {\n  content: \"x\";\n}\n.icon-music-rewind-button:before {\n  content: \"y\";\n}\n.icon-music-shuffle-button:before {\n  content: \"z\";\n}\n.icon-music-stop-button:before {\n  content: \"A\";\n}\n.icon-music-tape:before {\n  content: \"B\";\n}\n.icon-music-volume-down:before {\n  content: \"C\";\n}\n.icon-music-volume-up:before {\n  content: \"D\";\n}\n@font-face {\n  font-family: \"linea-software-10\";\n  src: url(\"fonts/linea-software-10.eot\");\n  src: url(\"fonts/linea-software-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-software-10.woff\") format(\"woff\"), url(\"fonts/linea-software-10.ttf\") format(\"truetype\"), url(\"fonts/linea-software-10.svg#linea-software-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-software[data-icon]:before {\n  font-family: \"linea-software-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-software-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-software-add-vectorpoint:before {\n  content: \"a\";\n}\n.icon-software-box-oval:before {\n  content: \"b\";\n}\n.icon-software-box-polygon:before {\n  content: \"c\";\n}\n.icon-software-box-rectangle:before {\n  content: \"d\";\n}\n.icon-software-box-roundedrectangle:before {\n  content: \"e\";\n}\n.icon-software-character:before {\n  content: \"f\";\n}\n.icon-software-crop:before {\n  content: \"g\";\n}\n.icon-software-eyedropper:before {\n  content: \"h\";\n}\n.icon-software-font-allcaps:before {\n  content: \"i\";\n}\n.icon-software-font-baseline-shift:before {\n  content: \"j\";\n}\n.icon-software-font-horizontal-scale:before {\n  content: \"k\";\n}\n.icon-software-font-kerning:before {\n  content: \"l\";\n}\n.icon-software-font-leading:before {\n  content: \"m\";\n}\n.icon-software-font-size:before {\n  content: \"n\";\n}\n.icon-software-font-smallcapital:before {\n  content: \"o\";\n}\n.icon-software-font-smallcaps:before {\n  content: \"p\";\n}\n.icon-software-font-strikethrough:before {\n  content: \"q\";\n}\n.icon-software-font-tracking:before {\n  content: \"r\";\n}\n.icon-software-font-underline:before {\n  content: \"s\";\n}\n.icon-software-font-vertical-scale:before {\n  content: \"t\";\n}\n.icon-software-horizontal-align-center:before {\n  content: \"u\";\n}\n.icon-software-horizontal-align-left:before {\n  content: \"v\";\n}\n.icon-software-horizontal-align-right:before {\n  content: \"w\";\n}\n.icon-software-horizontal-distribute-center:before {\n  content: \"x\";\n}\n.icon-software-horizontal-distribute-left:before {\n  content: \"y\";\n}\n.icon-software-horizontal-distribute-right:before {\n  content: \"z\";\n}\n.icon-software-indent-firstline:before {\n  content: \"A\";\n}\n.icon-software-indent-left:before {\n  content: \"B\";\n}\n.icon-software-indent-right:before {\n  content: \"C\";\n}\n.icon-software-lasso:before {\n  content: \"D\";\n}\n.icon-software-layers1:before {\n  content: \"E\";\n}\n.icon-software-layers2:before {\n  content: \"F\";\n}\n.icon-software-layout:before {\n  content: \"G\";\n}\n.icon-software-layout-2columns:before {\n  content: \"H\";\n}\n.icon-software-layout-3columns:before {\n  content: \"I\";\n}\n.icon-software-layout-4boxes:before {\n  content: \"J\";\n}\n.icon-software-layout-4columns:before {\n  content: \"K\";\n}\n.icon-software-layout-4lines:before {\n  content: \"L\";\n}\n.icon-software-layout-8boxes:before {\n  content: \"M\";\n}\n.icon-software-layout-header:before {\n  content: \"N\";\n}\n.icon-software-layout-header-2columns:before {\n  content: \"O\";\n}\n.icon-software-layout-header-3columns:before {\n  content: \"P\";\n}\n.icon-software-layout-header-4boxes:before {\n  content: \"Q\";\n}\n.icon-software-layout-header-4columns:before {\n  content: \"R\";\n}\n.icon-software-layout-header-complex:before {\n  content: \"S\";\n}\n.icon-software-layout-header-complex2:before {\n  content: \"T\";\n}\n.icon-software-layout-header-complex3:before {\n  content: \"U\";\n}\n.icon-software-layout-header-complex4:before {\n  content: \"V\";\n}\n.icon-software-layout-header-sideleft:before {\n  content: \"W\";\n}\n.icon-software-layout-header-sideright:before {\n  content: \"X\";\n}\n.icon-software-layout-sidebar-left:before {\n  content: \"Y\";\n}\n.icon-software-layout-sidebar-right:before {\n  content: \"Z\";\n}\n.icon-software-magnete:before {\n  content: \"0\";\n}\n.icon-software-pages:before {\n  content: \"1\";\n}\n.icon-software-paintbrush:before {\n  content: \"2\";\n}\n.icon-software-paintbucket:before {\n  content: \"3\";\n}\n.icon-software-paintroller:before {\n  content: \"4\";\n}\n.icon-software-paragraph:before {\n  content: \"5\";\n}\n.icon-software-paragraph-align-left:before {\n  content: \"6\";\n}\n.icon-software-paragraph-align-right:before {\n  content: \"7\";\n}\n.icon-software-paragraph-center:before {\n  content: \"8\";\n}\n.icon-software-paragraph-justify-all:before {\n  content: \"9\";\n}\n.icon-software-paragraph-justify-center:before {\n  content: \"!\";\n}\n.icon-software-paragraph-justify-left:before {\n  content: \"\\\"\";\n}\n.icon-software-paragraph-justify-right:before {\n  content: \"#\";\n}\n.icon-software-paragraph-space-after:before {\n  content: \"$\";\n}\n.icon-software-paragraph-space-before:before {\n  content: \"%\";\n}\n.icon-software-pathfinder-exclude:before {\n  content: \"&\";\n}\n.icon-software-pathfinder-intersect:before {\n  content: \"'\";\n}\n.icon-software-pathfinder-subtract:before {\n  content: \"(\";\n}\n.icon-software-pathfinder-unite:before {\n  content: \")\";\n}\n.icon-software-pen:before {\n  content: \"*\";\n}\n.icon-software-pen-add:before {\n  content: \"+\";\n}\n.icon-software-pen-remove:before {\n  content: \",\";\n}\n.icon-software-pencil:before {\n  content: \"-\";\n}\n.icon-software-polygonallasso:before {\n  content: \".\";\n}\n.icon-software-reflect-horizontal:before {\n  content: \"/\";\n}\n.icon-software-reflect-vertical:before {\n  content: \":\";\n}\n.icon-software-remove-vectorpoint:before {\n  content: \";\";\n}\n.icon-software-scale-expand:before {\n  content: \"<\";\n}\n.icon-software-scale-reduce:before {\n  content: \"=\";\n}\n.icon-software-selection-oval:before {\n  content: \">\";\n}\n.icon-software-selection-polygon:before {\n  content: \"?\";\n}\n.icon-software-selection-rectangle:before {\n  content: \"@\";\n}\n.icon-software-selection-roundedrectangle:before {\n  content: \"[\";\n}\n.icon-software-shape-oval:before {\n  content: \"]\";\n}\n.icon-software-shape-polygon:before {\n  content: \"^\";\n}\n.icon-software-shape-rectangle:before {\n  content: \"_\";\n}\n.icon-software-shape-roundedrectangle:before {\n  content: \"`\";\n}\n.icon-software-slice:before {\n  content: \"{\";\n}\n.icon-software-transform-bezier:before {\n  content: \"|\";\n}\n.icon-software-vector-box:before {\n  content: \"}\";\n}\n.icon-software-vector-composite:before {\n  content: \"~\";\n}\n.icon-software-vector-line:before {\n  content: \"\";\n}\n.icon-software-vertical-align-bottom:before {\n  content: \"\\e000\";\n}\n.icon-software-vertical-align-center:before {\n  content: \"\\e001\";\n}\n.icon-software-vertical-align-top:before {\n  content: \"\\e002\";\n}\n.icon-software-vertical-distribute-bottom:before {\n  content: \"\\e003\";\n}\n.icon-software-vertical-distribute-center:before {\n  content: \"\\e004\";\n}\n.icon-software-vertical-distribute-top:before {\n  content: \"\\e005\";\n}\n@font-face {\n  font-family: \"linea-weather-10\";\n  src: url(\"fonts/linea-weather-10.eot\");\n  src: url(\"fonts/linea-weather-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"fonts/linea-weather-10.woff\") format(\"woff\"), url(\"fonts/linea-weather-10.ttf\") format(\"truetype\"), url(\"fonts/linea-weather-10.svg#linea-weather-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n}\n.linea-weather[data-icon]:before {\n  font-family: \"linea-weather-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-weather-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-weather-aquarius:before {\n  content: \"\\e000\";\n}\n.icon-weather-aries:before {\n  content: \"\\e001\";\n}\n.icon-weather-cancer:before {\n  content: \"\\e002\";\n}\n.icon-weather-capricorn:before {\n  content: \"\\e003\";\n}\n.icon-weather-cloud:before {\n  content: \"\\e004\";\n}\n.icon-weather-cloud-drop:before {\n  content: \"\\e005\";\n}\n.icon-weather-cloud-lightning:before {\n  content: \"\\e006\";\n}\n.icon-weather-cloud-snowflake:before {\n  content: \"\\e007\";\n}\n.icon-weather-downpour-fullmoon:before {\n  content: \"\\e008\";\n}\n.icon-weather-downpour-halfmoon:before {\n  content: \"\\e009\";\n}\n.icon-weather-downpour-sun:before {\n  content: \"\\e00a\";\n}\n.icon-weather-drop:before {\n  content: \"\\e00b\";\n}\n.icon-weather-first-quarter:before {\n  content: \"\\e00c\";\n}\n.icon-weather-fog:before {\n  content: \"\\e00d\";\n}\n.icon-weather-fog-fullmoon:before {\n  content: \"\\e00e\";\n}\n.icon-weather-fog-halfmoon:before {\n  content: \"\\e00f\";\n}\n.icon-weather-fog-sun:before {\n  content: \"\\e010\";\n}\n.icon-weather-fullmoon:before {\n  content: \"\\e011\";\n}\n.icon-weather-gemini:before {\n  content: \"\\e012\";\n}\n.icon-weather-hail:before {\n  content: \"\\e013\";\n}\n.icon-weather-hail-fullmoon:before {\n  content: \"\\e014\";\n}\n.icon-weather-hail-halfmoon:before {\n  content: \"\\e015\";\n}\n.icon-weather-hail-sun:before {\n  content: \"\\e016\";\n}\n.icon-weather-last-quarter:before {\n  content: \"\\e017\";\n}\n.icon-weather-leo:before {\n  content: \"\\e018\";\n}\n.icon-weather-libra:before {\n  content: \"\\e019\";\n}\n.icon-weather-lightning:before {\n  content: \"\\e01a\";\n}\n.icon-weather-mistyrain:before {\n  content: \"\\e01b\";\n}\n.icon-weather-mistyrain-fullmoon:before {\n  content: \"\\e01c\";\n}\n.icon-weather-mistyrain-halfmoon:before {\n  content: \"\\e01d\";\n}\n.icon-weather-mistyrain-sun:before {\n  content: \"\\e01e\";\n}\n.icon-weather-moon:before {\n  content: \"\\e01f\";\n}\n.icon-weather-moondown-full:before {\n  content: \"\\e020\";\n}\n.icon-weather-moondown-half:before {\n  content: \"\\e021\";\n}\n.icon-weather-moonset-full:before {\n  content: \"\\e022\";\n}\n.icon-weather-moonset-half:before {\n  content: \"\\e023\";\n}\n.icon-weather-move2:before {\n  content: \"\\e024\";\n}\n.icon-weather-newmoon:before {\n  content: \"\\e025\";\n}\n.icon-weather-pisces:before {\n  content: \"\\e026\";\n}\n.icon-weather-rain:before {\n  content: \"\\e027\";\n}\n.icon-weather-rain-fullmoon:before {\n  content: \"\\e028\";\n}\n.icon-weather-rain-halfmoon:before {\n  content: \"\\e029\";\n}\n.icon-weather-rain-sun:before {\n  content: \"\\e02a\";\n}\n.icon-weather-sagittarius:before {\n  content: \"\\e02b\";\n}\n.icon-weather-scorpio:before {\n  content: \"\\e02c\";\n}\n.icon-weather-snow:before {\n  content: \"\\e02d\";\n}\n.icon-weather-snow-fullmoon:before {\n  content: \"\\e02e\";\n}\n.icon-weather-snow-halfmoon:before {\n  content: \"\\e02f\";\n}\n.icon-weather-snow-sun:before {\n  content: \"\\e030\";\n}\n.icon-weather-snowflake:before {\n  content: \"\\e031\";\n}\n.icon-weather-star:before {\n  content: \"\\e032\";\n}\n.icon-weather-storm-11:before {\n  content: \"\\e033\";\n}\n.icon-weather-storm-32:before {\n  content: \"\\e034\";\n}\n.icon-weather-storm-fullmoon:before {\n  content: \"\\e035\";\n}\n.icon-weather-storm-halfmoon:before {\n  content: \"\\e036\";\n}\n.icon-weather-storm-sun:before {\n  content: \"\\e037\";\n}\n.icon-weather-sun:before {\n  content: \"\\e038\";\n}\n.icon-weather-sundown:before {\n  content: \"\\e039\";\n}\n.icon-weather-sunset:before {\n  content: \"\\e03a\";\n}\n.icon-weather-taurus:before {\n  content: \"\\e03b\";\n}\n.icon-weather-tempest:before {\n  content: \"\\e03c\";\n}\n.icon-weather-tempest-fullmoon:before {\n  content: \"\\e03d\";\n}\n.icon-weather-tempest-halfmoon:before {\n  content: \"\\e03e\";\n}\n.icon-weather-tempest-sun:before {\n  content: \"\\e03f\";\n}\n.icon-weather-variable-fullmoon:before {\n  content: \"\\e040\";\n}\n.icon-weather-variable-halfmoon:before {\n  content: \"\\e041\";\n}\n.icon-weather-variable-sun:before {\n  content: \"\\e042\";\n}\n.icon-weather-virgo:before {\n  content: \"\\e043\";\n}\n.icon-weather-waning-cresent:before {\n  content: \"\\e044\";\n}\n.icon-weather-waning-gibbous:before {\n  content: \"\\e045\";\n}\n.icon-weather-waxing-cresent:before {\n  content: \"\\e046\";\n}\n.icon-weather-waxing-gibbous:before {\n  content: \"\\e047\";\n}\n.icon-weather-wind:before {\n  content: \"\\e048\";\n}\n.icon-weather-wind-e:before {\n  content: \"\\e049\";\n}\n.icon-weather-wind-fullmoon:before {\n  content: \"\\e04a\";\n}\n.icon-weather-wind-halfmoon:before {\n  content: \"\\e04b\";\n}\n.icon-weather-wind-n:before {\n  content: \"\\e04c\";\n}\n.icon-weather-wind-ne:before {\n  content: \"\\e04d\";\n}\n.icon-weather-wind-nw:before {\n  content: \"\\e04e\";\n}\n.icon-weather-wind-s:before {\n  content: \"\\e04f\";\n}\n.icon-weather-wind-se:before {\n  content: \"\\e050\";\n}\n.icon-weather-wind-sun:before {\n  content: \"\\e051\";\n}\n.icon-weather-wind-sw:before {\n  content: \"\\e052\";\n}\n.icon-weather-wind-w:before {\n  content: \"\\e053\";\n}\n.icon-weather-windgust:before {\n  content: \"\\e054\";\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/linea-icons/linea.less",
    "content": "@charset \"UTF-8\";\n.glyphs.character-mapping{margin:0 0 20px 0;padding:20px 0 20px 30px;color:rgba(0,0,0,0.5);border:1px solid #d8e0e5;-webkit-border-radius:3px;border-radius:3px;}\n.glyphs.character-mapping li{margin:0 30px 20px 0;display:inline-block;width:90px; text-align:center; font-size:24px; color:@dark;}\n.linea-icon{ position:relative;}\n.linea-icon svg{fill:#000}\n.glyphs.character-mapping input{margin:0;padding:5px 0;line-height:12px;font-size:12px;display:block;width:100%;border:1px solid #d8e0e5;text-align:center;outline:0;}\n.glyphs.character-mapping input:focus{border:1px solid #fbde4a;-webkit-box-shadow:inset 0 0 3px #fbde4a;box-shadow:inset 0 0 3px #fbde4a}\n.glyphs.character-mapping input:hover{-webkit-box-shadow:inset 0 0 3px #fbde4a;box-shadow:inset 0 0 3px #fbde4a}\n\n    \n@font-face {\n  font-family: \"linea-arrows-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-arrows-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-arrows-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-arrows-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-arrows-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-arrows-10.svg#linea-arrows-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-aerrow[data-icon]:before {\n  font-family: \"linea-arrows-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-arrows-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-arrows-anticlockwise:before {\n  content: \"\\e000\";\n}\n.icon-arrows-anticlockwise-dashed:before {\n  content: \"\\e001\";\n}\n.icon-arrows-button-down:before {\n  content: \"\\e002\";\n}\n.icon-arrows-button-off:before {\n  content: \"\\e003\";\n}\n.icon-arrows-button-on:before {\n  content: \"\\e004\";\n}\n.icon-arrows-button-up:before {\n  content: \"\\e005\";\n}\n.icon-arrows-check:before {\n  content: \"\\e006\";\n}\n.icon-arrows-circle-check:before {\n  content: \"\\e007\";\n}\n.icon-arrows-circle-down:before {\n  content: \"\\e008\";\n}\n.icon-arrows-circle-downleft:before {\n  content: \"\\e009\";\n}\n.icon-arrows-circle-downright:before {\n  content: \"\\e00a\";\n}\n.icon-arrows-circle-left:before {\n  content: \"\\e00b\";\n}\n.icon-arrows-circle-minus:before {\n  content: \"\\e00c\";\n}\n.icon-arrows-circle-plus:before {\n  content: \"\\e00d\";\n}\n.icon-arrows-circle-remove:before {\n  content: \"\\e00e\";\n}\n.icon-arrows-circle-right:before {\n  content: \"\\e00f\";\n}\n.icon-arrows-circle-up:before {\n  content: \"\\e010\";\n}\n.icon-arrows-circle-upleft:before {\n  content: \"\\e011\";\n}\n.icon-arrows-circle-upright:before {\n  content: \"\\e012\";\n}\n.icon-arrows-clockwise:before {\n  content: \"\\e013\";\n}\n.icon-arrows-clockwise-dashed:before {\n  content: \"\\e014\";\n}\n.icon-arrows-compress:before {\n  content: \"\\e015\";\n}\n.icon-arrows-deny:before {\n  content: \"\\e016\";\n}\n.icon-arrows-diagonal:before {\n  content: \"\\e017\";\n}\n.icon-arrows-diagonal2:before {\n  content: \"\\e018\";\n}\n.icon-arrows-down:before {\n  content: \"\\e019\";\n}\n.icon-arrows-down-double:before {\n  content: \"\\e01a\";\n}\n.icon-arrows-downleft:before {\n  content: \"\\e01b\";\n}\n.icon-arrows-downright:before {\n  content: \"\\e01c\";\n}\n.icon-arrows-drag-down:before {\n  content: \"\\e01d\";\n}\n.icon-arrows-drag-down-dashed:before {\n  content: \"\\e01e\";\n}\n.icon-arrows-drag-horiz:before {\n  content: \"\\e01f\";\n}\n.icon-arrows-drag-left:before {\n  content: \"\\e020\";\n}\n.icon-arrows-drag-left-dashed:before {\n  content: \"\\e021\";\n}\n.icon-arrows-drag-right:before {\n  content: \"\\e022\";\n}\n.icon-arrows-drag-right-dashed:before {\n  content: \"\\e023\";\n}\n.icon-arrows-drag-up:before {\n  content: \"\\e024\";\n}\n.icon-arrows-drag-up-dashed:before {\n  content: \"\\e025\";\n}\n.icon-arrows-drag-vert:before {\n  content: \"\\e026\";\n}\n.icon-arrows-exclamation:before {\n  content: \"\\e027\";\n}\n.icon-arrows-expand:before {\n  content: \"\\e028\";\n}\n.icon-arrows-expand-diagonal1:before {\n  content: \"\\e029\";\n}\n.icon-arrows-expand-horizontal1:before {\n  content: \"\\e02a\";\n}\n.icon-arrows-expand-vertical1:before {\n  content: \"\\e02b\";\n}\n.icon-arrows-fit-horizontal:before {\n  content: \"\\e02c\";\n}\n.icon-arrows-fit-vertical:before {\n  content: \"\\e02d\";\n}\n.icon-arrows-glide:before {\n  content: \"\\e02e\";\n}\n.icon-arrows-glide-horizontal:before {\n  content: \"\\e02f\";\n}\n.icon-arrows-glide-vertical:before {\n  content: \"\\e030\";\n}\n.icon-arrows-hamburger1:before {\n  content: \"\\e031\";\n}\n.icon-arrows-hamburger-2:before {\n  content: \"\\e032\";\n}\n.icon-arrows-horizontal:before {\n  content: \"\\e033\";\n}\n.icon-arrows-info:before {\n  content: \"\\e034\";\n}\n.icon-arrows-keyboard-alt:before {\n  content: \"\\e035\";\n}\n.icon-arrows-keyboard-cmd:before {\n  content: \"\\e036\";\n}\n.icon-arrows-keyboard-delete:before {\n  content: \"\\e037\";\n}\n.icon-arrows-keyboard-down:before {\n  content: \"\\e038\";\n}\n.icon-arrows-keyboard-left:before {\n  content: \"\\e039\";\n}\n.icon-arrows-keyboard-return:before {\n  content: \"\\e03a\";\n}\n.icon-arrows-keyboard-right:before {\n  content: \"\\e03b\";\n}\n.icon-arrows-keyboard-shift:before {\n  content: \"\\e03c\";\n}\n.icon-arrows-keyboard-tab:before {\n  content: \"\\e03d\";\n}\n.icon-arrows-keyboard-up:before {\n  content: \"\\e03e\";\n}\n.icon-arrows-left:before {\n  content: \"\\e03f\";\n}\n.icon-arrows-left-double-32:before {\n  content: \"\\e040\";\n}\n.icon-arrows-minus:before {\n  content: \"\\e041\";\n}\n.icon-arrows-move:before {\n  content: \"\\e042\";\n}\n.icon-arrows-move2:before {\n  content: \"\\e043\";\n}\n.icon-arrows-move-bottom:before {\n  content: \"\\e044\";\n}\n.icon-arrows-move-left:before {\n  content: \"\\e045\";\n}\n.icon-arrows-move-right:before {\n  content: \"\\e046\";\n}\n.icon-arrows-move-top:before {\n  content: \"\\e047\";\n}\n.icon-arrows-plus:before {\n  content: \"\\e048\";\n}\n.icon-arrows-question:before {\n  content: \"\\e049\";\n}\n.icon-arrows-remove:before {\n  content: \"\\e04a\";\n}\n.icon-arrows-right:before {\n  content: \"\\e04b\";\n}\n.icon-arrows-right-double:before {\n  content: \"\\e04c\";\n}\n.icon-arrows-rotate:before {\n  content: \"\\e04d\";\n}\n.icon-arrows-rotate-anti:before {\n  content: \"\\e04e\";\n}\n.icon-arrows-rotate-anti-dashed:before {\n  content: \"\\e04f\";\n}\n.icon-arrows-rotate-dashed:before {\n  content: \"\\e050\";\n}\n.icon-arrows-shrink:before {\n  content: \"\\e051\";\n}\n.icon-arrows-shrink-diagonal1:before {\n  content: \"\\e052\";\n}\n.icon-arrows-shrink-diagonal2:before {\n  content: \"\\e053\";\n}\n.icon-arrows-shrink-horizonal2:before {\n  content: \"\\e054\";\n}\n.icon-arrows-shrink-horizontal1:before {\n  content: \"\\e055\";\n}\n.icon-arrows-shrink-vertical1:before {\n  content: \"\\e056\";\n}\n.icon-arrows-shrink-vertical2:before {\n  content: \"\\e057\";\n}\n.icon-arrows-sign-down:before {\n  content: \"\\e058\";\n}\n.icon-arrows-sign-left:before {\n  content: \"\\e059\";\n}\n.icon-arrows-sign-right:before {\n  content: \"\\e05a\";\n}\n.icon-arrows-sign-up:before {\n  content: \"\\e05b\";\n}\n.icon-arrows-slide-down1:before {\n  content: \"\\e05c\";\n}\n.icon-arrows-slide-down2:before {\n  content: \"\\e05d\";\n}\n.icon-arrows-slide-left1:before {\n  content: \"\\e05e\";\n}\n.icon-arrows-slide-left2:before {\n  content: \"\\e05f\";\n}\n.icon-arrows-slide-right1:before {\n  content: \"\\e060\";\n}\n.icon-arrows-slide-right2:before {\n  content: \"\\e061\";\n}\n.icon-arrows-slide-up1:before {\n  content: \"\\e062\";\n}\n.icon-arrows-slide-up2:before {\n  content: \"\\e063\";\n}\n.icon-arrows-slim-down:before {\n  content: \"\\e064\";\n}\n.icon-arrows-slim-down-dashed:before {\n  content: \"\\e065\";\n}\n.icon-arrows-slim-left:before {\n  content: \"\\e066\";\n}\n.icon-arrows-slim-left-dashed:before {\n  content: \"\\e067\";\n}\n.icon-arrows-slim-right:before {\n  content: \"\\e068\";\n}\n.icon-arrows-slim-right-dashed:before {\n  content: \"\\e069\";\n}\n.icon-arrows-slim-up:before {\n  content: \"\\e06a\";\n}\n.icon-arrows-slim-up-dashed:before {\n  content: \"\\e06b\";\n}\n.icon-arrows-square-check:before {\n  content: \"\\e06c\";\n}\n.icon-arrows-square-down:before {\n  content: \"\\e06d\";\n}\n.icon-arrows-square-downleft:before {\n  content: \"\\e06e\";\n}\n.icon-arrows-square-downright:before {\n  content: \"\\e06f\";\n}\n.icon-arrows-square-left:before {\n  content: \"\\e070\";\n}\n.icon-arrows-square-minus:before {\n  content: \"\\e071\";\n}\n.icon-arrows-square-plus:before {\n  content: \"\\e072\";\n}\n.icon-arrows-square-remove:before {\n  content: \"\\e073\";\n}\n.icon-arrows-square-right:before {\n  content: \"\\e074\";\n}\n.icon-arrows-square-up:before {\n  content: \"\\e075\";\n}\n.icon-arrows-square-upleft:before {\n  content: \"\\e076\";\n}\n.icon-arrows-square-upright:before {\n  content: \"\\e077\";\n}\n.icon-arrows-squares:before {\n  content: \"\\e078\";\n}\n.icon-arrows-stretch-diagonal1:before {\n  content: \"\\e079\";\n}\n.icon-arrows-stretch-diagonal2:before {\n  content: \"\\e07a\";\n}\n.icon-arrows-stretch-diagonal3:before {\n  content: \"\\e07b\";\n}\n.icon-arrows-stretch-diagonal4:before {\n  content: \"\\e07c\";\n}\n.icon-arrows-stretch-horizontal1:before {\n  content: \"\\e07d\";\n}\n.icon-arrows-stretch-horizontal2:before {\n  content: \"\\e07e\";\n}\n.icon-arrows-stretch-vertical1:before {\n  content: \"\\e07f\";\n}\n.icon-arrows-stretch-vertical2:before {\n  content: \"\\e080\";\n}\n.icon-arrows-switch-horizontal:before {\n  content: \"\\e081\";\n}\n.icon-arrows-switch-vertical:before {\n  content: \"\\e082\";\n}\n.icon-arrows-up:before {\n  content: \"\\e083\";\n}\n.icon-arrows-up-double-33:before {\n  content: \"\\e084\";\n}\n.icon-arrows-upleft:before {\n  content: \"\\e085\";\n}\n.icon-arrows-upright:before {\n  content: \"\\e086\";\n}\n.icon-arrows-vertical:before {\n  content: \"\\e087\";\n}\n/*Basic icon*/\n@font-face {\n  font-family: \"linea-basic-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-basic-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-basic-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-10.svg#linea-basic-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-basic[data-icon]:before {\n  font-family: \"linea-basic-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-basic-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-basic-accelerator:before {\n  content: \"a\";\n}\n.icon-basic-alarm:before {\n  content: \"b\";\n}\n.icon-basic-anchor:before {\n  content: \"c\";\n}\n.icon-basic-anticlockwise:before {\n  content: \"d\";\n}\n.icon-basic-archive:before {\n  content: \"e\";\n}\n.icon-basic-archive-full:before {\n  content: \"f\";\n}\n.icon-basic-ban:before {\n  content: \"g\";\n}\n.icon-basic-battery-charge:before {\n  content: \"h\";\n}\n.icon-basic-battery-empty:before {\n  content: \"i\";\n}\n.icon-basic-battery-full:before {\n  content: \"j\";\n}\n.icon-basic-battery-half:before {\n  content: \"k\";\n}\n.icon-basic-bolt:before {\n  content: \"l\";\n}\n.icon-basic-book:before {\n  content: \"m\";\n}\n.icon-basic-book-pen:before {\n  content: \"n\";\n}\n.icon-basic-book-pencil:before {\n  content: \"o\";\n}\n.icon-basic-bookmark:before {\n  content: \"p\";\n}\n.icon-basic-calculator:before {\n  content: \"q\";\n}\n.icon-basic-calendar:before {\n  content: \"r\";\n}\n.icon-basic-cards-diamonds:before {\n  content: \"s\";\n}\n.icon-basic-cards-hearts:before {\n  content: \"t\";\n}\n.icon-basic-case:before {\n  content: \"u\";\n}\n.icon-basic-chronometer:before {\n  content: \"v\";\n}\n.icon-basic-clessidre:before {\n  content: \"w\";\n}\n.icon-basic-clock:before {\n  content: \"x\";\n}\n.icon-basic-clockwise:before {\n  content: \"y\";\n}\n.icon-basic-cloud:before {\n  content: \"z\";\n}\n.icon-basic-clubs:before {\n  content: \"A\";\n}\n.icon-basic-compass:before {\n  content: \"B\";\n}\n.icon-basic-cup:before {\n  content: \"C\";\n}\n.icon-basic-diamonds:before {\n  content: \"D\";\n}\n.icon-basic-display:before {\n  content: \"E\";\n}\n.icon-basic-download:before {\n  content: \"F\";\n}\n.icon-basic-exclamation:before {\n  content: \"G\";\n}\n.icon-basic-eye:before {\n  content: \"H\";\n}\n.icon-basic-eye-closed:before {\n  content: \"I\";\n}\n.icon-basic-female:before {\n  content: \"J\";\n}\n.icon-basic-flag1:before {\n  content: \"K\";\n}\n.icon-basic-flag2:before {\n  content: \"L\";\n}\n.icon-basic-floppydisk:before {\n  content: \"M\";\n}\n.icon-basic-folder:before {\n  content: \"N\";\n}\n.icon-basic-folder-multiple:before {\n  content: \"O\";\n}\n.icon-basic-gear:before {\n  content: \"P\";\n}\n.icon-basic-geolocalize-01:before {\n  content: \"Q\";\n}\n.icon-basic-geolocalize-05:before {\n  content: \"R\";\n}\n.icon-basic-globe:before {\n  content: \"S\";\n}\n.icon-basic-gunsight:before {\n  content: \"T\";\n}\n.icon-basic-hammer:before {\n  content: \"U\";\n}\n.icon-basic-headset:before {\n  content: \"V\";\n}\n.icon-basic-heart:before {\n  content: \"W\";\n}\n.icon-basic-heart-broken:before {\n  content: \"X\";\n}\n.icon-basic-helm:before {\n  content: \"Y\";\n}\n.icon-basic-home:before {\n  content: \"Z\";\n}\n.icon-basic-info:before {\n  content: \"0\";\n}\n.icon-basic-ipod:before {\n  content: \"1\";\n}\n.icon-basic-joypad:before {\n  content: \"2\";\n}\n.icon-basic-key:before {\n  content: \"3\";\n}\n.icon-basic-keyboard:before {\n  content: \"4\";\n}\n.icon-basic-laptop:before {\n  content: \"5\";\n}\n.icon-basic-life-buoy:before {\n  content: \"6\";\n}\n.icon-basic-lightbulb:before {\n  content: \"7\";\n}\n.icon-basic-link:before {\n  content: \"8\";\n}\n.icon-basic-lock:before {\n  content: \"9\";\n}\n.icon-basic-lock-open:before {\n  content: \"!\";\n}\n.icon-basic-magic-mouse:before {\n  content: \"\\\"\";\n}\n.icon-basic-magnifier:before {\n  content: \"#\";\n}\n.icon-basic-magnifier-minus:before {\n  content: \"$\";\n}\n.icon-basic-magnifier-plus:before {\n  content: \"%\";\n}\n.icon-basic-mail:before {\n  content: \"&\";\n}\n.icon-basic-mail-multiple:before {\n  content: \"'\";\n}\n.icon-basic-mail-open:before {\n  content: \"(\";\n}\n.icon-basic-mail-open-text:before {\n  content: \")\";\n}\n.icon-basic-male:before {\n  content: \"*\";\n}\n.icon-basic-map:before {\n  content: \"+\";\n}\n.icon-basic-message:before {\n  content: \",\";\n}\n.icon-basic-message-multiple:before {\n  content: \"-\";\n}\n.icon-basic-message-txt:before {\n  content: \".\";\n}\n.icon-basic-mixer2:before {\n  content: \"/\";\n}\n.icon-basic-mouse:before {\n  content: \":\";\n}\n.icon-basic-notebook:before {\n  content: \";\";\n}\n.icon-basic-notebook-pen:before {\n  content: \"<\";\n}\n.icon-basic-notebook-pencil:before {\n  content: \"=\";\n}\n.icon-basic-paperplane:before {\n  content: \">\";\n}\n.icon-basic-pencil-ruler:before {\n  content: \"?\";\n}\n.icon-basic-pencil-ruler-pen:before {\n  content: \"@\";\n}\n.icon-basic-photo:before {\n  content: \"[\";\n}\n.icon-basic-picture:before {\n  content: \"]\";\n}\n.icon-basic-picture-multiple:before {\n  content: \"^\";\n}\n.icon-basic-pin1:before {\n  content: \"_\";\n}\n.icon-basic-pin2:before {\n  content: \"`\";\n}\n.icon-basic-postcard:before {\n  content: \"{\";\n}\n.icon-basic-postcard-multiple:before {\n  content: \"|\";\n}\n.icon-basic-printer:before {\n  content: \"}\";\n}\n.icon-basic-question:before {\n  content: \"~\";\n}\n.icon-basic-rss:before {\n  content: \"\\\\\";\n}\n.icon-basic-server:before {\n  content: \"\\e000\";\n}\n.icon-basic-server2:before {\n  content: \"\\e001\";\n}\n.icon-basic-server-cloud:before {\n  content: \"\\e002\";\n}\n.icon-basic-server-download:before {\n  content: \"\\e003\";\n}\n.icon-basic-server-upload:before {\n  content: \"\\e004\";\n}\n.icon-basic-settings:before {\n  content: \"\\e005\";\n}\n.icon-basic-share:before {\n  content: \"\\e006\";\n}\n.icon-basic-sheet:before {\n  content: \"\\e007\";\n}\n.icon-basic-sheet-multiple:before {\n  content: \"\\e008\";\n}\n.icon-basic-sheet-pen:before {\n  content: \"\\e009\";\n}\n.icon-basic-sheet-pencil:before {\n  content: \"\\e00a\";\n}\n.icon-basic-sheet-txt:before {\n  content: \"\\e00b\";\n}\n.icon-basic-signs:before {\n  content: \"\\e00c\";\n}\n.icon-basic-smartphone:before {\n  content: \"\\e00d\";\n}\n.icon-basic-spades:before {\n  content: \"\\e00e\";\n}\n.icon-basic-spread:before {\n  content: \"\\e00f\";\n}\n.icon-basic-spread-bookmark:before {\n  content: \"\\e010\";\n}\n.icon-basic-spread-text:before {\n  content: \"\\e011\";\n}\n.icon-basic-spread-text-bookmark:before {\n  content: \"\\e012\";\n}\n.icon-basic-star:before {\n  content: \"\\e013\";\n}\n.icon-basic-tablet:before {\n  content: \"\\e014\";\n}\n.icon-basic-target:before {\n  content: \"\\e015\";\n}\n.icon-basic-todo:before {\n  content: \"\\e016\";\n}\n.icon-basic-todo-pen:before {\n  content: \"\\e017\";\n}\n.icon-basic-todo-pencil:before {\n  content: \"\\e018\";\n}\n.icon-basic-todo-txt:before {\n  content: \"\\e019\";\n}\n.icon-basic-todolist-pen:before {\n  content: \"\\e01a\";\n}\n.icon-basic-todolist-pencil:before {\n  content: \"\\e01b\";\n}\n.icon-basic-trashcan:before {\n  content: \"\\e01c\";\n}\n.icon-basic-trashcan-full:before {\n  content: \"\\e01d\";\n}\n.icon-basic-trashcan-refresh:before {\n  content: \"\\e01e\";\n}\n.icon-basic-trashcan-remove:before {\n  content: \"\\e01f\";\n}\n.icon-basic-upload:before {\n  content: \"\\e020\";\n}\n.icon-basic-usb:before {\n  content: \"\\e021\";\n}\n.icon-basic-video:before {\n  content: \"\\e022\";\n}\n.icon-basic-watch:before {\n  content: \"\\e023\";\n}\n.icon-basic-webpage:before {\n  content: \"\\e024\";\n}\n.icon-basic-webpage-img-txt:before {\n  content: \"\\e025\";\n}\n.icon-basic-webpage-multiple:before {\n  content: \"\\e026\";\n}\n.icon-basic-webpage-txt:before {\n  content: \"\\e027\";\n}\n.icon-basic-world:before {\n  content: \"\\e028\";\n}\n\n/*Basic elaboration*/\n\n\n@font-face {\n  font-family: \"linea-basic-elaboration-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-basic-elaboration-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-basic-elaboration-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-elaboration-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-elaboration-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-basic-elaboration-10.svg#linea-basic-elaboration-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-elaborate[data-icon]:before {\n  font-family: \"linea-basic-elaboration-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-basic-elaboration-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-basic-elaboration-bookmark-checck:before {\n  content: \"a\";\n}\n.icon-basic-elaboration-bookmark-minus:before {\n  content: \"b\";\n}\n.icon-basic-elaboration-bookmark-plus:before {\n  content: \"c\";\n}\n.icon-basic-elaboration-bookmark-remove:before {\n  content: \"d\";\n}\n.icon-basic-elaboration-briefcase-check:before {\n  content: \"e\";\n}\n.icon-basic-elaboration-briefcase-download:before {\n  content: \"f\";\n}\n.icon-basic-elaboration-briefcase-flagged:before {\n  content: \"g\";\n}\n.icon-basic-elaboration-briefcase-minus:before {\n  content: \"h\";\n}\n.icon-basic-elaboration-briefcase-plus:before {\n  content: \"i\";\n}\n.icon-basic-elaboration-briefcase-refresh:before {\n  content: \"j\";\n}\n.icon-basic-elaboration-briefcase-remove:before {\n  content: \"k\";\n}\n.icon-basic-elaboration-briefcase-search:before {\n  content: \"l\";\n}\n.icon-basic-elaboration-briefcase-star:before {\n  content: \"m\";\n}\n.icon-basic-elaboration-briefcase-upload:before {\n  content: \"n\";\n}\n.icon-basic-elaboration-browser-check:before {\n  content: \"o\";\n}\n.icon-basic-elaboration-browser-download:before {\n  content: \"p\";\n}\n.icon-basic-elaboration-browser-minus:before {\n  content: \"q\";\n}\n.icon-basic-elaboration-browser-plus:before {\n  content: \"r\";\n}\n.icon-basic-elaboration-browser-refresh:before {\n  content: \"s\";\n}\n.icon-basic-elaboration-browser-remove:before {\n  content: \"t\";\n}\n.icon-basic-elaboration-browser-search:before {\n  content: \"u\";\n}\n.icon-basic-elaboration-browser-star:before {\n  content: \"v\";\n}\n.icon-basic-elaboration-browser-upload:before {\n  content: \"w\";\n}\n.icon-basic-elaboration-calendar-check:before {\n  content: \"x\";\n}\n.icon-basic-elaboration-calendar-cloud:before {\n  content: \"y\";\n}\n.icon-basic-elaboration-calendar-download:before {\n  content: \"z\";\n}\n.icon-basic-elaboration-calendar-empty:before {\n  content: \"A\";\n}\n.icon-basic-elaboration-calendar-flagged:before {\n  content: \"B\";\n}\n.icon-basic-elaboration-calendar-heart:before {\n  content: \"C\";\n}\n.icon-basic-elaboration-calendar-minus:before {\n  content: \"D\";\n}\n.icon-basic-elaboration-calendar-next:before {\n  content: \"E\";\n}\n.icon-basic-elaboration-calendar-noaccess:before {\n  content: \"F\";\n}\n.icon-basic-elaboration-calendar-pencil:before {\n  content: \"G\";\n}\n.icon-basic-elaboration-calendar-plus:before {\n  content: \"H\";\n}\n.icon-basic-elaboration-calendar-previous:before {\n  content: \"I\";\n}\n.icon-basic-elaboration-calendar-refresh:before {\n  content: \"J\";\n}\n.icon-basic-elaboration-calendar-remove:before {\n  content: \"K\";\n}\n.icon-basic-elaboration-calendar-search:before {\n  content: \"L\";\n}\n.icon-basic-elaboration-calendar-star:before {\n  content: \"M\";\n}\n.icon-basic-elaboration-calendar-upload:before {\n  content: \"N\";\n}\n.icon-basic-elaboration-cloud-check:before {\n  content: \"O\";\n}\n.icon-basic-elaboration-cloud-download:before {\n  content: \"P\";\n}\n.icon-basic-elaboration-cloud-minus:before {\n  content: \"Q\";\n}\n.icon-basic-elaboration-cloud-noaccess:before {\n  content: \"R\";\n}\n.icon-basic-elaboration-cloud-plus:before {\n  content: \"S\";\n}\n.icon-basic-elaboration-cloud-refresh:before {\n  content: \"T\";\n}\n.icon-basic-elaboration-cloud-remove:before {\n  content: \"U\";\n}\n.icon-basic-elaboration-cloud-search:before {\n  content: \"V\";\n}\n.icon-basic-elaboration-cloud-upload:before {\n  content: \"W\";\n}\n.icon-basic-elaboration-document-check:before {\n  content: \"X\";\n}\n.icon-basic-elaboration-document-cloud:before {\n  content: \"Y\";\n}\n.icon-basic-elaboration-document-download:before {\n  content: \"Z\";\n}\n.icon-basic-elaboration-document-flagged:before {\n  content: \"0\";\n}\n.icon-basic-elaboration-document-graph:before {\n  content: \"1\";\n}\n.icon-basic-elaboration-document-heart:before {\n  content: \"2\";\n}\n.icon-basic-elaboration-document-minus:before {\n  content: \"3\";\n}\n.icon-basic-elaboration-document-next:before {\n  content: \"4\";\n}\n.icon-basic-elaboration-document-noaccess:before {\n  content: \"5\";\n}\n.icon-basic-elaboration-document-note:before {\n  content: \"6\";\n}\n.icon-basic-elaboration-document-pencil:before {\n  content: \"7\";\n}\n.icon-basic-elaboration-document-picture:before {\n  content: \"8\";\n}\n.icon-basic-elaboration-document-plus:before {\n  content: \"9\";\n}\n.icon-basic-elaboration-document-previous:before {\n  content: \"!\";\n}\n.icon-basic-elaboration-document-refresh:before {\n  content: \"\\\"\";\n}\n.icon-basic-elaboration-document-remove:before {\n  content: \"#\";\n}\n.icon-basic-elaboration-document-search:before {\n  content: \"$\";\n}\n.icon-basic-elaboration-document-star:before {\n  content: \"%\";\n}\n.icon-basic-elaboration-document-upload:before {\n  content: \"&\";\n}\n.icon-basic-elaboration-folder-check:before {\n  content: \"'\";\n}\n.icon-basic-elaboration-folder-cloud:before {\n  content: \"(\";\n}\n.icon-basic-elaboration-folder-document:before {\n  content: \")\";\n}\n.icon-basic-elaboration-folder-download:before {\n  content: \"*\";\n}\n.icon-basic-elaboration-folder-flagged:before {\n  content: \"+\";\n}\n.icon-basic-elaboration-folder-graph:before {\n  content: \",\";\n}\n.icon-basic-elaboration-folder-heart:before {\n  content: \"-\";\n}\n.icon-basic-elaboration-folder-minus:before {\n  content: \".\";\n}\n.icon-basic-elaboration-folder-next:before {\n  content: \"/\";\n}\n.icon-basic-elaboration-folder-noaccess:before {\n  content: \":\";\n}\n.icon-basic-elaboration-folder-note:before {\n  content: \";\";\n}\n.icon-basic-elaboration-folder-pencil:before {\n  content: \"<\";\n}\n.icon-basic-elaboration-folder-picture:before {\n  content: \"=\";\n}\n.icon-basic-elaboration-folder-plus:before {\n  content: \">\";\n}\n.icon-basic-elaboration-folder-previous:before {\n  content: \"?\";\n}\n.icon-basic-elaboration-folder-refresh:before {\n  content: \"@\";\n}\n.icon-basic-elaboration-folder-remove:before {\n  content: \"[\";\n}\n.icon-basic-elaboration-folder-search:before {\n  content: \"]\";\n}\n.icon-basic-elaboration-folder-star:before {\n  content: \"^\";\n}\n.icon-basic-elaboration-folder-upload:before {\n  content: \"_\";\n}\n.icon-basic-elaboration-mail-check:before {\n  content: \"`\";\n}\n.icon-basic-elaboration-mail-cloud:before {\n  content: \"{\";\n}\n.icon-basic-elaboration-mail-document:before {\n  content: \"|\";\n}\n.icon-basic-elaboration-mail-download:before {\n  content: \"}\";\n}\n.icon-basic-elaboration-mail-flagged:before {\n  content: \"~\";\n}\n.icon-basic-elaboration-mail-heart:before {\n  content: \"\\\\\";\n}\n.icon-basic-elaboration-mail-next:before {\n  content: \"\\e000\";\n}\n.icon-basic-elaboration-mail-noaccess:before {\n  content: \"\\e001\";\n}\n.icon-basic-elaboration-mail-note:before {\n  content: \"\\e002\";\n}\n.icon-basic-elaboration-mail-pencil:before {\n  content: \"\\e003\";\n}\n.icon-basic-elaboration-mail-picture:before {\n  content: \"\\e004\";\n}\n.icon-basic-elaboration-mail-previous:before {\n  content: \"\\e005\";\n}\n.icon-basic-elaboration-mail-refresh:before {\n  content: \"\\e006\";\n}\n.icon-basic-elaboration-mail-remove:before {\n  content: \"\\e007\";\n}\n.icon-basic-elaboration-mail-search:before {\n  content: \"\\e008\";\n}\n.icon-basic-elaboration-mail-star:before {\n  content: \"\\e009\";\n}\n.icon-basic-elaboration-mail-upload:before {\n  content: \"\\e00a\";\n}\n.icon-basic-elaboration-message-check:before {\n  content: \"\\e00b\";\n}\n.icon-basic-elaboration-message-dots:before {\n  content: \"\\e00c\";\n}\n.icon-basic-elaboration-message-happy:before {\n  content: \"\\e00d\";\n}\n.icon-basic-elaboration-message-heart:before {\n  content: \"\\e00e\";\n}\n.icon-basic-elaboration-message-minus:before {\n  content: \"\\e00f\";\n}\n.icon-basic-elaboration-message-note:before {\n  content: \"\\e010\";\n}\n.icon-basic-elaboration-message-plus:before {\n  content: \"\\e011\";\n}\n.icon-basic-elaboration-message-refresh:before {\n  content: \"\\e012\";\n}\n.icon-basic-elaboration-message-remove:before {\n  content: \"\\e013\";\n}\n.icon-basic-elaboration-message-sad:before {\n  content: \"\\e014\";\n}\n.icon-basic-elaboration-smartphone-cloud:before {\n  content: \"\\e015\";\n}\n.icon-basic-elaboration-smartphone-heart:before {\n  content: \"\\e016\";\n}\n.icon-basic-elaboration-smartphone-noaccess:before {\n  content: \"\\e017\";\n}\n.icon-basic-elaboration-smartphone-note:before {\n  content: \"\\e018\";\n}\n.icon-basic-elaboration-smartphone-pencil:before {\n  content: \"\\e019\";\n}\n.icon-basic-elaboration-smartphone-picture:before {\n  content: \"\\e01a\";\n}\n.icon-basic-elaboration-smartphone-refresh:before {\n  content: \"\\e01b\";\n}\n.icon-basic-elaboration-smartphone-search:before {\n  content: \"\\e01c\";\n}\n.icon-basic-elaboration-tablet-cloud:before {\n  content: \"\\e01d\";\n}\n.icon-basic-elaboration-tablet-heart:before {\n  content: \"\\e01e\";\n}\n.icon-basic-elaboration-tablet-noaccess:before {\n  content: \"\\e01f\";\n}\n.icon-basic-elaboration-tablet-note:before {\n  content: \"\\e020\";\n}\n.icon-basic-elaboration-tablet-pencil:before {\n  content: \"\\e021\";\n}\n.icon-basic-elaboration-tablet-picture:before {\n  content: \"\\e022\";\n}\n.icon-basic-elaboration-tablet-refresh:before {\n  content: \"\\e023\";\n}\n.icon-basic-elaboration-tablet-search:before {\n  content: \"\\e024\";\n}\n.icon-basic-elaboration-todolist-2:before {\n  content: \"\\e025\";\n}\n.icon-basic-elaboration-todolist-check:before {\n  content: \"\\e026\";\n}\n.icon-basic-elaboration-todolist-cloud:before {\n  content: \"\\e027\";\n}\n.icon-basic-elaboration-todolist-download:before {\n  content: \"\\e028\";\n}\n.icon-basic-elaboration-todolist-flagged:before {\n  content: \"\\e029\";\n}\n.icon-basic-elaboration-todolist-minus:before {\n  content: \"\\e02a\";\n}\n.icon-basic-elaboration-todolist-noaccess:before {\n  content: \"\\e02b\";\n}\n.icon-basic-elaboration-todolist-pencil:before {\n  content: \"\\e02c\";\n}\n.icon-basic-elaboration-todolist-plus:before {\n  content: \"\\e02d\";\n}\n.icon-basic-elaboration-todolist-refresh:before {\n  content: \"\\e02e\";\n}\n.icon-basic-elaboration-todolist-remove:before {\n  content: \"\\e02f\";\n}\n.icon-basic-elaboration-todolist-search:before {\n  content: \"\\e030\";\n}\n.icon-basic-elaboration-todolist-star:before {\n  content: \"\\e031\";\n}\n.icon-basic-elaboration-todolist-upload:before {\n  content: \"\\e032\";\n}\n\n/*Ecommerce*/\n\n@font-face {\n  font-family: \"linea-ecommerce-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-ecommerce-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-ecommerce-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-ecommerce-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-ecommerce-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-ecommerce-10.svg#linea-ecommerce-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-ecommerce[data-icon]:before {\n  font-family: \"linea-ecommerce-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-ecommerce-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-ecommerce-bag:before {\n  content: \"a\";\n}\n.icon-ecommerce-bag-check:before {\n  content: \"b\";\n}\n.icon-ecommerce-bag-cloud:before {\n  content: \"c\";\n}\n.icon-ecommerce-bag-download:before {\n  content: \"d\";\n}\n.icon-ecommerce-bag-minus:before {\n  content: \"e\";\n}\n.icon-ecommerce-bag-plus:before {\n  content: \"f\";\n}\n.icon-ecommerce-bag-refresh:before {\n  content: \"g\";\n}\n.icon-ecommerce-bag-remove:before {\n  content: \"h\";\n}\n.icon-ecommerce-bag-search:before {\n  content: \"i\";\n}\n.icon-ecommerce-bag-upload:before {\n  content: \"j\";\n}\n.icon-ecommerce-banknote:before {\n  content: \"k\";\n}\n.icon-ecommerce-banknotes:before {\n  content: \"l\";\n}\n.icon-ecommerce-basket:before {\n  content: \"m\";\n}\n.icon-ecommerce-basket-check:before {\n  content: \"n\";\n}\n.icon-ecommerce-basket-cloud:before {\n  content: \"o\";\n}\n.icon-ecommerce-basket-download:before {\n  content: \"p\";\n}\n.icon-ecommerce-basket-minus:before {\n  content: \"q\";\n}\n.icon-ecommerce-basket-plus:before {\n  content: \"r\";\n}\n.icon-ecommerce-basket-refresh:before {\n  content: \"s\";\n}\n.icon-ecommerce-basket-remove:before {\n  content: \"t\";\n}\n.icon-ecommerce-basket-search:before {\n  content: \"u\";\n}\n.icon-ecommerce-basket-upload:before {\n  content: \"v\";\n}\n.icon-ecommerce-bath:before {\n  content: \"w\";\n}\n.icon-ecommerce-cart:before {\n  content: \"x\";\n}\n.icon-ecommerce-cart-check:before {\n  content: \"y\";\n}\n.icon-ecommerce-cart-cloud:before {\n  content: \"z\";\n}\n.icon-ecommerce-cart-content:before {\n  content: \"A\";\n}\n.icon-ecommerce-cart-download:before {\n  content: \"B\";\n}\n.icon-ecommerce-cart-minus:before {\n  content: \"C\";\n}\n.icon-ecommerce-cart-plus:before {\n  content: \"D\";\n}\n.icon-ecommerce-cart-refresh:before {\n  content: \"E\";\n}\n.icon-ecommerce-cart-remove:before {\n  content: \"F\";\n}\n.icon-ecommerce-cart-search:before {\n  content: \"G\";\n}\n.icon-ecommerce-cart-upload:before {\n  content: \"H\";\n}\n.icon-ecommerce-cent:before {\n  content: \"I\";\n}\n.icon-ecommerce-colon:before {\n  content: \"J\";\n}\n.icon-ecommerce-creditcard:before {\n  content: \"K\";\n}\n.icon-ecommerce-diamond:before {\n  content: \"L\";\n}\n.icon-ecommerce-dollar:before {\n  content: \"M\";\n}\n.icon-ecommerce-euro:before {\n  content: \"N\";\n}\n.icon-ecommerce-franc:before {\n  content: \"O\";\n}\n.icon-ecommerce-gift:before {\n  content: \"P\";\n}\n.icon-ecommerce-graph1:before {\n  content: \"Q\";\n}\n.icon-ecommerce-graph2:before {\n  content: \"R\";\n}\n.icon-ecommerce-graph3:before {\n  content: \"S\";\n}\n.icon-ecommerce-graph-decrease:before {\n  content: \"T\";\n}\n.icon-ecommerce-graph-increase:before {\n  content: \"U\";\n}\n.icon-ecommerce-guarani:before {\n  content: \"V\";\n}\n.icon-ecommerce-kips:before {\n  content: \"W\";\n}\n.icon-ecommerce-lira:before {\n  content: \"X\";\n}\n.icon-ecommerce-megaphone:before {\n  content: \"Y\";\n}\n.icon-ecommerce-money:before {\n  content: \"Z\";\n}\n.icon-ecommerce-naira:before {\n  content: \"0\";\n}\n.icon-ecommerce-pesos:before {\n  content: \"1\";\n}\n.icon-ecommerce-pound:before {\n  content: \"2\";\n}\n.icon-ecommerce-receipt:before {\n  content: \"3\";\n}\n.icon-ecommerce-receipt-bath:before {\n  content: \"4\";\n}\n.icon-ecommerce-receipt-cent:before {\n  content: \"5\";\n}\n.icon-ecommerce-receipt-dollar:before {\n  content: \"6\";\n}\n.icon-ecommerce-receipt-euro:before {\n  content: \"7\";\n}\n.icon-ecommerce-receipt-franc:before {\n  content: \"8\";\n}\n.icon-ecommerce-receipt-guarani:before {\n  content: \"9\";\n}\n.icon-ecommerce-receipt-kips:before {\n  content: \"!\";\n}\n.icon-ecommerce-receipt-lira:before {\n  content: \"\\\"\";\n}\n.icon-ecommerce-receipt-naira:before {\n  content: \"#\";\n}\n.icon-ecommerce-receipt-pesos:before {\n  content: \"$\";\n}\n.icon-ecommerce-receipt-pound:before {\n  content: \"%\";\n}\n.icon-ecommerce-receipt-rublo:before {\n  content: \"&\";\n}\n.icon-ecommerce-receipt-rupee:before {\n  content: \"'\";\n}\n.icon-ecommerce-receipt-tugrik:before {\n  content: \"(\";\n}\n.icon-ecommerce-receipt-won:before {\n  content: \")\";\n}\n.icon-ecommerce-receipt-yen:before {\n  content: \"*\";\n}\n.icon-ecommerce-receipt-yen2:before {\n  content: \"+\";\n}\n.icon-ecommerce-recept-colon:before {\n  content: \",\";\n}\n.icon-ecommerce-rublo:before {\n  content: \"-\";\n}\n.icon-ecommerce-rupee:before {\n  content: \".\";\n}\n.icon-ecommerce-safe:before {\n  content: \"/\";\n}\n.icon-ecommerce-sale:before {\n  content: \":\";\n}\n.icon-ecommerce-sales:before {\n  content: \";\";\n}\n.icon-ecommerce-ticket:before {\n  content: \"<\";\n}\n.icon-ecommerce-tugriks:before {\n  content: \"=\";\n}\n.icon-ecommerce-wallet:before {\n  content: \">\";\n}\n.icon-ecommerce-won:before {\n  content: \"?\";\n}\n.icon-ecommerce-yen:before {\n  content: \"@\";\n}\n.icon-ecommerce-yen2:before {\n  content: \"[\";\n}\n\n/*Music */\n\n@font-face {\n  font-family: \"linea-music-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-music-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-music-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-music-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-music-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-music-10.svg#linea-music-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-music[data-icon]:before {\n  font-family: \"linea-music-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-music-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-music-beginning-button:before {\n  content: \"a\";\n}\n.icon-music-bell:before {\n  content: \"b\";\n}\n.icon-music-cd:before {\n  content: \"c\";\n}\n.icon-music-diapason:before {\n  content: \"d\";\n}\n.icon-music-eject-button:before {\n  content: \"e\";\n}\n.icon-music-end-button:before {\n  content: \"f\";\n}\n.icon-music-fastforward-button:before {\n  content: \"g\";\n}\n.icon-music-headphones:before {\n  content: \"h\";\n}\n.icon-music-ipod:before {\n  content: \"i\";\n}\n.icon-music-loudspeaker:before {\n  content: \"j\";\n}\n.icon-music-microphone:before {\n  content: \"k\";\n}\n.icon-music-microphone-old:before {\n  content: \"l\";\n}\n.icon-music-mixer:before {\n  content: \"m\";\n}\n.icon-music-mute:before {\n  content: \"n\";\n}\n.icon-music-note-multiple:before {\n  content: \"o\";\n}\n.icon-music-note-single:before {\n  content: \"p\";\n}\n.icon-music-pause-button:before {\n  content: \"q\";\n}\n.icon-music-play-button:before {\n  content: \"r\";\n}\n.icon-music-playlist:before {\n  content: \"s\";\n}\n.icon-music-radio-ghettoblaster:before {\n  content: \"t\";\n}\n.icon-music-radio-portable:before {\n  content: \"u\";\n}\n.icon-music-record:before {\n  content: \"v\";\n}\n.icon-music-recordplayer:before {\n  content: \"w\";\n}\n.icon-music-repeat-button:before {\n  content: \"x\";\n}\n.icon-music-rewind-button:before {\n  content: \"y\";\n}\n.icon-music-shuffle-button:before {\n  content: \"z\";\n}\n.icon-music-stop-button:before {\n  content: \"A\";\n}\n.icon-music-tape:before {\n  content: \"B\";\n}\n.icon-music-volume-down:before {\n  content: \"C\";\n}\n.icon-music-volume-up:before {\n  content: \"D\";\n}\n\n/*Software*/\n\n\n@font-face {\n  font-family: \"linea-software-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-software-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-software-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-software-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-software-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-software-10.svg#linea-software-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-software[data-icon]:before {\n  font-family: \"linea-software-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-software-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-software-add-vectorpoint:before {\n  content: \"a\";\n}\n.icon-software-box-oval:before {\n  content: \"b\";\n}\n.icon-software-box-polygon:before {\n  content: \"c\";\n}\n.icon-software-box-rectangle:before {\n  content: \"d\";\n}\n.icon-software-box-roundedrectangle:before {\n  content: \"e\";\n}\n.icon-software-character:before {\n  content: \"f\";\n}\n.icon-software-crop:before {\n  content: \"g\";\n}\n.icon-software-eyedropper:before {\n  content: \"h\";\n}\n.icon-software-font-allcaps:before {\n  content: \"i\";\n}\n.icon-software-font-baseline-shift:before {\n  content: \"j\";\n}\n.icon-software-font-horizontal-scale:before {\n  content: \"k\";\n}\n.icon-software-font-kerning:before {\n  content: \"l\";\n}\n.icon-software-font-leading:before {\n  content: \"m\";\n}\n.icon-software-font-size:before {\n  content: \"n\";\n}\n.icon-software-font-smallcapital:before {\n  content: \"o\";\n}\n.icon-software-font-smallcaps:before {\n  content: \"p\";\n}\n.icon-software-font-strikethrough:before {\n  content: \"q\";\n}\n.icon-software-font-tracking:before {\n  content: \"r\";\n}\n.icon-software-font-underline:before {\n  content: \"s\";\n}\n.icon-software-font-vertical-scale:before {\n  content: \"t\";\n}\n.icon-software-horizontal-align-center:before {\n  content: \"u\";\n}\n.icon-software-horizontal-align-left:before {\n  content: \"v\";\n}\n.icon-software-horizontal-align-right:before {\n  content: \"w\";\n}\n.icon-software-horizontal-distribute-center:before {\n  content: \"x\";\n}\n.icon-software-horizontal-distribute-left:before {\n  content: \"y\";\n}\n.icon-software-horizontal-distribute-right:before {\n  content: \"z\";\n}\n.icon-software-indent-firstline:before {\n  content: \"A\";\n}\n.icon-software-indent-left:before {\n  content: \"B\";\n}\n.icon-software-indent-right:before {\n  content: \"C\";\n}\n.icon-software-lasso:before {\n  content: \"D\";\n}\n.icon-software-layers1:before {\n  content: \"E\";\n}\n.icon-software-layers2:before {\n  content: \"F\";\n}\n.icon-software-layout:before {\n  content: \"G\";\n}\n.icon-software-layout-2columns:before {\n  content: \"H\";\n}\n.icon-software-layout-3columns:before {\n  content: \"I\";\n}\n.icon-software-layout-4boxes:before {\n  content: \"J\";\n}\n.icon-software-layout-4columns:before {\n  content: \"K\";\n}\n.icon-software-layout-4lines:before {\n  content: \"L\";\n}\n.icon-software-layout-8boxes:before {\n  content: \"M\";\n}\n.icon-software-layout-header:before {\n  content: \"N\";\n}\n.icon-software-layout-header-2columns:before {\n  content: \"O\";\n}\n.icon-software-layout-header-3columns:before {\n  content: \"P\";\n}\n.icon-software-layout-header-4boxes:before {\n  content: \"Q\";\n}\n.icon-software-layout-header-4columns:before {\n  content: \"R\";\n}\n.icon-software-layout-header-complex:before {\n  content: \"S\";\n}\n.icon-software-layout-header-complex2:before {\n  content: \"T\";\n}\n.icon-software-layout-header-complex3:before {\n  content: \"U\";\n}\n.icon-software-layout-header-complex4:before {\n  content: \"V\";\n}\n.icon-software-layout-header-sideleft:before {\n  content: \"W\";\n}\n.icon-software-layout-header-sideright:before {\n  content: \"X\";\n}\n.icon-software-layout-sidebar-left:before {\n  content: \"Y\";\n}\n.icon-software-layout-sidebar-right:before {\n  content: \"Z\";\n}\n.icon-software-magnete:before {\n  content: \"0\";\n}\n.icon-software-pages:before {\n  content: \"1\";\n}\n.icon-software-paintbrush:before {\n  content: \"2\";\n}\n.icon-software-paintbucket:before {\n  content: \"3\";\n}\n.icon-software-paintroller:before {\n  content: \"4\";\n}\n.icon-software-paragraph:before {\n  content: \"5\";\n}\n.icon-software-paragraph-align-left:before {\n  content: \"6\";\n}\n.icon-software-paragraph-align-right:before {\n  content: \"7\";\n}\n.icon-software-paragraph-center:before {\n  content: \"8\";\n}\n.icon-software-paragraph-justify-all:before {\n  content: \"9\";\n}\n.icon-software-paragraph-justify-center:before {\n  content: \"!\";\n}\n.icon-software-paragraph-justify-left:before {\n  content: \"\\\"\";\n}\n.icon-software-paragraph-justify-right:before {\n  content: \"#\";\n}\n.icon-software-paragraph-space-after:before {\n  content: \"$\";\n}\n.icon-software-paragraph-space-before:before {\n  content: \"%\";\n}\n.icon-software-pathfinder-exclude:before {\n  content: \"&\";\n}\n.icon-software-pathfinder-intersect:before {\n  content: \"'\";\n}\n.icon-software-pathfinder-subtract:before {\n  content: \"(\";\n}\n.icon-software-pathfinder-unite:before {\n  content: \")\";\n}\n.icon-software-pen:before {\n  content: \"*\";\n}\n.icon-software-pen-add:before {\n  content: \"+\";\n}\n.icon-software-pen-remove:before {\n  content: \",\";\n}\n.icon-software-pencil:before {\n  content: \"-\";\n}\n.icon-software-polygonallasso:before {\n  content: \".\";\n}\n.icon-software-reflect-horizontal:before {\n  content: \"/\";\n}\n.icon-software-reflect-vertical:before {\n  content: \":\";\n}\n.icon-software-remove-vectorpoint:before {\n  content: \";\";\n}\n.icon-software-scale-expand:before {\n  content: \"<\";\n}\n.icon-software-scale-reduce:before {\n  content: \"=\";\n}\n.icon-software-selection-oval:before {\n  content: \">\";\n}\n.icon-software-selection-polygon:before {\n  content: \"?\";\n}\n.icon-software-selection-rectangle:before {\n  content: \"@\";\n}\n.icon-software-selection-roundedrectangle:before {\n  content: \"[\";\n}\n.icon-software-shape-oval:before {\n  content: \"]\";\n}\n.icon-software-shape-polygon:before {\n  content: \"^\";\n}\n.icon-software-shape-rectangle:before {\n  content: \"_\";\n}\n.icon-software-shape-roundedrectangle:before {\n  content: \"`\";\n}\n.icon-software-slice:before {\n  content: \"{\";\n}\n.icon-software-transform-bezier:before {\n  content: \"|\";\n}\n.icon-software-vector-box:before {\n  content: \"}\";\n}\n.icon-software-vector-composite:before {\n  content: \"~\";\n}\n.icon-software-vector-line:before {\n  content: \"\\\\\";\n}\n.icon-software-vertical-align-bottom:before {\n  content: \"\\e000\";\n}\n.icon-software-vertical-align-center:before {\n  content: \"\\e001\";\n}\n.icon-software-vertical-align-top:before {\n  content: \"\\e002\";\n}\n.icon-software-vertical-distribute-bottom:before {\n  content: \"\\e003\";\n}\n.icon-software-vertical-distribute-center:before {\n  content: \"\\e004\";\n}\n.icon-software-vertical-distribute-top:before {\n  content: \"\\e005\";\n}\n\n/*Weather*/\n\n@font-face {\n  font-family: \"linea-weather-10\";\n  src:url(\"../less/icons/linea-icons/fonts/linea-weather-10.eot\");\n  src:url(\"../less/icons/linea-icons/fonts/linea-weather-10.eot?#iefix\") format(\"embedded-opentype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-weather-10.woff\") format(\"woff\"),\n    url(\"../less/icons/linea-icons/fonts/linea-weather-10.ttf\") format(\"truetype\"),\n    url(\"../less/icons/linea-icons/fonts/linea-weather-10.svg#linea-weather-10\") format(\"svg\");\n  font-weight: normal;\n  font-style: normal;\n\n}\n\n.linea-weather[data-icon]:before {\n  font-family: \"linea-weather-10\" !important;\n  content: attr(data-icon);\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n[class^=\"linea-icon-\"]:before,\n[class*=\"linea- icon-\"]:before {\n  font-family: \"linea-weather-10\" !important;\n  font-style: normal !important;\n  font-weight: normal !important;\n  font-variant: normal !important;\n  text-transform: none !important;\n  speak: none;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.icon-weather-aquarius:before {\n  content: \"\\e000\";\n}\n.icon-weather-aries:before {\n  content: \"\\e001\";\n}\n.icon-weather-cancer:before {\n  content: \"\\e002\";\n}\n.icon-weather-capricorn:before {\n  content: \"\\e003\";\n}\n.icon-weather-cloud:before {\n  content: \"\\e004\";\n}\n.icon-weather-cloud-drop:before {\n  content: \"\\e005\";\n}\n.icon-weather-cloud-lightning:before {\n  content: \"\\e006\";\n}\n.icon-weather-cloud-snowflake:before {\n  content: \"\\e007\";\n}\n.icon-weather-downpour-fullmoon:before {\n  content: \"\\e008\";\n}\n.icon-weather-downpour-halfmoon:before {\n  content: \"\\e009\";\n}\n.icon-weather-downpour-sun:before {\n  content: \"\\e00a\";\n}\n.icon-weather-drop:before {\n  content: \"\\e00b\";\n}\n.icon-weather-first-quarter:before {\n  content: \"\\e00c\";\n}\n.icon-weather-fog:before {\n  content: \"\\e00d\";\n}\n.icon-weather-fog-fullmoon:before {\n  content: \"\\e00e\";\n}\n.icon-weather-fog-halfmoon:before {\n  content: \"\\e00f\";\n}\n.icon-weather-fog-sun:before {\n  content: \"\\e010\";\n}\n.icon-weather-fullmoon:before {\n  content: \"\\e011\";\n}\n.icon-weather-gemini:before {\n  content: \"\\e012\";\n}\n.icon-weather-hail:before {\n  content: \"\\e013\";\n}\n.icon-weather-hail-fullmoon:before {\n  content: \"\\e014\";\n}\n.icon-weather-hail-halfmoon:before {\n  content: \"\\e015\";\n}\n.icon-weather-hail-sun:before {\n  content: \"\\e016\";\n}\n.icon-weather-last-quarter:before {\n  content: \"\\e017\";\n}\n.icon-weather-leo:before {\n  content: \"\\e018\";\n}\n.icon-weather-libra:before {\n  content: \"\\e019\";\n}\n.icon-weather-lightning:before {\n  content: \"\\e01a\";\n}\n.icon-weather-mistyrain:before {\n  content: \"\\e01b\";\n}\n.icon-weather-mistyrain-fullmoon:before {\n  content: \"\\e01c\";\n}\n.icon-weather-mistyrain-halfmoon:before {\n  content: \"\\e01d\";\n}\n.icon-weather-mistyrain-sun:before {\n  content: \"\\e01e\";\n}\n.icon-weather-moon:before {\n  content: \"\\e01f\";\n}\n.icon-weather-moondown-full:before {\n  content: \"\\e020\";\n}\n.icon-weather-moondown-half:before {\n  content: \"\\e021\";\n}\n.icon-weather-moonset-full:before {\n  content: \"\\e022\";\n}\n.icon-weather-moonset-half:before {\n  content: \"\\e023\";\n}\n.icon-weather-move2:before {\n  content: \"\\e024\";\n}\n.icon-weather-newmoon:before {\n  content: \"\\e025\";\n}\n.icon-weather-pisces:before {\n  content: \"\\e026\";\n}\n.icon-weather-rain:before {\n  content: \"\\e027\";\n}\n.icon-weather-rain-fullmoon:before {\n  content: \"\\e028\";\n}\n.icon-weather-rain-halfmoon:before {\n  content: \"\\e029\";\n}\n.icon-weather-rain-sun:before {\n  content: \"\\e02a\";\n}\n.icon-weather-sagittarius:before {\n  content: \"\\e02b\";\n}\n.icon-weather-scorpio:before {\n  content: \"\\e02c\";\n}\n.icon-weather-snow:before {\n  content: \"\\e02d\";\n}\n.icon-weather-snow-fullmoon:before {\n  content: \"\\e02e\";\n}\n.icon-weather-snow-halfmoon:before {\n  content: \"\\e02f\";\n}\n.icon-weather-snow-sun:before {\n  content: \"\\e030\";\n}\n.icon-weather-snowflake:before {\n  content: \"\\e031\";\n}\n.icon-weather-star:before {\n  content: \"\\e032\";\n}\n.icon-weather-storm-11:before {\n  content: \"\\e033\";\n}\n.icon-weather-storm-32:before {\n  content: \"\\e034\";\n}\n.icon-weather-storm-fullmoon:before {\n  content: \"\\e035\";\n}\n.icon-weather-storm-halfmoon:before {\n  content: \"\\e036\";\n}\n.icon-weather-storm-sun:before {\n  content: \"\\e037\";\n}\n.icon-weather-sun:before {\n  content: \"\\e038\";\n}\n.icon-weather-sundown:before {\n  content: \"\\e039\";\n}\n.icon-weather-sunset:before {\n  content: \"\\e03a\";\n}\n.icon-weather-taurus:before {\n  content: \"\\e03b\";\n}\n.icon-weather-tempest:before {\n  content: \"\\e03c\";\n}\n.icon-weather-tempest-fullmoon:before {\n  content: \"\\e03d\";\n}\n.icon-weather-tempest-halfmoon:before {\n  content: \"\\e03e\";\n}\n.icon-weather-tempest-sun:before {\n  content: \"\\e03f\";\n}\n.icon-weather-variable-fullmoon:before {\n  content: \"\\e040\";\n}\n.icon-weather-variable-halfmoon:before {\n  content: \"\\e041\";\n}\n.icon-weather-variable-sun:before {\n  content: \"\\e042\";\n}\n.icon-weather-virgo:before {\n  content: \"\\e043\";\n}\n.icon-weather-waning-cresent:before {\n  content: \"\\e044\";\n}\n.icon-weather-waning-gibbous:before {\n  content: \"\\e045\";\n}\n.icon-weather-waxing-cresent:before {\n  content: \"\\e046\";\n}\n.icon-weather-waxing-gibbous:before {\n  content: \"\\e047\";\n}\n.icon-weather-wind:before {\n  content: \"\\e048\";\n}\n.icon-weather-wind-e:before {\n  content: \"\\e049\";\n}\n.icon-weather-wind-fullmoon:before {\n  content: \"\\e04a\";\n}\n.icon-weather-wind-halfmoon:before {\n  content: \"\\e04b\";\n}\n.icon-weather-wind-n:before {\n  content: \"\\e04c\";\n}\n.icon-weather-wind-ne:before {\n  content: \"\\e04d\";\n}\n.icon-weather-wind-nw:before {\n  content: \"\\e04e\";\n}\n.icon-weather-wind-s:before {\n  content: \"\\e04f\";\n}\n.icon-weather-wind-se:before {\n  content: \"\\e050\";\n}\n.icon-weather-wind-sun:before {\n  content: \"\\e051\";\n}\n.icon-weather-wind-sw:before {\n  content: \"\\e052\";\n}\n.icon-weather-wind-w:before {\n  content: \"\\e053\";\n}\n.icon-weather-windgust:before {\n  content: \"\\e054\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/linea-icons/linea.scss",
    "content": "// Color variables (appears count calculates by raw css)\n$color0: #fbde4a; // Appears 10 times\n$color1: #d8e0e5; // Appears 4 times\n$color2: #162a36; // Appears 2 times\n\n\n.glyphs.character-mapping {\n  -webkit-border-radius:3px;\n  border-radius:3px;\n  border:1px solid $color1;\n  color:rgba(0,0,0,0.5);\n  margin:0 0 20px 0;\n  padding:20px 0 20px 30px;\n  li {\n    display:inline-block;\n    margin:0 30px 20px 0;\n    width:90px;\n  }\n  .icon {\n    -webkit-border-radius:3px;\n    border-radius:3px;\n    color:$color2 !important;\n    font-size:32px;\n    height:55px;\n    margin:10px 0 10px 15px;\n    overflow:hidden;\n    padding:15px;\n    position:relative;\n    width:55px;\n    svg {\n      fill:#000000;\n    }\n  }\n  input {\n    -webkit-border-radius:5px;\n    border-radius:5px;\n    border:1px solid $color1;\n    display:block;\n    font-size:12px;\n    line-height:12px;\n    margin:0;\n    outline:0;\n    padding:5px 0;\n    text-align:center;\n    width:100%;\n    &:focus {\n      -webkit-box-shadow:inset 0 0 3px $color0;\n      border:1px solid $color0;\n      box-shadow:inset 0 0 3px $color0;\n    }\n    &:hover {\n      -webkit-box-shadow:inset 0 0 3px $color0;\n      box-shadow:inset 0 0 3px $color0;\n    }\n  }\n}\n.glyphs.css-mapping {\n  -webkit-border-radius:3px;\n  border-radius:3px;\n  border:1px solid $color1;\n  color:rgba(0,0,0,0.5);\n  margin:0 0 60px 0;\n  padding:30px 0 20px 30px;\n  li {\n    display:inline-block;\n    margin:0 30px 20px 0;\n    overflow:hidden;\n    padding:0;\n  }\n  .icon {\n    color:$color2 !important;\n    float:left;\n    font-size:24px;\n    height:50px;\n    margin-right:10px;\n    margin:0;\n    overflow:hidden;\n    padding:13px;\n    width:50px;\n  }\n  input {\n    -webkit-border-radius:5px;\n    background:#ffffff;\n    border-radius:5px;\n    border:1px solid $color1;\n    display:block;\n    float:right;\n    font-size:16px;\n    height:40px;\n    line-height:16px;\n    margin-top:5px;\n    margin:0;\n    outline:0;\n    padding:8px;\n    width:150px;\n    &:focus {\n      -webkit-box-shadow:inset 0 0 3px $color0;\n      border:1px solid $color0;\n      box-shadow:inset 0 0 3px $color0;\n    }\n    &:hover {\n      -webkit-box-shadow:inset 0 0 3px $color0;\n      box-shadow:inset 0 0 3px $color0;\n    }\n  }\n}  \n$font-face {\n  font-family: \"linea-arrows-10\";\n  font-family: \"linea-basic-10\";\n  font-family: \"linea-basic-elaboration-10\";\n  font-family: \"linea-ecommerce-10\";\n  font-family: \"linea-music-10\";\n  font-family: \"linea-software-10\";\n  font-family: \"linea-weather-10\";\n  font-style: normal;\n  font-style: normal;\n  font-style: normal;\n  font-style: normal;\n  font-style: normal;\n  font-style: normal;\n  font-style: normal;\n  font-weight: normal;\n  font-weight: normal;\n  font-weight: normal;\n  font-weight: normal;\n  font-weight: normal;\n  font-weight: normal;\n  font-weight: normal;\n  src:url(\"/fonts/linea-arrows-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-arrows-10.woff\") format(\"woff\"), url(\"/fonts/linea-arrows-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-arrows-10.svg#linea-arrows-10\") format(\"svg\");\n  src:url(\"/fonts/linea-arrows-10.eot\");\n  src:url(\"/fonts/linea-basic-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-basic-10.woff\") format(\"woff\"), url(\"/fonts/linea-basic-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-basic-10.svg#linea-basic-10\") format(\"svg\");\n  src:url(\"/fonts/linea-basic-10.eot\");\n  src:url(\"/fonts/linea-basic-elaboration-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-basic-elaboration-10.woff\") format(\"woff\"), url(\"/fonts/linea-basic-elaboration-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-basic-elaboration-10.svg#linea-basic-elaboration-10\") format(\"svg\");\n  src:url(\"/fonts/linea-basic-elaboration-10.eot\");\n  src:url(\"/fonts/linea-ecommerce-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-ecommerce-10.woff\") format(\"woff\"), url(\"/fonts/linea-ecommerce-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-ecommerce-10.svg#linea-ecommerce-10\") format(\"svg\");\n  src:url(\"/fonts/linea-ecommerce-10.eot\");\n  src:url(\"/fonts/linea-music-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-music-10.woff\") format(\"woff\"), url(\"/fonts/linea-music-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-music-10.svg#linea-music-10\") format(\"svg\");\n  src:url(\"/fonts/linea-music-10.eot\");\n  src:url(\"/fonts/linea-software-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-software-10.woff\") format(\"woff\"), url(\"/fonts/linea-software-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-software-10.svg#linea-software-10\") format(\"svg\");\n  src:url(\"/fonts/linea-software-10.eot\");\n  src:url(\"/fonts/linea-weather-10.eot?#iefix\") format(\"embedded-opentype\"), url(\"/fonts/linea-weather-10.woff\") format(\"woff\"), url(\"/fonts/linea-weather-10.ttf\") format(\"truetype\"), url(\"/fonts/linea-weather-10.svg#linea-weather-10\") format(\"svg\");\n  src:url(\"/fonts/linea-weather-10.eot\");\n}\n[data-icon] {\n  &:before {\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    content: attr(data-icon);\n    content: attr(data-icon);\n    content: attr(data-icon);\n    content: attr(data-icon);\n    content: attr(data-icon);\n    content: attr(data-icon);\n    content: attr(data-icon);\n    font-family: \"linea-arrows-10\" !important;\n    font-family: \"linea-basic-10\" !important;\n    font-family: \"linea-basic-elaboration-10\" !important;\n    font-family: \"linea-ecommerce-10\" !important;\n    font-family: \"linea-music-10\" !important;\n    font-family: \"linea-software-10\" !important;\n    font-family: \"linea-weather-10\" !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n  }\n}\n[class^=\"icon-\"] {\n  &:before {\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -moz-osx-font-smoothing: grayscale;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    -webkit-font-smoothing: antialiased;\n    font-family: \"linea-arrows-10\" !important;\n    font-family: \"linea-basic-10\" !important;\n    font-family: \"linea-basic-elaboration-10\" !important;\n    font-family: \"linea-ecommerce-10\" !important;\n    font-family: \"linea-music-10\" !important;\n    font-family: \"linea-software-10\" !important;\n    font-family: \"linea-weather-10\" !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-style: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-variant: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    font-weight: normal !important;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    line-height: 1;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    speak: none;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n    text-transform: none !important;\n  }\n}\n[class*=\" {\n  icon-\"] {\n    &:before {\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -moz-osx-font-smoothing: grayscale;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      -webkit-font-smoothing: antialiased;\n      font-family: \"linea-arrows-10\" !important;\n      font-family: \"linea-basic-10\" !important;\n      font-family: \"linea-basic-elaboration-10\" !important;\n      font-family: \"linea-ecommerce-10\" !important;\n      font-family: \"linea-music-10\" !important;\n      font-family: \"linea-software-10\" !important;\n      font-family: \"linea-weather-10\" !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-style: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-variant: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      font-weight: normal !important;\n      line-height: 1;\n      line-height: 1;\n      line-height: 1;\n      line-height: 1;\n      line-height: 1;\n      line-height: 1;\n      line-height: 1;\n      speak: none;\n      speak: none;\n      speak: none;\n      speak: none;\n      speak: none;\n      speak: none;\n      speak: none;\n      text-transform: none !important;\n      text-transform: none !important;\n      text-transform: none !important;\n      text-transform: none !important;\n      text-transform: none !important;\n      text-transform: none !important;\n      text-transform: none !important;\n    }\n  }\n}\n.icon-arrows-anticlockwise {\n  &:before {\n    content: \"\\e000\";\n  }\n}\n.icon-arrows-anticlockwise-dashed {\n  &:before {\n    content: \"\\e001\";\n  }\n}\n.icon-arrows-button-down {\n  &:before {\n    content: \"\\e002\";\n  }\n}\n.icon-arrows-button-off {\n  &:before {\n    content: \"\\e003\";\n  }\n}\n.icon-arrows-button-on {\n  &:before {\n    content: \"\\e004\";\n  }\n}\n.icon-arrows-button-up {\n  &:before {\n    content: \"\\e005\";\n  }\n}\n.icon-arrows-check {\n  &:before {\n    content: \"\\e006\";\n  }\n}\n.icon-arrows-circle-check {\n  &:before {\n    content: \"\\e007\";\n  }\n}\n.icon-arrows-circle-down {\n  &:before {\n    content: \"\\e008\";\n  }\n}\n.icon-arrows-circle-downleft {\n  &:before {\n    content: \"\\e009\";\n  }\n}\n.icon-arrows-circle-downright {\n  &:before {\n    content: \"\\e00a\";\n  }\n}\n.icon-arrows-circle-left {\n  &:before {\n    content: \"\\e00b\";\n  }\n}\n.icon-arrows-circle-minus {\n  &:before {\n    content: \"\\e00c\";\n  }\n}\n.icon-arrows-circle-plus {\n  &:before {\n    content: \"\\e00d\";\n  }\n}\n.icon-arrows-circle-remove {\n  &:before {\n    content: \"\\e00e\";\n  }\n}\n.icon-arrows-circle-right {\n  &:before {\n    content: \"\\e00f\";\n  }\n}\n.icon-arrows-circle-up {\n  &:before {\n    content: \"\\e010\";\n  }\n}\n.icon-arrows-circle-upleft {\n  &:before {\n    content: \"\\e011\";\n  }\n}\n.icon-arrows-circle-upright {\n  &:before {\n    content: \"\\e012\";\n  }\n}\n.icon-arrows-clockwise {\n  &:before {\n    content: \"\\e013\";\n  }\n}\n.icon-arrows-clockwise-dashed {\n  &:before {\n    content: \"\\e014\";\n  }\n}\n.icon-arrows-compress {\n  &:before {\n    content: \"\\e015\";\n  }\n}\n.icon-arrows-deny {\n  &:before {\n    content: \"\\e016\";\n  }\n}\n.icon-arrows-diagonal {\n  &:before {\n    content: \"\\e017\";\n  }\n}\n.icon-arrows-diagonal2 {\n  &:before {\n    content: \"\\e018\";\n  }\n}\n.icon-arrows-down {\n  &:before {\n    content: \"\\e019\";\n  }\n}\n.icon-arrows-down-double {\n  &:before {\n    content: \"\\e01a\";\n  }\n}\n.icon-arrows-downleft {\n  &:before {\n    content: \"\\e01b\";\n  }\n}\n.icon-arrows-downright {\n  &:before {\n    content: \"\\e01c\";\n  }\n}\n.icon-arrows-drag-down {\n  &:before {\n    content: \"\\e01d\";\n  }\n}\n.icon-arrows-drag-down-dashed {\n  &:before {\n    content: \"\\e01e\";\n  }\n}\n.icon-arrows-drag-horiz {\n  &:before {\n    content: \"\\e01f\";\n  }\n}\n.icon-arrows-drag-left {\n  &:before {\n    content: \"\\e020\";\n  }\n}\n.icon-arrows-drag-left-dashed {\n  &:before {\n    content: \"\\e021\";\n  }\n}\n.icon-arrows-drag-right {\n  &:before {\n    content: \"\\e022\";\n  }\n}\n.icon-arrows-drag-right-dashed {\n  &:before {\n    content: \"\\e023\";\n  }\n}\n.icon-arrows-drag-up {\n  &:before {\n    content: \"\\e024\";\n  }\n}\n.icon-arrows-drag-up-dashed {\n  &:before {\n    content: \"\\e025\";\n  }\n}\n.icon-arrows-drag-vert {\n  &:before {\n    content: \"\\e026\";\n  }\n}\n.icon-arrows-exclamation {\n  &:before {\n    content: \"\\e027\";\n  }\n}\n.icon-arrows-expand {\n  &:before {\n    content: \"\\e028\";\n  }\n}\n.icon-arrows-expand-diagonal1 {\n  &:before {\n    content: \"\\e029\";\n  }\n}\n.icon-arrows-expand-horizontal1 {\n  &:before {\n    content: \"\\e02a\";\n  }\n}\n.icon-arrows-expand-vertical1 {\n  &:before {\n    content: \"\\e02b\";\n  }\n}\n.icon-arrows-fit-horizontal {\n  &:before {\n    content: \"\\e02c\";\n  }\n}\n.icon-arrows-fit-vertical {\n  &:before {\n    content: \"\\e02d\";\n  }\n}\n.icon-arrows-glide {\n  &:before {\n    content: \"\\e02e\";\n  }\n}\n.icon-arrows-glide-horizontal {\n  &:before {\n    content: \"\\e02f\";\n  }\n}\n.icon-arrows-glide-vertical {\n  &:before {\n    content: \"\\e030\";\n  }\n}\n.icon-arrows-hamburger1 {\n  &:before {\n    content: \"\\e031\";\n  }\n}\n.icon-arrows-hamburger-2 {\n  &:before {\n    content: \"\\e032\";\n  }\n}\n.icon-arrows-horizontal {\n  &:before {\n    content: \"\\e033\";\n  }\n}\n.icon-arrows-info {\n  &:before {\n    content: \"\\e034\";\n  }\n}\n.icon-arrows-keyboard-alt {\n  &:before {\n    content: \"\\e035\";\n  }\n}\n.icon-arrows-keyboard-cmd {\n  &:before {\n    content: \"\\e036\";\n  }\n}\n.icon-arrows-keyboard-delete {\n  &:before {\n    content: \"\\e037\";\n  }\n}\n.icon-arrows-keyboard-down {\n  &:before {\n    content: \"\\e038\";\n  }\n}\n.icon-arrows-keyboard-left {\n  &:before {\n    content: \"\\e039\";\n  }\n}\n.icon-arrows-keyboard-return {\n  &:before {\n    content: \"\\e03a\";\n  }\n}\n.icon-arrows-keyboard-right {\n  &:before {\n    content: \"\\e03b\";\n  }\n}\n.icon-arrows-keyboard-shift {\n  &:before {\n    content: \"\\e03c\";\n  }\n}\n.icon-arrows-keyboard-tab {\n  &:before {\n    content: \"\\e03d\";\n  }\n}\n.icon-arrows-keyboard-up {\n  &:before {\n    content: \"\\e03e\";\n  }\n}\n.icon-arrows-left {\n  &:before {\n    content: \"\\e03f\";\n  }\n}\n.icon-arrows-left-double-32 {\n  &:before {\n    content: \"\\e040\";\n  }\n}\n.icon-arrows-minus {\n  &:before {\n    content: \"\\e041\";\n  }\n}\n.icon-arrows-move {\n  &:before {\n    content: \"\\e042\";\n  }\n}\n.icon-arrows-move2 {\n  &:before {\n    content: \"\\e043\";\n  }\n}\n.icon-arrows-move-bottom {\n  &:before {\n    content: \"\\e044\";\n  }\n}\n.icon-arrows-move-left {\n  &:before {\n    content: \"\\e045\";\n  }\n}\n.icon-arrows-move-right {\n  &:before {\n    content: \"\\e046\";\n  }\n}\n.icon-arrows-move-top {\n  &:before {\n    content: \"\\e047\";\n  }\n}\n.icon-arrows-plus {\n  &:before {\n    content: \"\\e048\";\n  }\n}\n.icon-arrows-question {\n  &:before {\n    content: \"\\e049\";\n  }\n}\n.icon-arrows-remove {\n  &:before {\n    content: \"\\e04a\";\n  }\n}\n.icon-arrows-right {\n  &:before {\n    content: \"\\e04b\";\n  }\n}\n.icon-arrows-right-double {\n  &:before {\n    content: \"\\e04c\";\n  }\n}\n.icon-arrows-rotate {\n  &:before {\n    content: \"\\e04d\";\n  }\n}\n.icon-arrows-rotate-anti {\n  &:before {\n    content: \"\\e04e\";\n  }\n}\n.icon-arrows-rotate-anti-dashed {\n  &:before {\n    content: \"\\e04f\";\n  }\n}\n.icon-arrows-rotate-dashed {\n  &:before {\n    content: \"\\e050\";\n  }\n}\n.icon-arrows-shrink {\n  &:before {\n    content: \"\\e051\";\n  }\n}\n.icon-arrows-shrink-diagonal1 {\n  &:before {\n    content: \"\\e052\";\n  }\n}\n.icon-arrows-shrink-diagonal2 {\n  &:before {\n    content: \"\\e053\";\n  }\n}\n.icon-arrows-shrink-horizonal2 {\n  &:before {\n    content: \"\\e054\";\n  }\n}\n.icon-arrows-shrink-horizontal1 {\n  &:before {\n    content: \"\\e055\";\n  }\n}\n.icon-arrows-shrink-vertical1 {\n  &:before {\n    content: \"\\e056\";\n  }\n}\n.icon-arrows-shrink-vertical2 {\n  &:before {\n    content: \"\\e057\";\n  }\n}\n.icon-arrows-sign-down {\n  &:before {\n    content: \"\\e058\";\n  }\n}\n.icon-arrows-sign-left {\n  &:before {\n    content: \"\\e059\";\n  }\n}\n.icon-arrows-sign-right {\n  &:before {\n    content: \"\\e05a\";\n  }\n}\n.icon-arrows-sign-up {\n  &:before {\n    content: \"\\e05b\";\n  }\n}\n.icon-arrows-slide-down1 {\n  &:before {\n    content: \"\\e05c\";\n  }\n}\n.icon-arrows-slide-down2 {\n  &:before {\n    content: \"\\e05d\";\n  }\n}\n.icon-arrows-slide-left1 {\n  &:before {\n    content: \"\\e05e\";\n  }\n}\n.icon-arrows-slide-left2 {\n  &:before {\n    content: \"\\e05f\";\n  }\n}\n.icon-arrows-slide-right1 {\n  &:before {\n    content: \"\\e060\";\n  }\n}\n.icon-arrows-slide-right2 {\n  &:before {\n    content: \"\\e061\";\n  }\n}\n.icon-arrows-slide-up1 {\n  &:before {\n    content: \"\\e062\";\n  }\n}\n.icon-arrows-slide-up2 {\n  &:before {\n    content: \"\\e063\";\n  }\n}\n.icon-arrows-slim-down {\n  &:before {\n    content: \"\\e064\";\n  }\n}\n.icon-arrows-slim-down-dashed {\n  &:before {\n    content: \"\\e065\";\n  }\n}\n.icon-arrows-slim-left {\n  &:before {\n    content: \"\\e066\";\n  }\n}\n.icon-arrows-slim-left-dashed {\n  &:before {\n    content: \"\\e067\";\n  }\n}\n.icon-arrows-slim-right {\n  &:before {\n    content: \"\\e068\";\n  }\n}\n.icon-arrows-slim-right-dashed {\n  &:before {\n    content: \"\\e069\";\n  }\n}\n.icon-arrows-slim-up {\n  &:before {\n    content: \"\\e06a\";\n  }\n}\n.icon-arrows-slim-up-dashed {\n  &:before {\n    content: \"\\e06b\";\n  }\n}\n.icon-arrows-square-check {\n  &:before {\n    content: \"\\e06c\";\n  }\n}\n.icon-arrows-square-down {\n  &:before {\n    content: \"\\e06d\";\n  }\n}\n.icon-arrows-square-downleft {\n  &:before {\n    content: \"\\e06e\";\n  }\n}\n.icon-arrows-square-downright {\n  &:before {\n    content: \"\\e06f\";\n  }\n}\n.icon-arrows-square-left {\n  &:before {\n    content: \"\\e070\";\n  }\n}\n.icon-arrows-square-minus {\n  &:before {\n    content: \"\\e071\";\n  }\n}\n.icon-arrows-square-plus {\n  &:before {\n    content: \"\\e072\";\n  }\n}\n.icon-arrows-square-remove {\n  &:before {\n    content: \"\\e073\";\n  }\n}\n.icon-arrows-square-right {\n  &:before {\n    content: \"\\e074\";\n  }\n}\n.icon-arrows-square-up {\n  &:before {\n    content: \"\\e075\";\n  }\n}\n.icon-arrows-square-upleft {\n  &:before {\n    content: \"\\e076\";\n  }\n}\n.icon-arrows-square-upright {\n  &:before {\n    content: \"\\e077\";\n  }\n}\n.icon-arrows-squares {\n  &:before {\n    content: \"\\e078\";\n  }\n}\n.icon-arrows-stretch-diagonal1 {\n  &:before {\n    content: \"\\e079\";\n  }\n}\n.icon-arrows-stretch-diagonal2 {\n  &:before {\n    content: \"\\e07a\";\n  }\n}\n.icon-arrows-stretch-diagonal3 {\n  &:before {\n    content: \"\\e07b\";\n  }\n}\n.icon-arrows-stretch-diagonal4 {\n  &:before {\n    content: \"\\e07c\";\n  }\n}\n.icon-arrows-stretch-horizontal1 {\n  &:before {\n    content: \"\\e07d\";\n  }\n}\n.icon-arrows-stretch-horizontal2 {\n  &:before {\n    content: \"\\e07e\";\n  }\n}\n.icon-arrows-stretch-vertical1 {\n  &:before {\n    content: \"\\e07f\";\n  }\n}\n.icon-arrows-stretch-vertical2 {\n  &:before {\n    content: \"\\e080\";\n  }\n}\n.icon-arrows-switch-horizontal {\n  &:before {\n    content: \"\\e081\";\n  }\n}\n.icon-arrows-switch-vertical {\n  &:before {\n    content: \"\\e082\";\n  }\n}\n.icon-arrows-up {\n  &:before {\n    content: \"\\e083\";\n  }\n}\n.icon-arrows-up-double-33 {\n  &:before {\n    content: \"\\e084\";\n  }\n}\n.icon-arrows-upleft {\n  &:before {\n    content: \"\\e085\";\n  }\n}\n.icon-arrows-upright {\n  &:before {\n    content: \"\\e086\";\n  }\n}\n.icon-arrows-vertical {\n  &:before {\n    content: \"\\e087\";\n  }\n}\n.icon-basic-accelerator {\n  &:before {\n    content: \"a\";\n  }\n}\n.icon-basic-alarm {\n  &:before {\n    content: \"b\";\n  }\n}\n.icon-basic-anchor {\n  &:before {\n    content: \"c\";\n  }\n}\n.icon-basic-anticlockwise {\n  &:before {\n    content: \"d\";\n  }\n}\n.icon-basic-archive {\n  &:before {\n    content: \"e\";\n  }\n}\n.icon-basic-archive-full {\n  &:before {\n    content: \"f\";\n  }\n}\n.icon-basic-ban {\n  &:before {\n    content: \"g\";\n  }\n}\n.icon-basic-battery-charge {\n  &:before {\n    content: \"h\";\n  }\n}\n.icon-basic-battery-empty {\n  &:before {\n    content: \"i\";\n  }\n}\n.icon-basic-battery-full {\n  &:before {\n    content: \"j\";\n  }\n}\n.icon-basic-battery-half {\n  &:before {\n    content: \"k\";\n  }\n}\n.icon-basic-bolt {\n  &:before {\n    content: \"l\";\n  }\n}\n.icon-basic-book {\n  &:before {\n    content: \"m\";\n  }\n}\n.icon-basic-book-pen {\n  &:before {\n    content: \"n\";\n  }\n}\n.icon-basic-book-pencil {\n  &:before {\n    content: \"o\";\n  }\n}\n.icon-basic-bookmark {\n  &:before {\n    content: \"p\";\n  }\n}\n.icon-basic-calculator {\n  &:before {\n    content: \"q\";\n  }\n}\n.icon-basic-calendar {\n  &:before {\n    content: \"r\";\n  }\n}\n.icon-basic-cards-diamonds {\n  &:before {\n    content: \"s\";\n  }\n}\n.icon-basic-cards-hearts {\n  &:before {\n    content: \"t\";\n  }\n}\n.icon-basic-case {\n  &:before {\n    content: \"u\";\n  }\n}\n.icon-basic-chronometer {\n  &:before {\n    content: \"v\";\n  }\n}\n.icon-basic-clessidre {\n  &:before {\n    content: \"w\";\n  }\n}\n.icon-basic-clock {\n  &:before {\n    content: \"x\";\n  }\n}\n.icon-basic-clockwise {\n  &:before {\n    content: \"y\";\n  }\n}\n.icon-basic-cloud {\n  &:before {\n    content: \"z\";\n  }\n}\n.icon-basic-clubs {\n  &:before {\n    content: \"A\";\n  }\n}\n.icon-basic-compass {\n  &:before {\n    content: \"B\";\n  }\n}\n.icon-basic-cup {\n  &:before {\n    content: \"C\";\n  }\n}\n.icon-basic-diamonds {\n  &:before {\n    content: \"D\";\n  }\n}\n.icon-basic-display {\n  &:before {\n    content: \"E\";\n  }\n}\n.icon-basic-download {\n  &:before {\n    content: \"F\";\n  }\n}\n.icon-basic-exclamation {\n  &:before {\n    content: \"G\";\n  }\n}\n.icon-basic-eye {\n  &:before {\n    content: \"H\";\n  }\n}\n.icon-basic-eye-closed {\n  &:before {\n    content: \"I\";\n  }\n}\n.icon-basic-female {\n  &:before {\n    content: \"J\";\n  }\n}\n.icon-basic-flag1 {\n  &:before {\n    content: \"K\";\n  }\n}\n.icon-basic-flag2 {\n  &:before {\n    content: \"L\";\n  }\n}\n.icon-basic-floppydisk {\n  &:before {\n    content: \"M\";\n  }\n}\n.icon-basic-folder {\n  &:before {\n    content: \"N\";\n  }\n}\n.icon-basic-folder-multiple {\n  &:before {\n    content: \"O\";\n  }\n}\n.icon-basic-gear {\n  &:before {\n    content: \"P\";\n  }\n}\n.icon-basic-geolocalize-01 {\n  &:before {\n    content: \"Q\";\n  }\n}\n.icon-basic-geolocalize-05 {\n  &:before {\n    content: \"R\";\n  }\n}\n.icon-basic-globe {\n  &:before {\n    content: \"S\";\n  }\n}\n.icon-basic-gunsight {\n  &:before {\n    content: \"T\";\n  }\n}\n.icon-basic-hammer {\n  &:before {\n    content: \"U\";\n  }\n}\n.icon-basic-headset {\n  &:before {\n    content: \"V\";\n  }\n}\n.icon-basic-heart {\n  &:before {\n    content: \"W\";\n  }\n}\n.icon-basic-heart-broken {\n  &:before {\n    content: \"X\";\n  }\n}\n.icon-basic-helm {\n  &:before {\n    content: \"Y\";\n  }\n}\n.icon-basic-home {\n  &:before {\n    content: \"Z\";\n  }\n}\n.icon-basic-info {\n  &:before {\n    content: \"0\";\n  }\n}\n.icon-basic-ipod {\n  &:before {\n    content: \"1\";\n  }\n}\n.icon-basic-joypad {\n  &:before {\n    content: \"2\";\n  }\n}\n.icon-basic-key {\n  &:before {\n    content: \"3\";\n  }\n}\n.icon-basic-keyboard {\n  &:before {\n    content: \"4\";\n  }\n}\n.icon-basic-laptop {\n  &:before {\n    content: \"5\";\n  }\n}\n.icon-basic-life-buoy {\n  &:before {\n    content: \"6\";\n  }\n}\n.icon-basic-lightbulb {\n  &:before {\n    content: \"7\";\n  }\n}\n.icon-basic-link {\n  &:before {\n    content: \"8\";\n  }\n}\n.icon-basic-lock {\n  &:before {\n    content: \"9\";\n  }\n}\n.icon-basic-lock-open {\n  &:before {\n    content: \"!\";\n  }\n}\n.icon-basic-magic-mouse {\n  &:before {\n    content: \"\\\"\";\n  }\n}\n.icon-basic-magnifier {\n  &:before {\n    content: \"#\";\n  }\n}\n.icon-basic-magnifier-minus {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-basic-magnifier-plus {\n  &:before {\n    content: \"%\";\n  }\n}\n.icon-basic-mail {\n  &:before {\n    content: \"&\";\n  }\n}\n.icon-basic-mail-multiple {\n  &:before {\n    content: \"'\";\n  }\n}\n.icon-basic-mail-open {\n  &:before {\n    content: \"(\";\n  }\n}\n.icon-basic-mail-open-text {\n  &:before {\n    content: \")\";\n  }\n}\n.icon-basic-male {\n  &:before {\n    content: \"*\";\n  }\n}\n.icon-basic-map {\n  &:before {\n    content: \"+\";\n  }\n}\n.icon-basic-message {\n  &:before {\n    content: \",\";\n  }\n}\n.icon-basic-message-multiple {\n  &:before {\n    content: \"-\";\n  }\n}\n.icon-basic-message-txt {\n  &:before {\n    content: \".\";\n  }\n}\n.icon-basic-mixer2 {\n  &:before {\n    content: \"/\";\n  }\n}\n.icon-basic-mouse {\n  &:before {\n    content: \":\";\n  }\n}\n.icon-basic-notebook {\n  &:before {\n    \";\n    content: \";\n  }\n}\n.icon-basic-notebook-pen {\n  &:before {\n    content: \"<\";\n  }\n}\n.icon-basic-notebook-pencil {\n  &:before {\n    content: \"=\";\n  }\n}\n.icon-basic-paperplane {\n  &:before {\n    content: \">\";\n  }\n}\n.icon-basic-pencil-ruler {\n  &:before {\n    content: \"?\";\n  }\n}\n.icon-basic-pencil-ruler-pen {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-basic-photo {\n  &:before {\n    content: \"[\";\n  }\n}\n.icon-basic-picture {\n  &:before {\n    content: \"]\";\n  }\n}\n.icon-basic-picture-multiple {\n  &:before {\n    content: \"^\";\n  }\n}\n.icon-basic-pin1 {\n  &:before {\n    content: \"_\";\n  }\n}\n.icon-basic-pin2 {\n  &:before {\n    content: \"`\";\n  }\n}\n.icon-basic-postcard {\n  &:before {\n    content: \"{\";\n  }\n}\n.icon-basic-postcard-multiple {\n  &:before {\n    content: \"|\";\n  }\n}\n.icon-basic-printer {\n  &:before {\n    content: \";\n  }\n}\n.icon-basic-question {\n  &:before {\n    content: \"~\";\n  }\n}\n.icon-basic-rss {\n  &:before {\n    content: \"\\\\\";\n  }\n}\n.icon-basic-server {\n  &:before {\n    content: \"\\e000\";\n  }\n}\n.icon-basic-server2 {\n  &:before {\n    content: \"\\e001\";\n  }\n}\n.icon-basic-server-cloud {\n  &:before {\n    content: \"\\e002\";\n  }\n}\n.icon-basic-server-download {\n  &:before {\n    content: \"\\e003\";\n  }\n}\n.icon-basic-server-upload {\n  &:before {\n    content: \"\\e004\";\n  }\n}\n.icon-basic-settings {\n  &:before {\n    content: \"\\e005\";\n  }\n}\n.icon-basic-share {\n  &:before {\n    content: \"\\e006\";\n  }\n}\n.icon-basic-sheet {\n  &:before {\n    content: \"\\e007\";\n  }\n}\n.icon-basic-sheet-multiple {\n  &:before {\n    content: \"\\e008\";\n  }\n}\n.icon-basic-sheet-pen {\n  &:before {\n    content: \"\\e009\";\n  }\n}\n.icon-basic-sheet-pencil {\n  &:before {\n    content: \"\\e00a\";\n  }\n}\n.icon-basic-sheet-txt {\n  &:before {\n    content: \"\\e00b\";\n  }\n}\n.icon-basic-signs {\n  &:before {\n    content: \"\\e00c\";\n  }\n}\n.icon-basic-smartphone {\n  &:before {\n    content: \"\\e00d\";\n  }\n}\n.icon-basic-spades {\n  &:before {\n    content: \"\\e00e\";\n  }\n}\n.icon-basic-spread {\n  &:before {\n    content: \"\\e00f\";\n  }\n}\n.icon-basic-spread-bookmark {\n  &:before {\n    content: \"\\e010\";\n  }\n}\n.icon-basic-spread-text {\n  &:before {\n    content: \"\\e011\";\n  }\n}\n.icon-basic-spread-text-bookmark {\n  &:before {\n    content: \"\\e012\";\n  }\n}\n.icon-basic-star {\n  &:before {\n    content: \"\\e013\";\n  }\n}\n.icon-basic-tablet {\n  &:before {\n    content: \"\\e014\";\n  }\n}\n.icon-basic-target {\n  &:before {\n    content: \"\\e015\";\n  }\n}\n.icon-basic-todo {\n  &:before {\n    content: \"\\e016\";\n  }\n}\n.icon-basic-todo-pen {\n  &:before {\n    content: \"\\e017\";\n  }\n}\n.icon-basic-todo-pencil {\n  &:before {\n    content: \"\\e018\";\n  }\n}\n.icon-basic-todo-txt {\n  &:before {\n    content: \"\\e019\";\n  }\n}\n.icon-basic-todolist-pen {\n  &:before {\n    content: \"\\e01a\";\n  }\n}\n.icon-basic-todolist-pencil {\n  &:before {\n    content: \"\\e01b\";\n  }\n}\n.icon-basic-trashcan {\n  &:before {\n    content: \"\\e01c\";\n  }\n}\n.icon-basic-trashcan-full {\n  &:before {\n    content: \"\\e01d\";\n  }\n}\n.icon-basic-trashcan-refresh {\n  &:before {\n    content: \"\\e01e\";\n  }\n}\n.icon-basic-trashcan-remove {\n  &:before {\n    content: \"\\e01f\";\n  }\n}\n.icon-basic-upload {\n  &:before {\n    content: \"\\e020\";\n  }\n}\n.icon-basic-usb {\n  &:before {\n    content: \"\\e021\";\n  }\n}\n.icon-basic-video {\n  &:before {\n    content: \"\\e022\";\n  }\n}\n.icon-basic-watch {\n  &:before {\n    content: \"\\e023\";\n  }\n}\n.icon-basic-webpage {\n  &:before {\n    content: \"\\e024\";\n  }\n}\n.icon-basic-webpage-img-txt {\n  &:before {\n    content: \"\\e025\";\n  }\n}\n.icon-basic-webpage-multiple {\n  &:before {\n    content: \"\\e026\";\n  }\n}\n.icon-basic-webpage-txt {\n  &:before {\n    content: \"\\e027\";\n  }\n}\n.icon-basic-world {\n  &:before {\n    content: \"\\e028\";\n  }\n}\n.icon-basic-elaboration-bookmark-checck {\n  &:before {\n    content: \"a\";\n  }\n}\n.icon-basic-elaboration-bookmark-minus {\n  &:before {\n    content: \"b\";\n  }\n}\n.icon-basic-elaboration-bookmark-plus {\n  &:before {\n    content: \"c\";\n  }\n}\n.icon-basic-elaboration-bookmark-remove {\n  &:before {\n    content: \"d\";\n  }\n}\n.icon-basic-elaboration-briefcase-check {\n  &:before {\n    content: \"e\";\n  }\n}\n.icon-basic-elaboration-briefcase-download {\n  &:before {\n    content: \"f\";\n  }\n}\n.icon-basic-elaboration-briefcase-flagged {\n  &:before {\n    content: \"g\";\n  }\n}\n.icon-basic-elaboration-briefcase-minus {\n  &:before {\n    content: \"h\";\n  }\n}\n.icon-basic-elaboration-briefcase-plus {\n  &:before {\n    content: \"i\";\n  }\n}\n.icon-basic-elaboration-briefcase-refresh {\n  &:before {\n    content: \"j\";\n  }\n}\n.icon-basic-elaboration-briefcase-remove {\n  &:before {\n    content: \"k\";\n  }\n}\n.icon-basic-elaboration-briefcase-search {\n  &:before {\n    content: \"l\";\n  }\n}\n.icon-basic-elaboration-briefcase-star {\n  &:before {\n    content: \"m\";\n  }\n}\n.icon-basic-elaboration-briefcase-upload {\n  &:before {\n    content: \"n\";\n  }\n}\n.icon-basic-elaboration-browser-check {\n  &:before {\n    content: \"o\";\n  }\n}\n.icon-basic-elaboration-browser-download {\n  &:before {\n    content: \"p\";\n  }\n}\n.icon-basic-elaboration-browser-minus {\n  &:before {\n    content: \"q\";\n  }\n}\n.icon-basic-elaboration-browser-plus {\n  &:before {\n    content: \"r\";\n  }\n}\n.icon-basic-elaboration-browser-refresh {\n  &:before {\n    content: \"s\";\n  }\n}\n.icon-basic-elaboration-browser-remove {\n  &:before {\n    content: \"t\";\n  }\n}\n.icon-basic-elaboration-browser-search {\n  &:before {\n    content: \"u\";\n  }\n}\n.icon-basic-elaboration-browser-star {\n  &:before {\n    content: \"v\";\n  }\n}\n.icon-basic-elaboration-browser-upload {\n  &:before {\n    content: \"w\";\n  }\n}\n.icon-basic-elaboration-calendar-check {\n  &:before {\n    content: \"x\";\n  }\n}\n.icon-basic-elaboration-calendar-cloud {\n  &:before {\n    content: \"y\";\n  }\n}\n.icon-basic-elaboration-calendar-download {\n  &:before {\n    content: \"z\";\n  }\n}\n.icon-basic-elaboration-calendar-empty {\n  &:before {\n    content: \"A\";\n  }\n}\n.icon-basic-elaboration-calendar-flagged {\n  &:before {\n    content: \"B\";\n  }\n}\n.icon-basic-elaboration-calendar-heart {\n  &:before {\n    content: \"C\";\n  }\n}\n.icon-basic-elaboration-calendar-minus {\n  &:before {\n    content: \"D\";\n  }\n}\n.icon-basic-elaboration-calendar-next {\n  &:before {\n    content: \"E\";\n  }\n}\n.icon-basic-elaboration-calendar-noaccess {\n  &:before {\n    content: \"F\";\n  }\n}\n.icon-basic-elaboration-calendar-pencil {\n  &:before {\n    content: \"G\";\n  }\n}\n.icon-basic-elaboration-calendar-plus {\n  &:before {\n    content: \"H\";\n  }\n}\n.icon-basic-elaboration-calendar-previous {\n  &:before {\n    content: \"I\";\n  }\n}\n.icon-basic-elaboration-calendar-refresh {\n  &:before {\n    content: \"J\";\n  }\n}\n.icon-basic-elaboration-calendar-remove {\n  &:before {\n    content: \"K\";\n  }\n}\n.icon-basic-elaboration-calendar-search {\n  &:before {\n    content: \"L\";\n  }\n}\n.icon-basic-elaboration-calendar-star {\n  &:before {\n    content: \"M\";\n  }\n}\n.icon-basic-elaboration-calendar-upload {\n  &:before {\n    content: \"N\";\n  }\n}\n.icon-basic-elaboration-cloud-check {\n  &:before {\n    content: \"O\";\n  }\n}\n.icon-basic-elaboration-cloud-download {\n  &:before {\n    content: \"P\";\n  }\n}\n.icon-basic-elaboration-cloud-minus {\n  &:before {\n    content: \"Q\";\n  }\n}\n.icon-basic-elaboration-cloud-noaccess {\n  &:before {\n    content: \"R\";\n  }\n}\n.icon-basic-elaboration-cloud-plus {\n  &:before {\n    content: \"S\";\n  }\n}\n.icon-basic-elaboration-cloud-refresh {\n  &:before {\n    content: \"T\";\n  }\n}\n.icon-basic-elaboration-cloud-remove {\n  &:before {\n    content: \"U\";\n  }\n}\n.icon-basic-elaboration-cloud-search {\n  &:before {\n    content: \"V\";\n  }\n}\n.icon-basic-elaboration-cloud-upload {\n  &:before {\n    content: \"W\";\n  }\n}\n.icon-basic-elaboration-document-check {\n  &:before {\n    content: \"X\";\n  }\n}\n.icon-basic-elaboration-document-cloud {\n  &:before {\n    content: \"Y\";\n  }\n}\n.icon-basic-elaboration-document-download {\n  &:before {\n    content: \"Z\";\n  }\n}\n.icon-basic-elaboration-document-flagged {\n  &:before {\n    content: \"0\";\n  }\n}\n.icon-basic-elaboration-document-graph {\n  &:before {\n    content: \"1\";\n  }\n}\n.icon-basic-elaboration-document-heart {\n  &:before {\n    content: \"2\";\n  }\n}\n.icon-basic-elaboration-document-minus {\n  &:before {\n    content: \"3\";\n  }\n}\n.icon-basic-elaboration-document-next {\n  &:before {\n    content: \"4\";\n  }\n}\n.icon-basic-elaboration-document-noaccess {\n  &:before {\n    content: \"5\";\n  }\n}\n.icon-basic-elaboration-document-note {\n  &:before {\n    content: \"6\";\n  }\n}\n.icon-basic-elaboration-document-pencil {\n  &:before {\n    content: \"7\";\n  }\n}\n.icon-basic-elaboration-document-picture {\n  &:before {\n    content: \"8\";\n  }\n}\n.icon-basic-elaboration-document-plus {\n  &:before {\n    content: \"9\";\n  }\n}\n.icon-basic-elaboration-document-previous {\n  &:before {\n    content: \"!\";\n  }\n}\n.icon-basic-elaboration-document-refresh {\n  &:before {\n    content: \"\\\"\";\n  }\n}\n.icon-basic-elaboration-document-remove {\n  &:before {\n    content: \"#\";\n  }\n}\n.icon-basic-elaboration-document-search {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-basic-elaboration-document-star {\n  &:before {\n    content: \"%\";\n  }\n}\n.icon-basic-elaboration-document-upload {\n  &:before {\n    content: \"&\";\n  }\n}\n.icon-basic-elaboration-folder-check {\n  &:before {\n    content: \"'\";\n  }\n}\n.icon-basic-elaboration-folder-cloud {\n  &:before {\n    content: \"(\";\n  }\n}\n.icon-basic-elaboration-folder-document {\n  &:before {\n    content: \")\";\n  }\n}\n.icon-basic-elaboration-folder-download {\n  &:before {\n    content: \"*\";\n  }\n}\n.icon-basic-elaboration-folder-flagged {\n  &:before {\n    content: \"+\";\n  }\n}\n.icon-basic-elaboration-folder-graph {\n  &:before {\n    content: \",\";\n  }\n}\n.icon-basic-elaboration-folder-heart {\n  &:before {\n    content: \"-\";\n  }\n}\n.icon-basic-elaboration-folder-minus {\n  &:before {\n    content: \".\";\n  }\n}\n.icon-basic-elaboration-folder-next {\n  &:before {\n    content: \"/\";\n  }\n}\n.icon-basic-elaboration-folder-noaccess {\n  &:before {\n    content: \":\";\n  }\n}\n.icon-basic-elaboration-folder-note {\n  &:before {\n    \";\n    content: \";\n  }\n}\n.icon-basic-elaboration-folder-pencil {\n  &:before {\n    content: \"<\";\n  }\n}\n.icon-basic-elaboration-folder-picture {\n  &:before {\n    content: \"=\";\n  }\n}\n.icon-basic-elaboration-folder-plus {\n  &:before {\n    content: \">\";\n  }\n}\n.icon-basic-elaboration-folder-previous {\n  &:before {\n    content: \"?\";\n  }\n}\n.icon-basic-elaboration-folder-refresh {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-basic-elaboration-folder-remove {\n  &:before {\n    content: \"[\";\n  }\n}\n.icon-basic-elaboration-folder-search {\n  &:before {\n    content: \"]\";\n  }\n}\n.icon-basic-elaboration-folder-star {\n  &:before {\n    content: \"^\";\n  }\n}\n.icon-basic-elaboration-folder-upload {\n  &:before {\n    content: \"_\";\n  }\n}\n.icon-basic-elaboration-mail-check {\n  &:before {\n    content: \"`\";\n  }\n}\n.icon-basic-elaboration-mail-cloud {\n  &:before {\n    content: \"{\";\n  }\n}\n.icon-basic-elaboration-mail-document {\n  &:before {\n    content: \"|\";\n  }\n}\n.icon-basic-elaboration-mail-download {\n  &:before {\n    content: \";\n  }\n}\n.icon-basic-elaboration-mail-flagged {\n  &:before {\n    content: \"~\";\n  }\n}\n.icon-basic-elaboration-mail-heart {\n  &:before {\n    content: \"\\\\\";\n  }\n}\n.icon-basic-elaboration-mail-next {\n  &:before {\n    content: \"\\e000\";\n  }\n}\n.icon-basic-elaboration-mail-noaccess {\n  &:before {\n    content: \"\\e001\";\n  }\n}\n.icon-basic-elaboration-mail-note {\n  &:before {\n    content: \"\\e002\";\n  }\n}\n.icon-basic-elaboration-mail-pencil {\n  &:before {\n    content: \"\\e003\";\n  }\n}\n.icon-basic-elaboration-mail-picture {\n  &:before {\n    content: \"\\e004\";\n  }\n}\n.icon-basic-elaboration-mail-previous {\n  &:before {\n    content: \"\\e005\";\n  }\n}\n.icon-basic-elaboration-mail-refresh {\n  &:before {\n    content: \"\\e006\";\n  }\n}\n.icon-basic-elaboration-mail-remove {\n  &:before {\n    content: \"\\e007\";\n  }\n}\n.icon-basic-elaboration-mail-search {\n  &:before {\n    content: \"\\e008\";\n  }\n}\n.icon-basic-elaboration-mail-star {\n  &:before {\n    content: \"\\e009\";\n  }\n}\n.icon-basic-elaboration-mail-upload {\n  &:before {\n    content: \"\\e00a\";\n  }\n}\n.icon-basic-elaboration-message-check {\n  &:before {\n    content: \"\\e00b\";\n  }\n}\n.icon-basic-elaboration-message-dots {\n  &:before {\n    content: \"\\e00c\";\n  }\n}\n.icon-basic-elaboration-message-happy {\n  &:before {\n    content: \"\\e00d\";\n  }\n}\n.icon-basic-elaboration-message-heart {\n  &:before {\n    content: \"\\e00e\";\n  }\n}\n.icon-basic-elaboration-message-minus {\n  &:before {\n    content: \"\\e00f\";\n  }\n}\n.icon-basic-elaboration-message-note {\n  &:before {\n    content: \"\\e010\";\n  }\n}\n.icon-basic-elaboration-message-plus {\n  &:before {\n    content: \"\\e011\";\n  }\n}\n.icon-basic-elaboration-message-refresh {\n  &:before {\n    content: \"\\e012\";\n  }\n}\n.icon-basic-elaboration-message-remove {\n  &:before {\n    content: \"\\e013\";\n  }\n}\n.icon-basic-elaboration-message-sad {\n  &:before {\n    content: \"\\e014\";\n  }\n}\n.icon-basic-elaboration-smartphone-cloud {\n  &:before {\n    content: \"\\e015\";\n  }\n}\n.icon-basic-elaboration-smartphone-heart {\n  &:before {\n    content: \"\\e016\";\n  }\n}\n.icon-basic-elaboration-smartphone-noaccess {\n  &:before {\n    content: \"\\e017\";\n  }\n}\n.icon-basic-elaboration-smartphone-note {\n  &:before {\n    content: \"\\e018\";\n  }\n}\n.icon-basic-elaboration-smartphone-pencil {\n  &:before {\n    content: \"\\e019\";\n  }\n}\n.icon-basic-elaboration-smartphone-picture {\n  &:before {\n    content: \"\\e01a\";\n  }\n}\n.icon-basic-elaboration-smartphone-refresh {\n  &:before {\n    content: \"\\e01b\";\n  }\n}\n.icon-basic-elaboration-smartphone-search {\n  &:before {\n    content: \"\\e01c\";\n  }\n}\n.icon-basic-elaboration-tablet-cloud {\n  &:before {\n    content: \"\\e01d\";\n  }\n}\n.icon-basic-elaboration-tablet-heart {\n  &:before {\n    content: \"\\e01e\";\n  }\n}\n.icon-basic-elaboration-tablet-noaccess {\n  &:before {\n    content: \"\\e01f\";\n  }\n}\n.icon-basic-elaboration-tablet-note {\n  &:before {\n    content: \"\\e020\";\n  }\n}\n.icon-basic-elaboration-tablet-pencil {\n  &:before {\n    content: \"\\e021\";\n  }\n}\n.icon-basic-elaboration-tablet-picture {\n  &:before {\n    content: \"\\e022\";\n  }\n}\n.icon-basic-elaboration-tablet-refresh {\n  &:before {\n    content: \"\\e023\";\n  }\n}\n.icon-basic-elaboration-tablet-search {\n  &:before {\n    content: \"\\e024\";\n  }\n}\n.icon-basic-elaboration-todolist-2 {\n  &:before {\n    content: \"\\e025\";\n  }\n}\n.icon-basic-elaboration-todolist-check {\n  &:before {\n    content: \"\\e026\";\n  }\n}\n.icon-basic-elaboration-todolist-cloud {\n  &:before {\n    content: \"\\e027\";\n  }\n}\n.icon-basic-elaboration-todolist-download {\n  &:before {\n    content: \"\\e028\";\n  }\n}\n.icon-basic-elaboration-todolist-flagged {\n  &:before {\n    content: \"\\e029\";\n  }\n}\n.icon-basic-elaboration-todolist-minus {\n  &:before {\n    content: \"\\e02a\";\n  }\n}\n.icon-basic-elaboration-todolist-noaccess {\n  &:before {\n    content: \"\\e02b\";\n  }\n}\n.icon-basic-elaboration-todolist-pencil {\n  &:before {\n    content: \"\\e02c\";\n  }\n}\n.icon-basic-elaboration-todolist-plus {\n  &:before {\n    content: \"\\e02d\";\n  }\n}\n.icon-basic-elaboration-todolist-refresh {\n  &:before {\n    content: \"\\e02e\";\n  }\n}\n.icon-basic-elaboration-todolist-remove {\n  &:before {\n    content: \"\\e02f\";\n  }\n}\n.icon-basic-elaboration-todolist-search {\n  &:before {\n    content: \"\\e030\";\n  }\n}\n.icon-basic-elaboration-todolist-star {\n  &:before {\n    content: \"\\e031\";\n  }\n}\n.icon-basic-elaboration-todolist-upload {\n  &:before {\n    content: \"\\e032\";\n  }\n}\n.icon-ecommerce-bag {\n  &:before {\n    content: \"a\";\n  }\n}\n.icon-ecommerce-bag-check {\n  &:before {\n    content: \"b\";\n  }\n}\n.icon-ecommerce-bag-cloud {\n  &:before {\n    content: \"c\";\n  }\n}\n.icon-ecommerce-bag-download {\n  &:before {\n    content: \"d\";\n  }\n}\n.icon-ecommerce-bag-minus {\n  &:before {\n    content: \"e\";\n  }\n}\n.icon-ecommerce-bag-plus {\n  &:before {\n    content: \"f\";\n  }\n}\n.icon-ecommerce-bag-refresh {\n  &:before {\n    content: \"g\";\n  }\n}\n.icon-ecommerce-bag-remove {\n  &:before {\n    content: \"h\";\n  }\n}\n.icon-ecommerce-bag-search {\n  &:before {\n    content: \"i\";\n  }\n}\n.icon-ecommerce-bag-upload {\n  &:before {\n    content: \"j\";\n  }\n}\n.icon-ecommerce-banknote {\n  &:before {\n    content: \"k\";\n  }\n}\n.icon-ecommerce-banknotes {\n  &:before {\n    content: \"l\";\n  }\n}\n.icon-ecommerce-basket {\n  &:before {\n    content: \"m\";\n  }\n}\n.icon-ecommerce-basket-check {\n  &:before {\n    content: \"n\";\n  }\n}\n.icon-ecommerce-basket-cloud {\n  &:before {\n    content: \"o\";\n  }\n}\n.icon-ecommerce-basket-download {\n  &:before {\n    content: \"p\";\n  }\n}\n.icon-ecommerce-basket-minus {\n  &:before {\n    content: \"q\";\n  }\n}\n.icon-ecommerce-basket-plus {\n  &:before {\n    content: \"r\";\n  }\n}\n.icon-ecommerce-basket-refresh {\n  &:before {\n    content: \"s\";\n  }\n}\n.icon-ecommerce-basket-remove {\n  &:before {\n    content: \"t\";\n  }\n}\n.icon-ecommerce-basket-search {\n  &:before {\n    content: \"u\";\n  }\n}\n.icon-ecommerce-basket-upload {\n  &:before {\n    content: \"v\";\n  }\n}\n.icon-ecommerce-bath {\n  &:before {\n    content: \"w\";\n  }\n}\n.icon-ecommerce-cart {\n  &:before {\n    content: \"x\";\n  }\n}\n.icon-ecommerce-cart-check {\n  &:before {\n    content: \"y\";\n  }\n}\n.icon-ecommerce-cart-cloud {\n  &:before {\n    content: \"z\";\n  }\n}\n.icon-ecommerce-cart-content {\n  &:before {\n    content: \"A\";\n  }\n}\n.icon-ecommerce-cart-download {\n  &:before {\n    content: \"B\";\n  }\n}\n.icon-ecommerce-cart-minus {\n  &:before {\n    content: \"C\";\n  }\n}\n.icon-ecommerce-cart-plus {\n  &:before {\n    content: \"D\";\n  }\n}\n.icon-ecommerce-cart-refresh {\n  &:before {\n    content: \"E\";\n  }\n}\n.icon-ecommerce-cart-remove {\n  &:before {\n    content: \"F\";\n  }\n}\n.icon-ecommerce-cart-search {\n  &:before {\n    content: \"G\";\n  }\n}\n.icon-ecommerce-cart-upload {\n  &:before {\n    content: \"H\";\n  }\n}\n.icon-ecommerce-cent {\n  &:before {\n    content: \"I\";\n  }\n}\n.icon-ecommerce-colon {\n  &:before {\n    content: \"J\";\n  }\n}\n.icon-ecommerce-creditcard {\n  &:before {\n    content: \"K\";\n  }\n}\n.icon-ecommerce-diamond {\n  &:before {\n    content: \"L\";\n  }\n}\n.icon-ecommerce-dollar {\n  &:before {\n    content: \"M\";\n  }\n}\n.icon-ecommerce-euro {\n  &:before {\n    content: \"N\";\n  }\n}\n.icon-ecommerce-franc {\n  &:before {\n    content: \"O\";\n  }\n}\n.icon-ecommerce-gift {\n  &:before {\n    content: \"P\";\n  }\n}\n.icon-ecommerce-graph1 {\n  &:before {\n    content: \"Q\";\n  }\n}\n.icon-ecommerce-graph2 {\n  &:before {\n    content: \"R\";\n  }\n}\n.icon-ecommerce-graph3 {\n  &:before {\n    content: \"S\";\n  }\n}\n.icon-ecommerce-graph-decrease {\n  &:before {\n    content: \"T\";\n  }\n}\n.icon-ecommerce-graph-increase {\n  &:before {\n    content: \"U\";\n  }\n}\n.icon-ecommerce-guarani {\n  &:before {\n    content: \"V\";\n  }\n}\n.icon-ecommerce-kips {\n  &:before {\n    content: \"W\";\n  }\n}\n.icon-ecommerce-lira {\n  &:before {\n    content: \"X\";\n  }\n}\n.icon-ecommerce-megaphone {\n  &:before {\n    content: \"Y\";\n  }\n}\n.icon-ecommerce-money {\n  &:before {\n    content: \"Z\";\n  }\n}\n.icon-ecommerce-naira {\n  &:before {\n    content: \"0\";\n  }\n}\n.icon-ecommerce-pesos {\n  &:before {\n    content: \"1\";\n  }\n}\n.icon-ecommerce-pound {\n  &:before {\n    content: \"2\";\n  }\n}\n.icon-ecommerce-receipt {\n  &:before {\n    content: \"3\";\n  }\n}\n.icon-ecommerce-receipt-bath {\n  &:before {\n    content: \"4\";\n  }\n}\n.icon-ecommerce-receipt-cent {\n  &:before {\n    content: \"5\";\n  }\n}\n.icon-ecommerce-receipt-dollar {\n  &:before {\n    content: \"6\";\n  }\n}\n.icon-ecommerce-receipt-euro {\n  &:before {\n    content: \"7\";\n  }\n}\n.icon-ecommerce-receipt-franc {\n  &:before {\n    content: \"8\";\n  }\n}\n.icon-ecommerce-receipt-guarani {\n  &:before {\n    content: \"9\";\n  }\n}\n.icon-ecommerce-receipt-kips {\n  &:before {\n    content: \"!\";\n  }\n}\n.icon-ecommerce-receipt-lira {\n  &:before {\n    content: \"\\\"\";\n  }\n}\n.icon-ecommerce-receipt-naira {\n  &:before {\n    content: \"#\";\n  }\n}\n.icon-ecommerce-receipt-pesos {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-ecommerce-receipt-pound {\n  &:before {\n    content: \"%\";\n  }\n}\n.icon-ecommerce-receipt-rublo {\n  &:before {\n    content: \"&\";\n  }\n}\n.icon-ecommerce-receipt-rupee {\n  &:before {\n    content: \"'\";\n  }\n}\n.icon-ecommerce-receipt-tugrik {\n  &:before {\n    content: \"(\";\n  }\n}\n.icon-ecommerce-receipt-won {\n  &:before {\n    content: \")\";\n  }\n}\n.icon-ecommerce-receipt-yen {\n  &:before {\n    content: \"*\";\n  }\n}\n.icon-ecommerce-receipt-yen2 {\n  &:before {\n    content: \"+\";\n  }\n}\n.icon-ecommerce-recept-colon {\n  &:before {\n    content: \",\";\n  }\n}\n.icon-ecommerce-rublo {\n  &:before {\n    content: \"-\";\n  }\n}\n.icon-ecommerce-rupee {\n  &:before {\n    content: \".\";\n  }\n}\n.icon-ecommerce-safe {\n  &:before {\n    content: \"/\";\n  }\n}\n.icon-ecommerce-sale {\n  &:before {\n    content: \":\";\n  }\n}\n.icon-ecommerce-sales {\n  &:before {\n    \";\n    content: \";\n  }\n}\n.icon-ecommerce-ticket {\n  &:before {\n    content: \"<\";\n  }\n}\n.icon-ecommerce-tugriks {\n  &:before {\n    content: \"=\";\n  }\n}\n.icon-ecommerce-wallet {\n  &:before {\n    content: \">\";\n  }\n}\n.icon-ecommerce-won {\n  &:before {\n    content: \"?\";\n  }\n}\n.icon-ecommerce-yen {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-ecommerce-yen2 {\n  &:before {\n    content: \"[\";\n  }\n}\n.icon-music-beginning-button {\n  &:before {\n    content: \"a\";\n  }\n}\n.icon-music-bell {\n  &:before {\n    content: \"b\";\n  }\n}\n.icon-music-cd {\n  &:before {\n    content: \"c\";\n  }\n}\n.icon-music-diapason {\n  &:before {\n    content: \"d\";\n  }\n}\n.icon-music-eject-button {\n  &:before {\n    content: \"e\";\n  }\n}\n.icon-music-end-button {\n  &:before {\n    content: \"f\";\n  }\n}\n.icon-music-fastforward-button {\n  &:before {\n    content: \"g\";\n  }\n}\n.icon-music-headphones {\n  &:before {\n    content: \"h\";\n  }\n}\n.icon-music-ipod {\n  &:before {\n    content: \"i\";\n  }\n}\n.icon-music-loudspeaker {\n  &:before {\n    content: \"j\";\n  }\n}\n.icon-music-microphone {\n  &:before {\n    content: \"k\";\n  }\n}\n.icon-music-microphone-old {\n  &:before {\n    content: \"l\";\n  }\n}\n.icon-music-mixer {\n  &:before {\n    content: \"m\";\n  }\n}\n.icon-music-mute {\n  &:before {\n    content: \"n\";\n  }\n}\n.icon-music-note-multiple {\n  &:before {\n    content: \"o\";\n  }\n}\n.icon-music-note-single {\n  &:before {\n    content: \"p\";\n  }\n}\n.icon-music-pause-button {\n  &:before {\n    content: \"q\";\n  }\n}\n.icon-music-play-button {\n  &:before {\n    content: \"r\";\n  }\n}\n.icon-music-playlist {\n  &:before {\n    content: \"s\";\n  }\n}\n.icon-music-radio-ghettoblaster {\n  &:before {\n    content: \"t\";\n  }\n}\n.icon-music-radio-portable {\n  &:before {\n    content: \"u\";\n  }\n}\n.icon-music-record {\n  &:before {\n    content: \"v\";\n  }\n}\n.icon-music-recordplayer {\n  &:before {\n    content: \"w\";\n  }\n}\n.icon-music-repeat-button {\n  &:before {\n    content: \"x\";\n  }\n}\n.icon-music-rewind-button {\n  &:before {\n    content: \"y\";\n  }\n}\n.icon-music-shuffle-button {\n  &:before {\n    content: \"z\";\n  }\n}\n.icon-music-stop-button {\n  &:before {\n    content: \"A\";\n  }\n}\n.icon-music-tape {\n  &:before {\n    content: \"B\";\n  }\n}\n.icon-music-volume-down {\n  &:before {\n    content: \"C\";\n  }\n}\n.icon-music-volume-up {\n  &:before {\n    content: \"D\";\n  }\n}\n.icon-software-add-vectorpoint {\n  &:before {\n    content: \"a\";\n  }\n}\n.icon-software-box-oval {\n  &:before {\n    content: \"b\";\n  }\n}\n.icon-software-box-polygon {\n  &:before {\n    content: \"c\";\n  }\n}\n.icon-software-box-rectangle {\n  &:before {\n    content: \"d\";\n  }\n}\n.icon-software-box-roundedrectangle {\n  &:before {\n    content: \"e\";\n  }\n}\n.icon-software-character {\n  &:before {\n    content: \"f\";\n  }\n}\n.icon-software-crop {\n  &:before {\n    content: \"g\";\n  }\n}\n.icon-software-eyedropper {\n  &:before {\n    content: \"h\";\n  }\n}\n.icon-software-font-allcaps {\n  &:before {\n    content: \"i\";\n  }\n}\n.icon-software-font-baseline-shift {\n  &:before {\n    content: \"j\";\n  }\n}\n.icon-software-font-horizontal-scale {\n  &:before {\n    content: \"k\";\n  }\n}\n.icon-software-font-kerning {\n  &:before {\n    content: \"l\";\n  }\n}\n.icon-software-font-leading {\n  &:before {\n    content: \"m\";\n  }\n}\n.icon-software-font-size {\n  &:before {\n    content: \"n\";\n  }\n}\n.icon-software-font-smallcapital {\n  &:before {\n    content: \"o\";\n  }\n}\n.icon-software-font-smallcaps {\n  &:before {\n    content: \"p\";\n  }\n}\n.icon-software-font-strikethrough {\n  &:before {\n    content: \"q\";\n  }\n}\n.icon-software-font-tracking {\n  &:before {\n    content: \"r\";\n  }\n}\n.icon-software-font-underline {\n  &:before {\n    content: \"s\";\n  }\n}\n.icon-software-font-vertical-scale {\n  &:before {\n    content: \"t\";\n  }\n}\n.icon-software-horizontal-align-center {\n  &:before {\n    content: \"u\";\n  }\n}\n.icon-software-horizontal-align-left {\n  &:before {\n    content: \"v\";\n  }\n}\n.icon-software-horizontal-align-right {\n  &:before {\n    content: \"w\";\n  }\n}\n.icon-software-horizontal-distribute-center {\n  &:before {\n    content: \"x\";\n  }\n}\n.icon-software-horizontal-distribute-left {\n  &:before {\n    content: \"y\";\n  }\n}\n.icon-software-horizontal-distribute-right {\n  &:before {\n    content: \"z\";\n  }\n}\n.icon-software-indent-firstline {\n  &:before {\n    content: \"A\";\n  }\n}\n.icon-software-indent-left {\n  &:before {\n    content: \"B\";\n  }\n}\n.icon-software-indent-right {\n  &:before {\n    content: \"C\";\n  }\n}\n.icon-software-lasso {\n  &:before {\n    content: \"D\";\n  }\n}\n.icon-software-layers1 {\n  &:before {\n    content: \"E\";\n  }\n}\n.icon-software-layers2 {\n  &:before {\n    content: \"F\";\n  }\n}\n.icon-software-layout {\n  &:before {\n    content: \"G\";\n  }\n}\n.icon-software-layout-2columns {\n  &:before {\n    content: \"H\";\n  }\n}\n.icon-software-layout-3columns {\n  &:before {\n    content: \"I\";\n  }\n}\n.icon-software-layout-4boxes {\n  &:before {\n    content: \"J\";\n  }\n}\n.icon-software-layout-4columns {\n  &:before {\n    content: \"K\";\n  }\n}\n.icon-software-layout-4lines {\n  &:before {\n    content: \"L\";\n  }\n}\n.icon-software-layout-8boxes {\n  &:before {\n    content: \"M\";\n  }\n}\n.icon-software-layout-header {\n  &:before {\n    content: \"N\";\n  }\n}\n.icon-software-layout-header-2columns {\n  &:before {\n    content: \"O\";\n  }\n}\n.icon-software-layout-header-3columns {\n  &:before {\n    content: \"P\";\n  }\n}\n.icon-software-layout-header-4boxes {\n  &:before {\n    content: \"Q\";\n  }\n}\n.icon-software-layout-header-4columns {\n  &:before {\n    content: \"R\";\n  }\n}\n.icon-software-layout-header-complex {\n  &:before {\n    content: \"S\";\n  }\n}\n.icon-software-layout-header-complex2 {\n  &:before {\n    content: \"T\";\n  }\n}\n.icon-software-layout-header-complex3 {\n  &:before {\n    content: \"U\";\n  }\n}\n.icon-software-layout-header-complex4 {\n  &:before {\n    content: \"V\";\n  }\n}\n.icon-software-layout-header-sideleft {\n  &:before {\n    content: \"W\";\n  }\n}\n.icon-software-layout-header-sideright {\n  &:before {\n    content: \"X\";\n  }\n}\n.icon-software-layout-sidebar-left {\n  &:before {\n    content: \"Y\";\n  }\n}\n.icon-software-layout-sidebar-right {\n  &:before {\n    content: \"Z\";\n  }\n}\n.icon-software-magnete {\n  &:before {\n    content: \"0\";\n  }\n}\n.icon-software-pages {\n  &:before {\n    content: \"1\";\n  }\n}\n.icon-software-paintbrush {\n  &:before {\n    content: \"2\";\n  }\n}\n.icon-software-paintbucket {\n  &:before {\n    content: \"3\";\n  }\n}\n.icon-software-paintroller {\n  &:before {\n    content: \"4\";\n  }\n}\n.icon-software-paragraph {\n  &:before {\n    content: \"5\";\n  }\n}\n.icon-software-paragraph-align-left {\n  &:before {\n    content: \"6\";\n  }\n}\n.icon-software-paragraph-align-right {\n  &:before {\n    content: \"7\";\n  }\n}\n.icon-software-paragraph-center {\n  &:before {\n    content: \"8\";\n  }\n}\n.icon-software-paragraph-justify-all {\n  &:before {\n    content: \"9\";\n  }\n}\n.icon-software-paragraph-justify-center {\n  &:before {\n    content: \"!\";\n  }\n}\n.icon-software-paragraph-justify-left {\n  &:before {\n    content: \"\\\"\";\n  }\n}\n.icon-software-paragraph-justify-right {\n  &:before {\n    content: \"#\";\n  }\n}\n.icon-software-paragraph-space-after {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-software-paragraph-space-before {\n  &:before {\n    content: \"%\";\n  }\n}\n.icon-software-pathfinder-exclude {\n  &:before {\n    content: \"&\";\n  }\n}\n.icon-software-pathfinder-intersect {\n  &:before {\n    content: \"'\";\n  }\n}\n.icon-software-pathfinder-subtract {\n  &:before {\n    content: \"(\";\n  }\n}\n.icon-software-pathfinder-unite {\n  &:before {\n    content: \")\";\n  }\n}\n.icon-software-pen {\n  &:before {\n    content: \"*\";\n  }\n}\n.icon-software-pen-add {\n  &:before {\n    content: \"+\";\n  }\n}\n.icon-software-pen-remove {\n  &:before {\n    content: \",\";\n  }\n}\n.icon-software-pencil {\n  &:before {\n    content: \"-\";\n  }\n}\n.icon-software-polygonallasso {\n  &:before {\n    content: \".\";\n  }\n}\n.icon-software-reflect-horizontal {\n  &:before {\n    content: \"/\";\n  }\n}\n.icon-software-reflect-vertical {\n  &:before {\n    content: \":\";\n  }\n}\n.icon-software-remove-vectorpoint {\n  &:before {\n    \";\n    content: \";\n  }\n}\n.icon-software-scale-expand {\n  &:before {\n    content: \"<\";\n  }\n}\n.icon-software-scale-reduce {\n  &:before {\n    content: \"=\";\n  }\n}\n.icon-software-selection-oval {\n  &:before {\n    content: \">\";\n  }\n}\n.icon-software-selection-polygon {\n  &:before {\n    content: \"?\";\n  }\n}\n.icon-software-selection-rectangle {\n  &:before {\n    content: \"$\";\n  }\n}\n.icon-software-selection-roundedrectangle {\n  &:before {\n    content: \"[\";\n  }\n}\n.icon-software-shape-oval {\n  &:before {\n    content: \"]\";\n  }\n}\n.icon-software-shape-polygon {\n  &:before {\n    content: \"^\";\n  }\n}\n.icon-software-shape-rectangle {\n  &:before {\n    content: \"_\";\n  }\n}\n.icon-software-shape-roundedrectangle {\n  &:before {\n    content: \"`\";\n  }\n}\n.icon-software-slice {\n  &:before {\n    content: \"{\";\n  }\n}\n.icon-software-transform-bezier {\n  &:before {\n    content: \"|\";\n  }\n}\n.icon-software-vector-box {\n  &:before {\n    content: \";\n  }\n}\n.icon-software-vector-composite {\n  &:before {\n    content: \"~\";\n  }\n}\n.icon-software-vector-line {\n  &:before {\n    content: \"\\\\\";\n  }\n}\n.icon-software-vertical-align-bottom {\n  &:before {\n    content: \"\\e000\";\n  }\n}\n.icon-software-vertical-align-center {\n  &:before {\n    content: \"\\e001\";\n  }\n}\n.icon-software-vertical-align-top {\n  &:before {\n    content: \"\\e002\";\n  }\n}\n.icon-software-vertical-distribute-bottom {\n  &:before {\n    content: \"\\e003\";\n  }\n}\n.icon-software-vertical-distribute-center {\n  &:before {\n    content: \"\\e004\";\n  }\n}\n.icon-software-vertical-distribute-top {\n  &:before {\n    content: \"\\e005\";\n  }\n}\n.icon-weather-aquarius {\n  &:before {\n    content: \"\\e000\";\n  }\n}\n.icon-weather-aries {\n  &:before {\n    content: \"\\e001\";\n  }\n}\n.icon-weather-cancer {\n  &:before {\n    content: \"\\e002\";\n  }\n}\n.icon-weather-capricorn {\n  &:before {\n    content: \"\\e003\";\n  }\n}\n.icon-weather-cloud {\n  &:before {\n    content: \"\\e004\";\n  }\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/material-design-iconic-font/css/material-design-iconic-font.css",
    "content": "/*!\n *  Material Design Iconic Font by Sergey Kupletsky (@zavoloklom) - http://zavoloklom.github.io/material-design-iconic-font/\n *  License - http://zavoloklom.github.io/material-design-iconic-font/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n@font-face {\n  font-family: 'Material-Design-Iconic-Font';\n  src: url('..//fonts/Material-Design-Iconic-Font.woff2?v=2.2.0') format('woff2'), url('..//fonts/Material-Design-Iconic-Font.woff?v=2.2.0') format('woff'), url('..//fonts/Material-Design-Iconic-Font.ttf?v=2.2.0') format('truetype');\n  font-weight: normal;\n  font-style: normal;\n}\n.zmdi {\n  display: inline-block;\n  font: normal normal normal 14px/1 'Material-Design-Iconic-Font';\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.zmdi-hc-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.zmdi-hc-2x {\n  font-size: 2em;\n}\n.zmdi-hc-3x {\n  font-size: 3em;\n}\n.zmdi-hc-4x {\n  font-size: 4em;\n}\n.zmdi-hc-5x {\n  font-size: 5em;\n}\n.zmdi-hc-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.zmdi-hc-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.zmdi-hc-ul > li {\n  position: relative;\n}\n.zmdi-hc-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.zmdi-hc-li.zmdi-hc-lg {\n  left: -1.85714286em;\n}\n.zmdi-hc-border {\n  padding: .1em .25em;\n  border: solid 0.1em #9e9e9e;\n  border-radius: 2px;\n}\n.zmdi-hc-border-circle {\n  padding: .1em .25em;\n  border: solid 0.1em #9e9e9e;\n  border-radius: 50%;\n}\n.zmdi.pull-left {\n  float: left;\n  margin-right: .15em;\n}\n.zmdi.pull-right {\n  float: right;\n  margin-left: .15em;\n}\n.zmdi-hc-spin {\n  -webkit-animation: zmdi-spin 1.5s infinite linear;\n          animation: zmdi-spin 1.5s infinite linear;\n}\n.zmdi-hc-spin-reverse {\n  -webkit-animation: zmdi-spin-reverse 1.5s infinite linear;\n          animation: zmdi-spin-reverse 1.5s infinite linear;\n}\n@-webkit-keyframes zmdi-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n@keyframes zmdi-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n@-webkit-keyframes zmdi-spin-reverse {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(-359deg);\n            transform: rotate(-359deg);\n  }\n}\n@keyframes zmdi-spin-reverse {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(-359deg);\n            transform: rotate(-359deg);\n  }\n}\n.zmdi-hc-rotate-90 {\n  -webkit-transform: rotate(90deg);\n      -ms-transform: rotate(90deg);\n          transform: rotate(90deg);\n}\n.zmdi-hc-rotate-180 {\n  -webkit-transform: rotate(180deg);\n      -ms-transform: rotate(180deg);\n          transform: rotate(180deg);\n}\n.zmdi-hc-rotate-270 {\n  -webkit-transform: rotate(270deg);\n      -ms-transform: rotate(270deg);\n          transform: rotate(270deg);\n}\n.zmdi-hc-flip-horizontal {\n  -webkit-transform: scale(-1, 1);\n      -ms-transform: scale(-1, 1);\n          transform: scale(-1, 1);\n}\n.zmdi-hc-flip-vertical {\n  -webkit-transform: scale(1, -1);\n      -ms-transform: scale(1, -1);\n          transform: scale(1, -1);\n}\n.zmdi-hc-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.zmdi-hc-stack-1x,\n.zmdi-hc-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.zmdi-hc-stack-1x {\n  line-height: inherit;\n}\n.zmdi-hc-stack-2x {\n  font-size: 2em;\n}\n.zmdi-hc-inverse {\n  color: #ffffff;\n}\n/* Material Design Iconic Font uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.zmdi-3d-rotation:before {\n  content: '\\f101';\n}\n.zmdi-airplane-off:before {\n  content: '\\f102';\n}\n.zmdi-airplane:before {\n  content: '\\f103';\n}\n.zmdi-album:before {\n  content: '\\f104';\n}\n.zmdi-archive:before {\n  content: '\\f105';\n}\n.zmdi-assignment-account:before {\n  content: '\\f106';\n}\n.zmdi-assignment-alert:before {\n  content: '\\f107';\n}\n.zmdi-assignment-check:before {\n  content: '\\f108';\n}\n.zmdi-assignment-o:before {\n  content: '\\f109';\n}\n.zmdi-assignment-return:before {\n  content: '\\f10a';\n}\n.zmdi-assignment-returned:before {\n  content: '\\f10b';\n}\n.zmdi-assignment:before {\n  content: '\\f10c';\n}\n.zmdi-attachment-alt:before {\n  content: '\\f10d';\n}\n.zmdi-attachment:before {\n  content: '\\f10e';\n}\n.zmdi-audio:before {\n  content: '\\f10f';\n}\n.zmdi-badge-check:before {\n  content: '\\f110';\n}\n.zmdi-balance-wallet:before {\n  content: '\\f111';\n}\n.zmdi-balance:before {\n  content: '\\f112';\n}\n.zmdi-battery-alert:before {\n  content: '\\f113';\n}\n.zmdi-battery-flash:before {\n  content: '\\f114';\n}\n.zmdi-battery-unknown:before {\n  content: '\\f115';\n}\n.zmdi-battery:before {\n  content: '\\f116';\n}\n.zmdi-bike:before {\n  content: '\\f117';\n}\n.zmdi-block-alt:before {\n  content: '\\f118';\n}\n.zmdi-block:before {\n  content: '\\f119';\n}\n.zmdi-boat:before {\n  content: '\\f11a';\n}\n.zmdi-book-image:before {\n  content: '\\f11b';\n}\n.zmdi-book:before {\n  content: '\\f11c';\n}\n.zmdi-bookmark-outline:before {\n  content: '\\f11d';\n}\n.zmdi-bookmark:before {\n  content: '\\f11e';\n}\n.zmdi-brush:before {\n  content: '\\f11f';\n}\n.zmdi-bug:before {\n  content: '\\f120';\n}\n.zmdi-bus:before {\n  content: '\\f121';\n}\n.zmdi-cake:before {\n  content: '\\f122';\n}\n.zmdi-car-taxi:before {\n  content: '\\f123';\n}\n.zmdi-car-wash:before {\n  content: '\\f124';\n}\n.zmdi-car:before {\n  content: '\\f125';\n}\n.zmdi-card-giftcard:before {\n  content: '\\f126';\n}\n.zmdi-card-membership:before {\n  content: '\\f127';\n}\n.zmdi-card-travel:before {\n  content: '\\f128';\n}\n.zmdi-card:before {\n  content: '\\f129';\n}\n.zmdi-case-check:before {\n  content: '\\f12a';\n}\n.zmdi-case-download:before {\n  content: '\\f12b';\n}\n.zmdi-case-play:before {\n  content: '\\f12c';\n}\n.zmdi-case:before {\n  content: '\\f12d';\n}\n.zmdi-cast-connected:before {\n  content: '\\f12e';\n}\n.zmdi-cast:before {\n  content: '\\f12f';\n}\n.zmdi-chart-donut:before {\n  content: '\\f130';\n}\n.zmdi-chart:before {\n  content: '\\f131';\n}\n.zmdi-city-alt:before {\n  content: '\\f132';\n}\n.zmdi-city:before {\n  content: '\\f133';\n}\n.zmdi-close-circle-o:before {\n  content: '\\f134';\n}\n.zmdi-close-circle:before {\n  content: '\\f135';\n}\n.zmdi-close:before {\n  content: '\\f136';\n}\n.zmdi-cocktail:before {\n  content: '\\f137';\n}\n.zmdi-code-setting:before {\n  content: '\\f138';\n}\n.zmdi-code-smartphone:before {\n  content: '\\f139';\n}\n.zmdi-code:before {\n  content: '\\f13a';\n}\n.zmdi-coffee:before {\n  content: '\\f13b';\n}\n.zmdi-collection-bookmark:before {\n  content: '\\f13c';\n}\n.zmdi-collection-case-play:before {\n  content: '\\f13d';\n}\n.zmdi-collection-folder-image:before {\n  content: '\\f13e';\n}\n.zmdi-collection-image-o:before {\n  content: '\\f13f';\n}\n.zmdi-collection-image:before {\n  content: '\\f140';\n}\n.zmdi-collection-item-1:before {\n  content: '\\f141';\n}\n.zmdi-collection-item-2:before {\n  content: '\\f142';\n}\n.zmdi-collection-item-3:before {\n  content: '\\f143';\n}\n.zmdi-collection-item-4:before {\n  content: '\\f144';\n}\n.zmdi-collection-item-5:before {\n  content: '\\f145';\n}\n.zmdi-collection-item-6:before {\n  content: '\\f146';\n}\n.zmdi-collection-item-7:before {\n  content: '\\f147';\n}\n.zmdi-collection-item-8:before {\n  content: '\\f148';\n}\n.zmdi-collection-item-9-plus:before {\n  content: '\\f149';\n}\n.zmdi-collection-item-9:before {\n  content: '\\f14a';\n}\n.zmdi-collection-item:before {\n  content: '\\f14b';\n}\n.zmdi-collection-music:before {\n  content: '\\f14c';\n}\n.zmdi-collection-pdf:before {\n  content: '\\f14d';\n}\n.zmdi-collection-plus:before {\n  content: '\\f14e';\n}\n.zmdi-collection-speaker:before {\n  content: '\\f14f';\n}\n.zmdi-collection-text:before {\n  content: '\\f150';\n}\n.zmdi-collection-video:before {\n  content: '\\f151';\n}\n.zmdi-compass:before {\n  content: '\\f152';\n}\n.zmdi-cutlery:before {\n  content: '\\f153';\n}\n.zmdi-delete:before {\n  content: '\\f154';\n}\n.zmdi-dialpad:before {\n  content: '\\f155';\n}\n.zmdi-dns:before {\n  content: '\\f156';\n}\n.zmdi-drink:before {\n  content: '\\f157';\n}\n.zmdi-edit:before {\n  content: '\\f158';\n}\n.zmdi-email-open:before {\n  content: '\\f159';\n}\n.zmdi-email:before {\n  content: '\\f15a';\n}\n.zmdi-eye-off:before {\n  content: '\\f15b';\n}\n.zmdi-eye:before {\n  content: '\\f15c';\n}\n.zmdi-eyedropper:before {\n  content: '\\f15d';\n}\n.zmdi-favorite-outline:before {\n  content: '\\f15e';\n}\n.zmdi-favorite:before {\n  content: '\\f15f';\n}\n.zmdi-filter-list:before {\n  content: '\\f160';\n}\n.zmdi-fire:before {\n  content: '\\f161';\n}\n.zmdi-flag:before {\n  content: '\\f162';\n}\n.zmdi-flare:before {\n  content: '\\f163';\n}\n.zmdi-flash-auto:before {\n  content: '\\f164';\n}\n.zmdi-flash-off:before {\n  content: '\\f165';\n}\n.zmdi-flash:before {\n  content: '\\f166';\n}\n.zmdi-flip:before {\n  content: '\\f167';\n}\n.zmdi-flower-alt:before {\n  content: '\\f168';\n}\n.zmdi-flower:before {\n  content: '\\f169';\n}\n.zmdi-font:before {\n  content: '\\f16a';\n}\n.zmdi-fullscreen-alt:before {\n  content: '\\f16b';\n}\n.zmdi-fullscreen-exit:before {\n  content: '\\f16c';\n}\n.zmdi-fullscreen:before {\n  content: '\\f16d';\n}\n.zmdi-functions:before {\n  content: '\\f16e';\n}\n.zmdi-gas-station:before {\n  content: '\\f16f';\n}\n.zmdi-gesture:before {\n  content: '\\f170';\n}\n.zmdi-globe-alt:before {\n  content: '\\f171';\n}\n.zmdi-globe-lock:before {\n  content: '\\f172';\n}\n.zmdi-globe:before {\n  content: '\\f173';\n}\n.zmdi-graduation-cap:before {\n  content: '\\f174';\n}\n.zmdi-home:before {\n  content: '\\f175';\n}\n.zmdi-hospital-alt:before {\n  content: '\\f176';\n}\n.zmdi-hospital:before {\n  content: '\\f177';\n}\n.zmdi-hotel:before {\n  content: '\\f178';\n}\n.zmdi-hourglass-alt:before {\n  content: '\\f179';\n}\n.zmdi-hourglass-outline:before {\n  content: '\\f17a';\n}\n.zmdi-hourglass:before {\n  content: '\\f17b';\n}\n.zmdi-http:before {\n  content: '\\f17c';\n}\n.zmdi-image-alt:before {\n  content: '\\f17d';\n}\n.zmdi-image-o:before {\n  content: '\\f17e';\n}\n.zmdi-image:before {\n  content: '\\f17f';\n}\n.zmdi-inbox:before {\n  content: '\\f180';\n}\n.zmdi-invert-colors-off:before {\n  content: '\\f181';\n}\n.zmdi-invert-colors:before {\n  content: '\\f182';\n}\n.zmdi-key:before {\n  content: '\\f183';\n}\n.zmdi-label-alt-outline:before {\n  content: '\\f184';\n}\n.zmdi-label-alt:before {\n  content: '\\f185';\n}\n.zmdi-label-heart:before {\n  content: '\\f186';\n}\n.zmdi-label:before {\n  content: '\\f187';\n}\n.zmdi-labels:before {\n  content: '\\f188';\n}\n.zmdi-lamp:before {\n  content: '\\f189';\n}\n.zmdi-landscape:before {\n  content: '\\f18a';\n}\n.zmdi-layers-off:before {\n  content: '\\f18b';\n}\n.zmdi-layers:before {\n  content: '\\f18c';\n}\n.zmdi-library:before {\n  content: '\\f18d';\n}\n.zmdi-link:before {\n  content: '\\f18e';\n}\n.zmdi-lock-open:before {\n  content: '\\f18f';\n}\n.zmdi-lock-outline:before {\n  content: '\\f190';\n}\n.zmdi-lock:before {\n  content: '\\f191';\n}\n.zmdi-mail-reply-all:before {\n  content: '\\f192';\n}\n.zmdi-mail-reply:before {\n  content: '\\f193';\n}\n.zmdi-mail-send:before {\n  content: '\\f194';\n}\n.zmdi-mall:before {\n  content: '\\f195';\n}\n.zmdi-map:before {\n  content: '\\f196';\n}\n.zmdi-menu:before {\n  content: '\\f197';\n}\n.zmdi-money-box:before {\n  content: '\\f198';\n}\n.zmdi-money-off:before {\n  content: '\\f199';\n}\n.zmdi-money:before {\n  content: '\\f19a';\n}\n.zmdi-more-vert:before {\n  content: '\\f19b';\n}\n.zmdi-more:before {\n  content: '\\f19c';\n}\n.zmdi-movie-alt:before {\n  content: '\\f19d';\n}\n.zmdi-movie:before {\n  content: '\\f19e';\n}\n.zmdi-nature-people:before {\n  content: '\\f19f';\n}\n.zmdi-nature:before {\n  content: '\\f1a0';\n}\n.zmdi-navigation:before {\n  content: '\\f1a1';\n}\n.zmdi-open-in-browser:before {\n  content: '\\f1a2';\n}\n.zmdi-open-in-new:before {\n  content: '\\f1a3';\n}\n.zmdi-palette:before {\n  content: '\\f1a4';\n}\n.zmdi-parking:before {\n  content: '\\f1a5';\n}\n.zmdi-pin-account:before {\n  content: '\\f1a6';\n}\n.zmdi-pin-assistant:before {\n  content: '\\f1a7';\n}\n.zmdi-pin-drop:before {\n  content: '\\f1a8';\n}\n.zmdi-pin-help:before {\n  content: '\\f1a9';\n}\n.zmdi-pin-off:before {\n  content: '\\f1aa';\n}\n.zmdi-pin:before {\n  content: '\\f1ab';\n}\n.zmdi-pizza:before {\n  content: '\\f1ac';\n}\n.zmdi-plaster:before {\n  content: '\\f1ad';\n}\n.zmdi-power-setting:before {\n  content: '\\f1ae';\n}\n.zmdi-power:before {\n  content: '\\f1af';\n}\n.zmdi-print:before {\n  content: '\\f1b0';\n}\n.zmdi-puzzle-piece:before {\n  content: '\\f1b1';\n}\n.zmdi-quote:before {\n  content: '\\f1b2';\n}\n.zmdi-railway:before {\n  content: '\\f1b3';\n}\n.zmdi-receipt:before {\n  content: '\\f1b4';\n}\n.zmdi-refresh-alt:before {\n  content: '\\f1b5';\n}\n.zmdi-refresh-sync-alert:before {\n  content: '\\f1b6';\n}\n.zmdi-refresh-sync-off:before {\n  content: '\\f1b7';\n}\n.zmdi-refresh-sync:before {\n  content: '\\f1b8';\n}\n.zmdi-refresh:before {\n  content: '\\f1b9';\n}\n.zmdi-roller:before {\n  content: '\\f1ba';\n}\n.zmdi-ruler:before {\n  content: '\\f1bb';\n}\n.zmdi-scissors:before {\n  content: '\\f1bc';\n}\n.zmdi-screen-rotation-lock:before {\n  content: '\\f1bd';\n}\n.zmdi-screen-rotation:before {\n  content: '\\f1be';\n}\n.zmdi-search-for:before {\n  content: '\\f1bf';\n}\n.zmdi-search-in-file:before {\n  content: '\\f1c0';\n}\n.zmdi-search-in-page:before {\n  content: '\\f1c1';\n}\n.zmdi-search-replace:before {\n  content: '\\f1c2';\n}\n.zmdi-search:before {\n  content: '\\f1c3';\n}\n.zmdi-seat:before {\n  content: '\\f1c4';\n}\n.zmdi-settings-square:before {\n  content: '\\f1c5';\n}\n.zmdi-settings:before {\n  content: '\\f1c6';\n}\n.zmdi-shield-check:before {\n  content: '\\f1c7';\n}\n.zmdi-shield-security:before {\n  content: '\\f1c8';\n}\n.zmdi-shopping-basket:before {\n  content: '\\f1c9';\n}\n.zmdi-shopping-cart-plus:before {\n  content: '\\f1ca';\n}\n.zmdi-shopping-cart:before {\n  content: '\\f1cb';\n}\n.zmdi-sign-in:before {\n  content: '\\f1cc';\n}\n.zmdi-sort-amount-asc:before {\n  content: '\\f1cd';\n}\n.zmdi-sort-amount-desc:before {\n  content: '\\f1ce';\n}\n.zmdi-sort-asc:before {\n  content: '\\f1cf';\n}\n.zmdi-sort-desc:before {\n  content: '\\f1d0';\n}\n.zmdi-spellcheck:before {\n  content: '\\f1d1';\n}\n.zmdi-storage:before {\n  content: '\\f1d2';\n}\n.zmdi-store-24:before {\n  content: '\\f1d3';\n}\n.zmdi-store:before {\n  content: '\\f1d4';\n}\n.zmdi-subway:before {\n  content: '\\f1d5';\n}\n.zmdi-sun:before {\n  content: '\\f1d6';\n}\n.zmdi-tab-unselected:before {\n  content: '\\f1d7';\n}\n.zmdi-tab:before {\n  content: '\\f1d8';\n}\n.zmdi-tag-close:before {\n  content: '\\f1d9';\n}\n.zmdi-tag-more:before {\n  content: '\\f1da';\n}\n.zmdi-tag:before {\n  content: '\\f1db';\n}\n.zmdi-thumb-down:before {\n  content: '\\f1dc';\n}\n.zmdi-thumb-up-down:before {\n  content: '\\f1dd';\n}\n.zmdi-thumb-up:before {\n  content: '\\f1de';\n}\n.zmdi-ticket-star:before {\n  content: '\\f1df';\n}\n.zmdi-toll:before {\n  content: '\\f1e0';\n}\n.zmdi-toys:before {\n  content: '\\f1e1';\n}\n.zmdi-traffic:before {\n  content: '\\f1e2';\n}\n.zmdi-translate:before {\n  content: '\\f1e3';\n}\n.zmdi-triangle-down:before {\n  content: '\\f1e4';\n}\n.zmdi-triangle-up:before {\n  content: '\\f1e5';\n}\n.zmdi-truck:before {\n  content: '\\f1e6';\n}\n.zmdi-turning-sign:before {\n  content: '\\f1e7';\n}\n.zmdi-wallpaper:before {\n  content: '\\f1e8';\n}\n.zmdi-washing-machine:before {\n  content: '\\f1e9';\n}\n.zmdi-window-maximize:before {\n  content: '\\f1ea';\n}\n.zmdi-window-minimize:before {\n  content: '\\f1eb';\n}\n.zmdi-window-restore:before {\n  content: '\\f1ec';\n}\n.zmdi-wrench:before {\n  content: '\\f1ed';\n}\n.zmdi-zoom-in:before {\n  content: '\\f1ee';\n}\n.zmdi-zoom-out:before {\n  content: '\\f1ef';\n}\n.zmdi-alert-circle-o:before {\n  content: '\\f1f0';\n}\n.zmdi-alert-circle:before {\n  content: '\\f1f1';\n}\n.zmdi-alert-octagon:before {\n  content: '\\f1f2';\n}\n.zmdi-alert-polygon:before {\n  content: '\\f1f3';\n}\n.zmdi-alert-triangle:before {\n  content: '\\f1f4';\n}\n.zmdi-help-outline:before {\n  content: '\\f1f5';\n}\n.zmdi-help:before {\n  content: '\\f1f6';\n}\n.zmdi-info-outline:before {\n  content: '\\f1f7';\n}\n.zmdi-info:before {\n  content: '\\f1f8';\n}\n.zmdi-notifications-active:before {\n  content: '\\f1f9';\n}\n.zmdi-notifications-add:before {\n  content: '\\f1fa';\n}\n.zmdi-notifications-none:before {\n  content: '\\f1fb';\n}\n.zmdi-notifications-off:before {\n  content: '\\f1fc';\n}\n.zmdi-notifications-paused:before {\n  content: '\\f1fd';\n}\n.zmdi-notifications:before {\n  content: '\\f1fe';\n}\n.zmdi-account-add:before {\n  content: '\\f1ff';\n}\n.zmdi-account-box-mail:before {\n  content: '\\f200';\n}\n.zmdi-account-box-o:before {\n  content: '\\f201';\n}\n.zmdi-account-box-phone:before {\n  content: '\\f202';\n}\n.zmdi-account-box:before {\n  content: '\\f203';\n}\n.zmdi-account-calendar:before {\n  content: '\\f204';\n}\n.zmdi-account-circle:before {\n  content: '\\f205';\n}\n.zmdi-account-o:before {\n  content: '\\f206';\n}\n.zmdi-account:before {\n  content: '\\f207';\n}\n.zmdi-accounts-add:before {\n  content: '\\f208';\n}\n.zmdi-accounts-alt:before {\n  content: '\\f209';\n}\n.zmdi-accounts-list-alt:before {\n  content: '\\f20a';\n}\n.zmdi-accounts-list:before {\n  content: '\\f20b';\n}\n.zmdi-accounts-outline:before {\n  content: '\\f20c';\n}\n.zmdi-accounts:before {\n  content: '\\f20d';\n}\n.zmdi-face:before {\n  content: '\\f20e';\n}\n.zmdi-female:before {\n  content: '\\f20f';\n}\n.zmdi-male-alt:before {\n  content: '\\f210';\n}\n.zmdi-male-female:before {\n  content: '\\f211';\n}\n.zmdi-male:before {\n  content: '\\f212';\n}\n.zmdi-mood-bad:before {\n  content: '\\f213';\n}\n.zmdi-mood:before {\n  content: '\\f214';\n}\n.zmdi-run:before {\n  content: '\\f215';\n}\n.zmdi-walk:before {\n  content: '\\f216';\n}\n.zmdi-cloud-box:before {\n  content: '\\f217';\n}\n.zmdi-cloud-circle:before {\n  content: '\\f218';\n}\n.zmdi-cloud-done:before {\n  content: '\\f219';\n}\n.zmdi-cloud-download:before {\n  content: '\\f21a';\n}\n.zmdi-cloud-off:before {\n  content: '\\f21b';\n}\n.zmdi-cloud-outline-alt:before {\n  content: '\\f21c';\n}\n.zmdi-cloud-outline:before {\n  content: '\\f21d';\n}\n.zmdi-cloud-upload:before {\n  content: '\\f21e';\n}\n.zmdi-cloud:before {\n  content: '\\f21f';\n}\n.zmdi-download:before {\n  content: '\\f220';\n}\n.zmdi-file-plus:before {\n  content: '\\f221';\n}\n.zmdi-file-text:before {\n  content: '\\f222';\n}\n.zmdi-file:before {\n  content: '\\f223';\n}\n.zmdi-folder-outline:before {\n  content: '\\f224';\n}\n.zmdi-folder-person:before {\n  content: '\\f225';\n}\n.zmdi-folder-star-alt:before {\n  content: '\\f226';\n}\n.zmdi-folder-star:before {\n  content: '\\f227';\n}\n.zmdi-folder:before {\n  content: '\\f228';\n}\n.zmdi-gif:before {\n  content: '\\f229';\n}\n.zmdi-upload:before {\n  content: '\\f22a';\n}\n.zmdi-border-all:before {\n  content: '\\f22b';\n}\n.zmdi-border-bottom:before {\n  content: '\\f22c';\n}\n.zmdi-border-clear:before {\n  content: '\\f22d';\n}\n.zmdi-border-color:before {\n  content: '\\f22e';\n}\n.zmdi-border-horizontal:before {\n  content: '\\f22f';\n}\n.zmdi-border-inner:before {\n  content: '\\f230';\n}\n.zmdi-border-left:before {\n  content: '\\f231';\n}\n.zmdi-border-outer:before {\n  content: '\\f232';\n}\n.zmdi-border-right:before {\n  content: '\\f233';\n}\n.zmdi-border-style:before {\n  content: '\\f234';\n}\n.zmdi-border-top:before {\n  content: '\\f235';\n}\n.zmdi-border-vertical:before {\n  content: '\\f236';\n}\n.zmdi-copy:before {\n  content: '\\f237';\n}\n.zmdi-crop:before {\n  content: '\\f238';\n}\n.zmdi-format-align-center:before {\n  content: '\\f239';\n}\n.zmdi-format-align-justify:before {\n  content: '\\f23a';\n}\n.zmdi-format-align-left:before {\n  content: '\\f23b';\n}\n.zmdi-format-align-right:before {\n  content: '\\f23c';\n}\n.zmdi-format-bold:before {\n  content: '\\f23d';\n}\n.zmdi-format-clear-all:before {\n  content: '\\f23e';\n}\n.zmdi-format-clear:before {\n  content: '\\f23f';\n}\n.zmdi-format-color-fill:before {\n  content: '\\f240';\n}\n.zmdi-format-color-reset:before {\n  content: '\\f241';\n}\n.zmdi-format-color-text:before {\n  content: '\\f242';\n}\n.zmdi-format-indent-decrease:before {\n  content: '\\f243';\n}\n.zmdi-format-indent-increase:before {\n  content: '\\f244';\n}\n.zmdi-format-italic:before {\n  content: '\\f245';\n}\n.zmdi-format-line-spacing:before {\n  content: '\\f246';\n}\n.zmdi-format-list-bulleted:before {\n  content: '\\f247';\n}\n.zmdi-format-list-numbered:before {\n  content: '\\f248';\n}\n.zmdi-format-ltr:before {\n  content: '\\f249';\n}\n.zmdi-format-rtl:before {\n  content: '\\f24a';\n}\n.zmdi-format-size:before {\n  content: '\\f24b';\n}\n.zmdi-format-strikethrough-s:before {\n  content: '\\f24c';\n}\n.zmdi-format-strikethrough:before {\n  content: '\\f24d';\n}\n.zmdi-format-subject:before {\n  content: '\\f24e';\n}\n.zmdi-format-underlined:before {\n  content: '\\f24f';\n}\n.zmdi-format-valign-bottom:before {\n  content: '\\f250';\n}\n.zmdi-format-valign-center:before {\n  content: '\\f251';\n}\n.zmdi-format-valign-top:before {\n  content: '\\f252';\n}\n.zmdi-redo:before {\n  content: '\\f253';\n}\n.zmdi-select-all:before {\n  content: '\\f254';\n}\n.zmdi-space-bar:before {\n  content: '\\f255';\n}\n.zmdi-text-format:before {\n  content: '\\f256';\n}\n.zmdi-transform:before {\n  content: '\\f257';\n}\n.zmdi-undo:before {\n  content: '\\f258';\n}\n.zmdi-wrap-text:before {\n  content: '\\f259';\n}\n.zmdi-comment-alert:before {\n  content: '\\f25a';\n}\n.zmdi-comment-alt-text:before {\n  content: '\\f25b';\n}\n.zmdi-comment-alt:before {\n  content: '\\f25c';\n}\n.zmdi-comment-edit:before {\n  content: '\\f25d';\n}\n.zmdi-comment-image:before {\n  content: '\\f25e';\n}\n.zmdi-comment-list:before {\n  content: '\\f25f';\n}\n.zmdi-comment-more:before {\n  content: '\\f260';\n}\n.zmdi-comment-outline:before {\n  content: '\\f261';\n}\n.zmdi-comment-text-alt:before {\n  content: '\\f262';\n}\n.zmdi-comment-text:before {\n  content: '\\f263';\n}\n.zmdi-comment-video:before {\n  content: '\\f264';\n}\n.zmdi-comment:before {\n  content: '\\f265';\n}\n.zmdi-comments:before {\n  content: '\\f266';\n}\n.zmdi-check-all:before {\n  content: '\\f267';\n}\n.zmdi-check-circle-u:before {\n  content: '\\f268';\n}\n.zmdi-check-circle:before {\n  content: '\\f269';\n}\n.zmdi-check-square:before {\n  content: '\\f26a';\n}\n.zmdi-check:before {\n  content: '\\f26b';\n}\n.zmdi-circle-o:before {\n  content: '\\f26c';\n}\n.zmdi-circle:before {\n  content: '\\f26d';\n}\n.zmdi-dot-circle-alt:before {\n  content: '\\f26e';\n}\n.zmdi-dot-circle:before {\n  content: '\\f26f';\n}\n.zmdi-minus-circle-outline:before {\n  content: '\\f270';\n}\n.zmdi-minus-circle:before {\n  content: '\\f271';\n}\n.zmdi-minus-square:before {\n  content: '\\f272';\n}\n.zmdi-minus:before {\n  content: '\\f273';\n}\n.zmdi-plus-circle-o-duplicate:before {\n  content: '\\f274';\n}\n.zmdi-plus-circle-o:before {\n  content: '\\f275';\n}\n.zmdi-plus-circle:before {\n  content: '\\f276';\n}\n.zmdi-plus-square:before {\n  content: '\\f277';\n}\n.zmdi-plus:before {\n  content: '\\f278';\n}\n.zmdi-square-o:before {\n  content: '\\f279';\n}\n.zmdi-star-circle:before {\n  content: '\\f27a';\n}\n.zmdi-star-half:before {\n  content: '\\f27b';\n}\n.zmdi-star-outline:before {\n  content: '\\f27c';\n}\n.zmdi-star:before {\n  content: '\\f27d';\n}\n.zmdi-bluetooth-connected:before {\n  content: '\\f27e';\n}\n.zmdi-bluetooth-off:before {\n  content: '\\f27f';\n}\n.zmdi-bluetooth-search:before {\n  content: '\\f280';\n}\n.zmdi-bluetooth-setting:before {\n  content: '\\f281';\n}\n.zmdi-bluetooth:before {\n  content: '\\f282';\n}\n.zmdi-camera-add:before {\n  content: '\\f283';\n}\n.zmdi-camera-alt:before {\n  content: '\\f284';\n}\n.zmdi-camera-bw:before {\n  content: '\\f285';\n}\n.zmdi-camera-front:before {\n  content: '\\f286';\n}\n.zmdi-camera-mic:before {\n  content: '\\f287';\n}\n.zmdi-camera-party-mode:before {\n  content: '\\f288';\n}\n.zmdi-camera-rear:before {\n  content: '\\f289';\n}\n.zmdi-camera-roll:before {\n  content: '\\f28a';\n}\n.zmdi-camera-switch:before {\n  content: '\\f28b';\n}\n.zmdi-camera:before {\n  content: '\\f28c';\n}\n.zmdi-card-alert:before {\n  content: '\\f28d';\n}\n.zmdi-card-off:before {\n  content: '\\f28e';\n}\n.zmdi-card-sd:before {\n  content: '\\f28f';\n}\n.zmdi-card-sim:before {\n  content: '\\f290';\n}\n.zmdi-desktop-mac:before {\n  content: '\\f291';\n}\n.zmdi-desktop-windows:before {\n  content: '\\f292';\n}\n.zmdi-device-hub:before {\n  content: '\\f293';\n}\n.zmdi-devices-off:before {\n  content: '\\f294';\n}\n.zmdi-devices:before {\n  content: '\\f295';\n}\n.zmdi-dock:before {\n  content: '\\f296';\n}\n.zmdi-floppy:before {\n  content: '\\f297';\n}\n.zmdi-gamepad:before {\n  content: '\\f298';\n}\n.zmdi-gps-dot:before {\n  content: '\\f299';\n}\n.zmdi-gps-off:before {\n  content: '\\f29a';\n}\n.zmdi-gps:before {\n  content: '\\f29b';\n}\n.zmdi-headset-mic:before {\n  content: '\\f29c';\n}\n.zmdi-headset:before {\n  content: '\\f29d';\n}\n.zmdi-input-antenna:before {\n  content: '\\f29e';\n}\n.zmdi-input-composite:before {\n  content: '\\f29f';\n}\n.zmdi-input-hdmi:before {\n  content: '\\f2a0';\n}\n.zmdi-input-power:before {\n  content: '\\f2a1';\n}\n.zmdi-input-svideo:before {\n  content: '\\f2a2';\n}\n.zmdi-keyboard-hide:before {\n  content: '\\f2a3';\n}\n.zmdi-keyboard:before {\n  content: '\\f2a4';\n}\n.zmdi-laptop-chromebook:before {\n  content: '\\f2a5';\n}\n.zmdi-laptop-mac:before {\n  content: '\\f2a6';\n}\n.zmdi-laptop:before {\n  content: '\\f2a7';\n}\n.zmdi-mic-off:before {\n  content: '\\f2a8';\n}\n.zmdi-mic-outline:before {\n  content: '\\f2a9';\n}\n.zmdi-mic-setting:before {\n  content: '\\f2aa';\n}\n.zmdi-mic:before {\n  content: '\\f2ab';\n}\n.zmdi-mouse:before {\n  content: '\\f2ac';\n}\n.zmdi-network-alert:before {\n  content: '\\f2ad';\n}\n.zmdi-network-locked:before {\n  content: '\\f2ae';\n}\n.zmdi-network-off:before {\n  content: '\\f2af';\n}\n.zmdi-network-outline:before {\n  content: '\\f2b0';\n}\n.zmdi-network-setting:before {\n  content: '\\f2b1';\n}\n.zmdi-network:before {\n  content: '\\f2b2';\n}\n.zmdi-phone-bluetooth:before {\n  content: '\\f2b3';\n}\n.zmdi-phone-end:before {\n  content: '\\f2b4';\n}\n.zmdi-phone-forwarded:before {\n  content: '\\f2b5';\n}\n.zmdi-phone-in-talk:before {\n  content: '\\f2b6';\n}\n.zmdi-phone-locked:before {\n  content: '\\f2b7';\n}\n.zmdi-phone-missed:before {\n  content: '\\f2b8';\n}\n.zmdi-phone-msg:before {\n  content: '\\f2b9';\n}\n.zmdi-phone-paused:before {\n  content: '\\f2ba';\n}\n.zmdi-phone-ring:before {\n  content: '\\f2bb';\n}\n.zmdi-phone-setting:before {\n  content: '\\f2bc';\n}\n.zmdi-phone-sip:before {\n  content: '\\f2bd';\n}\n.zmdi-phone:before {\n  content: '\\f2be';\n}\n.zmdi-portable-wifi-changes:before {\n  content: '\\f2bf';\n}\n.zmdi-portable-wifi-off:before {\n  content: '\\f2c0';\n}\n.zmdi-portable-wifi:before {\n  content: '\\f2c1';\n}\n.zmdi-radio:before {\n  content: '\\f2c2';\n}\n.zmdi-reader:before {\n  content: '\\f2c3';\n}\n.zmdi-remote-control-alt:before {\n  content: '\\f2c4';\n}\n.zmdi-remote-control:before {\n  content: '\\f2c5';\n}\n.zmdi-router:before {\n  content: '\\f2c6';\n}\n.zmdi-scanner:before {\n  content: '\\f2c7';\n}\n.zmdi-smartphone-android:before {\n  content: '\\f2c8';\n}\n.zmdi-smartphone-download:before {\n  content: '\\f2c9';\n}\n.zmdi-smartphone-erase:before {\n  content: '\\f2ca';\n}\n.zmdi-smartphone-info:before {\n  content: '\\f2cb';\n}\n.zmdi-smartphone-iphone:before {\n  content: '\\f2cc';\n}\n.zmdi-smartphone-landscape-lock:before {\n  content: '\\f2cd';\n}\n.zmdi-smartphone-landscape:before {\n  content: '\\f2ce';\n}\n.zmdi-smartphone-lock:before {\n  content: '\\f2cf';\n}\n.zmdi-smartphone-portrait-lock:before {\n  content: '\\f2d0';\n}\n.zmdi-smartphone-ring:before {\n  content: '\\f2d1';\n}\n.zmdi-smartphone-setting:before {\n  content: '\\f2d2';\n}\n.zmdi-smartphone-setup:before {\n  content: '\\f2d3';\n}\n.zmdi-smartphone:before {\n  content: '\\f2d4';\n}\n.zmdi-speaker:before {\n  content: '\\f2d5';\n}\n.zmdi-tablet-android:before {\n  content: '\\f2d6';\n}\n.zmdi-tablet-mac:before {\n  content: '\\f2d7';\n}\n.zmdi-tablet:before {\n  content: '\\f2d8';\n}\n.zmdi-tv-alt-play:before {\n  content: '\\f2d9';\n}\n.zmdi-tv-list:before {\n  content: '\\f2da';\n}\n.zmdi-tv-play:before {\n  content: '\\f2db';\n}\n.zmdi-tv:before {\n  content: '\\f2dc';\n}\n.zmdi-usb:before {\n  content: '\\f2dd';\n}\n.zmdi-videocam-off:before {\n  content: '\\f2de';\n}\n.zmdi-videocam-switch:before {\n  content: '\\f2df';\n}\n.zmdi-videocam:before {\n  content: '\\f2e0';\n}\n.zmdi-watch:before {\n  content: '\\f2e1';\n}\n.zmdi-wifi-alt-2:before {\n  content: '\\f2e2';\n}\n.zmdi-wifi-alt:before {\n  content: '\\f2e3';\n}\n.zmdi-wifi-info:before {\n  content: '\\f2e4';\n}\n.zmdi-wifi-lock:before {\n  content: '\\f2e5';\n}\n.zmdi-wifi-off:before {\n  content: '\\f2e6';\n}\n.zmdi-wifi-outline:before {\n  content: '\\f2e7';\n}\n.zmdi-wifi:before {\n  content: '\\f2e8';\n}\n.zmdi-arrow-left-bottom:before {\n  content: '\\f2e9';\n}\n.zmdi-arrow-left:before {\n  content: '\\f2ea';\n}\n.zmdi-arrow-merge:before {\n  content: '\\f2eb';\n}\n.zmdi-arrow-missed:before {\n  content: '\\f2ec';\n}\n.zmdi-arrow-right-top:before {\n  content: '\\f2ed';\n}\n.zmdi-arrow-right:before {\n  content: '\\f2ee';\n}\n.zmdi-arrow-split:before {\n  content: '\\f2ef';\n}\n.zmdi-arrows:before {\n  content: '\\f2f0';\n}\n.zmdi-caret-down-circle:before {\n  content: '\\f2f1';\n}\n.zmdi-caret-down:before {\n  content: '\\f2f2';\n}\n.zmdi-caret-left-circle:before {\n  content: '\\f2f3';\n}\n.zmdi-caret-left:before {\n  content: '\\f2f4';\n}\n.zmdi-caret-right-circle:before {\n  content: '\\f2f5';\n}\n.zmdi-caret-right:before {\n  content: '\\f2f6';\n}\n.zmdi-caret-up-circle:before {\n  content: '\\f2f7';\n}\n.zmdi-caret-up:before {\n  content: '\\f2f8';\n}\n.zmdi-chevron-down:before {\n  content: '\\f2f9';\n}\n.zmdi-chevron-left:before {\n  content: '\\f2fa';\n}\n.zmdi-chevron-right:before {\n  content: '\\f2fb';\n}\n.zmdi-chevron-up:before {\n  content: '\\f2fc';\n}\n.zmdi-forward:before {\n  content: '\\f2fd';\n}\n.zmdi-long-arrow-down:before {\n  content: '\\f2fe';\n}\n.zmdi-long-arrow-left:before {\n  content: '\\f2ff';\n}\n.zmdi-long-arrow-return:before {\n  content: '\\f300';\n}\n.zmdi-long-arrow-right:before {\n  content: '\\f301';\n}\n.zmdi-long-arrow-tab:before {\n  content: '\\f302';\n}\n.zmdi-long-arrow-up:before {\n  content: '\\f303';\n}\n.zmdi-rotate-ccw:before {\n  content: '\\f304';\n}\n.zmdi-rotate-cw:before {\n  content: '\\f305';\n}\n.zmdi-rotate-left:before {\n  content: '\\f306';\n}\n.zmdi-rotate-right:before {\n  content: '\\f307';\n}\n.zmdi-square-down:before {\n  content: '\\f308';\n}\n.zmdi-square-right:before {\n  content: '\\f309';\n}\n.zmdi-swap-alt:before {\n  content: '\\f30a';\n}\n.zmdi-swap-vertical-circle:before {\n  content: '\\f30b';\n}\n.zmdi-swap-vertical:before {\n  content: '\\f30c';\n}\n.zmdi-swap:before {\n  content: '\\f30d';\n}\n.zmdi-trending-down:before {\n  content: '\\f30e';\n}\n.zmdi-trending-flat:before {\n  content: '\\f30f';\n}\n.zmdi-trending-up:before {\n  content: '\\f310';\n}\n.zmdi-unfold-less:before {\n  content: '\\f311';\n}\n.zmdi-unfold-more:before {\n  content: '\\f312';\n}\n.zmdi-apps:before {\n  content: '\\f313';\n}\n.zmdi-grid-off:before {\n  content: '\\f314';\n}\n.zmdi-grid:before {\n  content: '\\f315';\n}\n.zmdi-view-agenda:before {\n  content: '\\f316';\n}\n.zmdi-view-array:before {\n  content: '\\f317';\n}\n.zmdi-view-carousel:before {\n  content: '\\f318';\n}\n.zmdi-view-column:before {\n  content: '\\f319';\n}\n.zmdi-view-comfy:before {\n  content: '\\f31a';\n}\n.zmdi-view-compact:before {\n  content: '\\f31b';\n}\n.zmdi-view-dashboard:before {\n  content: '\\f31c';\n}\n.zmdi-view-day:before {\n  content: '\\f31d';\n}\n.zmdi-view-headline:before {\n  content: '\\f31e';\n}\n.zmdi-view-list-alt:before {\n  content: '\\f31f';\n}\n.zmdi-view-list:before {\n  content: '\\f320';\n}\n.zmdi-view-module:before {\n  content: '\\f321';\n}\n.zmdi-view-quilt:before {\n  content: '\\f322';\n}\n.zmdi-view-stream:before {\n  content: '\\f323';\n}\n.zmdi-view-subtitles:before {\n  content: '\\f324';\n}\n.zmdi-view-toc:before {\n  content: '\\f325';\n}\n.zmdi-view-web:before {\n  content: '\\f326';\n}\n.zmdi-view-week:before {\n  content: '\\f327';\n}\n.zmdi-widgets:before {\n  content: '\\f328';\n}\n.zmdi-alarm-check:before {\n  content: '\\f329';\n}\n.zmdi-alarm-off:before {\n  content: '\\f32a';\n}\n.zmdi-alarm-plus:before {\n  content: '\\f32b';\n}\n.zmdi-alarm-snooze:before {\n  content: '\\f32c';\n}\n.zmdi-alarm:before {\n  content: '\\f32d';\n}\n.zmdi-calendar-alt:before {\n  content: '\\f32e';\n}\n.zmdi-calendar-check:before {\n  content: '\\f32f';\n}\n.zmdi-calendar-close:before {\n  content: '\\f330';\n}\n.zmdi-calendar-note:before {\n  content: '\\f331';\n}\n.zmdi-calendar:before {\n  content: '\\f332';\n}\n.zmdi-time-countdown:before {\n  content: '\\f333';\n}\n.zmdi-time-interval:before {\n  content: '\\f334';\n}\n.zmdi-time-restore-setting:before {\n  content: '\\f335';\n}\n.zmdi-time-restore:before {\n  content: '\\f336';\n}\n.zmdi-time:before {\n  content: '\\f337';\n}\n.zmdi-timer-off:before {\n  content: '\\f338';\n}\n.zmdi-timer:before {\n  content: '\\f339';\n}\n.zmdi-android-alt:before {\n  content: '\\f33a';\n}\n.zmdi-android:before {\n  content: '\\f33b';\n}\n.zmdi-apple:before {\n  content: '\\f33c';\n}\n.zmdi-behance:before {\n  content: '\\f33d';\n}\n.zmdi-codepen:before {\n  content: '\\f33e';\n}\n.zmdi-dribbble:before {\n  content: '\\f33f';\n}\n.zmdi-dropbox:before {\n  content: '\\f340';\n}\n.zmdi-evernote:before {\n  content: '\\f341';\n}\n.zmdi-facebook-box:before {\n  content: '\\f342';\n}\n.zmdi-facebook:before {\n  content: '\\f343';\n}\n.zmdi-github-box:before {\n  content: '\\f344';\n}\n.zmdi-github:before {\n  content: '\\f345';\n}\n.zmdi-google-drive:before {\n  content: '\\f346';\n}\n.zmdi-google-earth:before {\n  content: '\\f347';\n}\n.zmdi-google-glass:before {\n  content: '\\f348';\n}\n.zmdi-google-maps:before {\n  content: '\\f349';\n}\n.zmdi-google-pages:before {\n  content: '\\f34a';\n}\n.zmdi-google-play:before {\n  content: '\\f34b';\n}\n.zmdi-google-plus-box:before {\n  content: '\\f34c';\n}\n.zmdi-google-plus:before {\n  content: '\\f34d';\n}\n.zmdi-google:before {\n  content: '\\f34e';\n}\n.zmdi-instagram:before {\n  content: '\\f34f';\n}\n.zmdi-language-css3:before {\n  content: '\\f350';\n}\n.zmdi-language-html5:before {\n  content: '\\f351';\n}\n.zmdi-language-javascript:before {\n  content: '\\f352';\n}\n.zmdi-language-python-alt:before {\n  content: '\\f353';\n}\n.zmdi-language-python:before {\n  content: '\\f354';\n}\n.zmdi-lastfm:before {\n  content: '\\f355';\n}\n.zmdi-linkedin-box:before {\n  content: '\\f356';\n}\n.zmdi-paypal:before {\n  content: '\\f357';\n}\n.zmdi-pinterest-box:before {\n  content: '\\f358';\n}\n.zmdi-pocket:before {\n  content: '\\f359';\n}\n.zmdi-polymer:before {\n  content: '\\f35a';\n}\n.zmdi-share:before {\n  content: '\\f35b';\n}\n.zmdi-stackoverflow:before {\n  content: '\\f35c';\n}\n.zmdi-steam-square:before {\n  content: '\\f35d';\n}\n.zmdi-steam:before {\n  content: '\\f35e';\n}\n.zmdi-twitter-box:before {\n  content: '\\f35f';\n}\n.zmdi-twitter:before {\n  content: '\\f360';\n}\n.zmdi-vk:before {\n  content: '\\f361';\n}\n.zmdi-wikipedia:before {\n  content: '\\f362';\n}\n.zmdi-windows:before {\n  content: '\\f363';\n}\n.zmdi-aspect-ratio-alt:before {\n  content: '\\f364';\n}\n.zmdi-aspect-ratio:before {\n  content: '\\f365';\n}\n.zmdi-blur-circular:before {\n  content: '\\f366';\n}\n.zmdi-blur-linear:before {\n  content: '\\f367';\n}\n.zmdi-blur-off:before {\n  content: '\\f368';\n}\n.zmdi-blur:before {\n  content: '\\f369';\n}\n.zmdi-brightness-2:before {\n  content: '\\f36a';\n}\n.zmdi-brightness-3:before {\n  content: '\\f36b';\n}\n.zmdi-brightness-4:before {\n  content: '\\f36c';\n}\n.zmdi-brightness-5:before {\n  content: '\\f36d';\n}\n.zmdi-brightness-6:before {\n  content: '\\f36e';\n}\n.zmdi-brightness-7:before {\n  content: '\\f36f';\n}\n.zmdi-brightness-auto:before {\n  content: '\\f370';\n}\n.zmdi-brightness-setting:before {\n  content: '\\f371';\n}\n.zmdi-broken-image:before {\n  content: '\\f372';\n}\n.zmdi-center-focus-strong:before {\n  content: '\\f373';\n}\n.zmdi-center-focus-weak:before {\n  content: '\\f374';\n}\n.zmdi-compare:before {\n  content: '\\f375';\n}\n.zmdi-crop-16-9:before {\n  content: '\\f376';\n}\n.zmdi-crop-3-2:before {\n  content: '\\f377';\n}\n.zmdi-crop-5-4:before {\n  content: '\\f378';\n}\n.zmdi-crop-7-5:before {\n  content: '\\f379';\n}\n.zmdi-crop-din:before {\n  content: '\\f37a';\n}\n.zmdi-crop-free:before {\n  content: '\\f37b';\n}\n.zmdi-crop-landscape:before {\n  content: '\\f37c';\n}\n.zmdi-crop-portrait:before {\n  content: '\\f37d';\n}\n.zmdi-crop-square:before {\n  content: '\\f37e';\n}\n.zmdi-exposure-alt:before {\n  content: '\\f37f';\n}\n.zmdi-exposure:before {\n  content: '\\f380';\n}\n.zmdi-filter-b-and-w:before {\n  content: '\\f381';\n}\n.zmdi-filter-center-focus:before {\n  content: '\\f382';\n}\n.zmdi-filter-frames:before {\n  content: '\\f383';\n}\n.zmdi-filter-tilt-shift:before {\n  content: '\\f384';\n}\n.zmdi-gradient:before {\n  content: '\\f385';\n}\n.zmdi-grain:before {\n  content: '\\f386';\n}\n.zmdi-graphic-eq:before {\n  content: '\\f387';\n}\n.zmdi-hdr-off:before {\n  content: '\\f388';\n}\n.zmdi-hdr-strong:before {\n  content: '\\f389';\n}\n.zmdi-hdr-weak:before {\n  content: '\\f38a';\n}\n.zmdi-hdr:before {\n  content: '\\f38b';\n}\n.zmdi-iridescent:before {\n  content: '\\f38c';\n}\n.zmdi-leak-off:before {\n  content: '\\f38d';\n}\n.zmdi-leak:before {\n  content: '\\f38e';\n}\n.zmdi-looks:before {\n  content: '\\f38f';\n}\n.zmdi-loupe:before {\n  content: '\\f390';\n}\n.zmdi-panorama-horizontal:before {\n  content: '\\f391';\n}\n.zmdi-panorama-vertical:before {\n  content: '\\f392';\n}\n.zmdi-panorama-wide-angle:before {\n  content: '\\f393';\n}\n.zmdi-photo-size-select-large:before {\n  content: '\\f394';\n}\n.zmdi-photo-size-select-small:before {\n  content: '\\f395';\n}\n.zmdi-picture-in-picture:before {\n  content: '\\f396';\n}\n.zmdi-slideshow:before {\n  content: '\\f397';\n}\n.zmdi-texture:before {\n  content: '\\f398';\n}\n.zmdi-tonality:before {\n  content: '\\f399';\n}\n.zmdi-vignette:before {\n  content: '\\f39a';\n}\n.zmdi-wb-auto:before {\n  content: '\\f39b';\n}\n.zmdi-eject-alt:before {\n  content: '\\f39c';\n}\n.zmdi-eject:before {\n  content: '\\f39d';\n}\n.zmdi-equalizer:before {\n  content: '\\f39e';\n}\n.zmdi-fast-forward:before {\n  content: '\\f39f';\n}\n.zmdi-fast-rewind:before {\n  content: '\\f3a0';\n}\n.zmdi-forward-10:before {\n  content: '\\f3a1';\n}\n.zmdi-forward-30:before {\n  content: '\\f3a2';\n}\n.zmdi-forward-5:before {\n  content: '\\f3a3';\n}\n.zmdi-hearing:before {\n  content: '\\f3a4';\n}\n.zmdi-pause-circle-outline:before {\n  content: '\\f3a5';\n}\n.zmdi-pause-circle:before {\n  content: '\\f3a6';\n}\n.zmdi-pause:before {\n  content: '\\f3a7';\n}\n.zmdi-play-circle-outline:before {\n  content: '\\f3a8';\n}\n.zmdi-play-circle:before {\n  content: '\\f3a9';\n}\n.zmdi-play:before {\n  content: '\\f3aa';\n}\n.zmdi-playlist-audio:before {\n  content: '\\f3ab';\n}\n.zmdi-playlist-plus:before {\n  content: '\\f3ac';\n}\n.zmdi-repeat-one:before {\n  content: '\\f3ad';\n}\n.zmdi-repeat:before {\n  content: '\\f3ae';\n}\n.zmdi-replay-10:before {\n  content: '\\f3af';\n}\n.zmdi-replay-30:before {\n  content: '\\f3b0';\n}\n.zmdi-replay-5:before {\n  content: '\\f3b1';\n}\n.zmdi-replay:before {\n  content: '\\f3b2';\n}\n.zmdi-shuffle:before {\n  content: '\\f3b3';\n}\n.zmdi-skip-next:before {\n  content: '\\f3b4';\n}\n.zmdi-skip-previous:before {\n  content: '\\f3b5';\n}\n.zmdi-stop:before {\n  content: '\\f3b6';\n}\n.zmdi-surround-sound:before {\n  content: '\\f3b7';\n}\n.zmdi-tune:before {\n  content: '\\f3b8';\n}\n.zmdi-volume-down:before {\n  content: '\\f3b9';\n}\n.zmdi-volume-mute:before {\n  content: '\\f3ba';\n}\n.zmdi-volume-off:before {\n  content: '\\f3bb';\n}\n.zmdi-volume-up:before {\n  content: '\\f3bc';\n}\n.zmdi-n-1-square:before {\n  content: '\\f3bd';\n}\n.zmdi-n-2-square:before {\n  content: '\\f3be';\n}\n.zmdi-n-3-square:before {\n  content: '\\f3bf';\n}\n.zmdi-n-4-square:before {\n  content: '\\f3c0';\n}\n.zmdi-n-5-square:before {\n  content: '\\f3c1';\n}\n.zmdi-n-6-square:before {\n  content: '\\f3c2';\n}\n.zmdi-neg-1:before {\n  content: '\\f3c3';\n}\n.zmdi-neg-2:before {\n  content: '\\f3c4';\n}\n.zmdi-plus-1:before {\n  content: '\\f3c5';\n}\n.zmdi-plus-2:before {\n  content: '\\f3c6';\n}\n.zmdi-sec-10:before {\n  content: '\\f3c7';\n}\n.zmdi-sec-3:before {\n  content: '\\f3c8';\n}\n.zmdi-zero:before {\n  content: '\\f3c9';\n}\n.zmdi-airline-seat-flat-angled:before {\n  content: '\\f3ca';\n}\n.zmdi-airline-seat-flat:before {\n  content: '\\f3cb';\n}\n.zmdi-airline-seat-individual-suite:before {\n  content: '\\f3cc';\n}\n.zmdi-airline-seat-legroom-extra:before {\n  content: '\\f3cd';\n}\n.zmdi-airline-seat-legroom-normal:before {\n  content: '\\f3ce';\n}\n.zmdi-airline-seat-legroom-reduced:before {\n  content: '\\f3cf';\n}\n.zmdi-airline-seat-recline-extra:before {\n  content: '\\f3d0';\n}\n.zmdi-airline-seat-recline-normal:before {\n  content: '\\f3d1';\n}\n.zmdi-airplay:before {\n  content: '\\f3d2';\n}\n.zmdi-closed-caption:before {\n  content: '\\f3d3';\n}\n.zmdi-confirmation-number:before {\n  content: '\\f3d4';\n}\n.zmdi-developer-board:before {\n  content: '\\f3d5';\n}\n.zmdi-disc-full:before {\n  content: '\\f3d6';\n}\n.zmdi-explicit:before {\n  content: '\\f3d7';\n}\n.zmdi-flight-land:before {\n  content: '\\f3d8';\n}\n.zmdi-flight-takeoff:before {\n  content: '\\f3d9';\n}\n.zmdi-flip-to-back:before {\n  content: '\\f3da';\n}\n.zmdi-flip-to-front:before {\n  content: '\\f3db';\n}\n.zmdi-group-work:before {\n  content: '\\f3dc';\n}\n.zmdi-hd:before {\n  content: '\\f3dd';\n}\n.zmdi-hq:before {\n  content: '\\f3de';\n}\n.zmdi-markunread-mailbox:before {\n  content: '\\f3df';\n}\n.zmdi-memory:before {\n  content: '\\f3e0';\n}\n.zmdi-nfc:before {\n  content: '\\f3e1';\n}\n.zmdi-play-for-work:before {\n  content: '\\f3e2';\n}\n.zmdi-power-input:before {\n  content: '\\f3e3';\n}\n.zmdi-present-to-all:before {\n  content: '\\f3e4';\n}\n.zmdi-satellite:before {\n  content: '\\f3e5';\n}\n.zmdi-tap-and-play:before {\n  content: '\\f3e6';\n}\n.zmdi-vibration:before {\n  content: '\\f3e7';\n}\n.zmdi-voicemail:before {\n  content: '\\f3e8';\n}\n.zmdi-group:before {\n  content: '\\f3e9';\n}\n.zmdi-rss:before {\n  content: '\\f3ea';\n}\n.zmdi-shape:before {\n  content: '\\f3eb';\n}\n.zmdi-spinner:before {\n  content: '\\f3ec';\n}\n.zmdi-ungroup:before {\n  content: '\\f3ed';\n}\n.zmdi-500px:before {\n  content: '\\f3ee';\n}\n.zmdi-8tracks:before {\n  content: '\\f3ef';\n}\n.zmdi-amazon:before {\n  content: '\\f3f0';\n}\n.zmdi-blogger:before {\n  content: '\\f3f1';\n}\n.zmdi-delicious:before {\n  content: '\\f3f2';\n}\n.zmdi-disqus:before {\n  content: '\\f3f3';\n}\n.zmdi-flattr:before {\n  content: '\\f3f4';\n}\n.zmdi-flickr:before {\n  content: '\\f3f5';\n}\n.zmdi-github-alt:before {\n  content: '\\f3f6';\n}\n.zmdi-google-old:before {\n  content: '\\f3f7';\n}\n.zmdi-linkedin:before {\n  content: '\\f3f8';\n}\n.zmdi-odnoklassniki:before {\n  content: '\\f3f9';\n}\n.zmdi-outlook:before {\n  content: '\\f3fa';\n}\n.zmdi-paypal-alt:before {\n  content: '\\f3fb';\n}\n.zmdi-pinterest:before {\n  content: '\\f3fc';\n}\n.zmdi-playstation:before {\n  content: '\\f3fd';\n}\n.zmdi-reddit:before {\n  content: '\\f3fe';\n}\n.zmdi-skype:before {\n  content: '\\f3ff';\n}\n.zmdi-slideshare:before {\n  content: '\\f400';\n}\n.zmdi-soundcloud:before {\n  content: '\\f401';\n}\n.zmdi-tumblr:before {\n  content: '\\f402';\n}\n.zmdi-twitch:before {\n  content: '\\f403';\n}\n.zmdi-vimeo:before {\n  content: '\\f404';\n}\n.zmdi-whatsapp:before {\n  content: '\\f405';\n}\n.zmdi-xbox:before {\n  content: '\\f406';\n}\n.zmdi-yahoo:before {\n  content: '\\f407';\n}\n.zmdi-youtube-play:before {\n  content: '\\f408';\n}\n.zmdi-youtube:before {\n  content: '\\f409';\n}\n.zmdi-3d-rotation:before {\n  content: '\\f101';\n}\n.zmdi-airplane-off:before {\n  content: '\\f102';\n}\n.zmdi-airplane:before {\n  content: '\\f103';\n}\n.zmdi-album:before {\n  content: '\\f104';\n}\n.zmdi-archive:before {\n  content: '\\f105';\n}\n.zmdi-assignment-account:before {\n  content: '\\f106';\n}\n.zmdi-assignment-alert:before {\n  content: '\\f107';\n}\n.zmdi-assignment-check:before {\n  content: '\\f108';\n}\n.zmdi-assignment-o:before {\n  content: '\\f109';\n}\n.zmdi-assignment-return:before {\n  content: '\\f10a';\n}\n.zmdi-assignment-returned:before {\n  content: '\\f10b';\n}\n.zmdi-assignment:before {\n  content: '\\f10c';\n}\n.zmdi-attachment-alt:before {\n  content: '\\f10d';\n}\n.zmdi-attachment:before {\n  content: '\\f10e';\n}\n.zmdi-audio:before {\n  content: '\\f10f';\n}\n.zmdi-badge-check:before {\n  content: '\\f110';\n}\n.zmdi-balance-wallet:before {\n  content: '\\f111';\n}\n.zmdi-balance:before {\n  content: '\\f112';\n}\n.zmdi-battery-alert:before {\n  content: '\\f113';\n}\n.zmdi-battery-flash:before {\n  content: '\\f114';\n}\n.zmdi-battery-unknown:before {\n  content: '\\f115';\n}\n.zmdi-battery:before {\n  content: '\\f116';\n}\n.zmdi-bike:before {\n  content: '\\f117';\n}\n.zmdi-block-alt:before {\n  content: '\\f118';\n}\n.zmdi-block:before {\n  content: '\\f119';\n}\n.zmdi-boat:before {\n  content: '\\f11a';\n}\n.zmdi-book-image:before {\n  content: '\\f11b';\n}\n.zmdi-book:before {\n  content: '\\f11c';\n}\n.zmdi-bookmark-outline:before {\n  content: '\\f11d';\n}\n.zmdi-bookmark:before {\n  content: '\\f11e';\n}\n.zmdi-brush:before {\n  content: '\\f11f';\n}\n.zmdi-bug:before {\n  content: '\\f120';\n}\n.zmdi-bus:before {\n  content: '\\f121';\n}\n.zmdi-cake:before {\n  content: '\\f122';\n}\n.zmdi-car-taxi:before {\n  content: '\\f123';\n}\n.zmdi-car-wash:before {\n  content: '\\f124';\n}\n.zmdi-car:before {\n  content: '\\f125';\n}\n.zmdi-card-giftcard:before {\n  content: '\\f126';\n}\n.zmdi-card-membership:before {\n  content: '\\f127';\n}\n.zmdi-card-travel:before {\n  content: '\\f128';\n}\n.zmdi-card:before {\n  content: '\\f129';\n}\n.zmdi-case-check:before {\n  content: '\\f12a';\n}\n.zmdi-case-download:before {\n  content: '\\f12b';\n}\n.zmdi-case-play:before {\n  content: '\\f12c';\n}\n.zmdi-case:before {\n  content: '\\f12d';\n}\n.zmdi-cast-connected:before {\n  content: '\\f12e';\n}\n.zmdi-cast:before {\n  content: '\\f12f';\n}\n.zmdi-chart-donut:before {\n  content: '\\f130';\n}\n.zmdi-chart:before {\n  content: '\\f131';\n}\n.zmdi-city-alt:before {\n  content: '\\f132';\n}\n.zmdi-city:before {\n  content: '\\f133';\n}\n.zmdi-close-circle-o:before {\n  content: '\\f134';\n}\n.zmdi-close-circle:before {\n  content: '\\f135';\n}\n.zmdi-close:before {\n  content: '\\f136';\n}\n.zmdi-cocktail:before {\n  content: '\\f137';\n}\n.zmdi-code-setting:before {\n  content: '\\f138';\n}\n.zmdi-code-smartphone:before {\n  content: '\\f139';\n}\n.zmdi-code:before {\n  content: '\\f13a';\n}\n.zmdi-coffee:before {\n  content: '\\f13b';\n}\n.zmdi-collection-bookmark:before {\n  content: '\\f13c';\n}\n.zmdi-collection-case-play:before {\n  content: '\\f13d';\n}\n.zmdi-collection-folder-image:before {\n  content: '\\f13e';\n}\n.zmdi-collection-image-o:before {\n  content: '\\f13f';\n}\n.zmdi-collection-image:before {\n  content: '\\f140';\n}\n.zmdi-collection-item-1:before {\n  content: '\\f141';\n}\n.zmdi-collection-item-2:before {\n  content: '\\f142';\n}\n.zmdi-collection-item-3:before {\n  content: '\\f143';\n}\n.zmdi-collection-item-4:before {\n  content: '\\f144';\n}\n.zmdi-collection-item-5:before {\n  content: '\\f145';\n}\n.zmdi-collection-item-6:before {\n  content: '\\f146';\n}\n.zmdi-collection-item-7:before {\n  content: '\\f147';\n}\n.zmdi-collection-item-8:before {\n  content: '\\f148';\n}\n.zmdi-collection-item-9-plus:before {\n  content: '\\f149';\n}\n.zmdi-collection-item-9:before {\n  content: '\\f14a';\n}\n.zmdi-collection-item:before {\n  content: '\\f14b';\n}\n.zmdi-collection-music:before {\n  content: '\\f14c';\n}\n.zmdi-collection-pdf:before {\n  content: '\\f14d';\n}\n.zmdi-collection-plus:before {\n  content: '\\f14e';\n}\n.zmdi-collection-speaker:before {\n  content: '\\f14f';\n}\n.zmdi-collection-text:before {\n  content: '\\f150';\n}\n.zmdi-collection-video:before {\n  content: '\\f151';\n}\n.zmdi-compass:before {\n  content: '\\f152';\n}\n.zmdi-cutlery:before {\n  content: '\\f153';\n}\n.zmdi-delete:before {\n  content: '\\f154';\n}\n.zmdi-dialpad:before {\n  content: '\\f155';\n}\n.zmdi-dns:before {\n  content: '\\f156';\n}\n.zmdi-drink:before {\n  content: '\\f157';\n}\n.zmdi-edit:before {\n  content: '\\f158';\n}\n.zmdi-email-open:before {\n  content: '\\f159';\n}\n.zmdi-email:before {\n  content: '\\f15a';\n}\n.zmdi-eye-off:before {\n  content: '\\f15b';\n}\n.zmdi-eye:before {\n  content: '\\f15c';\n}\n.zmdi-eyedropper:before {\n  content: '\\f15d';\n}\n.zmdi-favorite-outline:before {\n  content: '\\f15e';\n}\n.zmdi-favorite:before {\n  content: '\\f15f';\n}\n.zmdi-filter-list:before {\n  content: '\\f160';\n}\n.zmdi-fire:before {\n  content: '\\f161';\n}\n.zmdi-flag:before {\n  content: '\\f162';\n}\n.zmdi-flare:before {\n  content: '\\f163';\n}\n.zmdi-flash-auto:before {\n  content: '\\f164';\n}\n.zmdi-flash-off:before {\n  content: '\\f165';\n}\n.zmdi-flash:before {\n  content: '\\f166';\n}\n.zmdi-flip:before {\n  content: '\\f167';\n}\n.zmdi-flower-alt:before {\n  content: '\\f168';\n}\n.zmdi-flower:before {\n  content: '\\f169';\n}\n.zmdi-font:before {\n  content: '\\f16a';\n}\n.zmdi-fullscreen-alt:before {\n  content: '\\f16b';\n}\n.zmdi-fullscreen-exit:before {\n  content: '\\f16c';\n}\n.zmdi-fullscreen:before {\n  content: '\\f16d';\n}\n.zmdi-functions:before {\n  content: '\\f16e';\n}\n.zmdi-gas-station:before {\n  content: '\\f16f';\n}\n.zmdi-gesture:before {\n  content: '\\f170';\n}\n.zmdi-globe-alt:before {\n  content: '\\f171';\n}\n.zmdi-globe-lock:before {\n  content: '\\f172';\n}\n.zmdi-globe:before {\n  content: '\\f173';\n}\n.zmdi-graduation-cap:before {\n  content: '\\f174';\n}\n.zmdi-home:before {\n  content: '\\f175';\n}\n.zmdi-hospital-alt:before {\n  content: '\\f176';\n}\n.zmdi-hospital:before {\n  content: '\\f177';\n}\n.zmdi-hotel:before {\n  content: '\\f178';\n}\n.zmdi-hourglass-alt:before {\n  content: '\\f179';\n}\n.zmdi-hourglass-outline:before {\n  content: '\\f17a';\n}\n.zmdi-hourglass:before {\n  content: '\\f17b';\n}\n.zmdi-http:before {\n  content: '\\f17c';\n}\n.zmdi-image-alt:before {\n  content: '\\f17d';\n}\n.zmdi-image-o:before {\n  content: '\\f17e';\n}\n.zmdi-image:before {\n  content: '\\f17f';\n}\n.zmdi-inbox:before {\n  content: '\\f180';\n}\n.zmdi-invert-colors-off:before {\n  content: '\\f181';\n}\n.zmdi-invert-colors:before {\n  content: '\\f182';\n}\n.zmdi-key:before {\n  content: '\\f183';\n}\n.zmdi-label-alt-outline:before {\n  content: '\\f184';\n}\n.zmdi-label-alt:before {\n  content: '\\f185';\n}\n.zmdi-label-heart:before {\n  content: '\\f186';\n}\n.zmdi-label:before {\n  content: '\\f187';\n}\n.zmdi-labels:before {\n  content: '\\f188';\n}\n.zmdi-lamp:before {\n  content: '\\f189';\n}\n.zmdi-landscape:before {\n  content: '\\f18a';\n}\n.zmdi-layers-off:before {\n  content: '\\f18b';\n}\n.zmdi-layers:before {\n  content: '\\f18c';\n}\n.zmdi-library:before {\n  content: '\\f18d';\n}\n.zmdi-link:before {\n  content: '\\f18e';\n}\n.zmdi-lock-open:before {\n  content: '\\f18f';\n}\n.zmdi-lock-outline:before {\n  content: '\\f190';\n}\n.zmdi-lock:before {\n  content: '\\f191';\n}\n.zmdi-mail-reply-all:before {\n  content: '\\f192';\n}\n.zmdi-mail-reply:before {\n  content: '\\f193';\n}\n.zmdi-mail-send:before {\n  content: '\\f194';\n}\n.zmdi-mall:before {\n  content: '\\f195';\n}\n.zmdi-map:before {\n  content: '\\f196';\n}\n.zmdi-menu:before {\n  content: '\\f197';\n}\n.zmdi-money-box:before {\n  content: '\\f198';\n}\n.zmdi-money-off:before {\n  content: '\\f199';\n}\n.zmdi-money:before {\n  content: '\\f19a';\n}\n.zmdi-more-vert:before {\n  content: '\\f19b';\n}\n.zmdi-more:before {\n  content: '\\f19c';\n}\n.zmdi-movie-alt:before {\n  content: '\\f19d';\n}\n.zmdi-movie:before {\n  content: '\\f19e';\n}\n.zmdi-nature-people:before {\n  content: '\\f19f';\n}\n.zmdi-nature:before {\n  content: '\\f1a0';\n}\n.zmdi-navigation:before {\n  content: '\\f1a1';\n}\n.zmdi-open-in-browser:before {\n  content: '\\f1a2';\n}\n.zmdi-open-in-new:before {\n  content: '\\f1a3';\n}\n.zmdi-palette:before {\n  content: '\\f1a4';\n}\n.zmdi-parking:before {\n  content: '\\f1a5';\n}\n.zmdi-pin-account:before {\n  content: '\\f1a6';\n}\n.zmdi-pin-assistant:before {\n  content: '\\f1a7';\n}\n.zmdi-pin-drop:before {\n  content: '\\f1a8';\n}\n.zmdi-pin-help:before {\n  content: '\\f1a9';\n}\n.zmdi-pin-off:before {\n  content: '\\f1aa';\n}\n.zmdi-pin:before {\n  content: '\\f1ab';\n}\n.zmdi-pizza:before {\n  content: '\\f1ac';\n}\n.zmdi-plaster:before {\n  content: '\\f1ad';\n}\n.zmdi-power-setting:before {\n  content: '\\f1ae';\n}\n.zmdi-power:before {\n  content: '\\f1af';\n}\n.zmdi-print:before {\n  content: '\\f1b0';\n}\n.zmdi-puzzle-piece:before {\n  content: '\\f1b1';\n}\n.zmdi-quote:before {\n  content: '\\f1b2';\n}\n.zmdi-railway:before {\n  content: '\\f1b3';\n}\n.zmdi-receipt:before {\n  content: '\\f1b4';\n}\n.zmdi-refresh-alt:before {\n  content: '\\f1b5';\n}\n.zmdi-refresh-sync-alert:before {\n  content: '\\f1b6';\n}\n.zmdi-refresh-sync-off:before {\n  content: '\\f1b7';\n}\n.zmdi-refresh-sync:before {\n  content: '\\f1b8';\n}\n.zmdi-refresh:before {\n  content: '\\f1b9';\n}\n.zmdi-roller:before {\n  content: '\\f1ba';\n}\n.zmdi-ruler:before {\n  content: '\\f1bb';\n}\n.zmdi-scissors:before {\n  content: '\\f1bc';\n}\n.zmdi-screen-rotation-lock:before {\n  content: '\\f1bd';\n}\n.zmdi-screen-rotation:before {\n  content: '\\f1be';\n}\n.zmdi-search-for:before {\n  content: '\\f1bf';\n}\n.zmdi-search-in-file:before {\n  content: '\\f1c0';\n}\n.zmdi-search-in-page:before {\n  content: '\\f1c1';\n}\n.zmdi-search-replace:before {\n  content: '\\f1c2';\n}\n.zmdi-search:before {\n  content: '\\f1c3';\n}\n.zmdi-seat:before {\n  content: '\\f1c4';\n}\n.zmdi-settings-square:before {\n  content: '\\f1c5';\n}\n.zmdi-settings:before {\n  content: '\\f1c6';\n}\n.zmdi-shield-check:before {\n  content: '\\f1c7';\n}\n.zmdi-shield-security:before {\n  content: '\\f1c8';\n}\n.zmdi-shopping-basket:before {\n  content: '\\f1c9';\n}\n.zmdi-shopping-cart-plus:before {\n  content: '\\f1ca';\n}\n.zmdi-shopping-cart:before {\n  content: '\\f1cb';\n}\n.zmdi-sign-in:before {\n  content: '\\f1cc';\n}\n.zmdi-sort-amount-asc:before {\n  content: '\\f1cd';\n}\n.zmdi-sort-amount-desc:before {\n  content: '\\f1ce';\n}\n.zmdi-sort-asc:before {\n  content: '\\f1cf';\n}\n.zmdi-sort-desc:before {\n  content: '\\f1d0';\n}\n.zmdi-spellcheck:before {\n  content: '\\f1d1';\n}\n.zmdi-storage:before {\n  content: '\\f1d2';\n}\n.zmdi-store-24:before {\n  content: '\\f1d3';\n}\n.zmdi-store:before {\n  content: '\\f1d4';\n}\n.zmdi-subway:before {\n  content: '\\f1d5';\n}\n.zmdi-sun:before {\n  content: '\\f1d6';\n}\n.zmdi-tab-unselected:before {\n  content: '\\f1d7';\n}\n.zmdi-tab:before {\n  content: '\\f1d8';\n}\n.zmdi-tag-close:before {\n  content: '\\f1d9';\n}\n.zmdi-tag-more:before {\n  content: '\\f1da';\n}\n.zmdi-tag:before {\n  content: '\\f1db';\n}\n.zmdi-thumb-down:before {\n  content: '\\f1dc';\n}\n.zmdi-thumb-up-down:before {\n  content: '\\f1dd';\n}\n.zmdi-thumb-up:before {\n  content: '\\f1de';\n}\n.zmdi-ticket-star:before {\n  content: '\\f1df';\n}\n.zmdi-toll:before {\n  content: '\\f1e0';\n}\n.zmdi-toys:before {\n  content: '\\f1e1';\n}\n.zmdi-traffic:before {\n  content: '\\f1e2';\n}\n.zmdi-translate:before {\n  content: '\\f1e3';\n}\n.zmdi-triangle-down:before {\n  content: '\\f1e4';\n}\n.zmdi-triangle-up:before {\n  content: '\\f1e5';\n}\n.zmdi-truck:before {\n  content: '\\f1e6';\n}\n.zmdi-turning-sign:before {\n  content: '\\f1e7';\n}\n.zmdi-wallpaper:before {\n  content: '\\f1e8';\n}\n.zmdi-washing-machine:before {\n  content: '\\f1e9';\n}\n.zmdi-window-maximize:before {\n  content: '\\f1ea';\n}\n.zmdi-window-minimize:before {\n  content: '\\f1eb';\n}\n.zmdi-window-restore:before {\n  content: '\\f1ec';\n}\n.zmdi-wrench:before {\n  content: '\\f1ed';\n}\n.zmdi-zoom-in:before {\n  content: '\\f1ee';\n}\n.zmdi-zoom-out:before {\n  content: '\\f1ef';\n}\n.zmdi-alert-circle-o:before {\n  content: '\\f1f0';\n}\n.zmdi-alert-circle:before {\n  content: '\\f1f1';\n}\n.zmdi-alert-octagon:before {\n  content: '\\f1f2';\n}\n.zmdi-alert-polygon:before {\n  content: '\\f1f3';\n}\n.zmdi-alert-triangle:before {\n  content: '\\f1f4';\n}\n.zmdi-help-outline:before {\n  content: '\\f1f5';\n}\n.zmdi-help:before {\n  content: '\\f1f6';\n}\n.zmdi-info-outline:before {\n  content: '\\f1f7';\n}\n.zmdi-info:before {\n  content: '\\f1f8';\n}\n.zmdi-notifications-active:before {\n  content: '\\f1f9';\n}\n.zmdi-notifications-add:before {\n  content: '\\f1fa';\n}\n.zmdi-notifications-none:before {\n  content: '\\f1fb';\n}\n.zmdi-notifications-off:before {\n  content: '\\f1fc';\n}\n.zmdi-notifications-paused:before {\n  content: '\\f1fd';\n}\n.zmdi-notifications:before {\n  content: '\\f1fe';\n}\n.zmdi-account-add:before {\n  content: '\\f1ff';\n}\n.zmdi-account-box-mail:before {\n  content: '\\f200';\n}\n.zmdi-account-box-o:before {\n  content: '\\f201';\n}\n.zmdi-account-box-phone:before {\n  content: '\\f202';\n}\n.zmdi-account-box:before {\n  content: '\\f203';\n}\n.zmdi-account-calendar:before {\n  content: '\\f204';\n}\n.zmdi-account-circle:before {\n  content: '\\f205';\n}\n.zmdi-account-o:before {\n  content: '\\f206';\n}\n.zmdi-account:before {\n  content: '\\f207';\n}\n.zmdi-accounts-add:before {\n  content: '\\f208';\n}\n.zmdi-accounts-alt:before {\n  content: '\\f209';\n}\n.zmdi-accounts-list-alt:before {\n  content: '\\f20a';\n}\n.zmdi-accounts-list:before {\n  content: '\\f20b';\n}\n.zmdi-accounts-outline:before {\n  content: '\\f20c';\n}\n.zmdi-accounts:before {\n  content: '\\f20d';\n}\n.zmdi-face:before {\n  content: '\\f20e';\n}\n.zmdi-female:before {\n  content: '\\f20f';\n}\n.zmdi-male-alt:before {\n  content: '\\f210';\n}\n.zmdi-male-female:before {\n  content: '\\f211';\n}\n.zmdi-male:before {\n  content: '\\f212';\n}\n.zmdi-mood-bad:before {\n  content: '\\f213';\n}\n.zmdi-mood:before {\n  content: '\\f214';\n}\n.zmdi-run:before {\n  content: '\\f215';\n}\n.zmdi-walk:before {\n  content: '\\f216';\n}\n.zmdi-cloud-box:before {\n  content: '\\f217';\n}\n.zmdi-cloud-circle:before {\n  content: '\\f218';\n}\n.zmdi-cloud-done:before {\n  content: '\\f219';\n}\n.zmdi-cloud-download:before {\n  content: '\\f21a';\n}\n.zmdi-cloud-off:before {\n  content: '\\f21b';\n}\n.zmdi-cloud-outline-alt:before {\n  content: '\\f21c';\n}\n.zmdi-cloud-outline:before {\n  content: '\\f21d';\n}\n.zmdi-cloud-upload:before {\n  content: '\\f21e';\n}\n.zmdi-cloud:before {\n  content: '\\f21f';\n}\n.zmdi-download:before {\n  content: '\\f220';\n}\n.zmdi-file-plus:before {\n  content: '\\f221';\n}\n.zmdi-file-text:before {\n  content: '\\f222';\n}\n.zmdi-file:before {\n  content: '\\f223';\n}\n.zmdi-folder-outline:before {\n  content: '\\f224';\n}\n.zmdi-folder-person:before {\n  content: '\\f225';\n}\n.zmdi-folder-star-alt:before {\n  content: '\\f226';\n}\n.zmdi-folder-star:before {\n  content: '\\f227';\n}\n.zmdi-folder:before {\n  content: '\\f228';\n}\n.zmdi-gif:before {\n  content: '\\f229';\n}\n.zmdi-upload:before {\n  content: '\\f22a';\n}\n.zmdi-border-all:before {\n  content: '\\f22b';\n}\n.zmdi-border-bottom:before {\n  content: '\\f22c';\n}\n.zmdi-border-clear:before {\n  content: '\\f22d';\n}\n.zmdi-border-color:before {\n  content: '\\f22e';\n}\n.zmdi-border-horizontal:before {\n  content: '\\f22f';\n}\n.zmdi-border-inner:before {\n  content: '\\f230';\n}\n.zmdi-border-left:before {\n  content: '\\f231';\n}\n.zmdi-border-outer:before {\n  content: '\\f232';\n}\n.zmdi-border-right:before {\n  content: '\\f233';\n}\n.zmdi-border-style:before {\n  content: '\\f234';\n}\n.zmdi-border-top:before {\n  content: '\\f235';\n}\n.zmdi-border-vertical:before {\n  content: '\\f236';\n}\n.zmdi-copy:before {\n  content: '\\f237';\n}\n.zmdi-crop:before {\n  content: '\\f238';\n}\n.zmdi-format-align-center:before {\n  content: '\\f239';\n}\n.zmdi-format-align-justify:before {\n  content: '\\f23a';\n}\n.zmdi-format-align-left:before {\n  content: '\\f23b';\n}\n.zmdi-format-align-right:before {\n  content: '\\f23c';\n}\n.zmdi-format-bold:before {\n  content: '\\f23d';\n}\n.zmdi-format-clear-all:before {\n  content: '\\f23e';\n}\n.zmdi-format-clear:before {\n  content: '\\f23f';\n}\n.zmdi-format-color-fill:before {\n  content: '\\f240';\n}\n.zmdi-format-color-reset:before {\n  content: '\\f241';\n}\n.zmdi-format-color-text:before {\n  content: '\\f242';\n}\n.zmdi-format-indent-decrease:before {\n  content: '\\f243';\n}\n.zmdi-format-indent-increase:before {\n  content: '\\f244';\n}\n.zmdi-format-italic:before {\n  content: '\\f245';\n}\n.zmdi-format-line-spacing:before {\n  content: '\\f246';\n}\n.zmdi-format-list-bulleted:before {\n  content: '\\f247';\n}\n.zmdi-format-list-numbered:before {\n  content: '\\f248';\n}\n.zmdi-format-ltr:before {\n  content: '\\f249';\n}\n.zmdi-format-rtl:before {\n  content: '\\f24a';\n}\n.zmdi-format-size:before {\n  content: '\\f24b';\n}\n.zmdi-format-strikethrough-s:before {\n  content: '\\f24c';\n}\n.zmdi-format-strikethrough:before {\n  content: '\\f24d';\n}\n.zmdi-format-subject:before {\n  content: '\\f24e';\n}\n.zmdi-format-underlined:before {\n  content: '\\f24f';\n}\n.zmdi-format-valign-bottom:before {\n  content: '\\f250';\n}\n.zmdi-format-valign-center:before {\n  content: '\\f251';\n}\n.zmdi-format-valign-top:before {\n  content: '\\f252';\n}\n.zmdi-redo:before {\n  content: '\\f253';\n}\n.zmdi-select-all:before {\n  content: '\\f254';\n}\n.zmdi-space-bar:before {\n  content: '\\f255';\n}\n.zmdi-text-format:before {\n  content: '\\f256';\n}\n.zmdi-transform:before {\n  content: '\\f257';\n}\n.zmdi-undo:before {\n  content: '\\f258';\n}\n.zmdi-wrap-text:before {\n  content: '\\f259';\n}\n.zmdi-comment-alert:before {\n  content: '\\f25a';\n}\n.zmdi-comment-alt-text:before {\n  content: '\\f25b';\n}\n.zmdi-comment-alt:before {\n  content: '\\f25c';\n}\n.zmdi-comment-edit:before {\n  content: '\\f25d';\n}\n.zmdi-comment-image:before {\n  content: '\\f25e';\n}\n.zmdi-comment-list:before {\n  content: '\\f25f';\n}\n.zmdi-comment-more:before {\n  content: '\\f260';\n}\n.zmdi-comment-outline:before {\n  content: '\\f261';\n}\n.zmdi-comment-text-alt:before {\n  content: '\\f262';\n}\n.zmdi-comment-text:before {\n  content: '\\f263';\n}\n.zmdi-comment-video:before {\n  content: '\\f264';\n}\n.zmdi-comment:before {\n  content: '\\f265';\n}\n.zmdi-comments:before {\n  content: '\\f266';\n}\n.zmdi-check-all:before {\n  content: '\\f267';\n}\n.zmdi-check-circle-u:before {\n  content: '\\f268';\n}\n.zmdi-check-circle:before {\n  content: '\\f269';\n}\n.zmdi-check-square:before {\n  content: '\\f26a';\n}\n.zmdi-check:before {\n  content: '\\f26b';\n}\n.zmdi-circle-o:before {\n  content: '\\f26c';\n}\n.zmdi-circle:before {\n  content: '\\f26d';\n}\n.zmdi-dot-circle-alt:before {\n  content: '\\f26e';\n}\n.zmdi-dot-circle:before {\n  content: '\\f26f';\n}\n.zmdi-minus-circle-outline:before {\n  content: '\\f270';\n}\n.zmdi-minus-circle:before {\n  content: '\\f271';\n}\n.zmdi-minus-square:before {\n  content: '\\f272';\n}\n.zmdi-minus:before {\n  content: '\\f273';\n}\n.zmdi-plus-circle-o-duplicate:before {\n  content: '\\f274';\n}\n.zmdi-plus-circle-o:before {\n  content: '\\f275';\n}\n.zmdi-plus-circle:before {\n  content: '\\f276';\n}\n.zmdi-plus-square:before {\n  content: '\\f277';\n}\n.zmdi-plus:before {\n  content: '\\f278';\n}\n.zmdi-square-o:before {\n  content: '\\f279';\n}\n.zmdi-star-circle:before {\n  content: '\\f27a';\n}\n.zmdi-star-half:before {\n  content: '\\f27b';\n}\n.zmdi-star-outline:before {\n  content: '\\f27c';\n}\n.zmdi-star:before {\n  content: '\\f27d';\n}\n.zmdi-bluetooth-connected:before {\n  content: '\\f27e';\n}\n.zmdi-bluetooth-off:before {\n  content: '\\f27f';\n}\n.zmdi-bluetooth-search:before {\n  content: '\\f280';\n}\n.zmdi-bluetooth-setting:before {\n  content: '\\f281';\n}\n.zmdi-bluetooth:before {\n  content: '\\f282';\n}\n.zmdi-camera-add:before {\n  content: '\\f283';\n}\n.zmdi-camera-alt:before {\n  content: '\\f284';\n}\n.zmdi-camera-bw:before {\n  content: '\\f285';\n}\n.zmdi-camera-front:before {\n  content: '\\f286';\n}\n.zmdi-camera-mic:before {\n  content: '\\f287';\n}\n.zmdi-camera-party-mode:before {\n  content: '\\f288';\n}\n.zmdi-camera-rear:before {\n  content: '\\f289';\n}\n.zmdi-camera-roll:before {\n  content: '\\f28a';\n}\n.zmdi-camera-switch:before {\n  content: '\\f28b';\n}\n.zmdi-camera:before {\n  content: '\\f28c';\n}\n.zmdi-card-alert:before {\n  content: '\\f28d';\n}\n.zmdi-card-off:before {\n  content: '\\f28e';\n}\n.zmdi-card-sd:before {\n  content: '\\f28f';\n}\n.zmdi-card-sim:before {\n  content: '\\f290';\n}\n.zmdi-desktop-mac:before {\n  content: '\\f291';\n}\n.zmdi-desktop-windows:before {\n  content: '\\f292';\n}\n.zmdi-device-hub:before {\n  content: '\\f293';\n}\n.zmdi-devices-off:before {\n  content: '\\f294';\n}\n.zmdi-devices:before {\n  content: '\\f295';\n}\n.zmdi-dock:before {\n  content: '\\f296';\n}\n.zmdi-floppy:before {\n  content: '\\f297';\n}\n.zmdi-gamepad:before {\n  content: '\\f298';\n}\n.zmdi-gps-dot:before {\n  content: '\\f299';\n}\n.zmdi-gps-off:before {\n  content: '\\f29a';\n}\n.zmdi-gps:before {\n  content: '\\f29b';\n}\n.zmdi-headset-mic:before {\n  content: '\\f29c';\n}\n.zmdi-headset:before {\n  content: '\\f29d';\n}\n.zmdi-input-antenna:before {\n  content: '\\f29e';\n}\n.zmdi-input-composite:before {\n  content: '\\f29f';\n}\n.zmdi-input-hdmi:before {\n  content: '\\f2a0';\n}\n.zmdi-input-power:before {\n  content: '\\f2a1';\n}\n.zmdi-input-svideo:before {\n  content: '\\f2a2';\n}\n.zmdi-keyboard-hide:before {\n  content: '\\f2a3';\n}\n.zmdi-keyboard:before {\n  content: '\\f2a4';\n}\n.zmdi-laptop-chromebook:before {\n  content: '\\f2a5';\n}\n.zmdi-laptop-mac:before {\n  content: '\\f2a6';\n}\n.zmdi-laptop:before {\n  content: '\\f2a7';\n}\n.zmdi-mic-off:before {\n  content: '\\f2a8';\n}\n.zmdi-mic-outline:before {\n  content: '\\f2a9';\n}\n.zmdi-mic-setting:before {\n  content: '\\f2aa';\n}\n.zmdi-mic:before {\n  content: '\\f2ab';\n}\n.zmdi-mouse:before {\n  content: '\\f2ac';\n}\n.zmdi-network-alert:before {\n  content: '\\f2ad';\n}\n.zmdi-network-locked:before {\n  content: '\\f2ae';\n}\n.zmdi-network-off:before {\n  content: '\\f2af';\n}\n.zmdi-network-outline:before {\n  content: '\\f2b0';\n}\n.zmdi-network-setting:before {\n  content: '\\f2b1';\n}\n.zmdi-network:before {\n  content: '\\f2b2';\n}\n.zmdi-phone-bluetooth:before {\n  content: '\\f2b3';\n}\n.zmdi-phone-end:before {\n  content: '\\f2b4';\n}\n.zmdi-phone-forwarded:before {\n  content: '\\f2b5';\n}\n.zmdi-phone-in-talk:before {\n  content: '\\f2b6';\n}\n.zmdi-phone-locked:before {\n  content: '\\f2b7';\n}\n.zmdi-phone-missed:before {\n  content: '\\f2b8';\n}\n.zmdi-phone-msg:before {\n  content: '\\f2b9';\n}\n.zmdi-phone-paused:before {\n  content: '\\f2ba';\n}\n.zmdi-phone-ring:before {\n  content: '\\f2bb';\n}\n.zmdi-phone-setting:before {\n  content: '\\f2bc';\n}\n.zmdi-phone-sip:before {\n  content: '\\f2bd';\n}\n.zmdi-phone:before {\n  content: '\\f2be';\n}\n.zmdi-portable-wifi-changes:before {\n  content: '\\f2bf';\n}\n.zmdi-portable-wifi-off:before {\n  content: '\\f2c0';\n}\n.zmdi-portable-wifi:before {\n  content: '\\f2c1';\n}\n.zmdi-radio:before {\n  content: '\\f2c2';\n}\n.zmdi-reader:before {\n  content: '\\f2c3';\n}\n.zmdi-remote-control-alt:before {\n  content: '\\f2c4';\n}\n.zmdi-remote-control:before {\n  content: '\\f2c5';\n}\n.zmdi-router:before {\n  content: '\\f2c6';\n}\n.zmdi-scanner:before {\n  content: '\\f2c7';\n}\n.zmdi-smartphone-android:before {\n  content: '\\f2c8';\n}\n.zmdi-smartphone-download:before {\n  content: '\\f2c9';\n}\n.zmdi-smartphone-erase:before {\n  content: '\\f2ca';\n}\n.zmdi-smartphone-info:before {\n  content: '\\f2cb';\n}\n.zmdi-smartphone-iphone:before {\n  content: '\\f2cc';\n}\n.zmdi-smartphone-landscape-lock:before {\n  content: '\\f2cd';\n}\n.zmdi-smartphone-landscape:before {\n  content: '\\f2ce';\n}\n.zmdi-smartphone-lock:before {\n  content: '\\f2cf';\n}\n.zmdi-smartphone-portrait-lock:before {\n  content: '\\f2d0';\n}\n.zmdi-smartphone-ring:before {\n  content: '\\f2d1';\n}\n.zmdi-smartphone-setting:before {\n  content: '\\f2d2';\n}\n.zmdi-smartphone-setup:before {\n  content: '\\f2d3';\n}\n.zmdi-smartphone:before {\n  content: '\\f2d4';\n}\n.zmdi-speaker:before {\n  content: '\\f2d5';\n}\n.zmdi-tablet-android:before {\n  content: '\\f2d6';\n}\n.zmdi-tablet-mac:before {\n  content: '\\f2d7';\n}\n.zmdi-tablet:before {\n  content: '\\f2d8';\n}\n.zmdi-tv-alt-play:before {\n  content: '\\f2d9';\n}\n.zmdi-tv-list:before {\n  content: '\\f2da';\n}\n.zmdi-tv-play:before {\n  content: '\\f2db';\n}\n.zmdi-tv:before {\n  content: '\\f2dc';\n}\n.zmdi-usb:before {\n  content: '\\f2dd';\n}\n.zmdi-videocam-off:before {\n  content: '\\f2de';\n}\n.zmdi-videocam-switch:before {\n  content: '\\f2df';\n}\n.zmdi-videocam:before {\n  content: '\\f2e0';\n}\n.zmdi-watch:before {\n  content: '\\f2e1';\n}\n.zmdi-wifi-alt-2:before {\n  content: '\\f2e2';\n}\n.zmdi-wifi-alt:before {\n  content: '\\f2e3';\n}\n.zmdi-wifi-info:before {\n  content: '\\f2e4';\n}\n.zmdi-wifi-lock:before {\n  content: '\\f2e5';\n}\n.zmdi-wifi-off:before {\n  content: '\\f2e6';\n}\n.zmdi-wifi-outline:before {\n  content: '\\f2e7';\n}\n.zmdi-wifi:before {\n  content: '\\f2e8';\n}\n.zmdi-arrow-left-bottom:before {\n  content: '\\f2e9';\n}\n.zmdi-arrow-left:before {\n  content: '\\f2ea';\n}\n.zmdi-arrow-merge:before {\n  content: '\\f2eb';\n}\n.zmdi-arrow-missed:before {\n  content: '\\f2ec';\n}\n.zmdi-arrow-right-top:before {\n  content: '\\f2ed';\n}\n.zmdi-arrow-right:before {\n  content: '\\f2ee';\n}\n.zmdi-arrow-split:before {\n  content: '\\f2ef';\n}\n.zmdi-arrows:before {\n  content: '\\f2f0';\n}\n.zmdi-caret-down-circle:before {\n  content: '\\f2f1';\n}\n.zmdi-caret-down:before {\n  content: '\\f2f2';\n}\n.zmdi-caret-left-circle:before {\n  content: '\\f2f3';\n}\n.zmdi-caret-left:before {\n  content: '\\f2f4';\n}\n.zmdi-caret-right-circle:before {\n  content: '\\f2f5';\n}\n.zmdi-caret-right:before {\n  content: '\\f2f6';\n}\n.zmdi-caret-up-circle:before {\n  content: '\\f2f7';\n}\n.zmdi-caret-up:before {\n  content: '\\f2f8';\n}\n.zmdi-chevron-down:before {\n  content: '\\f2f9';\n}\n.zmdi-chevron-left:before {\n  content: '\\f2fa';\n}\n.zmdi-chevron-right:before {\n  content: '\\f2fb';\n}\n.zmdi-chevron-up:before {\n  content: '\\f2fc';\n}\n.zmdi-forward:before {\n  content: '\\f2fd';\n}\n.zmdi-long-arrow-down:before {\n  content: '\\f2fe';\n}\n.zmdi-long-arrow-left:before {\n  content: '\\f2ff';\n}\n.zmdi-long-arrow-return:before {\n  content: '\\f300';\n}\n.zmdi-long-arrow-right:before {\n  content: '\\f301';\n}\n.zmdi-long-arrow-tab:before {\n  content: '\\f302';\n}\n.zmdi-long-arrow-up:before {\n  content: '\\f303';\n}\n.zmdi-rotate-ccw:before {\n  content: '\\f304';\n}\n.zmdi-rotate-cw:before {\n  content: '\\f305';\n}\n.zmdi-rotate-left:before {\n  content: '\\f306';\n}\n.zmdi-rotate-right:before {\n  content: '\\f307';\n}\n.zmdi-square-down:before {\n  content: '\\f308';\n}\n.zmdi-square-right:before {\n  content: '\\f309';\n}\n.zmdi-swap-alt:before {\n  content: '\\f30a';\n}\n.zmdi-swap-vertical-circle:before {\n  content: '\\f30b';\n}\n.zmdi-swap-vertical:before {\n  content: '\\f30c';\n}\n.zmdi-swap:before {\n  content: '\\f30d';\n}\n.zmdi-trending-down:before {\n  content: '\\f30e';\n}\n.zmdi-trending-flat:before {\n  content: '\\f30f';\n}\n.zmdi-trending-up:before {\n  content: '\\f310';\n}\n.zmdi-unfold-less:before {\n  content: '\\f311';\n}\n.zmdi-unfold-more:before {\n  content: '\\f312';\n}\n.zmdi-apps:before {\n  content: '\\f313';\n}\n.zmdi-grid-off:before {\n  content: '\\f314';\n}\n.zmdi-grid:before {\n  content: '\\f315';\n}\n.zmdi-view-agenda:before {\n  content: '\\f316';\n}\n.zmdi-view-array:before {\n  content: '\\f317';\n}\n.zmdi-view-carousel:before {\n  content: '\\f318';\n}\n.zmdi-view-column:before {\n  content: '\\f319';\n}\n.zmdi-view-comfy:before {\n  content: '\\f31a';\n}\n.zmdi-view-compact:before {\n  content: '\\f31b';\n}\n.zmdi-view-dashboard:before {\n  content: '\\f31c';\n}\n.zmdi-view-day:before {\n  content: '\\f31d';\n}\n.zmdi-view-headline:before {\n  content: '\\f31e';\n}\n.zmdi-view-list-alt:before {\n  content: '\\f31f';\n}\n.zmdi-view-list:before {\n  content: '\\f320';\n}\n.zmdi-view-module:before {\n  content: '\\f321';\n}\n.zmdi-view-quilt:before {\n  content: '\\f322';\n}\n.zmdi-view-stream:before {\n  content: '\\f323';\n}\n.zmdi-view-subtitles:before {\n  content: '\\f324';\n}\n.zmdi-view-toc:before {\n  content: '\\f325';\n}\n.zmdi-view-web:before {\n  content: '\\f326';\n}\n.zmdi-view-week:before {\n  content: '\\f327';\n}\n.zmdi-widgets:before {\n  content: '\\f328';\n}\n.zmdi-alarm-check:before {\n  content: '\\f329';\n}\n.zmdi-alarm-off:before {\n  content: '\\f32a';\n}\n.zmdi-alarm-plus:before {\n  content: '\\f32b';\n}\n.zmdi-alarm-snooze:before {\n  content: '\\f32c';\n}\n.zmdi-alarm:before {\n  content: '\\f32d';\n}\n.zmdi-calendar-alt:before {\n  content: '\\f32e';\n}\n.zmdi-calendar-check:before {\n  content: '\\f32f';\n}\n.zmdi-calendar-close:before {\n  content: '\\f330';\n}\n.zmdi-calendar-note:before {\n  content: '\\f331';\n}\n.zmdi-calendar:before {\n  content: '\\f332';\n}\n.zmdi-time-countdown:before {\n  content: '\\f333';\n}\n.zmdi-time-interval:before {\n  content: '\\f334';\n}\n.zmdi-time-restore-setting:before {\n  content: '\\f335';\n}\n.zmdi-time-restore:before {\n  content: '\\f336';\n}\n.zmdi-time:before {\n  content: '\\f337';\n}\n.zmdi-timer-off:before {\n  content: '\\f338';\n}\n.zmdi-timer:before {\n  content: '\\f339';\n}\n.zmdi-android-alt:before {\n  content: '\\f33a';\n}\n.zmdi-android:before {\n  content: '\\f33b';\n}\n.zmdi-apple:before {\n  content: '\\f33c';\n}\n.zmdi-behance:before {\n  content: '\\f33d';\n}\n.zmdi-codepen:before {\n  content: '\\f33e';\n}\n.zmdi-dribbble:before {\n  content: '\\f33f';\n}\n.zmdi-dropbox:before {\n  content: '\\f340';\n}\n.zmdi-evernote:before {\n  content: '\\f341';\n}\n.zmdi-facebook-box:before {\n  content: '\\f342';\n}\n.zmdi-facebook:before {\n  content: '\\f343';\n}\n.zmdi-github-box:before {\n  content: '\\f344';\n}\n.zmdi-github:before {\n  content: '\\f345';\n}\n.zmdi-google-drive:before {\n  content: '\\f346';\n}\n.zmdi-google-earth:before {\n  content: '\\f347';\n}\n.zmdi-google-glass:before {\n  content: '\\f348';\n}\n.zmdi-google-maps:before {\n  content: '\\f349';\n}\n.zmdi-google-pages:before {\n  content: '\\f34a';\n}\n.zmdi-google-play:before {\n  content: '\\f34b';\n}\n.zmdi-google-plus-box:before {\n  content: '\\f34c';\n}\n.zmdi-google-plus:before {\n  content: '\\f34d';\n}\n.zmdi-google:before {\n  content: '\\f34e';\n}\n.zmdi-instagram:before {\n  content: '\\f34f';\n}\n.zmdi-language-css3:before {\n  content: '\\f350';\n}\n.zmdi-language-html5:before {\n  content: '\\f351';\n}\n.zmdi-language-javascript:before {\n  content: '\\f352';\n}\n.zmdi-language-python-alt:before {\n  content: '\\f353';\n}\n.zmdi-language-python:before {\n  content: '\\f354';\n}\n.zmdi-lastfm:before {\n  content: '\\f355';\n}\n.zmdi-linkedin-box:before {\n  content: '\\f356';\n}\n.zmdi-paypal:before {\n  content: '\\f357';\n}\n.zmdi-pinterest-box:before {\n  content: '\\f358';\n}\n.zmdi-pocket:before {\n  content: '\\f359';\n}\n.zmdi-polymer:before {\n  content: '\\f35a';\n}\n.zmdi-share:before {\n  content: '\\f35b';\n}\n.zmdi-stackoverflow:before {\n  content: '\\f35c';\n}\n.zmdi-steam-square:before {\n  content: '\\f35d';\n}\n.zmdi-steam:before {\n  content: '\\f35e';\n}\n.zmdi-twitter-box:before {\n  content: '\\f35f';\n}\n.zmdi-twitter:before {\n  content: '\\f360';\n}\n.zmdi-vk:before {\n  content: '\\f361';\n}\n.zmdi-wikipedia:before {\n  content: '\\f362';\n}\n.zmdi-windows:before {\n  content: '\\f363';\n}\n.zmdi-aspect-ratio-alt:before {\n  content: '\\f364';\n}\n.zmdi-aspect-ratio:before {\n  content: '\\f365';\n}\n.zmdi-blur-circular:before {\n  content: '\\f366';\n}\n.zmdi-blur-linear:before {\n  content: '\\f367';\n}\n.zmdi-blur-off:before {\n  content: '\\f368';\n}\n.zmdi-blur:before {\n  content: '\\f369';\n}\n.zmdi-brightness-2:before {\n  content: '\\f36a';\n}\n.zmdi-brightness-3:before {\n  content: '\\f36b';\n}\n.zmdi-brightness-4:before {\n  content: '\\f36c';\n}\n.zmdi-brightness-5:before {\n  content: '\\f36d';\n}\n.zmdi-brightness-6:before {\n  content: '\\f36e';\n}\n.zmdi-brightness-7:before {\n  content: '\\f36f';\n}\n.zmdi-brightness-auto:before {\n  content: '\\f370';\n}\n.zmdi-brightness-setting:before {\n  content: '\\f371';\n}\n.zmdi-broken-image:before {\n  content: '\\f372';\n}\n.zmdi-center-focus-strong:before {\n  content: '\\f373';\n}\n.zmdi-center-focus-weak:before {\n  content: '\\f374';\n}\n.zmdi-compare:before {\n  content: '\\f375';\n}\n.zmdi-crop-16-9:before {\n  content: '\\f376';\n}\n.zmdi-crop-3-2:before {\n  content: '\\f377';\n}\n.zmdi-crop-5-4:before {\n  content: '\\f378';\n}\n.zmdi-crop-7-5:before {\n  content: '\\f379';\n}\n.zmdi-crop-din:before {\n  content: '\\f37a';\n}\n.zmdi-crop-free:before {\n  content: '\\f37b';\n}\n.zmdi-crop-landscape:before {\n  content: '\\f37c';\n}\n.zmdi-crop-portrait:before {\n  content: '\\f37d';\n}\n.zmdi-crop-square:before {\n  content: '\\f37e';\n}\n.zmdi-exposure-alt:before {\n  content: '\\f37f';\n}\n.zmdi-exposure:before {\n  content: '\\f380';\n}\n.zmdi-filter-b-and-w:before {\n  content: '\\f381';\n}\n.zmdi-filter-center-focus:before {\n  content: '\\f382';\n}\n.zmdi-filter-frames:before {\n  content: '\\f383';\n}\n.zmdi-filter-tilt-shift:before {\n  content: '\\f384';\n}\n.zmdi-gradient:before {\n  content: '\\f385';\n}\n.zmdi-grain:before {\n  content: '\\f386';\n}\n.zmdi-graphic-eq:before {\n  content: '\\f387';\n}\n.zmdi-hdr-off:before {\n  content: '\\f388';\n}\n.zmdi-hdr-strong:before {\n  content: '\\f389';\n}\n.zmdi-hdr-weak:before {\n  content: '\\f38a';\n}\n.zmdi-hdr:before {\n  content: '\\f38b';\n}\n.zmdi-iridescent:before {\n  content: '\\f38c';\n}\n.zmdi-leak-off:before {\n  content: '\\f38d';\n}\n.zmdi-leak:before {\n  content: '\\f38e';\n}\n.zmdi-looks:before {\n  content: '\\f38f';\n}\n.zmdi-loupe:before {\n  content: '\\f390';\n}\n.zmdi-panorama-horizontal:before {\n  content: '\\f391';\n}\n.zmdi-panorama-vertical:before {\n  content: '\\f392';\n}\n.zmdi-panorama-wide-angle:before {\n  content: '\\f393';\n}\n.zmdi-photo-size-select-large:before {\n  content: '\\f394';\n}\n.zmdi-photo-size-select-small:before {\n  content: '\\f395';\n}\n.zmdi-picture-in-picture:before {\n  content: '\\f396';\n}\n.zmdi-slideshow:before {\n  content: '\\f397';\n}\n.zmdi-texture:before {\n  content: '\\f398';\n}\n.zmdi-tonality:before {\n  content: '\\f399';\n}\n.zmdi-vignette:before {\n  content: '\\f39a';\n}\n.zmdi-wb-auto:before {\n  content: '\\f39b';\n}\n.zmdi-eject-alt:before {\n  content: '\\f39c';\n}\n.zmdi-eject:before {\n  content: '\\f39d';\n}\n.zmdi-equalizer:before {\n  content: '\\f39e';\n}\n.zmdi-fast-forward:before {\n  content: '\\f39f';\n}\n.zmdi-fast-rewind:before {\n  content: '\\f3a0';\n}\n.zmdi-forward-10:before {\n  content: '\\f3a1';\n}\n.zmdi-forward-30:before {\n  content: '\\f3a2';\n}\n.zmdi-forward-5:before {\n  content: '\\f3a3';\n}\n.zmdi-hearing:before {\n  content: '\\f3a4';\n}\n.zmdi-pause-circle-outline:before {\n  content: '\\f3a5';\n}\n.zmdi-pause-circle:before {\n  content: '\\f3a6';\n}\n.zmdi-pause:before {\n  content: '\\f3a7';\n}\n.zmdi-play-circle-outline:before {\n  content: '\\f3a8';\n}\n.zmdi-play-circle:before {\n  content: '\\f3a9';\n}\n.zmdi-play:before {\n  content: '\\f3aa';\n}\n.zmdi-playlist-audio:before {\n  content: '\\f3ab';\n}\n.zmdi-playlist-plus:before {\n  content: '\\f3ac';\n}\n.zmdi-repeat-one:before {\n  content: '\\f3ad';\n}\n.zmdi-repeat:before {\n  content: '\\f3ae';\n}\n.zmdi-replay-10:before {\n  content: '\\f3af';\n}\n.zmdi-replay-30:before {\n  content: '\\f3b0';\n}\n.zmdi-replay-5:before {\n  content: '\\f3b1';\n}\n.zmdi-replay:before {\n  content: '\\f3b2';\n}\n.zmdi-shuffle:before {\n  content: '\\f3b3';\n}\n.zmdi-skip-next:before {\n  content: '\\f3b4';\n}\n.zmdi-skip-previous:before {\n  content: '\\f3b5';\n}\n.zmdi-stop:before {\n  content: '\\f3b6';\n}\n.zmdi-surround-sound:before {\n  content: '\\f3b7';\n}\n.zmdi-tune:before {\n  content: '\\f3b8';\n}\n.zmdi-volume-down:before {\n  content: '\\f3b9';\n}\n.zmdi-volume-mute:before {\n  content: '\\f3ba';\n}\n.zmdi-volume-off:before {\n  content: '\\f3bb';\n}\n.zmdi-volume-up:before {\n  content: '\\f3bc';\n}\n.zmdi-n-1-square:before {\n  content: '\\f3bd';\n}\n.zmdi-n-2-square:before {\n  content: '\\f3be';\n}\n.zmdi-n-3-square:before {\n  content: '\\f3bf';\n}\n.zmdi-n-4-square:before {\n  content: '\\f3c0';\n}\n.zmdi-n-5-square:before {\n  content: '\\f3c1';\n}\n.zmdi-n-6-square:before {\n  content: '\\f3c2';\n}\n.zmdi-neg-1:before {\n  content: '\\f3c3';\n}\n.zmdi-neg-2:before {\n  content: '\\f3c4';\n}\n.zmdi-plus-1:before {\n  content: '\\f3c5';\n}\n.zmdi-plus-2:before {\n  content: '\\f3c6';\n}\n.zmdi-sec-10:before {\n  content: '\\f3c7';\n}\n.zmdi-sec-3:before {\n  content: '\\f3c8';\n}\n.zmdi-zero:before {\n  content: '\\f3c9';\n}\n.zmdi-airline-seat-flat-angled:before {\n  content: '\\f3ca';\n}\n.zmdi-airline-seat-flat:before {\n  content: '\\f3cb';\n}\n.zmdi-airline-seat-individual-suite:before {\n  content: '\\f3cc';\n}\n.zmdi-airline-seat-legroom-extra:before {\n  content: '\\f3cd';\n}\n.zmdi-airline-seat-legroom-normal:before {\n  content: '\\f3ce';\n}\n.zmdi-airline-seat-legroom-reduced:before {\n  content: '\\f3cf';\n}\n.zmdi-airline-seat-recline-extra:before {\n  content: '\\f3d0';\n}\n.zmdi-airline-seat-recline-normal:before {\n  content: '\\f3d1';\n}\n.zmdi-airplay:before {\n  content: '\\f3d2';\n}\n.zmdi-closed-caption:before {\n  content: '\\f3d3';\n}\n.zmdi-confirmation-number:before {\n  content: '\\f3d4';\n}\n.zmdi-developer-board:before {\n  content: '\\f3d5';\n}\n.zmdi-disc-full:before {\n  content: '\\f3d6';\n}\n.zmdi-explicit:before {\n  content: '\\f3d7';\n}\n.zmdi-flight-land:before {\n  content: '\\f3d8';\n}\n.zmdi-flight-takeoff:before {\n  content: '\\f3d9';\n}\n.zmdi-flip-to-back:before {\n  content: '\\f3da';\n}\n.zmdi-flip-to-front:before {\n  content: '\\f3db';\n}\n.zmdi-group-work:before {\n  content: '\\f3dc';\n}\n.zmdi-hd:before {\n  content: '\\f3dd';\n}\n.zmdi-hq:before {\n  content: '\\f3de';\n}\n.zmdi-markunread-mailbox:before {\n  content: '\\f3df';\n}\n.zmdi-memory:before {\n  content: '\\f3e0';\n}\n.zmdi-nfc:before {\n  content: '\\f3e1';\n}\n.zmdi-play-for-work:before {\n  content: '\\f3e2';\n}\n.zmdi-power-input:before {\n  content: '\\f3e3';\n}\n.zmdi-present-to-all:before {\n  content: '\\f3e4';\n}\n.zmdi-satellite:before {\n  content: '\\f3e5';\n}\n.zmdi-tap-and-play:before {\n  content: '\\f3e6';\n}\n.zmdi-vibration:before {\n  content: '\\f3e7';\n}\n.zmdi-voicemail:before {\n  content: '\\f3e8';\n}\n.zmdi-group:before {\n  content: '\\f3e9';\n}\n.zmdi-rss:before {\n  content: '\\f3ea';\n}\n.zmdi-shape:before {\n  content: '\\f3eb';\n}\n.zmdi-spinner:before {\n  content: '\\f3ec';\n}\n.zmdi-ungroup:before {\n  content: '\\f3ed';\n}\n.zmdi-500px:before {\n  content: '\\f3ee';\n}\n.zmdi-8tracks:before {\n  content: '\\f3ef';\n}\n.zmdi-amazon:before {\n  content: '\\f3f0';\n}\n.zmdi-blogger:before {\n  content: '\\f3f1';\n}\n.zmdi-delicious:before {\n  content: '\\f3f2';\n}\n.zmdi-disqus:before {\n  content: '\\f3f3';\n}\n.zmdi-flattr:before {\n  content: '\\f3f4';\n}\n.zmdi-flickr:before {\n  content: '\\f3f5';\n}\n.zmdi-github-alt:before {\n  content: '\\f3f6';\n}\n.zmdi-google-old:before {\n  content: '\\f3f7';\n}\n.zmdi-linkedin:before {\n  content: '\\f3f8';\n}\n.zmdi-odnoklassniki:before {\n  content: '\\f3f9';\n}\n.zmdi-outlook:before {\n  content: '\\f3fa';\n}\n.zmdi-paypal-alt:before {\n  content: '\\f3fb';\n}\n.zmdi-pinterest:before {\n  content: '\\f3fc';\n}\n.zmdi-playstation:before {\n  content: '\\f3fd';\n}\n.zmdi-reddit:before {\n  content: '\\f3fe';\n}\n.zmdi-skype:before {\n  content: '\\f3ff';\n}\n.zmdi-slideshare:before {\n  content: '\\f400';\n}\n.zmdi-soundcloud:before {\n  content: '\\f401';\n}\n.zmdi-tumblr:before {\n  content: '\\f402';\n}\n.zmdi-twitch:before {\n  content: '\\f403';\n}\n.zmdi-vimeo:before {\n  content: '\\f404';\n}\n.zmdi-whatsapp:before {\n  content: '\\f405';\n}\n.zmdi-xbox:before {\n  content: '\\f406';\n}\n.zmdi-yahoo:before {\n  content: '\\f407';\n}\n.zmdi-youtube-play:before {\n  content: '\\f408';\n}\n.zmdi-youtube:before {\n  content: '\\f409';\n}\n.zmdi-import-export:before {\n  content: '\\f30c';\n}\n.zmdi-swap-vertical-:before {\n  content: '\\f30c';\n}\n.zmdi-airplanemode-inactive:before {\n  content: '\\f102';\n}\n.zmdi-airplanemode-active:before {\n  content: '\\f103';\n}\n.zmdi-rate-review:before {\n  content: '\\f103';\n}\n.zmdi-comment-sign:before {\n  content: '\\f25a';\n}\n.zmdi-network-warning:before {\n  content: '\\f2ad';\n}\n.zmdi-shopping-cart-add:before {\n  content: '\\f1ca';\n}\n.zmdi-file-add:before {\n  content: '\\f221';\n}\n.zmdi-network-wifi-scan:before {\n  content: '\\f2e4';\n}\n.zmdi-collection-add:before {\n  content: '\\f14e';\n}\n.zmdi-format-playlist-add:before {\n  content: '\\f3ac';\n}\n.zmdi-format-queue-music:before {\n  content: '\\f3ab';\n}\n.zmdi-plus-box:before {\n  content: '\\f277';\n}\n.zmdi-tag-backspace:before {\n  content: '\\f1d9';\n}\n.zmdi-alarm-add:before {\n  content: '\\f32b';\n}\n.zmdi-battery-charging:before {\n  content: '\\f114';\n}\n.zmdi-daydream-setting:before {\n  content: '\\f217';\n}\n.zmdi-more-horiz:before {\n  content: '\\f19c';\n}\n.zmdi-book-photo:before {\n  content: '\\f11b';\n}\n.zmdi-incandescent:before {\n  content: '\\f189';\n}\n.zmdi-wb-iridescent:before {\n  content: '\\f38c';\n}\n.zmdi-calendar-remove:before {\n  content: '\\f330';\n}\n.zmdi-refresh-sync-disabled:before {\n  content: '\\f1b7';\n}\n.zmdi-refresh-sync-problem:before {\n  content: '\\f1b6';\n}\n.zmdi-crop-original:before {\n  content: '\\f17e';\n}\n.zmdi-power-off:before {\n  content: '\\f1af';\n}\n.zmdi-power-off-setting:before {\n  content: '\\f1ae';\n}\n.zmdi-leak-remove:before {\n  content: '\\f38d';\n}\n.zmdi-star-border:before {\n  content: '\\f27c';\n}\n.zmdi-brightness-low:before {\n  content: '\\f36d';\n}\n.zmdi-brightness-medium:before {\n  content: '\\f36e';\n}\n.zmdi-brightness-high:before {\n  content: '\\f36f';\n}\n.zmdi-smartphone-portrait:before {\n  content: '\\f2d4';\n}\n.zmdi-live-tv:before {\n  content: '\\f2d9';\n}\n.zmdi-format-textdirection-l-to-r:before {\n  content: '\\f249';\n}\n.zmdi-format-textdirection-r-to-l:before {\n  content: '\\f24a';\n}\n.zmdi-arrow-back:before {\n  content: '\\f2ea';\n}\n.zmdi-arrow-forward:before {\n  content: '\\f2ee';\n}\n.zmdi-arrow-in:before {\n  content: '\\f2e9';\n}\n.zmdi-arrow-out:before {\n  content: '\\f2ed';\n}\n.zmdi-rotate-90-degrees-ccw:before {\n  content: '\\f304';\n}\n.zmdi-adb:before {\n  content: '\\f33a';\n}\n.zmdi-network-wifi:before {\n  content: '\\f2e8';\n}\n.zmdi-network-wifi-alt:before {\n  content: '\\f2e3';\n}\n.zmdi-network-wifi-lock:before {\n  content: '\\f2e5';\n}\n.zmdi-network-wifi-off:before {\n  content: '\\f2e6';\n}\n.zmdi-network-wifi-outline:before {\n  content: '\\f2e7';\n}\n.zmdi-network-wifi-info:before {\n  content: '\\f2e4';\n}\n.zmdi-layers-clear:before {\n  content: '\\f18b';\n}\n.zmdi-colorize:before {\n  content: '\\f15d';\n}\n.zmdi-format-paint:before {\n  content: '\\f1ba';\n}\n.zmdi-format-quote:before {\n  content: '\\f1b2';\n}\n.zmdi-camera-monochrome-photos:before {\n  content: '\\f285';\n}\n.zmdi-sort-by-alpha:before {\n  content: '\\f1cf';\n}\n.zmdi-folder-shared:before {\n  content: '\\f225';\n}\n.zmdi-folder-special:before {\n  content: '\\f226';\n}\n.zmdi-comment-dots:before {\n  content: '\\f260';\n}\n.zmdi-reorder:before {\n  content: '\\f31e';\n}\n.zmdi-dehaze:before {\n  content: '\\f197';\n}\n.zmdi-sort:before {\n  content: '\\f1ce';\n}\n.zmdi-pages:before {\n  content: '\\f34a';\n}\n.zmdi-stack-overflow:before {\n  content: '\\f35c';\n}\n.zmdi-calendar-account:before {\n  content: '\\f204';\n}\n.zmdi-paste:before {\n  content: '\\f109';\n}\n.zmdi-cut:before {\n  content: '\\f1bc';\n}\n.zmdi-save:before {\n  content: '\\f297';\n}\n.zmdi-smartphone-code:before {\n  content: '\\f139';\n}\n.zmdi-directions-bike:before {\n  content: '\\f117';\n}\n.zmdi-directions-boat:before {\n  content: '\\f11a';\n}\n.zmdi-directions-bus:before {\n  content: '\\f121';\n}\n.zmdi-directions-car:before {\n  content: '\\f125';\n}\n.zmdi-directions-railway:before {\n  content: '\\f1b3';\n}\n.zmdi-directions-run:before {\n  content: '\\f215';\n}\n.zmdi-directions-subway:before {\n  content: '\\f1d5';\n}\n.zmdi-directions-walk:before {\n  content: '\\f216';\n}\n.zmdi-local-hotel:before {\n  content: '\\f178';\n}\n.zmdi-local-activity:before {\n  content: '\\f1df';\n}\n.zmdi-local-play:before {\n  content: '\\f1df';\n}\n.zmdi-local-airport:before {\n  content: '\\f103';\n}\n.zmdi-local-atm:before {\n  content: '\\f198';\n}\n.zmdi-local-bar:before {\n  content: '\\f137';\n}\n.zmdi-local-cafe:before {\n  content: '\\f13b';\n}\n.zmdi-local-car-wash:before {\n  content: '\\f124';\n}\n.zmdi-local-convenience-store:before {\n  content: '\\f1d3';\n}\n.zmdi-local-dining:before {\n  content: '\\f153';\n}\n.zmdi-local-drink:before {\n  content: '\\f157';\n}\n.zmdi-local-florist:before {\n  content: '\\f168';\n}\n.zmdi-local-gas-station:before {\n  content: '\\f16f';\n}\n.zmdi-local-grocery-store:before {\n  content: '\\f1cb';\n}\n.zmdi-local-hospital:before {\n  content: '\\f177';\n}\n.zmdi-local-laundry-service:before {\n  content: '\\f1e9';\n}\n.zmdi-local-library:before {\n  content: '\\f18d';\n}\n.zmdi-local-mall:before {\n  content: '\\f195';\n}\n.zmdi-local-movies:before {\n  content: '\\f19d';\n}\n.zmdi-local-offer:before {\n  content: '\\f187';\n}\n.zmdi-local-parking:before {\n  content: '\\f1a5';\n}\n.zmdi-local-parking:before {\n  content: '\\f1a5';\n}\n.zmdi-local-pharmacy:before {\n  content: '\\f176';\n}\n.zmdi-local-phone:before {\n  content: '\\f2be';\n}\n.zmdi-local-pizza:before {\n  content: '\\f1ac';\n}\n.zmdi-local-post-office:before {\n  content: '\\f15a';\n}\n.zmdi-local-printshop:before {\n  content: '\\f1b0';\n}\n.zmdi-local-see:before {\n  content: '\\f28c';\n}\n.zmdi-local-shipping:before {\n  content: '\\f1e6';\n}\n.zmdi-local-store:before {\n  content: '\\f1d4';\n}\n.zmdi-local-taxi:before {\n  content: '\\f123';\n}\n.zmdi-local-wc:before {\n  content: '\\f211';\n}\n.zmdi-my-location:before {\n  content: '\\f299';\n}\n.zmdi-directions:before {\n  content: '\\f1e7';\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/simple-line-icons/css/simple-line-icons.css",
    "content": "@font-face {\n  font-family: 'simple-line-icons';\n  src: url('../fonts/Simple-Line-Icons.eot?-i3a2kk');\n  src: url('../fonts/Simple-Line-Icons.eot?#iefix-i3a2kk') format('embedded-opentype'), url('../fonts/Simple-Line-Icons.ttf?-i3a2kk') format('truetype'), url('../fonts/Simple-Line-Icons.woff2?-i3a2kk') format('woff2'), url('../fonts/Simple-Line-Icons.woff?-i3a2kk') format('woff'), url('../fonts/Simple-Line-Icons.svg?-i3a2kk#simple-line-icons') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n/*\n Use the following CSS code if you want to have a class per icon.\n Instead of a list of all class selectors, you can use the generic [class*=\"icon-\"] selector, but it's slower: \n*/\n.icon-user,\n.icon-people,\n.icon-user-female,\n.icon-user-follow,\n.icon-user-following,\n.icon-user-unfollow,\n.icon-login,\n.icon-logout,\n.icon-emotsmile,\n.icon-phone,\n.icon-call-end,\n.icon-call-in,\n.icon-call-out,\n.icon-map,\n.icon-location-pin,\n.icon-direction,\n.icon-directions,\n.icon-compass,\n.icon-layers,\n.icon-menu,\n.icon-list,\n.icon-options-vertical,\n.icon-options,\n.icon-arrow-down,\n.icon-arrow-left,\n.icon-arrow-right,\n.icon-arrow-up,\n.icon-arrow-up-circle,\n.icon-arrow-left-circle,\n.icon-arrow-right-circle,\n.icon-arrow-down-circle,\n.icon-check,\n.icon-clock,\n.icon-plus,\n.icon-close,\n.icon-trophy,\n.icon-screen-smartphone,\n.icon-screen-desktop,\n.icon-plane,\n.icon-notebook,\n.icon-mustache,\n.icon-mouse,\n.icon-magnet,\n.icon-energy,\n.icon-disc,\n.icon-cursor,\n.icon-cursor-move,\n.icon-crop,\n.icon-chemistry,\n.icon-speedometer,\n.icon-shield,\n.icon-screen-tablet,\n.icon-magic-wand,\n.icon-hourglass,\n.icon-graduation,\n.icon-ghost,\n.icon-game-controller,\n.icon-fire,\n.icon-eyeglass,\n.icon-envelope-open,\n.icon-envelope-letter,\n.icon-bell,\n.icon-badge,\n.icon-anchor,\n.icon-wallet,\n.icon-vector,\n.icon-speech,\n.icon-puzzle,\n.icon-printer,\n.icon-present,\n.icon-playlist,\n.icon-pin,\n.icon-picture,\n.icon-handbag,\n.icon-globe-alt,\n.icon-globe,\n.icon-folder-alt,\n.icon-folder,\n.icon-film,\n.icon-feed,\n.icon-drop,\n.icon-drawar,\n.icon-docs,\n.icon-doc,\n.icon-diamond,\n.icon-cup,\n.icon-calculator,\n.icon-bubbles,\n.icon-briefcase,\n.icon-book-open,\n.icon-basket-loaded,\n.icon-basket,\n.icon-bag,\n.icon-action-undo,\n.icon-action-redo,\n.icon-wrench,\n.icon-umbrella,\n.icon-trash,\n.icon-tag,\n.icon-support,\n.icon-frame,\n.icon-size-fullscreen,\n.icon-size-actual,\n.icon-shuffle,\n.icon-share-alt,\n.icon-share,\n.icon-rocket,\n.icon-question,\n.icon-pie-chart,\n.icon-pencil,\n.icon-note,\n.icon-loop,\n.icon-home,\n.icon-grid,\n.icon-graph,\n.icon-microphone,\n.icon-music-tone-alt,\n.icon-music-tone,\n.icon-earphones-alt,\n.icon-earphones,\n.icon-equalizer,\n.icon-like,\n.icon-dislike,\n.icon-control-start,\n.icon-control-rewind,\n.icon-control-play,\n.icon-control-pause,\n.icon-control-forward,\n.icon-control-end,\n.icon-volume-1,\n.icon-volume-2,\n.icon-volume-off,\n.icon-calender,\n.icon-bulb,\n.icon-chart,\n.icon-ban,\n.icon-bubble,\n.icon-camrecorder,\n.icon-camera,\n.icon-cloud-download,\n.icon-cloud-upload,\n.icon-envelope,\n.icon-eye,\n.icon-flag,\n.icon-heart,\n.icon-info,\n.icon-key,\n.icon-link,\n.icon-lock,\n.icon-lock-open,\n.icon-magnifier,\n.icon-magnifier-add,\n.icon-magnifier-remove,\n.icon-paper-clip,\n.icon-paper-plane,\n.icon-power,\n.icon-refresh,\n.icon-reload,\n.icon-settings,\n.icon-star,\n.icon-symble-female,\n.icon-symbol-male,\n.icon-target,\n.icon-credit-card,\n.icon-paypal,\n.icon-social-tumblr,\n.icon-social-twitter,\n.icon-social-facebook,\n.icon-social-instagram,\n.icon-social-linkedin,\n.icon-social-pintarest,\n.icon-social-github,\n.icon-social-gplus,\n.icon-social-reddit,\n.icon-social-skype,\n.icon-social-dribbble,\n.icon-social-behance,\n.icon-social-foursqare,\n.icon-social-soundcloud,\n.icon-social-spotify,\n.icon-social-stumbleupon,\n.icon-social-youtube,\n.icon-social-dropbox {\n  font-family: 'simple-line-icons';\n  speak: none;\n  font-style: normal;\n  font-weight: normal;\n  font-variant: normal;\n  text-transform: none;\n  line-height: 1;\n  /* Better Font Rendering =========== */\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.icon-user:before {\n  content: \"\\e005\";\n}\n.icon-people:before {\n  content: \"\\e001\";\n}\n.icon-user-female:before {\n  content: \"\\e000\";\n}\n.icon-user-follow:before {\n  content: \"\\e002\";\n}\n.icon-user-following:before {\n  content: \"\\e003\";\n}\n.icon-user-unfollow:before {\n  content: \"\\e004\";\n}\n.icon-login:before {\n  content: \"\\e066\";\n}\n.icon-logout:before {\n  content: \"\\e065\";\n}\n.icon-emotsmile:before {\n  content: \"\\e021\";\n}\n.icon-phone:before {\n  content: \"\\e600\";\n}\n.icon-call-end:before {\n  content: \"\\e048\";\n}\n.icon-call-in:before {\n  content: \"\\e047\";\n}\n.icon-call-out:before {\n  content: \"\\e046\";\n}\n.icon-map:before {\n  content: \"\\e033\";\n}\n.icon-location-pin:before {\n  content: \"\\e096\";\n}\n.icon-direction:before {\n  content: \"\\e042\";\n}\n.icon-directions:before {\n  content: \"\\e041\";\n}\n.icon-compass:before {\n  content: \"\\e045\";\n}\n.icon-layers:before {\n  content: \"\\e034\";\n}\n.icon-menu:before {\n  content: \"\\e601\";\n}\n.icon-list:before {\n  content: \"\\e067\";\n}\n.icon-options-vertical:before {\n  content: \"\\e602\";\n}\n.icon-options:before {\n  content: \"\\e603\";\n}\n.icon-arrow-down:before {\n  content: \"\\e604\";\n}\n.icon-arrow-left:before {\n  content: \"\\e605\";\n}\n.icon-arrow-right:before {\n  content: \"\\e606\";\n}\n.icon-arrow-up:before {\n  content: \"\\e607\";\n}\n.icon-arrow-up-circle:before {\n  content: \"\\e078\";\n}\n.icon-arrow-left-circle:before {\n  content: \"\\e07a\";\n}\n.icon-arrow-right-circle:before {\n  content: \"\\e079\";\n}\n.icon-arrow-down-circle:before {\n  content: \"\\e07b\";\n}\n.icon-check:before {\n  content: \"\\e080\";\n}\n.icon-clock:before {\n  content: \"\\e081\";\n}\n.icon-plus:before {\n  content: \"\\e095\";\n}\n.icon-close:before {\n  content: \"\\e082\";\n}\n.icon-trophy:before {\n  content: \"\\e006\";\n}\n.icon-screen-smartphone:before {\n  content: \"\\e010\";\n}\n.icon-screen-desktop:before {\n  content: \"\\e011\";\n}\n.icon-plane:before {\n  content: \"\\e012\";\n}\n.icon-notebook:before {\n  content: \"\\e013\";\n}\n.icon-mustache:before {\n  content: \"\\e014\";\n}\n.icon-mouse:before {\n  content: \"\\e015\";\n}\n.icon-magnet:before {\n  content: \"\\e016\";\n}\n.icon-energy:before {\n  content: \"\\e020\";\n}\n.icon-disc:before {\n  content: \"\\e022\";\n}\n.icon-cursor:before {\n  content: \"\\e06e\";\n}\n.icon-cursor-move:before {\n  content: \"\\e023\";\n}\n.icon-crop:before {\n  content: \"\\e024\";\n}\n.icon-chemistry:before {\n  content: \"\\e026\";\n}\n.icon-speedometer:before {\n  content: \"\\e007\";\n}\n.icon-shield:before {\n  content: \"\\e00e\";\n}\n.icon-screen-tablet:before {\n  content: \"\\e00f\";\n}\n.icon-magic-wand:before {\n  content: \"\\e017\";\n}\n.icon-hourglass:before {\n  content: \"\\e018\";\n}\n.icon-graduation:before {\n  content: \"\\e019\";\n}\n.icon-ghost:before {\n  content: \"\\e01a\";\n}\n.icon-game-controller:before {\n  content: \"\\e01b\";\n}\n.icon-fire:before {\n  content: \"\\e01c\";\n}\n.icon-eyeglass:before {\n  content: \"\\e01d\";\n}\n.icon-envelope-open:before {\n  content: \"\\e01e\";\n}\n.icon-envelope-letter:before {\n  content: \"\\e01f\";\n}\n.icon-bell:before {\n  content: \"\\e027\";\n}\n.icon-badge:before {\n  content: \"\\e028\";\n}\n.icon-anchor:before {\n  content: \"\\e029\";\n}\n.icon-wallet:before {\n  content: \"\\e02a\";\n}\n.icon-vector:before {\n  content: \"\\e02b\";\n}\n.icon-speech:before {\n  content: \"\\e02c\";\n}\n.icon-puzzle:before {\n  content: \"\\e02d\";\n}\n.icon-printer:before {\n  content: \"\\e02e\";\n}\n.icon-present:before {\n  content: \"\\e02f\";\n}\n.icon-playlist:before {\n  content: \"\\e030\";\n}\n.icon-pin:before {\n  content: \"\\e031\";\n}\n.icon-picture:before {\n  content: \"\\e032\";\n}\n.icon-handbag:before {\n  content: \"\\e035\";\n}\n.icon-globe-alt:before {\n  content: \"\\e036\";\n}\n.icon-globe:before {\n  content: \"\\e037\";\n}\n.icon-folder-alt:before {\n  content: \"\\e039\";\n}\n.icon-folder:before {\n  content: \"\\e089\";\n}\n.icon-film:before {\n  content: \"\\e03a\";\n}\n.icon-feed:before {\n  content: \"\\e03b\";\n}\n.icon-drop:before {\n  content: \"\\e03e\";\n}\n.icon-drawar:before {\n  content: \"\\e03f\";\n}\n.icon-docs:before {\n  content: \"\\e040\";\n}\n.icon-doc:before {\n  content: \"\\e085\";\n}\n.icon-diamond:before {\n  content: \"\\e043\";\n}\n.icon-cup:before {\n  content: \"\\e044\";\n}\n.icon-calculator:before {\n  content: \"\\e049\";\n}\n.icon-bubbles:before {\n  content: \"\\e04a\";\n}\n.icon-briefcase:before {\n  content: \"\\e04b\";\n}\n.icon-book-open:before {\n  content: \"\\e04c\";\n}\n.icon-basket-loaded:before {\n  content: \"\\e04d\";\n}\n.icon-basket:before {\n  content: \"\\e04e\";\n}\n.icon-bag:before {\n  content: \"\\e04f\";\n}\n.icon-action-undo:before {\n  content: \"\\e050\";\n}\n.icon-action-redo:before {\n  content: \"\\e051\";\n}\n.icon-wrench:before {\n  content: \"\\e052\";\n}\n.icon-umbrella:before {\n  content: \"\\e053\";\n}\n.icon-trash:before {\n  content: \"\\e054\";\n}\n.icon-tag:before {\n  content: \"\\e055\";\n}\n.icon-support:before {\n  content: \"\\e056\";\n}\n.icon-frame:before {\n  content: \"\\e038\";\n}\n.icon-size-fullscreen:before {\n  content: \"\\e057\";\n}\n.icon-size-actual:before {\n  content: \"\\e058\";\n}\n.icon-shuffle:before {\n  content: \"\\e059\";\n}\n.icon-share-alt:before {\n  content: \"\\e05a\";\n}\n.icon-share:before {\n  content: \"\\e05b\";\n}\n.icon-rocket:before {\n  content: \"\\e05c\";\n}\n.icon-question:before {\n  content: \"\\e05d\";\n}\n.icon-pie-chart:before {\n  content: \"\\e05e\";\n}\n.icon-pencil:before {\n  content: \"\\e05f\";\n}\n.icon-note:before {\n  content: \"\\e060\";\n}\n.icon-loop:before {\n  content: \"\\e064\";\n}\n.icon-home:before {\n  content: \"\\e069\";\n}\n.icon-grid:before {\n  content: \"\\e06a\";\n}\n.icon-graph:before {\n  content: \"\\e06b\";\n}\n.icon-microphone:before {\n  content: \"\\e063\";\n}\n.icon-music-tone-alt:before {\n  content: \"\\e061\";\n}\n.icon-music-tone:before {\n  content: \"\\e062\";\n}\n.icon-earphones-alt:before {\n  content: \"\\e03c\";\n}\n.icon-earphones:before {\n  content: \"\\e03d\";\n}\n.icon-equalizer:before {\n  content: \"\\e06c\";\n}\n.icon-like:before {\n  content: \"\\e068\";\n}\n.icon-dislike:before {\n  content: \"\\e06d\";\n}\n.icon-control-start:before {\n  content: \"\\e06f\";\n}\n.icon-control-rewind:before {\n  content: \"\\e070\";\n}\n.icon-control-play:before {\n  content: \"\\e071\";\n}\n.icon-control-pause:before {\n  content: \"\\e072\";\n}\n.icon-control-forward:before {\n  content: \"\\e073\";\n}\n.icon-control-end:before {\n  content: \"\\e074\";\n}\n.icon-volume-1:before {\n  content: \"\\e09f\";\n}\n.icon-volume-2:before {\n  content: \"\\e0a0\";\n}\n.icon-volume-off:before {\n  content: \"\\e0a1\";\n}\n.icon-calender:before {\n  content: \"\\e075\";\n}\n.icon-bulb:before {\n  content: \"\\e076\";\n}\n.icon-chart:before {\n  content: \"\\e077\";\n}\n.icon-ban:before {\n  content: \"\\e07c\";\n}\n.icon-bubble:before {\n  content: \"\\e07d\";\n}\n.icon-camrecorder:before {\n  content: \"\\e07e\";\n}\n.icon-camera:before {\n  content: \"\\e07f\";\n}\n.icon-cloud-download:before {\n  content: \"\\e083\";\n}\n.icon-cloud-upload:before {\n  content: \"\\e084\";\n}\n.icon-envelope:before {\n  content: \"\\e086\";\n}\n.icon-eye:before {\n  content: \"\\e087\";\n}\n.icon-flag:before {\n  content: \"\\e088\";\n}\n.icon-heart:before {\n  content: \"\\e08a\";\n}\n.icon-info:before {\n  content: \"\\e08b\";\n}\n.icon-key:before {\n  content: \"\\e08c\";\n}\n.icon-link:before {\n  content: \"\\e08d\";\n}\n.icon-lock:before {\n  content: \"\\e08e\";\n}\n.icon-lock-open:before {\n  content: \"\\e08f\";\n}\n.icon-magnifier:before {\n  content: \"\\e090\";\n}\n.icon-magnifier-add:before {\n  content: \"\\e091\";\n}\n.icon-magnifier-remove:before {\n  content: \"\\e092\";\n}\n.icon-paper-clip:before {\n  content: \"\\e093\";\n}\n.icon-paper-plane:before {\n  content: \"\\e094\";\n}\n.icon-power:before {\n  content: \"\\e097\";\n}\n.icon-refresh:before {\n  content: \"\\e098\";\n}\n.icon-reload:before {\n  content: \"\\e099\";\n}\n.icon-settings:before {\n  content: \"\\e09a\";\n}\n.icon-star:before {\n  content: \"\\e09b\";\n}\n.icon-symble-female:before {\n  content: \"\\e09c\";\n}\n.icon-symbol-male:before {\n  content: \"\\e09d\";\n}\n.icon-target:before {\n  content: \"\\e09e\";\n}\n.icon-credit-card:before {\n  content: \"\\e025\";\n}\n.icon-paypal:before {\n  content: \"\\e608\";\n}\n.icon-social-tumblr:before {\n  content: \"\\e00a\";\n}\n.icon-social-twitter:before {\n  content: \"\\e009\";\n}\n.icon-social-facebook:before {\n  content: \"\\e00b\";\n}\n.icon-social-instagram:before {\n  content: \"\\e609\";\n}\n.icon-social-linkedin:before {\n  content: \"\\e60a\";\n}\n.icon-social-pintarest:before {\n  content: \"\\e60b\";\n}\n.icon-social-github:before {\n  content: \"\\e60c\";\n}\n.icon-social-gplus:before {\n  content: \"\\e60d\";\n}\n.icon-social-reddit:before {\n  content: \"\\e60e\";\n}\n.icon-social-skype:before {\n  content: \"\\e60f\";\n}\n.icon-social-dribbble:before {\n  content: \"\\e00d\";\n}\n.icon-social-behance:before {\n  content: \"\\e610\";\n}\n.icon-social-foursqare:before {\n  content: \"\\e611\";\n}\n.icon-social-soundcloud:before {\n  content: \"\\e612\";\n}\n.icon-social-spotify:before {\n  content: \"\\e613\";\n}\n.icon-social-stumbleupon:before {\n  content: \"\\e614\";\n}\n.icon-social-youtube:before {\n  content: \"\\e008\";\n}\n.icon-social-dropbox:before {\n  content: \"\\e00c\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/simple-line-icons/less/simple-line-icons.less",
    "content": "// Default Variables\n@simple-line-font-path        : \"../less/icons/simple-line-icons/fonts/\";\n@simple-line-font-family      : \"simple-line-icons\";\n@simple-line-icon-prefix      : icon-;\n\n//Fonts\n@font-face {\n  font-family: '@{simple-line-font-family}';\n  src: url('@{simple-line-font-path}Simple-Line-Icons.eot?-i3a2kk');\n  src: url('@{simple-line-font-path}Simple-Line-Icons.eot?#iefix-i3a2kk') format('embedded-opentype'),\n  url('@{simple-line-font-path}Simple-Line-Icons.ttf?-i3a2kk') format('truetype'),\n  url('@{simple-line-font-path}Simple-Line-Icons.woff2?-i3a2kk') format('woff2'),\n  url('@{simple-line-font-path}Simple-Line-Icons.woff?-i3a2kk') format('woff'),\n  url('@{simple-line-font-path}Simple-Line-Icons.svg?-i3a2kk#simple-line-icons') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n\n/*\n Use the following CSS code if you want to have a class per icon.\n Instead of a list of all class selectors, you can use the generic [class*=\"icon-\"] selector, but it's slower: \n*/\n\n.@{simple-line-icon-prefix}  {\n    &user,\n  &people,\n  &user-female,\n  &user-follow,\n  &user-following,\n  &user-unfollow,\n  &login,\n  &logout,\n  &emotsmile,\n  &phone,\n  &call-end,\n  &call-in,\n  &call-out,\n  &map,\n  &location-pin,\n  &direction,\n  &directions,\n  &compass,\n  &layers,\n  &menu,\n  &list,\n  &options-vertical,\n  &options,\n  &arrow-down,\n  &arrow-left,\n  &arrow-right,\n  &arrow-up,\n  &arrow-up-circle,\n  &arrow-left-circle,\n  &arrow-right-circle,\n  &arrow-down-circle,\n  &check,\n  &clock,\n  &plus,\n  &close,\n  &trophy,\n  &screen-smartphone,\n  &screen-desktop,\n  &plane,\n  &notebook,\n  &mustache,\n  &mouse,\n  &magnet,\n  &energy,\n  &disc,\n  &cursor,\n  &cursor-move,\n  &crop,\n  &chemistry,\n  &speedometer,\n  &shield,\n  &screen-tablet,\n  &magic-wand,\n  &hourglass,\n  &graduation,\n  &ghost,\n  &game-controller,\n  &fire,\n  &eyeglass,\n  &envelope-open,\n  &envelope-letter,\n  &bell,\n  &badge,\n  &anchor,\n  &wallet,\n  &vector,\n  &speech,\n  &puzzle,\n  &printer,\n  &present,\n  &playlist,\n  &pin,\n  &picture,\n  &handbag,\n  &globe-alt,\n  &globe,\n  &folder-alt,\n  &folder,\n  &film,\n  &feed,\n  &drop,\n  &drawar,\n  &docs,\n  &doc,\n  &diamond,\n  &cup,\n  &calculator,\n  &bubbles,\n  &briefcase,\n  &book-open,\n  &basket-loaded,\n  &basket,\n  &bag,\n  &action-undo,\n  &action-redo,\n  &wrench,\n  &umbrella,\n  &trash,\n  &tag,\n  &support,\n  &frame,\n  &size-fullscreen,\n  &size-actual,\n  &shuffle,\n  &share-alt,\n  &share,\n  &rocket,\n  &question,\n  &pie-chart,\n  &pencil,\n  &note,\n  &loop,\n  &home,\n  &grid,\n  &graph,\n  &microphone,\n  &music-tone-alt,\n  &music-tone,\n  &earphones-alt,\n  &earphones,\n  &equalizer,\n  &like,\n  &dislike,\n  &control-start,\n  &control-rewind,\n  &control-play,\n  &control-pause,\n  &control-forward,\n  &control-end,\n  &volume-1,\n  &volume-2,\n  &volume-off,\n  &calender,\n  &bulb,\n  &chart,\n  &ban,\n  &bubble,\n  &camrecorder,\n  &camera,\n  &cloud-download,\n  &cloud-upload,\n  &envelope,\n  &eye,\n  &flag,\n  &heart,\n  &info,\n  &key,\n  &link,\n  &lock,\n  &lock-open,\n  &magnifier,\n  &magnifier-add,\n  &magnifier-remove,\n  &paper-clip,\n  &paper-plane,\n  &power,\n  &refresh,\n  &reload,\n  &settings,\n  &star,\n  &symble-female,\n  &symbol-male,\n  &target,\n  &credit-card,\n  &paypal,\n  &social-tumblr,\n  &social-twitter,\n  &social-facebook,\n  &social-instagram,\n  &social-linkedin,\n  &social-pintarest,\n  &social-github,\n  &social-gplus,\n  &social-reddit,\n  &social-skype,\n  &social-dribbble,\n  &social-behance,\n  &social-foursqare,\n  &social-soundcloud,\n  &social-spotify,\n  &social-stumbleupon,\n  &social-youtube,\n  &social-dropbox {\n    font-family: '@{simple-line-font-family}';\n    speak: none;\n    font-style: normal;\n    font-weight: normal;\n    font-variant: normal;\n    text-transform: none;\n    line-height: 1;\n\n    /* Better Font Rendering =========== */\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n  }\n}\n\n.@{simple-line-icon-prefix}user:before {\n  content: \"\\e005\";\n}\n\n.@{simple-line-icon-prefix}people:before {\n  content: \"\\e001\";\n}\n\n.@{simple-line-icon-prefix}user-female:before {\n  content: \"\\e000\";\n}\n\n.@{simple-line-icon-prefix}user-follow:before {\n  content: \"\\e002\";\n}\n\n.@{simple-line-icon-prefix}user-following:before {\n  content: \"\\e003\";\n}\n\n.@{simple-line-icon-prefix}user-unfollow:before {\n  content: \"\\e004\";\n}\n\n.@{simple-line-icon-prefix}login:before {\n  content: \"\\e066\";\n}\n\n.@{simple-line-icon-prefix}logout:before {\n  content: \"\\e065\";\n}\n\n.@{simple-line-icon-prefix}emotsmile:before {\n  content: \"\\e021\";\n}\n\n.@{simple-line-icon-prefix}phone:before {\n  content: \"\\e600\";\n}\n\n.@{simple-line-icon-prefix}call-end:before {\n  content: \"\\e048\";\n}\n\n.@{simple-line-icon-prefix}call-in:before {\n  content: \"\\e047\";\n}\n\n.@{simple-line-icon-prefix}call-out:before {\n  content: \"\\e046\";\n}\n\n.@{simple-line-icon-prefix}map:before {\n  content: \"\\e033\";\n}\n\n.@{simple-line-icon-prefix}location-pin:before {\n  content: \"\\e096\";\n}\n\n.@{simple-line-icon-prefix}direction:before {\n  content: \"\\e042\";\n}\n\n.@{simple-line-icon-prefix}directions:before {\n  content: \"\\e041\";\n}\n\n.@{simple-line-icon-prefix}compass:before {\n  content: \"\\e045\";\n}\n\n.@{simple-line-icon-prefix}layers:before {\n  content: \"\\e034\";\n}\n\n.@{simple-line-icon-prefix}menu:before {\n  content: \"\\e601\";\n}\n\n.@{simple-line-icon-prefix}list:before {\n  content: \"\\e067\";\n}\n\n.@{simple-line-icon-prefix}options-vertical:before {\n  content: \"\\e602\";\n}\n\n.@{simple-line-icon-prefix}options:before {\n  content: \"\\e603\";\n}\n\n.@{simple-line-icon-prefix}arrow-down:before {\n  content: \"\\e604\";\n}\n\n.@{simple-line-icon-prefix}arrow-left:before {\n  content: \"\\e605\";\n}\n\n.@{simple-line-icon-prefix}arrow-right:before {\n  content: \"\\e606\";\n}\n\n.@{simple-line-icon-prefix}arrow-up:before {\n  content: \"\\e607\";\n}\n\n.@{simple-line-icon-prefix}arrow-up-circle:before {\n  content: \"\\e078\";\n}\n\n.@{simple-line-icon-prefix}arrow-left-circle:before {\n  content: \"\\e07a\";\n}\n\n.@{simple-line-icon-prefix}arrow-right-circle:before {\n  content: \"\\e079\";\n}\n\n.@{simple-line-icon-prefix}arrow-down-circle:before {\n  content: \"\\e07b\";\n}\n\n.@{simple-line-icon-prefix}check:before {\n  content: \"\\e080\";\n}\n\n.@{simple-line-icon-prefix}clock:before {\n  content: \"\\e081\";\n}\n\n.@{simple-line-icon-prefix}plus:before {\n  content: \"\\e095\";\n}\n\n.@{simple-line-icon-prefix}close:before {\n  content: \"\\e082\";\n}\n\n.@{simple-line-icon-prefix}trophy:before {\n  content: \"\\e006\";\n}\n\n.@{simple-line-icon-prefix}screen-smartphone:before {\n  content: \"\\e010\";\n}\n\n.@{simple-line-icon-prefix}screen-desktop:before {\n  content: \"\\e011\";\n}\n\n.@{simple-line-icon-prefix}plane:before {\n  content: \"\\e012\";\n}\n\n.@{simple-line-icon-prefix}notebook:before {\n  content: \"\\e013\";\n}\n\n.@{simple-line-icon-prefix}mustache:before {\n  content: \"\\e014\";\n}\n\n.@{simple-line-icon-prefix}mouse:before {\n  content: \"\\e015\";\n}\n\n.@{simple-line-icon-prefix}magnet:before {\n  content: \"\\e016\";\n}\n\n.@{simple-line-icon-prefix}energy:before {\n  content: \"\\e020\";\n}\n\n.@{simple-line-icon-prefix}disc:before {\n  content: \"\\e022\";\n}\n\n.@{simple-line-icon-prefix}cursor:before {\n  content: \"\\e06e\";\n}\n\n.@{simple-line-icon-prefix}cursor-move:before {\n  content: \"\\e023\";\n}\n\n.@{simple-line-icon-prefix}crop:before {\n  content: \"\\e024\";\n}\n\n.@{simple-line-icon-prefix}chemistry:before {\n  content: \"\\e026\";\n}\n\n.@{simple-line-icon-prefix}speedometer:before {\n  content: \"\\e007\";\n}\n\n.@{simple-line-icon-prefix}shield:before {\n  content: \"\\e00e\";\n}\n\n.@{simple-line-icon-prefix}screen-tablet:before {\n  content: \"\\e00f\";\n}\n\n.@{simple-line-icon-prefix}magic-wand:before {\n  content: \"\\e017\";\n}\n\n.@{simple-line-icon-prefix}hourglass:before {\n  content: \"\\e018\";\n}\n\n.@{simple-line-icon-prefix}graduation:before {\n  content: \"\\e019\";\n}\n\n.@{simple-line-icon-prefix}ghost:before {\n  content: \"\\e01a\";\n}\n\n.@{simple-line-icon-prefix}game-controller:before {\n  content: \"\\e01b\";\n}\n\n.@{simple-line-icon-prefix}fire:before {\n  content: \"\\e01c\";\n}\n\n.@{simple-line-icon-prefix}eyeglass:before {\n  content: \"\\e01d\";\n}\n\n.@{simple-line-icon-prefix}envelope-open:before {\n  content: \"\\e01e\";\n}\n\n.@{simple-line-icon-prefix}envelope-letter:before {\n  content: \"\\e01f\";\n}\n\n.@{simple-line-icon-prefix}bell:before {\n  content: \"\\e027\";\n}\n\n.@{simple-line-icon-prefix}badge:before {\n  content: \"\\e028\";\n}\n\n.@{simple-line-icon-prefix}anchor:before {\n  content: \"\\e029\";\n}\n\n.@{simple-line-icon-prefix}wallet:before {\n  content: \"\\e02a\";\n}\n\n.@{simple-line-icon-prefix}vector:before {\n  content: \"\\e02b\";\n}\n\n.@{simple-line-icon-prefix}speech:before {\n  content: \"\\e02c\";\n}\n\n.@{simple-line-icon-prefix}puzzle:before {\n  content: \"\\e02d\";\n}\n\n.@{simple-line-icon-prefix}printer:before {\n  content: \"\\e02e\";\n}\n\n.@{simple-line-icon-prefix}present:before {\n  content: \"\\e02f\";\n}\n\n.@{simple-line-icon-prefix}playlist:before {\n  content: \"\\e030\";\n}\n\n.@{simple-line-icon-prefix}pin:before {\n  content: \"\\e031\";\n}\n\n.@{simple-line-icon-prefix}picture:before {\n  content: \"\\e032\";\n}\n\n.@{simple-line-icon-prefix}handbag:before {\n  content: \"\\e035\";\n}\n\n.@{simple-line-icon-prefix}globe-alt:before {\n  content: \"\\e036\";\n}\n\n.@{simple-line-icon-prefix}globe:before {\n  content: \"\\e037\";\n}\n\n.@{simple-line-icon-prefix}folder-alt:before {\n  content: \"\\e039\";\n}\n\n.@{simple-line-icon-prefix}folder:before {\n  content: \"\\e089\";\n}\n\n.@{simple-line-icon-prefix}film:before {\n  content: \"\\e03a\";\n}\n\n.@{simple-line-icon-prefix}feed:before {\n  content: \"\\e03b\";\n}\n\n.@{simple-line-icon-prefix}drop:before {\n  content: \"\\e03e\";\n}\n\n.@{simple-line-icon-prefix}drawar:before {\n  content: \"\\e03f\";\n}\n\n.@{simple-line-icon-prefix}docs:before {\n  content: \"\\e040\";\n}\n\n.@{simple-line-icon-prefix}doc:before {\n  content: \"\\e085\";\n}\n\n.@{simple-line-icon-prefix}diamond:before {\n  content: \"\\e043\";\n}\n\n.@{simple-line-icon-prefix}cup:before {\n  content: \"\\e044\";\n}\n\n.@{simple-line-icon-prefix}calculator:before {\n  content: \"\\e049\";\n}\n\n.@{simple-line-icon-prefix}bubbles:before {\n  content: \"\\e04a\";\n}\n\n.@{simple-line-icon-prefix}briefcase:before {\n  content: \"\\e04b\";\n}\n\n.@{simple-line-icon-prefix}book-open:before {\n  content: \"\\e04c\";\n}\n\n.@{simple-line-icon-prefix}basket-loaded:before {\n  content: \"\\e04d\";\n}\n\n.@{simple-line-icon-prefix}basket:before {\n  content: \"\\e04e\";\n}\n\n.@{simple-line-icon-prefix}bag:before {\n  content: \"\\e04f\";\n}\n\n.@{simple-line-icon-prefix}action-undo:before {\n  content: \"\\e050\";\n}\n\n.@{simple-line-icon-prefix}action-redo:before {\n  content: \"\\e051\";\n}\n\n.@{simple-line-icon-prefix}wrench:before {\n  content: \"\\e052\";\n}\n\n.@{simple-line-icon-prefix}umbrella:before {\n  content: \"\\e053\";\n}\n\n.@{simple-line-icon-prefix}trash:before {\n  content: \"\\e054\";\n}\n\n.@{simple-line-icon-prefix}tag:before {\n  content: \"\\e055\";\n}\n\n.@{simple-line-icon-prefix}support:before {\n  content: \"\\e056\";\n}\n\n.@{simple-line-icon-prefix}frame:before {\n  content: \"\\e038\";\n}\n\n.@{simple-line-icon-prefix}size-fullscreen:before {\n  content: \"\\e057\";\n}\n\n.@{simple-line-icon-prefix}size-actual:before {\n  content: \"\\e058\";\n}\n\n.@{simple-line-icon-prefix}shuffle:before {\n  content: \"\\e059\";\n}\n\n.@{simple-line-icon-prefix}share-alt:before {\n  content: \"\\e05a\";\n}\n\n.@{simple-line-icon-prefix}share:before {\n  content: \"\\e05b\";\n}\n\n.@{simple-line-icon-prefix}rocket:before {\n  content: \"\\e05c\";\n}\n\n.@{simple-line-icon-prefix}question:before {\n  content: \"\\e05d\";\n}\n\n.@{simple-line-icon-prefix}pie-chart:before {\n  content: \"\\e05e\";\n}\n\n.@{simple-line-icon-prefix}pencil:before {\n  content: \"\\e05f\";\n}\n\n.@{simple-line-icon-prefix}note:before {\n  content: \"\\e060\";\n}\n\n.@{simple-line-icon-prefix}loop:before {\n  content: \"\\e064\";\n}\n\n.@{simple-line-icon-prefix}home:before {\n  content: \"\\e069\";\n}\n\n.@{simple-line-icon-prefix}grid:before {\n  content: \"\\e06a\";\n}\n\n.@{simple-line-icon-prefix}graph:before {\n  content: \"\\e06b\";\n}\n\n.@{simple-line-icon-prefix}microphone:before {\n  content: \"\\e063\";\n}\n\n.@{simple-line-icon-prefix}music-tone-alt:before {\n  content: \"\\e061\";\n}\n\n.@{simple-line-icon-prefix}music-tone:before {\n  content: \"\\e062\";\n}\n\n.@{simple-line-icon-prefix}earphones-alt:before {\n  content: \"\\e03c\";\n}\n\n.@{simple-line-icon-prefix}earphones:before {\n  content: \"\\e03d\";\n}\n\n.@{simple-line-icon-prefix}equalizer:before {\n  content: \"\\e06c\";\n}\n\n.@{simple-line-icon-prefix}like:before {\n  content: \"\\e068\";\n}\n\n.@{simple-line-icon-prefix}dislike:before {\n  content: \"\\e06d\";\n}\n\n.@{simple-line-icon-prefix}control-start:before {\n  content: \"\\e06f\";\n}\n\n.@{simple-line-icon-prefix}control-rewind:before {\n  content: \"\\e070\";\n}\n\n.@{simple-line-icon-prefix}control-play:before {\n  content: \"\\e071\";\n}\n\n.@{simple-line-icon-prefix}control-pause:before {\n  content: \"\\e072\";\n}\n\n.@{simple-line-icon-prefix}control-forward:before {\n  content: \"\\e073\";\n}\n\n.@{simple-line-icon-prefix}control-end:before {\n  content: \"\\e074\";\n}\n\n.@{simple-line-icon-prefix}volume-1:before {\n  content: \"\\e09f\";\n}\n\n.@{simple-line-icon-prefix}volume-2:before {\n  content: \"\\e0a0\";\n}\n\n.@{simple-line-icon-prefix}volume-off:before {\n  content: \"\\e0a1\";\n}\n\n.@{simple-line-icon-prefix}calender:before {\n  content: \"\\e075\";\n}\n\n.@{simple-line-icon-prefix}bulb:before {\n  content: \"\\e076\";\n}\n\n.@{simple-line-icon-prefix}chart:before {\n  content: \"\\e077\";\n}\n\n.@{simple-line-icon-prefix}ban:before {\n  content: \"\\e07c\";\n}\n\n.@{simple-line-icon-prefix}bubble:before {\n  content: \"\\e07d\";\n}\n\n.@{simple-line-icon-prefix}camrecorder:before {\n  content: \"\\e07e\";\n}\n\n.@{simple-line-icon-prefix}camera:before {\n  content: \"\\e07f\";\n}\n\n.@{simple-line-icon-prefix}cloud-download:before {\n  content: \"\\e083\";\n}\n\n.@{simple-line-icon-prefix}cloud-upload:before {\n  content: \"\\e084\";\n}\n\n.@{simple-line-icon-prefix}envelope:before {\n  content: \"\\e086\";\n}\n\n.@{simple-line-icon-prefix}eye:before {\n  content: \"\\e087\";\n}\n\n.@{simple-line-icon-prefix}flag:before {\n  content: \"\\e088\";\n}\n\n.@{simple-line-icon-prefix}heart:before {\n  content: \"\\e08a\";\n}\n\n.@{simple-line-icon-prefix}info:before {\n  content: \"\\e08b\";\n}\n\n.@{simple-line-icon-prefix}key:before {\n  content: \"\\e08c\";\n}\n\n.@{simple-line-icon-prefix}link:before {\n  content: \"\\e08d\";\n}\n\n.@{simple-line-icon-prefix}lock:before {\n  content: \"\\e08e\";\n}\n\n.@{simple-line-icon-prefix}lock-open:before {\n  content: \"\\e08f\";\n}\n\n.@{simple-line-icon-prefix}magnifier:before {\n  content: \"\\e090\";\n}\n\n.@{simple-line-icon-prefix}magnifier-add:before {\n  content: \"\\e091\";\n}\n\n.@{simple-line-icon-prefix}magnifier-remove:before {\n  content: \"\\e092\";\n}\n\n.@{simple-line-icon-prefix}paper-clip:before {\n  content: \"\\e093\";\n}\n\n.@{simple-line-icon-prefix}paper-plane:before {\n  content: \"\\e094\";\n}\n\n.@{simple-line-icon-prefix}power:before {\n  content: \"\\e097\";\n}\n\n.@{simple-line-icon-prefix}refresh:before {\n  content: \"\\e098\";\n}\n\n.@{simple-line-icon-prefix}reload:before {\n  content: \"\\e099\";\n}\n\n.@{simple-line-icon-prefix}settings:before {\n  content: \"\\e09a\";\n}\n\n.@{simple-line-icon-prefix}star:before {\n  content: \"\\e09b\";\n}\n\n.@{simple-line-icon-prefix}symble-female:before {\n  content: \"\\e09c\";\n}\n\n.@{simple-line-icon-prefix}symbol-male:before {\n  content: \"\\e09d\";\n}\n\n.@{simple-line-icon-prefix}target:before {\n  content: \"\\e09e\";\n}\n\n.@{simple-line-icon-prefix}credit-card:before {\n  content: \"\\e025\";\n}\n\n.@{simple-line-icon-prefix}paypal:before {\n  content: \"\\e608\";\n}\n\n.@{simple-line-icon-prefix}social-tumblr:before {\n  content: \"\\e00a\";\n}\n\n.@{simple-line-icon-prefix}social-twitter:before {\n  content: \"\\e009\";\n}\n\n.@{simple-line-icon-prefix}social-facebook:before {\n  content: \"\\e00b\";\n}\n\n.@{simple-line-icon-prefix}social-instagram:before {\n  content: \"\\e609\";\n}\n\n.@{simple-line-icon-prefix}social-linkedin:before {\n  content: \"\\e60a\";\n}\n\n.@{simple-line-icon-prefix}social-pintarest:before {\n  content: \"\\e60b\";\n}\n\n.@{simple-line-icon-prefix}social-github:before {\n  content: \"\\e60c\";\n}\n\n.@{simple-line-icon-prefix}social-gplus:before {\n  content: \"\\e60d\";\n}\n\n.@{simple-line-icon-prefix}social-reddit:before {\n  content: \"\\e60e\";\n}\n\n.@{simple-line-icon-prefix}social-skype:before {\n  content: \"\\e60f\";\n}\n\n.@{simple-line-icon-prefix}social-dribbble:before {\n  content: \"\\e00d\";\n}\n\n.@{simple-line-icon-prefix}social-behance:before {\n  content: \"\\e610\";\n}\n\n.@{simple-line-icon-prefix}social-foursqare:before {\n  content: \"\\e611\";\n}\n\n.@{simple-line-icon-prefix}social-soundcloud:before {\n  content: \"\\e612\";\n}\n\n.@{simple-line-icon-prefix}social-spotify:before {\n  content: \"\\e613\";\n}\n\n.@{simple-line-icon-prefix}social-stumbleupon:before {\n  content: \"\\e614\";\n}\n\n.@{simple-line-icon-prefix}social-youtube:before {\n  content: \"\\e008\";\n}\n\n.@{simple-line-icon-prefix}social-dropbox:before {\n  content: \"\\e00c\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/simple-line-icons/scss/simple-line-icons.scss",
    "content": "// Default Variables\n$simple-line-font-path: \"../fonts/\" !default;\n$simple-line-font-family: \"simple-line-icons\" !default;\n$simple-line-icon-prefix: \"icon-\" !default;\n\n// Fonts\n@if $simple-line-font-family == \"simple-line-icons\" {\n  @font-face {\n    font-family: '#{$simple-line-font-family}';\n    src: url('#{$simple-line-font-path}Simple-Line-Icons.eot?-i3a2kk');\n    src: url('#{$simple-line-font-path}Simple-Line-Icons.eot?#iefix-i3a2kk') format('embedded-opentype'),\n    url('#{$simple-line-font-path}Simple-Line-Icons.ttf?-i3a2kk') format('truetype'),\n    url('#{$simple-line-font-path}Simple-Line-Icons.woff2?-i3a2kk') format('woff2'),\n    url('#{$simple-line-font-path}Simple-Line-Icons.woff?-i3a2kk') format('woff'),\n    url('#{$simple-line-font-path}Simple-Line-Icons.svg?-i3a2kk#simple-line-icons') format('svg');\n    font-weight: normal;\n    font-style: normal;\n  }\n}\n\n.#{$simple-line-icon-prefix} {\n  &user,\n  &people,\n  &user-female,\n  &user-follow,\n  &user-following,\n  &user-unfollow,\n  &login,\n  &logout,\n  &emotsmile,\n  &phone,\n  &call-end,\n  &call-in,\n  &call-out,\n  &map,\n  &location-pin,\n  &direction,\n  &directions,\n  &compass,\n  &layers,\n  &menu,\n  &list,\n  &options-vertical,\n  &options,\n  &arrow-down,\n  &arrow-left,\n  &arrow-right,\n  &arrow-up,\n  &arrow-up-circle,\n  &arrow-left-circle,\n  &arrow-right-circle,\n  &arrow-down-circle,\n  &check,\n  &clock,\n  &plus,\n  &close,\n  &trophy,\n  &screen-smartphone,\n  &screen-desktop,\n  &plane,\n  &notebook,\n  &mustache,\n  &mouse,\n  &magnet,\n  &energy,\n  &disc,\n  &cursor,\n  &cursor-move,\n  &crop,\n  &chemistry,\n  &speedometer,\n  &shield,\n  &screen-tablet,\n  &magic-wand,\n  &hourglass,\n  &graduation,\n  &ghost,\n  &game-controller,\n  &fire,\n  &eyeglass,\n  &envelope-open,\n  &envelope-letter,\n  &bell,\n  &badge,\n  &anchor,\n  &wallet,\n  &vector,\n  &speech,\n  &puzzle,\n  &printer,\n  &present,\n  &playlist,\n  &pin,\n  &picture,\n  &handbag,\n  &globe-alt,\n  &globe,\n  &folder-alt,\n  &folder,\n  &film,\n  &feed,\n  &drop,\n  &drawar,\n  &docs,\n  &doc,\n  &diamond,\n  &cup,\n  &calculator,\n  &bubbles,\n  &briefcase,\n  &book-open,\n  &basket-loaded,\n  &basket,\n  &bag,\n  &action-undo,\n  &action-redo,\n  &wrench,\n  &umbrella,\n  &trash,\n  &tag,\n  &support,\n  &frame,\n  &size-fullscreen,\n  &size-actual,\n  &shuffle,\n  &share-alt,\n  &share,\n  &rocket,\n  &question,\n  &pie-chart,\n  &pencil,\n  &note,\n  &loop,\n  &home,\n  &grid,\n  &graph,\n  &microphone,\n  &music-tone-alt,\n  &music-tone,\n  &earphones-alt,\n  &earphones,\n  &equalizer,\n  &like,\n  &dislike,\n  &control-start,\n  &control-rewind,\n  &control-play,\n  &control-pause,\n  &control-forward,\n  &control-end,\n  &volume-1,\n  &volume-2,\n  &volume-off,\n  &calender,\n  &bulb,\n  &chart,\n  &ban,\n  &bubble,\n  &camrecorder,\n  &camera,\n  &cloud-download,\n  &cloud-upload,\n  &envelope,\n  &eye,\n  &flag,\n  &heart,\n  &info,\n  &key,\n  &link,\n  &lock,\n  &lock-open,\n  &magnifier,\n  &magnifier-add,\n  &magnifier-remove,\n  &paper-clip,\n  &paper-plane,\n  &power,\n  &refresh,\n  &reload,\n  &settings,\n  &star,\n  &symble-female,\n  &symbol-male,\n  &target,\n  &credit-card,\n  &paypal,\n  &social-tumblr,\n  &social-twitter,\n  &social-facebook,\n  &social-instagram,\n  &social-linkedin,\n  &social-pintarest,\n  &social-github,\n  &social-gplus,\n  &social-reddit,\n  &social-skype,\n  &social-dribbble,\n  &social-behance,\n  &social-foursqare,\n  &social-soundcloud,\n  &social-spotify,\n  &social-stumbleupon,\n  &social-youtube,\n  &social-dropbox {\n    font-family: '#{$simple-line-font-family}';\n    speak: none;\n    font-style: normal;\n    font-weight: normal;\n    font-variant: normal;\n    text-transform: none;\n    line-height: 1;\n\n    /* Better Font Rendering =========== */\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n }\n}\n\n.#{$simple-line-icon-prefix}user:before {\n  content: \"\\e005\";\n}\n\n.#{$simple-line-icon-prefix}people:before {\n  content: \"\\e001\";\n}\n\n.#{$simple-line-icon-prefix}user-female:before {\n  content: \"\\e000\";\n}\n\n.#{$simple-line-icon-prefix}user-follow:before {\n  content: \"\\e002\";\n}\n\n.#{$simple-line-icon-prefix}user-following:before {\n  content: \"\\e003\";\n}\n\n.#{$simple-line-icon-prefix}user-unfollow:before {\n  content: \"\\e004\";\n}\n\n.#{$simple-line-icon-prefix}login:before {\n  content: \"\\e066\";\n}\n\n.#{$simple-line-icon-prefix}logout:before {\n  content: \"\\e065\";\n}\n\n.#{$simple-line-icon-prefix}emotsmile:before {\n  content: \"\\e021\";\n}\n\n.#{$simple-line-icon-prefix}phone:before {\n  content: \"\\e600\";\n}\n\n.#{$simple-line-icon-prefix}call-end:before {\n  content: \"\\e048\";\n}\n\n.#{$simple-line-icon-prefix}call-in:before {\n  content: \"\\e047\";\n}\n\n.#{$simple-line-icon-prefix}call-out:before {\n  content: \"\\e046\";\n}\n\n.#{$simple-line-icon-prefix}map:before {\n  content: \"\\e033\";\n}\n\n.#{$simple-line-icon-prefix}location-pin:before {\n  content: \"\\e096\";\n}\n\n.#{$simple-line-icon-prefix}direction:before {\n  content: \"\\e042\";\n}\n\n.#{$simple-line-icon-prefix}directions:before {\n  content: \"\\e041\";\n}\n\n.#{$simple-line-icon-prefix}compass:before {\n  content: \"\\e045\";\n}\n\n.#{$simple-line-icon-prefix}layers:before {\n  content: \"\\e034\";\n}\n\n.#{$simple-line-icon-prefix}menu:before {\n  content: \"\\e601\";\n}\n\n.#{$simple-line-icon-prefix}list:before {\n  content: \"\\e067\";\n}\n\n.#{$simple-line-icon-prefix}options-vertical:before {\n  content: \"\\e602\";\n}\n\n.#{$simple-line-icon-prefix}options:before {\n  content: \"\\e603\";\n}\n\n.#{$simple-line-icon-prefix}arrow-down:before {\n  content: \"\\e604\";\n}\n\n.#{$simple-line-icon-prefix}arrow-left:before {\n  content: \"\\e605\";\n}\n\n.#{$simple-line-icon-prefix}arrow-right:before {\n  content: \"\\e606\";\n}\n\n.#{$simple-line-icon-prefix}arrow-up:before {\n  content: \"\\e607\";\n}\n\n.#{$simple-line-icon-prefix}arrow-up-circle:before {\n  content: \"\\e078\";\n}\n\n.#{$simple-line-icon-prefix}arrow-left-circle:before {\n  content: \"\\e07a\";\n}\n\n.#{$simple-line-icon-prefix}arrow-right-circle:before {\n  content: \"\\e079\";\n}\n\n.#{$simple-line-icon-prefix}arrow-down-circle:before {\n  content: \"\\e07b\";\n}\n\n.#{$simple-line-icon-prefix}check:before {\n  content: \"\\e080\";\n}\n\n.#{$simple-line-icon-prefix}clock:before {\n  content: \"\\e081\";\n}\n\n.#{$simple-line-icon-prefix}plus:before {\n  content: \"\\e095\";\n}\n\n.#{$simple-line-icon-prefix}close:before {\n  content: \"\\e082\";\n}\n\n.#{$simple-line-icon-prefix}trophy:before {\n  content: \"\\e006\";\n}\n\n.#{$simple-line-icon-prefix}screen-smartphone:before {\n  content: \"\\e010\";\n}\n\n.#{$simple-line-icon-prefix}screen-desktop:before {\n  content: \"\\e011\";\n}\n\n.#{$simple-line-icon-prefix}plane:before {\n  content: \"\\e012\";\n}\n\n.#{$simple-line-icon-prefix}notebook:before {\n  content: \"\\e013\";\n}\n\n.#{$simple-line-icon-prefix}mustache:before {\n  content: \"\\e014\";\n}\n\n.#{$simple-line-icon-prefix}mouse:before {\n  content: \"\\e015\";\n}\n\n.#{$simple-line-icon-prefix}magnet:before {\n  content: \"\\e016\";\n}\n\n.#{$simple-line-icon-prefix}energy:before {\n  content: \"\\e020\";\n}\n\n.#{$simple-line-icon-prefix}disc:before {\n  content: \"\\e022\";\n}\n\n.#{$simple-line-icon-prefix}cursor:before {\n  content: \"\\e06e\";\n}\n\n.#{$simple-line-icon-prefix}cursor-move:before {\n  content: \"\\e023\";\n}\n\n.#{$simple-line-icon-prefix}crop:before {\n  content: \"\\e024\";\n}\n\n.#{$simple-line-icon-prefix}chemistry:before {\n  content: \"\\e026\";\n}\n\n.#{$simple-line-icon-prefix}speedometer:before {\n  content: \"\\e007\";\n}\n\n.#{$simple-line-icon-prefix}shield:before {\n  content: \"\\e00e\";\n}\n\n.#{$simple-line-icon-prefix}screen-tablet:before {\n  content: \"\\e00f\";\n}\n\n.#{$simple-line-icon-prefix}magic-wand:before {\n  content: \"\\e017\";\n}\n\n.#{$simple-line-icon-prefix}hourglass:before {\n  content: \"\\e018\";\n}\n\n.#{$simple-line-icon-prefix}graduation:before {\n  content: \"\\e019\";\n}\n\n.#{$simple-line-icon-prefix}ghost:before {\n  content: \"\\e01a\";\n}\n\n.#{$simple-line-icon-prefix}game-controller:before {\n  content: \"\\e01b\";\n}\n\n.#{$simple-line-icon-prefix}fire:before {\n  content: \"\\e01c\";\n}\n\n.#{$simple-line-icon-prefix}eyeglass:before {\n  content: \"\\e01d\";\n}\n\n.#{$simple-line-icon-prefix}envelope-open:before {\n  content: \"\\e01e\";\n}\n\n.#{$simple-line-icon-prefix}envelope-letter:before {\n  content: \"\\e01f\";\n}\n\n.#{$simple-line-icon-prefix}bell:before {\n  content: \"\\e027\";\n}\n\n.#{$simple-line-icon-prefix}badge:before {\n  content: \"\\e028\";\n}\n\n.#{$simple-line-icon-prefix}anchor:before {\n  content: \"\\e029\";\n}\n\n.#{$simple-line-icon-prefix}wallet:before {\n  content: \"\\e02a\";\n}\n\n.#{$simple-line-icon-prefix}vector:before {\n  content: \"\\e02b\";\n}\n\n.#{$simple-line-icon-prefix}speech:before {\n  content: \"\\e02c\";\n}\n\n.#{$simple-line-icon-prefix}puzzle:before {\n  content: \"\\e02d\";\n}\n\n.#{$simple-line-icon-prefix}printer:before {\n  content: \"\\e02e\";\n}\n\n.#{$simple-line-icon-prefix}present:before {\n  content: \"\\e02f\";\n}\n\n.#{$simple-line-icon-prefix}playlist:before {\n  content: \"\\e030\";\n}\n\n.#{$simple-line-icon-prefix}pin:before {\n  content: \"\\e031\";\n}\n\n.#{$simple-line-icon-prefix}picture:before {\n  content: \"\\e032\";\n}\n\n.#{$simple-line-icon-prefix}handbag:before {\n  content: \"\\e035\";\n}\n\n.#{$simple-line-icon-prefix}globe-alt:before {\n  content: \"\\e036\";\n}\n\n.#{$simple-line-icon-prefix}globe:before {\n  content: \"\\e037\";\n}\n\n.#{$simple-line-icon-prefix}folder-alt:before {\n  content: \"\\e039\";\n}\n\n.#{$simple-line-icon-prefix}folder:before {\n  content: \"\\e089\";\n}\n\n.#{$simple-line-icon-prefix}film:before {\n  content: \"\\e03a\";\n}\n\n.#{$simple-line-icon-prefix}feed:before {\n  content: \"\\e03b\";\n}\n\n.#{$simple-line-icon-prefix}drop:before {\n  content: \"\\e03e\";\n}\n\n.#{$simple-line-icon-prefix}drawar:before {\n  content: \"\\e03f\";\n}\n\n.#{$simple-line-icon-prefix}docs:before {\n  content: \"\\e040\";\n}\n\n.#{$simple-line-icon-prefix}doc:before {\n  content: \"\\e085\";\n}\n\n.#{$simple-line-icon-prefix}diamond:before {\n  content: \"\\e043\";\n}\n\n.#{$simple-line-icon-prefix}cup:before {\n  content: \"\\e044\";\n}\n\n.#{$simple-line-icon-prefix}calculator:before {\n  content: \"\\e049\";\n}\n\n.#{$simple-line-icon-prefix}bubbles:before {\n  content: \"\\e04a\";\n}\n\n.#{$simple-line-icon-prefix}briefcase:before {\n  content: \"\\e04b\";\n}\n\n.#{$simple-line-icon-prefix}book-open:before {\n  content: \"\\e04c\";\n}\n\n.#{$simple-line-icon-prefix}basket-loaded:before {\n  content: \"\\e04d\";\n}\n\n.#{$simple-line-icon-prefix}basket:before {\n  content: \"\\e04e\";\n}\n\n.#{$simple-line-icon-prefix}bag:before {\n  content: \"\\e04f\";\n}\n\n.#{$simple-line-icon-prefix}action-undo:before {\n  content: \"\\e050\";\n}\n\n.#{$simple-line-icon-prefix}action-redo:before {\n  content: \"\\e051\";\n}\n\n.#{$simple-line-icon-prefix}wrench:before {\n  content: \"\\e052\";\n}\n\n.#{$simple-line-icon-prefix}umbrella:before {\n  content: \"\\e053\";\n}\n\n.#{$simple-line-icon-prefix}trash:before {\n  content: \"\\e054\";\n}\n\n.#{$simple-line-icon-prefix}tag:before {\n  content: \"\\e055\";\n}\n\n.#{$simple-line-icon-prefix}support:before {\n  content: \"\\e056\";\n}\n\n.#{$simple-line-icon-prefix}frame:before {\n  content: \"\\e038\";\n}\n\n.#{$simple-line-icon-prefix}size-fullscreen:before {\n  content: \"\\e057\";\n}\n\n.#{$simple-line-icon-prefix}size-actual:before {\n  content: \"\\e058\";\n}\n\n.#{$simple-line-icon-prefix}shuffle:before {\n  content: \"\\e059\";\n}\n\n.#{$simple-line-icon-prefix}share-alt:before {\n  content: \"\\e05a\";\n}\n\n.#{$simple-line-icon-prefix}share:before {\n  content: \"\\e05b\";\n}\n\n.#{$simple-line-icon-prefix}rocket:before {\n  content: \"\\e05c\";\n}\n\n.#{$simple-line-icon-prefix}question:before {\n  content: \"\\e05d\";\n}\n\n.#{$simple-line-icon-prefix}pie-chart:before {\n  content: \"\\e05e\";\n}\n\n.#{$simple-line-icon-prefix}pencil:before {\n  content: \"\\e05f\";\n}\n\n.#{$simple-line-icon-prefix}note:before {\n  content: \"\\e060\";\n}\n\n.#{$simple-line-icon-prefix}loop:before {\n  content: \"\\e064\";\n}\n\n.#{$simple-line-icon-prefix}home:before {\n  content: \"\\e069\";\n}\n\n.#{$simple-line-icon-prefix}grid:before {\n  content: \"\\e06a\";\n}\n\n.#{$simple-line-icon-prefix}graph:before {\n  content: \"\\e06b\";\n}\n\n.#{$simple-line-icon-prefix}microphone:before {\n  content: \"\\e063\";\n}\n\n.#{$simple-line-icon-prefix}music-tone-alt:before {\n  content: \"\\e061\";\n}\n\n.#{$simple-line-icon-prefix}music-tone:before {\n  content: \"\\e062\";\n}\n\n.#{$simple-line-icon-prefix}earphones-alt:before {\n  content: \"\\e03c\";\n}\n\n.#{$simple-line-icon-prefix}earphones:before {\n  content: \"\\e03d\";\n}\n\n.#{$simple-line-icon-prefix}equalizer:before {\n  content: \"\\e06c\";\n}\n\n.#{$simple-line-icon-prefix}like:before {\n  content: \"\\e068\";\n}\n\n.#{$simple-line-icon-prefix}dislike:before {\n  content: \"\\e06d\";\n}\n\n.#{$simple-line-icon-prefix}control-start:before {\n  content: \"\\e06f\";\n}\n\n.#{$simple-line-icon-prefix}control-rewind:before {\n  content: \"\\e070\";\n}\n\n.#{$simple-line-icon-prefix}control-play:before {\n  content: \"\\e071\";\n}\n\n.#{$simple-line-icon-prefix}control-pause:before {\n  content: \"\\e072\";\n}\n\n.#{$simple-line-icon-prefix}control-forward:before {\n  content: \"\\e073\";\n}\n\n.#{$simple-line-icon-prefix}control-end:before {\n  content: \"\\e074\";\n}\n\n.#{$simple-line-icon-prefix}volume-1:before {\n  content: \"\\e09f\";\n}\n\n.#{$simple-line-icon-prefix}volume-2:before {\n  content: \"\\e0a0\";\n}\n\n.#{$simple-line-icon-prefix}volume-off:before {\n  content: \"\\e0a1\";\n}\n\n.#{$simple-line-icon-prefix}calender:before {\n  content: \"\\e075\";\n}\n\n.#{$simple-line-icon-prefix}bulb:before {\n  content: \"\\e076\";\n}\n\n.#{$simple-line-icon-prefix}chart:before {\n  content: \"\\e077\";\n}\n\n.#{$simple-line-icon-prefix}ban:before {\n  content: \"\\e07c\";\n}\n\n.#{$simple-line-icon-prefix}bubble:before {\n  content: \"\\e07d\";\n}\n\n.#{$simple-line-icon-prefix}camrecorder:before {\n  content: \"\\e07e\";\n}\n\n.#{$simple-line-icon-prefix}camera:before {\n  content: \"\\e07f\";\n}\n\n.#{$simple-line-icon-prefix}cloud-download:before {\n  content: \"\\e083\";\n}\n\n.#{$simple-line-icon-prefix}cloud-upload:before {\n  content: \"\\e084\";\n}\n\n.#{$simple-line-icon-prefix}envelope:before {\n  content: \"\\e086\";\n}\n\n.#{$simple-line-icon-prefix}eye:before {\n  content: \"\\e087\";\n}\n\n.#{$simple-line-icon-prefix}flag:before {\n  content: \"\\e088\";\n}\n\n.#{$simple-line-icon-prefix}heart:before {\n  content: \"\\e08a\";\n}\n\n.#{$simple-line-icon-prefix}info:before {\n  content: \"\\e08b\";\n}\n\n.#{$simple-line-icon-prefix}key:before {\n  content: \"\\e08c\";\n}\n\n.#{$simple-line-icon-prefix}link:before {\n  content: \"\\e08d\";\n}\n\n.#{$simple-line-icon-prefix}lock:before {\n  content: \"\\e08e\";\n}\n\n.#{$simple-line-icon-prefix}lock-open:before {\n  content: \"\\e08f\";\n}\n\n.#{$simple-line-icon-prefix}magnifier:before {\n  content: \"\\e090\";\n}\n\n.#{$simple-line-icon-prefix}magnifier-add:before {\n  content: \"\\e091\";\n}\n\n.#{$simple-line-icon-prefix}magnifier-remove:before {\n  content: \"\\e092\";\n}\n\n.#{$simple-line-icon-prefix}paper-clip:before {\n  content: \"\\e093\";\n}\n\n.#{$simple-line-icon-prefix}paper-plane:before {\n  content: \"\\e094\";\n}\n\n.#{$simple-line-icon-prefix}power:before {\n  content: \"\\e097\";\n}\n\n.#{$simple-line-icon-prefix}refresh:before {\n  content: \"\\e098\";\n}\n\n.#{$simple-line-icon-prefix}reload:before {\n  content: \"\\e099\";\n}\n\n.#{$simple-line-icon-prefix}settings:before {\n  content: \"\\e09a\";\n}\n\n.#{$simple-line-icon-prefix}star:before {\n  content: \"\\e09b\";\n}\n\n.#{$simple-line-icon-prefix}symble-female:before {\n  content: \"\\e09c\";\n}\n\n.#{$simple-line-icon-prefix}symbol-male:before {\n  content: \"\\e09d\";\n}\n\n.#{$simple-line-icon-prefix}target:before {\n  content: \"\\e09e\";\n}\n\n.#{$simple-line-icon-prefix}credit-card:before {\n  content: \"\\e025\";\n}\n\n.#{$simple-line-icon-prefix}paypal:before {\n  content: \"\\e608\";\n}\n\n.#{$simple-line-icon-prefix}social-tumblr:before {\n  content: \"\\e00a\";\n}\n\n.#{$simple-line-icon-prefix}social-twitter:before {\n  content: \"\\e009\";\n}\n\n.#{$simple-line-icon-prefix}social-facebook:before {\n  content: \"\\e00b\";\n}\n\n.#{$simple-line-icon-prefix}social-instagram:before {\n  content: \"\\e609\";\n}\n\n.#{$simple-line-icon-prefix}social-linkedin:before {\n  content: \"\\e60a\";\n}\n\n.#{$simple-line-icon-prefix}social-pintarest:before {\n  content: \"\\e60b\";\n}\n\n.#{$simple-line-icon-prefix}social-github:before {\n  content: \"\\e60c\";\n}\n\n.#{$simple-line-icon-prefix}social-gplus:before {\n  content: \"\\e60d\";\n}\n\n.#{$simple-line-icon-prefix}social-reddit:before {\n  content: \"\\e60e\";\n}\n\n.#{$simple-line-icon-prefix}social-skype:before {\n  content: \"\\e60f\";\n}\n\n.#{$simple-line-icon-prefix}social-dribbble:before {\n  content: \"\\e00d\";\n}\n\n.#{$simple-line-icon-prefix}social-behance:before {\n  content: \"\\e610\";\n}\n\n.#{$simple-line-icon-prefix}social-foursqare:before {\n  content: \"\\e611\";\n}\n\n.#{$simple-line-icon-prefix}social-soundcloud:before {\n  content: \"\\e612\";\n}\n\n.#{$simple-line-icon-prefix}social-spotify:before {\n  content: \"\\e613\";\n}\n\n.#{$simple-line-icon-prefix}social-stumbleupon:before {\n  content: \"\\e614\";\n}\n\n.#{$simple-line-icon-prefix}social-youtube:before {\n  content: \"\\e008\";\n}\n\n.#{$simple-line-icon-prefix}social-dropbox:before {\n  content: \"\\e00c\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/themify-icons/ie7/ie7.css",
    "content": ".ti-wand {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe600;');\n}\n.ti-volume {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe601;');\n}\n.ti-user {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe602;');\n}\n.ti-unlock {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe603;');\n}\n.ti-unlink {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe604;');\n}\n.ti-trash {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe605;');\n}\n.ti-thought {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe606;');\n}\n.ti-target {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe607;');\n}\n.ti-tag {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe608;');\n}\n.ti-tablet {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe609;');\n}\n.ti-star {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60a;');\n}\n.ti-spray {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60b;');\n}\n.ti-signal {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60c;');\n}\n.ti-shopping-cart {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60d;');\n}\n.ti-shopping-cart-full {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60e;');\n}\n.ti-settings {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe60f;');\n}\n.ti-search {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe610;');\n}\n.ti-zoom-in {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe611;');\n}\n.ti-zoom-out {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe612;');\n}\n.ti-cut {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe613;');\n}\n.ti-ruler {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe614;');\n}\n.ti-ruler-pencil {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe615;');\n}\n.ti-ruler-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe616;');\n}\n.ti-bookmark {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe617;');\n}\n.ti-bookmark-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe618;');\n}\n.ti-reload {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe619;');\n}\n.ti-plus {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61a;');\n}\n.ti-pin {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61b;');\n}\n.ti-pencil {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61c;');\n}\n.ti-pencil-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61d;');\n}\n.ti-paint-roller {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61e;');\n}\n.ti-paint-bucket {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe61f;');\n}\n.ti-na {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe620;');\n}\n.ti-mobile {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe621;');\n}\n.ti-minus {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe622;');\n}\n.ti-medall {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe623;');\n}\n.ti-medall-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe624;');\n}\n.ti-marker {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe625;');\n}\n.ti-marker-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe626;');\n}\n.ti-arrow-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe627;');\n}\n.ti-arrow-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe628;');\n}\n.ti-arrow-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe629;');\n}\n.ti-arrow-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62a;');\n}\n.ti-lock {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62b;');\n}\n.ti-location-arrow {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62c;');\n}\n.ti-link {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62d;');\n}\n.ti-layout {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62e;');\n}\n.ti-layers {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe62f;');\n}\n.ti-layers-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe630;');\n}\n.ti-key {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe631;');\n}\n.ti-import {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe632;');\n}\n.ti-image {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe633;');\n}\n.ti-heart {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe634;');\n}\n.ti-heart-broken {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe635;');\n}\n.ti-hand-stop {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe636;');\n}\n.ti-hand-open {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe637;');\n}\n.ti-hand-drag {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe638;');\n}\n.ti-folder {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe639;');\n}\n.ti-flag {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63a;');\n}\n.ti-flag-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63b;');\n}\n.ti-flag-alt-2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63c;');\n}\n.ti-eye {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63d;');\n}\n.ti-export {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63e;');\n}\n.ti-exchange-vertical {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe63f;');\n}\n.ti-desktop {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe640;');\n}\n.ti-cup {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe641;');\n}\n.ti-crown {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe642;');\n}\n.ti-comments {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe643;');\n}\n.ti-comment {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe644;');\n}\n.ti-comment-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe645;');\n}\n.ti-close {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe646;');\n}\n.ti-clip {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe647;');\n}\n.ti-angle-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe648;');\n}\n.ti-angle-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe649;');\n}\n.ti-angle-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64a;');\n}\n.ti-angle-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64b;');\n}\n.ti-check {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64c;');\n}\n.ti-check-box {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64d;');\n}\n.ti-camera {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64e;');\n}\n.ti-announcement {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe64f;');\n}\n.ti-brush {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe650;');\n}\n.ti-briefcase {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe651;');\n}\n.ti-bolt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe652;');\n}\n.ti-bolt-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe653;');\n}\n.ti-blackboard {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe654;');\n}\n.ti-bag {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe655;');\n}\n.ti-move {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe656;');\n}\n.ti-arrows-vertical {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe657;');\n}\n.ti-arrows-horizontal {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe658;');\n}\n.ti-fullscreen {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe659;');\n}\n.ti-arrow-top-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65a;');\n}\n.ti-arrow-top-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65b;');\n}\n.ti-arrow-circle-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65c;');\n}\n.ti-arrow-circle-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65d;');\n}\n.ti-arrow-circle-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65e;');\n}\n.ti-arrow-circle-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe65f;');\n}\n.ti-angle-double-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe660;');\n}\n.ti-angle-double-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe661;');\n}\n.ti-angle-double-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe662;');\n}\n.ti-angle-double-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe663;');\n}\n.ti-zip {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe664;');\n}\n.ti-world {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe665;');\n}\n.ti-wheelchair {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe666;');\n}\n.ti-view-list {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe667;');\n}\n.ti-view-list-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe668;');\n}\n.ti-view-grid {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe669;');\n}\n.ti-uppercase {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66a;');\n}\n.ti-upload {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66b;');\n}\n.ti-underline {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66c;');\n}\n.ti-truck {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66d;');\n}\n.ti-timer {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66e;');\n}\n.ti-ticket {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe66f;');\n}\n.ti-thumb-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe670;');\n}\n.ti-thumb-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe671;');\n}\n.ti-text {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe672;');\n}\n.ti-stats-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe673;');\n}\n.ti-stats-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe674;');\n}\n.ti-split-v {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe675;');\n}\n.ti-split-h {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe676;');\n}\n.ti-smallcap {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe677;');\n}\n.ti-shine {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe678;');\n}\n.ti-shift-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe679;');\n}\n.ti-shift-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67a;');\n}\n.ti-shield {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67b;');\n}\n.ti-notepad {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67c;');\n}\n.ti-server {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67d;');\n}\n.ti-quote-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67e;');\n}\n.ti-quote-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe67f;');\n}\n.ti-pulse {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe680;');\n}\n.ti-printer {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe681;');\n}\n.ti-power-off {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe682;');\n}\n.ti-plug {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe683;');\n}\n.ti-pie-chart {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe684;');\n}\n.ti-paragraph {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe685;');\n}\n.ti-panel {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe686;');\n}\n.ti-package {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe687;');\n}\n.ti-music {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe688;');\n}\n.ti-music-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe689;');\n}\n.ti-mouse {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68a;');\n}\n.ti-mouse-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68b;');\n}\n.ti-money {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68c;');\n}\n.ti-microphone {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68d;');\n}\n.ti-menu {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68e;');\n}\n.ti-menu-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe68f;');\n}\n.ti-map {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe690;');\n}\n.ti-map-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe691;');\n}\n.ti-loop {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe692;');\n}\n.ti-location-pin {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe693;');\n}\n.ti-list {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe694;');\n}\n.ti-light-bulb {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe695;');\n}\n.ti-Italic {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe696;');\n}\n.ti-info {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe697;');\n}\n.ti-infinite {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe698;');\n}\n.ti-id-badge {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe699;');\n}\n.ti-hummer {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69a;');\n}\n.ti-home {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69b;');\n}\n.ti-help {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69c;');\n}\n.ti-headphone {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69d;');\n}\n.ti-harddrives {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69e;');\n}\n.ti-harddrive {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe69f;');\n}\n.ti-gift {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a0;');\n}\n.ti-game {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a1;');\n}\n.ti-filter {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a2;');\n}\n.ti-files {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a3;');\n}\n.ti-file {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a4;');\n}\n.ti-eraser {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a5;');\n}\n.ti-envelope {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a6;');\n}\n.ti-download {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a7;');\n}\n.ti-direction {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a8;');\n}\n.ti-direction-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6a9;');\n}\n.ti-dashboard {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6aa;');\n}\n.ti-control-stop {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ab;');\n}\n.ti-control-shuffle {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ac;');\n}\n.ti-control-play {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ad;');\n}\n.ti-control-pause {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ae;');\n}\n.ti-control-forward {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6af;');\n}\n.ti-control-backward {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b0;');\n}\n.ti-cloud {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b1;');\n}\n.ti-cloud-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b2;');\n}\n.ti-cloud-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b3;');\n}\n.ti-clipboard {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b4;');\n}\n.ti-car {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b5;');\n}\n.ti-calendar {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b6;');\n}\n.ti-book {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b7;');\n}\n.ti-bell {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b8;');\n}\n.ti-basketball {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6b9;');\n}\n.ti-bar-chart {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ba;');\n}\n.ti-bar-chart-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6bb;');\n}\n.ti-back-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6bc;');\n}\n.ti-back-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6bd;');\n}\n.ti-arrows-corner {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6be;');\n}\n.ti-archive {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6bf;');\n}\n.ti-anchor {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c0;');\n}\n.ti-align-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c1;');\n}\n.ti-align-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c2;');\n}\n.ti-align-justify {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c3;');\n}\n.ti-align-center {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c4;');\n}\n.ti-alert {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c5;');\n}\n.ti-alarm-clock {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c6;');\n}\n.ti-agenda {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c7;');\n}\n.ti-write {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c8;');\n}\n.ti-window {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6c9;');\n}\n.ti-widgetized {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ca;');\n}\n.ti-widget {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6cb;');\n}\n.ti-widget-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6cc;');\n}\n.ti-wallet {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6cd;');\n}\n.ti-video-clapper {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ce;');\n}\n.ti-video-camera {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6cf;');\n}\n.ti-vector {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d0;');\n}\n.ti-themify-logo {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d1;');\n}\n.ti-themify-favicon {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d2;');\n}\n.ti-themify-favicon-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d3;');\n}\n.ti-support {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d4;');\n}\n.ti-stamp {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d5;');\n}\n.ti-split-v-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d6;');\n}\n.ti-slice {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d7;');\n}\n.ti-shortcode {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d8;');\n}\n.ti-shift-right-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6d9;');\n}\n.ti-shift-left-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6da;');\n}\n.ti-ruler-alt-2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6db;');\n}\n.ti-receipt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6dc;');\n}\n.ti-pin2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6dd;');\n}\n.ti-pin-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6de;');\n}\n.ti-pencil-alt2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6df;');\n}\n.ti-palette {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e0;');\n}\n.ti-more {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e1;');\n}\n.ti-more-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e2;');\n}\n.ti-microphone-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e3;');\n}\n.ti-magnet {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e4;');\n}\n.ti-line-double {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e5;');\n}\n.ti-line-dotted {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e6;');\n}\n.ti-line-dashed {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e7;');\n}\n.ti-layout-width-full {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e8;');\n}\n.ti-layout-width-default {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6e9;');\n}\n.ti-layout-width-default-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ea;');\n}\n.ti-layout-tab {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6eb;');\n}\n.ti-layout-tab-window {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ec;');\n}\n.ti-layout-tab-v {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ed;');\n}\n.ti-layout-tab-min {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ee;');\n}\n.ti-layout-slider {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ef;');\n}\n.ti-layout-slider-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f0;');\n}\n.ti-layout-sidebar-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f1;');\n}\n.ti-layout-sidebar-none {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f2;');\n}\n.ti-layout-sidebar-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f3;');\n}\n.ti-layout-placeholder {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f4;');\n}\n.ti-layout-menu {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f5;');\n}\n.ti-layout-menu-v {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f6;');\n}\n.ti-layout-menu-separated {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f7;');\n}\n.ti-layout-menu-full {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f8;');\n}\n.ti-layout-media-right-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6f9;');\n}\n.ti-layout-media-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6fa;');\n}\n.ti-layout-media-overlay {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6fb;');\n}\n.ti-layout-media-overlay-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6fc;');\n}\n.ti-layout-media-overlay-alt-2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6fd;');\n}\n.ti-layout-media-left-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6fe;');\n}\n.ti-layout-media-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe6ff;');\n}\n.ti-layout-media-center-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe700;');\n}\n.ti-layout-media-center {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe701;');\n}\n.ti-layout-list-thumb {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe702;');\n}\n.ti-layout-list-thumb-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe703;');\n}\n.ti-layout-list-post {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe704;');\n}\n.ti-layout-list-large-image {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe705;');\n}\n.ti-layout-line-solid {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe706;');\n}\n.ti-layout-grid4 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe707;');\n}\n.ti-layout-grid3 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe708;');\n}\n.ti-layout-grid2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe709;');\n}\n.ti-layout-grid2-thumb {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70a;');\n}\n.ti-layout-cta-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70b;');\n}\n.ti-layout-cta-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70c;');\n}\n.ti-layout-cta-center {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70d;');\n}\n.ti-layout-cta-btn-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70e;');\n}\n.ti-layout-cta-btn-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe70f;');\n}\n.ti-layout-column4 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe710;');\n}\n.ti-layout-column3 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe711;');\n}\n.ti-layout-column2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe712;');\n}\n.ti-layout-accordion-separated {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe713;');\n}\n.ti-layout-accordion-merged {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe714;');\n}\n.ti-layout-accordion-list {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe715;');\n}\n.ti-ink-pen {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe716;');\n}\n.ti-info-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe717;');\n}\n.ti-help-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe718;');\n}\n.ti-headphone-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe719;');\n}\n.ti-hand-point-up {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71a;');\n}\n.ti-hand-point-right {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71b;');\n}\n.ti-hand-point-left {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71c;');\n}\n.ti-hand-point-down {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71d;');\n}\n.ti-gallery {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71e;');\n}\n.ti-face-smile {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe71f;');\n}\n.ti-face-sad {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe720;');\n}\n.ti-credit-card {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe721;');\n}\n.ti-control-skip-forward {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe722;');\n}\n.ti-control-skip-backward {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe723;');\n}\n.ti-control-record {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe724;');\n}\n.ti-control-eject {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe725;');\n}\n.ti-comments-smiley {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe726;');\n}\n.ti-brush-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe727;');\n}\n.ti-youtube {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe728;');\n}\n.ti-vimeo {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe729;');\n}\n.ti-twitter {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72a;');\n}\n.ti-time {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72b;');\n}\n.ti-tumblr {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72c;');\n}\n.ti-skype {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72d;');\n}\n.ti-share {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72e;');\n}\n.ti-share-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe72f;');\n}\n.ti-rocket {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe730;');\n}\n.ti-pinterest {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe731;');\n}\n.ti-new-window {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe732;');\n}\n.ti-microsoft {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe733;');\n}\n.ti-list-ol {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe734;');\n}\n.ti-linkedin {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe735;');\n}\n.ti-layout-sidebar-2 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe736;');\n}\n.ti-layout-grid4-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe737;');\n}\n.ti-layout-grid3-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe738;');\n}\n.ti-layout-grid2-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe739;');\n}\n.ti-layout-column4-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73a;');\n}\n.ti-layout-column3-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73b;');\n}\n.ti-layout-column2-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73c;');\n}\n.ti-instagram {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73d;');\n}\n.ti-google {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73e;');\n}\n.ti-github {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe73f;');\n}\n.ti-flickr {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe740;');\n}\n.ti-facebook {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe741;');\n}\n.ti-dropbox {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe742;');\n}\n.ti-dribbble {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe743;');\n}\n.ti-apple {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe744;');\n}\n.ti-android {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe745;');\n}\n.ti-save {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe746;');\n}\n.ti-save-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe747;');\n}\n.ti-yahoo {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe748;');\n}\n.ti-wordpress {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe749;');\n}\n.ti-vimeo-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74a;');\n}\n.ti-twitter-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74b;');\n}\n.ti-tumblr-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74c;');\n}\n.ti-trello {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74d;');\n}\n.ti-stack-overflow {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74e;');\n}\n.ti-soundcloud {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe74f;');\n}\n.ti-sharethis {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe750;');\n}\n.ti-sharethis-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe751;');\n}\n.ti-reddit {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe752;');\n}\n.ti-pinterest-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe753;');\n}\n.ti-microsoft-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe754;');\n}\n.ti-linux {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe755;');\n}\n.ti-jsfiddle {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe756;');\n}\n.ti-joomla {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe757;');\n}\n.ti-html5 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe758;');\n}\n.ti-flickr-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe759;');\n}\n.ti-email {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75a;');\n}\n.ti-drupal {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75b;');\n}\n.ti-dropbox-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75c;');\n}\n.ti-css3 {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75d;');\n}\n.ti-rss {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75e;');\n}\n.ti-rss-alt {\n\t*zoom: expression(this.runtimeStyle['zoom'] = '1', this.innerHTML = '&#xe75f;');\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/themify-icons/ie7/ie7.js",
    "content": "/* To avoid CSS expressions while still supporting IE 7 and IE 6, use this script */\n/* The script tag referring to this file must be placed before the ending body tag. */\n\n/* Use conditional comments in order to target IE 7 and older:\n\t<!--[if lt IE 8]><!-->\n\t<script src=\"ie7/ie7.js\"></script>\n\t<!--<![endif]-->\n*/\n\n(function() {\n\tfunction addIcon(el, entity) {\n\t\tvar html = el.innerHTML;\n\t\tel.innerHTML = '<span style=\"font-family: \\'themify\\'\">' + entity + '</span>' + html;\n\t}\n\tvar icons = {\n\t\t'ti-wand': '&#xe600;',\n\t\t'ti-volume': '&#xe601;',\n\t\t'ti-user': '&#xe602;',\n\t\t'ti-unlock': '&#xe603;',\n\t\t'ti-unlink': '&#xe604;',\n\t\t'ti-trash': '&#xe605;',\n\t\t'ti-thought': '&#xe606;',\n\t\t'ti-target': '&#xe607;',\n\t\t'ti-tag': '&#xe608;',\n\t\t'ti-tablet': '&#xe609;',\n\t\t'ti-star': '&#xe60a;',\n\t\t'ti-spray': '&#xe60b;',\n\t\t'ti-signal': '&#xe60c;',\n\t\t'ti-shopping-cart': '&#xe60d;',\n\t\t'ti-shopping-cart-full': '&#xe60e;',\n\t\t'ti-settings': '&#xe60f;',\n\t\t'ti-search': '&#xe610;',\n\t\t'ti-zoom-in': '&#xe611;',\n\t\t'ti-zoom-out': '&#xe612;',\n\t\t'ti-cut': '&#xe613;',\n\t\t'ti-ruler': '&#xe614;',\n\t\t'ti-ruler-pencil': '&#xe615;',\n\t\t'ti-ruler-alt': '&#xe616;',\n\t\t'ti-bookmark': '&#xe617;',\n\t\t'ti-bookmark-alt': '&#xe618;',\n\t\t'ti-reload': '&#xe619;',\n\t\t'ti-plus': '&#xe61a;',\n\t\t'ti-pin': '&#xe61b;',\n\t\t'ti-pencil': '&#xe61c;',\n\t\t'ti-pencil-alt': '&#xe61d;',\n\t\t'ti-paint-roller': '&#xe61e;',\n\t\t'ti-paint-bucket': '&#xe61f;',\n\t\t'ti-na': '&#xe620;',\n\t\t'ti-mobile': '&#xe621;',\n\t\t'ti-minus': '&#xe622;',\n\t\t'ti-medall': '&#xe623;',\n\t\t'ti-medall-alt': '&#xe624;',\n\t\t'ti-marker': '&#xe625;',\n\t\t'ti-marker-alt': '&#xe626;',\n\t\t'ti-arrow-up': '&#xe627;',\n\t\t'ti-arrow-right': '&#xe628;',\n\t\t'ti-arrow-left': '&#xe629;',\n\t\t'ti-arrow-down': '&#xe62a;',\n\t\t'ti-lock': '&#xe62b;',\n\t\t'ti-location-arrow': '&#xe62c;',\n\t\t'ti-link': '&#xe62d;',\n\t\t'ti-layout': '&#xe62e;',\n\t\t'ti-layers': '&#xe62f;',\n\t\t'ti-layers-alt': '&#xe630;',\n\t\t'ti-key': '&#xe631;',\n\t\t'ti-import': '&#xe632;',\n\t\t'ti-image': '&#xe633;',\n\t\t'ti-heart': '&#xe634;',\n\t\t'ti-heart-broken': '&#xe635;',\n\t\t'ti-hand-stop': '&#xe636;',\n\t\t'ti-hand-open': '&#xe637;',\n\t\t'ti-hand-drag': '&#xe638;',\n\t\t'ti-folder': '&#xe639;',\n\t\t'ti-flag': '&#xe63a;',\n\t\t'ti-flag-alt': '&#xe63b;',\n\t\t'ti-flag-alt-2': '&#xe63c;',\n\t\t'ti-eye': '&#xe63d;',\n\t\t'ti-export': '&#xe63e;',\n\t\t'ti-exchange-vertical': '&#xe63f;',\n\t\t'ti-desktop': '&#xe640;',\n\t\t'ti-cup': '&#xe641;',\n\t\t'ti-crown': '&#xe642;',\n\t\t'ti-comments': '&#xe643;',\n\t\t'ti-comment': '&#xe644;',\n\t\t'ti-comment-alt': '&#xe645;',\n\t\t'ti-close': '&#xe646;',\n\t\t'ti-clip': '&#xe647;',\n\t\t'ti-angle-up': '&#xe648;',\n\t\t'ti-angle-right': '&#xe649;',\n\t\t'ti-angle-left': '&#xe64a;',\n\t\t'ti-angle-down': '&#xe64b;',\n\t\t'ti-check': '&#xe64c;',\n\t\t'ti-check-box': '&#xe64d;',\n\t\t'ti-camera': '&#xe64e;',\n\t\t'ti-announcement': '&#xe64f;',\n\t\t'ti-brush': '&#xe650;',\n\t\t'ti-briefcase': '&#xe651;',\n\t\t'ti-bolt': '&#xe652;',\n\t\t'ti-bolt-alt': '&#xe653;',\n\t\t'ti-blackboard': '&#xe654;',\n\t\t'ti-bag': '&#xe655;',\n\t\t'ti-move': '&#xe656;',\n\t\t'ti-arrows-vertical': '&#xe657;',\n\t\t'ti-arrows-horizontal': '&#xe658;',\n\t\t'ti-fullscreen': '&#xe659;',\n\t\t'ti-arrow-top-right': '&#xe65a;',\n\t\t'ti-arrow-top-left': '&#xe65b;',\n\t\t'ti-arrow-circle-up': '&#xe65c;',\n\t\t'ti-arrow-circle-right': '&#xe65d;',\n\t\t'ti-arrow-circle-left': '&#xe65e;',\n\t\t'ti-arrow-circle-down': '&#xe65f;',\n\t\t'ti-angle-double-up': '&#xe660;',\n\t\t'ti-angle-double-right': '&#xe661;',\n\t\t'ti-angle-double-left': '&#xe662;',\n\t\t'ti-angle-double-down': '&#xe663;',\n\t\t'ti-zip': '&#xe664;',\n\t\t'ti-world': '&#xe665;',\n\t\t'ti-wheelchair': '&#xe666;',\n\t\t'ti-view-list': '&#xe667;',\n\t\t'ti-view-list-alt': '&#xe668;',\n\t\t'ti-view-grid': '&#xe669;',\n\t\t'ti-uppercase': '&#xe66a;',\n\t\t'ti-upload': '&#xe66b;',\n\t\t'ti-underline': '&#xe66c;',\n\t\t'ti-truck': '&#xe66d;',\n\t\t'ti-timer': '&#xe66e;',\n\t\t'ti-ticket': '&#xe66f;',\n\t\t'ti-thumb-up': '&#xe670;',\n\t\t'ti-thumb-down': '&#xe671;',\n\t\t'ti-text': '&#xe672;',\n\t\t'ti-stats-up': '&#xe673;',\n\t\t'ti-stats-down': '&#xe674;',\n\t\t'ti-split-v': '&#xe675;',\n\t\t'ti-split-h': '&#xe676;',\n\t\t'ti-smallcap': '&#xe677;',\n\t\t'ti-shine': '&#xe678;',\n\t\t'ti-shift-right': '&#xe679;',\n\t\t'ti-shift-left': '&#xe67a;',\n\t\t'ti-shield': '&#xe67b;',\n\t\t'ti-notepad': '&#xe67c;',\n\t\t'ti-server': '&#xe67d;',\n\t\t'ti-quote-right': '&#xe67e;',\n\t\t'ti-quote-left': '&#xe67f;',\n\t\t'ti-pulse': '&#xe680;',\n\t\t'ti-printer': '&#xe681;',\n\t\t'ti-power-off': '&#xe682;',\n\t\t'ti-plug': '&#xe683;',\n\t\t'ti-pie-chart': '&#xe684;',\n\t\t'ti-paragraph': '&#xe685;',\n\t\t'ti-panel': '&#xe686;',\n\t\t'ti-package': '&#xe687;',\n\t\t'ti-music': '&#xe688;',\n\t\t'ti-music-alt': '&#xe689;',\n\t\t'ti-mouse': '&#xe68a;',\n\t\t'ti-mouse-alt': '&#xe68b;',\n\t\t'ti-money': '&#xe68c;',\n\t\t'ti-microphone': '&#xe68d;',\n\t\t'ti-menu': '&#xe68e;',\n\t\t'ti-menu-alt': '&#xe68f;',\n\t\t'ti-map': '&#xe690;',\n\t\t'ti-map-alt': '&#xe691;',\n\t\t'ti-loop': '&#xe692;',\n\t\t'ti-location-pin': '&#xe693;',\n\t\t'ti-list': '&#xe694;',\n\t\t'ti-light-bulb': '&#xe695;',\n\t\t'ti-Italic': '&#xe696;',\n\t\t'ti-info': '&#xe697;',\n\t\t'ti-infinite': '&#xe698;',\n\t\t'ti-id-badge': '&#xe699;',\n\t\t'ti-hummer': '&#xe69a;',\n\t\t'ti-home': '&#xe69b;',\n\t\t'ti-help': '&#xe69c;',\n\t\t'ti-headphone': '&#xe69d;',\n\t\t'ti-harddrives': '&#xe69e;',\n\t\t'ti-harddrive': '&#xe69f;',\n\t\t'ti-gift': '&#xe6a0;',\n\t\t'ti-game': '&#xe6a1;',\n\t\t'ti-filter': '&#xe6a2;',\n\t\t'ti-files': '&#xe6a3;',\n\t\t'ti-file': '&#xe6a4;',\n\t\t'ti-eraser': '&#xe6a5;',\n\t\t'ti-envelope': '&#xe6a6;',\n\t\t'ti-download': '&#xe6a7;',\n\t\t'ti-direction': '&#xe6a8;',\n\t\t'ti-direction-alt': '&#xe6a9;',\n\t\t'ti-dashboard': '&#xe6aa;',\n\t\t'ti-control-stop': '&#xe6ab;',\n\t\t'ti-control-shuffle': '&#xe6ac;',\n\t\t'ti-control-play': '&#xe6ad;',\n\t\t'ti-control-pause': '&#xe6ae;',\n\t\t'ti-control-forward': '&#xe6af;',\n\t\t'ti-control-backward': '&#xe6b0;',\n\t\t'ti-cloud': '&#xe6b1;',\n\t\t'ti-cloud-up': '&#xe6b2;',\n\t\t'ti-cloud-down': '&#xe6b3;',\n\t\t'ti-clipboard': '&#xe6b4;',\n\t\t'ti-car': '&#xe6b5;',\n\t\t'ti-calendar': '&#xe6b6;',\n\t\t'ti-book': '&#xe6b7;',\n\t\t'ti-bell': '&#xe6b8;',\n\t\t'ti-basketball': '&#xe6b9;',\n\t\t'ti-bar-chart': '&#xe6ba;',\n\t\t'ti-bar-chart-alt': '&#xe6bb;',\n\t\t'ti-back-right': '&#xe6bc;',\n\t\t'ti-back-left': '&#xe6bd;',\n\t\t'ti-arrows-corner': '&#xe6be;',\n\t\t'ti-archive': '&#xe6bf;',\n\t\t'ti-anchor': '&#xe6c0;',\n\t\t'ti-align-right': '&#xe6c1;',\n\t\t'ti-align-left': '&#xe6c2;',\n\t\t'ti-align-justify': '&#xe6c3;',\n\t\t'ti-align-center': '&#xe6c4;',\n\t\t'ti-alert': '&#xe6c5;',\n\t\t'ti-alarm-clock': '&#xe6c6;',\n\t\t'ti-agenda': '&#xe6c7;',\n\t\t'ti-write': '&#xe6c8;',\n\t\t'ti-window': '&#xe6c9;',\n\t\t'ti-widgetized': '&#xe6ca;',\n\t\t'ti-widget': '&#xe6cb;',\n\t\t'ti-widget-alt': '&#xe6cc;',\n\t\t'ti-wallet': '&#xe6cd;',\n\t\t'ti-video-clapper': '&#xe6ce;',\n\t\t'ti-video-camera': '&#xe6cf;',\n\t\t'ti-vector': '&#xe6d0;',\n\t\t'ti-themify-logo': '&#xe6d1;',\n\t\t'ti-themify-favicon': '&#xe6d2;',\n\t\t'ti-themify-favicon-alt': '&#xe6d3;',\n\t\t'ti-support': '&#xe6d4;',\n\t\t'ti-stamp': '&#xe6d5;',\n\t\t'ti-split-v-alt': '&#xe6d6;',\n\t\t'ti-slice': '&#xe6d7;',\n\t\t'ti-shortcode': '&#xe6d8;',\n\t\t'ti-shift-right-alt': '&#xe6d9;',\n\t\t'ti-shift-left-alt': '&#xe6da;',\n\t\t'ti-ruler-alt-2': '&#xe6db;',\n\t\t'ti-receipt': '&#xe6dc;',\n\t\t'ti-pin2': '&#xe6dd;',\n\t\t'ti-pin-alt': '&#xe6de;',\n\t\t'ti-pencil-alt2': '&#xe6df;',\n\t\t'ti-palette': '&#xe6e0;',\n\t\t'ti-more': '&#xe6e1;',\n\t\t'ti-more-alt': '&#xe6e2;',\n\t\t'ti-microphone-alt': '&#xe6e3;',\n\t\t'ti-magnet': '&#xe6e4;',\n\t\t'ti-line-double': '&#xe6e5;',\n\t\t'ti-line-dotted': '&#xe6e6;',\n\t\t'ti-line-dashed': '&#xe6e7;',\n\t\t'ti-layout-width-full': '&#xe6e8;',\n\t\t'ti-layout-width-default': '&#xe6e9;',\n\t\t'ti-layout-width-default-alt': '&#xe6ea;',\n\t\t'ti-layout-tab': '&#xe6eb;',\n\t\t'ti-layout-tab-window': '&#xe6ec;',\n\t\t'ti-layout-tab-v': '&#xe6ed;',\n\t\t'ti-layout-tab-min': '&#xe6ee;',\n\t\t'ti-layout-slider': '&#xe6ef;',\n\t\t'ti-layout-slider-alt': '&#xe6f0;',\n\t\t'ti-layout-sidebar-right': '&#xe6f1;',\n\t\t'ti-layout-sidebar-none': '&#xe6f2;',\n\t\t'ti-layout-sidebar-left': '&#xe6f3;',\n\t\t'ti-layout-placeholder': '&#xe6f4;',\n\t\t'ti-layout-menu': '&#xe6f5;',\n\t\t'ti-layout-menu-v': '&#xe6f6;',\n\t\t'ti-layout-menu-separated': '&#xe6f7;',\n\t\t'ti-layout-menu-full': '&#xe6f8;',\n\t\t'ti-layout-media-right-alt': '&#xe6f9;',\n\t\t'ti-layout-media-right': '&#xe6fa;',\n\t\t'ti-layout-media-overlay': '&#xe6fb;',\n\t\t'ti-layout-media-overlay-alt': '&#xe6fc;',\n\t\t'ti-layout-media-overlay-alt-2': '&#xe6fd;',\n\t\t'ti-layout-media-left-alt': '&#xe6fe;',\n\t\t'ti-layout-media-left': '&#xe6ff;',\n\t\t'ti-layout-media-center-alt': '&#xe700;',\n\t\t'ti-layout-media-center': '&#xe701;',\n\t\t'ti-layout-list-thumb': '&#xe702;',\n\t\t'ti-layout-list-thumb-alt': '&#xe703;',\n\t\t'ti-layout-list-post': '&#xe704;',\n\t\t'ti-layout-list-large-image': '&#xe705;',\n\t\t'ti-layout-line-solid': '&#xe706;',\n\t\t'ti-layout-grid4': '&#xe707;',\n\t\t'ti-layout-grid3': '&#xe708;',\n\t\t'ti-layout-grid2': '&#xe709;',\n\t\t'ti-layout-grid2-thumb': '&#xe70a;',\n\t\t'ti-layout-cta-right': '&#xe70b;',\n\t\t'ti-layout-cta-left': '&#xe70c;',\n\t\t'ti-layout-cta-center': '&#xe70d;',\n\t\t'ti-layout-cta-btn-right': '&#xe70e;',\n\t\t'ti-layout-cta-btn-left': '&#xe70f;',\n\t\t'ti-layout-column4': '&#xe710;',\n\t\t'ti-layout-column3': '&#xe711;',\n\t\t'ti-layout-column2': '&#xe712;',\n\t\t'ti-layout-accordion-separated': '&#xe713;',\n\t\t'ti-layout-accordion-merged': '&#xe714;',\n\t\t'ti-layout-accordion-list': '&#xe715;',\n\t\t'ti-ink-pen': '&#xe716;',\n\t\t'ti-info-alt': '&#xe717;',\n\t\t'ti-help-alt': '&#xe718;',\n\t\t'ti-headphone-alt': '&#xe719;',\n\t\t'ti-hand-point-up': '&#xe71a;',\n\t\t'ti-hand-point-right': '&#xe71b;',\n\t\t'ti-hand-point-left': '&#xe71c;',\n\t\t'ti-hand-point-down': '&#xe71d;',\n\t\t'ti-gallery': '&#xe71e;',\n\t\t'ti-face-smile': '&#xe71f;',\n\t\t'ti-face-sad': '&#xe720;',\n\t\t'ti-credit-card': '&#xe721;',\n\t\t'ti-control-skip-forward': '&#xe722;',\n\t\t'ti-control-skip-backward': '&#xe723;',\n\t\t'ti-control-record': '&#xe724;',\n\t\t'ti-control-eject': '&#xe725;',\n\t\t'ti-comments-smiley': '&#xe726;',\n\t\t'ti-brush-alt': '&#xe727;',\n\t\t'ti-youtube': '&#xe728;',\n\t\t'ti-vimeo': '&#xe729;',\n\t\t'ti-twitter': '&#xe72a;',\n\t\t'ti-time': '&#xe72b;',\n\t\t'ti-tumblr': '&#xe72c;',\n\t\t'ti-skype': '&#xe72d;',\n\t\t'ti-share': '&#xe72e;',\n\t\t'ti-share-alt': '&#xe72f;',\n\t\t'ti-rocket': '&#xe730;',\n\t\t'ti-pinterest': '&#xe731;',\n\t\t'ti-new-window': '&#xe732;',\n\t\t'ti-microsoft': '&#xe733;',\n\t\t'ti-list-ol': '&#xe734;',\n\t\t'ti-linkedin': '&#xe735;',\n\t\t'ti-layout-sidebar-2': '&#xe736;',\n\t\t'ti-layout-grid4-alt': '&#xe737;',\n\t\t'ti-layout-grid3-alt': '&#xe738;',\n\t\t'ti-layout-grid2-alt': '&#xe739;',\n\t\t'ti-layout-column4-alt': '&#xe73a;',\n\t\t'ti-layout-column3-alt': '&#xe73b;',\n\t\t'ti-layout-column2-alt': '&#xe73c;',\n\t\t'ti-instagram': '&#xe73d;',\n\t\t'ti-google': '&#xe73e;',\n\t\t'ti-github': '&#xe73f;',\n\t\t'ti-flickr': '&#xe740;',\n\t\t'ti-facebook': '&#xe741;',\n\t\t'ti-dropbox': '&#xe742;',\n\t\t'ti-dribbble': '&#xe743;',\n\t\t'ti-apple': '&#xe744;',\n\t\t'ti-android': '&#xe745;',\n\t\t'ti-save': '&#xe746;',\n\t\t'ti-save-alt': '&#xe747;',\n\t\t'ti-yahoo': '&#xe748;',\n\t\t'ti-wordpress': '&#xe749;',\n\t\t'ti-vimeo-alt': '&#xe74a;',\n\t\t'ti-twitter-alt': '&#xe74b;',\n\t\t'ti-tumblr-alt': '&#xe74c;',\n\t\t'ti-trello': '&#xe74d;',\n\t\t'ti-stack-overflow': '&#xe74e;',\n\t\t'ti-soundcloud': '&#xe74f;',\n\t\t'ti-sharethis': '&#xe750;',\n\t\t'ti-sharethis-alt': '&#xe751;',\n\t\t'ti-reddit': '&#xe752;',\n\t\t'ti-pinterest-alt': '&#xe753;',\n\t\t'ti-microsoft-alt': '&#xe754;',\n\t\t'ti-linux': '&#xe755;',\n\t\t'ti-jsfiddle': '&#xe756;',\n\t\t'ti-joomla': '&#xe757;',\n\t\t'ti-html5': '&#xe758;',\n\t\t'ti-flickr-alt': '&#xe759;',\n\t\t'ti-email': '&#xe75a;',\n\t\t'ti-drupal': '&#xe75b;',\n\t\t'ti-dropbox-alt': '&#xe75c;',\n\t\t'ti-css3': '&#xe75d;',\n\t\t'ti-rss': '&#xe75e;',\n\t\t'ti-rss-alt': '&#xe75f;',\n\t\t'0': 0\n\t\t},\n\t\tels = document.getElementsByTagName('*'),\n\t\ti, c, el;\n\tfor (i = 0; ; i += 1) {\n\t\tel = els[i];\n\t\tif(!el) {\n\t\t\tbreak;\n\t\t}\n\t\tc = el.className;\n\t\tc = c.match(/ti-[^\\s'\"]+/);\n\t\tif (c && icons[c[0]]) {\n\t\t\taddIcon(el, icons[c[0]]);\n\t\t}\n\t}\n}());\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/themify-icons/themify-icons.css",
    "content": "@font-face {\n\tfont-family: 'themify';\n\tsrc:url('fonts/themify.eot?-fvbane');\n\tsrc:url('fonts/themify.eot?#iefix-fvbane') format('embedded-opentype'),\n\t\turl('fonts/themify.woff') format('woff'),\n\t\turl('fonts/themify.ttf') format('truetype'),\n\t\turl('fonts/themify.svg?-fvbane#themify') format('svg');\n\tfont-weight: normal;\n\tfont-style: normal;\n}\n\n[class^=\"ti-\"], [class*=\" ti-\"] {\n\tfont-family: 'themify';\n\tspeak: none;\n\tfont-style: normal;\n\tfont-weight: normal;\n\tfont-variant: normal;\n\ttext-transform: none;\n\tline-height: 1;\n\n\t/* Better Font Rendering =========== */\n\t-webkit-font-smoothing: antialiased;\n\t-moz-osx-font-smoothing: grayscale;\n}\n\n.ti-wand:before {\n\tcontent: \"\\e600\";\n}\n.ti-volume:before {\n\tcontent: \"\\e601\";\n}\n.ti-user:before {\n\tcontent: \"\\e602\";\n}\n.ti-unlock:before {\n\tcontent: \"\\e603\";\n}\n.ti-unlink:before {\n\tcontent: \"\\e604\";\n}\n.ti-trash:before {\n\tcontent: \"\\e605\";\n}\n.ti-thought:before {\n\tcontent: \"\\e606\";\n}\n.ti-target:before {\n\tcontent: \"\\e607\";\n}\n.ti-tag:before {\n\tcontent: \"\\e608\";\n}\n.ti-tablet:before {\n\tcontent: \"\\e609\";\n}\n.ti-star:before {\n\tcontent: \"\\e60a\";\n}\n.ti-spray:before {\n\tcontent: \"\\e60b\";\n}\n.ti-signal:before {\n\tcontent: \"\\e60c\";\n}\n.ti-shopping-cart:before {\n\tcontent: \"\\e60d\";\n}\n.ti-shopping-cart-full:before {\n\tcontent: \"\\e60e\";\n}\n.ti-settings:before {\n\tcontent: \"\\e60f\";\n}\n.ti-search:before {\n\tcontent: \"\\e610\";\n}\n.ti-zoom-in:before {\n\tcontent: \"\\e611\";\n}\n.ti-zoom-out:before {\n\tcontent: \"\\e612\";\n}\n.ti-cut:before {\n\tcontent: \"\\e613\";\n}\n.ti-ruler:before {\n\tcontent: \"\\e614\";\n}\n.ti-ruler-pencil:before {\n\tcontent: \"\\e615\";\n}\n.ti-ruler-alt:before {\n\tcontent: \"\\e616\";\n}\n.ti-bookmark:before {\n\tcontent: \"\\e617\";\n}\n.ti-bookmark-alt:before {\n\tcontent: \"\\e618\";\n}\n.ti-reload:before {\n\tcontent: \"\\e619\";\n}\n.ti-plus:before {\n\tcontent: \"\\e61a\";\n}\n.ti-pin:before {\n\tcontent: \"\\e61b\";\n}\n.ti-pencil:before {\n\tcontent: \"\\e61c\";\n}\n.ti-pencil-alt:before {\n\tcontent: \"\\e61d\";\n}\n.ti-paint-roller:before {\n\tcontent: \"\\e61e\";\n}\n.ti-paint-bucket:before {\n\tcontent: \"\\e61f\";\n}\n.ti-na:before {\n\tcontent: \"\\e620\";\n}\n.ti-mobile:before {\n\tcontent: \"\\e621\";\n}\n.ti-minus:before {\n\tcontent: \"\\e622\";\n}\n.ti-medall:before {\n\tcontent: \"\\e623\";\n}\n.ti-medall-alt:before {\n\tcontent: \"\\e624\";\n}\n.ti-marker:before {\n\tcontent: \"\\e625\";\n}\n.ti-marker-alt:before {\n\tcontent: \"\\e626\";\n}\n.ti-arrow-up:before {\n\tcontent: \"\\e627\";\n}\n.ti-arrow-right:before {\n\tcontent: \"\\e628\";\n}\n.ti-arrow-left:before {\n\tcontent: \"\\e629\";\n}\n.ti-arrow-down:before {\n\tcontent: \"\\e62a\";\n}\n.ti-lock:before {\n\tcontent: \"\\e62b\";\n}\n.ti-location-arrow:before {\n\tcontent: \"\\e62c\";\n}\n.ti-link:before {\n\tcontent: \"\\e62d\";\n}\n.ti-layout:before {\n\tcontent: \"\\e62e\";\n}\n.ti-layers:before {\n\tcontent: \"\\e62f\";\n}\n.ti-layers-alt:before {\n\tcontent: \"\\e630\";\n}\n.ti-key:before {\n\tcontent: \"\\e631\";\n}\n.ti-import:before {\n\tcontent: \"\\e632\";\n}\n.ti-image:before {\n\tcontent: \"\\e633\";\n}\n.ti-heart:before {\n\tcontent: \"\\e634\";\n}\n.ti-heart-broken:before {\n\tcontent: \"\\e635\";\n}\n.ti-hand-stop:before {\n\tcontent: \"\\e636\";\n}\n.ti-hand-open:before {\n\tcontent: \"\\e637\";\n}\n.ti-hand-drag:before {\n\tcontent: \"\\e638\";\n}\n.ti-folder:before {\n\tcontent: \"\\e639\";\n}\n.ti-flag:before {\n\tcontent: \"\\e63a\";\n}\n.ti-flag-alt:before {\n\tcontent: \"\\e63b\";\n}\n.ti-flag-alt-2:before {\n\tcontent: \"\\e63c\";\n}\n.ti-eye:before {\n\tcontent: \"\\e63d\";\n}\n.ti-export:before {\n\tcontent: \"\\e63e\";\n}\n.ti-exchange-vertical:before {\n\tcontent: \"\\e63f\";\n}\n.ti-desktop:before {\n\tcontent: \"\\e640\";\n}\n.ti-cup:before {\n\tcontent: \"\\e641\";\n}\n.ti-crown:before {\n\tcontent: \"\\e642\";\n}\n.ti-comments:before {\n\tcontent: \"\\e643\";\n}\n.ti-comment:before {\n\tcontent: \"\\e644\";\n}\n.ti-comment-alt:before {\n\tcontent: \"\\e645\";\n}\n.ti-close:before {\n\tcontent: \"\\e646\";\n}\n.ti-clip:before {\n\tcontent: \"\\e647\";\n}\n.ti-angle-up:before {\n\tcontent: \"\\e648\";\n}\n.ti-angle-right:before {\n\tcontent: \"\\e649\";\n}\n.ti-angle-left:before {\n\tcontent: \"\\e64a\";\n}\n.ti-angle-down:before {\n\tcontent: \"\\e64b\";\n}\n.ti-check:before {\n\tcontent: \"\\e64c\";\n}\n.ti-check-box:before {\n\tcontent: \"\\e64d\";\n}\n.ti-camera:before {\n\tcontent: \"\\e64e\";\n}\n.ti-announcement:before {\n\tcontent: \"\\e64f\";\n}\n.ti-brush:before {\n\tcontent: \"\\e650\";\n}\n.ti-briefcase:before {\n\tcontent: \"\\e651\";\n}\n.ti-bolt:before {\n\tcontent: \"\\e652\";\n}\n.ti-bolt-alt:before {\n\tcontent: \"\\e653\";\n}\n.ti-blackboard:before {\n\tcontent: \"\\e654\";\n}\n.ti-bag:before {\n\tcontent: \"\\e655\";\n}\n.ti-move:before {\n\tcontent: \"\\e656\";\n}\n.ti-arrows-vertical:before {\n\tcontent: \"\\e657\";\n}\n.ti-arrows-horizontal:before {\n\tcontent: \"\\e658\";\n}\n.ti-fullscreen:before {\n\tcontent: \"\\e659\";\n}\n.ti-arrow-top-right:before {\n\tcontent: \"\\e65a\";\n}\n.ti-arrow-top-left:before {\n\tcontent: \"\\e65b\";\n}\n.ti-arrow-circle-up:before {\n\tcontent: \"\\e65c\";\n}\n.ti-arrow-circle-right:before {\n\tcontent: \"\\e65d\";\n}\n.ti-arrow-circle-left:before {\n\tcontent: \"\\e65e\";\n}\n.ti-arrow-circle-down:before {\n\tcontent: \"\\e65f\";\n}\n.ti-angle-double-up:before {\n\tcontent: \"\\e660\";\n}\n.ti-angle-double-right:before {\n\tcontent: \"\\e661\";\n}\n.ti-angle-double-left:before {\n\tcontent: \"\\e662\";\n}\n.ti-angle-double-down:before {\n\tcontent: \"\\e663\";\n}\n.ti-zip:before {\n\tcontent: \"\\e664\";\n}\n.ti-world:before {\n\tcontent: \"\\e665\";\n}\n.ti-wheelchair:before {\n\tcontent: \"\\e666\";\n}\n.ti-view-list:before {\n\tcontent: \"\\e667\";\n}\n.ti-view-list-alt:before {\n\tcontent: \"\\e668\";\n}\n.ti-view-grid:before {\n\tcontent: \"\\e669\";\n}\n.ti-uppercase:before {\n\tcontent: \"\\e66a\";\n}\n.ti-upload:before {\n\tcontent: \"\\e66b\";\n}\n.ti-underline:before {\n\tcontent: \"\\e66c\";\n}\n.ti-truck:before {\n\tcontent: \"\\e66d\";\n}\n.ti-timer:before {\n\tcontent: \"\\e66e\";\n}\n.ti-ticket:before {\n\tcontent: \"\\e66f\";\n}\n.ti-thumb-up:before {\n\tcontent: \"\\e670\";\n}\n.ti-thumb-down:before {\n\tcontent: \"\\e671\";\n}\n.ti-text:before {\n\tcontent: \"\\e672\";\n}\n.ti-stats-up:before {\n\tcontent: \"\\e673\";\n}\n.ti-stats-down:before {\n\tcontent: \"\\e674\";\n}\n.ti-split-v:before {\n\tcontent: \"\\e675\";\n}\n.ti-split-h:before {\n\tcontent: \"\\e676\";\n}\n.ti-smallcap:before {\n\tcontent: \"\\e677\";\n}\n.ti-shine:before {\n\tcontent: \"\\e678\";\n}\n.ti-shift-right:before {\n\tcontent: \"\\e679\";\n}\n.ti-shift-left:before {\n\tcontent: \"\\e67a\";\n}\n.ti-shield:before {\n\tcontent: \"\\e67b\";\n}\n.ti-notepad:before {\n\tcontent: \"\\e67c\";\n}\n.ti-server:before {\n\tcontent: \"\\e67d\";\n}\n.ti-quote-right:before {\n\tcontent: \"\\e67e\";\n}\n.ti-quote-left:before {\n\tcontent: \"\\e67f\";\n}\n.ti-pulse:before {\n\tcontent: \"\\e680\";\n}\n.ti-printer:before {\n\tcontent: \"\\e681\";\n}\n.ti-power-off:before {\n\tcontent: \"\\e682\";\n}\n.ti-plug:before {\n\tcontent: \"\\e683\";\n}\n.ti-pie-chart:before {\n\tcontent: \"\\e684\";\n}\n.ti-paragraph:before {\n\tcontent: \"\\e685\";\n}\n.ti-panel:before {\n\tcontent: \"\\e686\";\n}\n.ti-package:before {\n\tcontent: \"\\e687\";\n}\n.ti-music:before {\n\tcontent: \"\\e688\";\n}\n.ti-music-alt:before {\n\tcontent: \"\\e689\";\n}\n.ti-mouse:before {\n\tcontent: \"\\e68a\";\n}\n.ti-mouse-alt:before {\n\tcontent: \"\\e68b\";\n}\n.ti-money:before {\n\tcontent: \"\\e68c\";\n}\n.ti-microphone:before {\n\tcontent: \"\\e68d\";\n}\n.ti-menu:before {\n\tcontent: \"\\e68e\";\n}\n.ti-menu-alt:before {\n\tcontent: \"\\e68f\";\n}\n.ti-map:before {\n\tcontent: \"\\e690\";\n}\n.ti-map-alt:before {\n\tcontent: \"\\e691\";\n}\n.ti-loop:before {\n\tcontent: \"\\e692\";\n}\n.ti-location-pin:before {\n\tcontent: \"\\e693\";\n}\n.ti-list:before {\n\tcontent: \"\\e694\";\n}\n.ti-light-bulb:before {\n\tcontent: \"\\e695\";\n}\n.ti-Italic:before {\n\tcontent: \"\\e696\";\n}\n.ti-info:before {\n\tcontent: \"\\e697\";\n}\n.ti-infinite:before {\n\tcontent: \"\\e698\";\n}\n.ti-id-badge:before {\n\tcontent: \"\\e699\";\n}\n.ti-hummer:before {\n\tcontent: \"\\e69a\";\n}\n.ti-home:before {\n\tcontent: \"\\e69b\";\n}\n.ti-help:before {\n\tcontent: \"\\e69c\";\n}\n.ti-headphone:before {\n\tcontent: \"\\e69d\";\n}\n.ti-harddrives:before {\n\tcontent: \"\\e69e\";\n}\n.ti-harddrive:before {\n\tcontent: \"\\e69f\";\n}\n.ti-gift:before {\n\tcontent: \"\\e6a0\";\n}\n.ti-game:before {\n\tcontent: \"\\e6a1\";\n}\n.ti-filter:before {\n\tcontent: \"\\e6a2\";\n}\n.ti-files:before {\n\tcontent: \"\\e6a3\";\n}\n.ti-file:before {\n\tcontent: \"\\e6a4\";\n}\n.ti-eraser:before {\n\tcontent: \"\\e6a5\";\n}\n.ti-envelope:before {\n\tcontent: \"\\e6a6\";\n}\n.ti-download:before {\n\tcontent: \"\\e6a7\";\n}\n.ti-direction:before {\n\tcontent: \"\\e6a8\";\n}\n.ti-direction-alt:before {\n\tcontent: \"\\e6a9\";\n}\n.ti-dashboard:before {\n\tcontent: \"\\e6aa\";\n}\n.ti-control-stop:before {\n\tcontent: \"\\e6ab\";\n}\n.ti-control-shuffle:before {\n\tcontent: \"\\e6ac\";\n}\n.ti-control-play:before {\n\tcontent: \"\\e6ad\";\n}\n.ti-control-pause:before {\n\tcontent: \"\\e6ae\";\n}\n.ti-control-forward:before {\n\tcontent: \"\\e6af\";\n}\n.ti-control-backward:before {\n\tcontent: \"\\e6b0\";\n}\n.ti-cloud:before {\n\tcontent: \"\\e6b1\";\n}\n.ti-cloud-up:before {\n\tcontent: \"\\e6b2\";\n}\n.ti-cloud-down:before {\n\tcontent: \"\\e6b3\";\n}\n.ti-clipboard:before {\n\tcontent: \"\\e6b4\";\n}\n.ti-car:before {\n\tcontent: \"\\e6b5\";\n}\n.ti-calendar:before {\n\tcontent: \"\\e6b6\";\n}\n.ti-book:before {\n\tcontent: \"\\e6b7\";\n}\n.ti-bell:before {\n\tcontent: \"\\e6b8\";\n}\n.ti-basketball:before {\n\tcontent: \"\\e6b9\";\n}\n.ti-bar-chart:before {\n\tcontent: \"\\e6ba\";\n}\n.ti-bar-chart-alt:before {\n\tcontent: \"\\e6bb\";\n}\n.ti-back-right:before {\n\tcontent: \"\\e6bc\";\n}\n.ti-back-left:before {\n\tcontent: \"\\e6bd\";\n}\n.ti-arrows-corner:before {\n\tcontent: \"\\e6be\";\n}\n.ti-archive:before {\n\tcontent: \"\\e6bf\";\n}\n.ti-anchor:before {\n\tcontent: \"\\e6c0\";\n}\n.ti-align-right:before {\n\tcontent: \"\\e6c1\";\n}\n.ti-align-left:before {\n\tcontent: \"\\e6c2\";\n}\n.ti-align-justify:before {\n\tcontent: \"\\e6c3\";\n}\n.ti-align-center:before {\n\tcontent: \"\\e6c4\";\n}\n.ti-alert:before {\n\tcontent: \"\\e6c5\";\n}\n.ti-alarm-clock:before {\n\tcontent: \"\\e6c6\";\n}\n.ti-agenda:before {\n\tcontent: \"\\e6c7\";\n}\n.ti-write:before {\n\tcontent: \"\\e6c8\";\n}\n.ti-window:before {\n\tcontent: \"\\e6c9\";\n}\n.ti-widgetized:before {\n\tcontent: \"\\e6ca\";\n}\n.ti-widget:before {\n\tcontent: \"\\e6cb\";\n}\n.ti-widget-alt:before {\n\tcontent: \"\\e6cc\";\n}\n.ti-wallet:before {\n\tcontent: \"\\e6cd\";\n}\n.ti-video-clapper:before {\n\tcontent: \"\\e6ce\";\n}\n.ti-video-camera:before {\n\tcontent: \"\\e6cf\";\n}\n.ti-vector:before {\n\tcontent: \"\\e6d0\";\n}\n.ti-themify-logo:before {\n\tcontent: \"\\e6d1\";\n}\n.ti-themify-favicon:before {\n\tcontent: \"\\e6d2\";\n}\n.ti-themify-favicon-alt:before {\n\tcontent: \"\\e6d3\";\n}\n.ti-support:before {\n\tcontent: \"\\e6d4\";\n}\n.ti-stamp:before {\n\tcontent: \"\\e6d5\";\n}\n.ti-split-v-alt:before {\n\tcontent: \"\\e6d6\";\n}\n.ti-slice:before {\n\tcontent: \"\\e6d7\";\n}\n.ti-shortcode:before {\n\tcontent: \"\\e6d8\";\n}\n.ti-shift-right-alt:before {\n\tcontent: \"\\e6d9\";\n}\n.ti-shift-left-alt:before {\n\tcontent: \"\\e6da\";\n}\n.ti-ruler-alt-2:before {\n\tcontent: \"\\e6db\";\n}\n.ti-receipt:before {\n\tcontent: \"\\e6dc\";\n}\n.ti-pin2:before {\n\tcontent: \"\\e6dd\";\n}\n.ti-pin-alt:before {\n\tcontent: \"\\e6de\";\n}\n.ti-pencil-alt2:before {\n\tcontent: \"\\e6df\";\n}\n.ti-palette:before {\n\tcontent: \"\\e6e0\";\n}\n.ti-more:before {\n\tcontent: \"\\e6e1\";\n}\n.ti-more-alt:before {\n\tcontent: \"\\e6e2\";\n}\n.ti-microphone-alt:before {\n\tcontent: \"\\e6e3\";\n}\n.ti-magnet:before {\n\tcontent: \"\\e6e4\";\n}\n.ti-line-double:before {\n\tcontent: \"\\e6e5\";\n}\n.ti-line-dotted:before {\n\tcontent: \"\\e6e6\";\n}\n.ti-line-dashed:before {\n\tcontent: \"\\e6e7\";\n}\n.ti-layout-width-full:before {\n\tcontent: \"\\e6e8\";\n}\n.ti-layout-width-default:before {\n\tcontent: \"\\e6e9\";\n}\n.ti-layout-width-default-alt:before {\n\tcontent: \"\\e6ea\";\n}\n.ti-layout-tab:before {\n\tcontent: \"\\e6eb\";\n}\n.ti-layout-tab-window:before {\n\tcontent: \"\\e6ec\";\n}\n.ti-layout-tab-v:before {\n\tcontent: \"\\e6ed\";\n}\n.ti-layout-tab-min:before {\n\tcontent: \"\\e6ee\";\n}\n.ti-layout-slider:before {\n\tcontent: \"\\e6ef\";\n}\n.ti-layout-slider-alt:before {\n\tcontent: \"\\e6f0\";\n}\n.ti-layout-sidebar-right:before {\n\tcontent: \"\\e6f1\";\n}\n.ti-layout-sidebar-none:before {\n\tcontent: \"\\e6f2\";\n}\n.ti-layout-sidebar-left:before {\n\tcontent: \"\\e6f3\";\n}\n.ti-layout-placeholder:before {\n\tcontent: \"\\e6f4\";\n}\n.ti-layout-menu:before {\n\tcontent: \"\\e6f5\";\n}\n.ti-layout-menu-v:before {\n\tcontent: \"\\e6f6\";\n}\n.ti-layout-menu-separated:before {\n\tcontent: \"\\e6f7\";\n}\n.ti-layout-menu-full:before {\n\tcontent: \"\\e6f8\";\n}\n.ti-layout-media-right-alt:before {\n\tcontent: \"\\e6f9\";\n}\n.ti-layout-media-right:before {\n\tcontent: \"\\e6fa\";\n}\n.ti-layout-media-overlay:before {\n\tcontent: \"\\e6fb\";\n}\n.ti-layout-media-overlay-alt:before {\n\tcontent: \"\\e6fc\";\n}\n.ti-layout-media-overlay-alt-2:before {\n\tcontent: \"\\e6fd\";\n}\n.ti-layout-media-left-alt:before {\n\tcontent: \"\\e6fe\";\n}\n.ti-layout-media-left:before {\n\tcontent: \"\\e6ff\";\n}\n.ti-layout-media-center-alt:before {\n\tcontent: \"\\e700\";\n}\n.ti-layout-media-center:before {\n\tcontent: \"\\e701\";\n}\n.ti-layout-list-thumb:before {\n\tcontent: \"\\e702\";\n}\n.ti-layout-list-thumb-alt:before {\n\tcontent: \"\\e703\";\n}\n.ti-layout-list-post:before {\n\tcontent: \"\\e704\";\n}\n.ti-layout-list-large-image:before {\n\tcontent: \"\\e705\";\n}\n.ti-layout-line-solid:before {\n\tcontent: \"\\e706\";\n}\n.ti-layout-grid4:before {\n\tcontent: \"\\e707\";\n}\n.ti-layout-grid3:before {\n\tcontent: \"\\e708\";\n}\n.ti-layout-grid2:before {\n\tcontent: \"\\e709\";\n}\n.ti-layout-grid2-thumb:before {\n\tcontent: \"\\e70a\";\n}\n.ti-layout-cta-right:before {\n\tcontent: \"\\e70b\";\n}\n.ti-layout-cta-left:before {\n\tcontent: \"\\e70c\";\n}\n.ti-layout-cta-center:before {\n\tcontent: \"\\e70d\";\n}\n.ti-layout-cta-btn-right:before {\n\tcontent: \"\\e70e\";\n}\n.ti-layout-cta-btn-left:before {\n\tcontent: \"\\e70f\";\n}\n.ti-layout-column4:before {\n\tcontent: \"\\e710\";\n}\n.ti-layout-column3:before {\n\tcontent: \"\\e711\";\n}\n.ti-layout-column2:before {\n\tcontent: \"\\e712\";\n}\n.ti-layout-accordion-separated:before {\n\tcontent: \"\\e713\";\n}\n.ti-layout-accordion-merged:before {\n\tcontent: \"\\e714\";\n}\n.ti-layout-accordion-list:before {\n\tcontent: \"\\e715\";\n}\n.ti-ink-pen:before {\n\tcontent: \"\\e716\";\n}\n.ti-info-alt:before {\n\tcontent: \"\\e717\";\n}\n.ti-help-alt:before {\n\tcontent: \"\\e718\";\n}\n.ti-headphone-alt:before {\n\tcontent: \"\\e719\";\n}\n.ti-hand-point-up:before {\n\tcontent: \"\\e71a\";\n}\n.ti-hand-point-right:before {\n\tcontent: \"\\e71b\";\n}\n.ti-hand-point-left:before {\n\tcontent: \"\\e71c\";\n}\n.ti-hand-point-down:before {\n\tcontent: \"\\e71d\";\n}\n.ti-gallery:before {\n\tcontent: \"\\e71e\";\n}\n.ti-face-smile:before {\n\tcontent: \"\\e71f\";\n}\n.ti-face-sad:before {\n\tcontent: \"\\e720\";\n}\n.ti-credit-card:before {\n\tcontent: \"\\e721\";\n}\n.ti-control-skip-forward:before {\n\tcontent: \"\\e722\";\n}\n.ti-control-skip-backward:before {\n\tcontent: \"\\e723\";\n}\n.ti-control-record:before {\n\tcontent: \"\\e724\";\n}\n.ti-control-eject:before {\n\tcontent: \"\\e725\";\n}\n.ti-comments-smiley:before {\n\tcontent: \"\\e726\";\n}\n.ti-brush-alt:before {\n\tcontent: \"\\e727\";\n}\n.ti-youtube:before {\n\tcontent: \"\\e728\";\n}\n.ti-vimeo:before {\n\tcontent: \"\\e729\";\n}\n.ti-twitter:before {\n\tcontent: \"\\e72a\";\n}\n.ti-time:before {\n\tcontent: \"\\e72b\";\n}\n.ti-tumblr:before {\n\tcontent: \"\\e72c\";\n}\n.ti-skype:before {\n\tcontent: \"\\e72d\";\n}\n.ti-share:before {\n\tcontent: \"\\e72e\";\n}\n.ti-share-alt:before {\n\tcontent: \"\\e72f\";\n}\n.ti-rocket:before {\n\tcontent: \"\\e730\";\n}\n.ti-pinterest:before {\n\tcontent: \"\\e731\";\n}\n.ti-new-window:before {\n\tcontent: \"\\e732\";\n}\n.ti-microsoft:before {\n\tcontent: \"\\e733\";\n}\n.ti-list-ol:before {\n\tcontent: \"\\e734\";\n}\n.ti-linkedin:before {\n\tcontent: \"\\e735\";\n}\n.ti-layout-sidebar-2:before {\n\tcontent: \"\\e736\";\n}\n.ti-layout-grid4-alt:before {\n\tcontent: \"\\e737\";\n}\n.ti-layout-grid3-alt:before {\n\tcontent: \"\\e738\";\n}\n.ti-layout-grid2-alt:before {\n\tcontent: \"\\e739\";\n}\n.ti-layout-column4-alt:before {\n\tcontent: \"\\e73a\";\n}\n.ti-layout-column3-alt:before {\n\tcontent: \"\\e73b\";\n}\n.ti-layout-column2-alt:before {\n\tcontent: \"\\e73c\";\n}\n.ti-instagram:before {\n\tcontent: \"\\e73d\";\n}\n.ti-google:before {\n\tcontent: \"\\e73e\";\n}\n.ti-github:before {\n\tcontent: \"\\e73f\";\n}\n.ti-flickr:before {\n\tcontent: \"\\e740\";\n}\n.ti-facebook:before {\n\tcontent: \"\\e741\";\n}\n.ti-dropbox:before {\n\tcontent: \"\\e742\";\n}\n.ti-dribbble:before {\n\tcontent: \"\\e743\";\n}\n.ti-apple:before {\n\tcontent: \"\\e744\";\n}\n.ti-android:before {\n\tcontent: \"\\e745\";\n}\n.ti-save:before {\n\tcontent: \"\\e746\";\n}\n.ti-save-alt:before {\n\tcontent: \"\\e747\";\n}\n.ti-yahoo:before {\n\tcontent: \"\\e748\";\n}\n.ti-wordpress:before {\n\tcontent: \"\\e749\";\n}\n.ti-vimeo-alt:before {\n\tcontent: \"\\e74a\";\n}\n.ti-twitter-alt:before {\n\tcontent: \"\\e74b\";\n}\n.ti-tumblr-alt:before {\n\tcontent: \"\\e74c\";\n}\n.ti-trello:before {\n\tcontent: \"\\e74d\";\n}\n.ti-stack-overflow:before {\n\tcontent: \"\\e74e\";\n}\n.ti-soundcloud:before {\n\tcontent: \"\\e74f\";\n}\n.ti-sharethis:before {\n\tcontent: \"\\e750\";\n}\n.ti-sharethis-alt:before {\n\tcontent: \"\\e751\";\n}\n.ti-reddit:before {\n\tcontent: \"\\e752\";\n}\n.ti-pinterest-alt:before {\n\tcontent: \"\\e753\";\n}\n.ti-microsoft-alt:before {\n\tcontent: \"\\e754\";\n}\n.ti-linux:before {\n\tcontent: \"\\e755\";\n}\n.ti-jsfiddle:before {\n\tcontent: \"\\e756\";\n}\n.ti-joomla:before {\n\tcontent: \"\\e757\";\n}\n.ti-html5:before {\n\tcontent: \"\\e758\";\n}\n.ti-flickr-alt:before {\n\tcontent: \"\\e759\";\n}\n.ti-email:before {\n\tcontent: \"\\e75a\";\n}\n.ti-drupal:before {\n\tcontent: \"\\e75b\";\n}\n.ti-dropbox-alt:before {\n\tcontent: \"\\e75c\";\n}\n.ti-css3:before {\n\tcontent: \"\\e75d\";\n}\n.ti-rss:before {\n\tcontent: \"\\e75e\";\n}\n.ti-rss-alt:before {\n\tcontent: \"\\e75f\";\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/themify-icons/themify-icons.less",
    "content": "@font-face {\n  font-family: 'themify';\n  src:url('../scss/icons/themify-icons/fonts/themify.eot?-fvbane');\n  src:url('../scss/icons/themify-icons/fonts/themify.eot?#iefix-fvbane') format('embedded-opentype'),\n    url('../scss/icons/themify-icons/fonts/themify.woff?-fvbane') format('woff'),\n    url('../scss/icons/themify-icons/fonts/themify.ttf?-fvbane') format('truetype'),\n    url('../scss/icons/themify-icons/fonts/themify.svg?-fvbane#themify') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n\n[class^=\"ti-\"], [class*=\" ti-\"] {\n  font-family: 'themify';\n  speak: none;\n  font-style: normal;\n  font-weight: normal;\n  font-variant: normal;\n  text-transform: none;\n  line-height: 1;\n\n  /* Better Font Rendering =========== */\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.ti-wand:before {\n  content: \"\\e600\";\n}\n.ti-volume:before {\n  content: \"\\e601\";\n}\n.ti-user:before {\n  content: \"\\e602\";\n}\n.ti-unlock:before {\n  content: \"\\e603\";\n}\n.ti-unlink:before {\n  content: \"\\e604\";\n}\n.ti-trash:before {\n  content: \"\\e605\";\n}\n.ti-thought:before {\n  content: \"\\e606\";\n}\n.ti-target:before {\n  content: \"\\e607\";\n}\n.ti-tag:before {\n  content: \"\\e608\";\n}\n.ti-tablet:before {\n  content: \"\\e609\";\n}\n.ti-star:before {\n  content: \"\\e60a\";\n}\n.ti-spray:before {\n  content: \"\\e60b\";\n}\n.ti-signal:before {\n  content: \"\\e60c\";\n}\n.ti-shopping-cart:before {\n  content: \"\\e60d\";\n}\n.ti-shopping-cart-full:before {\n  content: \"\\e60e\";\n}\n.ti-settings:before {\n  content: \"\\e60f\";\n}\n.ti-search:before {\n  content: \"\\e610\";\n}\n.ti-zoom-in:before {\n  content: \"\\e611\";\n}\n.ti-zoom-out:before {\n  content: \"\\e612\";\n}\n.ti-cut:before {\n  content: \"\\e613\";\n}\n.ti-ruler:before {\n  content: \"\\e614\";\n}\n.ti-ruler-pencil:before {\n  content: \"\\e615\";\n}\n.ti-ruler-alt:before {\n  content: \"\\e616\";\n}\n.ti-bookmark:before {\n  content: \"\\e617\";\n}\n.ti-bookmark-alt:before {\n  content: \"\\e618\";\n}\n.ti-reload:before {\n  content: \"\\e619\";\n}\n.ti-plus:before {\n  content: \"\\e61a\";\n}\n.ti-pin:before {\n  content: \"\\e61b\";\n}\n.ti-pencil:before {\n  content: \"\\e61c\";\n}\n.ti-pencil-alt:before {\n  content: \"\\e61d\";\n}\n.ti-paint-roller:before {\n  content: \"\\e61e\";\n}\n.ti-paint-bucket:before {\n  content: \"\\e61f\";\n}\n.ti-na:before {\n  content: \"\\e620\";\n}\n.ti-mobile:before {\n  content: \"\\e621\";\n}\n.ti-minus:before {\n  content: \"\\e622\";\n}\n.ti-medall:before {\n  content: \"\\e623\";\n}\n.ti-medall-alt:before {\n  content: \"\\e624\";\n}\n.ti-marker:before {\n  content: \"\\e625\";\n}\n.ti-marker-alt:before {\n  content: \"\\e626\";\n}\n.ti-arrow-up:before {\n  content: \"\\e627\";\n}\n.ti-arrow-right:before {\n  content: \"\\e628\";\n}\n.ti-arrow-left:before {\n  content: \"\\e629\";\n}\n.ti-arrow-down:before {\n  content: \"\\e62a\";\n}\n.ti-lock:before {\n  content: \"\\e62b\";\n}\n.ti-location-arrow:before {\n  content: \"\\e62c\";\n}\n.ti-link:before {\n  content: \"\\e62d\";\n}\n.ti-layout:before {\n  content: \"\\e62e\";\n}\n.ti-layers:before {\n  content: \"\\e62f\";\n}\n.ti-layers-alt:before {\n  content: \"\\e630\";\n}\n.ti-key:before {\n  content: \"\\e631\";\n}\n.ti-import:before {\n  content: \"\\e632\";\n}\n.ti-image:before {\n  content: \"\\e633\";\n}\n.ti-heart:before {\n  content: \"\\e634\";\n}\n.ti-heart-broken:before {\n  content: \"\\e635\";\n}\n.ti-hand-stop:before {\n  content: \"\\e636\";\n}\n.ti-hand-open:before {\n  content: \"\\e637\";\n}\n.ti-hand-drag:before {\n  content: \"\\e638\";\n}\n.ti-folder:before {\n  content: \"\\e639\";\n}\n.ti-flag:before {\n  content: \"\\e63a\";\n}\n.ti-flag-alt:before {\n  content: \"\\e63b\";\n}\n.ti-flag-alt-2:before {\n  content: \"\\e63c\";\n}\n.ti-eye:before {\n  content: \"\\e63d\";\n}\n.ti-export:before {\n  content: \"\\e63e\";\n}\n.ti-exchange-vertical:before {\n  content: \"\\e63f\";\n}\n.ti-desktop:before {\n  content: \"\\e640\";\n}\n.ti-cup:before {\n  content: \"\\e641\";\n}\n.ti-crown:before {\n  content: \"\\e642\";\n}\n.ti-comments:before {\n  content: \"\\e643\";\n}\n.ti-comment:before {\n  content: \"\\e644\";\n}\n.ti-comment-alt:before {\n  content: \"\\e645\";\n}\n.ti-close:before {\n  content: \"\\e646\";\n}\n.ti-clip:before {\n  content: \"\\e647\";\n}\n.ti-angle-up:before {\n  content: \"\\e648\";\n}\n.ti-angle-right:before {\n  content: \"\\e649\";\n}\n.ti-angle-left:before {\n  content: \"\\e64a\";\n}\n.ti-angle-down:before {\n  content: \"\\e64b\";\n}\n.ti-check:before {\n  content: \"\\e64c\";\n}\n.ti-check-box:before {\n  content: \"\\e64d\";\n}\n.ti-camera:before {\n  content: \"\\e64e\";\n}\n.ti-announcement:before {\n  content: \"\\e64f\";\n}\n.ti-brush:before {\n  content: \"\\e650\";\n}\n.ti-briefcase:before {\n  content: \"\\e651\";\n}\n.ti-bolt:before {\n  content: \"\\e652\";\n}\n.ti-bolt-alt:before {\n  content: \"\\e653\";\n}\n.ti-blackboard:before {\n  content: \"\\e654\";\n}\n.ti-bag:before {\n  content: \"\\e655\";\n}\n.ti-move:before {\n  content: \"\\e656\";\n}\n.ti-arrows-vertical:before {\n  content: \"\\e657\";\n}\n.ti-arrows-horizontal:before {\n  content: \"\\e658\";\n}\n.ti-fullscreen:before {\n  content: \"\\e659\";\n}\n.ti-arrow-top-right:before {\n  content: \"\\e65a\";\n}\n.ti-arrow-top-left:before {\n  content: \"\\e65b\";\n}\n.ti-arrow-circle-up:before {\n  content: \"\\e65c\";\n}\n.ti-arrow-circle-right:before {\n  content: \"\\e65d\";\n}\n.ti-arrow-circle-left:before {\n  content: \"\\e65e\";\n}\n.ti-arrow-circle-down:before {\n  content: \"\\e65f\";\n}\n.ti-angle-double-up:before {\n  content: \"\\e660\";\n}\n.ti-angle-double-right:before {\n  content: \"\\e661\";\n}\n.ti-angle-double-left:before {\n  content: \"\\e662\";\n}\n.ti-angle-double-down:before {\n  content: \"\\e663\";\n}\n.ti-zip:before {\n  content: \"\\e664\";\n}\n.ti-world:before {\n  content: \"\\e665\";\n}\n.ti-wheelchair:before {\n  content: \"\\e666\";\n}\n.ti-view-list:before {\n  content: \"\\e667\";\n}\n.ti-view-list-alt:before {\n  content: \"\\e668\";\n}\n.ti-view-grid:before {\n  content: \"\\e669\";\n}\n.ti-uppercase:before {\n  content: \"\\e66a\";\n}\n.ti-upload:before {\n  content: \"\\e66b\";\n}\n.ti-underline:before {\n  content: \"\\e66c\";\n}\n.ti-truck:before {\n  content: \"\\e66d\";\n}\n.ti-timer:before {\n  content: \"\\e66e\";\n}\n.ti-ticket:before {\n  content: \"\\e66f\";\n}\n.ti-thumb-up:before {\n  content: \"\\e670\";\n}\n.ti-thumb-down:before {\n  content: \"\\e671\";\n}\n.ti-text:before {\n  content: \"\\e672\";\n}\n.ti-stats-up:before {\n  content: \"\\e673\";\n}\n.ti-stats-down:before {\n  content: \"\\e674\";\n}\n.ti-split-v:before {\n  content: \"\\e675\";\n}\n.ti-split-h:before {\n  content: \"\\e676\";\n}\n.ti-smallcap:before {\n  content: \"\\e677\";\n}\n.ti-shine:before {\n  content: \"\\e678\";\n}\n.ti-shift-right:before {\n  content: \"\\e679\";\n}\n.ti-shift-left:before {\n  content: \"\\e67a\";\n}\n.ti-shield:before {\n  content: \"\\e67b\";\n}\n.ti-notepad:before {\n  content: \"\\e67c\";\n}\n.ti-server:before {\n  content: \"\\e67d\";\n}\n.ti-quote-right:before {\n  content: \"\\e67e\";\n}\n.ti-quote-left:before {\n  content: \"\\e67f\";\n}\n.ti-pulse:before {\n  content: \"\\e680\";\n}\n.ti-printer:before {\n  content: \"\\e681\";\n}\n.ti-power-off:before {\n  content: \"\\e682\";\n}\n.ti-plug:before {\n  content: \"\\e683\";\n}\n.ti-pie-chart:before {\n  content: \"\\e684\";\n}\n.ti-paragraph:before {\n  content: \"\\e685\";\n}\n.ti-panel:before {\n  content: \"\\e686\";\n}\n.ti-package:before {\n  content: \"\\e687\";\n}\n.ti-music:before {\n  content: \"\\e688\";\n}\n.ti-music-alt:before {\n  content: \"\\e689\";\n}\n.ti-mouse:before {\n  content: \"\\e68a\";\n}\n.ti-mouse-alt:before {\n  content: \"\\e68b\";\n}\n.ti-money:before {\n  content: \"\\e68c\";\n}\n.ti-microphone:before {\n  content: \"\\e68d\";\n}\n.ti-menu:before {\n  content: \"\\e68e\";\n}\n.ti-menu-alt:before {\n  content: \"\\e68f\";\n}\n.ti-map:before {\n  content: \"\\e690\";\n}\n.ti-map-alt:before {\n  content: \"\\e691\";\n}\n.ti-loop:before {\n  content: \"\\e692\";\n}\n.ti-location-pin:before {\n  content: \"\\e693\";\n}\n.ti-list:before {\n  content: \"\\e694\";\n}\n.ti-light-bulb:before {\n  content: \"\\e695\";\n}\n.ti-Italic:before {\n  content: \"\\e696\";\n}\n.ti-info:before {\n  content: \"\\e697\";\n}\n.ti-infinite:before {\n  content: \"\\e698\";\n}\n.ti-id-badge:before {\n  content: \"\\e699\";\n}\n.ti-hummer:before {\n  content: \"\\e69a\";\n}\n.ti-home:before {\n  content: \"\\e69b\";\n}\n.ti-help:before {\n  content: \"\\e69c\";\n}\n.ti-headphone:before {\n  content: \"\\e69d\";\n}\n.ti-harddrives:before {\n  content: \"\\e69e\";\n}\n.ti-harddrive:before {\n  content: \"\\e69f\";\n}\n.ti-gift:before {\n  content: \"\\e6a0\";\n}\n.ti-game:before {\n  content: \"\\e6a1\";\n}\n.ti-filter:before {\n  content: \"\\e6a2\";\n}\n.ti-files:before {\n  content: \"\\e6a3\";\n}\n.ti-file:before {\n  content: \"\\e6a4\";\n}\n.ti-eraser:before {\n  content: \"\\e6a5\";\n}\n.ti-envelope:before {\n  content: \"\\e6a6\";\n}\n.ti-download:before {\n  content: \"\\e6a7\";\n}\n.ti-direction:before {\n  content: \"\\e6a8\";\n}\n.ti-direction-alt:before {\n  content: \"\\e6a9\";\n}\n.ti-dashboard:before {\n  content: \"\\e6aa\";\n}\n.ti-control-stop:before {\n  content: \"\\e6ab\";\n}\n.ti-control-shuffle:before {\n  content: \"\\e6ac\";\n}\n.ti-control-play:before {\n  content: \"\\e6ad\";\n}\n.ti-control-pause:before {\n  content: \"\\e6ae\";\n}\n.ti-control-forward:before {\n  content: \"\\e6af\";\n}\n.ti-control-backward:before {\n  content: \"\\e6b0\";\n}\n.ti-cloud:before {\n  content: \"\\e6b1\";\n}\n.ti-cloud-up:before {\n  content: \"\\e6b2\";\n}\n.ti-cloud-down:before {\n  content: \"\\e6b3\";\n}\n.ti-clipboard:before {\n  content: \"\\e6b4\";\n}\n.ti-car:before {\n  content: \"\\e6b5\";\n}\n.ti-calendar:before {\n  content: \"\\e6b6\";\n}\n.ti-book:before {\n  content: \"\\e6b7\";\n}\n.ti-bell:before {\n  content: \"\\e6b8\";\n}\n.ti-basketball:before {\n  content: \"\\e6b9\";\n}\n.ti-bar-chart:before {\n  content: \"\\e6ba\";\n}\n.ti-bar-chart-alt:before {\n  content: \"\\e6bb\";\n}\n.ti-back-right:before {\n  content: \"\\e6bc\";\n}\n.ti-back-left:before {\n  content: \"\\e6bd\";\n}\n.ti-arrows-corner:before {\n  content: \"\\e6be\";\n}\n.ti-archive:before {\n  content: \"\\e6bf\";\n}\n.ti-anchor:before {\n  content: \"\\e6c0\";\n}\n.ti-align-right:before {\n  content: \"\\e6c1\";\n}\n.ti-align-left:before {\n  content: \"\\e6c2\";\n}\n.ti-align-justify:before {\n  content: \"\\e6c3\";\n}\n.ti-align-center:before {\n  content: \"\\e6c4\";\n}\n.ti-alert:before {\n  content: \"\\e6c5\";\n}\n.ti-alarm-clock:before {\n  content: \"\\e6c6\";\n}\n.ti-agenda:before {\n  content: \"\\e6c7\";\n}\n.ti-write:before {\n  content: \"\\e6c8\";\n}\n.ti-window:before {\n  content: \"\\e6c9\";\n}\n.ti-widgetized:before {\n  content: \"\\e6ca\";\n}\n.ti-widget:before {\n  content: \"\\e6cb\";\n}\n.ti-widget-alt:before {\n  content: \"\\e6cc\";\n}\n.ti-wallet:before {\n  content: \"\\e6cd\";\n}\n.ti-video-clapper:before {\n  content: \"\\e6ce\";\n}\n.ti-video-camera:before {\n  content: \"\\e6cf\";\n}\n.ti-vector:before {\n  content: \"\\e6d0\";\n}\n.ti-themify-logo:before {\n  content: \"\\e6d1\";\n}\n.ti-themify-favicon:before {\n  content: \"\\e6d2\";\n}\n.ti-themify-favicon-alt:before {\n  content: \"\\e6d3\";\n}\n.ti-support:before {\n  content: \"\\e6d4\";\n}\n.ti-stamp:before {\n  content: \"\\e6d5\";\n}\n.ti-split-v-alt:before {\n  content: \"\\e6d6\";\n}\n.ti-slice:before {\n  content: \"\\e6d7\";\n}\n.ti-shortcode:before {\n  content: \"\\e6d8\";\n}\n.ti-shift-right-alt:before {\n  content: \"\\e6d9\";\n}\n.ti-shift-left-alt:before {\n  content: \"\\e6da\";\n}\n.ti-ruler-alt-2:before {\n  content: \"\\e6db\";\n}\n.ti-receipt:before {\n  content: \"\\e6dc\";\n}\n.ti-pin2:before {\n  content: \"\\e6dd\";\n}\n.ti-pin-alt:before {\n  content: \"\\e6de\";\n}\n.ti-pencil-alt2:before {\n  content: \"\\e6df\";\n}\n.ti-palette:before {\n  content: \"\\e6e0\";\n}\n.ti-more:before {\n  content: \"\\e6e1\";\n}\n.ti-more-alt:before {\n  content: \"\\e6e2\";\n}\n.ti-microphone-alt:before {\n  content: \"\\e6e3\";\n}\n.ti-magnet:before {\n  content: \"\\e6e4\";\n}\n.ti-line-double:before {\n  content: \"\\e6e5\";\n}\n.ti-line-dotted:before {\n  content: \"\\e6e6\";\n}\n.ti-line-dashed:before {\n  content: \"\\e6e7\";\n}\n.ti-layout-width-full:before {\n  content: \"\\e6e8\";\n}\n.ti-layout-width-default:before {\n  content: \"\\e6e9\";\n}\n.ti-layout-width-default-alt:before {\n  content: \"\\e6ea\";\n}\n.ti-layout-tab:before {\n  content: \"\\e6eb\";\n}\n.ti-layout-tab-window:before {\n  content: \"\\e6ec\";\n}\n.ti-layout-tab-v:before {\n  content: \"\\e6ed\";\n}\n.ti-layout-tab-min:before {\n  content: \"\\e6ee\";\n}\n.ti-layout-slider:before {\n  content: \"\\e6ef\";\n}\n.ti-layout-slider-alt:before {\n  content: \"\\e6f0\";\n}\n.ti-layout-sidebar-right:before {\n  content: \"\\e6f1\";\n}\n.ti-layout-sidebar-none:before {\n  content: \"\\e6f2\";\n}\n.ti-layout-sidebar-left:before {\n  content: \"\\e6f3\";\n}\n.ti-layout-placeholder:before {\n  content: \"\\e6f4\";\n}\n.ti-layout-menu:before {\n  content: \"\\e6f5\";\n}\n.ti-layout-menu-v:before {\n  content: \"\\e6f6\";\n}\n.ti-layout-menu-separated:before {\n  content: \"\\e6f7\";\n}\n.ti-layout-menu-full:before {\n  content: \"\\e6f8\";\n}\n.ti-layout-media-right-alt:before {\n  content: \"\\e6f9\";\n}\n.ti-layout-media-right:before {\n  content: \"\\e6fa\";\n}\n.ti-layout-media-overlay:before {\n  content: \"\\e6fb\";\n}\n.ti-layout-media-overlay-alt:before {\n  content: \"\\e6fc\";\n}\n.ti-layout-media-overlay-alt-2:before {\n  content: \"\\e6fd\";\n}\n.ti-layout-media-left-alt:before {\n  content: \"\\e6fe\";\n}\n.ti-layout-media-left:before {\n  content: \"\\e6ff\";\n}\n.ti-layout-media-center-alt:before {\n  content: \"\\e700\";\n}\n.ti-layout-media-center:before {\n  content: \"\\e701\";\n}\n.ti-layout-list-thumb:before {\n  content: \"\\e702\";\n}\n.ti-layout-list-thumb-alt:before {\n  content: \"\\e703\";\n}\n.ti-layout-list-post:before {\n  content: \"\\e704\";\n}\n.ti-layout-list-large-image:before {\n  content: \"\\e705\";\n}\n.ti-layout-line-solid:before {\n  content: \"\\e706\";\n}\n.ti-layout-grid4:before {\n  content: \"\\e707\";\n}\n.ti-layout-grid3:before {\n  content: \"\\e708\";\n}\n.ti-layout-grid2:before {\n  content: \"\\e709\";\n}\n.ti-layout-grid2-thumb:before {\n  content: \"\\e70a\";\n}\n.ti-layout-cta-right:before {\n  content: \"\\e70b\";\n}\n.ti-layout-cta-left:before {\n  content: \"\\e70c\";\n}\n.ti-layout-cta-center:before {\n  content: \"\\e70d\";\n}\n.ti-layout-cta-btn-right:before {\n  content: \"\\e70e\";\n}\n.ti-layout-cta-btn-left:before {\n  content: \"\\e70f\";\n}\n.ti-layout-column4:before {\n  content: \"\\e710\";\n}\n.ti-layout-column3:before {\n  content: \"\\e711\";\n}\n.ti-layout-column2:before {\n  content: \"\\e712\";\n}\n.ti-layout-accordion-separated:before {\n  content: \"\\e713\";\n}\n.ti-layout-accordion-merged:before {\n  content: \"\\e714\";\n}\n.ti-layout-accordion-list:before {\n  content: \"\\e715\";\n}\n.ti-ink-pen:before {\n  content: \"\\e716\";\n}\n.ti-info-alt:before {\n  content: \"\\e717\";\n}\n.ti-help-alt:before {\n  content: \"\\e718\";\n}\n.ti-headphone-alt:before {\n  content: \"\\e719\";\n}\n.ti-hand-point-up:before {\n  content: \"\\e71a\";\n}\n.ti-hand-point-right:before {\n  content: \"\\e71b\";\n}\n.ti-hand-point-left:before {\n  content: \"\\e71c\";\n}\n.ti-hand-point-down:before {\n  content: \"\\e71d\";\n}\n.ti-gallery:before {\n  content: \"\\e71e\";\n}\n.ti-face-smile:before {\n  content: \"\\e71f\";\n}\n.ti-face-sad:before {\n  content: \"\\e720\";\n}\n.ti-credit-card:before {\n  content: \"\\e721\";\n}\n.ti-control-skip-forward:before {\n  content: \"\\e722\";\n}\n.ti-control-skip-backward:before {\n  content: \"\\e723\";\n}\n.ti-control-record:before {\n  content: \"\\e724\";\n}\n.ti-control-eject:before {\n  content: \"\\e725\";\n}\n.ti-comments-smiley:before {\n  content: \"\\e726\";\n}\n.ti-brush-alt:before {\n  content: \"\\e727\";\n}\n.ti-youtube:before {\n  content: \"\\e728\";\n}\n.ti-vimeo:before {\n  content: \"\\e729\";\n}\n.ti-twitter:before {\n  content: \"\\e72a\";\n}\n.ti-time:before {\n  content: \"\\e72b\";\n}\n.ti-tumblr:before {\n  content: \"\\e72c\";\n}\n.ti-skype:before {\n  content: \"\\e72d\";\n}\n.ti-share:before {\n  content: \"\\e72e\";\n}\n.ti-share-alt:before {\n  content: \"\\e72f\";\n}\n.ti-rocket:before {\n  content: \"\\e730\";\n}\n.ti-pinterest:before {\n  content: \"\\e731\";\n}\n.ti-new-window:before {\n  content: \"\\e732\";\n}\n.ti-microsoft:before {\n  content: \"\\e733\";\n}\n.ti-list-ol:before {\n  content: \"\\e734\";\n}\n.ti-linkedin:before {\n  content: \"\\e735\";\n}\n.ti-layout-sidebar-2:before {\n  content: \"\\e736\";\n}\n.ti-layout-grid4-alt:before {\n  content: \"\\e737\";\n}\n.ti-layout-grid3-alt:before {\n  content: \"\\e738\";\n}\n.ti-layout-grid2-alt:before {\n  content: \"\\e739\";\n}\n.ti-layout-column4-alt:before {\n  content: \"\\e73a\";\n}\n.ti-layout-column3-alt:before {\n  content: \"\\e73b\";\n}\n.ti-layout-column2-alt:before {\n  content: \"\\e73c\";\n}\n.ti-instagram:before {\n  content: \"\\e73d\";\n}\n.ti-google:before {\n  content: \"\\e73e\";\n}\n.ti-github:before {\n  content: \"\\e73f\";\n}\n.ti-flickr:before {\n  content: \"\\e740\";\n}\n.ti-facebook:before {\n  content: \"\\e741\";\n}\n.ti-dropbox:before {\n  content: \"\\e742\";\n}\n.ti-dribbble:before {\n  content: \"\\e743\";\n}\n.ti-apple:before {\n  content: \"\\e744\";\n}\n.ti-android:before {\n  content: \"\\e745\";\n}\n.ti-save:before {\n  content: \"\\e746\";\n}\n.ti-save-alt:before {\n  content: \"\\e747\";\n}\n.ti-yahoo:before {\n  content: \"\\e748\";\n}\n.ti-wordpress:before {\n  content: \"\\e749\";\n}\n.ti-vimeo-alt:before {\n  content: \"\\e74a\";\n}\n.ti-twitter-alt:before {\n  content: \"\\e74b\";\n}\n.ti-tumblr-alt:before {\n  content: \"\\e74c\";\n}\n.ti-trello:before {\n  content: \"\\e74d\";\n}\n.ti-stack-overflow:before {\n  content: \"\\e74e\";\n}\n.ti-soundcloud:before {\n  content: \"\\e74f\";\n}\n.ti-sharethis:before {\n  content: \"\\e750\";\n}\n.ti-sharethis-alt:before {\n  content: \"\\e751\";\n}\n.ti-reddit:before {\n  content: \"\\e752\";\n}\n.ti-pinterest-alt:before {\n  content: \"\\e753\";\n}\n.ti-microsoft-alt:before {\n  content: \"\\e754\";\n}\n.ti-linux:before {\n  content: \"\\e755\";\n}\n.ti-jsfiddle:before {\n  content: \"\\e756\";\n}\n.ti-joomla:before {\n  content: \"\\e757\";\n}\n.ti-html5:before {\n  content: \"\\e758\";\n}\n.ti-flickr-alt:before {\n  content: \"\\e759\";\n}\n.ti-email:before {\n  content: \"\\e75a\";\n}\n.ti-drupal:before {\n  content: \"\\e75b\";\n}\n.ti-dropbox-alt:before {\n  content: \"\\e75c\";\n}\n.ti-css3:before {\n  content: \"\\e75d\";\n}\n.ti-rss:before {\n  content: \"\\e75e\";\n}\n.ti-rss-alt:before {\n  content: \"\\e75f\";\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/css/weather-icons-core.css",
    "content": "@font-face {\n  font-family: 'weathericons';\n  src: url('..//fonts/weathericons-regular-webfont.eot');\n  src: url('..//fonts/weathericons-regular-webfont.eot?#iefix') format('embedded-opentype'), url('..//fonts/weathericons-regular-webfont.woff2') format('woff2'), url('..//fonts/weathericons-regular-webfont.woff') format('woff'), url('..//fonts/weathericons-regular-webfont.ttf') format('truetype'), url('..//fonts/weathericons-regular-webfont.svg#weather_iconsregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.wi {\n  display: inline-block;\n  font-family: 'weathericons';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.wi-fw {\n  text-align: center;\n  width: 1.4em;\n}\n.wi-rotate-90 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-rotate-180 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-rotate-270 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-flip-horizontal {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.wi-flip-vertical {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/css/weather-icons-variables.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/css/weather-icons-wind.css",
    "content": "@font-face {\n  font-family: 'weathericons';\n  src: url('..//fonts/weathericons-regular-webfont.eot');\n  src: url('..//fonts/weathericons-regular-webfont.eot?#iefix') format('embedded-opentype'), url('..//fonts/weathericons-regular-webfont.woff2') format('woff2'), url('..//fonts/weathericons-regular-webfont.woff') format('woff'), url('..//fonts/weathericons-regular-webfont.ttf') format('truetype'), url('..//fonts/weathericons-regular-webfont.svg#weather_iconsregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.wi {\n  display: inline-block;\n  font-family: 'weathericons';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.wi-fw {\n  text-align: center;\n  width: 1.4em;\n}\n.wi-rotate-90 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-rotate-180 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-rotate-270 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-flip-horizontal {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.wi-flip-vertical {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n.wi-wind:before {\n  content: \"\\f0b1\";\n}\n.wi-wind.towards-0-deg {\n  -webkit-transform: rotate(0deg);\n  -moz-transform: rotate(0deg);\n  -ms-transform: rotate(0deg);\n  -o-transform: rotate(0deg);\n  transform: rotate(0deg);\n}\n.wi-wind.towards-1-deg {\n  -webkit-transform: rotate(1deg);\n  -moz-transform: rotate(1deg);\n  -ms-transform: rotate(1deg);\n  -o-transform: rotate(1deg);\n  transform: rotate(1deg);\n}\n.wi-wind.towards-2-deg {\n  -webkit-transform: rotate(2deg);\n  -moz-transform: rotate(2deg);\n  -ms-transform: rotate(2deg);\n  -o-transform: rotate(2deg);\n  transform: rotate(2deg);\n}\n.wi-wind.towards-3-deg {\n  -webkit-transform: rotate(3deg);\n  -moz-transform: rotate(3deg);\n  -ms-transform: rotate(3deg);\n  -o-transform: rotate(3deg);\n  transform: rotate(3deg);\n}\n.wi-wind.towards-4-deg {\n  -webkit-transform: rotate(4deg);\n  -moz-transform: rotate(4deg);\n  -ms-transform: rotate(4deg);\n  -o-transform: rotate(4deg);\n  transform: rotate(4deg);\n}\n.wi-wind.towards-5-deg {\n  -webkit-transform: rotate(5deg);\n  -moz-transform: rotate(5deg);\n  -ms-transform: rotate(5deg);\n  -o-transform: rotate(5deg);\n  transform: rotate(5deg);\n}\n.wi-wind.towards-6-deg {\n  -webkit-transform: rotate(6deg);\n  -moz-transform: rotate(6deg);\n  -ms-transform: rotate(6deg);\n  -o-transform: rotate(6deg);\n  transform: rotate(6deg);\n}\n.wi-wind.towards-7-deg {\n  -webkit-transform: rotate(7deg);\n  -moz-transform: rotate(7deg);\n  -ms-transform: rotate(7deg);\n  -o-transform: rotate(7deg);\n  transform: rotate(7deg);\n}\n.wi-wind.towards-8-deg {\n  -webkit-transform: rotate(8deg);\n  -moz-transform: rotate(8deg);\n  -ms-transform: rotate(8deg);\n  -o-transform: rotate(8deg);\n  transform: rotate(8deg);\n}\n.wi-wind.towards-9-deg {\n  -webkit-transform: rotate(9deg);\n  -moz-transform: rotate(9deg);\n  -ms-transform: rotate(9deg);\n  -o-transform: rotate(9deg);\n  transform: rotate(9deg);\n}\n.wi-wind.towards-10-deg {\n  -webkit-transform: rotate(10deg);\n  -moz-transform: rotate(10deg);\n  -ms-transform: rotate(10deg);\n  -o-transform: rotate(10deg);\n  transform: rotate(10deg);\n}\n.wi-wind.towards-11-deg {\n  -webkit-transform: rotate(11deg);\n  -moz-transform: rotate(11deg);\n  -ms-transform: rotate(11deg);\n  -o-transform: rotate(11deg);\n  transform: rotate(11deg);\n}\n.wi-wind.towards-12-deg {\n  -webkit-transform: rotate(12deg);\n  -moz-transform: rotate(12deg);\n  -ms-transform: rotate(12deg);\n  -o-transform: rotate(12deg);\n  transform: rotate(12deg);\n}\n.wi-wind.towards-13-deg {\n  -webkit-transform: rotate(13deg);\n  -moz-transform: rotate(13deg);\n  -ms-transform: rotate(13deg);\n  -o-transform: rotate(13deg);\n  transform: rotate(13deg);\n}\n.wi-wind.towards-14-deg {\n  -webkit-transform: rotate(14deg);\n  -moz-transform: rotate(14deg);\n  -ms-transform: rotate(14deg);\n  -o-transform: rotate(14deg);\n  transform: rotate(14deg);\n}\n.wi-wind.towards-15-deg {\n  -webkit-transform: rotate(15deg);\n  -moz-transform: rotate(15deg);\n  -ms-transform: rotate(15deg);\n  -o-transform: rotate(15deg);\n  transform: rotate(15deg);\n}\n.wi-wind.towards-16-deg {\n  -webkit-transform: rotate(16deg);\n  -moz-transform: rotate(16deg);\n  -ms-transform: rotate(16deg);\n  -o-transform: rotate(16deg);\n  transform: rotate(16deg);\n}\n.wi-wind.towards-17-deg {\n  -webkit-transform: rotate(17deg);\n  -moz-transform: rotate(17deg);\n  -ms-transform: rotate(17deg);\n  -o-transform: rotate(17deg);\n  transform: rotate(17deg);\n}\n.wi-wind.towards-18-deg {\n  -webkit-transform: rotate(18deg);\n  -moz-transform: rotate(18deg);\n  -ms-transform: rotate(18deg);\n  -o-transform: rotate(18deg);\n  transform: rotate(18deg);\n}\n.wi-wind.towards-19-deg {\n  -webkit-transform: rotate(19deg);\n  -moz-transform: rotate(19deg);\n  -ms-transform: rotate(19deg);\n  -o-transform: rotate(19deg);\n  transform: rotate(19deg);\n}\n.wi-wind.towards-20-deg {\n  -webkit-transform: rotate(20deg);\n  -moz-transform: rotate(20deg);\n  -ms-transform: rotate(20deg);\n  -o-transform: rotate(20deg);\n  transform: rotate(20deg);\n}\n.wi-wind.towards-21-deg {\n  -webkit-transform: rotate(21deg);\n  -moz-transform: rotate(21deg);\n  -ms-transform: rotate(21deg);\n  -o-transform: rotate(21deg);\n  transform: rotate(21deg);\n}\n.wi-wind.towards-22-deg {\n  -webkit-transform: rotate(22deg);\n  -moz-transform: rotate(22deg);\n  -ms-transform: rotate(22deg);\n  -o-transform: rotate(22deg);\n  transform: rotate(22deg);\n}\n.wi-wind.towards-23-deg {\n  -webkit-transform: rotate(23deg);\n  -moz-transform: rotate(23deg);\n  -ms-transform: rotate(23deg);\n  -o-transform: rotate(23deg);\n  transform: rotate(23deg);\n}\n.wi-wind.towards-24-deg {\n  -webkit-transform: rotate(24deg);\n  -moz-transform: rotate(24deg);\n  -ms-transform: rotate(24deg);\n  -o-transform: rotate(24deg);\n  transform: rotate(24deg);\n}\n.wi-wind.towards-25-deg {\n  -webkit-transform: rotate(25deg);\n  -moz-transform: rotate(25deg);\n  -ms-transform: rotate(25deg);\n  -o-transform: rotate(25deg);\n  transform: rotate(25deg);\n}\n.wi-wind.towards-26-deg {\n  -webkit-transform: rotate(26deg);\n  -moz-transform: rotate(26deg);\n  -ms-transform: rotate(26deg);\n  -o-transform: rotate(26deg);\n  transform: rotate(26deg);\n}\n.wi-wind.towards-27-deg {\n  -webkit-transform: rotate(27deg);\n  -moz-transform: rotate(27deg);\n  -ms-transform: rotate(27deg);\n  -o-transform: rotate(27deg);\n  transform: rotate(27deg);\n}\n.wi-wind.towards-28-deg {\n  -webkit-transform: rotate(28deg);\n  -moz-transform: rotate(28deg);\n  -ms-transform: rotate(28deg);\n  -o-transform: rotate(28deg);\n  transform: rotate(28deg);\n}\n.wi-wind.towards-29-deg {\n  -webkit-transform: rotate(29deg);\n  -moz-transform: rotate(29deg);\n  -ms-transform: rotate(29deg);\n  -o-transform: rotate(29deg);\n  transform: rotate(29deg);\n}\n.wi-wind.towards-30-deg {\n  -webkit-transform: rotate(30deg);\n  -moz-transform: rotate(30deg);\n  -ms-transform: rotate(30deg);\n  -o-transform: rotate(30deg);\n  transform: rotate(30deg);\n}\n.wi-wind.towards-31-deg {\n  -webkit-transform: rotate(31deg);\n  -moz-transform: rotate(31deg);\n  -ms-transform: rotate(31deg);\n  -o-transform: rotate(31deg);\n  transform: rotate(31deg);\n}\n.wi-wind.towards-32-deg {\n  -webkit-transform: rotate(32deg);\n  -moz-transform: rotate(32deg);\n  -ms-transform: rotate(32deg);\n  -o-transform: rotate(32deg);\n  transform: rotate(32deg);\n}\n.wi-wind.towards-33-deg {\n  -webkit-transform: rotate(33deg);\n  -moz-transform: rotate(33deg);\n  -ms-transform: rotate(33deg);\n  -o-transform: rotate(33deg);\n  transform: rotate(33deg);\n}\n.wi-wind.towards-34-deg {\n  -webkit-transform: rotate(34deg);\n  -moz-transform: rotate(34deg);\n  -ms-transform: rotate(34deg);\n  -o-transform: rotate(34deg);\n  transform: rotate(34deg);\n}\n.wi-wind.towards-35-deg {\n  -webkit-transform: rotate(35deg);\n  -moz-transform: rotate(35deg);\n  -ms-transform: rotate(35deg);\n  -o-transform: rotate(35deg);\n  transform: rotate(35deg);\n}\n.wi-wind.towards-36-deg {\n  -webkit-transform: rotate(36deg);\n  -moz-transform: rotate(36deg);\n  -ms-transform: rotate(36deg);\n  -o-transform: rotate(36deg);\n  transform: rotate(36deg);\n}\n.wi-wind.towards-37-deg {\n  -webkit-transform: rotate(37deg);\n  -moz-transform: rotate(37deg);\n  -ms-transform: rotate(37deg);\n  -o-transform: rotate(37deg);\n  transform: rotate(37deg);\n}\n.wi-wind.towards-38-deg {\n  -webkit-transform: rotate(38deg);\n  -moz-transform: rotate(38deg);\n  -ms-transform: rotate(38deg);\n  -o-transform: rotate(38deg);\n  transform: rotate(38deg);\n}\n.wi-wind.towards-39-deg {\n  -webkit-transform: rotate(39deg);\n  -moz-transform: rotate(39deg);\n  -ms-transform: rotate(39deg);\n  -o-transform: rotate(39deg);\n  transform: rotate(39deg);\n}\n.wi-wind.towards-40-deg {\n  -webkit-transform: rotate(40deg);\n  -moz-transform: rotate(40deg);\n  -ms-transform: rotate(40deg);\n  -o-transform: rotate(40deg);\n  transform: rotate(40deg);\n}\n.wi-wind.towards-41-deg {\n  -webkit-transform: rotate(41deg);\n  -moz-transform: rotate(41deg);\n  -ms-transform: rotate(41deg);\n  -o-transform: rotate(41deg);\n  transform: rotate(41deg);\n}\n.wi-wind.towards-42-deg {\n  -webkit-transform: rotate(42deg);\n  -moz-transform: rotate(42deg);\n  -ms-transform: rotate(42deg);\n  -o-transform: rotate(42deg);\n  transform: rotate(42deg);\n}\n.wi-wind.towards-43-deg {\n  -webkit-transform: rotate(43deg);\n  -moz-transform: rotate(43deg);\n  -ms-transform: rotate(43deg);\n  -o-transform: rotate(43deg);\n  transform: rotate(43deg);\n}\n.wi-wind.towards-44-deg {\n  -webkit-transform: rotate(44deg);\n  -moz-transform: rotate(44deg);\n  -ms-transform: rotate(44deg);\n  -o-transform: rotate(44deg);\n  transform: rotate(44deg);\n}\n.wi-wind.towards-45-deg {\n  -webkit-transform: rotate(45deg);\n  -moz-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg);\n}\n.wi-wind.towards-46-deg {\n  -webkit-transform: rotate(46deg);\n  -moz-transform: rotate(46deg);\n  -ms-transform: rotate(46deg);\n  -o-transform: rotate(46deg);\n  transform: rotate(46deg);\n}\n.wi-wind.towards-47-deg {\n  -webkit-transform: rotate(47deg);\n  -moz-transform: rotate(47deg);\n  -ms-transform: rotate(47deg);\n  -o-transform: rotate(47deg);\n  transform: rotate(47deg);\n}\n.wi-wind.towards-48-deg {\n  -webkit-transform: rotate(48deg);\n  -moz-transform: rotate(48deg);\n  -ms-transform: rotate(48deg);\n  -o-transform: rotate(48deg);\n  transform: rotate(48deg);\n}\n.wi-wind.towards-49-deg {\n  -webkit-transform: rotate(49deg);\n  -moz-transform: rotate(49deg);\n  -ms-transform: rotate(49deg);\n  -o-transform: rotate(49deg);\n  transform: rotate(49deg);\n}\n.wi-wind.towards-50-deg {\n  -webkit-transform: rotate(50deg);\n  -moz-transform: rotate(50deg);\n  -ms-transform: rotate(50deg);\n  -o-transform: rotate(50deg);\n  transform: rotate(50deg);\n}\n.wi-wind.towards-51-deg {\n  -webkit-transform: rotate(51deg);\n  -moz-transform: rotate(51deg);\n  -ms-transform: rotate(51deg);\n  -o-transform: rotate(51deg);\n  transform: rotate(51deg);\n}\n.wi-wind.towards-52-deg {\n  -webkit-transform: rotate(52deg);\n  -moz-transform: rotate(52deg);\n  -ms-transform: rotate(52deg);\n  -o-transform: rotate(52deg);\n  transform: rotate(52deg);\n}\n.wi-wind.towards-53-deg {\n  -webkit-transform: rotate(53deg);\n  -moz-transform: rotate(53deg);\n  -ms-transform: rotate(53deg);\n  -o-transform: rotate(53deg);\n  transform: rotate(53deg);\n}\n.wi-wind.towards-54-deg {\n  -webkit-transform: rotate(54deg);\n  -moz-transform: rotate(54deg);\n  -ms-transform: rotate(54deg);\n  -o-transform: rotate(54deg);\n  transform: rotate(54deg);\n}\n.wi-wind.towards-55-deg {\n  -webkit-transform: rotate(55deg);\n  -moz-transform: rotate(55deg);\n  -ms-transform: rotate(55deg);\n  -o-transform: rotate(55deg);\n  transform: rotate(55deg);\n}\n.wi-wind.towards-56-deg {\n  -webkit-transform: rotate(56deg);\n  -moz-transform: rotate(56deg);\n  -ms-transform: rotate(56deg);\n  -o-transform: rotate(56deg);\n  transform: rotate(56deg);\n}\n.wi-wind.towards-57-deg {\n  -webkit-transform: rotate(57deg);\n  -moz-transform: rotate(57deg);\n  -ms-transform: rotate(57deg);\n  -o-transform: rotate(57deg);\n  transform: rotate(57deg);\n}\n.wi-wind.towards-58-deg {\n  -webkit-transform: rotate(58deg);\n  -moz-transform: rotate(58deg);\n  -ms-transform: rotate(58deg);\n  -o-transform: rotate(58deg);\n  transform: rotate(58deg);\n}\n.wi-wind.towards-59-deg {\n  -webkit-transform: rotate(59deg);\n  -moz-transform: rotate(59deg);\n  -ms-transform: rotate(59deg);\n  -o-transform: rotate(59deg);\n  transform: rotate(59deg);\n}\n.wi-wind.towards-60-deg {\n  -webkit-transform: rotate(60deg);\n  -moz-transform: rotate(60deg);\n  -ms-transform: rotate(60deg);\n  -o-transform: rotate(60deg);\n  transform: rotate(60deg);\n}\n.wi-wind.towards-61-deg {\n  -webkit-transform: rotate(61deg);\n  -moz-transform: rotate(61deg);\n  -ms-transform: rotate(61deg);\n  -o-transform: rotate(61deg);\n  transform: rotate(61deg);\n}\n.wi-wind.towards-62-deg {\n  -webkit-transform: rotate(62deg);\n  -moz-transform: rotate(62deg);\n  -ms-transform: rotate(62deg);\n  -o-transform: rotate(62deg);\n  transform: rotate(62deg);\n}\n.wi-wind.towards-63-deg {\n  -webkit-transform: rotate(63deg);\n  -moz-transform: rotate(63deg);\n  -ms-transform: rotate(63deg);\n  -o-transform: rotate(63deg);\n  transform: rotate(63deg);\n}\n.wi-wind.towards-64-deg {\n  -webkit-transform: rotate(64deg);\n  -moz-transform: rotate(64deg);\n  -ms-transform: rotate(64deg);\n  -o-transform: rotate(64deg);\n  transform: rotate(64deg);\n}\n.wi-wind.towards-65-deg {\n  -webkit-transform: rotate(65deg);\n  -moz-transform: rotate(65deg);\n  -ms-transform: rotate(65deg);\n  -o-transform: rotate(65deg);\n  transform: rotate(65deg);\n}\n.wi-wind.towards-66-deg {\n  -webkit-transform: rotate(66deg);\n  -moz-transform: rotate(66deg);\n  -ms-transform: rotate(66deg);\n  -o-transform: rotate(66deg);\n  transform: rotate(66deg);\n}\n.wi-wind.towards-67-deg {\n  -webkit-transform: rotate(67deg);\n  -moz-transform: rotate(67deg);\n  -ms-transform: rotate(67deg);\n  -o-transform: rotate(67deg);\n  transform: rotate(67deg);\n}\n.wi-wind.towards-68-deg {\n  -webkit-transform: rotate(68deg);\n  -moz-transform: rotate(68deg);\n  -ms-transform: rotate(68deg);\n  -o-transform: rotate(68deg);\n  transform: rotate(68deg);\n}\n.wi-wind.towards-69-deg {\n  -webkit-transform: rotate(69deg);\n  -moz-transform: rotate(69deg);\n  -ms-transform: rotate(69deg);\n  -o-transform: rotate(69deg);\n  transform: rotate(69deg);\n}\n.wi-wind.towards-70-deg {\n  -webkit-transform: rotate(70deg);\n  -moz-transform: rotate(70deg);\n  -ms-transform: rotate(70deg);\n  -o-transform: rotate(70deg);\n  transform: rotate(70deg);\n}\n.wi-wind.towards-71-deg {\n  -webkit-transform: rotate(71deg);\n  -moz-transform: rotate(71deg);\n  -ms-transform: rotate(71deg);\n  -o-transform: rotate(71deg);\n  transform: rotate(71deg);\n}\n.wi-wind.towards-72-deg {\n  -webkit-transform: rotate(72deg);\n  -moz-transform: rotate(72deg);\n  -ms-transform: rotate(72deg);\n  -o-transform: rotate(72deg);\n  transform: rotate(72deg);\n}\n.wi-wind.towards-73-deg {\n  -webkit-transform: rotate(73deg);\n  -moz-transform: rotate(73deg);\n  -ms-transform: rotate(73deg);\n  -o-transform: rotate(73deg);\n  transform: rotate(73deg);\n}\n.wi-wind.towards-74-deg {\n  -webkit-transform: rotate(74deg);\n  -moz-transform: rotate(74deg);\n  -ms-transform: rotate(74deg);\n  -o-transform: rotate(74deg);\n  transform: rotate(74deg);\n}\n.wi-wind.towards-75-deg {\n  -webkit-transform: rotate(75deg);\n  -moz-transform: rotate(75deg);\n  -ms-transform: rotate(75deg);\n  -o-transform: rotate(75deg);\n  transform: rotate(75deg);\n}\n.wi-wind.towards-76-deg {\n  -webkit-transform: rotate(76deg);\n  -moz-transform: rotate(76deg);\n  -ms-transform: rotate(76deg);\n  -o-transform: rotate(76deg);\n  transform: rotate(76deg);\n}\n.wi-wind.towards-77-deg {\n  -webkit-transform: rotate(77deg);\n  -moz-transform: rotate(77deg);\n  -ms-transform: rotate(77deg);\n  -o-transform: rotate(77deg);\n  transform: rotate(77deg);\n}\n.wi-wind.towards-78-deg {\n  -webkit-transform: rotate(78deg);\n  -moz-transform: rotate(78deg);\n  -ms-transform: rotate(78deg);\n  -o-transform: rotate(78deg);\n  transform: rotate(78deg);\n}\n.wi-wind.towards-79-deg {\n  -webkit-transform: rotate(79deg);\n  -moz-transform: rotate(79deg);\n  -ms-transform: rotate(79deg);\n  -o-transform: rotate(79deg);\n  transform: rotate(79deg);\n}\n.wi-wind.towards-80-deg {\n  -webkit-transform: rotate(80deg);\n  -moz-transform: rotate(80deg);\n  -ms-transform: rotate(80deg);\n  -o-transform: rotate(80deg);\n  transform: rotate(80deg);\n}\n.wi-wind.towards-81-deg {\n  -webkit-transform: rotate(81deg);\n  -moz-transform: rotate(81deg);\n  -ms-transform: rotate(81deg);\n  -o-transform: rotate(81deg);\n  transform: rotate(81deg);\n}\n.wi-wind.towards-82-deg {\n  -webkit-transform: rotate(82deg);\n  -moz-transform: rotate(82deg);\n  -ms-transform: rotate(82deg);\n  -o-transform: rotate(82deg);\n  transform: rotate(82deg);\n}\n.wi-wind.towards-83-deg {\n  -webkit-transform: rotate(83deg);\n  -moz-transform: rotate(83deg);\n  -ms-transform: rotate(83deg);\n  -o-transform: rotate(83deg);\n  transform: rotate(83deg);\n}\n.wi-wind.towards-84-deg {\n  -webkit-transform: rotate(84deg);\n  -moz-transform: rotate(84deg);\n  -ms-transform: rotate(84deg);\n  -o-transform: rotate(84deg);\n  transform: rotate(84deg);\n}\n.wi-wind.towards-85-deg {\n  -webkit-transform: rotate(85deg);\n  -moz-transform: rotate(85deg);\n  -ms-transform: rotate(85deg);\n  -o-transform: rotate(85deg);\n  transform: rotate(85deg);\n}\n.wi-wind.towards-86-deg {\n  -webkit-transform: rotate(86deg);\n  -moz-transform: rotate(86deg);\n  -ms-transform: rotate(86deg);\n  -o-transform: rotate(86deg);\n  transform: rotate(86deg);\n}\n.wi-wind.towards-87-deg {\n  -webkit-transform: rotate(87deg);\n  -moz-transform: rotate(87deg);\n  -ms-transform: rotate(87deg);\n  -o-transform: rotate(87deg);\n  transform: rotate(87deg);\n}\n.wi-wind.towards-88-deg {\n  -webkit-transform: rotate(88deg);\n  -moz-transform: rotate(88deg);\n  -ms-transform: rotate(88deg);\n  -o-transform: rotate(88deg);\n  transform: rotate(88deg);\n}\n.wi-wind.towards-89-deg {\n  -webkit-transform: rotate(89deg);\n  -moz-transform: rotate(89deg);\n  -ms-transform: rotate(89deg);\n  -o-transform: rotate(89deg);\n  transform: rotate(89deg);\n}\n.wi-wind.towards-90-deg {\n  -webkit-transform: rotate(90deg);\n  -moz-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  -o-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-wind.towards-91-deg {\n  -webkit-transform: rotate(91deg);\n  -moz-transform: rotate(91deg);\n  -ms-transform: rotate(91deg);\n  -o-transform: rotate(91deg);\n  transform: rotate(91deg);\n}\n.wi-wind.towards-92-deg {\n  -webkit-transform: rotate(92deg);\n  -moz-transform: rotate(92deg);\n  -ms-transform: rotate(92deg);\n  -o-transform: rotate(92deg);\n  transform: rotate(92deg);\n}\n.wi-wind.towards-93-deg {\n  -webkit-transform: rotate(93deg);\n  -moz-transform: rotate(93deg);\n  -ms-transform: rotate(93deg);\n  -o-transform: rotate(93deg);\n  transform: rotate(93deg);\n}\n.wi-wind.towards-94-deg {\n  -webkit-transform: rotate(94deg);\n  -moz-transform: rotate(94deg);\n  -ms-transform: rotate(94deg);\n  -o-transform: rotate(94deg);\n  transform: rotate(94deg);\n}\n.wi-wind.towards-95-deg {\n  -webkit-transform: rotate(95deg);\n  -moz-transform: rotate(95deg);\n  -ms-transform: rotate(95deg);\n  -o-transform: rotate(95deg);\n  transform: rotate(95deg);\n}\n.wi-wind.towards-96-deg {\n  -webkit-transform: rotate(96deg);\n  -moz-transform: rotate(96deg);\n  -ms-transform: rotate(96deg);\n  -o-transform: rotate(96deg);\n  transform: rotate(96deg);\n}\n.wi-wind.towards-97-deg {\n  -webkit-transform: rotate(97deg);\n  -moz-transform: rotate(97deg);\n  -ms-transform: rotate(97deg);\n  -o-transform: rotate(97deg);\n  transform: rotate(97deg);\n}\n.wi-wind.towards-98-deg {\n  -webkit-transform: rotate(98deg);\n  -moz-transform: rotate(98deg);\n  -ms-transform: rotate(98deg);\n  -o-transform: rotate(98deg);\n  transform: rotate(98deg);\n}\n.wi-wind.towards-99-deg {\n  -webkit-transform: rotate(99deg);\n  -moz-transform: rotate(99deg);\n  -ms-transform: rotate(99deg);\n  -o-transform: rotate(99deg);\n  transform: rotate(99deg);\n}\n.wi-wind.towards-100-deg {\n  -webkit-transform: rotate(100deg);\n  -moz-transform: rotate(100deg);\n  -ms-transform: rotate(100deg);\n  -o-transform: rotate(100deg);\n  transform: rotate(100deg);\n}\n.wi-wind.towards-101-deg {\n  -webkit-transform: rotate(101deg);\n  -moz-transform: rotate(101deg);\n  -ms-transform: rotate(101deg);\n  -o-transform: rotate(101deg);\n  transform: rotate(101deg);\n}\n.wi-wind.towards-102-deg {\n  -webkit-transform: rotate(102deg);\n  -moz-transform: rotate(102deg);\n  -ms-transform: rotate(102deg);\n  -o-transform: rotate(102deg);\n  transform: rotate(102deg);\n}\n.wi-wind.towards-103-deg {\n  -webkit-transform: rotate(103deg);\n  -moz-transform: rotate(103deg);\n  -ms-transform: rotate(103deg);\n  -o-transform: rotate(103deg);\n  transform: rotate(103deg);\n}\n.wi-wind.towards-104-deg {\n  -webkit-transform: rotate(104deg);\n  -moz-transform: rotate(104deg);\n  -ms-transform: rotate(104deg);\n  -o-transform: rotate(104deg);\n  transform: rotate(104deg);\n}\n.wi-wind.towards-105-deg {\n  -webkit-transform: rotate(105deg);\n  -moz-transform: rotate(105deg);\n  -ms-transform: rotate(105deg);\n  -o-transform: rotate(105deg);\n  transform: rotate(105deg);\n}\n.wi-wind.towards-106-deg {\n  -webkit-transform: rotate(106deg);\n  -moz-transform: rotate(106deg);\n  -ms-transform: rotate(106deg);\n  -o-transform: rotate(106deg);\n  transform: rotate(106deg);\n}\n.wi-wind.towards-107-deg {\n  -webkit-transform: rotate(107deg);\n  -moz-transform: rotate(107deg);\n  -ms-transform: rotate(107deg);\n  -o-transform: rotate(107deg);\n  transform: rotate(107deg);\n}\n.wi-wind.towards-108-deg {\n  -webkit-transform: rotate(108deg);\n  -moz-transform: rotate(108deg);\n  -ms-transform: rotate(108deg);\n  -o-transform: rotate(108deg);\n  transform: rotate(108deg);\n}\n.wi-wind.towards-109-deg {\n  -webkit-transform: rotate(109deg);\n  -moz-transform: rotate(109deg);\n  -ms-transform: rotate(109deg);\n  -o-transform: rotate(109deg);\n  transform: rotate(109deg);\n}\n.wi-wind.towards-110-deg {\n  -webkit-transform: rotate(110deg);\n  -moz-transform: rotate(110deg);\n  -ms-transform: rotate(110deg);\n  -o-transform: rotate(110deg);\n  transform: rotate(110deg);\n}\n.wi-wind.towards-111-deg {\n  -webkit-transform: rotate(111deg);\n  -moz-transform: rotate(111deg);\n  -ms-transform: rotate(111deg);\n  -o-transform: rotate(111deg);\n  transform: rotate(111deg);\n}\n.wi-wind.towards-112-deg {\n  -webkit-transform: rotate(112deg);\n  -moz-transform: rotate(112deg);\n  -ms-transform: rotate(112deg);\n  -o-transform: rotate(112deg);\n  transform: rotate(112deg);\n}\n.wi-wind.towards-113-deg {\n  -webkit-transform: rotate(113deg);\n  -moz-transform: rotate(113deg);\n  -ms-transform: rotate(113deg);\n  -o-transform: rotate(113deg);\n  transform: rotate(113deg);\n}\n.wi-wind.towards-114-deg {\n  -webkit-transform: rotate(114deg);\n  -moz-transform: rotate(114deg);\n  -ms-transform: rotate(114deg);\n  -o-transform: rotate(114deg);\n  transform: rotate(114deg);\n}\n.wi-wind.towards-115-deg {\n  -webkit-transform: rotate(115deg);\n  -moz-transform: rotate(115deg);\n  -ms-transform: rotate(115deg);\n  -o-transform: rotate(115deg);\n  transform: rotate(115deg);\n}\n.wi-wind.towards-116-deg {\n  -webkit-transform: rotate(116deg);\n  -moz-transform: rotate(116deg);\n  -ms-transform: rotate(116deg);\n  -o-transform: rotate(116deg);\n  transform: rotate(116deg);\n}\n.wi-wind.towards-117-deg {\n  -webkit-transform: rotate(117deg);\n  -moz-transform: rotate(117deg);\n  -ms-transform: rotate(117deg);\n  -o-transform: rotate(117deg);\n  transform: rotate(117deg);\n}\n.wi-wind.towards-118-deg {\n  -webkit-transform: rotate(118deg);\n  -moz-transform: rotate(118deg);\n  -ms-transform: rotate(118deg);\n  -o-transform: rotate(118deg);\n  transform: rotate(118deg);\n}\n.wi-wind.towards-119-deg {\n  -webkit-transform: rotate(119deg);\n  -moz-transform: rotate(119deg);\n  -ms-transform: rotate(119deg);\n  -o-transform: rotate(119deg);\n  transform: rotate(119deg);\n}\n.wi-wind.towards-120-deg {\n  -webkit-transform: rotate(120deg);\n  -moz-transform: rotate(120deg);\n  -ms-transform: rotate(120deg);\n  -o-transform: rotate(120deg);\n  transform: rotate(120deg);\n}\n.wi-wind.towards-121-deg {\n  -webkit-transform: rotate(121deg);\n  -moz-transform: rotate(121deg);\n  -ms-transform: rotate(121deg);\n  -o-transform: rotate(121deg);\n  transform: rotate(121deg);\n}\n.wi-wind.towards-122-deg {\n  -webkit-transform: rotate(122deg);\n  -moz-transform: rotate(122deg);\n  -ms-transform: rotate(122deg);\n  -o-transform: rotate(122deg);\n  transform: rotate(122deg);\n}\n.wi-wind.towards-123-deg {\n  -webkit-transform: rotate(123deg);\n  -moz-transform: rotate(123deg);\n  -ms-transform: rotate(123deg);\n  -o-transform: rotate(123deg);\n  transform: rotate(123deg);\n}\n.wi-wind.towards-124-deg {\n  -webkit-transform: rotate(124deg);\n  -moz-transform: rotate(124deg);\n  -ms-transform: rotate(124deg);\n  -o-transform: rotate(124deg);\n  transform: rotate(124deg);\n}\n.wi-wind.towards-125-deg {\n  -webkit-transform: rotate(125deg);\n  -moz-transform: rotate(125deg);\n  -ms-transform: rotate(125deg);\n  -o-transform: rotate(125deg);\n  transform: rotate(125deg);\n}\n.wi-wind.towards-126-deg {\n  -webkit-transform: rotate(126deg);\n  -moz-transform: rotate(126deg);\n  -ms-transform: rotate(126deg);\n  -o-transform: rotate(126deg);\n  transform: rotate(126deg);\n}\n.wi-wind.towards-127-deg {\n  -webkit-transform: rotate(127deg);\n  -moz-transform: rotate(127deg);\n  -ms-transform: rotate(127deg);\n  -o-transform: rotate(127deg);\n  transform: rotate(127deg);\n}\n.wi-wind.towards-128-deg {\n  -webkit-transform: rotate(128deg);\n  -moz-transform: rotate(128deg);\n  -ms-transform: rotate(128deg);\n  -o-transform: rotate(128deg);\n  transform: rotate(128deg);\n}\n.wi-wind.towards-129-deg {\n  -webkit-transform: rotate(129deg);\n  -moz-transform: rotate(129deg);\n  -ms-transform: rotate(129deg);\n  -o-transform: rotate(129deg);\n  transform: rotate(129deg);\n}\n.wi-wind.towards-130-deg {\n  -webkit-transform: rotate(130deg);\n  -moz-transform: rotate(130deg);\n  -ms-transform: rotate(130deg);\n  -o-transform: rotate(130deg);\n  transform: rotate(130deg);\n}\n.wi-wind.towards-131-deg {\n  -webkit-transform: rotate(131deg);\n  -moz-transform: rotate(131deg);\n  -ms-transform: rotate(131deg);\n  -o-transform: rotate(131deg);\n  transform: rotate(131deg);\n}\n.wi-wind.towards-132-deg {\n  -webkit-transform: rotate(132deg);\n  -moz-transform: rotate(132deg);\n  -ms-transform: rotate(132deg);\n  -o-transform: rotate(132deg);\n  transform: rotate(132deg);\n}\n.wi-wind.towards-133-deg {\n  -webkit-transform: rotate(133deg);\n  -moz-transform: rotate(133deg);\n  -ms-transform: rotate(133deg);\n  -o-transform: rotate(133deg);\n  transform: rotate(133deg);\n}\n.wi-wind.towards-134-deg {\n  -webkit-transform: rotate(134deg);\n  -moz-transform: rotate(134deg);\n  -ms-transform: rotate(134deg);\n  -o-transform: rotate(134deg);\n  transform: rotate(134deg);\n}\n.wi-wind.towards-135-deg {\n  -webkit-transform: rotate(135deg);\n  -moz-transform: rotate(135deg);\n  -ms-transform: rotate(135deg);\n  -o-transform: rotate(135deg);\n  transform: rotate(135deg);\n}\n.wi-wind.towards-136-deg {\n  -webkit-transform: rotate(136deg);\n  -moz-transform: rotate(136deg);\n  -ms-transform: rotate(136deg);\n  -o-transform: rotate(136deg);\n  transform: rotate(136deg);\n}\n.wi-wind.towards-137-deg {\n  -webkit-transform: rotate(137deg);\n  -moz-transform: rotate(137deg);\n  -ms-transform: rotate(137deg);\n  -o-transform: rotate(137deg);\n  transform: rotate(137deg);\n}\n.wi-wind.towards-138-deg {\n  -webkit-transform: rotate(138deg);\n  -moz-transform: rotate(138deg);\n  -ms-transform: rotate(138deg);\n  -o-transform: rotate(138deg);\n  transform: rotate(138deg);\n}\n.wi-wind.towards-139-deg {\n  -webkit-transform: rotate(139deg);\n  -moz-transform: rotate(139deg);\n  -ms-transform: rotate(139deg);\n  -o-transform: rotate(139deg);\n  transform: rotate(139deg);\n}\n.wi-wind.towards-140-deg {\n  -webkit-transform: rotate(140deg);\n  -moz-transform: rotate(140deg);\n  -ms-transform: rotate(140deg);\n  -o-transform: rotate(140deg);\n  transform: rotate(140deg);\n}\n.wi-wind.towards-141-deg {\n  -webkit-transform: rotate(141deg);\n  -moz-transform: rotate(141deg);\n  -ms-transform: rotate(141deg);\n  -o-transform: rotate(141deg);\n  transform: rotate(141deg);\n}\n.wi-wind.towards-142-deg {\n  -webkit-transform: rotate(142deg);\n  -moz-transform: rotate(142deg);\n  -ms-transform: rotate(142deg);\n  -o-transform: rotate(142deg);\n  transform: rotate(142deg);\n}\n.wi-wind.towards-143-deg {\n  -webkit-transform: rotate(143deg);\n  -moz-transform: rotate(143deg);\n  -ms-transform: rotate(143deg);\n  -o-transform: rotate(143deg);\n  transform: rotate(143deg);\n}\n.wi-wind.towards-144-deg {\n  -webkit-transform: rotate(144deg);\n  -moz-transform: rotate(144deg);\n  -ms-transform: rotate(144deg);\n  -o-transform: rotate(144deg);\n  transform: rotate(144deg);\n}\n.wi-wind.towards-145-deg {\n  -webkit-transform: rotate(145deg);\n  -moz-transform: rotate(145deg);\n  -ms-transform: rotate(145deg);\n  -o-transform: rotate(145deg);\n  transform: rotate(145deg);\n}\n.wi-wind.towards-146-deg {\n  -webkit-transform: rotate(146deg);\n  -moz-transform: rotate(146deg);\n  -ms-transform: rotate(146deg);\n  -o-transform: rotate(146deg);\n  transform: rotate(146deg);\n}\n.wi-wind.towards-147-deg {\n  -webkit-transform: rotate(147deg);\n  -moz-transform: rotate(147deg);\n  -ms-transform: rotate(147deg);\n  -o-transform: rotate(147deg);\n  transform: rotate(147deg);\n}\n.wi-wind.towards-148-deg {\n  -webkit-transform: rotate(148deg);\n  -moz-transform: rotate(148deg);\n  -ms-transform: rotate(148deg);\n  -o-transform: rotate(148deg);\n  transform: rotate(148deg);\n}\n.wi-wind.towards-149-deg {\n  -webkit-transform: rotate(149deg);\n  -moz-transform: rotate(149deg);\n  -ms-transform: rotate(149deg);\n  -o-transform: rotate(149deg);\n  transform: rotate(149deg);\n}\n.wi-wind.towards-150-deg {\n  -webkit-transform: rotate(150deg);\n  -moz-transform: rotate(150deg);\n  -ms-transform: rotate(150deg);\n  -o-transform: rotate(150deg);\n  transform: rotate(150deg);\n}\n.wi-wind.towards-151-deg {\n  -webkit-transform: rotate(151deg);\n  -moz-transform: rotate(151deg);\n  -ms-transform: rotate(151deg);\n  -o-transform: rotate(151deg);\n  transform: rotate(151deg);\n}\n.wi-wind.towards-152-deg {\n  -webkit-transform: rotate(152deg);\n  -moz-transform: rotate(152deg);\n  -ms-transform: rotate(152deg);\n  -o-transform: rotate(152deg);\n  transform: rotate(152deg);\n}\n.wi-wind.towards-153-deg {\n  -webkit-transform: rotate(153deg);\n  -moz-transform: rotate(153deg);\n  -ms-transform: rotate(153deg);\n  -o-transform: rotate(153deg);\n  transform: rotate(153deg);\n}\n.wi-wind.towards-154-deg {\n  -webkit-transform: rotate(154deg);\n  -moz-transform: rotate(154deg);\n  -ms-transform: rotate(154deg);\n  -o-transform: rotate(154deg);\n  transform: rotate(154deg);\n}\n.wi-wind.towards-155-deg {\n  -webkit-transform: rotate(155deg);\n  -moz-transform: rotate(155deg);\n  -ms-transform: rotate(155deg);\n  -o-transform: rotate(155deg);\n  transform: rotate(155deg);\n}\n.wi-wind.towards-156-deg {\n  -webkit-transform: rotate(156deg);\n  -moz-transform: rotate(156deg);\n  -ms-transform: rotate(156deg);\n  -o-transform: rotate(156deg);\n  transform: rotate(156deg);\n}\n.wi-wind.towards-157-deg {\n  -webkit-transform: rotate(157deg);\n  -moz-transform: rotate(157deg);\n  -ms-transform: rotate(157deg);\n  -o-transform: rotate(157deg);\n  transform: rotate(157deg);\n}\n.wi-wind.towards-158-deg {\n  -webkit-transform: rotate(158deg);\n  -moz-transform: rotate(158deg);\n  -ms-transform: rotate(158deg);\n  -o-transform: rotate(158deg);\n  transform: rotate(158deg);\n}\n.wi-wind.towards-159-deg {\n  -webkit-transform: rotate(159deg);\n  -moz-transform: rotate(159deg);\n  -ms-transform: rotate(159deg);\n  -o-transform: rotate(159deg);\n  transform: rotate(159deg);\n}\n.wi-wind.towards-160-deg {\n  -webkit-transform: rotate(160deg);\n  -moz-transform: rotate(160deg);\n  -ms-transform: rotate(160deg);\n  -o-transform: rotate(160deg);\n  transform: rotate(160deg);\n}\n.wi-wind.towards-161-deg {\n  -webkit-transform: rotate(161deg);\n  -moz-transform: rotate(161deg);\n  -ms-transform: rotate(161deg);\n  -o-transform: rotate(161deg);\n  transform: rotate(161deg);\n}\n.wi-wind.towards-162-deg {\n  -webkit-transform: rotate(162deg);\n  -moz-transform: rotate(162deg);\n  -ms-transform: rotate(162deg);\n  -o-transform: rotate(162deg);\n  transform: rotate(162deg);\n}\n.wi-wind.towards-163-deg {\n  -webkit-transform: rotate(163deg);\n  -moz-transform: rotate(163deg);\n  -ms-transform: rotate(163deg);\n  -o-transform: rotate(163deg);\n  transform: rotate(163deg);\n}\n.wi-wind.towards-164-deg {\n  -webkit-transform: rotate(164deg);\n  -moz-transform: rotate(164deg);\n  -ms-transform: rotate(164deg);\n  -o-transform: rotate(164deg);\n  transform: rotate(164deg);\n}\n.wi-wind.towards-165-deg {\n  -webkit-transform: rotate(165deg);\n  -moz-transform: rotate(165deg);\n  -ms-transform: rotate(165deg);\n  -o-transform: rotate(165deg);\n  transform: rotate(165deg);\n}\n.wi-wind.towards-166-deg {\n  -webkit-transform: rotate(166deg);\n  -moz-transform: rotate(166deg);\n  -ms-transform: rotate(166deg);\n  -o-transform: rotate(166deg);\n  transform: rotate(166deg);\n}\n.wi-wind.towards-167-deg {\n  -webkit-transform: rotate(167deg);\n  -moz-transform: rotate(167deg);\n  -ms-transform: rotate(167deg);\n  -o-transform: rotate(167deg);\n  transform: rotate(167deg);\n}\n.wi-wind.towards-168-deg {\n  -webkit-transform: rotate(168deg);\n  -moz-transform: rotate(168deg);\n  -ms-transform: rotate(168deg);\n  -o-transform: rotate(168deg);\n  transform: rotate(168deg);\n}\n.wi-wind.towards-169-deg {\n  -webkit-transform: rotate(169deg);\n  -moz-transform: rotate(169deg);\n  -ms-transform: rotate(169deg);\n  -o-transform: rotate(169deg);\n  transform: rotate(169deg);\n}\n.wi-wind.towards-170-deg {\n  -webkit-transform: rotate(170deg);\n  -moz-transform: rotate(170deg);\n  -ms-transform: rotate(170deg);\n  -o-transform: rotate(170deg);\n  transform: rotate(170deg);\n}\n.wi-wind.towards-171-deg {\n  -webkit-transform: rotate(171deg);\n  -moz-transform: rotate(171deg);\n  -ms-transform: rotate(171deg);\n  -o-transform: rotate(171deg);\n  transform: rotate(171deg);\n}\n.wi-wind.towards-172-deg {\n  -webkit-transform: rotate(172deg);\n  -moz-transform: rotate(172deg);\n  -ms-transform: rotate(172deg);\n  -o-transform: rotate(172deg);\n  transform: rotate(172deg);\n}\n.wi-wind.towards-173-deg {\n  -webkit-transform: rotate(173deg);\n  -moz-transform: rotate(173deg);\n  -ms-transform: rotate(173deg);\n  -o-transform: rotate(173deg);\n  transform: rotate(173deg);\n}\n.wi-wind.towards-174-deg {\n  -webkit-transform: rotate(174deg);\n  -moz-transform: rotate(174deg);\n  -ms-transform: rotate(174deg);\n  -o-transform: rotate(174deg);\n  transform: rotate(174deg);\n}\n.wi-wind.towards-175-deg {\n  -webkit-transform: rotate(175deg);\n  -moz-transform: rotate(175deg);\n  -ms-transform: rotate(175deg);\n  -o-transform: rotate(175deg);\n  transform: rotate(175deg);\n}\n.wi-wind.towards-176-deg {\n  -webkit-transform: rotate(176deg);\n  -moz-transform: rotate(176deg);\n  -ms-transform: rotate(176deg);\n  -o-transform: rotate(176deg);\n  transform: rotate(176deg);\n}\n.wi-wind.towards-177-deg {\n  -webkit-transform: rotate(177deg);\n  -moz-transform: rotate(177deg);\n  -ms-transform: rotate(177deg);\n  -o-transform: rotate(177deg);\n  transform: rotate(177deg);\n}\n.wi-wind.towards-178-deg {\n  -webkit-transform: rotate(178deg);\n  -moz-transform: rotate(178deg);\n  -ms-transform: rotate(178deg);\n  -o-transform: rotate(178deg);\n  transform: rotate(178deg);\n}\n.wi-wind.towards-179-deg {\n  -webkit-transform: rotate(179deg);\n  -moz-transform: rotate(179deg);\n  -ms-transform: rotate(179deg);\n  -o-transform: rotate(179deg);\n  transform: rotate(179deg);\n}\n.wi-wind.towards-180-deg {\n  -webkit-transform: rotate(180deg);\n  -moz-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  -o-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-wind.towards-181-deg {\n  -webkit-transform: rotate(181deg);\n  -moz-transform: rotate(181deg);\n  -ms-transform: rotate(181deg);\n  -o-transform: rotate(181deg);\n  transform: rotate(181deg);\n}\n.wi-wind.towards-182-deg {\n  -webkit-transform: rotate(182deg);\n  -moz-transform: rotate(182deg);\n  -ms-transform: rotate(182deg);\n  -o-transform: rotate(182deg);\n  transform: rotate(182deg);\n}\n.wi-wind.towards-183-deg {\n  -webkit-transform: rotate(183deg);\n  -moz-transform: rotate(183deg);\n  -ms-transform: rotate(183deg);\n  -o-transform: rotate(183deg);\n  transform: rotate(183deg);\n}\n.wi-wind.towards-184-deg {\n  -webkit-transform: rotate(184deg);\n  -moz-transform: rotate(184deg);\n  -ms-transform: rotate(184deg);\n  -o-transform: rotate(184deg);\n  transform: rotate(184deg);\n}\n.wi-wind.towards-185-deg {\n  -webkit-transform: rotate(185deg);\n  -moz-transform: rotate(185deg);\n  -ms-transform: rotate(185deg);\n  -o-transform: rotate(185deg);\n  transform: rotate(185deg);\n}\n.wi-wind.towards-186-deg {\n  -webkit-transform: rotate(186deg);\n  -moz-transform: rotate(186deg);\n  -ms-transform: rotate(186deg);\n  -o-transform: rotate(186deg);\n  transform: rotate(186deg);\n}\n.wi-wind.towards-187-deg {\n  -webkit-transform: rotate(187deg);\n  -moz-transform: rotate(187deg);\n  -ms-transform: rotate(187deg);\n  -o-transform: rotate(187deg);\n  transform: rotate(187deg);\n}\n.wi-wind.towards-188-deg {\n  -webkit-transform: rotate(188deg);\n  -moz-transform: rotate(188deg);\n  -ms-transform: rotate(188deg);\n  -o-transform: rotate(188deg);\n  transform: rotate(188deg);\n}\n.wi-wind.towards-189-deg {\n  -webkit-transform: rotate(189deg);\n  -moz-transform: rotate(189deg);\n  -ms-transform: rotate(189deg);\n  -o-transform: rotate(189deg);\n  transform: rotate(189deg);\n}\n.wi-wind.towards-190-deg {\n  -webkit-transform: rotate(190deg);\n  -moz-transform: rotate(190deg);\n  -ms-transform: rotate(190deg);\n  -o-transform: rotate(190deg);\n  transform: rotate(190deg);\n}\n.wi-wind.towards-191-deg {\n  -webkit-transform: rotate(191deg);\n  -moz-transform: rotate(191deg);\n  -ms-transform: rotate(191deg);\n  -o-transform: rotate(191deg);\n  transform: rotate(191deg);\n}\n.wi-wind.towards-192-deg {\n  -webkit-transform: rotate(192deg);\n  -moz-transform: rotate(192deg);\n  -ms-transform: rotate(192deg);\n  -o-transform: rotate(192deg);\n  transform: rotate(192deg);\n}\n.wi-wind.towards-193-deg {\n  -webkit-transform: rotate(193deg);\n  -moz-transform: rotate(193deg);\n  -ms-transform: rotate(193deg);\n  -o-transform: rotate(193deg);\n  transform: rotate(193deg);\n}\n.wi-wind.towards-194-deg {\n  -webkit-transform: rotate(194deg);\n  -moz-transform: rotate(194deg);\n  -ms-transform: rotate(194deg);\n  -o-transform: rotate(194deg);\n  transform: rotate(194deg);\n}\n.wi-wind.towards-195-deg {\n  -webkit-transform: rotate(195deg);\n  -moz-transform: rotate(195deg);\n  -ms-transform: rotate(195deg);\n  -o-transform: rotate(195deg);\n  transform: rotate(195deg);\n}\n.wi-wind.towards-196-deg {\n  -webkit-transform: rotate(196deg);\n  -moz-transform: rotate(196deg);\n  -ms-transform: rotate(196deg);\n  -o-transform: rotate(196deg);\n  transform: rotate(196deg);\n}\n.wi-wind.towards-197-deg {\n  -webkit-transform: rotate(197deg);\n  -moz-transform: rotate(197deg);\n  -ms-transform: rotate(197deg);\n  -o-transform: rotate(197deg);\n  transform: rotate(197deg);\n}\n.wi-wind.towards-198-deg {\n  -webkit-transform: rotate(198deg);\n  -moz-transform: rotate(198deg);\n  -ms-transform: rotate(198deg);\n  -o-transform: rotate(198deg);\n  transform: rotate(198deg);\n}\n.wi-wind.towards-199-deg {\n  -webkit-transform: rotate(199deg);\n  -moz-transform: rotate(199deg);\n  -ms-transform: rotate(199deg);\n  -o-transform: rotate(199deg);\n  transform: rotate(199deg);\n}\n.wi-wind.towards-200-deg {\n  -webkit-transform: rotate(200deg);\n  -moz-transform: rotate(200deg);\n  -ms-transform: rotate(200deg);\n  -o-transform: rotate(200deg);\n  transform: rotate(200deg);\n}\n.wi-wind.towards-201-deg {\n  -webkit-transform: rotate(201deg);\n  -moz-transform: rotate(201deg);\n  -ms-transform: rotate(201deg);\n  -o-transform: rotate(201deg);\n  transform: rotate(201deg);\n}\n.wi-wind.towards-202-deg {\n  -webkit-transform: rotate(202deg);\n  -moz-transform: rotate(202deg);\n  -ms-transform: rotate(202deg);\n  -o-transform: rotate(202deg);\n  transform: rotate(202deg);\n}\n.wi-wind.towards-203-deg {\n  -webkit-transform: rotate(203deg);\n  -moz-transform: rotate(203deg);\n  -ms-transform: rotate(203deg);\n  -o-transform: rotate(203deg);\n  transform: rotate(203deg);\n}\n.wi-wind.towards-204-deg {\n  -webkit-transform: rotate(204deg);\n  -moz-transform: rotate(204deg);\n  -ms-transform: rotate(204deg);\n  -o-transform: rotate(204deg);\n  transform: rotate(204deg);\n}\n.wi-wind.towards-205-deg {\n  -webkit-transform: rotate(205deg);\n  -moz-transform: rotate(205deg);\n  -ms-transform: rotate(205deg);\n  -o-transform: rotate(205deg);\n  transform: rotate(205deg);\n}\n.wi-wind.towards-206-deg {\n  -webkit-transform: rotate(206deg);\n  -moz-transform: rotate(206deg);\n  -ms-transform: rotate(206deg);\n  -o-transform: rotate(206deg);\n  transform: rotate(206deg);\n}\n.wi-wind.towards-207-deg {\n  -webkit-transform: rotate(207deg);\n  -moz-transform: rotate(207deg);\n  -ms-transform: rotate(207deg);\n  -o-transform: rotate(207deg);\n  transform: rotate(207deg);\n}\n.wi-wind.towards-208-deg {\n  -webkit-transform: rotate(208deg);\n  -moz-transform: rotate(208deg);\n  -ms-transform: rotate(208deg);\n  -o-transform: rotate(208deg);\n  transform: rotate(208deg);\n}\n.wi-wind.towards-209-deg {\n  -webkit-transform: rotate(209deg);\n  -moz-transform: rotate(209deg);\n  -ms-transform: rotate(209deg);\n  -o-transform: rotate(209deg);\n  transform: rotate(209deg);\n}\n.wi-wind.towards-210-deg {\n  -webkit-transform: rotate(210deg);\n  -moz-transform: rotate(210deg);\n  -ms-transform: rotate(210deg);\n  -o-transform: rotate(210deg);\n  transform: rotate(210deg);\n}\n.wi-wind.towards-211-deg {\n  -webkit-transform: rotate(211deg);\n  -moz-transform: rotate(211deg);\n  -ms-transform: rotate(211deg);\n  -o-transform: rotate(211deg);\n  transform: rotate(211deg);\n}\n.wi-wind.towards-212-deg {\n  -webkit-transform: rotate(212deg);\n  -moz-transform: rotate(212deg);\n  -ms-transform: rotate(212deg);\n  -o-transform: rotate(212deg);\n  transform: rotate(212deg);\n}\n.wi-wind.towards-213-deg {\n  -webkit-transform: rotate(213deg);\n  -moz-transform: rotate(213deg);\n  -ms-transform: rotate(213deg);\n  -o-transform: rotate(213deg);\n  transform: rotate(213deg);\n}\n.wi-wind.towards-214-deg {\n  -webkit-transform: rotate(214deg);\n  -moz-transform: rotate(214deg);\n  -ms-transform: rotate(214deg);\n  -o-transform: rotate(214deg);\n  transform: rotate(214deg);\n}\n.wi-wind.towards-215-deg {\n  -webkit-transform: rotate(215deg);\n  -moz-transform: rotate(215deg);\n  -ms-transform: rotate(215deg);\n  -o-transform: rotate(215deg);\n  transform: rotate(215deg);\n}\n.wi-wind.towards-216-deg {\n  -webkit-transform: rotate(216deg);\n  -moz-transform: rotate(216deg);\n  -ms-transform: rotate(216deg);\n  -o-transform: rotate(216deg);\n  transform: rotate(216deg);\n}\n.wi-wind.towards-217-deg {\n  -webkit-transform: rotate(217deg);\n  -moz-transform: rotate(217deg);\n  -ms-transform: rotate(217deg);\n  -o-transform: rotate(217deg);\n  transform: rotate(217deg);\n}\n.wi-wind.towards-218-deg {\n  -webkit-transform: rotate(218deg);\n  -moz-transform: rotate(218deg);\n  -ms-transform: rotate(218deg);\n  -o-transform: rotate(218deg);\n  transform: rotate(218deg);\n}\n.wi-wind.towards-219-deg {\n  -webkit-transform: rotate(219deg);\n  -moz-transform: rotate(219deg);\n  -ms-transform: rotate(219deg);\n  -o-transform: rotate(219deg);\n  transform: rotate(219deg);\n}\n.wi-wind.towards-220-deg {\n  -webkit-transform: rotate(220deg);\n  -moz-transform: rotate(220deg);\n  -ms-transform: rotate(220deg);\n  -o-transform: rotate(220deg);\n  transform: rotate(220deg);\n}\n.wi-wind.towards-221-deg {\n  -webkit-transform: rotate(221deg);\n  -moz-transform: rotate(221deg);\n  -ms-transform: rotate(221deg);\n  -o-transform: rotate(221deg);\n  transform: rotate(221deg);\n}\n.wi-wind.towards-222-deg {\n  -webkit-transform: rotate(222deg);\n  -moz-transform: rotate(222deg);\n  -ms-transform: rotate(222deg);\n  -o-transform: rotate(222deg);\n  transform: rotate(222deg);\n}\n.wi-wind.towards-223-deg {\n  -webkit-transform: rotate(223deg);\n  -moz-transform: rotate(223deg);\n  -ms-transform: rotate(223deg);\n  -o-transform: rotate(223deg);\n  transform: rotate(223deg);\n}\n.wi-wind.towards-224-deg {\n  -webkit-transform: rotate(224deg);\n  -moz-transform: rotate(224deg);\n  -ms-transform: rotate(224deg);\n  -o-transform: rotate(224deg);\n  transform: rotate(224deg);\n}\n.wi-wind.towards-225-deg {\n  -webkit-transform: rotate(225deg);\n  -moz-transform: rotate(225deg);\n  -ms-transform: rotate(225deg);\n  -o-transform: rotate(225deg);\n  transform: rotate(225deg);\n}\n.wi-wind.towards-226-deg {\n  -webkit-transform: rotate(226deg);\n  -moz-transform: rotate(226deg);\n  -ms-transform: rotate(226deg);\n  -o-transform: rotate(226deg);\n  transform: rotate(226deg);\n}\n.wi-wind.towards-227-deg {\n  -webkit-transform: rotate(227deg);\n  -moz-transform: rotate(227deg);\n  -ms-transform: rotate(227deg);\n  -o-transform: rotate(227deg);\n  transform: rotate(227deg);\n}\n.wi-wind.towards-228-deg {\n  -webkit-transform: rotate(228deg);\n  -moz-transform: rotate(228deg);\n  -ms-transform: rotate(228deg);\n  -o-transform: rotate(228deg);\n  transform: rotate(228deg);\n}\n.wi-wind.towards-229-deg {\n  -webkit-transform: rotate(229deg);\n  -moz-transform: rotate(229deg);\n  -ms-transform: rotate(229deg);\n  -o-transform: rotate(229deg);\n  transform: rotate(229deg);\n}\n.wi-wind.towards-230-deg {\n  -webkit-transform: rotate(230deg);\n  -moz-transform: rotate(230deg);\n  -ms-transform: rotate(230deg);\n  -o-transform: rotate(230deg);\n  transform: rotate(230deg);\n}\n.wi-wind.towards-231-deg {\n  -webkit-transform: rotate(231deg);\n  -moz-transform: rotate(231deg);\n  -ms-transform: rotate(231deg);\n  -o-transform: rotate(231deg);\n  transform: rotate(231deg);\n}\n.wi-wind.towards-232-deg {\n  -webkit-transform: rotate(232deg);\n  -moz-transform: rotate(232deg);\n  -ms-transform: rotate(232deg);\n  -o-transform: rotate(232deg);\n  transform: rotate(232deg);\n}\n.wi-wind.towards-233-deg {\n  -webkit-transform: rotate(233deg);\n  -moz-transform: rotate(233deg);\n  -ms-transform: rotate(233deg);\n  -o-transform: rotate(233deg);\n  transform: rotate(233deg);\n}\n.wi-wind.towards-234-deg {\n  -webkit-transform: rotate(234deg);\n  -moz-transform: rotate(234deg);\n  -ms-transform: rotate(234deg);\n  -o-transform: rotate(234deg);\n  transform: rotate(234deg);\n}\n.wi-wind.towards-235-deg {\n  -webkit-transform: rotate(235deg);\n  -moz-transform: rotate(235deg);\n  -ms-transform: rotate(235deg);\n  -o-transform: rotate(235deg);\n  transform: rotate(235deg);\n}\n.wi-wind.towards-236-deg {\n  -webkit-transform: rotate(236deg);\n  -moz-transform: rotate(236deg);\n  -ms-transform: rotate(236deg);\n  -o-transform: rotate(236deg);\n  transform: rotate(236deg);\n}\n.wi-wind.towards-237-deg {\n  -webkit-transform: rotate(237deg);\n  -moz-transform: rotate(237deg);\n  -ms-transform: rotate(237deg);\n  -o-transform: rotate(237deg);\n  transform: rotate(237deg);\n}\n.wi-wind.towards-238-deg {\n  -webkit-transform: rotate(238deg);\n  -moz-transform: rotate(238deg);\n  -ms-transform: rotate(238deg);\n  -o-transform: rotate(238deg);\n  transform: rotate(238deg);\n}\n.wi-wind.towards-239-deg {\n  -webkit-transform: rotate(239deg);\n  -moz-transform: rotate(239deg);\n  -ms-transform: rotate(239deg);\n  -o-transform: rotate(239deg);\n  transform: rotate(239deg);\n}\n.wi-wind.towards-240-deg {\n  -webkit-transform: rotate(240deg);\n  -moz-transform: rotate(240deg);\n  -ms-transform: rotate(240deg);\n  -o-transform: rotate(240deg);\n  transform: rotate(240deg);\n}\n.wi-wind.towards-241-deg {\n  -webkit-transform: rotate(241deg);\n  -moz-transform: rotate(241deg);\n  -ms-transform: rotate(241deg);\n  -o-transform: rotate(241deg);\n  transform: rotate(241deg);\n}\n.wi-wind.towards-242-deg {\n  -webkit-transform: rotate(242deg);\n  -moz-transform: rotate(242deg);\n  -ms-transform: rotate(242deg);\n  -o-transform: rotate(242deg);\n  transform: rotate(242deg);\n}\n.wi-wind.towards-243-deg {\n  -webkit-transform: rotate(243deg);\n  -moz-transform: rotate(243deg);\n  -ms-transform: rotate(243deg);\n  -o-transform: rotate(243deg);\n  transform: rotate(243deg);\n}\n.wi-wind.towards-244-deg {\n  -webkit-transform: rotate(244deg);\n  -moz-transform: rotate(244deg);\n  -ms-transform: rotate(244deg);\n  -o-transform: rotate(244deg);\n  transform: rotate(244deg);\n}\n.wi-wind.towards-245-deg {\n  -webkit-transform: rotate(245deg);\n  -moz-transform: rotate(245deg);\n  -ms-transform: rotate(245deg);\n  -o-transform: rotate(245deg);\n  transform: rotate(245deg);\n}\n.wi-wind.towards-246-deg {\n  -webkit-transform: rotate(246deg);\n  -moz-transform: rotate(246deg);\n  -ms-transform: rotate(246deg);\n  -o-transform: rotate(246deg);\n  transform: rotate(246deg);\n}\n.wi-wind.towards-247-deg {\n  -webkit-transform: rotate(247deg);\n  -moz-transform: rotate(247deg);\n  -ms-transform: rotate(247deg);\n  -o-transform: rotate(247deg);\n  transform: rotate(247deg);\n}\n.wi-wind.towards-248-deg {\n  -webkit-transform: rotate(248deg);\n  -moz-transform: rotate(248deg);\n  -ms-transform: rotate(248deg);\n  -o-transform: rotate(248deg);\n  transform: rotate(248deg);\n}\n.wi-wind.towards-249-deg {\n  -webkit-transform: rotate(249deg);\n  -moz-transform: rotate(249deg);\n  -ms-transform: rotate(249deg);\n  -o-transform: rotate(249deg);\n  transform: rotate(249deg);\n}\n.wi-wind.towards-250-deg {\n  -webkit-transform: rotate(250deg);\n  -moz-transform: rotate(250deg);\n  -ms-transform: rotate(250deg);\n  -o-transform: rotate(250deg);\n  transform: rotate(250deg);\n}\n.wi-wind.towards-251-deg {\n  -webkit-transform: rotate(251deg);\n  -moz-transform: rotate(251deg);\n  -ms-transform: rotate(251deg);\n  -o-transform: rotate(251deg);\n  transform: rotate(251deg);\n}\n.wi-wind.towards-252-deg {\n  -webkit-transform: rotate(252deg);\n  -moz-transform: rotate(252deg);\n  -ms-transform: rotate(252deg);\n  -o-transform: rotate(252deg);\n  transform: rotate(252deg);\n}\n.wi-wind.towards-253-deg {\n  -webkit-transform: rotate(253deg);\n  -moz-transform: rotate(253deg);\n  -ms-transform: rotate(253deg);\n  -o-transform: rotate(253deg);\n  transform: rotate(253deg);\n}\n.wi-wind.towards-254-deg {\n  -webkit-transform: rotate(254deg);\n  -moz-transform: rotate(254deg);\n  -ms-transform: rotate(254deg);\n  -o-transform: rotate(254deg);\n  transform: rotate(254deg);\n}\n.wi-wind.towards-255-deg {\n  -webkit-transform: rotate(255deg);\n  -moz-transform: rotate(255deg);\n  -ms-transform: rotate(255deg);\n  -o-transform: rotate(255deg);\n  transform: rotate(255deg);\n}\n.wi-wind.towards-256-deg {\n  -webkit-transform: rotate(256deg);\n  -moz-transform: rotate(256deg);\n  -ms-transform: rotate(256deg);\n  -o-transform: rotate(256deg);\n  transform: rotate(256deg);\n}\n.wi-wind.towards-257-deg {\n  -webkit-transform: rotate(257deg);\n  -moz-transform: rotate(257deg);\n  -ms-transform: rotate(257deg);\n  -o-transform: rotate(257deg);\n  transform: rotate(257deg);\n}\n.wi-wind.towards-258-deg {\n  -webkit-transform: rotate(258deg);\n  -moz-transform: rotate(258deg);\n  -ms-transform: rotate(258deg);\n  -o-transform: rotate(258deg);\n  transform: rotate(258deg);\n}\n.wi-wind.towards-259-deg {\n  -webkit-transform: rotate(259deg);\n  -moz-transform: rotate(259deg);\n  -ms-transform: rotate(259deg);\n  -o-transform: rotate(259deg);\n  transform: rotate(259deg);\n}\n.wi-wind.towards-260-deg {\n  -webkit-transform: rotate(260deg);\n  -moz-transform: rotate(260deg);\n  -ms-transform: rotate(260deg);\n  -o-transform: rotate(260deg);\n  transform: rotate(260deg);\n}\n.wi-wind.towards-261-deg {\n  -webkit-transform: rotate(261deg);\n  -moz-transform: rotate(261deg);\n  -ms-transform: rotate(261deg);\n  -o-transform: rotate(261deg);\n  transform: rotate(261deg);\n}\n.wi-wind.towards-262-deg {\n  -webkit-transform: rotate(262deg);\n  -moz-transform: rotate(262deg);\n  -ms-transform: rotate(262deg);\n  -o-transform: rotate(262deg);\n  transform: rotate(262deg);\n}\n.wi-wind.towards-263-deg {\n  -webkit-transform: rotate(263deg);\n  -moz-transform: rotate(263deg);\n  -ms-transform: rotate(263deg);\n  -o-transform: rotate(263deg);\n  transform: rotate(263deg);\n}\n.wi-wind.towards-264-deg {\n  -webkit-transform: rotate(264deg);\n  -moz-transform: rotate(264deg);\n  -ms-transform: rotate(264deg);\n  -o-transform: rotate(264deg);\n  transform: rotate(264deg);\n}\n.wi-wind.towards-265-deg {\n  -webkit-transform: rotate(265deg);\n  -moz-transform: rotate(265deg);\n  -ms-transform: rotate(265deg);\n  -o-transform: rotate(265deg);\n  transform: rotate(265deg);\n}\n.wi-wind.towards-266-deg {\n  -webkit-transform: rotate(266deg);\n  -moz-transform: rotate(266deg);\n  -ms-transform: rotate(266deg);\n  -o-transform: rotate(266deg);\n  transform: rotate(266deg);\n}\n.wi-wind.towards-267-deg {\n  -webkit-transform: rotate(267deg);\n  -moz-transform: rotate(267deg);\n  -ms-transform: rotate(267deg);\n  -o-transform: rotate(267deg);\n  transform: rotate(267deg);\n}\n.wi-wind.towards-268-deg {\n  -webkit-transform: rotate(268deg);\n  -moz-transform: rotate(268deg);\n  -ms-transform: rotate(268deg);\n  -o-transform: rotate(268deg);\n  transform: rotate(268deg);\n}\n.wi-wind.towards-269-deg {\n  -webkit-transform: rotate(269deg);\n  -moz-transform: rotate(269deg);\n  -ms-transform: rotate(269deg);\n  -o-transform: rotate(269deg);\n  transform: rotate(269deg);\n}\n.wi-wind.towards-270-deg {\n  -webkit-transform: rotate(270deg);\n  -moz-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  -o-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-wind.towards-271-deg {\n  -webkit-transform: rotate(271deg);\n  -moz-transform: rotate(271deg);\n  -ms-transform: rotate(271deg);\n  -o-transform: rotate(271deg);\n  transform: rotate(271deg);\n}\n.wi-wind.towards-272-deg {\n  -webkit-transform: rotate(272deg);\n  -moz-transform: rotate(272deg);\n  -ms-transform: rotate(272deg);\n  -o-transform: rotate(272deg);\n  transform: rotate(272deg);\n}\n.wi-wind.towards-273-deg {\n  -webkit-transform: rotate(273deg);\n  -moz-transform: rotate(273deg);\n  -ms-transform: rotate(273deg);\n  -o-transform: rotate(273deg);\n  transform: rotate(273deg);\n}\n.wi-wind.towards-274-deg {\n  -webkit-transform: rotate(274deg);\n  -moz-transform: rotate(274deg);\n  -ms-transform: rotate(274deg);\n  -o-transform: rotate(274deg);\n  transform: rotate(274deg);\n}\n.wi-wind.towards-275-deg {\n  -webkit-transform: rotate(275deg);\n  -moz-transform: rotate(275deg);\n  -ms-transform: rotate(275deg);\n  -o-transform: rotate(275deg);\n  transform: rotate(275deg);\n}\n.wi-wind.towards-276-deg {\n  -webkit-transform: rotate(276deg);\n  -moz-transform: rotate(276deg);\n  -ms-transform: rotate(276deg);\n  -o-transform: rotate(276deg);\n  transform: rotate(276deg);\n}\n.wi-wind.towards-277-deg {\n  -webkit-transform: rotate(277deg);\n  -moz-transform: rotate(277deg);\n  -ms-transform: rotate(277deg);\n  -o-transform: rotate(277deg);\n  transform: rotate(277deg);\n}\n.wi-wind.towards-278-deg {\n  -webkit-transform: rotate(278deg);\n  -moz-transform: rotate(278deg);\n  -ms-transform: rotate(278deg);\n  -o-transform: rotate(278deg);\n  transform: rotate(278deg);\n}\n.wi-wind.towards-279-deg {\n  -webkit-transform: rotate(279deg);\n  -moz-transform: rotate(279deg);\n  -ms-transform: rotate(279deg);\n  -o-transform: rotate(279deg);\n  transform: rotate(279deg);\n}\n.wi-wind.towards-280-deg {\n  -webkit-transform: rotate(280deg);\n  -moz-transform: rotate(280deg);\n  -ms-transform: rotate(280deg);\n  -o-transform: rotate(280deg);\n  transform: rotate(280deg);\n}\n.wi-wind.towards-281-deg {\n  -webkit-transform: rotate(281deg);\n  -moz-transform: rotate(281deg);\n  -ms-transform: rotate(281deg);\n  -o-transform: rotate(281deg);\n  transform: rotate(281deg);\n}\n.wi-wind.towards-282-deg {\n  -webkit-transform: rotate(282deg);\n  -moz-transform: rotate(282deg);\n  -ms-transform: rotate(282deg);\n  -o-transform: rotate(282deg);\n  transform: rotate(282deg);\n}\n.wi-wind.towards-283-deg {\n  -webkit-transform: rotate(283deg);\n  -moz-transform: rotate(283deg);\n  -ms-transform: rotate(283deg);\n  -o-transform: rotate(283deg);\n  transform: rotate(283deg);\n}\n.wi-wind.towards-284-deg {\n  -webkit-transform: rotate(284deg);\n  -moz-transform: rotate(284deg);\n  -ms-transform: rotate(284deg);\n  -o-transform: rotate(284deg);\n  transform: rotate(284deg);\n}\n.wi-wind.towards-285-deg {\n  -webkit-transform: rotate(285deg);\n  -moz-transform: rotate(285deg);\n  -ms-transform: rotate(285deg);\n  -o-transform: rotate(285deg);\n  transform: rotate(285deg);\n}\n.wi-wind.towards-286-deg {\n  -webkit-transform: rotate(286deg);\n  -moz-transform: rotate(286deg);\n  -ms-transform: rotate(286deg);\n  -o-transform: rotate(286deg);\n  transform: rotate(286deg);\n}\n.wi-wind.towards-287-deg {\n  -webkit-transform: rotate(287deg);\n  -moz-transform: rotate(287deg);\n  -ms-transform: rotate(287deg);\n  -o-transform: rotate(287deg);\n  transform: rotate(287deg);\n}\n.wi-wind.towards-288-deg {\n  -webkit-transform: rotate(288deg);\n  -moz-transform: rotate(288deg);\n  -ms-transform: rotate(288deg);\n  -o-transform: rotate(288deg);\n  transform: rotate(288deg);\n}\n.wi-wind.towards-289-deg {\n  -webkit-transform: rotate(289deg);\n  -moz-transform: rotate(289deg);\n  -ms-transform: rotate(289deg);\n  -o-transform: rotate(289deg);\n  transform: rotate(289deg);\n}\n.wi-wind.towards-290-deg {\n  -webkit-transform: rotate(290deg);\n  -moz-transform: rotate(290deg);\n  -ms-transform: rotate(290deg);\n  -o-transform: rotate(290deg);\n  transform: rotate(290deg);\n}\n.wi-wind.towards-291-deg {\n  -webkit-transform: rotate(291deg);\n  -moz-transform: rotate(291deg);\n  -ms-transform: rotate(291deg);\n  -o-transform: rotate(291deg);\n  transform: rotate(291deg);\n}\n.wi-wind.towards-292-deg {\n  -webkit-transform: rotate(292deg);\n  -moz-transform: rotate(292deg);\n  -ms-transform: rotate(292deg);\n  -o-transform: rotate(292deg);\n  transform: rotate(292deg);\n}\n.wi-wind.towards-293-deg {\n  -webkit-transform: rotate(293deg);\n  -moz-transform: rotate(293deg);\n  -ms-transform: rotate(293deg);\n  -o-transform: rotate(293deg);\n  transform: rotate(293deg);\n}\n.wi-wind.towards-294-deg {\n  -webkit-transform: rotate(294deg);\n  -moz-transform: rotate(294deg);\n  -ms-transform: rotate(294deg);\n  -o-transform: rotate(294deg);\n  transform: rotate(294deg);\n}\n.wi-wind.towards-295-deg {\n  -webkit-transform: rotate(295deg);\n  -moz-transform: rotate(295deg);\n  -ms-transform: rotate(295deg);\n  -o-transform: rotate(295deg);\n  transform: rotate(295deg);\n}\n.wi-wind.towards-296-deg {\n  -webkit-transform: rotate(296deg);\n  -moz-transform: rotate(296deg);\n  -ms-transform: rotate(296deg);\n  -o-transform: rotate(296deg);\n  transform: rotate(296deg);\n}\n.wi-wind.towards-297-deg {\n  -webkit-transform: rotate(297deg);\n  -moz-transform: rotate(297deg);\n  -ms-transform: rotate(297deg);\n  -o-transform: rotate(297deg);\n  transform: rotate(297deg);\n}\n.wi-wind.towards-298-deg {\n  -webkit-transform: rotate(298deg);\n  -moz-transform: rotate(298deg);\n  -ms-transform: rotate(298deg);\n  -o-transform: rotate(298deg);\n  transform: rotate(298deg);\n}\n.wi-wind.towards-299-deg {\n  -webkit-transform: rotate(299deg);\n  -moz-transform: rotate(299deg);\n  -ms-transform: rotate(299deg);\n  -o-transform: rotate(299deg);\n  transform: rotate(299deg);\n}\n.wi-wind.towards-300-deg {\n  -webkit-transform: rotate(300deg);\n  -moz-transform: rotate(300deg);\n  -ms-transform: rotate(300deg);\n  -o-transform: rotate(300deg);\n  transform: rotate(300deg);\n}\n.wi-wind.towards-301-deg {\n  -webkit-transform: rotate(301deg);\n  -moz-transform: rotate(301deg);\n  -ms-transform: rotate(301deg);\n  -o-transform: rotate(301deg);\n  transform: rotate(301deg);\n}\n.wi-wind.towards-302-deg {\n  -webkit-transform: rotate(302deg);\n  -moz-transform: rotate(302deg);\n  -ms-transform: rotate(302deg);\n  -o-transform: rotate(302deg);\n  transform: rotate(302deg);\n}\n.wi-wind.towards-303-deg {\n  -webkit-transform: rotate(303deg);\n  -moz-transform: rotate(303deg);\n  -ms-transform: rotate(303deg);\n  -o-transform: rotate(303deg);\n  transform: rotate(303deg);\n}\n.wi-wind.towards-304-deg {\n  -webkit-transform: rotate(304deg);\n  -moz-transform: rotate(304deg);\n  -ms-transform: rotate(304deg);\n  -o-transform: rotate(304deg);\n  transform: rotate(304deg);\n}\n.wi-wind.towards-305-deg {\n  -webkit-transform: rotate(305deg);\n  -moz-transform: rotate(305deg);\n  -ms-transform: rotate(305deg);\n  -o-transform: rotate(305deg);\n  transform: rotate(305deg);\n}\n.wi-wind.towards-306-deg {\n  -webkit-transform: rotate(306deg);\n  -moz-transform: rotate(306deg);\n  -ms-transform: rotate(306deg);\n  -o-transform: rotate(306deg);\n  transform: rotate(306deg);\n}\n.wi-wind.towards-307-deg {\n  -webkit-transform: rotate(307deg);\n  -moz-transform: rotate(307deg);\n  -ms-transform: rotate(307deg);\n  -o-transform: rotate(307deg);\n  transform: rotate(307deg);\n}\n.wi-wind.towards-308-deg {\n  -webkit-transform: rotate(308deg);\n  -moz-transform: rotate(308deg);\n  -ms-transform: rotate(308deg);\n  -o-transform: rotate(308deg);\n  transform: rotate(308deg);\n}\n.wi-wind.towards-309-deg {\n  -webkit-transform: rotate(309deg);\n  -moz-transform: rotate(309deg);\n  -ms-transform: rotate(309deg);\n  -o-transform: rotate(309deg);\n  transform: rotate(309deg);\n}\n.wi-wind.towards-310-deg {\n  -webkit-transform: rotate(310deg);\n  -moz-transform: rotate(310deg);\n  -ms-transform: rotate(310deg);\n  -o-transform: rotate(310deg);\n  transform: rotate(310deg);\n}\n.wi-wind.towards-311-deg {\n  -webkit-transform: rotate(311deg);\n  -moz-transform: rotate(311deg);\n  -ms-transform: rotate(311deg);\n  -o-transform: rotate(311deg);\n  transform: rotate(311deg);\n}\n.wi-wind.towards-312-deg {\n  -webkit-transform: rotate(312deg);\n  -moz-transform: rotate(312deg);\n  -ms-transform: rotate(312deg);\n  -o-transform: rotate(312deg);\n  transform: rotate(312deg);\n}\n.wi-wind.towards-313-deg {\n  -webkit-transform: rotate(313deg);\n  -moz-transform: rotate(313deg);\n  -ms-transform: rotate(313deg);\n  -o-transform: rotate(313deg);\n  transform: rotate(313deg);\n}\n.wi-wind.towards-314-deg {\n  -webkit-transform: rotate(314deg);\n  -moz-transform: rotate(314deg);\n  -ms-transform: rotate(314deg);\n  -o-transform: rotate(314deg);\n  transform: rotate(314deg);\n}\n.wi-wind.towards-315-deg {\n  -webkit-transform: rotate(315deg);\n  -moz-transform: rotate(315deg);\n  -ms-transform: rotate(315deg);\n  -o-transform: rotate(315deg);\n  transform: rotate(315deg);\n}\n.wi-wind.towards-316-deg {\n  -webkit-transform: rotate(316deg);\n  -moz-transform: rotate(316deg);\n  -ms-transform: rotate(316deg);\n  -o-transform: rotate(316deg);\n  transform: rotate(316deg);\n}\n.wi-wind.towards-317-deg {\n  -webkit-transform: rotate(317deg);\n  -moz-transform: rotate(317deg);\n  -ms-transform: rotate(317deg);\n  -o-transform: rotate(317deg);\n  transform: rotate(317deg);\n}\n.wi-wind.towards-318-deg {\n  -webkit-transform: rotate(318deg);\n  -moz-transform: rotate(318deg);\n  -ms-transform: rotate(318deg);\n  -o-transform: rotate(318deg);\n  transform: rotate(318deg);\n}\n.wi-wind.towards-319-deg {\n  -webkit-transform: rotate(319deg);\n  -moz-transform: rotate(319deg);\n  -ms-transform: rotate(319deg);\n  -o-transform: rotate(319deg);\n  transform: rotate(319deg);\n}\n.wi-wind.towards-320-deg {\n  -webkit-transform: rotate(320deg);\n  -moz-transform: rotate(320deg);\n  -ms-transform: rotate(320deg);\n  -o-transform: rotate(320deg);\n  transform: rotate(320deg);\n}\n.wi-wind.towards-321-deg {\n  -webkit-transform: rotate(321deg);\n  -moz-transform: rotate(321deg);\n  -ms-transform: rotate(321deg);\n  -o-transform: rotate(321deg);\n  transform: rotate(321deg);\n}\n.wi-wind.towards-322-deg {\n  -webkit-transform: rotate(322deg);\n  -moz-transform: rotate(322deg);\n  -ms-transform: rotate(322deg);\n  -o-transform: rotate(322deg);\n  transform: rotate(322deg);\n}\n.wi-wind.towards-323-deg {\n  -webkit-transform: rotate(323deg);\n  -moz-transform: rotate(323deg);\n  -ms-transform: rotate(323deg);\n  -o-transform: rotate(323deg);\n  transform: rotate(323deg);\n}\n.wi-wind.towards-324-deg {\n  -webkit-transform: rotate(324deg);\n  -moz-transform: rotate(324deg);\n  -ms-transform: rotate(324deg);\n  -o-transform: rotate(324deg);\n  transform: rotate(324deg);\n}\n.wi-wind.towards-325-deg {\n  -webkit-transform: rotate(325deg);\n  -moz-transform: rotate(325deg);\n  -ms-transform: rotate(325deg);\n  -o-transform: rotate(325deg);\n  transform: rotate(325deg);\n}\n.wi-wind.towards-326-deg {\n  -webkit-transform: rotate(326deg);\n  -moz-transform: rotate(326deg);\n  -ms-transform: rotate(326deg);\n  -o-transform: rotate(326deg);\n  transform: rotate(326deg);\n}\n.wi-wind.towards-327-deg {\n  -webkit-transform: rotate(327deg);\n  -moz-transform: rotate(327deg);\n  -ms-transform: rotate(327deg);\n  -o-transform: rotate(327deg);\n  transform: rotate(327deg);\n}\n.wi-wind.towards-328-deg {\n  -webkit-transform: rotate(328deg);\n  -moz-transform: rotate(328deg);\n  -ms-transform: rotate(328deg);\n  -o-transform: rotate(328deg);\n  transform: rotate(328deg);\n}\n.wi-wind.towards-329-deg {\n  -webkit-transform: rotate(329deg);\n  -moz-transform: rotate(329deg);\n  -ms-transform: rotate(329deg);\n  -o-transform: rotate(329deg);\n  transform: rotate(329deg);\n}\n.wi-wind.towards-330-deg {\n  -webkit-transform: rotate(330deg);\n  -moz-transform: rotate(330deg);\n  -ms-transform: rotate(330deg);\n  -o-transform: rotate(330deg);\n  transform: rotate(330deg);\n}\n.wi-wind.towards-331-deg {\n  -webkit-transform: rotate(331deg);\n  -moz-transform: rotate(331deg);\n  -ms-transform: rotate(331deg);\n  -o-transform: rotate(331deg);\n  transform: rotate(331deg);\n}\n.wi-wind.towards-332-deg {\n  -webkit-transform: rotate(332deg);\n  -moz-transform: rotate(332deg);\n  -ms-transform: rotate(332deg);\n  -o-transform: rotate(332deg);\n  transform: rotate(332deg);\n}\n.wi-wind.towards-333-deg {\n  -webkit-transform: rotate(333deg);\n  -moz-transform: rotate(333deg);\n  -ms-transform: rotate(333deg);\n  -o-transform: rotate(333deg);\n  transform: rotate(333deg);\n}\n.wi-wind.towards-334-deg {\n  -webkit-transform: rotate(334deg);\n  -moz-transform: rotate(334deg);\n  -ms-transform: rotate(334deg);\n  -o-transform: rotate(334deg);\n  transform: rotate(334deg);\n}\n.wi-wind.towards-335-deg {\n  -webkit-transform: rotate(335deg);\n  -moz-transform: rotate(335deg);\n  -ms-transform: rotate(335deg);\n  -o-transform: rotate(335deg);\n  transform: rotate(335deg);\n}\n.wi-wind.towards-336-deg {\n  -webkit-transform: rotate(336deg);\n  -moz-transform: rotate(336deg);\n  -ms-transform: rotate(336deg);\n  -o-transform: rotate(336deg);\n  transform: rotate(336deg);\n}\n.wi-wind.towards-337-deg {\n  -webkit-transform: rotate(337deg);\n  -moz-transform: rotate(337deg);\n  -ms-transform: rotate(337deg);\n  -o-transform: rotate(337deg);\n  transform: rotate(337deg);\n}\n.wi-wind.towards-338-deg {\n  -webkit-transform: rotate(338deg);\n  -moz-transform: rotate(338deg);\n  -ms-transform: rotate(338deg);\n  -o-transform: rotate(338deg);\n  transform: rotate(338deg);\n}\n.wi-wind.towards-339-deg {\n  -webkit-transform: rotate(339deg);\n  -moz-transform: rotate(339deg);\n  -ms-transform: rotate(339deg);\n  -o-transform: rotate(339deg);\n  transform: rotate(339deg);\n}\n.wi-wind.towards-340-deg {\n  -webkit-transform: rotate(340deg);\n  -moz-transform: rotate(340deg);\n  -ms-transform: rotate(340deg);\n  -o-transform: rotate(340deg);\n  transform: rotate(340deg);\n}\n.wi-wind.towards-341-deg {\n  -webkit-transform: rotate(341deg);\n  -moz-transform: rotate(341deg);\n  -ms-transform: rotate(341deg);\n  -o-transform: rotate(341deg);\n  transform: rotate(341deg);\n}\n.wi-wind.towards-342-deg {\n  -webkit-transform: rotate(342deg);\n  -moz-transform: rotate(342deg);\n  -ms-transform: rotate(342deg);\n  -o-transform: rotate(342deg);\n  transform: rotate(342deg);\n}\n.wi-wind.towards-343-deg {\n  -webkit-transform: rotate(343deg);\n  -moz-transform: rotate(343deg);\n  -ms-transform: rotate(343deg);\n  -o-transform: rotate(343deg);\n  transform: rotate(343deg);\n}\n.wi-wind.towards-344-deg {\n  -webkit-transform: rotate(344deg);\n  -moz-transform: rotate(344deg);\n  -ms-transform: rotate(344deg);\n  -o-transform: rotate(344deg);\n  transform: rotate(344deg);\n}\n.wi-wind.towards-345-deg {\n  -webkit-transform: rotate(345deg);\n  -moz-transform: rotate(345deg);\n  -ms-transform: rotate(345deg);\n  -o-transform: rotate(345deg);\n  transform: rotate(345deg);\n}\n.wi-wind.towards-346-deg {\n  -webkit-transform: rotate(346deg);\n  -moz-transform: rotate(346deg);\n  -ms-transform: rotate(346deg);\n  -o-transform: rotate(346deg);\n  transform: rotate(346deg);\n}\n.wi-wind.towards-347-deg {\n  -webkit-transform: rotate(347deg);\n  -moz-transform: rotate(347deg);\n  -ms-transform: rotate(347deg);\n  -o-transform: rotate(347deg);\n  transform: rotate(347deg);\n}\n.wi-wind.towards-348-deg {\n  -webkit-transform: rotate(348deg);\n  -moz-transform: rotate(348deg);\n  -ms-transform: rotate(348deg);\n  -o-transform: rotate(348deg);\n  transform: rotate(348deg);\n}\n.wi-wind.towards-349-deg {\n  -webkit-transform: rotate(349deg);\n  -moz-transform: rotate(349deg);\n  -ms-transform: rotate(349deg);\n  -o-transform: rotate(349deg);\n  transform: rotate(349deg);\n}\n.wi-wind.towards-350-deg {\n  -webkit-transform: rotate(350deg);\n  -moz-transform: rotate(350deg);\n  -ms-transform: rotate(350deg);\n  -o-transform: rotate(350deg);\n  transform: rotate(350deg);\n}\n.wi-wind.towards-351-deg {\n  -webkit-transform: rotate(351deg);\n  -moz-transform: rotate(351deg);\n  -ms-transform: rotate(351deg);\n  -o-transform: rotate(351deg);\n  transform: rotate(351deg);\n}\n.wi-wind.towards-352-deg {\n  -webkit-transform: rotate(352deg);\n  -moz-transform: rotate(352deg);\n  -ms-transform: rotate(352deg);\n  -o-transform: rotate(352deg);\n  transform: rotate(352deg);\n}\n.wi-wind.towards-353-deg {\n  -webkit-transform: rotate(353deg);\n  -moz-transform: rotate(353deg);\n  -ms-transform: rotate(353deg);\n  -o-transform: rotate(353deg);\n  transform: rotate(353deg);\n}\n.wi-wind.towards-354-deg {\n  -webkit-transform: rotate(354deg);\n  -moz-transform: rotate(354deg);\n  -ms-transform: rotate(354deg);\n  -o-transform: rotate(354deg);\n  transform: rotate(354deg);\n}\n.wi-wind.towards-355-deg {\n  -webkit-transform: rotate(355deg);\n  -moz-transform: rotate(355deg);\n  -ms-transform: rotate(355deg);\n  -o-transform: rotate(355deg);\n  transform: rotate(355deg);\n}\n.wi-wind.towards-356-deg {\n  -webkit-transform: rotate(356deg);\n  -moz-transform: rotate(356deg);\n  -ms-transform: rotate(356deg);\n  -o-transform: rotate(356deg);\n  transform: rotate(356deg);\n}\n.wi-wind.towards-357-deg {\n  -webkit-transform: rotate(357deg);\n  -moz-transform: rotate(357deg);\n  -ms-transform: rotate(357deg);\n  -o-transform: rotate(357deg);\n  transform: rotate(357deg);\n}\n.wi-wind.towards-358-deg {\n  -webkit-transform: rotate(358deg);\n  -moz-transform: rotate(358deg);\n  -ms-transform: rotate(358deg);\n  -o-transform: rotate(358deg);\n  transform: rotate(358deg);\n}\n.wi-wind.towards-359-deg {\n  -webkit-transform: rotate(359deg);\n  -moz-transform: rotate(359deg);\n  -ms-transform: rotate(359deg);\n  -o-transform: rotate(359deg);\n  transform: rotate(359deg);\n}\n.wi-wind.towards-360-deg {\n  -webkit-transform: rotate(0deg);\n  -moz-transform: rotate(0deg);\n  -ms-transform: rotate(0deg);\n  -o-transform: rotate(0deg);\n  transform: rotate(0deg);\n}\n.wi-wind.from-0-deg {\n  -webkit-transform: rotate(180deg);\n  -moz-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  -o-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-wind.from-1-deg {\n  -webkit-transform: rotate(181deg);\n  -moz-transform: rotate(181deg);\n  -ms-transform: rotate(181deg);\n  -o-transform: rotate(181deg);\n  transform: rotate(181deg);\n}\n.wi-wind.from-2-deg {\n  -webkit-transform: rotate(182deg);\n  -moz-transform: rotate(182deg);\n  -ms-transform: rotate(182deg);\n  -o-transform: rotate(182deg);\n  transform: rotate(182deg);\n}\n.wi-wind.from-3-deg {\n  -webkit-transform: rotate(183deg);\n  -moz-transform: rotate(183deg);\n  -ms-transform: rotate(183deg);\n  -o-transform: rotate(183deg);\n  transform: rotate(183deg);\n}\n.wi-wind.from-4-deg {\n  -webkit-transform: rotate(184deg);\n  -moz-transform: rotate(184deg);\n  -ms-transform: rotate(184deg);\n  -o-transform: rotate(184deg);\n  transform: rotate(184deg);\n}\n.wi-wind.from-5-deg {\n  -webkit-transform: rotate(185deg);\n  -moz-transform: rotate(185deg);\n  -ms-transform: rotate(185deg);\n  -o-transform: rotate(185deg);\n  transform: rotate(185deg);\n}\n.wi-wind.from-6-deg {\n  -webkit-transform: rotate(186deg);\n  -moz-transform: rotate(186deg);\n  -ms-transform: rotate(186deg);\n  -o-transform: rotate(186deg);\n  transform: rotate(186deg);\n}\n.wi-wind.from-7-deg {\n  -webkit-transform: rotate(187deg);\n  -moz-transform: rotate(187deg);\n  -ms-transform: rotate(187deg);\n  -o-transform: rotate(187deg);\n  transform: rotate(187deg);\n}\n.wi-wind.from-8-deg {\n  -webkit-transform: rotate(188deg);\n  -moz-transform: rotate(188deg);\n  -ms-transform: rotate(188deg);\n  -o-transform: rotate(188deg);\n  transform: rotate(188deg);\n}\n.wi-wind.from-9-deg {\n  -webkit-transform: rotate(189deg);\n  -moz-transform: rotate(189deg);\n  -ms-transform: rotate(189deg);\n  -o-transform: rotate(189deg);\n  transform: rotate(189deg);\n}\n.wi-wind.from-10-deg {\n  -webkit-transform: rotate(190deg);\n  -moz-transform: rotate(190deg);\n  -ms-transform: rotate(190deg);\n  -o-transform: rotate(190deg);\n  transform: rotate(190deg);\n}\n.wi-wind.from-11-deg {\n  -webkit-transform: rotate(191deg);\n  -moz-transform: rotate(191deg);\n  -ms-transform: rotate(191deg);\n  -o-transform: rotate(191deg);\n  transform: rotate(191deg);\n}\n.wi-wind.from-12-deg {\n  -webkit-transform: rotate(192deg);\n  -moz-transform: rotate(192deg);\n  -ms-transform: rotate(192deg);\n  -o-transform: rotate(192deg);\n  transform: rotate(192deg);\n}\n.wi-wind.from-13-deg {\n  -webkit-transform: rotate(193deg);\n  -moz-transform: rotate(193deg);\n  -ms-transform: rotate(193deg);\n  -o-transform: rotate(193deg);\n  transform: rotate(193deg);\n}\n.wi-wind.from-14-deg {\n  -webkit-transform: rotate(194deg);\n  -moz-transform: rotate(194deg);\n  -ms-transform: rotate(194deg);\n  -o-transform: rotate(194deg);\n  transform: rotate(194deg);\n}\n.wi-wind.from-15-deg {\n  -webkit-transform: rotate(195deg);\n  -moz-transform: rotate(195deg);\n  -ms-transform: rotate(195deg);\n  -o-transform: rotate(195deg);\n  transform: rotate(195deg);\n}\n.wi-wind.from-16-deg {\n  -webkit-transform: rotate(196deg);\n  -moz-transform: rotate(196deg);\n  -ms-transform: rotate(196deg);\n  -o-transform: rotate(196deg);\n  transform: rotate(196deg);\n}\n.wi-wind.from-17-deg {\n  -webkit-transform: rotate(197deg);\n  -moz-transform: rotate(197deg);\n  -ms-transform: rotate(197deg);\n  -o-transform: rotate(197deg);\n  transform: rotate(197deg);\n}\n.wi-wind.from-18-deg {\n  -webkit-transform: rotate(198deg);\n  -moz-transform: rotate(198deg);\n  -ms-transform: rotate(198deg);\n  -o-transform: rotate(198deg);\n  transform: rotate(198deg);\n}\n.wi-wind.from-19-deg {\n  -webkit-transform: rotate(199deg);\n  -moz-transform: rotate(199deg);\n  -ms-transform: rotate(199deg);\n  -o-transform: rotate(199deg);\n  transform: rotate(199deg);\n}\n.wi-wind.from-20-deg {\n  -webkit-transform: rotate(200deg);\n  -moz-transform: rotate(200deg);\n  -ms-transform: rotate(200deg);\n  -o-transform: rotate(200deg);\n  transform: rotate(200deg);\n}\n.wi-wind.from-21-deg {\n  -webkit-transform: rotate(201deg);\n  -moz-transform: rotate(201deg);\n  -ms-transform: rotate(201deg);\n  -o-transform: rotate(201deg);\n  transform: rotate(201deg);\n}\n.wi-wind.from-22-deg {\n  -webkit-transform: rotate(202deg);\n  -moz-transform: rotate(202deg);\n  -ms-transform: rotate(202deg);\n  -o-transform: rotate(202deg);\n  transform: rotate(202deg);\n}\n.wi-wind.from-23-deg {\n  -webkit-transform: rotate(203deg);\n  -moz-transform: rotate(203deg);\n  -ms-transform: rotate(203deg);\n  -o-transform: rotate(203deg);\n  transform: rotate(203deg);\n}\n.wi-wind.from-24-deg {\n  -webkit-transform: rotate(204deg);\n  -moz-transform: rotate(204deg);\n  -ms-transform: rotate(204deg);\n  -o-transform: rotate(204deg);\n  transform: rotate(204deg);\n}\n.wi-wind.from-25-deg {\n  -webkit-transform: rotate(205deg);\n  -moz-transform: rotate(205deg);\n  -ms-transform: rotate(205deg);\n  -o-transform: rotate(205deg);\n  transform: rotate(205deg);\n}\n.wi-wind.from-26-deg {\n  -webkit-transform: rotate(206deg);\n  -moz-transform: rotate(206deg);\n  -ms-transform: rotate(206deg);\n  -o-transform: rotate(206deg);\n  transform: rotate(206deg);\n}\n.wi-wind.from-27-deg {\n  -webkit-transform: rotate(207deg);\n  -moz-transform: rotate(207deg);\n  -ms-transform: rotate(207deg);\n  -o-transform: rotate(207deg);\n  transform: rotate(207deg);\n}\n.wi-wind.from-28-deg {\n  -webkit-transform: rotate(208deg);\n  -moz-transform: rotate(208deg);\n  -ms-transform: rotate(208deg);\n  -o-transform: rotate(208deg);\n  transform: rotate(208deg);\n}\n.wi-wind.from-29-deg {\n  -webkit-transform: rotate(209deg);\n  -moz-transform: rotate(209deg);\n  -ms-transform: rotate(209deg);\n  -o-transform: rotate(209deg);\n  transform: rotate(209deg);\n}\n.wi-wind.from-30-deg {\n  -webkit-transform: rotate(210deg);\n  -moz-transform: rotate(210deg);\n  -ms-transform: rotate(210deg);\n  -o-transform: rotate(210deg);\n  transform: rotate(210deg);\n}\n.wi-wind.from-31-deg {\n  -webkit-transform: rotate(211deg);\n  -moz-transform: rotate(211deg);\n  -ms-transform: rotate(211deg);\n  -o-transform: rotate(211deg);\n  transform: rotate(211deg);\n}\n.wi-wind.from-32-deg {\n  -webkit-transform: rotate(212deg);\n  -moz-transform: rotate(212deg);\n  -ms-transform: rotate(212deg);\n  -o-transform: rotate(212deg);\n  transform: rotate(212deg);\n}\n.wi-wind.from-33-deg {\n  -webkit-transform: rotate(213deg);\n  -moz-transform: rotate(213deg);\n  -ms-transform: rotate(213deg);\n  -o-transform: rotate(213deg);\n  transform: rotate(213deg);\n}\n.wi-wind.from-34-deg {\n  -webkit-transform: rotate(214deg);\n  -moz-transform: rotate(214deg);\n  -ms-transform: rotate(214deg);\n  -o-transform: rotate(214deg);\n  transform: rotate(214deg);\n}\n.wi-wind.from-35-deg {\n  -webkit-transform: rotate(215deg);\n  -moz-transform: rotate(215deg);\n  -ms-transform: rotate(215deg);\n  -o-transform: rotate(215deg);\n  transform: rotate(215deg);\n}\n.wi-wind.from-36-deg {\n  -webkit-transform: rotate(216deg);\n  -moz-transform: rotate(216deg);\n  -ms-transform: rotate(216deg);\n  -o-transform: rotate(216deg);\n  transform: rotate(216deg);\n}\n.wi-wind.from-37-deg {\n  -webkit-transform: rotate(217deg);\n  -moz-transform: rotate(217deg);\n  -ms-transform: rotate(217deg);\n  -o-transform: rotate(217deg);\n  transform: rotate(217deg);\n}\n.wi-wind.from-38-deg {\n  -webkit-transform: rotate(218deg);\n  -moz-transform: rotate(218deg);\n  -ms-transform: rotate(218deg);\n  -o-transform: rotate(218deg);\n  transform: rotate(218deg);\n}\n.wi-wind.from-39-deg {\n  -webkit-transform: rotate(219deg);\n  -moz-transform: rotate(219deg);\n  -ms-transform: rotate(219deg);\n  -o-transform: rotate(219deg);\n  transform: rotate(219deg);\n}\n.wi-wind.from-40-deg {\n  -webkit-transform: rotate(220deg);\n  -moz-transform: rotate(220deg);\n  -ms-transform: rotate(220deg);\n  -o-transform: rotate(220deg);\n  transform: rotate(220deg);\n}\n.wi-wind.from-41-deg {\n  -webkit-transform: rotate(221deg);\n  -moz-transform: rotate(221deg);\n  -ms-transform: rotate(221deg);\n  -o-transform: rotate(221deg);\n  transform: rotate(221deg);\n}\n.wi-wind.from-42-deg {\n  -webkit-transform: rotate(222deg);\n  -moz-transform: rotate(222deg);\n  -ms-transform: rotate(222deg);\n  -o-transform: rotate(222deg);\n  transform: rotate(222deg);\n}\n.wi-wind.from-43-deg {\n  -webkit-transform: rotate(223deg);\n  -moz-transform: rotate(223deg);\n  -ms-transform: rotate(223deg);\n  -o-transform: rotate(223deg);\n  transform: rotate(223deg);\n}\n.wi-wind.from-44-deg {\n  -webkit-transform: rotate(224deg);\n  -moz-transform: rotate(224deg);\n  -ms-transform: rotate(224deg);\n  -o-transform: rotate(224deg);\n  transform: rotate(224deg);\n}\n.wi-wind.from-45-deg {\n  -webkit-transform: rotate(225deg);\n  -moz-transform: rotate(225deg);\n  -ms-transform: rotate(225deg);\n  -o-transform: rotate(225deg);\n  transform: rotate(225deg);\n}\n.wi-wind.from-46-deg {\n  -webkit-transform: rotate(226deg);\n  -moz-transform: rotate(226deg);\n  -ms-transform: rotate(226deg);\n  -o-transform: rotate(226deg);\n  transform: rotate(226deg);\n}\n.wi-wind.from-47-deg {\n  -webkit-transform: rotate(227deg);\n  -moz-transform: rotate(227deg);\n  -ms-transform: rotate(227deg);\n  -o-transform: rotate(227deg);\n  transform: rotate(227deg);\n}\n.wi-wind.from-48-deg {\n  -webkit-transform: rotate(228deg);\n  -moz-transform: rotate(228deg);\n  -ms-transform: rotate(228deg);\n  -o-transform: rotate(228deg);\n  transform: rotate(228deg);\n}\n.wi-wind.from-49-deg {\n  -webkit-transform: rotate(229deg);\n  -moz-transform: rotate(229deg);\n  -ms-transform: rotate(229deg);\n  -o-transform: rotate(229deg);\n  transform: rotate(229deg);\n}\n.wi-wind.from-50-deg {\n  -webkit-transform: rotate(230deg);\n  -moz-transform: rotate(230deg);\n  -ms-transform: rotate(230deg);\n  -o-transform: rotate(230deg);\n  transform: rotate(230deg);\n}\n.wi-wind.from-51-deg {\n  -webkit-transform: rotate(231deg);\n  -moz-transform: rotate(231deg);\n  -ms-transform: rotate(231deg);\n  -o-transform: rotate(231deg);\n  transform: rotate(231deg);\n}\n.wi-wind.from-52-deg {\n  -webkit-transform: rotate(232deg);\n  -moz-transform: rotate(232deg);\n  -ms-transform: rotate(232deg);\n  -o-transform: rotate(232deg);\n  transform: rotate(232deg);\n}\n.wi-wind.from-53-deg {\n  -webkit-transform: rotate(233deg);\n  -moz-transform: rotate(233deg);\n  -ms-transform: rotate(233deg);\n  -o-transform: rotate(233deg);\n  transform: rotate(233deg);\n}\n.wi-wind.from-54-deg {\n  -webkit-transform: rotate(234deg);\n  -moz-transform: rotate(234deg);\n  -ms-transform: rotate(234deg);\n  -o-transform: rotate(234deg);\n  transform: rotate(234deg);\n}\n.wi-wind.from-55-deg {\n  -webkit-transform: rotate(235deg);\n  -moz-transform: rotate(235deg);\n  -ms-transform: rotate(235deg);\n  -o-transform: rotate(235deg);\n  transform: rotate(235deg);\n}\n.wi-wind.from-56-deg {\n  -webkit-transform: rotate(236deg);\n  -moz-transform: rotate(236deg);\n  -ms-transform: rotate(236deg);\n  -o-transform: rotate(236deg);\n  transform: rotate(236deg);\n}\n.wi-wind.from-57-deg {\n  -webkit-transform: rotate(237deg);\n  -moz-transform: rotate(237deg);\n  -ms-transform: rotate(237deg);\n  -o-transform: rotate(237deg);\n  transform: rotate(237deg);\n}\n.wi-wind.from-58-deg {\n  -webkit-transform: rotate(238deg);\n  -moz-transform: rotate(238deg);\n  -ms-transform: rotate(238deg);\n  -o-transform: rotate(238deg);\n  transform: rotate(238deg);\n}\n.wi-wind.from-59-deg {\n  -webkit-transform: rotate(239deg);\n  -moz-transform: rotate(239deg);\n  -ms-transform: rotate(239deg);\n  -o-transform: rotate(239deg);\n  transform: rotate(239deg);\n}\n.wi-wind.from-60-deg {\n  -webkit-transform: rotate(240deg);\n  -moz-transform: rotate(240deg);\n  -ms-transform: rotate(240deg);\n  -o-transform: rotate(240deg);\n  transform: rotate(240deg);\n}\n.wi-wind.from-61-deg {\n  -webkit-transform: rotate(241deg);\n  -moz-transform: rotate(241deg);\n  -ms-transform: rotate(241deg);\n  -o-transform: rotate(241deg);\n  transform: rotate(241deg);\n}\n.wi-wind.from-62-deg {\n  -webkit-transform: rotate(242deg);\n  -moz-transform: rotate(242deg);\n  -ms-transform: rotate(242deg);\n  -o-transform: rotate(242deg);\n  transform: rotate(242deg);\n}\n.wi-wind.from-63-deg {\n  -webkit-transform: rotate(243deg);\n  -moz-transform: rotate(243deg);\n  -ms-transform: rotate(243deg);\n  -o-transform: rotate(243deg);\n  transform: rotate(243deg);\n}\n.wi-wind.from-64-deg {\n  -webkit-transform: rotate(244deg);\n  -moz-transform: rotate(244deg);\n  -ms-transform: rotate(244deg);\n  -o-transform: rotate(244deg);\n  transform: rotate(244deg);\n}\n.wi-wind.from-65-deg {\n  -webkit-transform: rotate(245deg);\n  -moz-transform: rotate(245deg);\n  -ms-transform: rotate(245deg);\n  -o-transform: rotate(245deg);\n  transform: rotate(245deg);\n}\n.wi-wind.from-66-deg {\n  -webkit-transform: rotate(246deg);\n  -moz-transform: rotate(246deg);\n  -ms-transform: rotate(246deg);\n  -o-transform: rotate(246deg);\n  transform: rotate(246deg);\n}\n.wi-wind.from-67-deg {\n  -webkit-transform: rotate(247deg);\n  -moz-transform: rotate(247deg);\n  -ms-transform: rotate(247deg);\n  -o-transform: rotate(247deg);\n  transform: rotate(247deg);\n}\n.wi-wind.from-68-deg {\n  -webkit-transform: rotate(248deg);\n  -moz-transform: rotate(248deg);\n  -ms-transform: rotate(248deg);\n  -o-transform: rotate(248deg);\n  transform: rotate(248deg);\n}\n.wi-wind.from-69-deg {\n  -webkit-transform: rotate(249deg);\n  -moz-transform: rotate(249deg);\n  -ms-transform: rotate(249deg);\n  -o-transform: rotate(249deg);\n  transform: rotate(249deg);\n}\n.wi-wind.from-70-deg {\n  -webkit-transform: rotate(250deg);\n  -moz-transform: rotate(250deg);\n  -ms-transform: rotate(250deg);\n  -o-transform: rotate(250deg);\n  transform: rotate(250deg);\n}\n.wi-wind.from-71-deg {\n  -webkit-transform: rotate(251deg);\n  -moz-transform: rotate(251deg);\n  -ms-transform: rotate(251deg);\n  -o-transform: rotate(251deg);\n  transform: rotate(251deg);\n}\n.wi-wind.from-72-deg {\n  -webkit-transform: rotate(252deg);\n  -moz-transform: rotate(252deg);\n  -ms-transform: rotate(252deg);\n  -o-transform: rotate(252deg);\n  transform: rotate(252deg);\n}\n.wi-wind.from-73-deg {\n  -webkit-transform: rotate(253deg);\n  -moz-transform: rotate(253deg);\n  -ms-transform: rotate(253deg);\n  -o-transform: rotate(253deg);\n  transform: rotate(253deg);\n}\n.wi-wind.from-74-deg {\n  -webkit-transform: rotate(254deg);\n  -moz-transform: rotate(254deg);\n  -ms-transform: rotate(254deg);\n  -o-transform: rotate(254deg);\n  transform: rotate(254deg);\n}\n.wi-wind.from-75-deg {\n  -webkit-transform: rotate(255deg);\n  -moz-transform: rotate(255deg);\n  -ms-transform: rotate(255deg);\n  -o-transform: rotate(255deg);\n  transform: rotate(255deg);\n}\n.wi-wind.from-76-deg {\n  -webkit-transform: rotate(256deg);\n  -moz-transform: rotate(256deg);\n  -ms-transform: rotate(256deg);\n  -o-transform: rotate(256deg);\n  transform: rotate(256deg);\n}\n.wi-wind.from-77-deg {\n  -webkit-transform: rotate(257deg);\n  -moz-transform: rotate(257deg);\n  -ms-transform: rotate(257deg);\n  -o-transform: rotate(257deg);\n  transform: rotate(257deg);\n}\n.wi-wind.from-78-deg {\n  -webkit-transform: rotate(258deg);\n  -moz-transform: rotate(258deg);\n  -ms-transform: rotate(258deg);\n  -o-transform: rotate(258deg);\n  transform: rotate(258deg);\n}\n.wi-wind.from-79-deg {\n  -webkit-transform: rotate(259deg);\n  -moz-transform: rotate(259deg);\n  -ms-transform: rotate(259deg);\n  -o-transform: rotate(259deg);\n  transform: rotate(259deg);\n}\n.wi-wind.from-80-deg {\n  -webkit-transform: rotate(260deg);\n  -moz-transform: rotate(260deg);\n  -ms-transform: rotate(260deg);\n  -o-transform: rotate(260deg);\n  transform: rotate(260deg);\n}\n.wi-wind.from-81-deg {\n  -webkit-transform: rotate(261deg);\n  -moz-transform: rotate(261deg);\n  -ms-transform: rotate(261deg);\n  -o-transform: rotate(261deg);\n  transform: rotate(261deg);\n}\n.wi-wind.from-82-deg {\n  -webkit-transform: rotate(262deg);\n  -moz-transform: rotate(262deg);\n  -ms-transform: rotate(262deg);\n  -o-transform: rotate(262deg);\n  transform: rotate(262deg);\n}\n.wi-wind.from-83-deg {\n  -webkit-transform: rotate(263deg);\n  -moz-transform: rotate(263deg);\n  -ms-transform: rotate(263deg);\n  -o-transform: rotate(263deg);\n  transform: rotate(263deg);\n}\n.wi-wind.from-84-deg {\n  -webkit-transform: rotate(264deg);\n  -moz-transform: rotate(264deg);\n  -ms-transform: rotate(264deg);\n  -o-transform: rotate(264deg);\n  transform: rotate(264deg);\n}\n.wi-wind.from-85-deg {\n  -webkit-transform: rotate(265deg);\n  -moz-transform: rotate(265deg);\n  -ms-transform: rotate(265deg);\n  -o-transform: rotate(265deg);\n  transform: rotate(265deg);\n}\n.wi-wind.from-86-deg {\n  -webkit-transform: rotate(266deg);\n  -moz-transform: rotate(266deg);\n  -ms-transform: rotate(266deg);\n  -o-transform: rotate(266deg);\n  transform: rotate(266deg);\n}\n.wi-wind.from-87-deg {\n  -webkit-transform: rotate(267deg);\n  -moz-transform: rotate(267deg);\n  -ms-transform: rotate(267deg);\n  -o-transform: rotate(267deg);\n  transform: rotate(267deg);\n}\n.wi-wind.from-88-deg {\n  -webkit-transform: rotate(268deg);\n  -moz-transform: rotate(268deg);\n  -ms-transform: rotate(268deg);\n  -o-transform: rotate(268deg);\n  transform: rotate(268deg);\n}\n.wi-wind.from-89-deg {\n  -webkit-transform: rotate(269deg);\n  -moz-transform: rotate(269deg);\n  -ms-transform: rotate(269deg);\n  -o-transform: rotate(269deg);\n  transform: rotate(269deg);\n}\n.wi-wind.from-90-deg {\n  -webkit-transform: rotate(270deg);\n  -moz-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  -o-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-wind.from-91-deg {\n  -webkit-transform: rotate(271deg);\n  -moz-transform: rotate(271deg);\n  -ms-transform: rotate(271deg);\n  -o-transform: rotate(271deg);\n  transform: rotate(271deg);\n}\n.wi-wind.from-92-deg {\n  -webkit-transform: rotate(272deg);\n  -moz-transform: rotate(272deg);\n  -ms-transform: rotate(272deg);\n  -o-transform: rotate(272deg);\n  transform: rotate(272deg);\n}\n.wi-wind.from-93-deg {\n  -webkit-transform: rotate(273deg);\n  -moz-transform: rotate(273deg);\n  -ms-transform: rotate(273deg);\n  -o-transform: rotate(273deg);\n  transform: rotate(273deg);\n}\n.wi-wind.from-94-deg {\n  -webkit-transform: rotate(274deg);\n  -moz-transform: rotate(274deg);\n  -ms-transform: rotate(274deg);\n  -o-transform: rotate(274deg);\n  transform: rotate(274deg);\n}\n.wi-wind.from-95-deg {\n  -webkit-transform: rotate(275deg);\n  -moz-transform: rotate(275deg);\n  -ms-transform: rotate(275deg);\n  -o-transform: rotate(275deg);\n  transform: rotate(275deg);\n}\n.wi-wind.from-96-deg {\n  -webkit-transform: rotate(276deg);\n  -moz-transform: rotate(276deg);\n  -ms-transform: rotate(276deg);\n  -o-transform: rotate(276deg);\n  transform: rotate(276deg);\n}\n.wi-wind.from-97-deg {\n  -webkit-transform: rotate(277deg);\n  -moz-transform: rotate(277deg);\n  -ms-transform: rotate(277deg);\n  -o-transform: rotate(277deg);\n  transform: rotate(277deg);\n}\n.wi-wind.from-98-deg {\n  -webkit-transform: rotate(278deg);\n  -moz-transform: rotate(278deg);\n  -ms-transform: rotate(278deg);\n  -o-transform: rotate(278deg);\n  transform: rotate(278deg);\n}\n.wi-wind.from-99-deg {\n  -webkit-transform: rotate(279deg);\n  -moz-transform: rotate(279deg);\n  -ms-transform: rotate(279deg);\n  -o-transform: rotate(279deg);\n  transform: rotate(279deg);\n}\n.wi-wind.from-100-deg {\n  -webkit-transform: rotate(280deg);\n  -moz-transform: rotate(280deg);\n  -ms-transform: rotate(280deg);\n  -o-transform: rotate(280deg);\n  transform: rotate(280deg);\n}\n.wi-wind.from-101-deg {\n  -webkit-transform: rotate(281deg);\n  -moz-transform: rotate(281deg);\n  -ms-transform: rotate(281deg);\n  -o-transform: rotate(281deg);\n  transform: rotate(281deg);\n}\n.wi-wind.from-102-deg {\n  -webkit-transform: rotate(282deg);\n  -moz-transform: rotate(282deg);\n  -ms-transform: rotate(282deg);\n  -o-transform: rotate(282deg);\n  transform: rotate(282deg);\n}\n.wi-wind.from-103-deg {\n  -webkit-transform: rotate(283deg);\n  -moz-transform: rotate(283deg);\n  -ms-transform: rotate(283deg);\n  -o-transform: rotate(283deg);\n  transform: rotate(283deg);\n}\n.wi-wind.from-104-deg {\n  -webkit-transform: rotate(284deg);\n  -moz-transform: rotate(284deg);\n  -ms-transform: rotate(284deg);\n  -o-transform: rotate(284deg);\n  transform: rotate(284deg);\n}\n.wi-wind.from-105-deg {\n  -webkit-transform: rotate(285deg);\n  -moz-transform: rotate(285deg);\n  -ms-transform: rotate(285deg);\n  -o-transform: rotate(285deg);\n  transform: rotate(285deg);\n}\n.wi-wind.from-106-deg {\n  -webkit-transform: rotate(286deg);\n  -moz-transform: rotate(286deg);\n  -ms-transform: rotate(286deg);\n  -o-transform: rotate(286deg);\n  transform: rotate(286deg);\n}\n.wi-wind.from-107-deg {\n  -webkit-transform: rotate(287deg);\n  -moz-transform: rotate(287deg);\n  -ms-transform: rotate(287deg);\n  -o-transform: rotate(287deg);\n  transform: rotate(287deg);\n}\n.wi-wind.from-108-deg {\n  -webkit-transform: rotate(288deg);\n  -moz-transform: rotate(288deg);\n  -ms-transform: rotate(288deg);\n  -o-transform: rotate(288deg);\n  transform: rotate(288deg);\n}\n.wi-wind.from-109-deg {\n  -webkit-transform: rotate(289deg);\n  -moz-transform: rotate(289deg);\n  -ms-transform: rotate(289deg);\n  -o-transform: rotate(289deg);\n  transform: rotate(289deg);\n}\n.wi-wind.from-110-deg {\n  -webkit-transform: rotate(290deg);\n  -moz-transform: rotate(290deg);\n  -ms-transform: rotate(290deg);\n  -o-transform: rotate(290deg);\n  transform: rotate(290deg);\n}\n.wi-wind.from-111-deg {\n  -webkit-transform: rotate(291deg);\n  -moz-transform: rotate(291deg);\n  -ms-transform: rotate(291deg);\n  -o-transform: rotate(291deg);\n  transform: rotate(291deg);\n}\n.wi-wind.from-112-deg {\n  -webkit-transform: rotate(292deg);\n  -moz-transform: rotate(292deg);\n  -ms-transform: rotate(292deg);\n  -o-transform: rotate(292deg);\n  transform: rotate(292deg);\n}\n.wi-wind.from-113-deg {\n  -webkit-transform: rotate(293deg);\n  -moz-transform: rotate(293deg);\n  -ms-transform: rotate(293deg);\n  -o-transform: rotate(293deg);\n  transform: rotate(293deg);\n}\n.wi-wind.from-114-deg {\n  -webkit-transform: rotate(294deg);\n  -moz-transform: rotate(294deg);\n  -ms-transform: rotate(294deg);\n  -o-transform: rotate(294deg);\n  transform: rotate(294deg);\n}\n.wi-wind.from-115-deg {\n  -webkit-transform: rotate(295deg);\n  -moz-transform: rotate(295deg);\n  -ms-transform: rotate(295deg);\n  -o-transform: rotate(295deg);\n  transform: rotate(295deg);\n}\n.wi-wind.from-116-deg {\n  -webkit-transform: rotate(296deg);\n  -moz-transform: rotate(296deg);\n  -ms-transform: rotate(296deg);\n  -o-transform: rotate(296deg);\n  transform: rotate(296deg);\n}\n.wi-wind.from-117-deg {\n  -webkit-transform: rotate(297deg);\n  -moz-transform: rotate(297deg);\n  -ms-transform: rotate(297deg);\n  -o-transform: rotate(297deg);\n  transform: rotate(297deg);\n}\n.wi-wind.from-118-deg {\n  -webkit-transform: rotate(298deg);\n  -moz-transform: rotate(298deg);\n  -ms-transform: rotate(298deg);\n  -o-transform: rotate(298deg);\n  transform: rotate(298deg);\n}\n.wi-wind.from-119-deg {\n  -webkit-transform: rotate(299deg);\n  -moz-transform: rotate(299deg);\n  -ms-transform: rotate(299deg);\n  -o-transform: rotate(299deg);\n  transform: rotate(299deg);\n}\n.wi-wind.from-120-deg {\n  -webkit-transform: rotate(300deg);\n  -moz-transform: rotate(300deg);\n  -ms-transform: rotate(300deg);\n  -o-transform: rotate(300deg);\n  transform: rotate(300deg);\n}\n.wi-wind.from-121-deg {\n  -webkit-transform: rotate(301deg);\n  -moz-transform: rotate(301deg);\n  -ms-transform: rotate(301deg);\n  -o-transform: rotate(301deg);\n  transform: rotate(301deg);\n}\n.wi-wind.from-122-deg {\n  -webkit-transform: rotate(302deg);\n  -moz-transform: rotate(302deg);\n  -ms-transform: rotate(302deg);\n  -o-transform: rotate(302deg);\n  transform: rotate(302deg);\n}\n.wi-wind.from-123-deg {\n  -webkit-transform: rotate(303deg);\n  -moz-transform: rotate(303deg);\n  -ms-transform: rotate(303deg);\n  -o-transform: rotate(303deg);\n  transform: rotate(303deg);\n}\n.wi-wind.from-124-deg {\n  -webkit-transform: rotate(304deg);\n  -moz-transform: rotate(304deg);\n  -ms-transform: rotate(304deg);\n  -o-transform: rotate(304deg);\n  transform: rotate(304deg);\n}\n.wi-wind.from-125-deg {\n  -webkit-transform: rotate(305deg);\n  -moz-transform: rotate(305deg);\n  -ms-transform: rotate(305deg);\n  -o-transform: rotate(305deg);\n  transform: rotate(305deg);\n}\n.wi-wind.from-126-deg {\n  -webkit-transform: rotate(306deg);\n  -moz-transform: rotate(306deg);\n  -ms-transform: rotate(306deg);\n  -o-transform: rotate(306deg);\n  transform: rotate(306deg);\n}\n.wi-wind.from-127-deg {\n  -webkit-transform: rotate(307deg);\n  -moz-transform: rotate(307deg);\n  -ms-transform: rotate(307deg);\n  -o-transform: rotate(307deg);\n  transform: rotate(307deg);\n}\n.wi-wind.from-128-deg {\n  -webkit-transform: rotate(308deg);\n  -moz-transform: rotate(308deg);\n  -ms-transform: rotate(308deg);\n  -o-transform: rotate(308deg);\n  transform: rotate(308deg);\n}\n.wi-wind.from-129-deg {\n  -webkit-transform: rotate(309deg);\n  -moz-transform: rotate(309deg);\n  -ms-transform: rotate(309deg);\n  -o-transform: rotate(309deg);\n  transform: rotate(309deg);\n}\n.wi-wind.from-130-deg {\n  -webkit-transform: rotate(310deg);\n  -moz-transform: rotate(310deg);\n  -ms-transform: rotate(310deg);\n  -o-transform: rotate(310deg);\n  transform: rotate(310deg);\n}\n.wi-wind.from-131-deg {\n  -webkit-transform: rotate(311deg);\n  -moz-transform: rotate(311deg);\n  -ms-transform: rotate(311deg);\n  -o-transform: rotate(311deg);\n  transform: rotate(311deg);\n}\n.wi-wind.from-132-deg {\n  -webkit-transform: rotate(312deg);\n  -moz-transform: rotate(312deg);\n  -ms-transform: rotate(312deg);\n  -o-transform: rotate(312deg);\n  transform: rotate(312deg);\n}\n.wi-wind.from-133-deg {\n  -webkit-transform: rotate(313deg);\n  -moz-transform: rotate(313deg);\n  -ms-transform: rotate(313deg);\n  -o-transform: rotate(313deg);\n  transform: rotate(313deg);\n}\n.wi-wind.from-134-deg {\n  -webkit-transform: rotate(314deg);\n  -moz-transform: rotate(314deg);\n  -ms-transform: rotate(314deg);\n  -o-transform: rotate(314deg);\n  transform: rotate(314deg);\n}\n.wi-wind.from-135-deg {\n  -webkit-transform: rotate(315deg);\n  -moz-transform: rotate(315deg);\n  -ms-transform: rotate(315deg);\n  -o-transform: rotate(315deg);\n  transform: rotate(315deg);\n}\n.wi-wind.from-136-deg {\n  -webkit-transform: rotate(316deg);\n  -moz-transform: rotate(316deg);\n  -ms-transform: rotate(316deg);\n  -o-transform: rotate(316deg);\n  transform: rotate(316deg);\n}\n.wi-wind.from-137-deg {\n  -webkit-transform: rotate(317deg);\n  -moz-transform: rotate(317deg);\n  -ms-transform: rotate(317deg);\n  -o-transform: rotate(317deg);\n  transform: rotate(317deg);\n}\n.wi-wind.from-138-deg {\n  -webkit-transform: rotate(318deg);\n  -moz-transform: rotate(318deg);\n  -ms-transform: rotate(318deg);\n  -o-transform: rotate(318deg);\n  transform: rotate(318deg);\n}\n.wi-wind.from-139-deg {\n  -webkit-transform: rotate(319deg);\n  -moz-transform: rotate(319deg);\n  -ms-transform: rotate(319deg);\n  -o-transform: rotate(319deg);\n  transform: rotate(319deg);\n}\n.wi-wind.from-140-deg {\n  -webkit-transform: rotate(320deg);\n  -moz-transform: rotate(320deg);\n  -ms-transform: rotate(320deg);\n  -o-transform: rotate(320deg);\n  transform: rotate(320deg);\n}\n.wi-wind.from-141-deg {\n  -webkit-transform: rotate(321deg);\n  -moz-transform: rotate(321deg);\n  -ms-transform: rotate(321deg);\n  -o-transform: rotate(321deg);\n  transform: rotate(321deg);\n}\n.wi-wind.from-142-deg {\n  -webkit-transform: rotate(322deg);\n  -moz-transform: rotate(322deg);\n  -ms-transform: rotate(322deg);\n  -o-transform: rotate(322deg);\n  transform: rotate(322deg);\n}\n.wi-wind.from-143-deg {\n  -webkit-transform: rotate(323deg);\n  -moz-transform: rotate(323deg);\n  -ms-transform: rotate(323deg);\n  -o-transform: rotate(323deg);\n  transform: rotate(323deg);\n}\n.wi-wind.from-144-deg {\n  -webkit-transform: rotate(324deg);\n  -moz-transform: rotate(324deg);\n  -ms-transform: rotate(324deg);\n  -o-transform: rotate(324deg);\n  transform: rotate(324deg);\n}\n.wi-wind.from-145-deg {\n  -webkit-transform: rotate(325deg);\n  -moz-transform: rotate(325deg);\n  -ms-transform: rotate(325deg);\n  -o-transform: rotate(325deg);\n  transform: rotate(325deg);\n}\n.wi-wind.from-146-deg {\n  -webkit-transform: rotate(326deg);\n  -moz-transform: rotate(326deg);\n  -ms-transform: rotate(326deg);\n  -o-transform: rotate(326deg);\n  transform: rotate(326deg);\n}\n.wi-wind.from-147-deg {\n  -webkit-transform: rotate(327deg);\n  -moz-transform: rotate(327deg);\n  -ms-transform: rotate(327deg);\n  -o-transform: rotate(327deg);\n  transform: rotate(327deg);\n}\n.wi-wind.from-148-deg {\n  -webkit-transform: rotate(328deg);\n  -moz-transform: rotate(328deg);\n  -ms-transform: rotate(328deg);\n  -o-transform: rotate(328deg);\n  transform: rotate(328deg);\n}\n.wi-wind.from-149-deg {\n  -webkit-transform: rotate(329deg);\n  -moz-transform: rotate(329deg);\n  -ms-transform: rotate(329deg);\n  -o-transform: rotate(329deg);\n  transform: rotate(329deg);\n}\n.wi-wind.from-150-deg {\n  -webkit-transform: rotate(330deg);\n  -moz-transform: rotate(330deg);\n  -ms-transform: rotate(330deg);\n  -o-transform: rotate(330deg);\n  transform: rotate(330deg);\n}\n.wi-wind.from-151-deg {\n  -webkit-transform: rotate(331deg);\n  -moz-transform: rotate(331deg);\n  -ms-transform: rotate(331deg);\n  -o-transform: rotate(331deg);\n  transform: rotate(331deg);\n}\n.wi-wind.from-152-deg {\n  -webkit-transform: rotate(332deg);\n  -moz-transform: rotate(332deg);\n  -ms-transform: rotate(332deg);\n  -o-transform: rotate(332deg);\n  transform: rotate(332deg);\n}\n.wi-wind.from-153-deg {\n  -webkit-transform: rotate(333deg);\n  -moz-transform: rotate(333deg);\n  -ms-transform: rotate(333deg);\n  -o-transform: rotate(333deg);\n  transform: rotate(333deg);\n}\n.wi-wind.from-154-deg {\n  -webkit-transform: rotate(334deg);\n  -moz-transform: rotate(334deg);\n  -ms-transform: rotate(334deg);\n  -o-transform: rotate(334deg);\n  transform: rotate(334deg);\n}\n.wi-wind.from-155-deg {\n  -webkit-transform: rotate(335deg);\n  -moz-transform: rotate(335deg);\n  -ms-transform: rotate(335deg);\n  -o-transform: rotate(335deg);\n  transform: rotate(335deg);\n}\n.wi-wind.from-156-deg {\n  -webkit-transform: rotate(336deg);\n  -moz-transform: rotate(336deg);\n  -ms-transform: rotate(336deg);\n  -o-transform: rotate(336deg);\n  transform: rotate(336deg);\n}\n.wi-wind.from-157-deg {\n  -webkit-transform: rotate(337deg);\n  -moz-transform: rotate(337deg);\n  -ms-transform: rotate(337deg);\n  -o-transform: rotate(337deg);\n  transform: rotate(337deg);\n}\n.wi-wind.from-158-deg {\n  -webkit-transform: rotate(338deg);\n  -moz-transform: rotate(338deg);\n  -ms-transform: rotate(338deg);\n  -o-transform: rotate(338deg);\n  transform: rotate(338deg);\n}\n.wi-wind.from-159-deg {\n  -webkit-transform: rotate(339deg);\n  -moz-transform: rotate(339deg);\n  -ms-transform: rotate(339deg);\n  -o-transform: rotate(339deg);\n  transform: rotate(339deg);\n}\n.wi-wind.from-160-deg {\n  -webkit-transform: rotate(340deg);\n  -moz-transform: rotate(340deg);\n  -ms-transform: rotate(340deg);\n  -o-transform: rotate(340deg);\n  transform: rotate(340deg);\n}\n.wi-wind.from-161-deg {\n  -webkit-transform: rotate(341deg);\n  -moz-transform: rotate(341deg);\n  -ms-transform: rotate(341deg);\n  -o-transform: rotate(341deg);\n  transform: rotate(341deg);\n}\n.wi-wind.from-162-deg {\n  -webkit-transform: rotate(342deg);\n  -moz-transform: rotate(342deg);\n  -ms-transform: rotate(342deg);\n  -o-transform: rotate(342deg);\n  transform: rotate(342deg);\n}\n.wi-wind.from-163-deg {\n  -webkit-transform: rotate(343deg);\n  -moz-transform: rotate(343deg);\n  -ms-transform: rotate(343deg);\n  -o-transform: rotate(343deg);\n  transform: rotate(343deg);\n}\n.wi-wind.from-164-deg {\n  -webkit-transform: rotate(344deg);\n  -moz-transform: rotate(344deg);\n  -ms-transform: rotate(344deg);\n  -o-transform: rotate(344deg);\n  transform: rotate(344deg);\n}\n.wi-wind.from-165-deg {\n  -webkit-transform: rotate(345deg);\n  -moz-transform: rotate(345deg);\n  -ms-transform: rotate(345deg);\n  -o-transform: rotate(345deg);\n  transform: rotate(345deg);\n}\n.wi-wind.from-166-deg {\n  -webkit-transform: rotate(346deg);\n  -moz-transform: rotate(346deg);\n  -ms-transform: rotate(346deg);\n  -o-transform: rotate(346deg);\n  transform: rotate(346deg);\n}\n.wi-wind.from-167-deg {\n  -webkit-transform: rotate(347deg);\n  -moz-transform: rotate(347deg);\n  -ms-transform: rotate(347deg);\n  -o-transform: rotate(347deg);\n  transform: rotate(347deg);\n}\n.wi-wind.from-168-deg {\n  -webkit-transform: rotate(348deg);\n  -moz-transform: rotate(348deg);\n  -ms-transform: rotate(348deg);\n  -o-transform: rotate(348deg);\n  transform: rotate(348deg);\n}\n.wi-wind.from-169-deg {\n  -webkit-transform: rotate(349deg);\n  -moz-transform: rotate(349deg);\n  -ms-transform: rotate(349deg);\n  -o-transform: rotate(349deg);\n  transform: rotate(349deg);\n}\n.wi-wind.from-170-deg {\n  -webkit-transform: rotate(350deg);\n  -moz-transform: rotate(350deg);\n  -ms-transform: rotate(350deg);\n  -o-transform: rotate(350deg);\n  transform: rotate(350deg);\n}\n.wi-wind.from-171-deg {\n  -webkit-transform: rotate(351deg);\n  -moz-transform: rotate(351deg);\n  -ms-transform: rotate(351deg);\n  -o-transform: rotate(351deg);\n  transform: rotate(351deg);\n}\n.wi-wind.from-172-deg {\n  -webkit-transform: rotate(352deg);\n  -moz-transform: rotate(352deg);\n  -ms-transform: rotate(352deg);\n  -o-transform: rotate(352deg);\n  transform: rotate(352deg);\n}\n.wi-wind.from-173-deg {\n  -webkit-transform: rotate(353deg);\n  -moz-transform: rotate(353deg);\n  -ms-transform: rotate(353deg);\n  -o-transform: rotate(353deg);\n  transform: rotate(353deg);\n}\n.wi-wind.from-174-deg {\n  -webkit-transform: rotate(354deg);\n  -moz-transform: rotate(354deg);\n  -ms-transform: rotate(354deg);\n  -o-transform: rotate(354deg);\n  transform: rotate(354deg);\n}\n.wi-wind.from-175-deg {\n  -webkit-transform: rotate(355deg);\n  -moz-transform: rotate(355deg);\n  -ms-transform: rotate(355deg);\n  -o-transform: rotate(355deg);\n  transform: rotate(355deg);\n}\n.wi-wind.from-176-deg {\n  -webkit-transform: rotate(356deg);\n  -moz-transform: rotate(356deg);\n  -ms-transform: rotate(356deg);\n  -o-transform: rotate(356deg);\n  transform: rotate(356deg);\n}\n.wi-wind.from-177-deg {\n  -webkit-transform: rotate(357deg);\n  -moz-transform: rotate(357deg);\n  -ms-transform: rotate(357deg);\n  -o-transform: rotate(357deg);\n  transform: rotate(357deg);\n}\n.wi-wind.from-178-deg {\n  -webkit-transform: rotate(358deg);\n  -moz-transform: rotate(358deg);\n  -ms-transform: rotate(358deg);\n  -o-transform: rotate(358deg);\n  transform: rotate(358deg);\n}\n.wi-wind.from-179-deg {\n  -webkit-transform: rotate(359deg);\n  -moz-transform: rotate(359deg);\n  -ms-transform: rotate(359deg);\n  -o-transform: rotate(359deg);\n  transform: rotate(359deg);\n}\n.wi-wind.from-180-deg {\n  -webkit-transform: rotate(0deg);\n  -moz-transform: rotate(0deg);\n  -ms-transform: rotate(0deg);\n  -o-transform: rotate(0deg);\n  transform: rotate(0deg);\n}\n.wi-wind.from-181-deg {\n  -webkit-transform: rotate(1deg);\n  -moz-transform: rotate(1deg);\n  -ms-transform: rotate(1deg);\n  -o-transform: rotate(1deg);\n  transform: rotate(1deg);\n}\n.wi-wind.from-182-deg {\n  -webkit-transform: rotate(2deg);\n  -moz-transform: rotate(2deg);\n  -ms-transform: rotate(2deg);\n  -o-transform: rotate(2deg);\n  transform: rotate(2deg);\n}\n.wi-wind.from-183-deg {\n  -webkit-transform: rotate(3deg);\n  -moz-transform: rotate(3deg);\n  -ms-transform: rotate(3deg);\n  -o-transform: rotate(3deg);\n  transform: rotate(3deg);\n}\n.wi-wind.from-184-deg {\n  -webkit-transform: rotate(4deg);\n  -moz-transform: rotate(4deg);\n  -ms-transform: rotate(4deg);\n  -o-transform: rotate(4deg);\n  transform: rotate(4deg);\n}\n.wi-wind.from-185-deg {\n  -webkit-transform: rotate(5deg);\n  -moz-transform: rotate(5deg);\n  -ms-transform: rotate(5deg);\n  -o-transform: rotate(5deg);\n  transform: rotate(5deg);\n}\n.wi-wind.from-186-deg {\n  -webkit-transform: rotate(6deg);\n  -moz-transform: rotate(6deg);\n  -ms-transform: rotate(6deg);\n  -o-transform: rotate(6deg);\n  transform: rotate(6deg);\n}\n.wi-wind.from-187-deg {\n  -webkit-transform: rotate(7deg);\n  -moz-transform: rotate(7deg);\n  -ms-transform: rotate(7deg);\n  -o-transform: rotate(7deg);\n  transform: rotate(7deg);\n}\n.wi-wind.from-188-deg {\n  -webkit-transform: rotate(8deg);\n  -moz-transform: rotate(8deg);\n  -ms-transform: rotate(8deg);\n  -o-transform: rotate(8deg);\n  transform: rotate(8deg);\n}\n.wi-wind.from-189-deg {\n  -webkit-transform: rotate(9deg);\n  -moz-transform: rotate(9deg);\n  -ms-transform: rotate(9deg);\n  -o-transform: rotate(9deg);\n  transform: rotate(9deg);\n}\n.wi-wind.from-190-deg {\n  -webkit-transform: rotate(10deg);\n  -moz-transform: rotate(10deg);\n  -ms-transform: rotate(10deg);\n  -o-transform: rotate(10deg);\n  transform: rotate(10deg);\n}\n.wi-wind.from-191-deg {\n  -webkit-transform: rotate(11deg);\n  -moz-transform: rotate(11deg);\n  -ms-transform: rotate(11deg);\n  -o-transform: rotate(11deg);\n  transform: rotate(11deg);\n}\n.wi-wind.from-192-deg {\n  -webkit-transform: rotate(12deg);\n  -moz-transform: rotate(12deg);\n  -ms-transform: rotate(12deg);\n  -o-transform: rotate(12deg);\n  transform: rotate(12deg);\n}\n.wi-wind.from-193-deg {\n  -webkit-transform: rotate(13deg);\n  -moz-transform: rotate(13deg);\n  -ms-transform: rotate(13deg);\n  -o-transform: rotate(13deg);\n  transform: rotate(13deg);\n}\n.wi-wind.from-194-deg {\n  -webkit-transform: rotate(14deg);\n  -moz-transform: rotate(14deg);\n  -ms-transform: rotate(14deg);\n  -o-transform: rotate(14deg);\n  transform: rotate(14deg);\n}\n.wi-wind.from-195-deg {\n  -webkit-transform: rotate(15deg);\n  -moz-transform: rotate(15deg);\n  -ms-transform: rotate(15deg);\n  -o-transform: rotate(15deg);\n  transform: rotate(15deg);\n}\n.wi-wind.from-196-deg {\n  -webkit-transform: rotate(16deg);\n  -moz-transform: rotate(16deg);\n  -ms-transform: rotate(16deg);\n  -o-transform: rotate(16deg);\n  transform: rotate(16deg);\n}\n.wi-wind.from-197-deg {\n  -webkit-transform: rotate(17deg);\n  -moz-transform: rotate(17deg);\n  -ms-transform: rotate(17deg);\n  -o-transform: rotate(17deg);\n  transform: rotate(17deg);\n}\n.wi-wind.from-198-deg {\n  -webkit-transform: rotate(18deg);\n  -moz-transform: rotate(18deg);\n  -ms-transform: rotate(18deg);\n  -o-transform: rotate(18deg);\n  transform: rotate(18deg);\n}\n.wi-wind.from-199-deg {\n  -webkit-transform: rotate(19deg);\n  -moz-transform: rotate(19deg);\n  -ms-transform: rotate(19deg);\n  -o-transform: rotate(19deg);\n  transform: rotate(19deg);\n}\n.wi-wind.from-200-deg {\n  -webkit-transform: rotate(20deg);\n  -moz-transform: rotate(20deg);\n  -ms-transform: rotate(20deg);\n  -o-transform: rotate(20deg);\n  transform: rotate(20deg);\n}\n.wi-wind.from-201-deg {\n  -webkit-transform: rotate(21deg);\n  -moz-transform: rotate(21deg);\n  -ms-transform: rotate(21deg);\n  -o-transform: rotate(21deg);\n  transform: rotate(21deg);\n}\n.wi-wind.from-202-deg {\n  -webkit-transform: rotate(22deg);\n  -moz-transform: rotate(22deg);\n  -ms-transform: rotate(22deg);\n  -o-transform: rotate(22deg);\n  transform: rotate(22deg);\n}\n.wi-wind.from-203-deg {\n  -webkit-transform: rotate(23deg);\n  -moz-transform: rotate(23deg);\n  -ms-transform: rotate(23deg);\n  -o-transform: rotate(23deg);\n  transform: rotate(23deg);\n}\n.wi-wind.from-204-deg {\n  -webkit-transform: rotate(24deg);\n  -moz-transform: rotate(24deg);\n  -ms-transform: rotate(24deg);\n  -o-transform: rotate(24deg);\n  transform: rotate(24deg);\n}\n.wi-wind.from-205-deg {\n  -webkit-transform: rotate(25deg);\n  -moz-transform: rotate(25deg);\n  -ms-transform: rotate(25deg);\n  -o-transform: rotate(25deg);\n  transform: rotate(25deg);\n}\n.wi-wind.from-206-deg {\n  -webkit-transform: rotate(26deg);\n  -moz-transform: rotate(26deg);\n  -ms-transform: rotate(26deg);\n  -o-transform: rotate(26deg);\n  transform: rotate(26deg);\n}\n.wi-wind.from-207-deg {\n  -webkit-transform: rotate(27deg);\n  -moz-transform: rotate(27deg);\n  -ms-transform: rotate(27deg);\n  -o-transform: rotate(27deg);\n  transform: rotate(27deg);\n}\n.wi-wind.from-208-deg {\n  -webkit-transform: rotate(28deg);\n  -moz-transform: rotate(28deg);\n  -ms-transform: rotate(28deg);\n  -o-transform: rotate(28deg);\n  transform: rotate(28deg);\n}\n.wi-wind.from-209-deg {\n  -webkit-transform: rotate(29deg);\n  -moz-transform: rotate(29deg);\n  -ms-transform: rotate(29deg);\n  -o-transform: rotate(29deg);\n  transform: rotate(29deg);\n}\n.wi-wind.from-210-deg {\n  -webkit-transform: rotate(30deg);\n  -moz-transform: rotate(30deg);\n  -ms-transform: rotate(30deg);\n  -o-transform: rotate(30deg);\n  transform: rotate(30deg);\n}\n.wi-wind.from-211-deg {\n  -webkit-transform: rotate(31deg);\n  -moz-transform: rotate(31deg);\n  -ms-transform: rotate(31deg);\n  -o-transform: rotate(31deg);\n  transform: rotate(31deg);\n}\n.wi-wind.from-212-deg {\n  -webkit-transform: rotate(32deg);\n  -moz-transform: rotate(32deg);\n  -ms-transform: rotate(32deg);\n  -o-transform: rotate(32deg);\n  transform: rotate(32deg);\n}\n.wi-wind.from-213-deg {\n  -webkit-transform: rotate(33deg);\n  -moz-transform: rotate(33deg);\n  -ms-transform: rotate(33deg);\n  -o-transform: rotate(33deg);\n  transform: rotate(33deg);\n}\n.wi-wind.from-214-deg {\n  -webkit-transform: rotate(34deg);\n  -moz-transform: rotate(34deg);\n  -ms-transform: rotate(34deg);\n  -o-transform: rotate(34deg);\n  transform: rotate(34deg);\n}\n.wi-wind.from-215-deg {\n  -webkit-transform: rotate(35deg);\n  -moz-transform: rotate(35deg);\n  -ms-transform: rotate(35deg);\n  -o-transform: rotate(35deg);\n  transform: rotate(35deg);\n}\n.wi-wind.from-216-deg {\n  -webkit-transform: rotate(36deg);\n  -moz-transform: rotate(36deg);\n  -ms-transform: rotate(36deg);\n  -o-transform: rotate(36deg);\n  transform: rotate(36deg);\n}\n.wi-wind.from-217-deg {\n  -webkit-transform: rotate(37deg);\n  -moz-transform: rotate(37deg);\n  -ms-transform: rotate(37deg);\n  -o-transform: rotate(37deg);\n  transform: rotate(37deg);\n}\n.wi-wind.from-218-deg {\n  -webkit-transform: rotate(38deg);\n  -moz-transform: rotate(38deg);\n  -ms-transform: rotate(38deg);\n  -o-transform: rotate(38deg);\n  transform: rotate(38deg);\n}\n.wi-wind.from-219-deg {\n  -webkit-transform: rotate(39deg);\n  -moz-transform: rotate(39deg);\n  -ms-transform: rotate(39deg);\n  -o-transform: rotate(39deg);\n  transform: rotate(39deg);\n}\n.wi-wind.from-220-deg {\n  -webkit-transform: rotate(40deg);\n  -moz-transform: rotate(40deg);\n  -ms-transform: rotate(40deg);\n  -o-transform: rotate(40deg);\n  transform: rotate(40deg);\n}\n.wi-wind.from-221-deg {\n  -webkit-transform: rotate(41deg);\n  -moz-transform: rotate(41deg);\n  -ms-transform: rotate(41deg);\n  -o-transform: rotate(41deg);\n  transform: rotate(41deg);\n}\n.wi-wind.from-222-deg {\n  -webkit-transform: rotate(42deg);\n  -moz-transform: rotate(42deg);\n  -ms-transform: rotate(42deg);\n  -o-transform: rotate(42deg);\n  transform: rotate(42deg);\n}\n.wi-wind.from-223-deg {\n  -webkit-transform: rotate(43deg);\n  -moz-transform: rotate(43deg);\n  -ms-transform: rotate(43deg);\n  -o-transform: rotate(43deg);\n  transform: rotate(43deg);\n}\n.wi-wind.from-224-deg {\n  -webkit-transform: rotate(44deg);\n  -moz-transform: rotate(44deg);\n  -ms-transform: rotate(44deg);\n  -o-transform: rotate(44deg);\n  transform: rotate(44deg);\n}\n.wi-wind.from-225-deg {\n  -webkit-transform: rotate(45deg);\n  -moz-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg);\n}\n.wi-wind.from-226-deg {\n  -webkit-transform: rotate(46deg);\n  -moz-transform: rotate(46deg);\n  -ms-transform: rotate(46deg);\n  -o-transform: rotate(46deg);\n  transform: rotate(46deg);\n}\n.wi-wind.from-227-deg {\n  -webkit-transform: rotate(47deg);\n  -moz-transform: rotate(47deg);\n  -ms-transform: rotate(47deg);\n  -o-transform: rotate(47deg);\n  transform: rotate(47deg);\n}\n.wi-wind.from-228-deg {\n  -webkit-transform: rotate(48deg);\n  -moz-transform: rotate(48deg);\n  -ms-transform: rotate(48deg);\n  -o-transform: rotate(48deg);\n  transform: rotate(48deg);\n}\n.wi-wind.from-229-deg {\n  -webkit-transform: rotate(49deg);\n  -moz-transform: rotate(49deg);\n  -ms-transform: rotate(49deg);\n  -o-transform: rotate(49deg);\n  transform: rotate(49deg);\n}\n.wi-wind.from-230-deg {\n  -webkit-transform: rotate(50deg);\n  -moz-transform: rotate(50deg);\n  -ms-transform: rotate(50deg);\n  -o-transform: rotate(50deg);\n  transform: rotate(50deg);\n}\n.wi-wind.from-231-deg {\n  -webkit-transform: rotate(51deg);\n  -moz-transform: rotate(51deg);\n  -ms-transform: rotate(51deg);\n  -o-transform: rotate(51deg);\n  transform: rotate(51deg);\n}\n.wi-wind.from-232-deg {\n  -webkit-transform: rotate(52deg);\n  -moz-transform: rotate(52deg);\n  -ms-transform: rotate(52deg);\n  -o-transform: rotate(52deg);\n  transform: rotate(52deg);\n}\n.wi-wind.from-233-deg {\n  -webkit-transform: rotate(53deg);\n  -moz-transform: rotate(53deg);\n  -ms-transform: rotate(53deg);\n  -o-transform: rotate(53deg);\n  transform: rotate(53deg);\n}\n.wi-wind.from-234-deg {\n  -webkit-transform: rotate(54deg);\n  -moz-transform: rotate(54deg);\n  -ms-transform: rotate(54deg);\n  -o-transform: rotate(54deg);\n  transform: rotate(54deg);\n}\n.wi-wind.from-235-deg {\n  -webkit-transform: rotate(55deg);\n  -moz-transform: rotate(55deg);\n  -ms-transform: rotate(55deg);\n  -o-transform: rotate(55deg);\n  transform: rotate(55deg);\n}\n.wi-wind.from-236-deg {\n  -webkit-transform: rotate(56deg);\n  -moz-transform: rotate(56deg);\n  -ms-transform: rotate(56deg);\n  -o-transform: rotate(56deg);\n  transform: rotate(56deg);\n}\n.wi-wind.from-237-deg {\n  -webkit-transform: rotate(57deg);\n  -moz-transform: rotate(57deg);\n  -ms-transform: rotate(57deg);\n  -o-transform: rotate(57deg);\n  transform: rotate(57deg);\n}\n.wi-wind.from-238-deg {\n  -webkit-transform: rotate(58deg);\n  -moz-transform: rotate(58deg);\n  -ms-transform: rotate(58deg);\n  -o-transform: rotate(58deg);\n  transform: rotate(58deg);\n}\n.wi-wind.from-239-deg {\n  -webkit-transform: rotate(59deg);\n  -moz-transform: rotate(59deg);\n  -ms-transform: rotate(59deg);\n  -o-transform: rotate(59deg);\n  transform: rotate(59deg);\n}\n.wi-wind.from-240-deg {\n  -webkit-transform: rotate(60deg);\n  -moz-transform: rotate(60deg);\n  -ms-transform: rotate(60deg);\n  -o-transform: rotate(60deg);\n  transform: rotate(60deg);\n}\n.wi-wind.from-241-deg {\n  -webkit-transform: rotate(61deg);\n  -moz-transform: rotate(61deg);\n  -ms-transform: rotate(61deg);\n  -o-transform: rotate(61deg);\n  transform: rotate(61deg);\n}\n.wi-wind.from-242-deg {\n  -webkit-transform: rotate(62deg);\n  -moz-transform: rotate(62deg);\n  -ms-transform: rotate(62deg);\n  -o-transform: rotate(62deg);\n  transform: rotate(62deg);\n}\n.wi-wind.from-243-deg {\n  -webkit-transform: rotate(63deg);\n  -moz-transform: rotate(63deg);\n  -ms-transform: rotate(63deg);\n  -o-transform: rotate(63deg);\n  transform: rotate(63deg);\n}\n.wi-wind.from-244-deg {\n  -webkit-transform: rotate(64deg);\n  -moz-transform: rotate(64deg);\n  -ms-transform: rotate(64deg);\n  -o-transform: rotate(64deg);\n  transform: rotate(64deg);\n}\n.wi-wind.from-245-deg {\n  -webkit-transform: rotate(65deg);\n  -moz-transform: rotate(65deg);\n  -ms-transform: rotate(65deg);\n  -o-transform: rotate(65deg);\n  transform: rotate(65deg);\n}\n.wi-wind.from-246-deg {\n  -webkit-transform: rotate(66deg);\n  -moz-transform: rotate(66deg);\n  -ms-transform: rotate(66deg);\n  -o-transform: rotate(66deg);\n  transform: rotate(66deg);\n}\n.wi-wind.from-247-deg {\n  -webkit-transform: rotate(67deg);\n  -moz-transform: rotate(67deg);\n  -ms-transform: rotate(67deg);\n  -o-transform: rotate(67deg);\n  transform: rotate(67deg);\n}\n.wi-wind.from-248-deg {\n  -webkit-transform: rotate(68deg);\n  -moz-transform: rotate(68deg);\n  -ms-transform: rotate(68deg);\n  -o-transform: rotate(68deg);\n  transform: rotate(68deg);\n}\n.wi-wind.from-249-deg {\n  -webkit-transform: rotate(69deg);\n  -moz-transform: rotate(69deg);\n  -ms-transform: rotate(69deg);\n  -o-transform: rotate(69deg);\n  transform: rotate(69deg);\n}\n.wi-wind.from-250-deg {\n  -webkit-transform: rotate(70deg);\n  -moz-transform: rotate(70deg);\n  -ms-transform: rotate(70deg);\n  -o-transform: rotate(70deg);\n  transform: rotate(70deg);\n}\n.wi-wind.from-251-deg {\n  -webkit-transform: rotate(71deg);\n  -moz-transform: rotate(71deg);\n  -ms-transform: rotate(71deg);\n  -o-transform: rotate(71deg);\n  transform: rotate(71deg);\n}\n.wi-wind.from-252-deg {\n  -webkit-transform: rotate(72deg);\n  -moz-transform: rotate(72deg);\n  -ms-transform: rotate(72deg);\n  -o-transform: rotate(72deg);\n  transform: rotate(72deg);\n}\n.wi-wind.from-253-deg {\n  -webkit-transform: rotate(73deg);\n  -moz-transform: rotate(73deg);\n  -ms-transform: rotate(73deg);\n  -o-transform: rotate(73deg);\n  transform: rotate(73deg);\n}\n.wi-wind.from-254-deg {\n  -webkit-transform: rotate(74deg);\n  -moz-transform: rotate(74deg);\n  -ms-transform: rotate(74deg);\n  -o-transform: rotate(74deg);\n  transform: rotate(74deg);\n}\n.wi-wind.from-255-deg {\n  -webkit-transform: rotate(75deg);\n  -moz-transform: rotate(75deg);\n  -ms-transform: rotate(75deg);\n  -o-transform: rotate(75deg);\n  transform: rotate(75deg);\n}\n.wi-wind.from-256-deg {\n  -webkit-transform: rotate(76deg);\n  -moz-transform: rotate(76deg);\n  -ms-transform: rotate(76deg);\n  -o-transform: rotate(76deg);\n  transform: rotate(76deg);\n}\n.wi-wind.from-257-deg {\n  -webkit-transform: rotate(77deg);\n  -moz-transform: rotate(77deg);\n  -ms-transform: rotate(77deg);\n  -o-transform: rotate(77deg);\n  transform: rotate(77deg);\n}\n.wi-wind.from-258-deg {\n  -webkit-transform: rotate(78deg);\n  -moz-transform: rotate(78deg);\n  -ms-transform: rotate(78deg);\n  -o-transform: rotate(78deg);\n  transform: rotate(78deg);\n}\n.wi-wind.from-259-deg {\n  -webkit-transform: rotate(79deg);\n  -moz-transform: rotate(79deg);\n  -ms-transform: rotate(79deg);\n  -o-transform: rotate(79deg);\n  transform: rotate(79deg);\n}\n.wi-wind.from-260-deg {\n  -webkit-transform: rotate(80deg);\n  -moz-transform: rotate(80deg);\n  -ms-transform: rotate(80deg);\n  -o-transform: rotate(80deg);\n  transform: rotate(80deg);\n}\n.wi-wind.from-261-deg {\n  -webkit-transform: rotate(81deg);\n  -moz-transform: rotate(81deg);\n  -ms-transform: rotate(81deg);\n  -o-transform: rotate(81deg);\n  transform: rotate(81deg);\n}\n.wi-wind.from-262-deg {\n  -webkit-transform: rotate(82deg);\n  -moz-transform: rotate(82deg);\n  -ms-transform: rotate(82deg);\n  -o-transform: rotate(82deg);\n  transform: rotate(82deg);\n}\n.wi-wind.from-263-deg {\n  -webkit-transform: rotate(83deg);\n  -moz-transform: rotate(83deg);\n  -ms-transform: rotate(83deg);\n  -o-transform: rotate(83deg);\n  transform: rotate(83deg);\n}\n.wi-wind.from-264-deg {\n  -webkit-transform: rotate(84deg);\n  -moz-transform: rotate(84deg);\n  -ms-transform: rotate(84deg);\n  -o-transform: rotate(84deg);\n  transform: rotate(84deg);\n}\n.wi-wind.from-265-deg {\n  -webkit-transform: rotate(85deg);\n  -moz-transform: rotate(85deg);\n  -ms-transform: rotate(85deg);\n  -o-transform: rotate(85deg);\n  transform: rotate(85deg);\n}\n.wi-wind.from-266-deg {\n  -webkit-transform: rotate(86deg);\n  -moz-transform: rotate(86deg);\n  -ms-transform: rotate(86deg);\n  -o-transform: rotate(86deg);\n  transform: rotate(86deg);\n}\n.wi-wind.from-267-deg {\n  -webkit-transform: rotate(87deg);\n  -moz-transform: rotate(87deg);\n  -ms-transform: rotate(87deg);\n  -o-transform: rotate(87deg);\n  transform: rotate(87deg);\n}\n.wi-wind.from-268-deg {\n  -webkit-transform: rotate(88deg);\n  -moz-transform: rotate(88deg);\n  -ms-transform: rotate(88deg);\n  -o-transform: rotate(88deg);\n  transform: rotate(88deg);\n}\n.wi-wind.from-269-deg {\n  -webkit-transform: rotate(89deg);\n  -moz-transform: rotate(89deg);\n  -ms-transform: rotate(89deg);\n  -o-transform: rotate(89deg);\n  transform: rotate(89deg);\n}\n.wi-wind.from-270-deg {\n  -webkit-transform: rotate(90deg);\n  -moz-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  -o-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-wind.from-271-deg {\n  -webkit-transform: rotate(91deg);\n  -moz-transform: rotate(91deg);\n  -ms-transform: rotate(91deg);\n  -o-transform: rotate(91deg);\n  transform: rotate(91deg);\n}\n.wi-wind.from-272-deg {\n  -webkit-transform: rotate(92deg);\n  -moz-transform: rotate(92deg);\n  -ms-transform: rotate(92deg);\n  -o-transform: rotate(92deg);\n  transform: rotate(92deg);\n}\n.wi-wind.from-273-deg {\n  -webkit-transform: rotate(93deg);\n  -moz-transform: rotate(93deg);\n  -ms-transform: rotate(93deg);\n  -o-transform: rotate(93deg);\n  transform: rotate(93deg);\n}\n.wi-wind.from-274-deg {\n  -webkit-transform: rotate(94deg);\n  -moz-transform: rotate(94deg);\n  -ms-transform: rotate(94deg);\n  -o-transform: rotate(94deg);\n  transform: rotate(94deg);\n}\n.wi-wind.from-275-deg {\n  -webkit-transform: rotate(95deg);\n  -moz-transform: rotate(95deg);\n  -ms-transform: rotate(95deg);\n  -o-transform: rotate(95deg);\n  transform: rotate(95deg);\n}\n.wi-wind.from-276-deg {\n  -webkit-transform: rotate(96deg);\n  -moz-transform: rotate(96deg);\n  -ms-transform: rotate(96deg);\n  -o-transform: rotate(96deg);\n  transform: rotate(96deg);\n}\n.wi-wind.from-277-deg {\n  -webkit-transform: rotate(97deg);\n  -moz-transform: rotate(97deg);\n  -ms-transform: rotate(97deg);\n  -o-transform: rotate(97deg);\n  transform: rotate(97deg);\n}\n.wi-wind.from-278-deg {\n  -webkit-transform: rotate(98deg);\n  -moz-transform: rotate(98deg);\n  -ms-transform: rotate(98deg);\n  -o-transform: rotate(98deg);\n  transform: rotate(98deg);\n}\n.wi-wind.from-279-deg {\n  -webkit-transform: rotate(99deg);\n  -moz-transform: rotate(99deg);\n  -ms-transform: rotate(99deg);\n  -o-transform: rotate(99deg);\n  transform: rotate(99deg);\n}\n.wi-wind.from-280-deg {\n  -webkit-transform: rotate(100deg);\n  -moz-transform: rotate(100deg);\n  -ms-transform: rotate(100deg);\n  -o-transform: rotate(100deg);\n  transform: rotate(100deg);\n}\n.wi-wind.from-281-deg {\n  -webkit-transform: rotate(101deg);\n  -moz-transform: rotate(101deg);\n  -ms-transform: rotate(101deg);\n  -o-transform: rotate(101deg);\n  transform: rotate(101deg);\n}\n.wi-wind.from-282-deg {\n  -webkit-transform: rotate(102deg);\n  -moz-transform: rotate(102deg);\n  -ms-transform: rotate(102deg);\n  -o-transform: rotate(102deg);\n  transform: rotate(102deg);\n}\n.wi-wind.from-283-deg {\n  -webkit-transform: rotate(103deg);\n  -moz-transform: rotate(103deg);\n  -ms-transform: rotate(103deg);\n  -o-transform: rotate(103deg);\n  transform: rotate(103deg);\n}\n.wi-wind.from-284-deg {\n  -webkit-transform: rotate(104deg);\n  -moz-transform: rotate(104deg);\n  -ms-transform: rotate(104deg);\n  -o-transform: rotate(104deg);\n  transform: rotate(104deg);\n}\n.wi-wind.from-285-deg {\n  -webkit-transform: rotate(105deg);\n  -moz-transform: rotate(105deg);\n  -ms-transform: rotate(105deg);\n  -o-transform: rotate(105deg);\n  transform: rotate(105deg);\n}\n.wi-wind.from-286-deg {\n  -webkit-transform: rotate(106deg);\n  -moz-transform: rotate(106deg);\n  -ms-transform: rotate(106deg);\n  -o-transform: rotate(106deg);\n  transform: rotate(106deg);\n}\n.wi-wind.from-287-deg {\n  -webkit-transform: rotate(107deg);\n  -moz-transform: rotate(107deg);\n  -ms-transform: rotate(107deg);\n  -o-transform: rotate(107deg);\n  transform: rotate(107deg);\n}\n.wi-wind.from-288-deg {\n  -webkit-transform: rotate(108deg);\n  -moz-transform: rotate(108deg);\n  -ms-transform: rotate(108deg);\n  -o-transform: rotate(108deg);\n  transform: rotate(108deg);\n}\n.wi-wind.from-289-deg {\n  -webkit-transform: rotate(109deg);\n  -moz-transform: rotate(109deg);\n  -ms-transform: rotate(109deg);\n  -o-transform: rotate(109deg);\n  transform: rotate(109deg);\n}\n.wi-wind.from-290-deg {\n  -webkit-transform: rotate(110deg);\n  -moz-transform: rotate(110deg);\n  -ms-transform: rotate(110deg);\n  -o-transform: rotate(110deg);\n  transform: rotate(110deg);\n}\n.wi-wind.from-291-deg {\n  -webkit-transform: rotate(111deg);\n  -moz-transform: rotate(111deg);\n  -ms-transform: rotate(111deg);\n  -o-transform: rotate(111deg);\n  transform: rotate(111deg);\n}\n.wi-wind.from-292-deg {\n  -webkit-transform: rotate(112deg);\n  -moz-transform: rotate(112deg);\n  -ms-transform: rotate(112deg);\n  -o-transform: rotate(112deg);\n  transform: rotate(112deg);\n}\n.wi-wind.from-293-deg {\n  -webkit-transform: rotate(113deg);\n  -moz-transform: rotate(113deg);\n  -ms-transform: rotate(113deg);\n  -o-transform: rotate(113deg);\n  transform: rotate(113deg);\n}\n.wi-wind.from-294-deg {\n  -webkit-transform: rotate(114deg);\n  -moz-transform: rotate(114deg);\n  -ms-transform: rotate(114deg);\n  -o-transform: rotate(114deg);\n  transform: rotate(114deg);\n}\n.wi-wind.from-295-deg {\n  -webkit-transform: rotate(115deg);\n  -moz-transform: rotate(115deg);\n  -ms-transform: rotate(115deg);\n  -o-transform: rotate(115deg);\n  transform: rotate(115deg);\n}\n.wi-wind.from-296-deg {\n  -webkit-transform: rotate(116deg);\n  -moz-transform: rotate(116deg);\n  -ms-transform: rotate(116deg);\n  -o-transform: rotate(116deg);\n  transform: rotate(116deg);\n}\n.wi-wind.from-297-deg {\n  -webkit-transform: rotate(117deg);\n  -moz-transform: rotate(117deg);\n  -ms-transform: rotate(117deg);\n  -o-transform: rotate(117deg);\n  transform: rotate(117deg);\n}\n.wi-wind.from-298-deg {\n  -webkit-transform: rotate(118deg);\n  -moz-transform: rotate(118deg);\n  -ms-transform: rotate(118deg);\n  -o-transform: rotate(118deg);\n  transform: rotate(118deg);\n}\n.wi-wind.from-299-deg {\n  -webkit-transform: rotate(119deg);\n  -moz-transform: rotate(119deg);\n  -ms-transform: rotate(119deg);\n  -o-transform: rotate(119deg);\n  transform: rotate(119deg);\n}\n.wi-wind.from-300-deg {\n  -webkit-transform: rotate(120deg);\n  -moz-transform: rotate(120deg);\n  -ms-transform: rotate(120deg);\n  -o-transform: rotate(120deg);\n  transform: rotate(120deg);\n}\n.wi-wind.from-301-deg {\n  -webkit-transform: rotate(121deg);\n  -moz-transform: rotate(121deg);\n  -ms-transform: rotate(121deg);\n  -o-transform: rotate(121deg);\n  transform: rotate(121deg);\n}\n.wi-wind.from-302-deg {\n  -webkit-transform: rotate(122deg);\n  -moz-transform: rotate(122deg);\n  -ms-transform: rotate(122deg);\n  -o-transform: rotate(122deg);\n  transform: rotate(122deg);\n}\n.wi-wind.from-303-deg {\n  -webkit-transform: rotate(123deg);\n  -moz-transform: rotate(123deg);\n  -ms-transform: rotate(123deg);\n  -o-transform: rotate(123deg);\n  transform: rotate(123deg);\n}\n.wi-wind.from-304-deg {\n  -webkit-transform: rotate(124deg);\n  -moz-transform: rotate(124deg);\n  -ms-transform: rotate(124deg);\n  -o-transform: rotate(124deg);\n  transform: rotate(124deg);\n}\n.wi-wind.from-305-deg {\n  -webkit-transform: rotate(125deg);\n  -moz-transform: rotate(125deg);\n  -ms-transform: rotate(125deg);\n  -o-transform: rotate(125deg);\n  transform: rotate(125deg);\n}\n.wi-wind.from-306-deg {\n  -webkit-transform: rotate(126deg);\n  -moz-transform: rotate(126deg);\n  -ms-transform: rotate(126deg);\n  -o-transform: rotate(126deg);\n  transform: rotate(126deg);\n}\n.wi-wind.from-307-deg {\n  -webkit-transform: rotate(127deg);\n  -moz-transform: rotate(127deg);\n  -ms-transform: rotate(127deg);\n  -o-transform: rotate(127deg);\n  transform: rotate(127deg);\n}\n.wi-wind.from-308-deg {\n  -webkit-transform: rotate(128deg);\n  -moz-transform: rotate(128deg);\n  -ms-transform: rotate(128deg);\n  -o-transform: rotate(128deg);\n  transform: rotate(128deg);\n}\n.wi-wind.from-309-deg {\n  -webkit-transform: rotate(129deg);\n  -moz-transform: rotate(129deg);\n  -ms-transform: rotate(129deg);\n  -o-transform: rotate(129deg);\n  transform: rotate(129deg);\n}\n.wi-wind.from-310-deg {\n  -webkit-transform: rotate(130deg);\n  -moz-transform: rotate(130deg);\n  -ms-transform: rotate(130deg);\n  -o-transform: rotate(130deg);\n  transform: rotate(130deg);\n}\n.wi-wind.from-311-deg {\n  -webkit-transform: rotate(131deg);\n  -moz-transform: rotate(131deg);\n  -ms-transform: rotate(131deg);\n  -o-transform: rotate(131deg);\n  transform: rotate(131deg);\n}\n.wi-wind.from-312-deg {\n  -webkit-transform: rotate(132deg);\n  -moz-transform: rotate(132deg);\n  -ms-transform: rotate(132deg);\n  -o-transform: rotate(132deg);\n  transform: rotate(132deg);\n}\n.wi-wind.from-313-deg {\n  -webkit-transform: rotate(133deg);\n  -moz-transform: rotate(133deg);\n  -ms-transform: rotate(133deg);\n  -o-transform: rotate(133deg);\n  transform: rotate(133deg);\n}\n.wi-wind.from-314-deg {\n  -webkit-transform: rotate(134deg);\n  -moz-transform: rotate(134deg);\n  -ms-transform: rotate(134deg);\n  -o-transform: rotate(134deg);\n  transform: rotate(134deg);\n}\n.wi-wind.from-315-deg {\n  -webkit-transform: rotate(135deg);\n  -moz-transform: rotate(135deg);\n  -ms-transform: rotate(135deg);\n  -o-transform: rotate(135deg);\n  transform: rotate(135deg);\n}\n.wi-wind.from-316-deg {\n  -webkit-transform: rotate(136deg);\n  -moz-transform: rotate(136deg);\n  -ms-transform: rotate(136deg);\n  -o-transform: rotate(136deg);\n  transform: rotate(136deg);\n}\n.wi-wind.from-317-deg {\n  -webkit-transform: rotate(137deg);\n  -moz-transform: rotate(137deg);\n  -ms-transform: rotate(137deg);\n  -o-transform: rotate(137deg);\n  transform: rotate(137deg);\n}\n.wi-wind.from-318-deg {\n  -webkit-transform: rotate(138deg);\n  -moz-transform: rotate(138deg);\n  -ms-transform: rotate(138deg);\n  -o-transform: rotate(138deg);\n  transform: rotate(138deg);\n}\n.wi-wind.from-319-deg {\n  -webkit-transform: rotate(139deg);\n  -moz-transform: rotate(139deg);\n  -ms-transform: rotate(139deg);\n  -o-transform: rotate(139deg);\n  transform: rotate(139deg);\n}\n.wi-wind.from-320-deg {\n  -webkit-transform: rotate(140deg);\n  -moz-transform: rotate(140deg);\n  -ms-transform: rotate(140deg);\n  -o-transform: rotate(140deg);\n  transform: rotate(140deg);\n}\n.wi-wind.from-321-deg {\n  -webkit-transform: rotate(141deg);\n  -moz-transform: rotate(141deg);\n  -ms-transform: rotate(141deg);\n  -o-transform: rotate(141deg);\n  transform: rotate(141deg);\n}\n.wi-wind.from-322-deg {\n  -webkit-transform: rotate(142deg);\n  -moz-transform: rotate(142deg);\n  -ms-transform: rotate(142deg);\n  -o-transform: rotate(142deg);\n  transform: rotate(142deg);\n}\n.wi-wind.from-323-deg {\n  -webkit-transform: rotate(143deg);\n  -moz-transform: rotate(143deg);\n  -ms-transform: rotate(143deg);\n  -o-transform: rotate(143deg);\n  transform: rotate(143deg);\n}\n.wi-wind.from-324-deg {\n  -webkit-transform: rotate(144deg);\n  -moz-transform: rotate(144deg);\n  -ms-transform: rotate(144deg);\n  -o-transform: rotate(144deg);\n  transform: rotate(144deg);\n}\n.wi-wind.from-325-deg {\n  -webkit-transform: rotate(145deg);\n  -moz-transform: rotate(145deg);\n  -ms-transform: rotate(145deg);\n  -o-transform: rotate(145deg);\n  transform: rotate(145deg);\n}\n.wi-wind.from-326-deg {\n  -webkit-transform: rotate(146deg);\n  -moz-transform: rotate(146deg);\n  -ms-transform: rotate(146deg);\n  -o-transform: rotate(146deg);\n  transform: rotate(146deg);\n}\n.wi-wind.from-327-deg {\n  -webkit-transform: rotate(147deg);\n  -moz-transform: rotate(147deg);\n  -ms-transform: rotate(147deg);\n  -o-transform: rotate(147deg);\n  transform: rotate(147deg);\n}\n.wi-wind.from-328-deg {\n  -webkit-transform: rotate(148deg);\n  -moz-transform: rotate(148deg);\n  -ms-transform: rotate(148deg);\n  -o-transform: rotate(148deg);\n  transform: rotate(148deg);\n}\n.wi-wind.from-329-deg {\n  -webkit-transform: rotate(149deg);\n  -moz-transform: rotate(149deg);\n  -ms-transform: rotate(149deg);\n  -o-transform: rotate(149deg);\n  transform: rotate(149deg);\n}\n.wi-wind.from-330-deg {\n  -webkit-transform: rotate(150deg);\n  -moz-transform: rotate(150deg);\n  -ms-transform: rotate(150deg);\n  -o-transform: rotate(150deg);\n  transform: rotate(150deg);\n}\n.wi-wind.from-331-deg {\n  -webkit-transform: rotate(151deg);\n  -moz-transform: rotate(151deg);\n  -ms-transform: rotate(151deg);\n  -o-transform: rotate(151deg);\n  transform: rotate(151deg);\n}\n.wi-wind.from-332-deg {\n  -webkit-transform: rotate(152deg);\n  -moz-transform: rotate(152deg);\n  -ms-transform: rotate(152deg);\n  -o-transform: rotate(152deg);\n  transform: rotate(152deg);\n}\n.wi-wind.from-333-deg {\n  -webkit-transform: rotate(153deg);\n  -moz-transform: rotate(153deg);\n  -ms-transform: rotate(153deg);\n  -o-transform: rotate(153deg);\n  transform: rotate(153deg);\n}\n.wi-wind.from-334-deg {\n  -webkit-transform: rotate(154deg);\n  -moz-transform: rotate(154deg);\n  -ms-transform: rotate(154deg);\n  -o-transform: rotate(154deg);\n  transform: rotate(154deg);\n}\n.wi-wind.from-335-deg {\n  -webkit-transform: rotate(155deg);\n  -moz-transform: rotate(155deg);\n  -ms-transform: rotate(155deg);\n  -o-transform: rotate(155deg);\n  transform: rotate(155deg);\n}\n.wi-wind.from-336-deg {\n  -webkit-transform: rotate(156deg);\n  -moz-transform: rotate(156deg);\n  -ms-transform: rotate(156deg);\n  -o-transform: rotate(156deg);\n  transform: rotate(156deg);\n}\n.wi-wind.from-337-deg {\n  -webkit-transform: rotate(157deg);\n  -moz-transform: rotate(157deg);\n  -ms-transform: rotate(157deg);\n  -o-transform: rotate(157deg);\n  transform: rotate(157deg);\n}\n.wi-wind.from-338-deg {\n  -webkit-transform: rotate(158deg);\n  -moz-transform: rotate(158deg);\n  -ms-transform: rotate(158deg);\n  -o-transform: rotate(158deg);\n  transform: rotate(158deg);\n}\n.wi-wind.from-339-deg {\n  -webkit-transform: rotate(159deg);\n  -moz-transform: rotate(159deg);\n  -ms-transform: rotate(159deg);\n  -o-transform: rotate(159deg);\n  transform: rotate(159deg);\n}\n.wi-wind.from-340-deg {\n  -webkit-transform: rotate(160deg);\n  -moz-transform: rotate(160deg);\n  -ms-transform: rotate(160deg);\n  -o-transform: rotate(160deg);\n  transform: rotate(160deg);\n}\n.wi-wind.from-341-deg {\n  -webkit-transform: rotate(161deg);\n  -moz-transform: rotate(161deg);\n  -ms-transform: rotate(161deg);\n  -o-transform: rotate(161deg);\n  transform: rotate(161deg);\n}\n.wi-wind.from-342-deg {\n  -webkit-transform: rotate(162deg);\n  -moz-transform: rotate(162deg);\n  -ms-transform: rotate(162deg);\n  -o-transform: rotate(162deg);\n  transform: rotate(162deg);\n}\n.wi-wind.from-343-deg {\n  -webkit-transform: rotate(163deg);\n  -moz-transform: rotate(163deg);\n  -ms-transform: rotate(163deg);\n  -o-transform: rotate(163deg);\n  transform: rotate(163deg);\n}\n.wi-wind.from-344-deg {\n  -webkit-transform: rotate(164deg);\n  -moz-transform: rotate(164deg);\n  -ms-transform: rotate(164deg);\n  -o-transform: rotate(164deg);\n  transform: rotate(164deg);\n}\n.wi-wind.from-345-deg {\n  -webkit-transform: rotate(165deg);\n  -moz-transform: rotate(165deg);\n  -ms-transform: rotate(165deg);\n  -o-transform: rotate(165deg);\n  transform: rotate(165deg);\n}\n.wi-wind.from-346-deg {\n  -webkit-transform: rotate(166deg);\n  -moz-transform: rotate(166deg);\n  -ms-transform: rotate(166deg);\n  -o-transform: rotate(166deg);\n  transform: rotate(166deg);\n}\n.wi-wind.from-347-deg {\n  -webkit-transform: rotate(167deg);\n  -moz-transform: rotate(167deg);\n  -ms-transform: rotate(167deg);\n  -o-transform: rotate(167deg);\n  transform: rotate(167deg);\n}\n.wi-wind.from-348-deg {\n  -webkit-transform: rotate(168deg);\n  -moz-transform: rotate(168deg);\n  -ms-transform: rotate(168deg);\n  -o-transform: rotate(168deg);\n  transform: rotate(168deg);\n}\n.wi-wind.from-349-deg {\n  -webkit-transform: rotate(169deg);\n  -moz-transform: rotate(169deg);\n  -ms-transform: rotate(169deg);\n  -o-transform: rotate(169deg);\n  transform: rotate(169deg);\n}\n.wi-wind.from-350-deg {\n  -webkit-transform: rotate(170deg);\n  -moz-transform: rotate(170deg);\n  -ms-transform: rotate(170deg);\n  -o-transform: rotate(170deg);\n  transform: rotate(170deg);\n}\n.wi-wind.from-351-deg {\n  -webkit-transform: rotate(171deg);\n  -moz-transform: rotate(171deg);\n  -ms-transform: rotate(171deg);\n  -o-transform: rotate(171deg);\n  transform: rotate(171deg);\n}\n.wi-wind.from-352-deg {\n  -webkit-transform: rotate(172deg);\n  -moz-transform: rotate(172deg);\n  -ms-transform: rotate(172deg);\n  -o-transform: rotate(172deg);\n  transform: rotate(172deg);\n}\n.wi-wind.from-353-deg {\n  -webkit-transform: rotate(173deg);\n  -moz-transform: rotate(173deg);\n  -ms-transform: rotate(173deg);\n  -o-transform: rotate(173deg);\n  transform: rotate(173deg);\n}\n.wi-wind.from-354-deg {\n  -webkit-transform: rotate(174deg);\n  -moz-transform: rotate(174deg);\n  -ms-transform: rotate(174deg);\n  -o-transform: rotate(174deg);\n  transform: rotate(174deg);\n}\n.wi-wind.from-355-deg {\n  -webkit-transform: rotate(175deg);\n  -moz-transform: rotate(175deg);\n  -ms-transform: rotate(175deg);\n  -o-transform: rotate(175deg);\n  transform: rotate(175deg);\n}\n.wi-wind.from-356-deg {\n  -webkit-transform: rotate(176deg);\n  -moz-transform: rotate(176deg);\n  -ms-transform: rotate(176deg);\n  -o-transform: rotate(176deg);\n  transform: rotate(176deg);\n}\n.wi-wind.from-357-deg {\n  -webkit-transform: rotate(177deg);\n  -moz-transform: rotate(177deg);\n  -ms-transform: rotate(177deg);\n  -o-transform: rotate(177deg);\n  transform: rotate(177deg);\n}\n.wi-wind.from-358-deg {\n  -webkit-transform: rotate(178deg);\n  -moz-transform: rotate(178deg);\n  -ms-transform: rotate(178deg);\n  -o-transform: rotate(178deg);\n  transform: rotate(178deg);\n}\n.wi-wind.from-359-deg {\n  -webkit-transform: rotate(179deg);\n  -moz-transform: rotate(179deg);\n  -ms-transform: rotate(179deg);\n  -o-transform: rotate(179deg);\n  transform: rotate(179deg);\n}\n.wi-wind.from-360-deg {\n  -webkit-transform: rotate(180deg);\n  -moz-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  -o-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-towards-n {\n  -webkit-transform: rotate(0deg);\n  -moz-transform: rotate(0deg);\n  -ms-transform: rotate(0deg);\n  -o-transform: rotate(0deg);\n  transform: rotate(0deg);\n}\n.wi-towards-nne {\n  -webkit-transform: rotate(23deg);\n  -moz-transform: rotate(23deg);\n  -ms-transform: rotate(23deg);\n  -o-transform: rotate(23deg);\n  transform: rotate(23deg);\n}\n.wi-towards-ne {\n  -webkit-transform: rotate(45deg);\n  -moz-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg);\n}\n.wi-towards-ene {\n  -webkit-transform: rotate(68deg);\n  -moz-transform: rotate(68deg);\n  -ms-transform: rotate(68deg);\n  -o-transform: rotate(68deg);\n  transform: rotate(68deg);\n}\n.wi-towards-e {\n  -webkit-transform: rotate(90deg);\n  -moz-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  -o-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-towards-ese {\n  -webkit-transform: rotate(113deg);\n  -moz-transform: rotate(113deg);\n  -ms-transform: rotate(113deg);\n  -o-transform: rotate(113deg);\n  transform: rotate(113deg);\n}\n.wi-towards-se {\n  -webkit-transform: rotate(135deg);\n  -moz-transform: rotate(135deg);\n  -ms-transform: rotate(135deg);\n  -o-transform: rotate(135deg);\n  transform: rotate(135deg);\n}\n.wi-towards-sse {\n  -webkit-transform: rotate(158deg);\n  -moz-transform: rotate(158deg);\n  -ms-transform: rotate(158deg);\n  -o-transform: rotate(158deg);\n  transform: rotate(158deg);\n}\n.wi-towards-s {\n  -webkit-transform: rotate(180deg);\n  -moz-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  -o-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-towards-ssw {\n  -webkit-transform: rotate(203deg);\n  -moz-transform: rotate(203deg);\n  -ms-transform: rotate(203deg);\n  -o-transform: rotate(203deg);\n  transform: rotate(203deg);\n}\n.wi-towards-sw {\n  -webkit-transform: rotate(225deg);\n  -moz-transform: rotate(225deg);\n  -ms-transform: rotate(225deg);\n  -o-transform: rotate(225deg);\n  transform: rotate(225deg);\n}\n.wi-towards-wsw {\n  -webkit-transform: rotate(248deg);\n  -moz-transform: rotate(248deg);\n  -ms-transform: rotate(248deg);\n  -o-transform: rotate(248deg);\n  transform: rotate(248deg);\n}\n.wi-towards-w {\n  -webkit-transform: rotate(270deg);\n  -moz-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  -o-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-towards-wnw {\n  -webkit-transform: rotate(293deg);\n  -moz-transform: rotate(293deg);\n  -ms-transform: rotate(293deg);\n  -o-transform: rotate(293deg);\n  transform: rotate(293deg);\n}\n.wi-towards-nw {\n  -webkit-transform: rotate(313deg);\n  -moz-transform: rotate(313deg);\n  -ms-transform: rotate(313deg);\n  -o-transform: rotate(313deg);\n  transform: rotate(313deg);\n}\n.wi-towards-nnw {\n  -webkit-transform: rotate(336deg);\n  -moz-transform: rotate(336deg);\n  -ms-transform: rotate(336deg);\n  -o-transform: rotate(336deg);\n  transform: rotate(336deg);\n}\n.wi-from-n {\n  -webkit-transform: rotate(180deg);\n  -moz-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  -o-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.wi-from-nne {\n  -webkit-transform: rotate(203deg);\n  -moz-transform: rotate(203deg);\n  -ms-transform: rotate(203deg);\n  -o-transform: rotate(203deg);\n  transform: rotate(203deg);\n}\n.wi-from-ne {\n  -webkit-transform: rotate(225deg);\n  -moz-transform: rotate(225deg);\n  -ms-transform: rotate(225deg);\n  -o-transform: rotate(225deg);\n  transform: rotate(225deg);\n}\n.wi-from-ene {\n  -webkit-transform: rotate(248deg);\n  -moz-transform: rotate(248deg);\n  -ms-transform: rotate(248deg);\n  -o-transform: rotate(248deg);\n  transform: rotate(248deg);\n}\n.wi-from-e {\n  -webkit-transform: rotate(270deg);\n  -moz-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  -o-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.wi-from-ese {\n  -webkit-transform: rotate(293deg);\n  -moz-transform: rotate(293deg);\n  -ms-transform: rotate(293deg);\n  -o-transform: rotate(293deg);\n  transform: rotate(293deg);\n}\n.wi-from-se {\n  -webkit-transform: rotate(315deg);\n  -moz-transform: rotate(315deg);\n  -ms-transform: rotate(315deg);\n  -o-transform: rotate(315deg);\n  transform: rotate(315deg);\n}\n.wi-from-sse {\n  -webkit-transform: rotate(338deg);\n  -moz-transform: rotate(338deg);\n  -ms-transform: rotate(338deg);\n  -o-transform: rotate(338deg);\n  transform: rotate(338deg);\n}\n.wi-from-s {\n  -webkit-transform: rotate(0deg);\n  -moz-transform: rotate(0deg);\n  -ms-transform: rotate(0deg);\n  -o-transform: rotate(0deg);\n  transform: rotate(0deg);\n}\n.wi-from-ssw {\n  -webkit-transform: rotate(23deg);\n  -moz-transform: rotate(23deg);\n  -ms-transform: rotate(23deg);\n  -o-transform: rotate(23deg);\n  transform: rotate(23deg);\n}\n.wi-from-sw {\n  -webkit-transform: rotate(45deg);\n  -moz-transform: rotate(45deg);\n  -ms-transform: rotate(45deg);\n  -o-transform: rotate(45deg);\n  transform: rotate(45deg);\n}\n.wi-from-wsw {\n  -webkit-transform: rotate(68deg);\n  -moz-transform: rotate(68deg);\n  -ms-transform: rotate(68deg);\n  -o-transform: rotate(68deg);\n  transform: rotate(68deg);\n}\n.wi-from-w {\n  -webkit-transform: rotate(90deg);\n  -moz-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  -o-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.wi-from-wnw {\n  -webkit-transform: rotate(113deg);\n  -moz-transform: rotate(113deg);\n  -ms-transform: rotate(113deg);\n  -o-transform: rotate(113deg);\n  transform: rotate(113deg);\n}\n.wi-from-nw {\n  -webkit-transform: rotate(133deg);\n  -moz-transform: rotate(133deg);\n  -ms-transform: rotate(133deg);\n  -o-transform: rotate(133deg);\n  transform: rotate(133deg);\n}\n.wi-from-nnw {\n  -webkit-transform: rotate(156deg);\n  -moz-transform: rotate(156deg);\n  -ms-transform: rotate(156deg);\n  -o-transform: rotate(156deg);\n  transform: rotate(156deg);\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/css/weather-icons.css",
    "content": "/*!\n *  Weather Icons 2.0\n *  Updated August 1, 2015\n *  Weather themed icons for Bootstrap\n *  Author - Erik Flowers - erik@helloerik.com\n *  Email: erik@helloerik.com\n *  Twitter: http://twitter.com/Erik_UX\n *  ------------------------------------------------------------------------------\n *  Maintained at http://erikflowers.github.io/weather-icons\n *\n *  License\n *  ------------------------------------------------------------------------------\n *  - Font licensed under SIL OFL 1.1 -\n *    http://scripts.sil.org/OFL\n *  - CSS, SCSS and LESS are licensed under MIT License -\n *    http://opensource.org/licenses/mit-license.html\n *  - Documentation licensed under CC BY 3.0 -\n *    http://creativecommons.org/licenses/by/3.0/\n *  - Inspired by and works great as a companion with Font Awesome\n *    \"Font Awesome by Dave Gandy - http://fontawesome.io\"\n */\n\n@font-face {\n    font-family: 'weathericons';\n    src: url('..//fonts/weathericons-regular-webfont.eot');\n    src: url('..//fonts/weathericons-regular-webfont.eot?#iefix') format('embedded-opentype'), url('..//fonts/weathericons-regular-webfont.woff2') format('woff2'), url('..//fonts/weathericons-regular-webfont.woff') format('woff'), url('..//fonts/weathericons-regular-webfont.ttf') format('truetype'), url('..//fonts/weathericons-regular-webfont.svg#weather_iconsregular') format('svg');\n    font-weight: normal;\n    font-style: normal;\n}\n\n.wi {\n    display: inline-block;\n    font-family: 'weathericons';\n    font-style: normal;\n    font-weight: normal;\n    line-height: 1;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.wi-fw {\n    text-align: center;\n    width: 1.4em;\n}\n\n.wi-rotate-90 {\n    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=1);\n    -webkit-transform: rotate(90deg);\n    -ms-transform: rotate(90deg);\n    transform: rotate(90deg);\n}\n\n.wi-rotate-180 {\n    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=2);\n    -webkit-transform: rotate(180deg);\n    -ms-transform: rotate(180deg);\n    transform: rotate(180deg);\n}\n\n.wi-rotate-270 {\n    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=3);\n    -webkit-transform: rotate(270deg);\n    -ms-transform: rotate(270deg);\n    transform: rotate(270deg);\n}\n\n.wi-flip-horizontal {\n    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n    -webkit-transform: scale(-1, 1);\n    -ms-transform: scale(-1, 1);\n    transform: scale(-1, 1);\n}\n\n.wi-flip-vertical {\n    filter: progid: DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n    -webkit-transform: scale(1, -1);\n    -ms-transform: scale(1, -1);\n    transform: scale(1, -1);\n}\n\n.wi-day-sunny:before {\n    content: \"\\f00d\";\n}\n\n.wi-day-cloudy:before {\n    content: \"\\f002\";\n}\n\n.wi-day-cloudy-gusts:before {\n    content: \"\\f000\";\n}\n\n.wi-day-cloudy-windy:before {\n    content: \"\\f001\";\n}\n\n.wi-day-fog:before {\n    content: \"\\f003\";\n}\n\n.wi-day-hail:before {\n    content: \"\\f004\";\n}\n\n.wi-day-haze:before {\n    content: \"\\f0b6\";\n}\n\n.wi-day-lightning:before {\n    content: \"\\f005\";\n}\n\n.wi-day-rain:before {\n    content: \"\\f008\";\n}\n\n.wi-day-rain-mix:before {\n    content: \"\\f006\";\n}\n\n.wi-day-rain-wind:before {\n    content: \"\\f007\";\n}\n\n.wi-day-showers:before {\n    content: \"\\f009\";\n}\n\n.wi-day-sleet:before {\n    content: \"\\f0b2\";\n}\n\n.wi-day-sleet-storm:before {\n    content: \"\\f068\";\n}\n\n.wi-day-snow:before {\n    content: \"\\f00a\";\n}\n\n.wi-day-snow-thunderstorm:before {\n    content: \"\\f06b\";\n}\n\n.wi-day-snow-wind:before {\n    content: \"\\f065\";\n}\n\n.wi-day-sprinkle:before {\n    content: \"\\f00b\";\n}\n\n.wi-day-storm-showers:before {\n    content: \"\\f00e\";\n}\n\n.wi-day-sunny-overcast:before {\n    content: \"\\f00c\";\n}\n\n.wi-day-thunderstorm:before {\n    content: \"\\f010\";\n}\n\n.wi-day-windy:before {\n    content: \"\\f085\";\n}\n\n.wi-solar-eclipse:before {\n    content: \"\\f06e\";\n}\n\n.wi-hot:before {\n    content: \"\\f072\";\n}\n\n.wi-day-cloudy-high:before {\n    content: \"\\f07d\";\n}\n\n.wi-day-light-wind:before {\n    content: \"\\f0c4\";\n}\n\n.wi-night-clear:before {\n    content: \"\\f02e\";\n}\n\n.wi-night-alt-cloudy:before {\n    content: \"\\f086\";\n}\n\n.wi-night-alt-cloudy-gusts:before {\n    content: \"\\f022\";\n}\n\n.wi-night-alt-cloudy-windy:before {\n    content: \"\\f023\";\n}\n\n.wi-night-alt-hail:before {\n    content: \"\\f024\";\n}\n\n.wi-night-alt-lightning:before {\n    content: \"\\f025\";\n}\n\n.wi-night-alt-rain:before {\n    content: \"\\f028\";\n}\n\n.wi-night-alt-rain-mix:before {\n    content: \"\\f026\";\n}\n\n.wi-night-alt-rain-wind:before {\n    content: \"\\f027\";\n}\n\n.wi-night-alt-showers:before {\n    content: \"\\f029\";\n}\n\n.wi-night-alt-sleet:before {\n    content: \"\\f0b4\";\n}\n\n.wi-night-alt-sleet-storm:before {\n    content: \"\\f06a\";\n}\n\n.wi-night-alt-snow:before {\n    content: \"\\f02a\";\n}\n\n.wi-night-alt-snow-thunderstorm:before {\n    content: \"\\f06d\";\n}\n\n.wi-night-alt-snow-wind:before {\n    content: \"\\f067\";\n}\n\n.wi-night-alt-sprinkle:before {\n    content: \"\\f02b\";\n}\n\n.wi-night-alt-storm-showers:before {\n    content: \"\\f02c\";\n}\n\n.wi-night-alt-thunderstorm:before {\n    content: \"\\f02d\";\n}\n\n.wi-night-cloudy:before {\n    content: \"\\f031\";\n}\n\n.wi-night-cloudy-gusts:before {\n    content: \"\\f02f\";\n}\n\n.wi-night-cloudy-windy:before {\n    content: \"\\f030\";\n}\n\n.wi-night-fog:before {\n    content: \"\\f04a\";\n}\n\n.wi-night-hail:before {\n    content: \"\\f032\";\n}\n\n.wi-night-lightning:before {\n    content: \"\\f033\";\n}\n\n.wi-night-partly-cloudy:before {\n    content: \"\\f083\";\n}\n\n.wi-night-rain:before {\n    content: \"\\f036\";\n}\n\n.wi-night-rain-mix:before {\n    content: \"\\f034\";\n}\n\n.wi-night-rain-wind:before {\n    content: \"\\f035\";\n}\n\n.wi-night-showers:before {\n    content: \"\\f037\";\n}\n\n.wi-night-sleet:before {\n    content: \"\\f0b3\";\n}\n\n.wi-night-sleet-storm:before {\n    content: \"\\f069\";\n}\n\n.wi-night-snow:before {\n    content: \"\\f038\";\n}\n\n.wi-night-snow-thunderstorm:before {\n    content: \"\\f06c\";\n}\n\n.wi-night-snow-wind:before {\n    content: \"\\f066\";\n}\n\n.wi-night-sprinkle:before {\n    content: \"\\f039\";\n}\n\n.wi-night-storm-showers:before {\n    content: \"\\f03a\";\n}\n\n.wi-night-thunderstorm:before {\n    content: \"\\f03b\";\n}\n\n.wi-lunar-eclipse:before {\n    content: \"\\f070\";\n}\n\n.wi-stars:before {\n    content: \"\\f077\";\n}\n\n.wi-storm-showers:before {\n    content: \"\\f01d\";\n}\n\n.wi-thunderstorm:before {\n    content: \"\\f01e\";\n}\n\n.wi-night-alt-cloudy-high:before {\n    content: \"\\f07e\";\n}\n\n.wi-night-cloudy-high:before {\n    content: \"\\f080\";\n}\n\n.wi-night-alt-partly-cloudy:before {\n    content: \"\\f081\";\n}\n\n.wi-cloud:before {\n    content: \"\\f041\";\n}\n\n.wi-cloudy:before {\n    content: \"\\f013\";\n}\n\n.wi-cloudy-gusts:before {\n    content: \"\\f011\";\n}\n\n.wi-cloudy-windy:before {\n    content: \"\\f012\";\n}\n\n.wi-fog:before {\n    content: \"\\f014\";\n}\n\n.wi-hail:before {\n    content: \"\\f015\";\n}\n\n.wi-rain:before {\n    content: \"\\f019\";\n}\n\n.wi-rain-mix:before {\n    content: \"\\f017\";\n}\n\n.wi-rain-wind:before {\n    content: \"\\f018\";\n}\n\n.wi-showers:before {\n    content: \"\\f01a\";\n}\n\n.wi-sleet:before {\n    content: \"\\f0b5\";\n}\n\n.wi-snow:before {\n    content: \"\\f01b\";\n}\n\n.wi-sprinkle:before {\n    content: \"\\f01c\";\n}\n\n.wi-storm-showers:before {\n    content: \"\\f01d\";\n}\n\n.wi-thunderstorm:before {\n    content: \"\\f01e\";\n}\n\n.wi-snow-wind:before {\n    content: \"\\f064\";\n}\n\n.wi-snow:before {\n    content: \"\\f01b\";\n}\n\n.wi-smog:before {\n    content: \"\\f074\";\n}\n\n.wi-smoke:before {\n    content: \"\\f062\";\n}\n\n.wi-lightning:before {\n    content: \"\\f016\";\n}\n\n.wi-raindrops:before {\n    content: \"\\f04e\";\n}\n\n.wi-raindrop:before {\n    content: \"\\f078\";\n}\n\n.wi-dust:before {\n    content: \"\\f063\";\n}\n\n.wi-snowflake-cold:before {\n    content: \"\\f076\";\n}\n\n.wi-windy:before {\n    content: \"\\f021\";\n}\n\n.wi-strong-wind:before {\n    content: \"\\f050\";\n}\n\n.wi-sandstorm:before {\n    content: \"\\f082\";\n}\n\n.wi-earthquake:before {\n    content: \"\\f0c6\";\n}\n\n.wi-fire:before {\n    content: \"\\f0c7\";\n}\n\n.wi-flood:before {\n    content: \"\\f07c\";\n}\n\n.wi-meteor:before {\n    content: \"\\f071\";\n}\n\n.wi-tsunami:before {\n    content: \"\\f0c5\";\n}\n\n.wi-volcano:before {\n    content: \"\\f0c8\";\n}\n\n.wi-hurricane:before {\n    content: \"\\f073\";\n}\n\n.wi-tornado:before {\n    content: \"\\f056\";\n}\n\n.wi-small-craft-advisory:before {\n    content: \"\\f0cc\";\n}\n\n.wi-gale-warning:before {\n    content: \"\\f0cd\";\n}\n\n.wi-storm-warning:before {\n    content: \"\\f0ce\";\n}\n\n.wi-hurricane-warning:before {\n    content: \"\\f0cf\";\n}\n\n.wi-wind-direction:before {\n    content: \"\\f0b1\";\n}\n\n.wi-alien:before {\n    content: \"\\f075\";\n}\n\n.wi-celsius:before {\n    content: \"\\f03c\";\n}\n\n.wi-fahrenheit:before {\n    content: \"\\f045\";\n}\n\n.wi-degrees:before {\n    content: \"\\f042\";\n}\n\n.wi-thermometer:before {\n    content: \"\\f055\";\n}\n\n.wi-thermometer-exterior:before {\n    content: \"\\f053\";\n}\n\n.wi-thermometer-internal:before {\n    content: \"\\f054\";\n}\n\n.wi-cloud-down:before {\n    content: \"\\f03d\";\n}\n\n.wi-cloud-up:before {\n    content: \"\\f040\";\n}\n\n.wi-cloud-refresh:before {\n    content: \"\\f03e\";\n}\n\n.wi-horizon:before {\n    content: \"\\f047\";\n}\n\n.wi-horizon-alt:before {\n    content: \"\\f046\";\n}\n\n.wi-sunrise:before {\n    content: \"\\f051\";\n}\n\n.wi-sunset:before {\n    content: \"\\f052\";\n}\n\n.wi-moonrise:before {\n    content: \"\\f0c9\";\n}\n\n.wi-moonset:before {\n    content: \"\\f0ca\";\n}\n\n.wi-refresh:before {\n    content: \"\\f04c\";\n}\n\n.wi-refresh-alt:before {\n    content: \"\\f04b\";\n}\n\n.wi-umbrella:before {\n    content: \"\\f084\";\n}\n\n.wi-barometer:before {\n    content: \"\\f079\";\n}\n\n.wi-humidity:before {\n    content: \"\\f07a\";\n}\n\n.wi-na:before {\n    content: \"\\f07b\";\n}\n\n.wi-train:before {\n    content: \"\\f0cb\";\n}\n\n.wi-moon-new:before {\n    content: \"\\f095\";\n}\n\n.wi-moon-waxing-cresent-1:before {\n    content: \"\\f096\";\n}\n\n.wi-moon-waxing-cresent-2:before {\n    content: \"\\f097\";\n}\n\n.wi-moon-waxing-cresent-3:before {\n    content: \"\\f098\";\n}\n\n.wi-moon-waxing-cresent-4:before {\n    content: \"\\f099\";\n}\n\n.wi-moon-waxing-cresent-5:before {\n    content: \"\\f09a\";\n}\n\n.wi-moon-waxing-cresent-6:before {\n    content: \"\\f09b\";\n}\n\n.wi-moon-first-quarter:before {\n    content: \"\\f09c\";\n}\n\n.wi-moon-waxing-gibbous-1:before {\n    content: \"\\f09d\";\n}\n\n.wi-moon-waxing-gibbous-2:before {\n    content: \"\\f09e\";\n}\n\n.wi-moon-waxing-gibbous-3:before {\n    content: \"\\f09f\";\n}\n\n.wi-moon-waxing-gibbous-4:before {\n    content: \"\\f0a0\";\n}\n\n.wi-moon-waxing-gibbous-5:before {\n    content: \"\\f0a1\";\n}\n\n.wi-moon-waxing-gibbous-6:before {\n    content: \"\\f0a2\";\n}\n\n.wi-moon-full:before {\n    content: \"\\f0a3\";\n}\n\n.wi-moon-waning-gibbous-1:before {\n    content: \"\\f0a4\";\n}\n\n.wi-moon-waning-gibbous-2:before {\n    content: \"\\f0a5\";\n}\n\n.wi-moon-waning-gibbous-3:before {\n    content: \"\\f0a6\";\n}\n\n.wi-moon-waning-gibbous-4:before {\n    content: \"\\f0a7\";\n}\n\n.wi-moon-waning-gibbous-5:before {\n    content: \"\\f0a8\";\n}\n\n.wi-moon-waning-gibbous-6:before {\n    content: \"\\f0a9\";\n}\n\n.wi-moon-third-quarter:before {\n    content: \"\\f0aa\";\n}\n\n.wi-moon-waning-crescent-1:before {\n    content: \"\\f0ab\";\n}\n\n.wi-moon-waning-crescent-2:before {\n    content: \"\\f0ac\";\n}\n\n.wi-moon-waning-crescent-3:before {\n    content: \"\\f0ad\";\n}\n\n.wi-moon-waning-crescent-4:before {\n    content: \"\\f0ae\";\n}\n\n.wi-moon-waning-crescent-5:before {\n    content: \"\\f0af\";\n}\n\n.wi-moon-waning-crescent-6:before {\n    content: \"\\f0b0\";\n}\n\n.wi-moon-alt-new:before {\n    content: \"\\f0eb\";\n}\n\n.wi-moon-alt-waxing-cresent-1:before {\n    content: \"\\f0d0\";\n}\n\n.wi-moon-alt-waxing-cresent-2:before {\n    content: \"\\f0d1\";\n}\n\n.wi-moon-alt-waxing-cresent-3:before {\n    content: \"\\f0d2\";\n}\n\n.wi-moon-alt-waxing-cresent-4:before {\n    content: \"\\f0d3\";\n}\n\n.wi-moon-alt-waxing-cresent-5:before {\n    content: \"\\f0d4\";\n}\n\n.wi-moon-alt-waxing-cresent-6:before {\n    content: \"\\f0d5\";\n}\n\n.wi-moon-alt-first-quarter:before {\n    content: \"\\f0d6\";\n}\n\n.wi-moon-alt-waxing-gibbous-1:before {\n    content: \"\\f0d7\";\n}\n\n.wi-moon-alt-waxing-gibbous-2:before {\n    content: \"\\f0d8\";\n}\n\n.wi-moon-alt-waxing-gibbous-3:before {\n    content: \"\\f0d9\";\n}\n\n.wi-moon-alt-waxing-gibbous-4:before {\n    content: \"\\f0da\";\n}\n\n.wi-moon-alt-waxing-gibbous-5:before {\n    content: \"\\f0db\";\n}\n\n.wi-moon-alt-waxing-gibbous-6:before {\n    content: \"\\f0dc\";\n}\n\n.wi-moon-alt-full:before {\n    content: \"\\f0dd\";\n}\n\n.wi-moon-alt-waning-gibbous-1:before {\n    content: \"\\f0de\";\n}\n\n.wi-moon-alt-waning-gibbous-2:before {\n    content: \"\\f0df\";\n}\n\n.wi-moon-alt-waning-gibbous-3:before {\n    content: \"\\f0e0\";\n}\n\n.wi-moon-alt-waning-gibbous-4:before {\n    content: \"\\f0e1\";\n}\n\n.wi-moon-alt-waning-gibbous-5:before {\n    content: \"\\f0e2\";\n}\n\n.wi-moon-alt-waning-gibbous-6:before {\n    content: \"\\f0e3\";\n}\n\n.wi-moon-alt-third-quarter:before {\n    content: \"\\f0e4\";\n}\n\n.wi-moon-alt-waning-crescent-1:before {\n    content: \"\\f0e5\";\n}\n\n.wi-moon-alt-waning-crescent-2:before {\n    content: \"\\f0e6\";\n}\n\n.wi-moon-alt-waning-crescent-3:before {\n    content: \"\\f0e7\";\n}\n\n.wi-moon-alt-waning-crescent-4:before {\n    content: \"\\f0e8\";\n}\n\n.wi-moon-alt-waning-crescent-5:before {\n    content: \"\\f0e9\";\n}\n\n.wi-moon-alt-waning-crescent-6:before {\n    content: \"\\f0ea\";\n}\n\n.wi-moon-0:before {\n    content: \"\\f095\";\n}\n\n.wi-moon-1:before {\n    content: \"\\f096\";\n}\n\n.wi-moon-2:before {\n    content: \"\\f097\";\n}\n\n.wi-moon-3:before {\n    content: \"\\f098\";\n}\n\n.wi-moon-4:before {\n    content: \"\\f099\";\n}\n\n.wi-moon-5:before {\n    content: \"\\f09a\";\n}\n\n.wi-moon-6:before {\n    content: \"\\f09b\";\n}\n\n.wi-moon-7:before {\n    content: \"\\f09c\";\n}\n\n.wi-moon-8:before {\n    content: \"\\f09d\";\n}\n\n.wi-moon-9:before {\n    content: \"\\f09e\";\n}\n\n.wi-moon-10:before {\n    content: \"\\f09f\";\n}\n\n.wi-moon-11:before {\n    content: \"\\f0a0\";\n}\n\n.wi-moon-12:before {\n    content: \"\\f0a1\";\n}\n\n.wi-moon-13:before {\n    content: \"\\f0a2\";\n}\n\n.wi-moon-14:before {\n    content: \"\\f0a3\";\n}\n\n.wi-moon-15:before {\n    content: \"\\f0a4\";\n}\n\n.wi-moon-16:before {\n    content: \"\\f0a5\";\n}\n\n.wi-moon-17:before {\n    content: \"\\f0a6\";\n}\n\n.wi-moon-18:before {\n    content: \"\\f0a7\";\n}\n\n.wi-moon-19:before {\n    content: \"\\f0a8\";\n}\n\n.wi-moon-20:before {\n    content: \"\\f0a9\";\n}\n\n.wi-moon-21:before {\n    content: \"\\f0aa\";\n}\n\n.wi-moon-22:before {\n    content: \"\\f0ab\";\n}\n\n.wi-moon-23:before {\n    content: \"\\f0ac\";\n}\n\n.wi-moon-24:before {\n    content: \"\\f0ad\";\n}\n\n.wi-moon-25:before {\n    content: \"\\f0ae\";\n}\n\n.wi-moon-26:before {\n    content: \"\\f0af\";\n}\n\n.wi-moon-27:before {\n    content: \"\\f0b0\";\n}\n\n.wi-time-1:before {\n    content: \"\\f08a\";\n}\n\n.wi-time-2:before {\n    content: \"\\f08b\";\n}\n\n.wi-time-3:before {\n    content: \"\\f08c\";\n}\n\n.wi-time-4:before {\n    content: \"\\f08d\";\n}\n\n.wi-time-5:before {\n    content: \"\\f08e\";\n}\n\n.wi-time-6:before {\n    content: \"\\f08f\";\n}\n\n.wi-time-7:before {\n    content: \"\\f090\";\n}\n\n.wi-time-8:before {\n    content: \"\\f091\";\n}\n\n.wi-time-9:before {\n    content: \"\\f092\";\n}\n\n.wi-time-10:before {\n    content: \"\\f093\";\n}\n\n.wi-time-11:before {\n    content: \"\\f094\";\n}\n\n.wi-time-12:before {\n    content: \"\\f089\";\n}\n\n.wi-direction-up:before {\n    content: \"\\f058\";\n}\n\n.wi-direction-up-right:before {\n    content: \"\\f057\";\n}\n\n.wi-direction-right:before {\n    content: \"\\f04d\";\n}\n\n.wi-direction-down-right:before {\n    content: \"\\f088\";\n}\n\n.wi-direction-down:before {\n    content: \"\\f044\";\n}\n\n.wi-direction-down-left:before {\n    content: \"\\f043\";\n}\n\n.wi-direction-left:before {\n    content: \"\\f048\";\n}\n\n.wi-direction-up-left:before {\n    content: \"\\f087\";\n}\n\n.wi-wind-beaufort-0:before {\n    content: \"\\f0b7\";\n}\n\n.wi-wind-beaufort-1:before {\n    content: \"\\f0b8\";\n}\n\n.wi-wind-beaufort-2:before {\n    content: \"\\f0b9\";\n}\n\n.wi-wind-beaufort-3:before {\n    content: \"\\f0ba\";\n}\n\n.wi-wind-beaufort-4:before {\n    content: \"\\f0bb\";\n}\n\n.wi-wind-beaufort-5:before {\n    content: \"\\f0bc\";\n}\n\n.wi-wind-beaufort-6:before {\n    content: \"\\f0bd\";\n}\n\n.wi-wind-beaufort-7:before {\n    content: \"\\f0be\";\n}\n\n.wi-wind-beaufort-8:before {\n    content: \"\\f0bf\";\n}\n\n.wi-wind-beaufort-9:before {\n    content: \"\\f0c0\";\n}\n\n.wi-wind-beaufort-10:before {\n    content: \"\\f0c1\";\n}\n\n.wi-wind-beaufort-11:before {\n    content: \"\\f0c2\";\n}\n\n.wi-wind-beaufort-12:before {\n    content: \"\\f0c3\";\n}\n\n.wi-yahoo-0:before {\n    content: \"\\f056\";\n}\n\n.wi-yahoo-1:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-2:before {\n    content: \"\\f073\";\n}\n\n.wi-yahoo-3:before {\n    content: \"\\f01e\";\n}\n\n.wi-yahoo-4:before {\n    content: \"\\f01e\";\n}\n\n.wi-yahoo-5:before {\n    content: \"\\f017\";\n}\n\n.wi-yahoo-6:before {\n    content: \"\\f017\";\n}\n\n.wi-yahoo-7:before {\n    content: \"\\f017\";\n}\n\n.wi-yahoo-8:before {\n    content: \"\\f015\";\n}\n\n.wi-yahoo-9:before {\n    content: \"\\f01a\";\n}\n\n.wi-yahoo-10:before {\n    content: \"\\f015\";\n}\n\n.wi-yahoo-11:before {\n    content: \"\\f01a\";\n}\n\n.wi-yahoo-12:before {\n    content: \"\\f01a\";\n}\n\n.wi-yahoo-13:before {\n    content: \"\\f01b\";\n}\n\n.wi-yahoo-14:before {\n    content: \"\\f00a\";\n}\n\n.wi-yahoo-15:before {\n    content: \"\\f064\";\n}\n\n.wi-yahoo-16:before {\n    content: \"\\f01b\";\n}\n\n.wi-yahoo-17:before {\n    content: \"\\f015\";\n}\n\n.wi-yahoo-18:before {\n    content: \"\\f017\";\n}\n\n.wi-yahoo-19:before {\n    content: \"\\f063\";\n}\n\n.wi-yahoo-20:before {\n    content: \"\\f014\";\n}\n\n.wi-yahoo-21:before {\n    content: \"\\f021\";\n}\n\n.wi-yahoo-22:before {\n    content: \"\\f062\";\n}\n\n.wi-yahoo-23:before {\n    content: \"\\f050\";\n}\n\n.wi-yahoo-24:before {\n    content: \"\\f050\";\n}\n\n.wi-yahoo-25:before {\n    content: \"\\f076\";\n}\n\n.wi-yahoo-26:before {\n    content: \"\\f013\";\n}\n\n.wi-yahoo-27:before {\n    content: \"\\f031\";\n}\n\n.wi-yahoo-28:before {\n    content: \"\\f002\";\n}\n\n.wi-yahoo-29:before {\n    content: \"\\f031\";\n}\n\n.wi-yahoo-30:before {\n    content: \"\\f002\";\n}\n\n.wi-yahoo-31:before {\n    content: \"\\f02e\";\n}\n\n.wi-yahoo-32:before {\n    content: \"\\f00d\";\n}\n\n.wi-yahoo-33:before {\n    content: \"\\f083\";\n}\n\n.wi-yahoo-34:before {\n    content: \"\\f00c\";\n}\n\n.wi-yahoo-35:before {\n    content: \"\\f017\";\n}\n\n.wi-yahoo-36:before {\n    content: \"\\f072\";\n}\n\n.wi-yahoo-37:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-38:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-39:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-40:before {\n    content: \"\\f01a\";\n}\n\n.wi-yahoo-41:before {\n    content: \"\\f064\";\n}\n\n.wi-yahoo-42:before {\n    content: \"\\f01b\";\n}\n\n.wi-yahoo-43:before {\n    content: \"\\f064\";\n}\n\n.wi-yahoo-44:before {\n    content: \"\\f00c\";\n}\n\n.wi-yahoo-45:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-46:before {\n    content: \"\\f01b\";\n}\n\n.wi-yahoo-47:before {\n    content: \"\\f00e\";\n}\n\n.wi-yahoo-3200:before {\n    content: \"\\f077\";\n}\n\n.wi-forecast-io-clear-day:before {\n    content: \"\\f00d\";\n}\n\n.wi-forecast-io-clear-night:before {\n    content: \"\\f02e\";\n}\n\n.wi-forecast-io-rain:before {\n    content: \"\\f019\";\n}\n\n.wi-forecast-io-snow:before {\n    content: \"\\f01b\";\n}\n\n.wi-forecast-io-sleet:before {\n    content: \"\\f0b5\";\n}\n\n.wi-forecast-io-wind:before {\n    content: \"\\f050\";\n}\n\n.wi-forecast-io-fog:before {\n    content: \"\\f014\";\n}\n\n.wi-forecast-io-cloudy:before {\n    content: \"\\f013\";\n}\n\n.wi-forecast-io-partly-cloudy-day:before {\n    content: \"\\f002\";\n}\n\n.wi-forecast-io-partly-cloudy-night:before {\n    content: \"\\f031\";\n}\n\n.wi-forecast-io-hail:before {\n    content: \"\\f015\";\n}\n\n.wi-forecast-io-thunderstorm:before {\n    content: \"\\f01e\";\n}\n\n.wi-forecast-io-tornado:before {\n    content: \"\\f056\";\n}\n\n.wi-wmo4680-0:before,\n.wi-wmo4680-00:before {\n    content: \"\\f055\";\n}\n\n.wi-wmo4680-1:before,\n.wi-wmo4680-01:before {\n    content: \"\\f013\";\n}\n\n.wi-wmo4680-2:before,\n.wi-wmo4680-02:before {\n    content: \"\\f055\";\n}\n\n.wi-wmo4680-3:before,\n.wi-wmo4680-03:before {\n    content: \"\\f013\";\n}\n\n.wi-wmo4680-4:before,\n.wi-wmo4680-04:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-5:before,\n.wi-wmo4680-05:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-10:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-11:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-12:before {\n    content: \"\\f016\";\n}\n\n.wi-wmo4680-18:before {\n    content: \"\\f050\";\n}\n\n.wi-wmo4680-20:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-21:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-22:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-23:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-24:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-25:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-26:before {\n    content: \"\\f01e\";\n}\n\n.wi-wmo4680-27:before {\n    content: \"\\f063\";\n}\n\n.wi-wmo4680-28:before {\n    content: \"\\f063\";\n}\n\n.wi-wmo4680-29:before {\n    content: \"\\f063\";\n}\n\n.wi-wmo4680-30:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-31:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-32:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-33:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-34:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-35:before {\n    content: \"\\f014\";\n}\n\n.wi-wmo4680-40:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-41:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-42:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-43:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-44:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-45:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-46:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-47:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-48:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-50:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-51:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-52:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-53:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-54:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-55:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-56:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-57:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-58:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-60:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-61:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-62:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-63:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-64:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-65:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-66:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-67:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-68:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-70:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-71:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-72:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-73:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-74:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-75:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-76:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-77:before {\n    content: \"\\f01b\";\n}\n\n.wi-wmo4680-78:before {\n    content: \"\\f076\";\n}\n\n.wi-wmo4680-80:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-81:before {\n    content: \"\\f01c\";\n}\n\n.wi-wmo4680-82:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-83:before {\n    content: \"\\f019\";\n}\n\n.wi-wmo4680-84:before {\n    content: \"\\f01d\";\n}\n\n.wi-wmo4680-85:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-86:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-87:before {\n    content: \"\\f017\";\n}\n\n.wi-wmo4680-89:before {\n    content: \"\\f015\";\n}\n\n.wi-wmo4680-90:before {\n    content: \"\\f016\";\n}\n\n.wi-wmo4680-91:before {\n    content: \"\\f01d\";\n}\n\n.wi-wmo4680-92:before {\n    content: \"\\f01e\";\n}\n\n.wi-wmo4680-93:before {\n    content: \"\\f01e\";\n}\n\n.wi-wmo4680-94:before {\n    content: \"\\f016\";\n}\n\n.wi-wmo4680-95:before {\n    content: \"\\f01e\";\n}\n\n.wi-wmo4680-96:before {\n    content: \"\\f01e\";\n}\n\n.wi-wmo4680-99:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-200:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-201:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-202:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-210:before {\n    content: \"\\f016\";\n}\n\n.wi-owm-211:before {\n    content: \"\\f016\";\n}\n\n.wi-owm-212:before {\n    content: \"\\f016\";\n}\n\n.wi-owm-221:before {\n    content: \"\\f016\";\n}\n\n.wi-owm-230:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-231:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-232:before {\n    content: \"\\f01e\";\n}\n\n.wi-owm-300:before {\n    content: \"\\f01c\";\n}\n\n.wi-owm-301:before {\n    content: \"\\f01c\";\n}\n\n.wi-owm-302:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-310:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-311:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-312:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-313:before {\n    content: \"\\f01a\";\n}\n\n.wi-owm-314:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-321:before {\n    content: \"\\f01c\";\n}\n\n.wi-owm-500:before {\n    content: \"\\f01c\";\n}\n\n.wi-owm-501:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-502:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-503:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-504:before {\n    content: \"\\f019\";\n}\n\n.wi-owm-511:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-520:before {\n    content: \"\\f01a\";\n}\n\n.wi-owm-521:before {\n    content: \"\\f01a\";\n}\n\n.wi-owm-522:before {\n    content: \"\\f01a\";\n}\n\n.wi-owm-531:before {\n    content: \"\\f01d\";\n}\n\n.wi-owm-600:before {\n    content: \"\\f01b\";\n}\n\n.wi-owm-601:before {\n    content: \"\\f01b\";\n}\n\n.wi-owm-602:before {\n    content: \"\\f0b5\";\n}\n\n.wi-owm-611:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-612:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-615:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-616:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-620:before {\n    content: \"\\f017\";\n}\n\n.wi-owm-621:before {\n    content: \"\\f01b\";\n}\n\n.wi-owm-622:before {\n    content: \"\\f01b\";\n}\n\n.wi-owm-701:before {\n    content: \"\\f01a\";\n}\n\n.wi-owm-711:before {\n    content: \"\\f062\";\n}\n\n.wi-owm-721:before {\n    content: \"\\f0b6\";\n}\n\n.wi-owm-731:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-741:before {\n    content: \"\\f014\";\n}\n\n.wi-owm-761:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-762:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-771:before {\n    content: \"\\f011\";\n}\n\n.wi-owm-781:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-800:before {\n    content: \"\\f00d\";\n}\n\n.wi-owm-801:before {\n    content: \"\\f011\";\n}\n\n.wi-owm-802:before {\n    content: \"\\f011\";\n}\n\n.wi-owm-803:before {\n    content: \"\\f011\";\n}\n\n.wi-owm-803:before {\n    content: \"\\f012\";\n}\n\n.wi-owm-804:before {\n    content: \"\\f013\";\n}\n\n.wi-owm-900:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-901:before {\n    content: \"\\f01d\";\n}\n\n.wi-owm-902:before {\n    content: \"\\f073\";\n}\n\n.wi-owm-903:before {\n    content: \"\\f076\";\n}\n\n.wi-owm-904:before {\n    content: \"\\f072\";\n}\n\n.wi-owm-905:before {\n    content: \"\\f021\";\n}\n\n.wi-owm-906:before {\n    content: \"\\f015\";\n}\n\n.wi-owm-957:before {\n    content: \"\\f050\";\n}\n\n.wi-owm-day-200:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-201:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-202:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-210:before {\n    content: \"\\f005\";\n}\n\n.wi-owm-day-211:before {\n    content: \"\\f005\";\n}\n\n.wi-owm-day-212:before {\n    content: \"\\f005\";\n}\n\n.wi-owm-day-221:before {\n    content: \"\\f005\";\n}\n\n.wi-owm-day-230:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-231:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-232:before {\n    content: \"\\f010\";\n}\n\n.wi-owm-day-300:before {\n    content: \"\\f00b\";\n}\n\n.wi-owm-day-301:before {\n    content: \"\\f00b\";\n}\n\n.wi-owm-day-302:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-310:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-311:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-312:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-313:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-314:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-321:before {\n    content: \"\\f00b\";\n}\n\n.wi-owm-day-500:before {\n    content: \"\\f00b\";\n}\n\n.wi-owm-day-501:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-502:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-503:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-504:before {\n    content: \"\\f008\";\n}\n\n.wi-owm-day-511:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-520:before {\n    content: \"\\f009\";\n}\n\n.wi-owm-day-521:before {\n    content: \"\\f009\";\n}\n\n.wi-owm-day-522:before {\n    content: \"\\f009\";\n}\n\n.wi-owm-day-531:before {\n    content: \"\\f00e\";\n}\n\n.wi-owm-day-600:before {\n    content: \"\\f00a\";\n}\n\n.wi-owm-day-601:before {\n    content: \"\\f0b2\";\n}\n\n.wi-owm-day-602:before {\n    content: \"\\f00a\";\n}\n\n.wi-owm-day-611:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-612:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-615:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-616:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-620:before {\n    content: \"\\f006\";\n}\n\n.wi-owm-day-621:before {\n    content: \"\\f00a\";\n}\n\n.wi-owm-day-622:before {\n    content: \"\\f00a\";\n}\n\n.wi-owm-day-701:before {\n    content: \"\\f009\";\n}\n\n.wi-owm-day-711:before {\n    content: \"\\f062\";\n}\n\n.wi-owm-day-721:before {\n    content: \"\\f0b6\";\n}\n\n.wi-owm-day-731:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-day-741:before {\n    content: \"\\f003\";\n}\n\n.wi-owm-day-761:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-day-762:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-day-781:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-day-800:before {\n    content: \"\\f00d\";\n}\n\n.wi-owm-day-801:before {\n    content: \"\\f000\";\n}\n\n.wi-owm-day-802:before {\n    content: \"\\f000\";\n}\n\n.wi-owm-day-803:before {\n    content: \"\\f000\";\n}\n\n.wi-owm-day-804:before {\n    content: \"\\f00c\";\n}\n\n.wi-owm-day-900:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-day-902:before {\n    content: \"\\f073\";\n}\n\n.wi-owm-day-903:before {\n    content: \"\\f076\";\n}\n\n.wi-owm-day-904:before {\n    content: \"\\f072\";\n}\n\n.wi-owm-day-906:before {\n    content: \"\\f004\";\n}\n\n.wi-owm-day-957:before {\n    content: \"\\f050\";\n}\n\n.wi-owm-night-200:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-201:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-202:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-210:before {\n    content: \"\\f025\";\n}\n\n.wi-owm-night-211:before {\n    content: \"\\f025\";\n}\n\n.wi-owm-night-212:before {\n    content: \"\\f025\";\n}\n\n.wi-owm-night-221:before {\n    content: \"\\f025\";\n}\n\n.wi-owm-night-230:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-231:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-232:before {\n    content: \"\\f02d\";\n}\n\n.wi-owm-night-300:before {\n    content: \"\\f02b\";\n}\n\n.wi-owm-night-301:before {\n    content: \"\\f02b\";\n}\n\n.wi-owm-night-302:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-310:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-311:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-312:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-313:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-314:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-321:before {\n    content: \"\\f02b\";\n}\n\n.wi-owm-night-500:before {\n    content: \"\\f02b\";\n}\n\n.wi-owm-night-501:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-502:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-503:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-504:before {\n    content: \"\\f028\";\n}\n\n.wi-owm-night-511:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-520:before {\n    content: \"\\f029\";\n}\n\n.wi-owm-night-521:before {\n    content: \"\\f029\";\n}\n\n.wi-owm-night-522:before {\n    content: \"\\f029\";\n}\n\n.wi-owm-night-531:before {\n    content: \"\\f02c\";\n}\n\n.wi-owm-night-600:before {\n    content: \"\\f02a\";\n}\n\n.wi-owm-night-601:before {\n    content: \"\\f0b4\";\n}\n\n.wi-owm-night-602:before {\n    content: \"\\f02a\";\n}\n\n.wi-owm-night-611:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-612:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-615:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-616:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-620:before {\n    content: \"\\f026\";\n}\n\n.wi-owm-night-621:before {\n    content: \"\\f02a\";\n}\n\n.wi-owm-night-622:before {\n    content: \"\\f02a\";\n}\n\n.wi-owm-night-701:before {\n    content: \"\\f029\";\n}\n\n.wi-owm-night-711:before {\n    content: \"\\f062\";\n}\n\n.wi-owm-night-721:before {\n    content: \"\\f0b6\";\n}\n\n.wi-owm-night-731:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-night-741:before {\n    content: \"\\f04a\";\n}\n\n.wi-owm-night-761:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-night-762:before {\n    content: \"\\f063\";\n}\n\n.wi-owm-night-781:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-night-800:before {\n    content: \"\\f02e\";\n}\n\n.wi-owm-night-801:before {\n    content: \"\\f022\";\n}\n\n.wi-owm-night-802:before {\n    content: \"\\f022\";\n}\n\n.wi-owm-night-803:before {\n    content: \"\\f022\";\n}\n\n.wi-owm-night-804:before {\n    content: \"\\f086\";\n}\n\n.wi-owm-night-900:before {\n    content: \"\\f056\";\n}\n\n.wi-owm-night-902:before {\n    content: \"\\f073\";\n}\n\n.wi-owm-night-903:before {\n    content: \"\\f076\";\n}\n\n.wi-owm-night-904:before {\n    content: \"\\f072\";\n}\n\n.wi-owm-night-906:before {\n    content: \"\\f024\";\n}\n\n.wi-owm-night-957:before {\n    content: \"\\f050\";\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-beaufort.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-day.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-direction.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-misc.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-moon.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-neutral.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-night.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-time.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/css/variables-wind-names.css",
    "content": ""
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-beaufort.less",
    "content": ".wi-wind-beaufort-0:before {content: @wind-beaufort-0;}\n.wi-wind-beaufort-1:before {content: @wind-beaufort-1;}\n.wi-wind-beaufort-2:before {content: @wind-beaufort-2;}\n.wi-wind-beaufort-3:before {content: @wind-beaufort-3;}\n.wi-wind-beaufort-4:before {content: @wind-beaufort-4;}\n.wi-wind-beaufort-5:before {content: @wind-beaufort-5;}\n.wi-wind-beaufort-6:before {content: @wind-beaufort-6;}\n.wi-wind-beaufort-7:before {content: @wind-beaufort-7;}\n.wi-wind-beaufort-8:before {content: @wind-beaufort-8;}\n.wi-wind-beaufort-9:before {content: @wind-beaufort-9;}\n.wi-wind-beaufort-10:before {content: @wind-beaufort-10;}\n.wi-wind-beaufort-11:before {content: @wind-beaufort-11;}\n.wi-wind-beaufort-12:before {content: @wind-beaufort-12;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-day.less",
    "content": ".wi-day-sunny:before {content: @day-sunny;}\n.wi-day-cloudy:before {content: @day-cloudy;}\n.wi-day-cloudy-gusts:before {content: @day-cloudy-gusts;}\n.wi-day-cloudy-windy:before {content: @day-cloudy-windy;}\n.wi-day-fog:before {content: @day-fog;}\n.wi-day-hail:before {content: @day-hail;}\n.wi-day-haze:before {content: @day-haze;}\n.wi-day-lightning:before {content: @day-lightning;}\n.wi-day-rain:before {content: @day-rain;}\n.wi-day-rain-mix:before {content: @day-rain-mix;}\n.wi-day-rain-wind:before {content: @day-rain-wind;}\n.wi-day-showers:before {content: @day-showers;}\n.wi-day-sleet:before {content: @day-sleet;}\n.wi-day-sleet-storm:before {content: @day-sleet-storm;}\n.wi-day-snow:before {content: @day-snow;}\n.wi-day-snow-thunderstorm:before {content: @day-snow-thunderstorm;}\n.wi-day-snow-wind:before {content: @day-snow-wind;}\n.wi-day-sprinkle:before {content: @day-sprinkle;}\n.wi-day-storm-showers:before {content: @day-storm-showers;}\n.wi-day-sunny-overcast:before {content: @day-sunny-overcast;}\n.wi-day-thunderstorm:before {content: @day-thunderstorm;}\n.wi-day-windy:before {content: @day-windy;}\n.wi-solar-eclipse:before {content: @solar-eclipse;}\n.wi-hot:before {content: @hot;}\n.wi-day-cloudy-high:before {content: @day-cloudy-high;}\n.wi-day-light-wind:before {content: @day-light-wind;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-direction.less",
    "content": ".wi-direction-up:before {content: @direction-up;}\n.wi-direction-up-right:before {content: @direction-up-right;}\n.wi-direction-right:before {content: @direction-right;}\n.wi-direction-down-right:before {content: @direction-down-right;}\n.wi-direction-down:before {content: @direction-down;}\n.wi-direction-down-left:before {content: @direction-down-left;}\n.wi-direction-left:before {content: @direction-left;}\n.wi-direction-up-left:before {content: @direction-up-left;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-misc.less",
    "content": ".wi-alien:before {content: @alien;}\n.wi-celsius:before {content: @celsius;}\n.wi-fahrenheit:before {content: @fahrenheit;}\n.wi-degrees:before {content: @degrees;}\n.wi-thermometer:before {content: @thermometer;}\n.wi-thermometer-exterior:before {content: @thermometer-exterior;}\n.wi-thermometer-internal:before {content: @thermometer-internal;}\n.wi-cloud-down:before {content: @cloud-down;}\n.wi-cloud-up:before {content: @cloud-up;}\n.wi-cloud-refresh:before {content: @cloud-refresh;}\n.wi-horizon:before {content: @horizon;}\n.wi-horizon-alt:before {content: @horizon-alt;}\n.wi-sunrise:before {content: @sunrise;}\n.wi-sunset:before {content: @sunset;}\n.wi-moonrise:before {content: @moonrise;}\n.wi-moonset:before {content: @moonset;}\n.wi-refresh:before {content: @refresh;}\n.wi-refresh-alt:before {content: @refresh-alt;}\n.wi-umbrella:before {content: @umbrella;}\n.wi-barometer:before {content: @barometer;}\n.wi-humidity:before {content: @humidity;}\n.wi-na:before {content: @na;}\n.wi-train:before {content: @train;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-moon-aliases.less",
    "content": ".wi-moon-0:before {content: @moon-new;}\n.wi-moon-1:before {content: @moon-waxing-cresent-1;}\n.wi-moon-2:before {content: @moon-waxing-cresent-2;}\n.wi-moon-3:before {content: @moon-waxing-cresent-3;}\n.wi-moon-4:before {content: @moon-waxing-cresent-4;}\n.wi-moon-5:before {content: @moon-waxing-cresent-5;}\n.wi-moon-6:before {content: @moon-waxing-cresent-6;}\n.wi-moon-7:before {content: @moon-first-quarter;}\n.wi-moon-8:before {content: @moon-waxing-gibbous-1;}\n.wi-moon-9:before {content: @moon-waxing-gibbous-2;}\n.wi-moon-10:before {content: @moon-waxing-gibbous-3;}\n.wi-moon-11:before {content: @moon-waxing-gibbous-4;}\n.wi-moon-12:before {content: @moon-waxing-gibbous-5;}\n.wi-moon-13:before {content: @moon-waxing-gibbous-6;}\n.wi-moon-14:before {content: @moon-full;}\n.wi-moon-15:before {content: @moon-waning-gibbous-1;}\n.wi-moon-16:before {content: @moon-waning-gibbous-2;}\n.wi-moon-17:before {content: @moon-waning-gibbous-3;}\n.wi-moon-18:before {content: @moon-waning-gibbous-4;}\n.wi-moon-19:before {content: @moon-waning-gibbous-5;}\n.wi-moon-20:before {content: @moon-waning-gibbous-6;}\n.wi-moon-21:before {content: @moon-third-quarter;}\n.wi-moon-22:before {content: @moon-waning-crescent-1;}\n.wi-moon-23:before {content: @moon-waning-crescent-2;}\n.wi-moon-24:before {content: @moon-waning-crescent-3;}\n.wi-moon-25:before {content: @moon-waning-crescent-4;}\n.wi-moon-26:before {content: @moon-waning-crescent-5;}\n.wi-moon-27:before {content: @moon-waning-crescent-6;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-moon.less",
    "content": ".wi-moon-new:before {content: @moon-new;}\n.wi-moon-waxing-cresent-1:before {content: @moon-waxing-cresent-1;}\n.wi-moon-waxing-cresent-2:before {content: @moon-waxing-cresent-2;}\n.wi-moon-waxing-cresent-3:before {content: @moon-waxing-cresent-3;}\n.wi-moon-waxing-cresent-4:before {content: @moon-waxing-cresent-4;}\n.wi-moon-waxing-cresent-5:before {content: @moon-waxing-cresent-5;}\n.wi-moon-waxing-cresent-6:before {content: @moon-waxing-cresent-6;}\n.wi-moon-first-quarter:before {content: @moon-first-quarter;}\n.wi-moon-waxing-gibbous-1:before {content: @moon-waxing-gibbous-1;}\n.wi-moon-waxing-gibbous-2:before {content: @moon-waxing-gibbous-2;}\n.wi-moon-waxing-gibbous-3:before {content: @moon-waxing-gibbous-3;}\n.wi-moon-waxing-gibbous-4:before {content: @moon-waxing-gibbous-4;}\n.wi-moon-waxing-gibbous-5:before {content: @moon-waxing-gibbous-5;}\n.wi-moon-waxing-gibbous-6:before {content: @moon-waxing-gibbous-6;}\n.wi-moon-full:before {content: @moon-full;}\n.wi-moon-waning-gibbous-1:before {content: @moon-waning-gibbous-1;}\n.wi-moon-waning-gibbous-2:before {content: @moon-waning-gibbous-2;}\n.wi-moon-waning-gibbous-3:before {content: @moon-waning-gibbous-3;}\n.wi-moon-waning-gibbous-4:before {content: @moon-waning-gibbous-4;}\n.wi-moon-waning-gibbous-5:before {content: @moon-waning-gibbous-5;}\n.wi-moon-waning-gibbous-6:before {content: @moon-waning-gibbous-6;}\n.wi-moon-third-quarter:before {content: @moon-third-quarter;}\n.wi-moon-waning-crescent-1:before {content: @moon-waning-crescent-1;}\n.wi-moon-waning-crescent-2:before {content: @moon-waning-crescent-2;}\n.wi-moon-waning-crescent-3:before {content: @moon-waning-crescent-3;}\n.wi-moon-waning-crescent-4:before {content: @moon-waning-crescent-4;}\n.wi-moon-waning-crescent-5:before {content: @moon-waning-crescent-5;}\n.wi-moon-waning-crescent-6:before {content: @moon-waning-crescent-6;}\n.wi-moon-alt-new:before {content: @moon-alt-new;}\n.wi-moon-alt-waxing-cresent-1:before {content: @moon-alt-waxing-cresent-1;}\n.wi-moon-alt-waxing-cresent-2:before {content: @moon-alt-waxing-cresent-2;}\n.wi-moon-alt-waxing-cresent-3:before {content: @moon-alt-waxing-cresent-3;}\n.wi-moon-alt-waxing-cresent-4:before {content: @moon-alt-waxing-cresent-4;}\n.wi-moon-alt-waxing-cresent-5:before {content: @moon-alt-waxing-cresent-5;}\n.wi-moon-alt-waxing-cresent-6:before {content: @moon-alt-waxing-cresent-6;}\n.wi-moon-alt-first-quarter:before {content: @moon-alt-first-quarter;}\n.wi-moon-alt-waxing-gibbous-1:before {content: @moon-alt-waxing-gibbous-1;}\n.wi-moon-alt-waxing-gibbous-2:before {content: @moon-alt-waxing-gibbous-2;}\n.wi-moon-alt-waxing-gibbous-3:before {content: @moon-alt-waxing-gibbous-3;}\n.wi-moon-alt-waxing-gibbous-4:before {content: @moon-alt-waxing-gibbous-4;}\n.wi-moon-alt-waxing-gibbous-5:before {content: @moon-alt-waxing-gibbous-5;}\n.wi-moon-alt-waxing-gibbous-6:before {content: @moon-alt-waxing-gibbous-6;}\n.wi-moon-alt-full:before {content: @moon-alt-full;}\n.wi-moon-alt-waning-gibbous-1:before {content: @moon-alt-waning-gibbous-1;}\n.wi-moon-alt-waning-gibbous-2:before {content: @moon-alt-waning-gibbous-2;}\n.wi-moon-alt-waning-gibbous-3:before {content: @moon-alt-waning-gibbous-3;}\n.wi-moon-alt-waning-gibbous-4:before {content: @moon-alt-waning-gibbous-4;}\n.wi-moon-alt-waning-gibbous-5:before {content: @moon-alt-waning-gibbous-5;}\n.wi-moon-alt-waning-gibbous-6:before {content: @moon-alt-waning-gibbous-6;}\n.wi-moon-alt-third-quarter:before {content: @moon-alt-third-quarter;}\n.wi-moon-alt-waning-crescent-1:before {content: @moon-alt-waning-crescent-1;}\n.wi-moon-alt-waning-crescent-2:before {content: @moon-alt-waning-crescent-2;}\n.wi-moon-alt-waning-crescent-3:before {content: @moon-alt-waning-crescent-3;}\n.wi-moon-alt-waning-crescent-4:before {content: @moon-alt-waning-crescent-4;}\n.wi-moon-alt-waning-crescent-5:before {content: @moon-alt-waning-crescent-5;}\n.wi-moon-alt-waning-crescent-6:before {content: @moon-alt-waning-crescent-6;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-neutral.less",
    "content": ".wi-cloud:before {content: @cloud;}\n.wi-cloudy:before {content: @cloudy;}\n.wi-cloudy-gusts:before {content: @cloudy-gusts;}\n.wi-cloudy-windy:before {content: @cloudy-windy;}\n.wi-fog:before {content: @fog;}\n.wi-hail:before {content: @hail;}\n.wi-rain:before {content: @rain;}\n.wi-rain-mix:before {content: @rain-mix;}\n.wi-rain-wind:before {content: @rain-wind;}\n.wi-showers:before {content: @showers;}\n.wi-sleet:before {content: @sleet;}\n.wi-snow:before {content: @snow;}\n.wi-sprinkle:before {content: @sprinkle;}\n.wi-storm-showers:before {content: @storm-showers;}\n.wi-thunderstorm:before {content: @thunderstorm;}\n.wi-snow-wind:before {content: @snow-wind;}\n.wi-snow:before {content: @snow;}\n.wi-smog:before {content: @smog;}\n.wi-smoke:before {content: @smoke;}\n.wi-lightning:before {content: @lightning;}\n.wi-raindrops:before {content: @raindrops;}\n.wi-raindrop:before {content: @raindrop;}\n.wi-dust:before {content: @dust;}\n.wi-snowflake-cold:before {content: @snowflake-cold;}\n.wi-windy:before {content: @windy;}\n.wi-strong-wind:before {content: @strong-wind;}\n.wi-sandstorm:before {content: @sandstorm;}\n.wi-earthquake:before {content: @earthquake;}\n.wi-fire:before {content: @fire;}\n.wi-flood:before {content: @flood;}\n.wi-meteor:before {content: @meteor;}\n.wi-tsunami:before {content: @tsunami;}\n.wi-volcano:before {content: @volcano;}\n.wi-hurricane:before {content: @hurricane;}\n.wi-tornado:before {content: @tornado;}\n.wi-small-craft-advisory:before {content: @small-craft-advisory;}\n.wi-gale-warning:before {content: @gale-warning;}\n.wi-storm-warning:before {content: @storm-warning;}\n.wi-hurricane-warning:before {content: @hurricane-warning;}\n.wi-wind-direction:before {content: @wind-direction;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-night.less",
    "content": ".wi-night-clear:before {content: @night-clear;}\n.wi-night-alt-cloudy:before {content: @night-alt-cloudy;}\n.wi-night-alt-cloudy-gusts:before {content: @night-alt-cloudy-gusts;}\n.wi-night-alt-cloudy-windy:before {content: @night-alt-cloudy-windy;}\n.wi-night-alt-hail:before {content: @night-alt-hail;}\n.wi-night-alt-lightning:before {content: @night-alt-lightning;}\n.wi-night-alt-rain:before {content: @night-alt-rain;}\n.wi-night-alt-rain-mix:before {content: @night-alt-rain-mix;}\n.wi-night-alt-rain-wind:before {content: @night-alt-rain-wind;}\n.wi-night-alt-showers:before {content: @night-alt-showers;}\n.wi-night-alt-sleet:before {content: @night-alt-sleet;}\n.wi-night-alt-sleet-storm:before {content: @night-alt-sleet-storm;}\n.wi-night-alt-snow:before {content: @night-alt-snow;}\n.wi-night-alt-snow-thunderstorm:before {content: @night-alt-snow-thunderstorm;}\n.wi-night-alt-snow-wind:before {content: @night-alt-snow-wind;}\n.wi-night-alt-sprinkle:before {content: @night-alt-sprinkle;}\n.wi-night-alt-storm-showers:before {content: @night-alt-storm-showers;}\n.wi-night-alt-thunderstorm:before {content: @night-alt-thunderstorm;}\n.wi-night-cloudy:before {content: @night-cloudy;}\n.wi-night-cloudy-gusts:before {content: @night-cloudy-gusts;}\n.wi-night-cloudy-windy:before {content: @night-cloudy-windy;}\n.wi-night-fog:before {content: @night-fog;}\n.wi-night-hail:before {content: @night-hail;}\n.wi-night-lightning:before {content: @night-lightning;}\n.wi-night-partly-cloudy:before {content: @night-partly-cloudy;}\n.wi-night-rain:before {content: @night-rain;}\n.wi-night-rain-mix:before {content: @night-rain-mix;}\n.wi-night-rain-wind:before {content: @night-rain-wind;}\n.wi-night-showers:before {content: @night-showers;}\n.wi-night-sleet:before {content: @night-sleet;}\n.wi-night-sleet-storm:before {content: @night-sleet-storm;}\n.wi-night-snow:before {content: @night-snow;}\n.wi-night-snow-thunderstorm:before {content: @night-snow-thunderstorm;}\n.wi-night-snow-wind:before {content: @night-snow-wind;}\n.wi-night-sprinkle:before {content: @night-sprinkle;}\n.wi-night-storm-showers:before {content: @night-storm-showers;}\n.wi-night-thunderstorm:before {content: @night-thunderstorm;}\n.wi-lunar-eclipse:before {content: @lunar-eclipse;}\n.wi-stars:before {content: @stars;}\n.wi-storm-showers:before {content: @storm-showers;}\n.wi-thunderstorm:before {content: @thunderstorm;}\n.wi-night-alt-cloudy-high:before {content: @night-alt-cloudy-high;}\n.wi-night-cloudy-high:before {content: @night-cloudy-high;}\n.wi-night-alt-partly-cloudy:before {content: @night-alt-partly-cloudy;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-time.less",
    "content": ".wi-time-1:before {content: @time-1;}\n.wi-time-2:before {content: @time-2;}\n.wi-time-3:before {content: @time-3;}\n.wi-time-4:before {content: @time-4;}\n.wi-time-5:before {content: @time-5;}\n.wi-time-6:before {content: @time-6;}\n.wi-time-7:before {content: @time-7;}\n.wi-time-8:before {content: @time-8;}\n.wi-time-9:before {content: @time-9;}\n.wi-time-10:before {content: @time-10;}\n.wi-time-11:before {content: @time-11;}\n.wi-time-12:before {content: @time-12;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-wind-aliases.less",
    "content": ".wi-towards-n    {\n  .wi-wind.towards-0-deg;\n}\n.wi-towards-nne   {\n  .wi-wind.towards-23-deg;\n}\n.wi-towards-ne    {\n  .wi-wind.towards-45-deg;\n}\n.wi-towards-ene   {\n  .wi-wind.towards-68-deg;\n}\n.wi-towards-e    {\n  .wi-wind.towards-90-deg;\n}\n.wi-towards-ese   {\n  .wi-wind.towards-113-deg;\n}\n.wi-towards-se    {\n  .wi-wind.towards-135-deg;\n}\n.wi-towards-sse   {\n  .wi-wind.towards-158-deg;\n}\n.wi-towards-s    {\n  .wi-wind.towards-180-deg;\n}\n.wi-towards-ssw   {\n  .wi-wind.towards-203-deg;\n}\n.wi-towards-sw    {\n  .wi-wind.towards-225-deg;\n}\n.wi-towards-wsw   {\n  .wi-wind.towards-248-deg;\n}\n.wi-towards-w    {\n  .wi-wind.towards-270-deg;\n}\n.wi-towards-wnw   {\n  .wi-wind.towards-293-deg;\n}\n.wi-towards-nw    {\n  .wi-wind.towards-313-deg;\n}\n.wi-towards-nnw   {\n  .wi-wind.towards-336-deg;\n}\n.wi-from-n    {\n  .wi-wind.from-0-deg;\n}\n.wi-from-nne   {\n  .wi-wind.from-23-deg;\n}\n.wi-from-ne    {\n  .wi-wind.from-45-deg;\n}\n.wi-from-ene   {\n  .wi-wind.from-68-deg;\n}\n.wi-from-e    {\n  .wi-wind.from-90-deg;\n}\n.wi-from-ese   {\n  .wi-wind.from-113-deg;\n}\n.wi-from-se    {\n  .wi-wind.from-135-deg;\n}\n.wi-from-sse   {\n  .wi-wind.from-158-deg;\n}\n.wi-from-s    {\n  .wi-wind.from-180-deg;\n}\n.wi-from-ssw   {\n  .wi-wind.from-203-deg;\n}\n.wi-from-sw    {\n  .wi-wind.from-225-deg;\n}\n.wi-from-wsw   {\n  .wi-wind.from-248-deg;\n}\n.wi-from-w    {\n  .wi-wind.from-270-deg;\n}\n.wi-from-wnw   {\n  .wi-wind.from-293-deg;\n}\n.wi-from-nw    {\n  .wi-wind.from-313-deg;\n}\n.wi-from-nnw   {\n  .wi-wind.from-336-deg;\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-wind-degrees.less",
    "content": ".@{wi-css-prefix}-wind { \n  &.towards-0-deg {.wind-rotate(0deg);}\n  &.towards-1-deg {.wind-rotate(1deg);}\n  &.towards-2-deg {.wind-rotate(2deg);}\n  &.towards-3-deg {.wind-rotate(3deg);}\n  &.towards-4-deg {.wind-rotate(4deg);}\n  &.towards-5-deg {.wind-rotate(5deg);}\n  &.towards-6-deg {.wind-rotate(6deg);}\n  &.towards-7-deg {.wind-rotate(7deg);}\n  &.towards-8-deg {.wind-rotate(8deg);}\n  &.towards-9-deg {.wind-rotate(9deg);}\n  &.towards-10-deg {.wind-rotate(10deg);}\n  &.towards-11-deg {.wind-rotate(11deg);}\n  &.towards-12-deg {.wind-rotate(12deg);}\n  &.towards-13-deg {.wind-rotate(13deg);}\n  &.towards-14-deg {.wind-rotate(14deg);}\n  &.towards-15-deg {.wind-rotate(15deg);}\n  &.towards-16-deg {.wind-rotate(16deg);}\n  &.towards-17-deg {.wind-rotate(17deg);}\n  &.towards-18-deg {.wind-rotate(18deg);}\n  &.towards-19-deg {.wind-rotate(19deg);}\n  &.towards-20-deg {.wind-rotate(20deg);}\n  &.towards-21-deg {.wind-rotate(21deg);}\n  &.towards-22-deg {.wind-rotate(22deg);}\n  &.towards-23-deg {.wind-rotate(23deg);}\n  &.towards-24-deg {.wind-rotate(24deg);}\n  &.towards-25-deg {.wind-rotate(25deg);}\n  &.towards-26-deg {.wind-rotate(26deg);}\n  &.towards-27-deg {.wind-rotate(27deg);}\n  &.towards-28-deg {.wind-rotate(28deg);}\n  &.towards-29-deg {.wind-rotate(29deg);}\n  &.towards-30-deg {.wind-rotate(30deg);}\n  &.towards-31-deg {.wind-rotate(31deg);}\n  &.towards-32-deg {.wind-rotate(32deg);}\n  &.towards-33-deg {.wind-rotate(33deg);}\n  &.towards-34-deg {.wind-rotate(34deg);}\n  &.towards-35-deg {.wind-rotate(35deg);}\n  &.towards-36-deg {.wind-rotate(36deg);}\n  &.towards-37-deg {.wind-rotate(37deg);}\n  &.towards-38-deg {.wind-rotate(38deg);}\n  &.towards-39-deg {.wind-rotate(39deg);}\n  &.towards-40-deg {.wind-rotate(40deg);}\n  &.towards-41-deg {.wind-rotate(41deg);}\n  &.towards-42-deg {.wind-rotate(42deg);}\n  &.towards-43-deg {.wind-rotate(43deg);}\n  &.towards-44-deg {.wind-rotate(44deg);}\n  &.towards-45-deg {.wind-rotate(45deg);}\n  &.towards-46-deg {.wind-rotate(46deg);}\n  &.towards-47-deg {.wind-rotate(47deg);}\n  &.towards-48-deg {.wind-rotate(48deg);}\n  &.towards-49-deg {.wind-rotate(49deg);}\n  &.towards-50-deg {.wind-rotate(50deg);}\n  &.towards-51-deg {.wind-rotate(51deg);}\n  &.towards-52-deg {.wind-rotate(52deg);}\n  &.towards-53-deg {.wind-rotate(53deg);}\n  &.towards-54-deg {.wind-rotate(54deg);}\n  &.towards-55-deg {.wind-rotate(55deg);}\n  &.towards-56-deg {.wind-rotate(56deg);}\n  &.towards-57-deg {.wind-rotate(57deg);}\n  &.towards-58-deg {.wind-rotate(58deg);}\n  &.towards-59-deg {.wind-rotate(59deg);}\n  &.towards-60-deg {.wind-rotate(60deg);}\n  &.towards-61-deg {.wind-rotate(61deg);}\n  &.towards-62-deg {.wind-rotate(62deg);}\n  &.towards-63-deg {.wind-rotate(63deg);}\n  &.towards-64-deg {.wind-rotate(64deg);}\n  &.towards-65-deg {.wind-rotate(65deg);}\n  &.towards-66-deg {.wind-rotate(66deg);}\n  &.towards-67-deg {.wind-rotate(67deg);}\n  &.towards-68-deg {.wind-rotate(68deg);}\n  &.towards-69-deg {.wind-rotate(69deg);}\n  &.towards-70-deg {.wind-rotate(70deg);}\n  &.towards-71-deg {.wind-rotate(71deg);}\n  &.towards-72-deg {.wind-rotate(72deg);}\n  &.towards-73-deg {.wind-rotate(73deg);}\n  &.towards-74-deg {.wind-rotate(74deg);}\n  &.towards-75-deg {.wind-rotate(75deg);}\n  &.towards-76-deg {.wind-rotate(76deg);}\n  &.towards-77-deg {.wind-rotate(77deg);}\n  &.towards-78-deg {.wind-rotate(78deg);}\n  &.towards-79-deg {.wind-rotate(79deg);}\n  &.towards-80-deg {.wind-rotate(80deg);}\n  &.towards-81-deg {.wind-rotate(81deg);}\n  &.towards-82-deg {.wind-rotate(82deg);}\n  &.towards-83-deg {.wind-rotate(83deg);}\n  &.towards-84-deg {.wind-rotate(84deg);}\n  &.towards-85-deg {.wind-rotate(85deg);}\n  &.towards-86-deg {.wind-rotate(86deg);}\n  &.towards-87-deg {.wind-rotate(87deg);}\n  &.towards-88-deg {.wind-rotate(88deg);}\n  &.towards-89-deg {.wind-rotate(89deg);}\n  &.towards-90-deg {.wind-rotate(90deg);}\n  &.towards-91-deg {.wind-rotate(91deg);}\n  &.towards-92-deg {.wind-rotate(92deg);}\n  &.towards-93-deg {.wind-rotate(93deg);}\n  &.towards-94-deg {.wind-rotate(94deg);}\n  &.towards-95-deg {.wind-rotate(95deg);}\n  &.towards-96-deg {.wind-rotate(96deg);}\n  &.towards-97-deg {.wind-rotate(97deg);}\n  &.towards-98-deg {.wind-rotate(98deg);}\n  &.towards-99-deg {.wind-rotate(99deg);}\n  &.towards-100-deg {.wind-rotate(100deg);}\n  &.towards-101-deg {.wind-rotate(101deg);}\n  &.towards-102-deg {.wind-rotate(102deg);}\n  &.towards-103-deg {.wind-rotate(103deg);}\n  &.towards-104-deg {.wind-rotate(104deg);}\n  &.towards-105-deg {.wind-rotate(105deg);}\n  &.towards-106-deg {.wind-rotate(106deg);}\n  &.towards-107-deg {.wind-rotate(107deg);}\n  &.towards-108-deg {.wind-rotate(108deg);}\n  &.towards-109-deg {.wind-rotate(109deg);}\n  &.towards-110-deg {.wind-rotate(110deg);}\n  &.towards-111-deg {.wind-rotate(111deg);}\n  &.towards-112-deg {.wind-rotate(112deg);}\n  &.towards-113-deg {.wind-rotate(113deg);}\n  &.towards-114-deg {.wind-rotate(114deg);}\n  &.towards-115-deg {.wind-rotate(115deg);}\n  &.towards-116-deg {.wind-rotate(116deg);}\n  &.towards-117-deg {.wind-rotate(117deg);}\n  &.towards-118-deg {.wind-rotate(118deg);}\n  &.towards-119-deg {.wind-rotate(119deg);}\n  &.towards-120-deg {.wind-rotate(120deg);}\n  &.towards-121-deg {.wind-rotate(121deg);}\n  &.towards-122-deg {.wind-rotate(122deg);}\n  &.towards-123-deg {.wind-rotate(123deg);}\n  &.towards-124-deg {.wind-rotate(124deg);}\n  &.towards-125-deg {.wind-rotate(125deg);}\n  &.towards-126-deg {.wind-rotate(126deg);}\n  &.towards-127-deg {.wind-rotate(127deg);}\n  &.towards-128-deg {.wind-rotate(128deg);}\n  &.towards-129-deg {.wind-rotate(129deg);}\n  &.towards-130-deg {.wind-rotate(130deg);}\n  &.towards-131-deg {.wind-rotate(131deg);}\n  &.towards-132-deg {.wind-rotate(132deg);}\n  &.towards-133-deg {.wind-rotate(133deg);}\n  &.towards-134-deg {.wind-rotate(134deg);}\n  &.towards-135-deg {.wind-rotate(135deg);}\n  &.towards-136-deg {.wind-rotate(136deg);}\n  &.towards-137-deg {.wind-rotate(137deg);}\n  &.towards-138-deg {.wind-rotate(138deg);}\n  &.towards-139-deg {.wind-rotate(139deg);}\n  &.towards-140-deg {.wind-rotate(140deg);}\n  &.towards-141-deg {.wind-rotate(141deg);}\n  &.towards-142-deg {.wind-rotate(142deg);}\n  &.towards-143-deg {.wind-rotate(143deg);}\n  &.towards-144-deg {.wind-rotate(144deg);}\n  &.towards-145-deg {.wind-rotate(145deg);}\n  &.towards-146-deg {.wind-rotate(146deg);}\n  &.towards-147-deg {.wind-rotate(147deg);}\n  &.towards-148-deg {.wind-rotate(148deg);}\n  &.towards-149-deg {.wind-rotate(149deg);}\n  &.towards-150-deg {.wind-rotate(150deg);}\n  &.towards-151-deg {.wind-rotate(151deg);}\n  &.towards-152-deg {.wind-rotate(152deg);}\n  &.towards-153-deg {.wind-rotate(153deg);}\n  &.towards-154-deg {.wind-rotate(154deg);}\n  &.towards-155-deg {.wind-rotate(155deg);}\n  &.towards-156-deg {.wind-rotate(156deg);}\n  &.towards-157-deg {.wind-rotate(157deg);}\n  &.towards-158-deg {.wind-rotate(158deg);}\n  &.towards-159-deg {.wind-rotate(159deg);}\n  &.towards-160-deg {.wind-rotate(160deg);}\n  &.towards-161-deg {.wind-rotate(161deg);}\n  &.towards-162-deg {.wind-rotate(162deg);}\n  &.towards-163-deg {.wind-rotate(163deg);}\n  &.towards-164-deg {.wind-rotate(164deg);}\n  &.towards-165-deg {.wind-rotate(165deg);}\n  &.towards-166-deg {.wind-rotate(166deg);}\n  &.towards-167-deg {.wind-rotate(167deg);}\n  &.towards-168-deg {.wind-rotate(168deg);}\n  &.towards-169-deg {.wind-rotate(169deg);}\n  &.towards-170-deg {.wind-rotate(170deg);}\n  &.towards-171-deg {.wind-rotate(171deg);}\n  &.towards-172-deg {.wind-rotate(172deg);}\n  &.towards-173-deg {.wind-rotate(173deg);}\n  &.towards-174-deg {.wind-rotate(174deg);}\n  &.towards-175-deg {.wind-rotate(175deg);}\n  &.towards-176-deg {.wind-rotate(176deg);}\n  &.towards-177-deg {.wind-rotate(177deg);}\n  &.towards-178-deg {.wind-rotate(178deg);}\n  &.towards-179-deg {.wind-rotate(179deg);}\n  &.towards-180-deg {.wind-rotate(180deg);}\n  &.towards-181-deg {.wind-rotate(181deg);}\n  &.towards-182-deg {.wind-rotate(182deg);}\n  &.towards-183-deg {.wind-rotate(183deg);}\n  &.towards-184-deg {.wind-rotate(184deg);}\n  &.towards-185-deg {.wind-rotate(185deg);}\n  &.towards-186-deg {.wind-rotate(186deg);}\n  &.towards-187-deg {.wind-rotate(187deg);}\n  &.towards-188-deg {.wind-rotate(188deg);}\n  &.towards-189-deg {.wind-rotate(189deg);}\n  &.towards-190-deg {.wind-rotate(190deg);}\n  &.towards-191-deg {.wind-rotate(191deg);}\n  &.towards-192-deg {.wind-rotate(192deg);}\n  &.towards-193-deg {.wind-rotate(193deg);}\n  &.towards-194-deg {.wind-rotate(194deg);}\n  &.towards-195-deg {.wind-rotate(195deg);}\n  &.towards-196-deg {.wind-rotate(196deg);}\n  &.towards-197-deg {.wind-rotate(197deg);}\n  &.towards-198-deg {.wind-rotate(198deg);}\n  &.towards-199-deg {.wind-rotate(199deg);}\n  &.towards-200-deg {.wind-rotate(200deg);}\n  &.towards-201-deg {.wind-rotate(201deg);}\n  &.towards-202-deg {.wind-rotate(202deg);}\n  &.towards-203-deg {.wind-rotate(203deg);}\n  &.towards-204-deg {.wind-rotate(204deg);}\n  &.towards-205-deg {.wind-rotate(205deg);}\n  &.towards-206-deg {.wind-rotate(206deg);}\n  &.towards-207-deg {.wind-rotate(207deg);}\n  &.towards-208-deg {.wind-rotate(208deg);}\n  &.towards-209-deg {.wind-rotate(209deg);}\n  &.towards-210-deg {.wind-rotate(210deg);}\n  &.towards-211-deg {.wind-rotate(211deg);}\n  &.towards-212-deg {.wind-rotate(212deg);}\n  &.towards-213-deg {.wind-rotate(213deg);}\n  &.towards-214-deg {.wind-rotate(214deg);}\n  &.towards-215-deg {.wind-rotate(215deg);}\n  &.towards-216-deg {.wind-rotate(216deg);}\n  &.towards-217-deg {.wind-rotate(217deg);}\n  &.towards-218-deg {.wind-rotate(218deg);}\n  &.towards-219-deg {.wind-rotate(219deg);}\n  &.towards-220-deg {.wind-rotate(220deg);}\n  &.towards-221-deg {.wind-rotate(221deg);}\n  &.towards-222-deg {.wind-rotate(222deg);}\n  &.towards-223-deg {.wind-rotate(223deg);}\n  &.towards-224-deg {.wind-rotate(224deg);}\n  &.towards-225-deg {.wind-rotate(225deg);}\n  &.towards-226-deg {.wind-rotate(226deg);}\n  &.towards-227-deg {.wind-rotate(227deg);}\n  &.towards-228-deg {.wind-rotate(228deg);}\n  &.towards-229-deg {.wind-rotate(229deg);}\n  &.towards-230-deg {.wind-rotate(230deg);}\n  &.towards-231-deg {.wind-rotate(231deg);}\n  &.towards-232-deg {.wind-rotate(232deg);}\n  &.towards-233-deg {.wind-rotate(233deg);}\n  &.towards-234-deg {.wind-rotate(234deg);}\n  &.towards-235-deg {.wind-rotate(235deg);}\n  &.towards-236-deg {.wind-rotate(236deg);}\n  &.towards-237-deg {.wind-rotate(237deg);}\n  &.towards-238-deg {.wind-rotate(238deg);}\n  &.towards-239-deg {.wind-rotate(239deg);}\n  &.towards-240-deg {.wind-rotate(240deg);}\n  &.towards-241-deg {.wind-rotate(241deg);}\n  &.towards-242-deg {.wind-rotate(242deg);}\n  &.towards-243-deg {.wind-rotate(243deg);}\n  &.towards-244-deg {.wind-rotate(244deg);}\n  &.towards-245-deg {.wind-rotate(245deg);}\n  &.towards-246-deg {.wind-rotate(246deg);}\n  &.towards-247-deg {.wind-rotate(247deg);}\n  &.towards-248-deg {.wind-rotate(248deg);}\n  &.towards-249-deg {.wind-rotate(249deg);}\n  &.towards-250-deg {.wind-rotate(250deg);}\n  &.towards-251-deg {.wind-rotate(251deg);}\n  &.towards-252-deg {.wind-rotate(252deg);}\n  &.towards-253-deg {.wind-rotate(253deg);}\n  &.towards-254-deg {.wind-rotate(254deg);}\n  &.towards-255-deg {.wind-rotate(255deg);}\n  &.towards-256-deg {.wind-rotate(256deg);}\n  &.towards-257-deg {.wind-rotate(257deg);}\n  &.towards-258-deg {.wind-rotate(258deg);}\n  &.towards-259-deg {.wind-rotate(259deg);}\n  &.towards-260-deg {.wind-rotate(260deg);}\n  &.towards-261-deg {.wind-rotate(261deg);}\n  &.towards-262-deg {.wind-rotate(262deg);}\n  &.towards-263-deg {.wind-rotate(263deg);}\n  &.towards-264-deg {.wind-rotate(264deg);}\n  &.towards-265-deg {.wind-rotate(265deg);}\n  &.towards-266-deg {.wind-rotate(266deg);}\n  &.towards-267-deg {.wind-rotate(267deg);}\n  &.towards-268-deg {.wind-rotate(268deg);}\n  &.towards-269-deg {.wind-rotate(269deg);}\n  &.towards-270-deg {.wind-rotate(270deg);}\n  &.towards-271-deg {.wind-rotate(271deg);}\n  &.towards-272-deg {.wind-rotate(272deg);}\n  &.towards-273-deg {.wind-rotate(273deg);}\n  &.towards-274-deg {.wind-rotate(274deg);}\n  &.towards-275-deg {.wind-rotate(275deg);}\n  &.towards-276-deg {.wind-rotate(276deg);}\n  &.towards-277-deg {.wind-rotate(277deg);}\n  &.towards-278-deg {.wind-rotate(278deg);}\n  &.towards-279-deg {.wind-rotate(279deg);}\n  &.towards-280-deg {.wind-rotate(280deg);}\n  &.towards-281-deg {.wind-rotate(281deg);}\n  &.towards-282-deg {.wind-rotate(282deg);}\n  &.towards-283-deg {.wind-rotate(283deg);}\n  &.towards-284-deg {.wind-rotate(284deg);}\n  &.towards-285-deg {.wind-rotate(285deg);}\n  &.towards-286-deg {.wind-rotate(286deg);}\n  &.towards-287-deg {.wind-rotate(287deg);}\n  &.towards-288-deg {.wind-rotate(288deg);}\n  &.towards-289-deg {.wind-rotate(289deg);}\n  &.towards-290-deg {.wind-rotate(290deg);}\n  &.towards-291-deg {.wind-rotate(291deg);}\n  &.towards-292-deg {.wind-rotate(292deg);}\n  &.towards-293-deg {.wind-rotate(293deg);}\n  &.towards-294-deg {.wind-rotate(294deg);}\n  &.towards-295-deg {.wind-rotate(295deg);}\n  &.towards-296-deg {.wind-rotate(296deg);}\n  &.towards-297-deg {.wind-rotate(297deg);}\n  &.towards-298-deg {.wind-rotate(298deg);}\n  &.towards-299-deg {.wind-rotate(299deg);}\n  &.towards-300-deg {.wind-rotate(300deg);}\n  &.towards-301-deg {.wind-rotate(301deg);}\n  &.towards-302-deg {.wind-rotate(302deg);}\n  &.towards-303-deg {.wind-rotate(303deg);}\n  &.towards-304-deg {.wind-rotate(304deg);}\n  &.towards-305-deg {.wind-rotate(305deg);}\n  &.towards-306-deg {.wind-rotate(306deg);}\n  &.towards-307-deg {.wind-rotate(307deg);}\n  &.towards-308-deg {.wind-rotate(308deg);}\n  &.towards-309-deg {.wind-rotate(309deg);}\n  &.towards-310-deg {.wind-rotate(310deg);}\n  &.towards-311-deg {.wind-rotate(311deg);}\n  &.towards-312-deg {.wind-rotate(312deg);}\n  &.towards-313-deg {.wind-rotate(313deg);}\n  &.towards-314-deg {.wind-rotate(314deg);}\n  &.towards-315-deg {.wind-rotate(315deg);}\n  &.towards-316-deg {.wind-rotate(316deg);}\n  &.towards-317-deg {.wind-rotate(317deg);}\n  &.towards-318-deg {.wind-rotate(318deg);}\n  &.towards-319-deg {.wind-rotate(319deg);}\n  &.towards-320-deg {.wind-rotate(320deg);}\n  &.towards-321-deg {.wind-rotate(321deg);}\n  &.towards-322-deg {.wind-rotate(322deg);}\n  &.towards-323-deg {.wind-rotate(323deg);}\n  &.towards-324-deg {.wind-rotate(324deg);}\n  &.towards-325-deg {.wind-rotate(325deg);}\n  &.towards-326-deg {.wind-rotate(326deg);}\n  &.towards-327-deg {.wind-rotate(327deg);}\n  &.towards-328-deg {.wind-rotate(328deg);}\n  &.towards-329-deg {.wind-rotate(329deg);}\n  &.towards-330-deg {.wind-rotate(330deg);}\n  &.towards-331-deg {.wind-rotate(331deg);}\n  &.towards-332-deg {.wind-rotate(332deg);}\n  &.towards-333-deg {.wind-rotate(333deg);}\n  &.towards-334-deg {.wind-rotate(334deg);}\n  &.towards-335-deg {.wind-rotate(335deg);}\n  &.towards-336-deg {.wind-rotate(336deg);}\n  &.towards-337-deg {.wind-rotate(337deg);}\n  &.towards-338-deg {.wind-rotate(338deg);}\n  &.towards-339-deg {.wind-rotate(339deg);}\n  &.towards-340-deg {.wind-rotate(340deg);}\n  &.towards-341-deg {.wind-rotate(341deg);}\n  &.towards-342-deg {.wind-rotate(342deg);}\n  &.towards-343-deg {.wind-rotate(343deg);}\n  &.towards-344-deg {.wind-rotate(344deg);}\n  &.towards-345-deg {.wind-rotate(345deg);}\n  &.towards-346-deg {.wind-rotate(346deg);}\n  &.towards-347-deg {.wind-rotate(347deg);}\n  &.towards-348-deg {.wind-rotate(348deg);}\n  &.towards-349-deg {.wind-rotate(349deg);}\n  &.towards-350-deg {.wind-rotate(350deg);}\n  &.towards-351-deg {.wind-rotate(351deg);}\n  &.towards-352-deg {.wind-rotate(352deg);}\n  &.towards-353-deg {.wind-rotate(353deg);}\n  &.towards-354-deg {.wind-rotate(354deg);}\n  &.towards-355-deg {.wind-rotate(355deg);}\n  &.towards-356-deg {.wind-rotate(356deg);}\n  &.towards-357-deg {.wind-rotate(357deg);}\n  &.towards-358-deg {.wind-rotate(358deg);}\n  &.towards-359-deg {.wind-rotate(359deg);}\n  &.towards-360-deg {.wind-rotate(0deg);}\n  &.from-0-deg {.wind-rotate(180deg);}\n  &.from-1-deg {.wind-rotate(181deg);}\n  &.from-2-deg {.wind-rotate(182deg);}\n  &.from-3-deg {.wind-rotate(183deg);}\n  &.from-4-deg {.wind-rotate(184deg);}\n  &.from-5-deg {.wind-rotate(185deg);}\n  &.from-6-deg {.wind-rotate(186deg);}\n  &.from-7-deg {.wind-rotate(187deg);}\n  &.from-8-deg {.wind-rotate(188deg);}\n  &.from-9-deg {.wind-rotate(189deg);}\n  &.from-10-deg {.wind-rotate(190deg);}\n  &.from-11-deg {.wind-rotate(191deg);}\n  &.from-12-deg {.wind-rotate(192deg);}\n  &.from-13-deg {.wind-rotate(193deg);}\n  &.from-14-deg {.wind-rotate(194deg);}\n  &.from-15-deg {.wind-rotate(195deg);}\n  &.from-16-deg {.wind-rotate(196deg);}\n  &.from-17-deg {.wind-rotate(197deg);}\n  &.from-18-deg {.wind-rotate(198deg);}\n  &.from-19-deg {.wind-rotate(199deg);}\n  &.from-20-deg {.wind-rotate(200deg);}\n  &.from-21-deg {.wind-rotate(201deg);}\n  &.from-22-deg {.wind-rotate(202deg);}\n  &.from-23-deg {.wind-rotate(203deg);}\n  &.from-24-deg {.wind-rotate(204deg);}\n  &.from-25-deg {.wind-rotate(205deg);}\n  &.from-26-deg {.wind-rotate(206deg);}\n  &.from-27-deg {.wind-rotate(207deg);}\n  &.from-28-deg {.wind-rotate(208deg);}\n  &.from-29-deg {.wind-rotate(209deg);}\n  &.from-30-deg {.wind-rotate(210deg);}\n  &.from-31-deg {.wind-rotate(211deg);}\n  &.from-32-deg {.wind-rotate(212deg);}\n  &.from-33-deg {.wind-rotate(213deg);}\n  &.from-34-deg {.wind-rotate(214deg);}\n  &.from-35-deg {.wind-rotate(215deg);}\n  &.from-36-deg {.wind-rotate(216deg);}\n  &.from-37-deg {.wind-rotate(217deg);}\n  &.from-38-deg {.wind-rotate(218deg);}\n  &.from-39-deg {.wind-rotate(219deg);}\n  &.from-40-deg {.wind-rotate(220deg);}\n  &.from-41-deg {.wind-rotate(221deg);}\n  &.from-42-deg {.wind-rotate(222deg);}\n  &.from-43-deg {.wind-rotate(223deg);}\n  &.from-44-deg {.wind-rotate(224deg);}\n  &.from-45-deg {.wind-rotate(225deg);}\n  &.from-46-deg {.wind-rotate(226deg);}\n  &.from-47-deg {.wind-rotate(227deg);}\n  &.from-48-deg {.wind-rotate(228deg);}\n  &.from-49-deg {.wind-rotate(229deg);}\n  &.from-50-deg {.wind-rotate(230deg);}\n  &.from-51-deg {.wind-rotate(231deg);}\n  &.from-52-deg {.wind-rotate(232deg);}\n  &.from-53-deg {.wind-rotate(233deg);}\n  &.from-54-deg {.wind-rotate(234deg);}\n  &.from-55-deg {.wind-rotate(235deg);}\n  &.from-56-deg {.wind-rotate(236deg);}\n  &.from-57-deg {.wind-rotate(237deg);}\n  &.from-58-deg {.wind-rotate(238deg);}\n  &.from-59-deg {.wind-rotate(239deg);}\n  &.from-60-deg {.wind-rotate(240deg);}\n  &.from-61-deg {.wind-rotate(241deg);}\n  &.from-62-deg {.wind-rotate(242deg);}\n  &.from-63-deg {.wind-rotate(243deg);}\n  &.from-64-deg {.wind-rotate(244deg);}\n  &.from-65-deg {.wind-rotate(245deg);}\n  &.from-66-deg {.wind-rotate(246deg);}\n  &.from-67-deg {.wind-rotate(247deg);}\n  &.from-68-deg {.wind-rotate(248deg);}\n  &.from-69-deg {.wind-rotate(249deg);}\n  &.from-70-deg {.wind-rotate(250deg);}\n  &.from-71-deg {.wind-rotate(251deg);}\n  &.from-72-deg {.wind-rotate(252deg);}\n  &.from-73-deg {.wind-rotate(253deg);}\n  &.from-74-deg {.wind-rotate(254deg);}\n  &.from-75-deg {.wind-rotate(255deg);}\n  &.from-76-deg {.wind-rotate(256deg);}\n  &.from-77-deg {.wind-rotate(257deg);}\n  &.from-78-deg {.wind-rotate(258deg);}\n  &.from-79-deg {.wind-rotate(259deg);}\n  &.from-80-deg {.wind-rotate(260deg);}\n  &.from-81-deg {.wind-rotate(261deg);}\n  &.from-82-deg {.wind-rotate(262deg);}\n  &.from-83-deg {.wind-rotate(263deg);}\n  &.from-84-deg {.wind-rotate(264deg);}\n  &.from-85-deg {.wind-rotate(265deg);}\n  &.from-86-deg {.wind-rotate(266deg);}\n  &.from-87-deg {.wind-rotate(267deg);}\n  &.from-88-deg {.wind-rotate(268deg);}\n  &.from-89-deg {.wind-rotate(269deg);}\n  &.from-90-deg {.wind-rotate(270deg);}\n  &.from-91-deg {.wind-rotate(271deg);}\n  &.from-92-deg {.wind-rotate(272deg);}\n  &.from-93-deg {.wind-rotate(273deg);}\n  &.from-94-deg {.wind-rotate(274deg);}\n  &.from-95-deg {.wind-rotate(275deg);}\n  &.from-96-deg {.wind-rotate(276deg);}\n  &.from-97-deg {.wind-rotate(277deg);}\n  &.from-98-deg {.wind-rotate(278deg);}\n  &.from-99-deg {.wind-rotate(279deg);}\n  &.from-100-deg {.wind-rotate(280deg);}\n  &.from-101-deg {.wind-rotate(281deg);}\n  &.from-102-deg {.wind-rotate(282deg);}\n  &.from-103-deg {.wind-rotate(283deg);}\n  &.from-104-deg {.wind-rotate(284deg);}\n  &.from-105-deg {.wind-rotate(285deg);}\n  &.from-106-deg {.wind-rotate(286deg);}\n  &.from-107-deg {.wind-rotate(287deg);}\n  &.from-108-deg {.wind-rotate(288deg);}\n  &.from-109-deg {.wind-rotate(289deg);}\n  &.from-110-deg {.wind-rotate(290deg);}\n  &.from-111-deg {.wind-rotate(291deg);}\n  &.from-112-deg {.wind-rotate(292deg);}\n  &.from-113-deg {.wind-rotate(293deg);}\n  &.from-114-deg {.wind-rotate(294deg);}\n  &.from-115-deg {.wind-rotate(295deg);}\n  &.from-116-deg {.wind-rotate(296deg);}\n  &.from-117-deg {.wind-rotate(297deg);}\n  &.from-118-deg {.wind-rotate(298deg);}\n  &.from-119-deg {.wind-rotate(299deg);}\n  &.from-120-deg {.wind-rotate(300deg);}\n  &.from-121-deg {.wind-rotate(301deg);}\n  &.from-122-deg {.wind-rotate(302deg);}\n  &.from-123-deg {.wind-rotate(303deg);}\n  &.from-124-deg {.wind-rotate(304deg);}\n  &.from-125-deg {.wind-rotate(305deg);}\n  &.from-126-deg {.wind-rotate(306deg);}\n  &.from-127-deg {.wind-rotate(307deg);}\n  &.from-128-deg {.wind-rotate(308deg);}\n  &.from-129-deg {.wind-rotate(309deg);}\n  &.from-130-deg {.wind-rotate(310deg);}\n  &.from-131-deg {.wind-rotate(311deg);}\n  &.from-132-deg {.wind-rotate(312deg);}\n  &.from-133-deg {.wind-rotate(313deg);}\n  &.from-134-deg {.wind-rotate(314deg);}\n  &.from-135-deg {.wind-rotate(315deg);}\n  &.from-136-deg {.wind-rotate(316deg);}\n  &.from-137-deg {.wind-rotate(317deg);}\n  &.from-138-deg {.wind-rotate(318deg);}\n  &.from-139-deg {.wind-rotate(319deg);}\n  &.from-140-deg {.wind-rotate(320deg);}\n  &.from-141-deg {.wind-rotate(321deg);}\n  &.from-142-deg {.wind-rotate(322deg);}\n  &.from-143-deg {.wind-rotate(323deg);}\n  &.from-144-deg {.wind-rotate(324deg);}\n  &.from-145-deg {.wind-rotate(325deg);}\n  &.from-146-deg {.wind-rotate(326deg);}\n  &.from-147-deg {.wind-rotate(327deg);}\n  &.from-148-deg {.wind-rotate(328deg);}\n  &.from-149-deg {.wind-rotate(329deg);}\n  &.from-150-deg {.wind-rotate(330deg);}\n  &.from-151-deg {.wind-rotate(331deg);}\n  &.from-152-deg {.wind-rotate(332deg);}\n  &.from-153-deg {.wind-rotate(333deg);}\n  &.from-154-deg {.wind-rotate(334deg);}\n  &.from-155-deg {.wind-rotate(335deg);}\n  &.from-156-deg {.wind-rotate(336deg);}\n  &.from-157-deg {.wind-rotate(337deg);}\n  &.from-158-deg {.wind-rotate(338deg);}\n  &.from-159-deg {.wind-rotate(339deg);}\n  &.from-160-deg {.wind-rotate(340deg);}\n  &.from-161-deg {.wind-rotate(341deg);}\n  &.from-162-deg {.wind-rotate(342deg);}\n  &.from-163-deg {.wind-rotate(343deg);}\n  &.from-164-deg {.wind-rotate(344deg);}\n  &.from-165-deg {.wind-rotate(345deg);}\n  &.from-166-deg {.wind-rotate(346deg);}\n  &.from-167-deg {.wind-rotate(347deg);}\n  &.from-168-deg {.wind-rotate(348deg);}\n  &.from-169-deg {.wind-rotate(349deg);}\n  &.from-170-deg {.wind-rotate(350deg);}\n  &.from-171-deg {.wind-rotate(351deg);}\n  &.from-172-deg {.wind-rotate(352deg);}\n  &.from-173-deg {.wind-rotate(353deg);}\n  &.from-174-deg {.wind-rotate(354deg);}\n  &.from-175-deg {.wind-rotate(355deg);}\n  &.from-176-deg {.wind-rotate(356deg);}\n  &.from-177-deg {.wind-rotate(357deg);}\n  &.from-178-deg {.wind-rotate(358deg);}\n  &.from-179-deg {.wind-rotate(359deg);}\n  &.from-180-deg {.wind-rotate(0deg);}\n  &.from-181-deg {.wind-rotate(1deg);}\n  &.from-182-deg {.wind-rotate(2deg);}\n  &.from-183-deg {.wind-rotate(3deg);}\n  &.from-184-deg {.wind-rotate(4deg);}\n  &.from-185-deg {.wind-rotate(5deg);}\n  &.from-186-deg {.wind-rotate(6deg);}\n  &.from-187-deg {.wind-rotate(7deg);}\n  &.from-188-deg {.wind-rotate(8deg);}\n  &.from-189-deg {.wind-rotate(9deg);}\n  &.from-190-deg {.wind-rotate(10deg);}\n  &.from-191-deg {.wind-rotate(11deg);}\n  &.from-192-deg {.wind-rotate(12deg);}\n  &.from-193-deg {.wind-rotate(13deg);}\n  &.from-194-deg {.wind-rotate(14deg);}\n  &.from-195-deg {.wind-rotate(15deg);}\n  &.from-196-deg {.wind-rotate(16deg);}\n  &.from-197-deg {.wind-rotate(17deg);}\n  &.from-198-deg {.wind-rotate(18deg);}\n  &.from-199-deg {.wind-rotate(19deg);}\n  &.from-200-deg {.wind-rotate(20deg);}\n  &.from-201-deg {.wind-rotate(21deg);}\n  &.from-202-deg {.wind-rotate(22deg);}\n  &.from-203-deg {.wind-rotate(23deg);}\n  &.from-204-deg {.wind-rotate(24deg);}\n  &.from-205-deg {.wind-rotate(25deg);}\n  &.from-206-deg {.wind-rotate(26deg);}\n  &.from-207-deg {.wind-rotate(27deg);}\n  &.from-208-deg {.wind-rotate(28deg);}\n  &.from-209-deg {.wind-rotate(29deg);}\n  &.from-210-deg {.wind-rotate(30deg);}\n  &.from-211-deg {.wind-rotate(31deg);}\n  &.from-212-deg {.wind-rotate(32deg);}\n  &.from-213-deg {.wind-rotate(33deg);}\n  &.from-214-deg {.wind-rotate(34deg);}\n  &.from-215-deg {.wind-rotate(35deg);}\n  &.from-216-deg {.wind-rotate(36deg);}\n  &.from-217-deg {.wind-rotate(37deg);}\n  &.from-218-deg {.wind-rotate(38deg);}\n  &.from-219-deg {.wind-rotate(39deg);}\n  &.from-220-deg {.wind-rotate(40deg);}\n  &.from-221-deg {.wind-rotate(41deg);}\n  &.from-222-deg {.wind-rotate(42deg);}\n  &.from-223-deg {.wind-rotate(43deg);}\n  &.from-224-deg {.wind-rotate(44deg);}\n  &.from-225-deg {.wind-rotate(45deg);}\n  &.from-226-deg {.wind-rotate(46deg);}\n  &.from-227-deg {.wind-rotate(47deg);}\n  &.from-228-deg {.wind-rotate(48deg);}\n  &.from-229-deg {.wind-rotate(49deg);}\n  &.from-230-deg {.wind-rotate(50deg);}\n  &.from-231-deg {.wind-rotate(51deg);}\n  &.from-232-deg {.wind-rotate(52deg);}\n  &.from-233-deg {.wind-rotate(53deg);}\n  &.from-234-deg {.wind-rotate(54deg);}\n  &.from-235-deg {.wind-rotate(55deg);}\n  &.from-236-deg {.wind-rotate(56deg);}\n  &.from-237-deg {.wind-rotate(57deg);}\n  &.from-238-deg {.wind-rotate(58deg);}\n  &.from-239-deg {.wind-rotate(59deg);}\n  &.from-240-deg {.wind-rotate(60deg);}\n  &.from-241-deg {.wind-rotate(61deg);}\n  &.from-242-deg {.wind-rotate(62deg);}\n  &.from-243-deg {.wind-rotate(63deg);}\n  &.from-244-deg {.wind-rotate(64deg);}\n  &.from-245-deg {.wind-rotate(65deg);}\n  &.from-246-deg {.wind-rotate(66deg);}\n  &.from-247-deg {.wind-rotate(67deg);}\n  &.from-248-deg {.wind-rotate(68deg);}\n  &.from-249-deg {.wind-rotate(69deg);}\n  &.from-250-deg {.wind-rotate(70deg);}\n  &.from-251-deg {.wind-rotate(71deg);}\n  &.from-252-deg {.wind-rotate(72deg);}\n  &.from-253-deg {.wind-rotate(73deg);}\n  &.from-254-deg {.wind-rotate(74deg);}\n  &.from-255-deg {.wind-rotate(75deg);}\n  &.from-256-deg {.wind-rotate(76deg);}\n  &.from-257-deg {.wind-rotate(77deg);}\n  &.from-258-deg {.wind-rotate(78deg);}\n  &.from-259-deg {.wind-rotate(79deg);}\n  &.from-260-deg {.wind-rotate(80deg);}\n  &.from-261-deg {.wind-rotate(81deg);}\n  &.from-262-deg {.wind-rotate(82deg);}\n  &.from-263-deg {.wind-rotate(83deg);}\n  &.from-264-deg {.wind-rotate(84deg);}\n  &.from-265-deg {.wind-rotate(85deg);}\n  &.from-266-deg {.wind-rotate(86deg);}\n  &.from-267-deg {.wind-rotate(87deg);}\n  &.from-268-deg {.wind-rotate(88deg);}\n  &.from-269-deg {.wind-rotate(89deg);}\n  &.from-270-deg {.wind-rotate(90deg);}\n  &.from-271-deg {.wind-rotate(91deg);}\n  &.from-272-deg {.wind-rotate(92deg);}\n  &.from-273-deg {.wind-rotate(93deg);}\n  &.from-274-deg {.wind-rotate(94deg);}\n  &.from-275-deg {.wind-rotate(95deg);}\n  &.from-276-deg {.wind-rotate(96deg);}\n  &.from-277-deg {.wind-rotate(97deg);}\n  &.from-278-deg {.wind-rotate(98deg);}\n  &.from-279-deg {.wind-rotate(99deg);}\n  &.from-280-deg {.wind-rotate(100deg);}\n  &.from-281-deg {.wind-rotate(101deg);}\n  &.from-282-deg {.wind-rotate(102deg);}\n  &.from-283-deg {.wind-rotate(103deg);}\n  &.from-284-deg {.wind-rotate(104deg);}\n  &.from-285-deg {.wind-rotate(105deg);}\n  &.from-286-deg {.wind-rotate(106deg);}\n  &.from-287-deg {.wind-rotate(107deg);}\n  &.from-288-deg {.wind-rotate(108deg);}\n  &.from-289-deg {.wind-rotate(109deg);}\n  &.from-290-deg {.wind-rotate(110deg);}\n  &.from-291-deg {.wind-rotate(111deg);}\n  &.from-292-deg {.wind-rotate(112deg);}\n  &.from-293-deg {.wind-rotate(113deg);}\n  &.from-294-deg {.wind-rotate(114deg);}\n  &.from-295-deg {.wind-rotate(115deg);}\n  &.from-296-deg {.wind-rotate(116deg);}\n  &.from-297-deg {.wind-rotate(117deg);}\n  &.from-298-deg {.wind-rotate(118deg);}\n  &.from-299-deg {.wind-rotate(119deg);}\n  &.from-300-deg {.wind-rotate(120deg);}\n  &.from-301-deg {.wind-rotate(121deg);}\n  &.from-302-deg {.wind-rotate(122deg);}\n  &.from-303-deg {.wind-rotate(123deg);}\n  &.from-304-deg {.wind-rotate(124deg);}\n  &.from-305-deg {.wind-rotate(125deg);}\n  &.from-306-deg {.wind-rotate(126deg);}\n  &.from-307-deg {.wind-rotate(127deg);}\n  &.from-308-deg {.wind-rotate(128deg);}\n  &.from-309-deg {.wind-rotate(129deg);}\n  &.from-310-deg {.wind-rotate(130deg);}\n  &.from-311-deg {.wind-rotate(131deg);}\n  &.from-312-deg {.wind-rotate(132deg);}\n  &.from-313-deg {.wind-rotate(133deg);}\n  &.from-314-deg {.wind-rotate(134deg);}\n  &.from-315-deg {.wind-rotate(135deg);}\n  &.from-316-deg {.wind-rotate(136deg);}\n  &.from-317-deg {.wind-rotate(137deg);}\n  &.from-318-deg {.wind-rotate(138deg);}\n  &.from-319-deg {.wind-rotate(139deg);}\n  &.from-320-deg {.wind-rotate(140deg);}\n  &.from-321-deg {.wind-rotate(141deg);}\n  &.from-322-deg {.wind-rotate(142deg);}\n  &.from-323-deg {.wind-rotate(143deg);}\n  &.from-324-deg {.wind-rotate(144deg);}\n  &.from-325-deg {.wind-rotate(145deg);}\n  &.from-326-deg {.wind-rotate(146deg);}\n  &.from-327-deg {.wind-rotate(147deg);}\n  &.from-328-deg {.wind-rotate(148deg);}\n  &.from-329-deg {.wind-rotate(149deg);}\n  &.from-330-deg {.wind-rotate(150deg);}\n  &.from-331-deg {.wind-rotate(151deg);}\n  &.from-332-deg {.wind-rotate(152deg);}\n  &.from-333-deg {.wind-rotate(153deg);}\n  &.from-334-deg {.wind-rotate(154deg);}\n  &.from-335-deg {.wind-rotate(155deg);}\n  &.from-336-deg {.wind-rotate(156deg);}\n  &.from-337-deg {.wind-rotate(157deg);}\n  &.from-338-deg {.wind-rotate(158deg);}\n  &.from-339-deg {.wind-rotate(159deg);}\n  &.from-340-deg {.wind-rotate(160deg);}\n  &.from-341-deg {.wind-rotate(161deg);}\n  &.from-342-deg {.wind-rotate(162deg);}\n  &.from-343-deg {.wind-rotate(163deg);}\n  &.from-344-deg {.wind-rotate(164deg);}\n  &.from-345-deg {.wind-rotate(165deg);}\n  &.from-346-deg {.wind-rotate(166deg);}\n  &.from-347-deg {.wind-rotate(167deg);}\n  &.from-348-deg {.wind-rotate(168deg);}\n  &.from-349-deg {.wind-rotate(169deg);}\n  &.from-350-deg {.wind-rotate(170deg);}\n  &.from-351-deg {.wind-rotate(171deg);}\n  &.from-352-deg {.wind-rotate(172deg);}\n  &.from-353-deg {.wind-rotate(173deg);}\n  &.from-354-deg {.wind-rotate(174deg);}\n  &.from-355-deg {.wind-rotate(175deg);}\n  &.from-356-deg {.wind-rotate(176deg);}\n  &.from-357-deg {.wind-rotate(177deg);}\n  &.from-358-deg {.wind-rotate(178deg);}\n  &.from-359-deg {.wind-rotate(179deg);}\n  &.from-360-deg {.wind-rotate(180deg);} \n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-classes/classes-wind.less",
    "content": "// Wind Variables 2.0\n\n@wind: \"\\f0b1\";\n\n.@{wi-css-prefix}-wind:before { content: @wind; }\n.wind-rotate(@degrees) {\n  -webkit-transform: rotate(@degrees);\n  -moz-transform: rotate(@degrees);\n  -ms-transform: rotate(@degrees);\n  -o-transform: rotate(@degrees);\n  transform: rotate(@degrees);\n}\n\n@import \"classes-wind-degrees.less\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-beaufort.less",
    "content": "@wind-beaufort-0: \"\\f0b7\";\n@wind-beaufort-1: \"\\f0b8\";\n@wind-beaufort-2: \"\\f0b9\";\n@wind-beaufort-3: \"\\f0ba\";\n@wind-beaufort-4: \"\\f0bb\";\n@wind-beaufort-5: \"\\f0bc\";\n@wind-beaufort-6: \"\\f0bd\";\n@wind-beaufort-7: \"\\f0be\";\n@wind-beaufort-8: \"\\f0bf\";\n@wind-beaufort-9: \"\\f0c0\";\n@wind-beaufort-10: \"\\f0c1\";\n@wind-beaufort-11: \"\\f0c2\";\n@wind-beaufort-12: \"\\f0c3\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-day.less",
    "content": "@day-sunny: \"\\f00d\";\n@day-cloudy: \"\\f002\";\n@day-cloudy-gusts: \"\\f000\";\n@day-cloudy-windy: \"\\f001\";\n@day-fog: \"\\f003\";\n@day-hail: \"\\f004\";\n@day-haze: \"\\f0b6\";\n@day-lightning: \"\\f005\";\n@day-rain: \"\\f008\";\n@day-rain-mix: \"\\f006\";\n@day-rain-wind: \"\\f007\";\n@day-showers: \"\\f009\";\n@day-sleet: \"\\f0b2\";\n@day-sleet-storm: \"\\f068\";\n@day-snow: \"\\f00a\";\n@day-snow-thunderstorm: \"\\f06b\";\n@day-snow-wind: \"\\f065\";\n@day-sprinkle: \"\\f00b\";\n@day-storm-showers: \"\\f00e\";\n@day-sunny-overcast: \"\\f00c\";\n@day-thunderstorm: \"\\f010\";\n@day-windy: \"\\f085\";\n@solar-eclipse: \"\\f06e\";\n@hot: \"\\f072\";\n@day-cloudy-high: \"\\f07d\";\n@day-light-wind: \"\\f0c4\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-direction.less",
    "content": "@direction-up: \"\\f058\";\n@direction-up-right: \"\\f057\";\n@direction-right: \"\\f04d\";\n@direction-down-right: \"\\f088\";\n@direction-down: \"\\f044\";\n@direction-down-left: \"\\f043\";\n@direction-left: \"\\f048\";\n@direction-up-left: \"\\f087\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-misc.less",
    "content": "@alien: \"\\f075\";\n@celsius: \"\\f03c\";\n@fahrenheit: \"\\f045\";\n@degrees: \"\\f042\";\n@thermometer: \"\\f055\";\n@thermometer-exterior: \"\\f053\";\n@thermometer-internal: \"\\f054\";\n@cloud-down: \"\\f03d\";\n@cloud-up: \"\\f040\";\n@cloud-refresh: \"\\f03e\";\n@horizon: \"\\f047\";\n@horizon-alt: \"\\f046\";\n@sunrise: \"\\f051\";\n@sunset: \"\\f052\";\n@moonrise: \"\\f0c9\";\n@moonset: \"\\f0ca\";\n@refresh: \"\\f04c\";\n@refresh-alt: \"\\f04b\";\n@umbrella: \"\\f084\";\n@barometer: \"\\f079\";\n@humidity: \"\\f07a\";\n@na: \"\\f07b\";\n@train: \"\\f0cb\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-moon.less",
    "content": "@moon-new: \"\\f095\";\n@moon-waxing-cresent-1: \"\\f096\";\n@moon-waxing-cresent-2: \"\\f097\";\n@moon-waxing-cresent-3: \"\\f098\";\n@moon-waxing-cresent-4: \"\\f099\";\n@moon-waxing-cresent-5: \"\\f09a\";\n@moon-waxing-cresent-6: \"\\f09b\";\n@moon-first-quarter: \"\\f09c\";\n@moon-waxing-gibbous-1: \"\\f09d\";\n@moon-waxing-gibbous-2: \"\\f09e\";\n@moon-waxing-gibbous-3: \"\\f09f\";\n@moon-waxing-gibbous-4: \"\\f0a0\";\n@moon-waxing-gibbous-5: \"\\f0a1\";\n@moon-waxing-gibbous-6: \"\\f0a2\";\n@moon-full: \"\\f0a3\";\n@moon-waning-gibbous-1: \"\\f0a4\";\n@moon-waning-gibbous-2: \"\\f0a5\";\n@moon-waning-gibbous-3: \"\\f0a6\";\n@moon-waning-gibbous-4: \"\\f0a7\";\n@moon-waning-gibbous-5: \"\\f0a8\";\n@moon-waning-gibbous-6: \"\\f0a9\";\n@moon-third-quarter: \"\\f0aa\";\n@moon-waning-crescent-1: \"\\f0ab\";\n@moon-waning-crescent-2: \"\\f0ac\";\n@moon-waning-crescent-3: \"\\f0ad\";\n@moon-waning-crescent-4: \"\\f0ae\";\n@moon-waning-crescent-5: \"\\f0af\";\n@moon-waning-crescent-6: \"\\f0b0\";\n@moon-alt-new: \"\\f0eb\";\n@moon-alt-waxing-cresent-1: \"\\f0d0\";\n@moon-alt-waxing-cresent-2: \"\\f0d1\";\n@moon-alt-waxing-cresent-3: \"\\f0d2\";\n@moon-alt-waxing-cresent-4: \"\\f0d3\";\n@moon-alt-waxing-cresent-5: \"\\f0d4\";\n@moon-alt-waxing-cresent-6: \"\\f0d5\";\n@moon-alt-first-quarter: \"\\f0d6\";\n@moon-alt-waxing-gibbous-1: \"\\f0d7\";\n@moon-alt-waxing-gibbous-2: \"\\f0d8\";\n@moon-alt-waxing-gibbous-3: \"\\f0d9\";\n@moon-alt-waxing-gibbous-4: \"\\f0da\";\n@moon-alt-waxing-gibbous-5: \"\\f0db\";\n@moon-alt-waxing-gibbous-6: \"\\f0dc\";\n@moon-alt-full: \"\\f0dd\";\n@moon-alt-waning-gibbous-1: \"\\f0de\";\n@moon-alt-waning-gibbous-2: \"\\f0df\";\n@moon-alt-waning-gibbous-3: \"\\f0e0\";\n@moon-alt-waning-gibbous-4: \"\\f0e1\";\n@moon-alt-waning-gibbous-5: \"\\f0e2\";\n@moon-alt-waning-gibbous-6: \"\\f0e3\";\n@moon-alt-third-quarter: \"\\f0e4\";\n@moon-alt-waning-crescent-1: \"\\f0e5\";\n@moon-alt-waning-crescent-2: \"\\f0e6\";\n@moon-alt-waning-crescent-3: \"\\f0e7\";\n@moon-alt-waning-crescent-4: \"\\f0e8\";\n@moon-alt-waning-crescent-5: \"\\f0e9\";\n@moon-alt-waning-crescent-6: \"\\f0ea\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-neutral.less",
    "content": "@cloud: \"\\f041\";\n@cloudy: \"\\f013\";\n@cloudy-gusts: \"\\f011\";\n@cloudy-windy: \"\\f012\";\n@fog: \"\\f014\";\n@hail: \"\\f015\";\n@rain: \"\\f019\";\n@rain-mix: \"\\f017\";\n@rain-wind: \"\\f018\";\n@showers: \"\\f01a\";\n@sleet: \"\\f0b5\";\n@snow: \"\\f01b\";\n@sprinkle: \"\\f01c\";\n@storm-showers: \"\\f01d\";\n@thunderstorm: \"\\f01e\";\n@snow-wind: \"\\f064\";\n@snow: \"\\f01b\";\n@smog: \"\\f074\";\n@smoke: \"\\f062\";\n@lightning: \"\\f016\";\n@raindrops: \"\\f04e\";\n@raindrop: \"\\f078\";\n@dust: \"\\f063\";\n@snowflake-cold: \"\\f076\";\n@windy: \"\\f021\";\n@strong-wind: \"\\f050\";\n@sandstorm: \"\\f082\";\n@earthquake: \"\\f0c6\";\n@fire: \"\\f0c7\";\n@flood: \"\\f07c\";\n@meteor: \"\\f071\";\n@tsunami: \"\\f0c5\";\n@volcano: \"\\f0c8\";\n@hurricane: \"\\f073\";\n@tornado: \"\\f056\";\n@small-craft-advisory: \"\\f0cc\";\n@gale-warning: \"\\f0cd\";\n@storm-warning: \"\\f0ce\";\n@hurricane-warning: \"\\f0cf\";\n@wind-direction: \"\\f0b1\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-night.less",
    "content": "@night-clear: \"\\f02e\";\n@night-alt-cloudy: \"\\f086\";\n@night-alt-cloudy-gusts: \"\\f022\";\n@night-alt-cloudy-windy: \"\\f023\";\n@night-alt-hail: \"\\f024\";\n@night-alt-lightning: \"\\f025\";\n@night-alt-rain: \"\\f028\";\n@night-alt-rain-mix: \"\\f026\";\n@night-alt-rain-wind: \"\\f027\";\n@night-alt-showers: \"\\f029\";\n@night-alt-sleet: \"\\f0b4\";\n@night-alt-sleet-storm: \"\\f06a\";\n@night-alt-snow: \"\\f02a\";\n@night-alt-snow-thunderstorm: \"\\f06d\";\n@night-alt-snow-wind: \"\\f067\";\n@night-alt-sprinkle: \"\\f02b\";\n@night-alt-storm-showers: \"\\f02c\";\n@night-alt-thunderstorm: \"\\f02d\";\n@night-cloudy: \"\\f031\";\n@night-cloudy-gusts: \"\\f02f\";\n@night-cloudy-windy: \"\\f030\";\n@night-fog: \"\\f04a\";\n@night-hail: \"\\f032\";\n@night-lightning: \"\\f033\";\n@night-partly-cloudy: \"\\f083\";\n@night-rain: \"\\f036\";\n@night-rain-mix: \"\\f034\";\n@night-rain-wind: \"\\f035\";\n@night-showers: \"\\f037\";\n@night-sleet: \"\\f0b3\";\n@night-sleet-storm: \"\\f069\";\n@night-snow: \"\\f038\";\n@night-snow-thunderstorm: \"\\f06c\";\n@night-snow-wind: \"\\f066\";\n@night-sprinkle: \"\\f039\";\n@night-storm-showers: \"\\f03a\";\n@night-thunderstorm: \"\\f03b\";\n@lunar-eclipse: \"\\f070\";\n@stars: \"\\f077\";\n@storm-showers: \"\\f01d\";\n@thunderstorm: \"\\f01e\";\n@night-alt-cloudy-high: \"\\f07e\";\n@night-cloudy-high: \"\\f080\";\n@night-alt-partly-cloudy: \"\\f081\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-time.less",
    "content": "@time-1: \"\\f08a\";\n@time-2: \"\\f08b\";\n@time-3: \"\\f08c\";\n@time-4: \"\\f08d\";\n@time-5: \"\\f08e\";\n@time-6: \"\\f08f\";\n@time-7: \"\\f090\";\n@time-8: \"\\f091\";\n@time-9: \"\\f092\";\n@time-10: \"\\f093\";\n@time-11: \"\\f094\";\n@time-12: \"\\f089\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/icon-variables/variables-wind-names.less",
    "content": "@n: \"\\f0b1\";\n@nne: \"\\f0b1\";\n@ne: \"\\f0b1\";\n@ene: \"\\f0b1\";\n@e: \"\\f0b1\";\n@ese: \"\\f0b1\";\n@se: \"\\f0b1\";\n@sse: \"\\f0b1\";\n@s: \"\\f0b1\";\n@ssw: \"\\f0b1\";\n@sw: \"\\f0b1\";\n@wsw: \"\\f0b1\";\n@w: \"\\f0b1\";\n@wnw: \"\\f0b1\";\n@nw: \"\\f0b1\";\n@nnw: \"\\f0b1\";\n@n: \"\\f0b1\";\n@nne: \"\\f0b1\";\n@ne: \"\\f0b1\";\n@ene: \"\\f0b1\";\n@e: \"\\f0b1\";\n@ese: \"\\f0b1\";\n@se: \"\\f0b1\";\n@sse: \"\\f0b1\";\n@s: \"\\f0b1\";\n@ssw: \"\\f0b1\";\n@sw: \"\\f0b1\";\n@wsw: \"\\f0b1\";\n@w: \"\\f0b1\";\n@wnw: \"\\f0b1\";\n@nw: \"\\f0b1\";\n@nnw: \"\\f0b1\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/mappings/wi-forecast-io.less",
    "content": ".@{wi-css-prefix}-forecast-io-clear-day:before            { content: @day-sunny     ; }\n.@{wi-css-prefix}-forecast-io-clear-night:before          { content: @night-clear   ; }\n.@{wi-css-prefix}-forecast-io-rain:before                 { content: @rain          ; }\n.@{wi-css-prefix}-forecast-io-snow:before                 { content: @snow          ; }\n.@{wi-css-prefix}-forecast-io-sleet:before                { content: @sleet         ; }\n.@{wi-css-prefix}-forecast-io-wind:before                 { content: @strong-wind   ; }\n.@{wi-css-prefix}-forecast-io-fog:before                  { content: @fog           ; }\n.@{wi-css-prefix}-forecast-io-cloudy:before               { content: @cloudy        ; }\n.@{wi-css-prefix}-forecast-io-partly-cloudy-day:before    { content: @day-cloudy    ; }\n.@{wi-css-prefix}-forecast-io-partly-cloudy-night:before  { content: @night-cloudy  ; }\n.@{wi-css-prefix}-forecast-io-hail:before                 { content: @hail          ; }\n.@{wi-css-prefix}-forecast-io-thunderstorm:before         { content: @thunderstorm  ; }\n.@{wi-css-prefix}-forecast-io-tornado:before              { content: @tornado       ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/mappings/wi-owm.less",
    "content": "// Neutral\n    .@{wi-css-prefix}-owm-200:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-201:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-202:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-210:before                            { content: @lightning                   ; }\n    .@{wi-css-prefix}-owm-211:before                            { content: @lightning                   ; }\n    .@{wi-css-prefix}-owm-212:before                            { content: @lightning                   ; }\n    .@{wi-css-prefix}-owm-221:before                            { content: @lightning                   ; }\n    .@{wi-css-prefix}-owm-230:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-231:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-232:before                            { content: @thunderstorm                ; }\n    .@{wi-css-prefix}-owm-300:before                            { content: @sprinkle                    ; }\n    .@{wi-css-prefix}-owm-301:before                            { content: @sprinkle                    ; }\n    .@{wi-css-prefix}-owm-302:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-310:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-311:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-312:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-313:before                            { content: @showers                     ; }\n    .@{wi-css-prefix}-owm-314:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-321:before                            { content: @sprinkle                    ; }\n    .@{wi-css-prefix}-owm-500:before                            { content: @sprinkle                    ; }\n    .@{wi-css-prefix}-owm-501:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-502:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-503:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-504:before                            { content: @rain                        ; }\n    .@{wi-css-prefix}-owm-511:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-520:before                            { content: @showers                     ; }\n    .@{wi-css-prefix}-owm-521:before                            { content: @showers                     ; }\n    .@{wi-css-prefix}-owm-522:before                            { content: @showers                     ; }\n    .@{wi-css-prefix}-owm-531:before                            { content: @storm-showers               ; }\n    .@{wi-css-prefix}-owm-600:before                            { content: @snow                        ; }\n    .@{wi-css-prefix}-owm-601:before                            { content: @snow                        ; }\n    .@{wi-css-prefix}-owm-602:before                            { content: @sleet                       ; }\n    .@{wi-css-prefix}-owm-611:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-612:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-615:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-616:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-620:before                            { content: @rain-mix                    ; }\n    .@{wi-css-prefix}-owm-621:before                            { content: @snow                        ; }\n    .@{wi-css-prefix}-owm-622:before                            { content: @snow                        ; }\n    .@{wi-css-prefix}-owm-701:before                            { content: @showers                     ; }\n    .@{wi-css-prefix}-owm-711:before                            { content: @smoke                       ; }\n    .@{wi-css-prefix}-owm-721:before                            { content: @day-haze                    ; }\n    .@{wi-css-prefix}-owm-731:before                            { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-741:before                            { content: @fog                         ; }\n    .@{wi-css-prefix}-owm-761:before                            { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-762:before                            { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-771:before                            { content: @cloudy-gusts                ; }\n    .@{wi-css-prefix}-owm-781:before                            { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-800:before                            { content: @day-sunny                   ; }\n    .@{wi-css-prefix}-owm-801:before                            { content: @cloudy-gusts                ; }\n    .@{wi-css-prefix}-owm-802:before                            { content: @cloudy-gusts                ; }\n    .@{wi-css-prefix}-owm-803:before                            { content: @cloudy-gusts                ; }\n    .@{wi-css-prefix}-owm-803:before                            { content: @cloudy-windy                ; }\n    .@{wi-css-prefix}-owm-804:before                            { content: @cloudy                      ; }\n    .@{wi-css-prefix}-owm-900:before                            { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-901:before                            { content: @storm-showers               ; }\n    .@{wi-css-prefix}-owm-902:before                            { content: @hurricane                   ; }\n    .@{wi-css-prefix}-owm-903:before                            { content: @snowflake-cold              ; }\n    .@{wi-css-prefix}-owm-904:before                            { content: @hot                         ; }\n    .@{wi-css-prefix}-owm-905:before                            { content: @windy                       ; }\n    .@{wi-css-prefix}-owm-906:before                            { content: @hail                        ; }\n    .@{wi-css-prefix}-owm-957:before                            { content: @strong-wind                 ; }\n    //Day\n    .@{wi-css-prefix}-owm-day-200:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-201:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-202:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-210:before                        { content: @day-lightning               ; }\n    .@{wi-css-prefix}-owm-day-211:before                        { content: @day-lightning               ; }\n    .@{wi-css-prefix}-owm-day-212:before                        { content: @day-lightning               ; }\n    .@{wi-css-prefix}-owm-day-221:before                        { content: @day-lightning               ; }\n    .@{wi-css-prefix}-owm-day-230:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-231:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-232:before                        { content: @day-thunderstorm            ; }\n    .@{wi-css-prefix}-owm-day-300:before                        { content: @day-sprinkle                ; }\n    .@{wi-css-prefix}-owm-day-301:before                        { content: @day-sprinkle                ; }\n    .@{wi-css-prefix}-owm-day-302:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-310:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-311:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-312:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-313:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-314:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-321:before                        { content: @day-sprinkle                ; }\n    .@{wi-css-prefix}-owm-day-500:before                        { content: @day-sprinkle                ; }\n    .@{wi-css-prefix}-owm-day-501:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-502:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-503:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-504:before                        { content: @day-rain                    ; }\n    .@{wi-css-prefix}-owm-day-511:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-520:before                        { content: @day-showers                 ; }\n    .@{wi-css-prefix}-owm-day-521:before                        { content: @day-showers                 ; }\n    .@{wi-css-prefix}-owm-day-522:before                        { content: @day-showers                 ; }\n    .@{wi-css-prefix}-owm-day-531:before                        { content: @day-storm-showers           ; }\n    .@{wi-css-prefix}-owm-day-600:before                        { content: @day-snow                    ; }\n    .@{wi-css-prefix}-owm-day-601:before                        { content: @day-sleet                   ; }\n    .@{wi-css-prefix}-owm-day-602:before                        { content: @day-snow                    ; }\n    .@{wi-css-prefix}-owm-day-611:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-612:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-615:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-616:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-620:before                        { content: @day-rain-mix                ; }\n    .@{wi-css-prefix}-owm-day-621:before                        { content: @day-snow                    ; }\n    .@{wi-css-prefix}-owm-day-622:before                        { content: @day-snow                    ; }\n    .@{wi-css-prefix}-owm-day-701:before                        { content: @day-showers                 ; }\n    .@{wi-css-prefix}-owm-day-711:before                        { content: @smoke                       ; }\n    .@{wi-css-prefix}-owm-day-721:before                        { content: @day-haze                    ; }\n    .@{wi-css-prefix}-owm-day-731:before                        { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-day-741:before                        { content: @day-fog                     ; }\n    .@{wi-css-prefix}-owm-day-761:before                        { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-day-762:before                        { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-day-781:before                        { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-day-800:before                        { content: @day-sunny                   ; }\n    .@{wi-css-prefix}-owm-day-801:before                        { content: @day-cloudy-gusts            ; }\n    .@{wi-css-prefix}-owm-day-802:before                        { content: @day-cloudy-gusts            ; }\n    .@{wi-css-prefix}-owm-day-803:before                        { content: @day-cloudy-gusts            ; }\n    .@{wi-css-prefix}-owm-day-804:before                        { content: @day-sunny-overcast          ; }\n    .@{wi-css-prefix}-owm-day-900:before                        { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-day-902:before                        { content: @hurricane                   ; }\n    .@{wi-css-prefix}-owm-day-903:before                        { content: @snowflake-cold              ; }\n    .@{wi-css-prefix}-owm-day-904:before                        { content: @hot                         ; }\n    .@{wi-css-prefix}-owm-day-906:before                        { content: @day-hail                    ; }\n    .@{wi-css-prefix}-owm-day-957:before                        { content: @strong-wind                 ; }\n    //Night\n    .@{wi-css-prefix}-owm-night-200:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-201:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-202:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-210:before                      { content: @night-alt-lightning         ; }\n    .@{wi-css-prefix}-owm-night-211:before                      { content: @night-alt-lightning         ; }\n    .@{wi-css-prefix}-owm-night-212:before                      { content: @night-alt-lightning         ; }\n    .@{wi-css-prefix}-owm-night-221:before                      { content: @night-alt-lightning         ; }\n    .@{wi-css-prefix}-owm-night-230:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-231:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-232:before                      { content: @night-alt-thunderstorm      ; }\n    .@{wi-css-prefix}-owm-night-300:before                      { content: @night-alt-sprinkle          ; }\n    .@{wi-css-prefix}-owm-night-301:before                      { content: @night-alt-sprinkle          ; }\n    .@{wi-css-prefix}-owm-night-302:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-310:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-311:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-312:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-313:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-314:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-321:before                      { content: @night-alt-sprinkle          ; }\n    .@{wi-css-prefix}-owm-night-500:before                      { content: @night-alt-sprinkle          ; }\n    .@{wi-css-prefix}-owm-night-501:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-502:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-503:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-504:before                      { content: @night-alt-rain              ; }\n    .@{wi-css-prefix}-owm-night-511:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-520:before                      { content: @night-alt-showers           ; }\n    .@{wi-css-prefix}-owm-night-521:before                      { content: @night-alt-showers           ; }\n    .@{wi-css-prefix}-owm-night-522:before                      { content: @night-alt-showers           ; }\n    .@{wi-css-prefix}-owm-night-531:before                      { content: @night-alt-storm-showers     ; }\n    .@{wi-css-prefix}-owm-night-600:before                      { content: @night-alt-snow              ; }\n    .@{wi-css-prefix}-owm-night-601:before                      { content: @night-alt-sleet             ; }\n    .@{wi-css-prefix}-owm-night-602:before                      { content: @night-alt-snow              ; }\n    .@{wi-css-prefix}-owm-night-611:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-612:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-615:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-616:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-620:before                      { content: @night-alt-rain-mix          ; }\n    .@{wi-css-prefix}-owm-night-621:before                      { content: @night-alt-snow              ; }\n    .@{wi-css-prefix}-owm-night-622:before                      { content: @night-alt-snow              ; }\n    .@{wi-css-prefix}-owm-night-701:before                      { content: @night-alt-showers           ; }\n    .@{wi-css-prefix}-owm-night-711:before                      { content: @smoke                       ; }\n    .@{wi-css-prefix}-owm-night-721:before                      { content: @day-haze                    ; }\n    .@{wi-css-prefix}-owm-night-731:before                      { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-night-741:before                      { content: @night-fog                   ; }\n    .@{wi-css-prefix}-owm-night-761:before                      { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-night-762:before                      { content: @dust                        ; }\n    .@{wi-css-prefix}-owm-night-781:before                      { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-night-800:before                      { content: @night-clear                 ; }\n    .@{wi-css-prefix}-owm-night-801:before                      { content: @night-alt-cloudy-gusts      ; }\n    .@{wi-css-prefix}-owm-night-802:before                      { content: @night-alt-cloudy-gusts      ; }\n    .@{wi-css-prefix}-owm-night-803:before                      { content: @night-alt-cloudy-gusts      ; }\n    .@{wi-css-prefix}-owm-night-804:before                      { content: @night-alt-cloudy            ; }\n    .@{wi-css-prefix}-owm-night-900:before                      { content: @tornado                     ; }\n    .@{wi-css-prefix}-owm-night-902:before                      { content: @hurricane                   ; }\n    .@{wi-css-prefix}-owm-night-903:before                      { content: @snowflake-cold              ; }\n    .@{wi-css-prefix}-owm-night-904:before                      { content: @hot                         ; }\n    .@{wi-css-prefix}-owm-night-906:before                      { content: @night-alt-hail              ; }\n    .@{wi-css-prefix}-owm-night-957:before                      { content: @strong-wind                 ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/mappings/wi-wmo4680.less",
    "content": ".@{wi-css-prefix}-wmo4680-0:before,\n.@{wi-css-prefix}-wmo4680-00:before       { content: @thermometer           ; }\n.@{wi-css-prefix}-wmo4680-1:before,\n.@{wi-css-prefix}-wmo4680-01:before       { content: @cloudy                ; }\n.@{wi-css-prefix}-wmo4680-2:before,\n.@{wi-css-prefix}-wmo4680-02:before       { content: @thermometer           ; }\n.@{wi-css-prefix}-wmo4680-3:before,\n.@{wi-css-prefix}-wmo4680-03:before       { content: @cloudy                ; }\n.@{wi-css-prefix}-wmo4680-4:before,\n.@{wi-css-prefix}-wmo4680-04:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-5:before,\n.@{wi-css-prefix}-wmo4680-05:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-10:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-11:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-12:before       { content: @lightning             ; }\n.@{wi-css-prefix}-wmo4680-18:before       { content: @strong-wind           ; }\n.@{wi-css-prefix}-wmo4680-20:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-21:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-22:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-23:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-24:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-25:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-26:before       { content: @thunderstorm          ; }\n.@{wi-css-prefix}-wmo4680-27:before       { content: @dust                  ; }\n.@{wi-css-prefix}-wmo4680-28:before       { content: @dust                  ; }\n.@{wi-css-prefix}-wmo4680-29:before       { content: @dust                  ; }\n.@{wi-css-prefix}-wmo4680-30:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-31:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-32:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-33:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-34:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-35:before       { content: @fog                   ; }\n.@{wi-css-prefix}-wmo4680-40:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-41:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-42:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-43:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-44:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-45:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-46:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-47:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-48:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-50:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-51:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-52:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-53:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-54:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-55:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-56:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-57:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-58:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-60:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-61:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-62:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-63:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-64:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-65:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-66:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-67:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-68:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-70:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-71:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-72:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-73:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-74:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-75:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-76:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-77:before       { content: @snow                  ; }\n.@{wi-css-prefix}-wmo4680-78:before       { content: @snowflake-cold        ; }\n.@{wi-css-prefix}-wmo4680-80:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-81:before       { content: @sprinkle              ; }\n.@{wi-css-prefix}-wmo4680-82:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-83:before       { content: @rain                  ; }\n.@{wi-css-prefix}-wmo4680-84:before       { content: @storm-showers         ; }\n.@{wi-css-prefix}-wmo4680-85:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-86:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-87:before       { content: @rain-mix              ; }\n.@{wi-css-prefix}-wmo4680-89:before       { content: @hail                  ; }\n.@{wi-css-prefix}-wmo4680-90:before       { content: @lightning             ; }\n.@{wi-css-prefix}-wmo4680-91:before       { content: @storm-showers         ; }\n.@{wi-css-prefix}-wmo4680-92:before       { content: @thunderstorm          ; }\n.@{wi-css-prefix}-wmo4680-93:before       { content: @thunderstorm          ; }\n.@{wi-css-prefix}-wmo4680-94:before       { content: @lightning             ; }\n.@{wi-css-prefix}-wmo4680-95:before       { content: @thunderstorm          ; }\n.@{wi-css-prefix}-wmo4680-96:before       { content: @thunderstorm          ; }\n.@{wi-css-prefix}-wmo4680-99:before       { content: @tornado               ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/mappings/wi-yahoo.less",
    "content": ".@{wi-css-prefix}-yahoo-0:before { content: @tornado; };\n.@{wi-css-prefix}-yahoo-1:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-2:before { content: @hurricane; };\n.@{wi-css-prefix}-yahoo-3:before { content: @thunderstorm; };\n.@{wi-css-prefix}-yahoo-4:before { content: @thunderstorm; };\n.@{wi-css-prefix}-yahoo-5:before { content: @rain-mix; };\n.@{wi-css-prefix}-yahoo-6:before { content: @rain-mix; };\n.@{wi-css-prefix}-yahoo-7:before { content: @rain-mix; };\n.@{wi-css-prefix}-yahoo-8:before { content: @hail; };\n.@{wi-css-prefix}-yahoo-9:before { content: @showers; };\n.@{wi-css-prefix}-yahoo-10:before { content: @hail; };\n.@{wi-css-prefix}-yahoo-11:before { content: @showers; };\n.@{wi-css-prefix}-yahoo-12:before { content: @showers; };\n.@{wi-css-prefix}-yahoo-13:before { content: @snow; };\n.@{wi-css-prefix}-yahoo-14:before { content: @day-snow; };\n.@{wi-css-prefix}-yahoo-15:before { content: @snow-wind; };\n.@{wi-css-prefix}-yahoo-16:before { content: @snow; };\n.@{wi-css-prefix}-yahoo-17:before { content: @hail; };\n.@{wi-css-prefix}-yahoo-18:before { content: @rain-mix; };\n.@{wi-css-prefix}-yahoo-19:before { content: @dust; };\n.@{wi-css-prefix}-yahoo-20:before { content: @fog; };\n.@{wi-css-prefix}-yahoo-21:before { content: @windy; };\n.@{wi-css-prefix}-yahoo-22:before { content: @smoke; };\n.@{wi-css-prefix}-yahoo-23:before { content: @strong-wind; };\n.@{wi-css-prefix}-yahoo-24:before { content: @strong-wind; };\n.@{wi-css-prefix}-yahoo-25:before { content: @snowflake-cold; };\n.@{wi-css-prefix}-yahoo-26:before { content: @cloudy; };\n.@{wi-css-prefix}-yahoo-27:before { content: @night-cloudy; };\n.@{wi-css-prefix}-yahoo-28:before { content: @day-cloudy; };\n.@{wi-css-prefix}-yahoo-29:before { content: @night-cloudy; };\n.@{wi-css-prefix}-yahoo-30:before { content: @day-cloudy; };\n.@{wi-css-prefix}-yahoo-31:before { content: @night-clear; };\n.@{wi-css-prefix}-yahoo-32:before { content: @day-sunny; };\n.@{wi-css-prefix}-yahoo-33:before { content: @night-partly-cloudy; };\n.@{wi-css-prefix}-yahoo-34:before { content: @day-sunny-overcast; };\n.@{wi-css-prefix}-yahoo-35:before { content: @rain-mix; };\n.@{wi-css-prefix}-yahoo-36:before { content: @hot; };\n.@{wi-css-prefix}-yahoo-37:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-38:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-39:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-40:before { content: @showers; };\n.@{wi-css-prefix}-yahoo-41:before { content: @snow-wind; };\n.@{wi-css-prefix}-yahoo-42:before { content: @snow; };\n.@{wi-css-prefix}-yahoo-43:before { content: @snow-wind; };\n.@{wi-css-prefix}-yahoo-44:before { content: @day-sunny-overcast; };\n.@{wi-css-prefix}-yahoo-45:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-46:before { content: @snow; };\n.@{wi-css-prefix}-yahoo-47:before { content: @day-storm-showers; };\n.@{wi-css-prefix}-yahoo-3200:before { content: @stars; };"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons-classes.less",
    "content": "@import \"icon-classes/classes-day.less\";\n@import \"icon-classes/classes-night.less\";\n@import \"icon-classes/classes-neutral.less\";\n@import \"icon-classes/classes-misc.less\";\n@import \"icon-classes/classes-moon.less\";\n@import \"icon-classes/classes-moon-aliases.less\";\n@import \"icon-classes/classes-time.less\";\n@import \"icon-classes/classes-direction.less\";\n@import \"icon-classes/classes-beaufort.less\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons-core.less",
    "content": "// Base Variables\n@wi-path:                        \"../fonts\";\n@wi-version:                     \"2.0\";\n@wi-css-prefix:                  wi;\n@wi-font-family:                 weathericons;\n\n@font-face {\n    font-family: '@{wi-font-family}';\n    src: url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.eot');\n    src: url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.eot?#iefix') format('embedded-opentype'),\n         url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.woff2') format('woff2'),\n         url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.woff') format('woff'),\n         url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.ttf') format('truetype'),\n         url('../less/icons/weather-icons/font/@{wi-font-family}-regular-webfont.svg#weather_iconsregular') format('svg');\n    font-weight: normal;\n    font-style: normal;\n}\n\n.@{wi-css-prefix} {\n  display: inline-block;\n  font-family: '@{wi-font-family}';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.@{wi-css-prefix}-fw {\n  text-align: center;\n  width: 1.4em;\n}\n\n.wi-icon-rotate(@degrees, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation);\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n\n.wi-icon-flip(@horiz, @vert, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation, mirror=1);\n  -webkit-transform: scale(@horiz, @vert);\n      -ms-transform: scale(@horiz, @vert);\n          transform: scale(@horiz, @vert);\n}\n\n.@{wi-css-prefix}-rotate-90  { .wi-icon-rotate(90deg, 1);  }\n.@{wi-css-prefix}-rotate-180 { .wi-icon-rotate(180deg, 2); }\n.@{wi-css-prefix}-rotate-270 { .wi-icon-rotate(270deg, 3); }\n\n.@{wi-css-prefix}-flip-horizontal { .wi-icon-flip(-1, 1, 0); }\n.@{wi-css-prefix}-flip-vertical   { .wi-icon-flip(1, -1, 2); }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons-variables.less",
    "content": "@import \"icon-variables/variables-beaufort.less\";\n@import \"icon-variables/variables-time.less\";\n@import \"icon-variables/variables-moon.less\";\n@import \"icon-variables/variables-direction.less\";\n@import \"icon-variables/variables-day.less\";\n@import \"icon-variables/variables-night.less\";\n@import \"icon-variables/variables-neutral.less\";\n@import \"icon-variables/variables-misc.less\";\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons-wind.less",
    "content": "@import \"weather-icons-core.less\";\n@import \"icon-variables/variables-wind-names.less\";\n@import \"icon-classes/classes-wind.less\";\n@import \"icon-classes/classes-wind-degrees.less\";\n@import \"icon-classes/classes-wind-aliases.less\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons-wind.min.less",
    "content": "@import \"weather-icons-core.less\";\n@import \"icon-variables/variables-wind-names.less\";\n@import \"icon-classes/classes-wind.less\";\n@import \"icon-classes/classes-wind-degrees.less\";\n@import \"icon-classes/classes-wind-aliases.less\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons.less",
    "content": "/*!\n *  Weather Icons 2.0\n *  Updated August 1, 2015\n *  Weather themed icons for Bootstrap\n *  Author - Erik Flowers - erik@helloerik.com\n *  Email: erik@helloerik.com\n *  Twitter: http://twitter.com/Erik_UX\n *  ------------------------------------------------------------------------------\n *  Maintained at http://erikflowers.github.io/weather-icons\n *\n *  License\n *  ------------------------------------------------------------------------------\n *  - Font licensed under SIL OFL 1.1 -\n *    http://scripts.sil.org/OFL\n *  - CSS, SCSS and LESS are licensed under MIT License -\n *    http://opensource.org/licenses/mit-license.html\n *  - Documentation licensed under CC BY 3.0 -\n *    http://creativecommons.org/licenses/by/3.0/\n *  - Inspired by and works great as a companion with Font Awesome\n *    \"Font Awesome by Dave Gandy - http://fontawesome.io\"\n */\n\n@import \"weather-icons-core.less\";\n@import \"weather-icons-variables.less\";\n@import \"weather-icons-classes.less\";\n// Mappings to various APIs\n@import \"mappings/wi-yahoo.less\";\n@import \"mappings/wi-forecast-io.less\";\n@import \"mappings/wi-wmo4680.less\";\n@import \"mappings/wi-owm.less\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/less/weather-icons.min.less",
    "content": "/*!\n *  Weather Icons 2.0\n *  Updated August 1, 2015\n *  Weather themed icons for Bootstrap\n *  Author - Erik Flowers - erik@helloerik.com\n *  Email: erik@helloerik.com\n *  Twitter: http://twitter.com/Erik_UX\n *  ------------------------------------------------------------------------------\n *  Maintained at http://erikflowers.github.io/weather-icons\n *\n *  License\n *  ------------------------------------------------------------------------------\n *  - Font licensed under SIL OFL 1.1 -\n *    http://scripts.sil.org/OFL\n *  - CSS, SCSS and LESS are licensed under MIT License -\n *    http://opensource.org/licenses/mit-license.html\n *  - Documentation licensed under CC BY 3.0 -\n *    http://creativecommons.org/licenses/by/3.0/\n *  - Inspired by and works great as a companion with Font Awesome\n *    \"Font Awesome by Dave Gandy - http://fontawesome.io\"\n */\n\n@import \"weather-icons-core.less\";\n@import \"weather-icons-variables.less\";\n@import \"weather-icons-classes.less\";\n// Mappings to various APIs\n@import \"mappings/wi-yahoo.less\";\n@import \"mappings/wi-forecast-io.less\";\n@import \"mappings/wi-wmo4680.less\";\n@import \"mappings/wi-owm.less\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-beaufort.scss",
    "content": ".wi-wind-beaufort-0:before {content: $wind-beaufort-0;}\n.wi-wind-beaufort-1:before {content: $wind-beaufort-1;}\n.wi-wind-beaufort-2:before {content: $wind-beaufort-2;}\n.wi-wind-beaufort-3:before {content: $wind-beaufort-3;}\n.wi-wind-beaufort-4:before {content: $wind-beaufort-4;}\n.wi-wind-beaufort-5:before {content: $wind-beaufort-5;}\n.wi-wind-beaufort-6:before {content: $wind-beaufort-6;}\n.wi-wind-beaufort-7:before {content: $wind-beaufort-7;}\n.wi-wind-beaufort-8:before {content: $wind-beaufort-8;}\n.wi-wind-beaufort-9:before {content: $wind-beaufort-9;}\n.wi-wind-beaufort-10:before {content: $wind-beaufort-10;}\n.wi-wind-beaufort-11:before {content: $wind-beaufort-11;}\n.wi-wind-beaufort-12:before {content: $wind-beaufort-12;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-day.scss",
    "content": ".wi-day-sunny:before {content: $day-sunny;}\n.wi-day-cloudy:before {content: $day-cloudy;}\n.wi-day-cloudy-gusts:before {content: $day-cloudy-gusts;}\n.wi-day-cloudy-windy:before {content: $day-cloudy-windy;}\n.wi-day-fog:before {content: $day-fog;}\n.wi-day-hail:before {content: $day-hail;}\n.wi-day-haze:before {content: $day-haze;}\n.wi-day-lightning:before {content: $day-lightning;}\n.wi-day-rain:before {content: $day-rain;}\n.wi-day-rain-mix:before {content: $day-rain-mix;}\n.wi-day-rain-wind:before {content: $day-rain-wind;}\n.wi-day-showers:before {content: $day-showers;}\n.wi-day-sleet:before {content: $day-sleet;}\n.wi-day-sleet-storm:before {content: $day-sleet-storm;}\n.wi-day-snow:before {content: $day-snow;}\n.wi-day-snow-thunderstorm:before {content: $day-snow-thunderstorm;}\n.wi-day-snow-wind:before {content: $day-snow-wind;}\n.wi-day-sprinkle:before {content: $day-sprinkle;}\n.wi-day-storm-showers:before {content: $day-storm-showers;}\n.wi-day-sunny-overcast:before {content: $day-sunny-overcast;}\n.wi-day-thunderstorm:before {content: $day-thunderstorm;}\n.wi-day-windy:before {content: $day-windy;}\n.wi-solar-eclipse:before {content: $solar-eclipse;}\n.wi-hot:before {content: $hot;}\n.wi-day-cloudy-high:before {content: $day-cloudy-high;}\n.wi-day-light-wind:before {content: $day-light-wind;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-direction.scss",
    "content": ".wi-direction-up:before {content: $direction-up;}\n.wi-direction-up-right:before {content: $direction-up-right;}\n.wi-direction-right:before {content: $direction-right;}\n.wi-direction-down-right:before {content: $direction-down-right;}\n.wi-direction-down:before {content: $direction-down;}\n.wi-direction-down-left:before {content: $direction-down-left;}\n.wi-direction-left:before {content: $direction-left;}\n.wi-direction-up-left:before {content: $direction-up-left;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-misc.scss",
    "content": ".wi-alien:before {content: $alien;}\n.wi-celsius:before {content: $celsius;}\n.wi-fahrenheit:before {content: $fahrenheit;}\n.wi-degrees:before {content: $degrees;}\n.wi-thermometer:before {content: $thermometer;}\n.wi-thermometer-exterior:before {content: $thermometer-exterior;}\n.wi-thermometer-internal:before {content: $thermometer-internal;}\n.wi-cloud-down:before {content: $cloud-down;}\n.wi-cloud-up:before {content: $cloud-up;}\n.wi-cloud-refresh:before {content: $cloud-refresh;}\n.wi-horizon:before {content: $horizon;}\n.wi-horizon-alt:before {content: $horizon-alt;}\n.wi-sunrise:before {content: $sunrise;}\n.wi-sunset:before {content: $sunset;}\n.wi-moonrise:before {content: $moonrise;}\n.wi-moonset:before {content: $moonset;}\n.wi-refresh:before {content: $refresh;}\n.wi-refresh-alt:before {content: $refresh-alt;}\n.wi-umbrella:before {content: $umbrella;}\n.wi-barometer:before {content: $barometer;}\n.wi-humidity:before {content: $humidity;}\n.wi-na:before {content: $na;}\n.wi-train:before {content: $train;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-moon-aliases.scss",
    "content": ".wi-moon-0:before {content: $moon-new;}\n.wi-moon-1:before {content: $moon-waxing-cresent-1;}\n.wi-moon-2:before {content: $moon-waxing-cresent-2;}\n.wi-moon-3:before {content: $moon-waxing-cresent-3;}\n.wi-moon-4:before {content: $moon-waxing-cresent-4;}\n.wi-moon-5:before {content: $moon-waxing-cresent-5;}\n.wi-moon-6:before {content: $moon-waxing-cresent-6;}\n.wi-moon-7:before {content: $moon-first-quarter;}\n.wi-moon-8:before {content: $moon-waxing-gibbous-1;}\n.wi-moon-9:before {content: $moon-waxing-gibbous-2;}\n.wi-moon-10:before {content: $moon-waxing-gibbous-3;}\n.wi-moon-11:before {content: $moon-waxing-gibbous-4;}\n.wi-moon-12:before {content: $moon-waxing-gibbous-5;}\n.wi-moon-13:before {content: $moon-waxing-gibbous-6;}\n.wi-moon-14:before {content: $moon-full;}\n.wi-moon-15:before {content: $moon-waning-gibbous-1;}\n.wi-moon-16:before {content: $moon-waning-gibbous-2;}\n.wi-moon-17:before {content: $moon-waning-gibbous-3;}\n.wi-moon-18:before {content: $moon-waning-gibbous-4;}\n.wi-moon-19:before {content: $moon-waning-gibbous-5;}\n.wi-moon-20:before {content: $moon-waning-gibbous-6;}\n.wi-moon-21:before {content: $moon-third-quarter;}\n.wi-moon-22:before {content: $moon-waning-crescent-1;}\n.wi-moon-23:before {content: $moon-waning-crescent-2;}\n.wi-moon-24:before {content: $moon-waning-crescent-3;}\n.wi-moon-25:before {content: $moon-waning-crescent-4;}\n.wi-moon-26:before {content: $moon-waning-crescent-5;}\n.wi-moon-27:before {content: $moon-waning-crescent-6;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-moon.scss",
    "content": ".wi-moon-new:before {content: $moon-new;}\n.wi-moon-waxing-cresent-1:before {content: $moon-waxing-cresent-1;}\n.wi-moon-waxing-cresent-2:before {content: $moon-waxing-cresent-2;}\n.wi-moon-waxing-cresent-3:before {content: $moon-waxing-cresent-3;}\n.wi-moon-waxing-cresent-4:before {content: $moon-waxing-cresent-4;}\n.wi-moon-waxing-cresent-5:before {content: $moon-waxing-cresent-5;}\n.wi-moon-waxing-cresent-6:before {content: $moon-waxing-cresent-6;}\n.wi-moon-first-quarter:before {content: $moon-first-quarter;}\n.wi-moon-waxing-gibbous-1:before {content: $moon-waxing-gibbous-1;}\n.wi-moon-waxing-gibbous-2:before {content: $moon-waxing-gibbous-2;}\n.wi-moon-waxing-gibbous-3:before {content: $moon-waxing-gibbous-3;}\n.wi-moon-waxing-gibbous-4:before {content: $moon-waxing-gibbous-4;}\n.wi-moon-waxing-gibbous-5:before {content: $moon-waxing-gibbous-5;}\n.wi-moon-waxing-gibbous-6:before {content: $moon-waxing-gibbous-6;}\n.wi-moon-full:before {content: $moon-full;}\n.wi-moon-waning-gibbous-1:before {content: $moon-waning-gibbous-1;}\n.wi-moon-waning-gibbous-2:before {content: $moon-waning-gibbous-2;}\n.wi-moon-waning-gibbous-3:before {content: $moon-waning-gibbous-3;}\n.wi-moon-waning-gibbous-4:before {content: $moon-waning-gibbous-4;}\n.wi-moon-waning-gibbous-5:before {content: $moon-waning-gibbous-5;}\n.wi-moon-waning-gibbous-6:before {content: $moon-waning-gibbous-6;}\n.wi-moon-third-quarter:before {content: $moon-third-quarter;}\n.wi-moon-waning-crescent-1:before {content: $moon-waning-crescent-1;}\n.wi-moon-waning-crescent-2:before {content: $moon-waning-crescent-2;}\n.wi-moon-waning-crescent-3:before {content: $moon-waning-crescent-3;}\n.wi-moon-waning-crescent-4:before {content: $moon-waning-crescent-4;}\n.wi-moon-waning-crescent-5:before {content: $moon-waning-crescent-5;}\n.wi-moon-waning-crescent-6:before {content: $moon-waning-crescent-6;}\n.wi-moon-alt-new:before {content: $moon-alt-new;}\n.wi-moon-alt-waxing-cresent-1:before {content: $moon-alt-waxing-cresent-1;}\n.wi-moon-alt-waxing-cresent-2:before {content: $moon-alt-waxing-cresent-2;}\n.wi-moon-alt-waxing-cresent-3:before {content: $moon-alt-waxing-cresent-3;}\n.wi-moon-alt-waxing-cresent-4:before {content: $moon-alt-waxing-cresent-4;}\n.wi-moon-alt-waxing-cresent-5:before {content: $moon-alt-waxing-cresent-5;}\n.wi-moon-alt-waxing-cresent-6:before {content: $moon-alt-waxing-cresent-6;}\n.wi-moon-alt-first-quarter:before {content: $moon-alt-first-quarter;}\n.wi-moon-alt-waxing-gibbous-1:before {content: $moon-alt-waxing-gibbous-1;}\n.wi-moon-alt-waxing-gibbous-2:before {content: $moon-alt-waxing-gibbous-2;}\n.wi-moon-alt-waxing-gibbous-3:before {content: $moon-alt-waxing-gibbous-3;}\n.wi-moon-alt-waxing-gibbous-4:before {content: $moon-alt-waxing-gibbous-4;}\n.wi-moon-alt-waxing-gibbous-5:before {content: $moon-alt-waxing-gibbous-5;}\n.wi-moon-alt-waxing-gibbous-6:before {content: $moon-alt-waxing-gibbous-6;}\n.wi-moon-alt-full:before {content: $moon-alt-full;}\n.wi-moon-alt-waning-gibbous-1:before {content: $moon-alt-waning-gibbous-1;}\n.wi-moon-alt-waning-gibbous-2:before {content: $moon-alt-waning-gibbous-2;}\n.wi-moon-alt-waning-gibbous-3:before {content: $moon-alt-waning-gibbous-3;}\n.wi-moon-alt-waning-gibbous-4:before {content: $moon-alt-waning-gibbous-4;}\n.wi-moon-alt-waning-gibbous-5:before {content: $moon-alt-waning-gibbous-5;}\n.wi-moon-alt-waning-gibbous-6:before {content: $moon-alt-waning-gibbous-6;}\n.wi-moon-alt-third-quarter:before {content: $moon-alt-third-quarter;}\n.wi-moon-alt-waning-crescent-1:before {content: $moon-alt-waning-crescent-1;}\n.wi-moon-alt-waning-crescent-2:before {content: $moon-alt-waning-crescent-2;}\n.wi-moon-alt-waning-crescent-3:before {content: $moon-alt-waning-crescent-3;}\n.wi-moon-alt-waning-crescent-4:before {content: $moon-alt-waning-crescent-4;}\n.wi-moon-alt-waning-crescent-5:before {content: $moon-alt-waning-crescent-5;}\n.wi-moon-alt-waning-crescent-6:before {content: $moon-alt-waning-crescent-6;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-neutral.scss",
    "content": ".wi-cloud:before {content: $cloud;}\n.wi-cloudy:before {content: $cloudy;}\n.wi-cloudy-gusts:before {content: $cloudy-gusts;}\n.wi-cloudy-windy:before {content: $cloudy-windy;}\n.wi-fog:before {content: $fog;}\n.wi-hail:before {content: $hail;}\n.wi-rain:before {content: $rain;}\n.wi-rain-mix:before {content: $rain-mix;}\n.wi-rain-wind:before {content: $rain-wind;}\n.wi-showers:before {content: $showers;}\n.wi-sleet:before {content: $sleet;}\n.wi-snow:before {content: $snow;}\n.wi-sprinkle:before {content: $sprinkle;}\n.wi-storm-showers:before {content: $storm-showers;}\n.wi-thunderstorm:before {content: $thunderstorm;}\n.wi-snow-wind:before {content: $snow-wind;}\n.wi-snow:before {content: $snow;}\n.wi-smog:before {content: $smog;}\n.wi-smoke:before {content: $smoke;}\n.wi-lightning:before {content: $lightning;}\n.wi-raindrops:before {content: $raindrops;}\n.wi-raindrop:before {content: $raindrop;}\n.wi-dust:before {content: $dust;}\n.wi-snowflake-cold:before {content: $snowflake-cold;}\n.wi-windy:before {content: $windy;}\n.wi-strong-wind:before {content: $strong-wind;}\n.wi-sandstorm:before {content: $sandstorm;}\n.wi-earthquake:before {content: $earthquake;}\n.wi-fire:before {content: $fire;}\n.wi-flood:before {content: $flood;}\n.wi-meteor:before {content: $meteor;}\n.wi-tsunami:before {content: $tsunami;}\n.wi-volcano:before {content: $volcano;}\n.wi-hurricane:before {content: $hurricane;}\n.wi-tornado:before {content: $tornado;}\n.wi-small-craft-advisory:before {content: $small-craft-advisory;}\n.wi-gale-warning:before {content: $gale-warning;}\n.wi-storm-warning:before {content: $storm-warning;}\n.wi-hurricane-warning:before {content: $hurricane-warning;}\n.wi-wind-direction:before {content: $wind-direction;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-night.scss",
    "content": ".wi-night-clear:before {content: $night-clear;}\n.wi-night-alt-cloudy:before {content: $night-alt-cloudy;}\n.wi-night-alt-cloudy-gusts:before {content: $night-alt-cloudy-gusts;}\n.wi-night-alt-cloudy-windy:before {content: $night-alt-cloudy-windy;}\n.wi-night-alt-hail:before {content: $night-alt-hail;}\n.wi-night-alt-lightning:before {content: $night-alt-lightning;}\n.wi-night-alt-rain:before {content: $night-alt-rain;}\n.wi-night-alt-rain-mix:before {content: $night-alt-rain-mix;}\n.wi-night-alt-rain-wind:before {content: $night-alt-rain-wind;}\n.wi-night-alt-showers:before {content: $night-alt-showers;}\n.wi-night-alt-sleet:before {content: $night-alt-sleet;}\n.wi-night-alt-sleet-storm:before {content: $night-alt-sleet-storm;}\n.wi-night-alt-snow:before {content: $night-alt-snow;}\n.wi-night-alt-snow-thunderstorm:before {content: $night-alt-snow-thunderstorm;}\n.wi-night-alt-snow-wind:before {content: $night-alt-snow-wind;}\n.wi-night-alt-sprinkle:before {content: $night-alt-sprinkle;}\n.wi-night-alt-storm-showers:before {content: $night-alt-storm-showers;}\n.wi-night-alt-thunderstorm:before {content: $night-alt-thunderstorm;}\n.wi-night-cloudy:before {content: $night-cloudy;}\n.wi-night-cloudy-gusts:before {content: $night-cloudy-gusts;}\n.wi-night-cloudy-windy:before {content: $night-cloudy-windy;}\n.wi-night-fog:before {content: $night-fog;}\n.wi-night-hail:before {content: $night-hail;}\n.wi-night-lightning:before {content: $night-lightning;}\n.wi-night-partly-cloudy:before {content: $night-partly-cloudy;}\n.wi-night-rain:before {content: $night-rain;}\n.wi-night-rain-mix:before {content: $night-rain-mix;}\n.wi-night-rain-wind:before {content: $night-rain-wind;}\n.wi-night-showers:before {content: $night-showers;}\n.wi-night-sleet:before {content: $night-sleet;}\n.wi-night-sleet-storm:before {content: $night-sleet-storm;}\n.wi-night-snow:before {content: $night-snow;}\n.wi-night-snow-thunderstorm:before {content: $night-snow-thunderstorm;}\n.wi-night-snow-wind:before {content: $night-snow-wind;}\n.wi-night-sprinkle:before {content: $night-sprinkle;}\n.wi-night-storm-showers:before {content: $night-storm-showers;}\n.wi-night-thunderstorm:before {content: $night-thunderstorm;}\n.wi-lunar-eclipse:before {content: $lunar-eclipse;}\n.wi-stars:before {content: $stars;}\n.wi-storm-showers:before {content: $storm-showers;}\n.wi-thunderstorm:before {content: $thunderstorm;}\n.wi-night-alt-cloudy-high:before {content: $night-alt-cloudy-high;}\n.wi-night-cloudy-high:before {content: $night-cloudy-high;}\n.wi-night-alt-partly-cloudy:before {content: $night-alt-partly-cloudy;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-time.scss",
    "content": ".wi-time-1:before {content: $time-1;}\n.wi-time-2:before {content: $time-2;}\n.wi-time-3:before {content: $time-3;}\n.wi-time-4:before {content: $time-4;}\n.wi-time-5:before {content: $time-5;}\n.wi-time-6:before {content: $time-6;}\n.wi-time-7:before {content: $time-7;}\n.wi-time-8:before {content: $time-8;}\n.wi-time-9:before {content: $time-9;}\n.wi-time-10:before {content: $time-10;}\n.wi-time-11:before {content: $time-11;}\n.wi-time-12:before {content: $time-12;}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-wind-aliases.scss",
    "content": "@mixin wind-rotate( $val: 0deg ) {\n  -webkit-transform: rotate($val);\n  -moz-transform: rotate($val);\n  -ms-transform: rotate($val);\n  -o-transform: rotate($val);\n  transform: rotate($val);\n}\n\n.wi-wind-towards-n    {\n  @include wind-rotate(0deg);\n}\n.wi-wind-towards-nne   {\n  @include wind-rotate(23deg);\n}\n.wi-wind-towards-ne    {\n  @include wind-rotate(45deg);\n}\n.wi-wind-towards-ene   {\n  @include wind-rotate(68deg);\n}\n.wi-wind-towards-e    {\n  @include wind-rotate(90deg);\n}\n.wi-wind-towards-ese   {\n  @include wind-rotate(113deg);\n}\n.wi-wind-towards-se    {\n  @include wind-rotate(135deg);\n}\n.wi-wind-towards-sse   {\n  @include wind-rotate(158deg);\n}\n.wi-wind-towards-s    {\n  @include wind-rotate(180deg);\n}\n.wi-wind-towards-ssw   {\n  @include wind-rotate(203deg);\n}\n.wi-wind-towards-sw    {\n  @include wind-rotate(225deg);\n}\n.wi-wind-towards-wsw   {\n  @include wind-rotate(248deg);\n}\n.wi-wind-towards-w    {\n  @include wind-rotate(270deg);\n}\n.wi-wind-towards-wnw   {\n  @include wind-rotate(293deg);\n}\n.wi-wind-towards-nw    {\n  @include wind-rotate(313deg);\n}\n.wi-wind-towards-nnw   {\n  @include wind-rotate(336deg);\n}\n.wi-wind-from-n    {\n  @include wind-rotate(0deg);\n}\n.wi-wind-from-nne   {\n  @include wind-rotate(23deg);\n}\n.wi-wind-from-ne    {\n  @include wind-rotate(45deg);\n}\n.wi-wind-from-ene   {\n  @include wind-rotate(68deg);\n}\n.wi-wind-from-e    {\n  @include wind-rotate(90deg);\n}\n.wi-wind-from-ese   {\n  @include wind-rotate(113deg);\n}\n.wi-wind-from-se    {\n  @include wind-rotate(135deg);\n}\n.wi-wind-from-sse   {\n  @include wind-rotate(158deg);\n}\n.wi-wind-from-s    {\n  @include wind-rotate(180deg);\n}\n.wi-wind-from-ssw   {\n  @include wind-rotate(203deg);\n}\n.wi-wind-from-sw    {\n  @include wind-rotate(225deg);\n}\n.wi-wind-from-wsw   {\n  @include wind-rotate(248deg);\n}\n.wi-wind-from-w    {\n  @include wind-rotate(270deg);\n}\n.wi-wind-from-wnw   {\n  @include wind-rotate(293deg);\n}\n.wi-wind-from-nw    {\n  @include wind-rotate(313deg);\n}\n.wi-wind-from-nnw   {\n  @include wind-rotate(336deg);\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-wind-degrees.scss",
    "content": ".#{$wi-css-prefix}-wind {\n  &.towards-0-deg {@include wind-rotate(0deg);}\n  &.towards-1-deg {@include wind-rotate(1deg);}\n  &.towards-2-deg {@include wind-rotate(2deg);}\n  &.towards-3-deg {@include wind-rotate(3deg);}\n  &.towards-4-deg {@include wind-rotate(4deg);}\n  &.towards-5-deg {@include wind-rotate(5deg);}\n  &.towards-6-deg {@include wind-rotate(6deg);}\n  &.towards-7-deg {@include wind-rotate(7deg);}\n  &.towards-8-deg {@include wind-rotate(8deg);}\n  &.towards-9-deg {@include wind-rotate(9deg);}\n  &.towards-10-deg {@include wind-rotate(10deg);}\n  &.towards-11-deg {@include wind-rotate(11deg);}\n  &.towards-12-deg {@include wind-rotate(12deg);}\n  &.towards-13-deg {@include wind-rotate(13deg);}\n  &.towards-14-deg {@include wind-rotate(14deg);}\n  &.towards-15-deg {@include wind-rotate(15deg);}\n  &.towards-16-deg {@include wind-rotate(16deg);}\n  &.towards-17-deg {@include wind-rotate(17deg);}\n  &.towards-18-deg {@include wind-rotate(18deg);}\n  &.towards-19-deg {@include wind-rotate(19deg);}\n  &.towards-20-deg {@include wind-rotate(20deg);}\n  &.towards-21-deg {@include wind-rotate(21deg);}\n  &.towards-22-deg {@include wind-rotate(22deg);}\n  &.towards-23-deg {@include wind-rotate(23deg);}\n  &.towards-24-deg {@include wind-rotate(24deg);}\n  &.towards-25-deg {@include wind-rotate(25deg);}\n  &.towards-26-deg {@include wind-rotate(26deg);}\n  &.towards-27-deg {@include wind-rotate(27deg);}\n  &.towards-28-deg {@include wind-rotate(28deg);}\n  &.towards-29-deg {@include wind-rotate(29deg);}\n  &.towards-30-deg {@include wind-rotate(30deg);}\n  &.towards-31-deg {@include wind-rotate(31deg);}\n  &.towards-32-deg {@include wind-rotate(32deg);}\n  &.towards-33-deg {@include wind-rotate(33deg);}\n  &.towards-34-deg {@include wind-rotate(34deg);}\n  &.towards-35-deg {@include wind-rotate(35deg);}\n  &.towards-36-deg {@include wind-rotate(36deg);}\n  &.towards-37-deg {@include wind-rotate(37deg);}\n  &.towards-38-deg {@include wind-rotate(38deg);}\n  &.towards-39-deg {@include wind-rotate(39deg);}\n  &.towards-40-deg {@include wind-rotate(40deg);}\n  &.towards-41-deg {@include wind-rotate(41deg);}\n  &.towards-42-deg {@include wind-rotate(42deg);}\n  &.towards-43-deg {@include wind-rotate(43deg);}\n  &.towards-44-deg {@include wind-rotate(44deg);}\n  &.towards-45-deg {@include wind-rotate(45deg);}\n  &.towards-46-deg {@include wind-rotate(46deg);}\n  &.towards-47-deg {@include wind-rotate(47deg);}\n  &.towards-48-deg {@include wind-rotate(48deg);}\n  &.towards-49-deg {@include wind-rotate(49deg);}\n  &.towards-50-deg {@include wind-rotate(50deg);}\n  &.towards-51-deg {@include wind-rotate(51deg);}\n  &.towards-52-deg {@include wind-rotate(52deg);}\n  &.towards-53-deg {@include wind-rotate(53deg);}\n  &.towards-54-deg {@include wind-rotate(54deg);}\n  &.towards-55-deg {@include wind-rotate(55deg);}\n  &.towards-56-deg {@include wind-rotate(56deg);}\n  &.towards-57-deg {@include wind-rotate(57deg);}\n  &.towards-58-deg {@include wind-rotate(58deg);}\n  &.towards-59-deg {@include wind-rotate(59deg);}\n  &.towards-60-deg {@include wind-rotate(60deg);}\n  &.towards-61-deg {@include wind-rotate(61deg);}\n  &.towards-62-deg {@include wind-rotate(62deg);}\n  &.towards-63-deg {@include wind-rotate(63deg);}\n  &.towards-64-deg {@include wind-rotate(64deg);}\n  &.towards-65-deg {@include wind-rotate(65deg);}\n  &.towards-66-deg {@include wind-rotate(66deg);}\n  &.towards-67-deg {@include wind-rotate(67deg);}\n  &.towards-68-deg {@include wind-rotate(68deg);}\n  &.towards-69-deg {@include wind-rotate(69deg);}\n  &.towards-70-deg {@include wind-rotate(70deg);}\n  &.towards-71-deg {@include wind-rotate(71deg);}\n  &.towards-72-deg {@include wind-rotate(72deg);}\n  &.towards-73-deg {@include wind-rotate(73deg);}\n  &.towards-74-deg {@include wind-rotate(74deg);}\n  &.towards-75-deg {@include wind-rotate(75deg);}\n  &.towards-76-deg {@include wind-rotate(76deg);}\n  &.towards-77-deg {@include wind-rotate(77deg);}\n  &.towards-78-deg {@include wind-rotate(78deg);}\n  &.towards-79-deg {@include wind-rotate(79deg);}\n  &.towards-80-deg {@include wind-rotate(80deg);}\n  &.towards-81-deg {@include wind-rotate(81deg);}\n  &.towards-82-deg {@include wind-rotate(82deg);}\n  &.towards-83-deg {@include wind-rotate(83deg);}\n  &.towards-84-deg {@include wind-rotate(84deg);}\n  &.towards-85-deg {@include wind-rotate(85deg);}\n  &.towards-86-deg {@include wind-rotate(86deg);}\n  &.towards-87-deg {@include wind-rotate(87deg);}\n  &.towards-88-deg {@include wind-rotate(88deg);}\n  &.towards-89-deg {@include wind-rotate(89deg);}\n  &.towards-90-deg {@include wind-rotate(90deg);}\n  &.towards-91-deg {@include wind-rotate(91deg);}\n  &.towards-92-deg {@include wind-rotate(92deg);}\n  &.towards-93-deg {@include wind-rotate(93deg);}\n  &.towards-94-deg {@include wind-rotate(94deg);}\n  &.towards-95-deg {@include wind-rotate(95deg);}\n  &.towards-96-deg {@include wind-rotate(96deg);}\n  &.towards-97-deg {@include wind-rotate(97deg);}\n  &.towards-98-deg {@include wind-rotate(98deg);}\n  &.towards-99-deg {@include wind-rotate(99deg);}\n  &.towards-100-deg {@include wind-rotate(100deg);}\n  &.towards-101-deg {@include wind-rotate(101deg);}\n  &.towards-102-deg {@include wind-rotate(102deg);}\n  &.towards-103-deg {@include wind-rotate(103deg);}\n  &.towards-104-deg {@include wind-rotate(104deg);}\n  &.towards-105-deg {@include wind-rotate(105deg);}\n  &.towards-106-deg {@include wind-rotate(106deg);}\n  &.towards-107-deg {@include wind-rotate(107deg);}\n  &.towards-108-deg {@include wind-rotate(108deg);}\n  &.towards-109-deg {@include wind-rotate(109deg);}\n  &.towards-110-deg {@include wind-rotate(110deg);}\n  &.towards-111-deg {@include wind-rotate(111deg);}\n  &.towards-112-deg {@include wind-rotate(112deg);}\n  &.towards-113-deg {@include wind-rotate(113deg);}\n  &.towards-114-deg {@include wind-rotate(114deg);}\n  &.towards-115-deg {@include wind-rotate(115deg);}\n  &.towards-116-deg {@include wind-rotate(116deg);}\n  &.towards-117-deg {@include wind-rotate(117deg);}\n  &.towards-118-deg {@include wind-rotate(118deg);}\n  &.towards-119-deg {@include wind-rotate(119deg);}\n  &.towards-120-deg {@include wind-rotate(120deg);}\n  &.towards-121-deg {@include wind-rotate(121deg);}\n  &.towards-122-deg {@include wind-rotate(122deg);}\n  &.towards-123-deg {@include wind-rotate(123deg);}\n  &.towards-124-deg {@include wind-rotate(124deg);}\n  &.towards-125-deg {@include wind-rotate(125deg);}\n  &.towards-126-deg {@include wind-rotate(126deg);}\n  &.towards-127-deg {@include wind-rotate(127deg);}\n  &.towards-128-deg {@include wind-rotate(128deg);}\n  &.towards-129-deg {@include wind-rotate(129deg);}\n  &.towards-130-deg {@include wind-rotate(130deg);}\n  &.towards-131-deg {@include wind-rotate(131deg);}\n  &.towards-132-deg {@include wind-rotate(132deg);}\n  &.towards-133-deg {@include wind-rotate(133deg);}\n  &.towards-134-deg {@include wind-rotate(134deg);}\n  &.towards-135-deg {@include wind-rotate(135deg);}\n  &.towards-136-deg {@include wind-rotate(136deg);}\n  &.towards-137-deg {@include wind-rotate(137deg);}\n  &.towards-138-deg {@include wind-rotate(138deg);}\n  &.towards-139-deg {@include wind-rotate(139deg);}\n  &.towards-140-deg {@include wind-rotate(140deg);}\n  &.towards-141-deg {@include wind-rotate(141deg);}\n  &.towards-142-deg {@include wind-rotate(142deg);}\n  &.towards-143-deg {@include wind-rotate(143deg);}\n  &.towards-144-deg {@include wind-rotate(144deg);}\n  &.towards-145-deg {@include wind-rotate(145deg);}\n  &.towards-146-deg {@include wind-rotate(146deg);}\n  &.towards-147-deg {@include wind-rotate(147deg);}\n  &.towards-148-deg {@include wind-rotate(148deg);}\n  &.towards-149-deg {@include wind-rotate(149deg);}\n  &.towards-150-deg {@include wind-rotate(150deg);}\n  &.towards-151-deg {@include wind-rotate(151deg);}\n  &.towards-152-deg {@include wind-rotate(152deg);}\n  &.towards-153-deg {@include wind-rotate(153deg);}\n  &.towards-154-deg {@include wind-rotate(154deg);}\n  &.towards-155-deg {@include wind-rotate(155deg);}\n  &.towards-156-deg {@include wind-rotate(156deg);}\n  &.towards-157-deg {@include wind-rotate(157deg);}\n  &.towards-158-deg {@include wind-rotate(158deg);}\n  &.towards-159-deg {@include wind-rotate(159deg);}\n  &.towards-160-deg {@include wind-rotate(160deg);}\n  &.towards-161-deg {@include wind-rotate(161deg);}\n  &.towards-162-deg {@include wind-rotate(162deg);}\n  &.towards-163-deg {@include wind-rotate(163deg);}\n  &.towards-164-deg {@include wind-rotate(164deg);}\n  &.towards-165-deg {@include wind-rotate(165deg);}\n  &.towards-166-deg {@include wind-rotate(166deg);}\n  &.towards-167-deg {@include wind-rotate(167deg);}\n  &.towards-168-deg {@include wind-rotate(168deg);}\n  &.towards-169-deg {@include wind-rotate(169deg);}\n  &.towards-170-deg {@include wind-rotate(170deg);}\n  &.towards-171-deg {@include wind-rotate(171deg);}\n  &.towards-172-deg {@include wind-rotate(172deg);}\n  &.towards-173-deg {@include wind-rotate(173deg);}\n  &.towards-174-deg {@include wind-rotate(174deg);}\n  &.towards-175-deg {@include wind-rotate(175deg);}\n  &.towards-176-deg {@include wind-rotate(176deg);}\n  &.towards-177-deg {@include wind-rotate(177deg);}\n  &.towards-178-deg {@include wind-rotate(178deg);}\n  &.towards-179-deg {@include wind-rotate(179deg);}\n  &.towards-180-deg {@include wind-rotate(180deg);}\n  &.towards-181-deg {@include wind-rotate(181deg);}\n  &.towards-182-deg {@include wind-rotate(182deg);}\n  &.towards-183-deg {@include wind-rotate(183deg);}\n  &.towards-184-deg {@include wind-rotate(184deg);}\n  &.towards-185-deg {@include wind-rotate(185deg);}\n  &.towards-186-deg {@include wind-rotate(186deg);}\n  &.towards-187-deg {@include wind-rotate(187deg);}\n  &.towards-188-deg {@include wind-rotate(188deg);}\n  &.towards-189-deg {@include wind-rotate(189deg);}\n  &.towards-190-deg {@include wind-rotate(190deg);}\n  &.towards-191-deg {@include wind-rotate(191deg);}\n  &.towards-192-deg {@include wind-rotate(192deg);}\n  &.towards-193-deg {@include wind-rotate(193deg);}\n  &.towards-194-deg {@include wind-rotate(194deg);}\n  &.towards-195-deg {@include wind-rotate(195deg);}\n  &.towards-196-deg {@include wind-rotate(196deg);}\n  &.towards-197-deg {@include wind-rotate(197deg);}\n  &.towards-198-deg {@include wind-rotate(198deg);}\n  &.towards-199-deg {@include wind-rotate(199deg);}\n  &.towards-200-deg {@include wind-rotate(200deg);}\n  &.towards-201-deg {@include wind-rotate(201deg);}\n  &.towards-202-deg {@include wind-rotate(202deg);}\n  &.towards-203-deg {@include wind-rotate(203deg);}\n  &.towards-204-deg {@include wind-rotate(204deg);}\n  &.towards-205-deg {@include wind-rotate(205deg);}\n  &.towards-206-deg {@include wind-rotate(206deg);}\n  &.towards-207-deg {@include wind-rotate(207deg);}\n  &.towards-208-deg {@include wind-rotate(208deg);}\n  &.towards-209-deg {@include wind-rotate(209deg);}\n  &.towards-210-deg {@include wind-rotate(210deg);}\n  &.towards-211-deg {@include wind-rotate(211deg);}\n  &.towards-212-deg {@include wind-rotate(212deg);}\n  &.towards-213-deg {@include wind-rotate(213deg);}\n  &.towards-214-deg {@include wind-rotate(214deg);}\n  &.towards-215-deg {@include wind-rotate(215deg);}\n  &.towards-216-deg {@include wind-rotate(216deg);}\n  &.towards-217-deg {@include wind-rotate(217deg);}\n  &.towards-218-deg {@include wind-rotate(218deg);}\n  &.towards-219-deg {@include wind-rotate(219deg);}\n  &.towards-220-deg {@include wind-rotate(220deg);}\n  &.towards-221-deg {@include wind-rotate(221deg);}\n  &.towards-222-deg {@include wind-rotate(222deg);}\n  &.towards-223-deg {@include wind-rotate(223deg);}\n  &.towards-224-deg {@include wind-rotate(224deg);}\n  &.towards-225-deg {@include wind-rotate(225deg);}\n  &.towards-226-deg {@include wind-rotate(226deg);}\n  &.towards-227-deg {@include wind-rotate(227deg);}\n  &.towards-228-deg {@include wind-rotate(228deg);}\n  &.towards-229-deg {@include wind-rotate(229deg);}\n  &.towards-230-deg {@include wind-rotate(230deg);}\n  &.towards-231-deg {@include wind-rotate(231deg);}\n  &.towards-232-deg {@include wind-rotate(232deg);}\n  &.towards-233-deg {@include wind-rotate(233deg);}\n  &.towards-234-deg {@include wind-rotate(234deg);}\n  &.towards-235-deg {@include wind-rotate(235deg);}\n  &.towards-236-deg {@include wind-rotate(236deg);}\n  &.towards-237-deg {@include wind-rotate(237deg);}\n  &.towards-238-deg {@include wind-rotate(238deg);}\n  &.towards-239-deg {@include wind-rotate(239deg);}\n  &.towards-240-deg {@include wind-rotate(240deg);}\n  &.towards-241-deg {@include wind-rotate(241deg);}\n  &.towards-242-deg {@include wind-rotate(242deg);}\n  &.towards-243-deg {@include wind-rotate(243deg);}\n  &.towards-244-deg {@include wind-rotate(244deg);}\n  &.towards-245-deg {@include wind-rotate(245deg);}\n  &.towards-246-deg {@include wind-rotate(246deg);}\n  &.towards-247-deg {@include wind-rotate(247deg);}\n  &.towards-248-deg {@include wind-rotate(248deg);}\n  &.towards-249-deg {@include wind-rotate(249deg);}\n  &.towards-250-deg {@include wind-rotate(250deg);}\n  &.towards-251-deg {@include wind-rotate(251deg);}\n  &.towards-252-deg {@include wind-rotate(252deg);}\n  &.towards-253-deg {@include wind-rotate(253deg);}\n  &.towards-254-deg {@include wind-rotate(254deg);}\n  &.towards-255-deg {@include wind-rotate(255deg);}\n  &.towards-256-deg {@include wind-rotate(256deg);}\n  &.towards-257-deg {@include wind-rotate(257deg);}\n  &.towards-258-deg {@include wind-rotate(258deg);}\n  &.towards-259-deg {@include wind-rotate(259deg);}\n  &.towards-260-deg {@include wind-rotate(260deg);}\n  &.towards-261-deg {@include wind-rotate(261deg);}\n  &.towards-262-deg {@include wind-rotate(262deg);}\n  &.towards-263-deg {@include wind-rotate(263deg);}\n  &.towards-264-deg {@include wind-rotate(264deg);}\n  &.towards-265-deg {@include wind-rotate(265deg);}\n  &.towards-266-deg {@include wind-rotate(266deg);}\n  &.towards-267-deg {@include wind-rotate(267deg);}\n  &.towards-268-deg {@include wind-rotate(268deg);}\n  &.towards-269-deg {@include wind-rotate(269deg);}\n  &.towards-270-deg {@include wind-rotate(270deg);}\n  &.towards-271-deg {@include wind-rotate(271deg);}\n  &.towards-272-deg {@include wind-rotate(272deg);}\n  &.towards-273-deg {@include wind-rotate(273deg);}\n  &.towards-274-deg {@include wind-rotate(274deg);}\n  &.towards-275-deg {@include wind-rotate(275deg);}\n  &.towards-276-deg {@include wind-rotate(276deg);}\n  &.towards-277-deg {@include wind-rotate(277deg);}\n  &.towards-278-deg {@include wind-rotate(278deg);}\n  &.towards-279-deg {@include wind-rotate(279deg);}\n  &.towards-280-deg {@include wind-rotate(280deg);}\n  &.towards-281-deg {@include wind-rotate(281deg);}\n  &.towards-282-deg {@include wind-rotate(282deg);}\n  &.towards-283-deg {@include wind-rotate(283deg);}\n  &.towards-284-deg {@include wind-rotate(284deg);}\n  &.towards-285-deg {@include wind-rotate(285deg);}\n  &.towards-286-deg {@include wind-rotate(286deg);}\n  &.towards-287-deg {@include wind-rotate(287deg);}\n  &.towards-288-deg {@include wind-rotate(288deg);}\n  &.towards-289-deg {@include wind-rotate(289deg);}\n  &.towards-290-deg {@include wind-rotate(290deg);}\n  &.towards-291-deg {@include wind-rotate(291deg);}\n  &.towards-292-deg {@include wind-rotate(292deg);}\n  &.towards-293-deg {@include wind-rotate(293deg);}\n  &.towards-294-deg {@include wind-rotate(294deg);}\n  &.towards-295-deg {@include wind-rotate(295deg);}\n  &.towards-296-deg {@include wind-rotate(296deg);}\n  &.towards-297-deg {@include wind-rotate(297deg);}\n  &.towards-298-deg {@include wind-rotate(298deg);}\n  &.towards-299-deg {@include wind-rotate(299deg);}\n  &.towards-300-deg {@include wind-rotate(300deg);}\n  &.towards-301-deg {@include wind-rotate(301deg);}\n  &.towards-302-deg {@include wind-rotate(302deg);}\n  &.towards-303-deg {@include wind-rotate(303deg);}\n  &.towards-304-deg {@include wind-rotate(304deg);}\n  &.towards-305-deg {@include wind-rotate(305deg);}\n  &.towards-306-deg {@include wind-rotate(306deg);}\n  &.towards-307-deg {@include wind-rotate(307deg);}\n  &.towards-308-deg {@include wind-rotate(308deg);}\n  &.towards-309-deg {@include wind-rotate(309deg);}\n  &.towards-310-deg {@include wind-rotate(310deg);}\n  &.towards-311-deg {@include wind-rotate(311deg);}\n  &.towards-312-deg {@include wind-rotate(312deg);}\n  &.towards-313-deg {@include wind-rotate(313deg);}\n  &.towards-314-deg {@include wind-rotate(314deg);}\n  &.towards-315-deg {@include wind-rotate(315deg);}\n  &.towards-316-deg {@include wind-rotate(316deg);}\n  &.towards-317-deg {@include wind-rotate(317deg);}\n  &.towards-318-deg {@include wind-rotate(318deg);}\n  &.towards-319-deg {@include wind-rotate(319deg);}\n  &.towards-320-deg {@include wind-rotate(320deg);}\n  &.towards-321-deg {@include wind-rotate(321deg);}\n  &.towards-322-deg {@include wind-rotate(322deg);}\n  &.towards-323-deg {@include wind-rotate(323deg);}\n  &.towards-324-deg {@include wind-rotate(324deg);}\n  &.towards-325-deg {@include wind-rotate(325deg);}\n  &.towards-326-deg {@include wind-rotate(326deg);}\n  &.towards-327-deg {@include wind-rotate(327deg);}\n  &.towards-328-deg {@include wind-rotate(328deg);}\n  &.towards-329-deg {@include wind-rotate(329deg);}\n  &.towards-330-deg {@include wind-rotate(330deg);}\n  &.towards-331-deg {@include wind-rotate(331deg);}\n  &.towards-332-deg {@include wind-rotate(332deg);}\n  &.towards-333-deg {@include wind-rotate(333deg);}\n  &.towards-334-deg {@include wind-rotate(334deg);}\n  &.towards-335-deg {@include wind-rotate(335deg);}\n  &.towards-336-deg {@include wind-rotate(336deg);}\n  &.towards-337-deg {@include wind-rotate(337deg);}\n  &.towards-338-deg {@include wind-rotate(338deg);}\n  &.towards-339-deg {@include wind-rotate(339deg);}\n  &.towards-340-deg {@include wind-rotate(340deg);}\n  &.towards-341-deg {@include wind-rotate(341deg);}\n  &.towards-342-deg {@include wind-rotate(342deg);}\n  &.towards-343-deg {@include wind-rotate(343deg);}\n  &.towards-344-deg {@include wind-rotate(344deg);}\n  &.towards-345-deg {@include wind-rotate(345deg);}\n  &.towards-346-deg {@include wind-rotate(346deg);}\n  &.towards-347-deg {@include wind-rotate(347deg);}\n  &.towards-348-deg {@include wind-rotate(348deg);}\n  &.towards-349-deg {@include wind-rotate(349deg);}\n  &.towards-350-deg {@include wind-rotate(350deg);}\n  &.towards-351-deg {@include wind-rotate(351deg);}\n  &.towards-352-deg {@include wind-rotate(352deg);}\n  &.towards-353-deg {@include wind-rotate(353deg);}\n  &.towards-354-deg {@include wind-rotate(354deg);}\n  &.towards-355-deg {@include wind-rotate(355deg);}\n  &.towards-356-deg {@include wind-rotate(356deg);}\n  &.towards-357-deg {@include wind-rotate(357deg);}\n  &.towards-358-deg {@include wind-rotate(358deg);}\n  &.towards-359-deg {@include wind-rotate(359deg);}\n  &.towards-360-deg {@include wind-rotate(0deg);}\n  &.from-0-deg {@include wind-rotate(180deg);}\n  &.from-1-deg {@include wind-rotate(181deg);}\n  &.from-2-deg {@include wind-rotate(182deg);}\n  &.from-3-deg {@include wind-rotate(183deg);}\n  &.from-4-deg {@include wind-rotate(184deg);}\n  &.from-5-deg {@include wind-rotate(185deg);}\n  &.from-6-deg {@include wind-rotate(186deg);}\n  &.from-7-deg {@include wind-rotate(187deg);}\n  &.from-8-deg {@include wind-rotate(188deg);}\n  &.from-9-deg {@include wind-rotate(189deg);}\n  &.from-10-deg {@include wind-rotate(190deg);}\n  &.from-11-deg {@include wind-rotate(191deg);}\n  &.from-12-deg {@include wind-rotate(192deg);}\n  &.from-13-deg {@include wind-rotate(193deg);}\n  &.from-14-deg {@include wind-rotate(194deg);}\n  &.from-15-deg {@include wind-rotate(195deg);}\n  &.from-16-deg {@include wind-rotate(196deg);}\n  &.from-17-deg {@include wind-rotate(197deg);}\n  &.from-18-deg {@include wind-rotate(198deg);}\n  &.from-19-deg {@include wind-rotate(199deg);}\n  &.from-20-deg {@include wind-rotate(200deg);}\n  &.from-21-deg {@include wind-rotate(201deg);}\n  &.from-22-deg {@include wind-rotate(202deg);}\n  &.from-23-deg {@include wind-rotate(203deg);}\n  &.from-24-deg {@include wind-rotate(204deg);}\n  &.from-25-deg {@include wind-rotate(205deg);}\n  &.from-26-deg {@include wind-rotate(206deg);}\n  &.from-27-deg {@include wind-rotate(207deg);}\n  &.from-28-deg {@include wind-rotate(208deg);}\n  &.from-29-deg {@include wind-rotate(209deg);}\n  &.from-30-deg {@include wind-rotate(210deg);}\n  &.from-31-deg {@include wind-rotate(211deg);}\n  &.from-32-deg {@include wind-rotate(212deg);}\n  &.from-33-deg {@include wind-rotate(213deg);}\n  &.from-34-deg {@include wind-rotate(214deg);}\n  &.from-35-deg {@include wind-rotate(215deg);}\n  &.from-36-deg {@include wind-rotate(216deg);}\n  &.from-37-deg {@include wind-rotate(217deg);}\n  &.from-38-deg {@include wind-rotate(218deg);}\n  &.from-39-deg {@include wind-rotate(219deg);}\n  &.from-40-deg {@include wind-rotate(220deg);}\n  &.from-41-deg {@include wind-rotate(221deg);}\n  &.from-42-deg {@include wind-rotate(222deg);}\n  &.from-43-deg {@include wind-rotate(223deg);}\n  &.from-44-deg {@include wind-rotate(224deg);}\n  &.from-45-deg {@include wind-rotate(225deg);}\n  &.from-46-deg {@include wind-rotate(226deg);}\n  &.from-47-deg {@include wind-rotate(227deg);}\n  &.from-48-deg {@include wind-rotate(228deg);}\n  &.from-49-deg {@include wind-rotate(229deg);}\n  &.from-50-deg {@include wind-rotate(230deg);}\n  &.from-51-deg {@include wind-rotate(231deg);}\n  &.from-52-deg {@include wind-rotate(232deg);}\n  &.from-53-deg {@include wind-rotate(233deg);}\n  &.from-54-deg {@include wind-rotate(234deg);}\n  &.from-55-deg {@include wind-rotate(235deg);}\n  &.from-56-deg {@include wind-rotate(236deg);}\n  &.from-57-deg {@include wind-rotate(237deg);}\n  &.from-58-deg {@include wind-rotate(238deg);}\n  &.from-59-deg {@include wind-rotate(239deg);}\n  &.from-60-deg {@include wind-rotate(240deg);}\n  &.from-61-deg {@include wind-rotate(241deg);}\n  &.from-62-deg {@include wind-rotate(242deg);}\n  &.from-63-deg {@include wind-rotate(243deg);}\n  &.from-64-deg {@include wind-rotate(244deg);}\n  &.from-65-deg {@include wind-rotate(245deg);}\n  &.from-66-deg {@include wind-rotate(246deg);}\n  &.from-67-deg {@include wind-rotate(247deg);}\n  &.from-68-deg {@include wind-rotate(248deg);}\n  &.from-69-deg {@include wind-rotate(249deg);}\n  &.from-70-deg {@include wind-rotate(250deg);}\n  &.from-71-deg {@include wind-rotate(251deg);}\n  &.from-72-deg {@include wind-rotate(252deg);}\n  &.from-73-deg {@include wind-rotate(253deg);}\n  &.from-74-deg {@include wind-rotate(254deg);}\n  &.from-75-deg {@include wind-rotate(255deg);}\n  &.from-76-deg {@include wind-rotate(256deg);}\n  &.from-77-deg {@include wind-rotate(257deg);}\n  &.from-78-deg {@include wind-rotate(258deg);}\n  &.from-79-deg {@include wind-rotate(259deg);}\n  &.from-80-deg {@include wind-rotate(260deg);}\n  &.from-81-deg {@include wind-rotate(261deg);}\n  &.from-82-deg {@include wind-rotate(262deg);}\n  &.from-83-deg {@include wind-rotate(263deg);}\n  &.from-84-deg {@include wind-rotate(264deg);}\n  &.from-85-deg {@include wind-rotate(265deg);}\n  &.from-86-deg {@include wind-rotate(266deg);}\n  &.from-87-deg {@include wind-rotate(267deg);}\n  &.from-88-deg {@include wind-rotate(268deg);}\n  &.from-89-deg {@include wind-rotate(269deg);}\n  &.from-90-deg {@include wind-rotate(270deg);}\n  &.from-91-deg {@include wind-rotate(271deg);}\n  &.from-92-deg {@include wind-rotate(272deg);}\n  &.from-93-deg {@include wind-rotate(273deg);}\n  &.from-94-deg {@include wind-rotate(274deg);}\n  &.from-95-deg {@include wind-rotate(275deg);}\n  &.from-96-deg {@include wind-rotate(276deg);}\n  &.from-97-deg {@include wind-rotate(277deg);}\n  &.from-98-deg {@include wind-rotate(278deg);}\n  &.from-99-deg {@include wind-rotate(279deg);}\n  &.from-100-deg {@include wind-rotate(280deg);}\n  &.from-101-deg {@include wind-rotate(281deg);}\n  &.from-102-deg {@include wind-rotate(282deg);}\n  &.from-103-deg {@include wind-rotate(283deg);}\n  &.from-104-deg {@include wind-rotate(284deg);}\n  &.from-105-deg {@include wind-rotate(285deg);}\n  &.from-106-deg {@include wind-rotate(286deg);}\n  &.from-107-deg {@include wind-rotate(287deg);}\n  &.from-108-deg {@include wind-rotate(288deg);}\n  &.from-109-deg {@include wind-rotate(289deg);}\n  &.from-110-deg {@include wind-rotate(290deg);}\n  &.from-111-deg {@include wind-rotate(291deg);}\n  &.from-112-deg {@include wind-rotate(292deg);}\n  &.from-113-deg {@include wind-rotate(293deg);}\n  &.from-114-deg {@include wind-rotate(294deg);}\n  &.from-115-deg {@include wind-rotate(295deg);}\n  &.from-116-deg {@include wind-rotate(296deg);}\n  &.from-117-deg {@include wind-rotate(297deg);}\n  &.from-118-deg {@include wind-rotate(298deg);}\n  &.from-119-deg {@include wind-rotate(299deg);}\n  &.from-120-deg {@include wind-rotate(300deg);}\n  &.from-121-deg {@include wind-rotate(301deg);}\n  &.from-122-deg {@include wind-rotate(302deg);}\n  &.from-123-deg {@include wind-rotate(303deg);}\n  &.from-124-deg {@include wind-rotate(304deg);}\n  &.from-125-deg {@include wind-rotate(305deg);}\n  &.from-126-deg {@include wind-rotate(306deg);}\n  &.from-127-deg {@include wind-rotate(307deg);}\n  &.from-128-deg {@include wind-rotate(308deg);}\n  &.from-129-deg {@include wind-rotate(309deg);}\n  &.from-130-deg {@include wind-rotate(310deg);}\n  &.from-131-deg {@include wind-rotate(311deg);}\n  &.from-132-deg {@include wind-rotate(312deg);}\n  &.from-133-deg {@include wind-rotate(313deg);}\n  &.from-134-deg {@include wind-rotate(314deg);}\n  &.from-135-deg {@include wind-rotate(315deg);}\n  &.from-136-deg {@include wind-rotate(316deg);}\n  &.from-137-deg {@include wind-rotate(317deg);}\n  &.from-138-deg {@include wind-rotate(318deg);}\n  &.from-139-deg {@include wind-rotate(319deg);}\n  &.from-140-deg {@include wind-rotate(320deg);}\n  &.from-141-deg {@include wind-rotate(321deg);}\n  &.from-142-deg {@include wind-rotate(322deg);}\n  &.from-143-deg {@include wind-rotate(323deg);}\n  &.from-144-deg {@include wind-rotate(324deg);}\n  &.from-145-deg {@include wind-rotate(325deg);}\n  &.from-146-deg {@include wind-rotate(326deg);}\n  &.from-147-deg {@include wind-rotate(327deg);}\n  &.from-148-deg {@include wind-rotate(328deg);}\n  &.from-149-deg {@include wind-rotate(329deg);}\n  &.from-150-deg {@include wind-rotate(330deg);}\n  &.from-151-deg {@include wind-rotate(331deg);}\n  &.from-152-deg {@include wind-rotate(332deg);}\n  &.from-153-deg {@include wind-rotate(333deg);}\n  &.from-154-deg {@include wind-rotate(334deg);}\n  &.from-155-deg {@include wind-rotate(335deg);}\n  &.from-156-deg {@include wind-rotate(336deg);}\n  &.from-157-deg {@include wind-rotate(337deg);}\n  &.from-158-deg {@include wind-rotate(338deg);}\n  &.from-159-deg {@include wind-rotate(339deg);}\n  &.from-160-deg {@include wind-rotate(340deg);}\n  &.from-161-deg {@include wind-rotate(341deg);}\n  &.from-162-deg {@include wind-rotate(342deg);}\n  &.from-163-deg {@include wind-rotate(343deg);}\n  &.from-164-deg {@include wind-rotate(344deg);}\n  &.from-165-deg {@include wind-rotate(345deg);}\n  &.from-166-deg {@include wind-rotate(346deg);}\n  &.from-167-deg {@include wind-rotate(347deg);}\n  &.from-168-deg {@include wind-rotate(348deg);}\n  &.from-169-deg {@include wind-rotate(349deg);}\n  &.from-170-deg {@include wind-rotate(350deg);}\n  &.from-171-deg {@include wind-rotate(351deg);}\n  &.from-172-deg {@include wind-rotate(352deg);}\n  &.from-173-deg {@include wind-rotate(353deg);}\n  &.from-174-deg {@include wind-rotate(354deg);}\n  &.from-175-deg {@include wind-rotate(355deg);}\n  &.from-176-deg {@include wind-rotate(356deg);}\n  &.from-177-deg {@include wind-rotate(357deg);}\n  &.from-178-deg {@include wind-rotate(358deg);}\n  &.from-179-deg {@include wind-rotate(359deg);}\n  &.from-180-deg {@include wind-rotate(0deg);}\n  &.from-181-deg {@include wind-rotate(1deg);}\n  &.from-182-deg {@include wind-rotate(2deg);}\n  &.from-183-deg {@include wind-rotate(3deg);}\n  &.from-184-deg {@include wind-rotate(4deg);}\n  &.from-185-deg {@include wind-rotate(5deg);}\n  &.from-186-deg {@include wind-rotate(6deg);}\n  &.from-187-deg {@include wind-rotate(7deg);}\n  &.from-188-deg {@include wind-rotate(8deg);}\n  &.from-189-deg {@include wind-rotate(9deg);}\n  &.from-190-deg {@include wind-rotate(10deg);}\n  &.from-191-deg {@include wind-rotate(11deg);}\n  &.from-192-deg {@include wind-rotate(12deg);}\n  &.from-193-deg {@include wind-rotate(13deg);}\n  &.from-194-deg {@include wind-rotate(14deg);}\n  &.from-195-deg {@include wind-rotate(15deg);}\n  &.from-196-deg {@include wind-rotate(16deg);}\n  &.from-197-deg {@include wind-rotate(17deg);}\n  &.from-198-deg {@include wind-rotate(18deg);}\n  &.from-199-deg {@include wind-rotate(19deg);}\n  &.from-200-deg {@include wind-rotate(20deg);}\n  &.from-201-deg {@include wind-rotate(21deg);}\n  &.from-202-deg {@include wind-rotate(22deg);}\n  &.from-203-deg {@include wind-rotate(23deg);}\n  &.from-204-deg {@include wind-rotate(24deg);}\n  &.from-205-deg {@include wind-rotate(25deg);}\n  &.from-206-deg {@include wind-rotate(26deg);}\n  &.from-207-deg {@include wind-rotate(27deg);}\n  &.from-208-deg {@include wind-rotate(28deg);}\n  &.from-209-deg {@include wind-rotate(29deg);}\n  &.from-210-deg {@include wind-rotate(30deg);}\n  &.from-211-deg {@include wind-rotate(31deg);}\n  &.from-212-deg {@include wind-rotate(32deg);}\n  &.from-213-deg {@include wind-rotate(33deg);}\n  &.from-214-deg {@include wind-rotate(34deg);}\n  &.from-215-deg {@include wind-rotate(35deg);}\n  &.from-216-deg {@include wind-rotate(36deg);}\n  &.from-217-deg {@include wind-rotate(37deg);}\n  &.from-218-deg {@include wind-rotate(38deg);}\n  &.from-219-deg {@include wind-rotate(39deg);}\n  &.from-220-deg {@include wind-rotate(40deg);}\n  &.from-221-deg {@include wind-rotate(41deg);}\n  &.from-222-deg {@include wind-rotate(42deg);}\n  &.from-223-deg {@include wind-rotate(43deg);}\n  &.from-224-deg {@include wind-rotate(44deg);}\n  &.from-225-deg {@include wind-rotate(45deg);}\n  &.from-226-deg {@include wind-rotate(46deg);}\n  &.from-227-deg {@include wind-rotate(47deg);}\n  &.from-228-deg {@include wind-rotate(48deg);}\n  &.from-229-deg {@include wind-rotate(49deg);}\n  &.from-230-deg {@include wind-rotate(50deg);}\n  &.from-231-deg {@include wind-rotate(51deg);}\n  &.from-232-deg {@include wind-rotate(52deg);}\n  &.from-233-deg {@include wind-rotate(53deg);}\n  &.from-234-deg {@include wind-rotate(54deg);}\n  &.from-235-deg {@include wind-rotate(55deg);}\n  &.from-236-deg {@include wind-rotate(56deg);}\n  &.from-237-deg {@include wind-rotate(57deg);}\n  &.from-238-deg {@include wind-rotate(58deg);}\n  &.from-239-deg {@include wind-rotate(59deg);}\n  &.from-240-deg {@include wind-rotate(60deg);}\n  &.from-241-deg {@include wind-rotate(61deg);}\n  &.from-242-deg {@include wind-rotate(62deg);}\n  &.from-243-deg {@include wind-rotate(63deg);}\n  &.from-244-deg {@include wind-rotate(64deg);}\n  &.from-245-deg {@include wind-rotate(65deg);}\n  &.from-246-deg {@include wind-rotate(66deg);}\n  &.from-247-deg {@include wind-rotate(67deg);}\n  &.from-248-deg {@include wind-rotate(68deg);}\n  &.from-249-deg {@include wind-rotate(69deg);}\n  &.from-250-deg {@include wind-rotate(70deg);}\n  &.from-251-deg {@include wind-rotate(71deg);}\n  &.from-252-deg {@include wind-rotate(72deg);}\n  &.from-253-deg {@include wind-rotate(73deg);}\n  &.from-254-deg {@include wind-rotate(74deg);}\n  &.from-255-deg {@include wind-rotate(75deg);}\n  &.from-256-deg {@include wind-rotate(76deg);}\n  &.from-257-deg {@include wind-rotate(77deg);}\n  &.from-258-deg {@include wind-rotate(78deg);}\n  &.from-259-deg {@include wind-rotate(79deg);}\n  &.from-260-deg {@include wind-rotate(80deg);}\n  &.from-261-deg {@include wind-rotate(81deg);}\n  &.from-262-deg {@include wind-rotate(82deg);}\n  &.from-263-deg {@include wind-rotate(83deg);}\n  &.from-264-deg {@include wind-rotate(84deg);}\n  &.from-265-deg {@include wind-rotate(85deg);}\n  &.from-266-deg {@include wind-rotate(86deg);}\n  &.from-267-deg {@include wind-rotate(87deg);}\n  &.from-268-deg {@include wind-rotate(88deg);}\n  &.from-269-deg {@include wind-rotate(89deg);}\n  &.from-270-deg {@include wind-rotate(90deg);}\n  &.from-271-deg {@include wind-rotate(91deg);}\n  &.from-272-deg {@include wind-rotate(92deg);}\n  &.from-273-deg {@include wind-rotate(93deg);}\n  &.from-274-deg {@include wind-rotate(94deg);}\n  &.from-275-deg {@include wind-rotate(95deg);}\n  &.from-276-deg {@include wind-rotate(96deg);}\n  &.from-277-deg {@include wind-rotate(97deg);}\n  &.from-278-deg {@include wind-rotate(98deg);}\n  &.from-279-deg {@include wind-rotate(99deg);}\n  &.from-280-deg {@include wind-rotate(100deg);}\n  &.from-281-deg {@include wind-rotate(101deg);}\n  &.from-282-deg {@include wind-rotate(102deg);}\n  &.from-283-deg {@include wind-rotate(103deg);}\n  &.from-284-deg {@include wind-rotate(104deg);}\n  &.from-285-deg {@include wind-rotate(105deg);}\n  &.from-286-deg {@include wind-rotate(106deg);}\n  &.from-287-deg {@include wind-rotate(107deg);}\n  &.from-288-deg {@include wind-rotate(108deg);}\n  &.from-289-deg {@include wind-rotate(109deg);}\n  &.from-290-deg {@include wind-rotate(110deg);}\n  &.from-291-deg {@include wind-rotate(111deg);}\n  &.from-292-deg {@include wind-rotate(112deg);}\n  &.from-293-deg {@include wind-rotate(113deg);}\n  &.from-294-deg {@include wind-rotate(114deg);}\n  &.from-295-deg {@include wind-rotate(115deg);}\n  &.from-296-deg {@include wind-rotate(116deg);}\n  &.from-297-deg {@include wind-rotate(117deg);}\n  &.from-298-deg {@include wind-rotate(118deg);}\n  &.from-299-deg {@include wind-rotate(119deg);}\n  &.from-300-deg {@include wind-rotate(120deg);}\n  &.from-301-deg {@include wind-rotate(121deg);}\n  &.from-302-deg {@include wind-rotate(122deg);}\n  &.from-303-deg {@include wind-rotate(123deg);}\n  &.from-304-deg {@include wind-rotate(124deg);}\n  &.from-305-deg {@include wind-rotate(125deg);}\n  &.from-306-deg {@include wind-rotate(126deg);}\n  &.from-307-deg {@include wind-rotate(127deg);}\n  &.from-308-deg {@include wind-rotate(128deg);}\n  &.from-309-deg {@include wind-rotate(129deg);}\n  &.from-310-deg {@include wind-rotate(130deg);}\n  &.from-311-deg {@include wind-rotate(131deg);}\n  &.from-312-deg {@include wind-rotate(132deg);}\n  &.from-313-deg {@include wind-rotate(133deg);}\n  &.from-314-deg {@include wind-rotate(134deg);}\n  &.from-315-deg {@include wind-rotate(135deg);}\n  &.from-316-deg {@include wind-rotate(136deg);}\n  &.from-317-deg {@include wind-rotate(137deg);}\n  &.from-318-deg {@include wind-rotate(138deg);}\n  &.from-319-deg {@include wind-rotate(139deg);}\n  &.from-320-deg {@include wind-rotate(140deg);}\n  &.from-321-deg {@include wind-rotate(141deg);}\n  &.from-322-deg {@include wind-rotate(142deg);}\n  &.from-323-deg {@include wind-rotate(143deg);}\n  &.from-324-deg {@include wind-rotate(144deg);}\n  &.from-325-deg {@include wind-rotate(145deg);}\n  &.from-326-deg {@include wind-rotate(146deg);}\n  &.from-327-deg {@include wind-rotate(147deg);}\n  &.from-328-deg {@include wind-rotate(148deg);}\n  &.from-329-deg {@include wind-rotate(149deg);}\n  &.from-330-deg {@include wind-rotate(150deg);}\n  &.from-331-deg {@include wind-rotate(151deg);}\n  &.from-332-deg {@include wind-rotate(152deg);}\n  &.from-333-deg {@include wind-rotate(153deg);}\n  &.from-334-deg {@include wind-rotate(154deg);}\n  &.from-335-deg {@include wind-rotate(155deg);}\n  &.from-336-deg {@include wind-rotate(156deg);}\n  &.from-337-deg {@include wind-rotate(157deg);}\n  &.from-338-deg {@include wind-rotate(158deg);}\n  &.from-339-deg {@include wind-rotate(159deg);}\n  &.from-340-deg {@include wind-rotate(160deg);}\n  &.from-341-deg {@include wind-rotate(161deg);}\n  &.from-342-deg {@include wind-rotate(162deg);}\n  &.from-343-deg {@include wind-rotate(163deg);}\n  &.from-344-deg {@include wind-rotate(164deg);}\n  &.from-345-deg {@include wind-rotate(165deg);}\n  &.from-346-deg {@include wind-rotate(166deg);}\n  &.from-347-deg {@include wind-rotate(167deg);}\n  &.from-348-deg {@include wind-rotate(168deg);}\n  &.from-349-deg {@include wind-rotate(169deg);}\n  &.from-350-deg {@include wind-rotate(170deg);}\n  &.from-351-deg {@include wind-rotate(171deg);}\n  &.from-352-deg {@include wind-rotate(172deg);}\n  &.from-353-deg {@include wind-rotate(173deg);}\n  &.from-354-deg {@include wind-rotate(174deg);}\n  &.from-355-deg {@include wind-rotate(175deg);}\n  &.from-356-deg {@include wind-rotate(176deg);}\n  &.from-357-deg {@include wind-rotate(177deg);}\n  &.from-358-deg {@include wind-rotate(178deg);}\n  &.from-359-deg {@include wind-rotate(179deg);}\n  &.from-360-deg {@include wind-rotate(180deg);}\n}\n\n.wi-wind-towards-n    {\n  @extend .wi-wind.towards-0-deg;\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-classes/classes-wind.scss",
    "content": "// Wind Variables 2.0\n\n$wind: \"\\f0b1\";\n\n.#{$wi-css-prefix}-wind:before { content: $wind; }\n\n@mixin wind-rotate( $val: 0deg ) {\n  -webkit-transform: rotate($val);\n  -moz-transform: rotate($val);\n  -ms-transform: rotate($val);\n  -o-transform: rotate($val);\n  transform: rotate($val);\n}\n\n@import \"classes-wind-degrees.scss\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-beaufort.scss",
    "content": "$wind-beaufort-0: \"\\f0b7\";\n$wind-beaufort-1: \"\\f0b8\";\n$wind-beaufort-2: \"\\f0b9\";\n$wind-beaufort-3: \"\\f0ba\";\n$wind-beaufort-4: \"\\f0bb\";\n$wind-beaufort-5: \"\\f0bc\";\n$wind-beaufort-6: \"\\f0bd\";\n$wind-beaufort-7: \"\\f0be\";\n$wind-beaufort-8: \"\\f0bf\";\n$wind-beaufort-9: \"\\f0c0\";\n$wind-beaufort-10: \"\\f0c1\";\n$wind-beaufort-11: \"\\f0c2\";\n$wind-beaufort-12: \"\\f0c3\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-day.scss",
    "content": "$day-sunny: \"\\f00d\";\n$day-cloudy: \"\\f002\";\n$day-cloudy-gusts: \"\\f000\";\n$day-cloudy-windy: \"\\f001\";\n$day-fog: \"\\f003\";\n$day-hail: \"\\f004\";\n$day-haze: \"\\f0b6\";\n$day-lightning: \"\\f005\";\n$day-rain: \"\\f008\";\n$day-rain-mix: \"\\f006\";\n$day-rain-wind: \"\\f007\";\n$day-showers: \"\\f009\";\n$day-sleet: \"\\f0b2\";\n$day-sleet-storm: \"\\f068\";\n$day-snow: \"\\f00a\";\n$day-snow-thunderstorm: \"\\f06b\";\n$day-snow-wind: \"\\f065\";\n$day-sprinkle: \"\\f00b\";\n$day-storm-showers: \"\\f00e\";\n$day-sunny-overcast: \"\\f00c\";\n$day-thunderstorm: \"\\f010\";\n$day-windy: \"\\f085\";\n$solar-eclipse: \"\\f06e\";\n$hot: \"\\f072\";\n$day-cloudy-high: \"\\f07d\";\n$day-light-wind: \"\\f0c4\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-direction.scss",
    "content": "$direction-up: \"\\f058\";\n$direction-up-right: \"\\f057\";\n$direction-right: \"\\f04d\";\n$direction-down-right: \"\\f088\";\n$direction-down: \"\\f044\";\n$direction-down-left: \"\\f043\";\n$direction-left: \"\\f048\";\n$direction-up-left: \"\\f087\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-misc.scss",
    "content": "$alien: \"\\f075\";\n$celsius: \"\\f03c\";\n$fahrenheit: \"\\f045\";\n$degrees: \"\\f042\";\n$thermometer: \"\\f055\";\n$thermometer-exterior: \"\\f053\";\n$thermometer-internal: \"\\f054\";\n$cloud-down: \"\\f03d\";\n$cloud-up: \"\\f040\";\n$cloud-refresh: \"\\f03e\";\n$horizon: \"\\f047\";\n$horizon-alt: \"\\f046\";\n$sunrise: \"\\f051\";\n$sunset: \"\\f052\";\n$moonrise: \"\\f0c9\";\n$moonset: \"\\f0ca\";\n$refresh: \"\\f04c\";\n$refresh-alt: \"\\f04b\";\n$umbrella: \"\\f084\";\n$barometer: \"\\f079\";\n$humidity: \"\\f07a\";\n$na: \"\\f07b\";\n$train: \"\\f0cb\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-moon.scss",
    "content": "$moon-new: \"\\f095\";\n$moon-waxing-cresent-1: \"\\f096\";\n$moon-waxing-cresent-2: \"\\f097\";\n$moon-waxing-cresent-3: \"\\f098\";\n$moon-waxing-cresent-4: \"\\f099\";\n$moon-waxing-cresent-5: \"\\f09a\";\n$moon-waxing-cresent-6: \"\\f09b\";\n$moon-first-quarter: \"\\f09c\";\n$moon-waxing-gibbous-1: \"\\f09d\";\n$moon-waxing-gibbous-2: \"\\f09e\";\n$moon-waxing-gibbous-3: \"\\f09f\";\n$moon-waxing-gibbous-4: \"\\f0a0\";\n$moon-waxing-gibbous-5: \"\\f0a1\";\n$moon-waxing-gibbous-6: \"\\f0a2\";\n$moon-full: \"\\f0a3\";\n$moon-waning-gibbous-1: \"\\f0a4\";\n$moon-waning-gibbous-2: \"\\f0a5\";\n$moon-waning-gibbous-3: \"\\f0a6\";\n$moon-waning-gibbous-4: \"\\f0a7\";\n$moon-waning-gibbous-5: \"\\f0a8\";\n$moon-waning-gibbous-6: \"\\f0a9\";\n$moon-third-quarter: \"\\f0aa\";\n$moon-waning-crescent-1: \"\\f0ab\";\n$moon-waning-crescent-2: \"\\f0ac\";\n$moon-waning-crescent-3: \"\\f0ad\";\n$moon-waning-crescent-4: \"\\f0ae\";\n$moon-waning-crescent-5: \"\\f0af\";\n$moon-waning-crescent-6: \"\\f0b0\";\n$moon-alt-new: \"\\f0eb\";\n$moon-alt-waxing-cresent-1: \"\\f0d0\";\n$moon-alt-waxing-cresent-2: \"\\f0d1\";\n$moon-alt-waxing-cresent-3: \"\\f0d2\";\n$moon-alt-waxing-cresent-4: \"\\f0d3\";\n$moon-alt-waxing-cresent-5: \"\\f0d4\";\n$moon-alt-waxing-cresent-6: \"\\f0d5\";\n$moon-alt-first-quarter: \"\\f0d6\";\n$moon-alt-waxing-gibbous-1: \"\\f0d7\";\n$moon-alt-waxing-gibbous-2: \"\\f0d8\";\n$moon-alt-waxing-gibbous-3: \"\\f0d9\";\n$moon-alt-waxing-gibbous-4: \"\\f0da\";\n$moon-alt-waxing-gibbous-5: \"\\f0db\";\n$moon-alt-waxing-gibbous-6: \"\\f0dc\";\n$moon-alt-full: \"\\f0dd\";\n$moon-alt-waning-gibbous-1: \"\\f0de\";\n$moon-alt-waning-gibbous-2: \"\\f0df\";\n$moon-alt-waning-gibbous-3: \"\\f0e0\";\n$moon-alt-waning-gibbous-4: \"\\f0e1\";\n$moon-alt-waning-gibbous-5: \"\\f0e2\";\n$moon-alt-waning-gibbous-6: \"\\f0e3\";\n$moon-alt-third-quarter: \"\\f0e4\";\n$moon-alt-waning-crescent-1: \"\\f0e5\";\n$moon-alt-waning-crescent-2: \"\\f0e6\";\n$moon-alt-waning-crescent-3: \"\\f0e7\";\n$moon-alt-waning-crescent-4: \"\\f0e8\";\n$moon-alt-waning-crescent-5: \"\\f0e9\";\n$moon-alt-waning-crescent-6: \"\\f0ea\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-neutral.scss",
    "content": "$cloud: \"\\f041\";\n$cloudy: \"\\f013\";\n$cloudy-gusts: \"\\f011\";\n$cloudy-windy: \"\\f012\";\n$fog: \"\\f014\";\n$hail: \"\\f015\";\n$rain: \"\\f019\";\n$rain-mix: \"\\f017\";\n$rain-wind: \"\\f018\";\n$showers: \"\\f01a\";\n$sleet: \"\\f0b5\";\n$snow: \"\\f01b\";\n$sprinkle: \"\\f01c\";\n$storm-showers: \"\\f01d\";\n$thunderstorm: \"\\f01e\";\n$snow-wind: \"\\f064\";\n$snow: \"\\f01b\";\n$smog: \"\\f074\";\n$smoke: \"\\f062\";\n$lightning: \"\\f016\";\n$raindrops: \"\\f04e\";\n$raindrop: \"\\f078\";\n$dust: \"\\f063\";\n$snowflake-cold: \"\\f076\";\n$windy: \"\\f021\";\n$strong-wind: \"\\f050\";\n$sandstorm: \"\\f082\";\n$earthquake: \"\\f0c6\";\n$fire: \"\\f0c7\";\n$flood: \"\\f07c\";\n$meteor: \"\\f071\";\n$tsunami: \"\\f0c5\";\n$volcano: \"\\f0c8\";\n$hurricane: \"\\f073\";\n$tornado: \"\\f056\";\n$small-craft-advisory: \"\\f0cc\";\n$gale-warning: \"\\f0cd\";\n$storm-warning: \"\\f0ce\";\n$hurricane-warning: \"\\f0cf\";\n$wind-direction: \"\\f0b1\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-night.scss",
    "content": "$night-clear: \"\\f02e\";\n$night-alt-cloudy: \"\\f086\";\n$night-alt-cloudy-gusts: \"\\f022\";\n$night-alt-cloudy-windy: \"\\f023\";\n$night-alt-hail: \"\\f024\";\n$night-alt-lightning: \"\\f025\";\n$night-alt-rain: \"\\f028\";\n$night-alt-rain-mix: \"\\f026\";\n$night-alt-rain-wind: \"\\f027\";\n$night-alt-showers: \"\\f029\";\n$night-alt-sleet: \"\\f0b4\";\n$night-alt-sleet-storm: \"\\f06a\";\n$night-alt-snow: \"\\f02a\";\n$night-alt-snow-thunderstorm: \"\\f06d\";\n$night-alt-snow-wind: \"\\f067\";\n$night-alt-sprinkle: \"\\f02b\";\n$night-alt-storm-showers: \"\\f02c\";\n$night-alt-thunderstorm: \"\\f02d\";\n$night-cloudy: \"\\f031\";\n$night-cloudy-gusts: \"\\f02f\";\n$night-cloudy-windy: \"\\f030\";\n$night-fog: \"\\f04a\";\n$night-hail: \"\\f032\";\n$night-lightning: \"\\f033\";\n$night-partly-cloudy: \"\\f083\";\n$night-rain: \"\\f036\";\n$night-rain-mix: \"\\f034\";\n$night-rain-wind: \"\\f035\";\n$night-showers: \"\\f037\";\n$night-sleet: \"\\f0b3\";\n$night-sleet-storm: \"\\f069\";\n$night-snow: \"\\f038\";\n$night-snow-thunderstorm: \"\\f06c\";\n$night-snow-wind: \"\\f066\";\n$night-sprinkle: \"\\f039\";\n$night-storm-showers: \"\\f03a\";\n$night-thunderstorm: \"\\f03b\";\n$lunar-eclipse: \"\\f070\";\n$stars: \"\\f077\";\n$storm-showers: \"\\f01d\";\n$thunderstorm: \"\\f01e\";\n$night-alt-cloudy-high: \"\\f07e\";\n$night-cloudy-high: \"\\f080\";\n$night-alt-partly-cloudy: \"\\f081\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-time.scss",
    "content": "$time-1: \"\\f08a\";\n$time-2: \"\\f08b\";\n$time-3: \"\\f08c\";\n$time-4: \"\\f08d\";\n$time-5: \"\\f08e\";\n$time-6: \"\\f08f\";\n$time-7: \"\\f090\";\n$time-8: \"\\f091\";\n$time-9: \"\\f092\";\n$time-10: \"\\f093\";\n$time-11: \"\\f094\";\n$time-12: \"\\f089\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/icon-variables/variables-wind-names.scss",
    "content": "$n: \"\\f0b1\";\n$nne: \"\\f0b1\";\n$ne: \"\\f0b1\";\n$ene: \"\\f0b1\";\n$e: \"\\f0b1\";\n$ese: \"\\f0b1\";\n$se: \"\\f0b1\";\n$sse: \"\\f0b1\";\n$s: \"\\f0b1\";\n$ssw: \"\\f0b1\";\n$sw: \"\\f0b1\";\n$wsw: \"\\f0b1\";\n$w: \"\\f0b1\";\n$wnw: \"\\f0b1\";\n$nw: \"\\f0b1\";\n$nnw: \"\\f0b1\";\n$n: \"\\f0b1\";\n$nne: \"\\f0b1\";\n$ne: \"\\f0b1\";\n$ene: \"\\f0b1\";\n$e: \"\\f0b1\";\n$ese: \"\\f0b1\";\n$se: \"\\f0b1\";\n$sse: \"\\f0b1\";\n$s: \"\\f0b1\";\n$ssw: \"\\f0b1\";\n$sw: \"\\f0b1\";\n$wsw: \"\\f0b1\";\n$w: \"\\f0b1\";\n$wnw: \"\\f0b1\";\n$nw: \"\\f0b1\";\n$nnw: \"\\f0b1\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/mappings/wi-forecast-io.scss",
    "content": ".#{$wi-css-prefix}-forecast-io-clear-day:before            { content: $day-sunny     ; }\n.#{$wi-css-prefix}-forecast-io-clear-night:before          { content: $night-clear   ; }\n.#{$wi-css-prefix}-forecast-io-rain:before                 { content: $rain          ; }\n.#{$wi-css-prefix}-forecast-io-snow:before                 { content: $snow          ; }\n.#{$wi-css-prefix}-forecast-io-sleet:before                { content: $sleet         ; }\n.#{$wi-css-prefix}-forecast-io-wind:before                 { content: $strong-wind   ; }\n.#{$wi-css-prefix}-forecast-io-fog:before                  { content: $fog           ; }\n.#{$wi-css-prefix}-forecast-io-cloudy:before               { content: $cloudy        ; }\n.#{$wi-css-prefix}-forecast-io-partly-cloudy-day:before    { content: $day-cloudy    ; }\n.#{$wi-css-prefix}-forecast-io-partly-cloudy-night:before  { content: $night-cloudy  ; }\n.#{$wi-css-prefix}-forecast-io-hail:before                 { content: $hail          ; }\n.#{$wi-css-prefix}-forecast-io-thunderstorm:before         { content: $thunderstorm  ; }\n.#{$wi-css-prefix}-forecast-io-tornado:before              { content: $tornado       ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/mappings/wi-owm.scss",
    "content": "// Neutral\n    .#{$wi-css-prefix}-owm-200:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-201:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-202:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-210:before                            { content: $lightning                   ; }\n    .#{$wi-css-prefix}-owm-211:before                            { content: $lightning                   ; }\n    .#{$wi-css-prefix}-owm-212:before                            { content: $lightning                   ; }\n    .#{$wi-css-prefix}-owm-221:before                            { content: $lightning                   ; }\n    .#{$wi-css-prefix}-owm-230:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-231:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-232:before                            { content: $thunderstorm                ; }\n    .#{$wi-css-prefix}-owm-300:before                            { content: $sprinkle                    ; }\n    .#{$wi-css-prefix}-owm-301:before                            { content: $sprinkle                    ; }\n    .#{$wi-css-prefix}-owm-302:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-310:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-311:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-312:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-313:before                            { content: $showers                     ; }\n    .#{$wi-css-prefix}-owm-314:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-321:before                            { content: $sprinkle                    ; }\n    .#{$wi-css-prefix}-owm-500:before                            { content: $sprinkle                    ; }\n    .#{$wi-css-prefix}-owm-501:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-502:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-503:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-504:before                            { content: $rain                        ; }\n    .#{$wi-css-prefix}-owm-511:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-520:before                            { content: $showers                     ; }\n    .#{$wi-css-prefix}-owm-521:before                            { content: $showers                     ; }\n    .#{$wi-css-prefix}-owm-522:before                            { content: $showers                     ; }\n    .#{$wi-css-prefix}-owm-531:before                            { content: $storm-showers               ; }\n    .#{$wi-css-prefix}-owm-600:before                            { content: $snow                        ; }\n    .#{$wi-css-prefix}-owm-601:before                            { content: $snow                        ; }\n    .#{$wi-css-prefix}-owm-602:before                            { content: $sleet                       ; }\n    .#{$wi-css-prefix}-owm-611:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-612:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-615:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-616:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-620:before                            { content: $rain-mix                    ; }\n    .#{$wi-css-prefix}-owm-621:before                            { content: $snow                        ; }\n    .#{$wi-css-prefix}-owm-622:before                            { content: $snow                        ; }\n    .#{$wi-css-prefix}-owm-701:before                            { content: $showers                     ; }\n    .#{$wi-css-prefix}-owm-711:before                            { content: $smoke                       ; }\n    .#{$wi-css-prefix}-owm-721:before                            { content: $day-haze                    ; }\n    .#{$wi-css-prefix}-owm-731:before                            { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-741:before                            { content: $fog                         ; }\n    .#{$wi-css-prefix}-owm-761:before                            { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-762:before                            { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-771:before                            { content: $cloudy-gusts                ; }\n    .#{$wi-css-prefix}-owm-781:before                            { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-800:before                            { content: $day-sunny                   ; }\n    .#{$wi-css-prefix}-owm-801:before                            { content: $cloudy-gusts                ; }\n    .#{$wi-css-prefix}-owm-802:before                            { content: $cloudy-gusts                ; }\n    .#{$wi-css-prefix}-owm-803:before                            { content: $cloudy-gusts                ; }\n    .#{$wi-css-prefix}-owm-803:before                            { content: $cloudy-windy                ; }\n    .#{$wi-css-prefix}-owm-804:before                            { content: $cloudy                      ; }\n    .#{$wi-css-prefix}-owm-900:before                            { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-901:before                            { content: $storm-showers               ; }\n    .#{$wi-css-prefix}-owm-902:before                            { content: $hurricane                   ; }\n    .#{$wi-css-prefix}-owm-903:before                            { content: $snowflake-cold              ; }\n    .#{$wi-css-prefix}-owm-904:before                            { content: $hot                         ; }\n    .#{$wi-css-prefix}-owm-905:before                            { content: $windy                       ; }\n    .#{$wi-css-prefix}-owm-906:before                            { content: $hail                        ; }\n    .#{$wi-css-prefix}-owm-957:before                            { content: $strong-wind                 ; }\n    //Day\n    .#{$wi-css-prefix}-owm-day-200:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-201:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-202:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-210:before                        { content: $day-lightning               ; }\n    .#{$wi-css-prefix}-owm-day-211:before                        { content: $day-lightning               ; }\n    .#{$wi-css-prefix}-owm-day-212:before                        { content: $day-lightning               ; }\n    .#{$wi-css-prefix}-owm-day-221:before                        { content: $day-lightning               ; }\n    .#{$wi-css-prefix}-owm-day-230:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-231:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-232:before                        { content: $day-thunderstorm            ; }\n    .#{$wi-css-prefix}-owm-day-300:before                        { content: $day-sprinkle                ; }\n    .#{$wi-css-prefix}-owm-day-301:before                        { content: $day-sprinkle                ; }\n    .#{$wi-css-prefix}-owm-day-302:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-310:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-311:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-312:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-313:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-314:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-321:before                        { content: $day-sprinkle                ; }\n    .#{$wi-css-prefix}-owm-day-500:before                        { content: $day-sprinkle                ; }\n    .#{$wi-css-prefix}-owm-day-501:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-502:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-503:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-504:before                        { content: $day-rain                    ; }\n    .#{$wi-css-prefix}-owm-day-511:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-520:before                        { content: $day-showers                 ; }\n    .#{$wi-css-prefix}-owm-day-521:before                        { content: $day-showers                 ; }\n    .#{$wi-css-prefix}-owm-day-522:before                        { content: $day-showers                 ; }\n    .#{$wi-css-prefix}-owm-day-531:before                        { content: $day-storm-showers           ; }\n    .#{$wi-css-prefix}-owm-day-600:before                        { content: $day-snow                    ; }\n    .#{$wi-css-prefix}-owm-day-601:before                        { content: $day-sleet                   ; }\n    .#{$wi-css-prefix}-owm-day-602:before                        { content: $day-snow                    ; }\n    .#{$wi-css-prefix}-owm-day-611:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-612:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-615:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-616:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-620:before                        { content: $day-rain-mix                ; }\n    .#{$wi-css-prefix}-owm-day-621:before                        { content: $day-snow                    ; }\n    .#{$wi-css-prefix}-owm-day-622:before                        { content: $day-snow                    ; }\n    .#{$wi-css-prefix}-owm-day-701:before                        { content: $day-showers                 ; }\n    .#{$wi-css-prefix}-owm-day-711:before                        { content: $smoke                       ; }\n    .#{$wi-css-prefix}-owm-day-721:before                        { content: $day-haze                    ; }\n    .#{$wi-css-prefix}-owm-day-731:before                        { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-day-741:before                        { content: $day-fog                     ; }\n    .#{$wi-css-prefix}-owm-day-761:before                        { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-day-762:before                        { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-day-781:before                        { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-day-800:before                        { content: $day-sunny                   ; }\n    .#{$wi-css-prefix}-owm-day-801:before                        { content: $day-cloudy-gusts            ; }\n    .#{$wi-css-prefix}-owm-day-802:before                        { content: $day-cloudy-gusts            ; }\n    .#{$wi-css-prefix}-owm-day-803:before                        { content: $day-cloudy-gusts            ; }\n    .#{$wi-css-prefix}-owm-day-804:before                        { content: $day-sunny-overcast          ; }\n    .#{$wi-css-prefix}-owm-day-900:before                        { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-day-902:before                        { content: $hurricane                   ; }\n    .#{$wi-css-prefix}-owm-day-903:before                        { content: $snowflake-cold              ; }\n    .#{$wi-css-prefix}-owm-day-904:before                        { content: $hot                         ; }\n    .#{$wi-css-prefix}-owm-day-906:before                        { content: $day-hail                    ; }\n    .#{$wi-css-prefix}-owm-day-957:before                        { content: $strong-wind                 ; }\n    //Night\n    .#{$wi-css-prefix}-owm-night-200:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-201:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-202:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-210:before                      { content: $night-alt-lightning         ; }\n    .#{$wi-css-prefix}-owm-night-211:before                      { content: $night-alt-lightning         ; }\n    .#{$wi-css-prefix}-owm-night-212:before                      { content: $night-alt-lightning         ; }\n    .#{$wi-css-prefix}-owm-night-221:before                      { content: $night-alt-lightning         ; }\n    .#{$wi-css-prefix}-owm-night-230:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-231:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-232:before                      { content: $night-alt-thunderstorm      ; }\n    .#{$wi-css-prefix}-owm-night-300:before                      { content: $night-alt-sprinkle          ; }\n    .#{$wi-css-prefix}-owm-night-301:before                      { content: $night-alt-sprinkle          ; }\n    .#{$wi-css-prefix}-owm-night-302:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-310:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-311:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-312:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-313:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-314:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-321:before                      { content: $night-alt-sprinkle          ; }\n    .#{$wi-css-prefix}-owm-night-500:before                      { content: $night-alt-sprinkle          ; }\n    .#{$wi-css-prefix}-owm-night-501:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-502:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-503:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-504:before                      { content: $night-alt-rain              ; }\n    .#{$wi-css-prefix}-owm-night-511:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-520:before                      { content: $night-alt-showers           ; }\n    .#{$wi-css-prefix}-owm-night-521:before                      { content: $night-alt-showers           ; }\n    .#{$wi-css-prefix}-owm-night-522:before                      { content: $night-alt-showers           ; }\n    .#{$wi-css-prefix}-owm-night-531:before                      { content: $night-alt-storm-showers     ; }\n    .#{$wi-css-prefix}-owm-night-600:before                      { content: $night-alt-snow              ; }\n    .#{$wi-css-prefix}-owm-night-601:before                      { content: $night-alt-sleet             ; }\n    .#{$wi-css-prefix}-owm-night-602:before                      { content: $night-alt-snow              ; }\n    .#{$wi-css-prefix}-owm-night-611:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-612:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-615:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-616:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-620:before                      { content: $night-alt-rain-mix          ; }\n    .#{$wi-css-prefix}-owm-night-621:before                      { content: $night-alt-snow              ; }\n    .#{$wi-css-prefix}-owm-night-622:before                      { content: $night-alt-snow              ; }\n    .#{$wi-css-prefix}-owm-night-701:before                      { content: $night-alt-showers           ; }\n    .#{$wi-css-prefix}-owm-night-711:before                      { content: $smoke                       ; }\n    .#{$wi-css-prefix}-owm-night-721:before                      { content: $day-haze                    ; }\n    .#{$wi-css-prefix}-owm-night-731:before                      { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-night-741:before                      { content: $night-fog                   ; }\n    .#{$wi-css-prefix}-owm-night-761:before                      { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-night-762:before                      { content: $dust                        ; }\n    .#{$wi-css-prefix}-owm-night-781:before                      { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-night-800:before                      { content: $night-clear                 ; }\n    .#{$wi-css-prefix}-owm-night-801:before                      { content: $night-alt-cloudy-gusts      ; }\n    .#{$wi-css-prefix}-owm-night-802:before                      { content: $night-alt-cloudy-gusts      ; }\n    .#{$wi-css-prefix}-owm-night-803:before                      { content: $night-alt-cloudy-gusts      ; }\n    .#{$wi-css-prefix}-owm-night-804:before                      { content: $night-alt-cloudy            ; }\n    .#{$wi-css-prefix}-owm-night-900:before                      { content: $tornado                     ; }\n    .#{$wi-css-prefix}-owm-night-902:before                      { content: $hurricane                   ; }\n    .#{$wi-css-prefix}-owm-night-903:before                      { content: $snowflake-cold              ; }\n    .#{$wi-css-prefix}-owm-night-904:before                      { content: $hot                         ; }\n    .#{$wi-css-prefix}-owm-night-906:before                      { content: $night-alt-hail              ; }\n    .#{$wi-css-prefix}-owm-night-957:before                      { content: $strong-wind                 ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/mappings/wi-wmo4680.scss",
    "content": ".#{$wi-css-prefix}-wmo4680-0:before,\n.#{$wi-css-prefix}-wmo4680-00:before       { content: $thermometer           ; }\n.#{$wi-css-prefix}-wmo4680-1:before,\n.#{$wi-css-prefix}-wmo4680-01:before       { content: $cloudy                ; }\n.#{$wi-css-prefix}-wmo4680-2:before,\n.#{$wi-css-prefix}-wmo4680-02:before       { content: $thermometer           ; }\n.#{$wi-css-prefix}-wmo4680-3:before,\n.#{$wi-css-prefix}-wmo4680-03:before       { content: $cloudy                ; }\n.#{$wi-css-prefix}-wmo4680-4:before,\n.#{$wi-css-prefix}-wmo4680-04:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-5:before,\n.#{$wi-css-prefix}-wmo4680-05:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-10:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-11:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-12:before       { content: $lightning             ; }\n.#{$wi-css-prefix}-wmo4680-18:before       { content: $strong-wind           ; }\n.#{$wi-css-prefix}-wmo4680-20:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-21:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-22:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-23:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-24:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-25:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-26:before       { content: $thunderstorm          ; }\n.#{$wi-css-prefix}-wmo4680-27:before       { content: $dust                  ; }\n.#{$wi-css-prefix}-wmo4680-28:before       { content: $dust                  ; }\n.#{$wi-css-prefix}-wmo4680-29:before       { content: $dust                  ; }\n.#{$wi-css-prefix}-wmo4680-30:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-31:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-32:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-33:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-34:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-35:before       { content: $fog                   ; }\n.#{$wi-css-prefix}-wmo4680-40:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-41:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-42:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-43:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-44:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-45:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-46:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-47:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-48:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-50:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-51:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-52:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-53:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-54:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-55:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-56:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-57:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-58:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-60:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-61:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-62:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-63:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-64:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-65:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-66:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-67:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-68:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-70:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-71:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-72:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-73:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-74:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-75:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-76:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-77:before       { content: $snow                  ; }\n.#{$wi-css-prefix}-wmo4680-78:before       { content: $snowflake-cold        ; }\n.#{$wi-css-prefix}-wmo4680-80:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-81:before       { content: $sprinkle              ; }\n.#{$wi-css-prefix}-wmo4680-82:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-83:before       { content: $rain                  ; }\n.#{$wi-css-prefix}-wmo4680-84:before       { content: $storm-showers         ; }\n.#{$wi-css-prefix}-wmo4680-85:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-86:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-87:before       { content: $rain-mix              ; }\n.#{$wi-css-prefix}-wmo4680-89:before       { content: $hail                  ; }\n.#{$wi-css-prefix}-wmo4680-90:before       { content: $lightning             ; }\n.#{$wi-css-prefix}-wmo4680-91:before       { content: $storm-showers         ; }\n.#{$wi-css-prefix}-wmo4680-92:before       { content: $thunderstorm          ; }\n.#{$wi-css-prefix}-wmo4680-93:before       { content: $thunderstorm          ; }\n.#{$wi-css-prefix}-wmo4680-94:before       { content: $lightning             ; }\n.#{$wi-css-prefix}-wmo4680-95:before       { content: $thunderstorm          ; }\n.#{$wi-css-prefix}-wmo4680-96:before       { content: $thunderstorm          ; }\n.#{$wi-css-prefix}-wmo4680-99:before       { content: $tornado               ; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/mappings/wi-yahoo.scss",
    "content": ".#{$wi-css-prefix}-yahoo-0:before { content: $tornado; }\n.#{$wi-css-prefix}-yahoo-1:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-2:before { content: $hurricane; }\n.#{$wi-css-prefix}-yahoo-3:before { content: $thunderstorm; }\n.#{$wi-css-prefix}-yahoo-4:before { content: $thunderstorm; }\n.#{$wi-css-prefix}-yahoo-5:before { content: $rain-mix; }\n.#{$wi-css-prefix}-yahoo-6:before { content: $rain-mix; }\n.#{$wi-css-prefix}-yahoo-7:before { content: $rain-mix; }\n.#{$wi-css-prefix}-yahoo-8:before { content: $hail; }\n.#{$wi-css-prefix}-yahoo-9:before { content: $showers; }\n.#{$wi-css-prefix}-yahoo-10:before { content: $hail; }\n.#{$wi-css-prefix}-yahoo-11:before { content: $showers; }\n.#{$wi-css-prefix}-yahoo-12:before { content: $showers; }\n.#{$wi-css-prefix}-yahoo-13:before { content: $snow; }\n.#{$wi-css-prefix}-yahoo-14:before { content: $day-snow; }\n.#{$wi-css-prefix}-yahoo-15:before { content: $snow-wind; }\n.#{$wi-css-prefix}-yahoo-16:before { content: $snow; }\n.#{$wi-css-prefix}-yahoo-17:before { content: $hail; }\n.#{$wi-css-prefix}-yahoo-18:before { content: $rain-mix; }\n.#{$wi-css-prefix}-yahoo-19:before { content: $dust; }\n.#{$wi-css-prefix}-yahoo-20:before { content: $fog; }\n.#{$wi-css-prefix}-yahoo-21:before { content: $windy; }\n.#{$wi-css-prefix}-yahoo-22:before { content: $smoke; }\n.#{$wi-css-prefix}-yahoo-23:before { content: $strong-wind; }\n.#{$wi-css-prefix}-yahoo-24:before { content: $strong-wind; }\n.#{$wi-css-prefix}-yahoo-25:before { content: $snowflake-cold; }\n.#{$wi-css-prefix}-yahoo-26:before { content: $cloudy; }\n.#{$wi-css-prefix}-yahoo-27:before { content: $night-cloudy; }\n.#{$wi-css-prefix}-yahoo-28:before { content: $day-cloudy; }\n.#{$wi-css-prefix}-yahoo-29:before { content: $night-cloudy; }\n.#{$wi-css-prefix}-yahoo-30:before { content: $day-cloudy; }\n.#{$wi-css-prefix}-yahoo-31:before { content: $night-clear; }\n.#{$wi-css-prefix}-yahoo-32:before { content: $day-sunny; }\n.#{$wi-css-prefix}-yahoo-33:before { content: $night-partly-cloudy; }\n.#{$wi-css-prefix}-yahoo-34:before { content: $day-sunny-overcast; }\n.#{$wi-css-prefix}-yahoo-35:before { content: $rain-mix; }\n.#{$wi-css-prefix}-yahoo-36:before { content: $hot; }\n.#{$wi-css-prefix}-yahoo-37:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-38:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-39:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-40:before { content: $showers; }\n.#{$wi-css-prefix}-yahoo-41:before { content: $snow-wind; }\n.#{$wi-css-prefix}-yahoo-42:before { content: $snow; }\n.#{$wi-css-prefix}-yahoo-43:before { content: $snow-wind; }\n.#{$wi-css-prefix}-yahoo-44:before { content: $day-sunny-overcast; }\n.#{$wi-css-prefix}-yahoo-45:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-46:before { content: $snow; }\n.#{$wi-css-prefix}-yahoo-47:before { content: $day-storm-showers; }\n.#{$wi-css-prefix}-yahoo-3200:before { content: $stars; }"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons-classes.scss",
    "content": "@import \"icon-classes/classes-day.scss\";\n@import \"icon-classes/classes-night.scss\";\n@import \"icon-classes/classes-neutral.scss\";\n@import \"icon-classes/classes-misc.scss\";\n@import \"icon-classes/classes-moon.scss\";\n@import \"icon-classes/classes-moon-aliases.scss\";\n@import \"icon-classes/classes-time.scss\";\n@import \"icon-classes/classes-direction.scss\";\n@import \"icon-classes/classes-beaufort.scss\";\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons-core.scss",
    "content": "// Base Variables\n$wi-path:                        \"../font\" !default;\n$wi-version:                     \"2.0\" !default;\n$wi-css-prefix:                  wi !default;\n$wi-font-family:                 weathericons !default;\n\n@font-face {\n    font-family: '#{$wi-font-family}';\n    src: url('#{$wi-path}/#{$wi-font-family}-regular-webfont.eot');\n    src: url('#{$wi-path}/#{$wi-font-family}-regular-webfont.eot?#iefix') format('embedded-opentype'),\n         url('#{$wi-path}/#{$wi-font-family}-regular-webfont.woff2') format('woff2'),\n         url('#{$wi-path}/#{$wi-font-family}-regular-webfont.woff') format('woff'),\n         url('#{$wi-path}/#{$wi-font-family}-regular-webfont.ttf') format('truetype'),\n         url('#{$wi-path}/#{$wi-font-family}-regular-webfont.svg#weather_iconsregular') format('svg');\n    font-weight: normal;\n    font-style: normal;\n}\n\n.#{$wi-css-prefix} {\n  display: inline-block;\n  font-family: '#{$wi-font-family}';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.#{$wi-css-prefix}-fw {\n  width: 1.4em;\n  text-align: center;\n}\n\n@mixin wi-icon-rotate($degrees, $rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});\n  -webkit-transform: rotate($degrees);\n      -ms-transform: rotate($degrees);\n          transform: rotate($degrees);\n}\n\n@mixin wi-icon-flip($horiz, $vert, $rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation});\n  -webkit-transform: scale($horiz, $vert);\n      -ms-transform: scale($horiz, $vert);\n          transform: scale($horiz, $vert);\n}\n\n.#{$wi-css-prefix}-rotate-90  { @include wi-icon-rotate(90deg, 1);  }\n.#{$wi-css-prefix}-rotate-180 { @include wi-icon-rotate(180deg, 2); }\n.#{$wi-css-prefix}-rotate-270 { @include wi-icon-rotate(270deg, 3); }\n\n.#{$wi-css-prefix}-flip-horizontal { @include wi-icon-flip(-1, 1, 0); }\n.#{$wi-css-prefix}-flip-vertical   { @include wi-icon-flip(1, -1, 2); }\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons-variables.scss",
    "content": "@import 'icon-variables/variables-beaufort.scss';\n@import 'icon-variables/variables-time.scss';\n@import 'icon-variables/variables-moon.scss';\n@import 'icon-variables/variables-direction.scss';\n@import 'icon-variables/variables-day.scss';\n@import 'icon-variables/variables-night.scss';\n@import 'icon-variables/variables-neutral.scss';\n@import 'icon-variables/variables-misc.scss';\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons-wind.min.scss",
    "content": "@import \"weather-icons-core.scss\";\n@import \"icon-variables/variables-wind-names.scss\";\n@import \"icon-classes/classes-wind.scss\";\n@import \"icon-classes/classes-wind-degrees.scss\";\n@import \"icon-classes/classes-wind-aliases.scss\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons-wind.scss",
    "content": "@import \"weather-icons-core.scss\";\n@import \"icon-variables/variables-wind-names.scss\";\n@import \"icon-classes/classes-wind.scss\";\n@import \"icon-classes/classes-wind-degrees.scss\";\n@import \"icon-classes/classes-wind-aliases.scss\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons.min.scss",
    "content": "/*!\n *  Weather Icons 2.0\n *  Updated August 1, 2015\n *  Weather themed icons for Bootstrap\n *  Author - Erik Flowers - erik@helloerik.com\n *  Email: erik@helloerik.com\n *  Twitter: http://twitter.com/Erik_UX\n *  ------------------------------------------------------------------------------\n *  Maintained at http://erikflowers.github.io/weather-icons\n *\n *  License\n *  ------------------------------------------------------------------------------\n *  - Font licensed under SIL OFL 1.1 -\n *    http://scripts.sil.org/OFL\n *  - CSS, SCSS and LESS are licensed under MIT License -\n *    http://opensource.org/licenses/mit-license.html\n *  - Documentation licensed under CC BY 3.0 -\n *    http://creativecommons.org/licenses/by/3.0/\n *  - Inspired by and works great as a companion with Font Awesome\n *    \"Font Awesome by Dave Gandy - http://fontawesome.io\"\n */\n\n@import 'weather-icons-core.scss';\n@import 'weather-icons-variables.scss';\n@import 'weather-icons-classes.scss';\n// Mappings to various APIs\n@import \"mappings/wi-yahoo.scss\";\n@import \"mappings/wi-forecast-io.scss\";\n@import \"mappings/wi-wmo4680.scss\";\n@import \"mappings/wi-owm.scss\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/icons/weather-icons/sass/weather-icons.scss",
    "content": "/*!\n *  Weather Icons 2.0\n *  Updated August 1, 2015\n *  Weather themed icons for Bootstrap\n *  Author - Erik Flowers - erik@helloerik.com\n *  Email: erik@helloerik.com\n *  Twitter: http://twitter.com/Erik_UX\n *  ------------------------------------------------------------------------------\n *  Maintained at http://erikflowers.github.io/weather-icons\n *\n *  License\n *  ------------------------------------------------------------------------------\n *  - Font licensed under SIL OFL 1.1 -\n *    http://scripts.sil.org/OFL\n *  - CSS, LESS and SCSS are licensed under MIT License -\n *    http://opensource.org/licenses/mit-license.html\n *  - Documentation licensed under CC BY 3.0 -\n *    http://creativecommons.org/licenses/by/3.0/\n *  - Inspired by and works great as a companion with Font Awesome\n *    \"Font Awesome by Dave Gandy - http://fontawesome.io\"\n */\n\n@import 'weather-icons-core.scss';\n@import 'weather-icons-variables.scss';\n@import 'weather-icons-classes.scss';\n// Mappings to various APIs\n@import \"mappings/wi-yahoo.scss\";\n@import \"mappings/wi-forecast-io.scss\";\n@import \"mappings/wi-wmo4680.scss\";\n@import \"mappings/wi-owm.scss\";"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/material.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n@import 'variable';\n\n$btn-box-shadow:0 3px 4px 1px rgba(0,0,0,.1);\n$btn-box-shadow-hover:0 1px 4px 0 rgba(0,0,0,.2);\n$box-shadow:0 1px 4px 0 rgba(0,0,0,.1);\n$text-shadow:rgba(0,0,0,.15) 0 0 1px;\n$colors: ( red: #fb3a3a, pink: #E91E63, purple: #7460ee, deep-purple: #673AB7, indigo: #3F51B5, blue: #02bec9, light-blue: #03A9F4, cyan: #00BCD4, teal: #009688, green: #26c6da, light-green: #8BC34A, lime: #CDDC39, yellow: #ffe821, amber: #FFC107, orange: #FF9800, deep-orange: #FF5722, brown: #795548, grey: #9E9E9E, blue-grey: #607D8B, black: #000000, white: #ffffff ) !default;\n\n\n/* Radio Buttons\n   ========================================================================== */\n[type=\"radio\"]:not(:checked),\n[type=\"radio\"]:checked {\n  position: absolute;\n  left: -9999px;\n  opacity: 0;\n}\n\n[type=\"radio\"]:not(:checked) + label,\n[type=\"radio\"]:checked + label {\n  position: relative;\n  padding-left: 35px;\n  cursor: pointer;\n  display: inline-block;\n  height: 25px;\n  line-height: 25px;\n  font-size: 1rem;\n  transition: .28s ease;\n  /* webkit (konqueror) browsers */\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n}\n\n[type=\"radio\"] + label:before,\n[type=\"radio\"] + label:after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 4px;\n  width: 16px;\n  height: 16px;\n  z-index: 0;\n  transition: .28s ease;\n}\n\n/* Unchecked styles */\n[type=\"radio\"]:not(:checked) + label:before,\n[type=\"radio\"]:not(:checked) + label:after,\n[type=\"radio\"]:checked + label:before,\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:before,\n[type=\"radio\"].with-gap:checked + label:after {\n  border-radius: 50%;\n}\n\n[type=\"radio\"]:not(:checked) + label:before,\n[type=\"radio\"]:not(:checked) + label:after {\n  border: 2px solid #5a5a5a;\n}\n\n[type=\"radio\"]:not(:checked) + label:after {\n  z-index: -1;\n  -webkit-transform: scale(0);\n          transform: scale(0);\n}\n\n/* Checked styles */\n[type=\"radio\"]:checked + label:before {\n  border: 2px solid transparent;\n    animation: ripple 0.2s linear forwards;\n}\n\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:before,\n[type=\"radio\"].with-gap:checked + label:after {\n  border: 2px solid #26a69a;\n}\n\n[type=\"radio\"]:checked + label:after,\n[type=\"radio\"].with-gap:checked + label:after {\n  background-color: #26a69a;\n  z-index: 0;\n}\n\n[type=\"radio\"]:checked + label:after {\n  -webkit-transform: scale(1.02);\n          transform: scale(1.02);\n}\n\n/* Radio With gap */\n[type=\"radio\"].with-gap:checked + label:after {\n  -webkit-transform: scale(0.5);\n          transform: scale(0.5);\n}\n\n/* Focused styles */\n[type=\"radio\"].tabbed:focus + label:before {\n  box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n animation: ripple 0.2s linear forwards;    \n}\n\n/* Disabled Radio With gap */\n[type=\"radio\"].with-gap:disabled:checked + label:before {\n  border: 2px solid rgba(0, 0, 0, 0.26);\n    animation: ripple 0.2s linear forwards;\n}\n\n[type=\"radio\"].with-gap:disabled:checked + label:after {\n  border: none;\n  background-color: rgba(0, 0, 0, 0.26);\n}\n\n/* Disabled style */\n[type=\"radio\"]:disabled:not(:checked) + label:before,\n[type=\"radio\"]:disabled:checked + label:before {\n  background-color: transparent;\n  border-color: rgba(0, 0, 0, 0.26);\n animation: ripple 0.2s linear forwards;    \n}\n\n[type=\"radio\"]:disabled + label {\n  color: rgba(0, 0, 0, 0.26);\n}\n\n[type=\"radio\"]:disabled:not(:checked) + label:before {\n  border-color: rgba(0, 0, 0, 0.26);\n}\n\n[type=\"radio\"]:disabled:checked + label:after {\n  background-color: rgba(0, 0, 0, 0.26);\n  border-color: #BDBDBD;\n}\n\n/* Checkboxes\n   ========================================================================== */\n/* CUSTOM CSS CHECKBOXES */\nform p {\n  margin-bottom: 10px;\n  text-align: left;\n}\n\nform p:last-child {\n  margin-bottom: 0;\n}\n\n/* Remove default checkbox */\n[type=\"checkbox\"]:not(:checked),\n[type=\"checkbox\"]:checked {\n  position: absolute;\n  left: -9999px;\n  opacity: 0;\n}\n\n[type=\"checkbox\"] {\n  /* checkbox aspect */\n}\n\n[type=\"checkbox\"] + label {\n  position: relative;\n  padding-left: 35px;\n  cursor: pointer;\n  display: inline-block;\n  height: 25px;\n  line-height: 25px;\n  font-size: 1rem;\n  -webkit-user-select: none;\n  /* webkit (safari, chrome) browsers */\n  -moz-user-select: none;\n  /* mozilla browsers */\n  -khtml-user-select: none;\n  /* webkit (konqueror) browsers */\n  -ms-user-select: none;\n  /* IE10+ */\n}\n\n[type=\"checkbox\"] + label:before,\n[type=\"checkbox\"]:not(.filled-in) + label:after {\n  content: '';\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 18px;\n  height: 18px;\n  z-index: 0;\n  border: 2px solid #5a5a5a;\n  border-radius: 1px;\n  margin-top: 2px;\n  transition: .2s;\n}\n\n[type=\"checkbox\"]:not(.filled-in) + label:after {\n  border: 0;\n  -webkit-transform: scale(0);\n          transform: scale(0);\n}\n\n[type=\"checkbox\"]:not(:checked):disabled + label:before {\n  border: none;\n  background-color: rgba(0, 0, 0, 0.26);\n}\n\n[type=\"checkbox\"].tabbed:focus + label:after {\n  -webkit-transform: scale(1);\n          transform: scale(1);\n  border: 0;\n  border-radius: 50%;\n  box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n  background-color: rgba(0, 0, 0, 0.1);\n}\n\n[type=\"checkbox\"]:checked + label:before {\n  top: -4px;\n  left: -5px;\n  width: 12px;\n  height: 22px;\n  border-top: 2px solid transparent;\n  border-left: 2px solid transparent;\n  border-right: 2px solid #26a69a;\n  border-bottom: 2px solid #26a69a;\n  -webkit-transform: rotate(40deg);\n          transform: rotate(40deg);\n  -webkit-backface-visibility: hidden;\n          backface-visibility: hidden;\n  -webkit-transform-origin: 100% 100%;\n          transform-origin: 100% 100%;\n}\n\n[type=\"checkbox\"]:checked:disabled + label:before {\n  border-right: 2px solid rgba(0, 0, 0, 0.26);\n  border-bottom: 2px solid rgba(0, 0, 0, 0.26);\n}\n\n/* Indeterminate checkbox */\n[type=\"checkbox\"]:indeterminate + label:before {\n  top: -11px;\n  left: -12px;\n  width: 10px;\n  height: 22px;\n  border-top: none;\n  border-left: none;\n  border-right: 2px solid #26a69a;\n  border-bottom: none;\n  -webkit-transform: rotate(90deg);\n          transform: rotate(90deg);\n  -webkit-backface-visibility: hidden;\n          backface-visibility: hidden;\n  -webkit-transform-origin: 100% 100%;\n          transform-origin: 100% 100%;\n}\n\n[type=\"checkbox\"]:indeterminate:disabled + label:before {\n  border-right: 2px solid rgba(0, 0, 0, 0.26);\n  background-color: transparent;\n}\n\n[type=\"checkbox\"].filled-in + label:after {\n  border-radius: 2px;\n}\n\n[type=\"checkbox\"].filled-in + label:before,\n[type=\"checkbox\"].filled-in + label:after {\n  content: '';\n  left: 0;\n  position: absolute;\n  /* .1s delay is for check animation */\n  transition: border .25s, background-color .25s, width .20s .1s, height .20s .1s, top .20s .1s, left .20s .1s;\n  z-index: 1;\n}\n\n[type=\"checkbox\"].filled-in:not(:checked) + label:before {\n  width: 0;\n  height: 0;\n  border: 3px solid transparent;\n  left: 6px;\n  top: 10px;\n  -webkit-transform: rotateZ(37deg);\n  transform: rotateZ(37deg);\n  -webkit-transform-origin: 20% 40%;\n  transform-origin: 100% 100%;\n}\n\n[type=\"checkbox\"].filled-in:not(:checked) + label:after {\n  height: 20px;\n  width: 20px;\n  background-color: transparent;\n  border: 2px solid #5a5a5a;\n  top: 0px;\n  z-index: 0;\n}\n\n[type=\"checkbox\"].filled-in:checked + label:before {\n  top: 0;\n  left: 1px;\n  width: 8px;\n  height: 13px;\n  border-top: 2px solid transparent;\n  border-left: 2px solid transparent;\n  border-right: 2px solid #fff;\n  border-bottom: 2px solid #fff;\n  -webkit-transform: rotateZ(37deg);\n  transform: rotateZ(37deg);\n  -webkit-transform-origin: 100% 100%;\n  transform-origin: 100% 100%;\n}\n\n[type=\"checkbox\"].filled-in:checked + label:after {\n  top: 0;\n  width: 20px;\n  height: 20px;\n  border: 2px solid #26a69a;\n  background-color: #26a69a;\n  z-index: 0;\n}\n\n[type=\"checkbox\"].filled-in.tabbed:focus + label:after {\n  border-radius: 2px;\n  border-color: #5a5a5a;\n  background-color: rgba(0, 0, 0, 0.1);\n}\n\n[type=\"checkbox\"].filled-in.tabbed:checked:focus + label:after {\n  border-radius: 2px;\n  background-color: #26a69a;\n  border-color: #26a69a;\n}\n\n[type=\"checkbox\"].filled-in:disabled:not(:checked) + label:before {\n  background-color: transparent;\n  border: 2px solid transparent;\n}\n\n[type=\"checkbox\"].filled-in:disabled:not(:checked) + label:after {\n  border-color: transparent;\n  background-color: #BDBDBD;\n}\n\n[type=\"checkbox\"].filled-in:disabled:checked + label:before {\n  background-color: transparent;\n}\n\n[type=\"checkbox\"].filled-in:disabled:checked + label:after {\n  background-color: #BDBDBD;\n  border-color: #BDBDBD;\n}\n\n/* Switch\n   ========================================================================== */\n.switch,\n.switch * {\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -khtml-user-select: none;\n  -ms-user-select: none;\n}\n\n.switch label {\n  cursor: pointer;\n}\n\n.switch label input[type=checkbox] {\n  opacity: 0;\n  width: 0;\n  height: 0;\n}\n\n.switch label input[type=checkbox]:checked + .lever {\n  background-color: #84c7c1;\n}\n\n.switch label input[type=checkbox]:checked + .lever:after {\n  background-color: #26a69a;\n  left: 24px;\n}\n\n.switch label .lever {\n  content: \"\";\n  display: inline-block;\n  position: relative;\n  width: 40px;\n  height: 15px;\n  background-color: #818181;\n  border-radius: 15px;\n  margin-right: 10px;\n  transition: background 0.3s ease;\n  vertical-align: middle;\n  margin: 0 16px;\n}\n\n.switch label .lever:after {\n  content: \"\";\n  position: absolute;\n  display: inline-block;\n  width: 21px;\n  height: 21px;\n  background-color: #F1F1F1;\n  border-radius: 21px;\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4);\n  left: -5px;\n  top: -3px;\n  transition: left 0.3s ease, background .3s ease, box-shadow 0.1s ease;\n}\n\ninput[type=checkbox]:checked:not(:disabled) ~ .lever:active::after,\ninput[type=checkbox]:checked:not(:disabled).tabbed:focus ~ .lever::after {\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(38, 166, 154, 0.1);\n}\n\ninput[type=checkbox]:not(:disabled) ~ .lever:active:after,\ninput[type=checkbox]:not(:disabled).tabbed:focus ~ .lever::after {\n  box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba(0, 0, 0, 0.08);\n}\n\n.switch input[type=checkbox][disabled] + .lever {\n  cursor: default;\n}\n\n.switch label input[type=checkbox][disabled] + .lever:after,\n.switch label input[type=checkbox][disabled]:checked + .lever:after {\n  background-color: #BDBDBD;\n}\n\n\n\n.scale-up{ \n    -webkit-transition: all 0.3s ease;\n    transition: all 0.3s ease;\n    -webkit-transform: scale(0);\n    transform: scale(0);\n    display:inline-block;\n    transform-origin: right 0px;\n}\n.scale-up-left{ \n    -webkit-transition: all 0.3s ease;\n    transition: all 0.3s ease;\n    -webkit-transform: scale(0);\n    transform: scale(0);\n    display:inline-block;\n    transform-origin: left 0px;\n}\n.show>.scale-up{\n  transform: scale(1);\n  transform-origin: right 0px;\n}\n.show>.scale-up-left{\n    transform: scale(1);\n  transform-origin: left 0px;\n}\n/*panels*/\n.card{\n   box-shadow:$box-shadow; \n   border-radius:$radius;  \n}\n\n.well, pre{\n  box-shadow:$box-shadow;\n}\n\n.page-titles .justify-content-end:last-child .d-flex{\n  margin-right:10px;\n}\n.btn-circle.right-side-toggle{\n  position:fixed;\n  bottom:20px;\n  right:20px;\n  padding:25px;\n}\n\n\n\n/*Radio button*/\n@keyframes ripple {\n  0% {\n    box-shadow: 0px 0px 0px 1px transparent;\n  }\n  50% {\n    box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0.1);\n  }\n  100% {\n    box-shadow: 0px 0px 0px 15px transparent;\n  }\n}\n\n\n/*Bootstrap Select*/\n.bootstrap-select.btn-group .dropdown-menu{\n    margin-top: -40px;\n    box-shadow: $box-shadow;\n}\n\n.demo-checkbox label, .demo-radio-button label{\n    min-width:200px;\n    margin-bottom: 20px;\n}\n.demo-swtich .demo-switch-title, .demo-swtich .switch{\n    width: 150px;\n    margin-bottom: 10px;\n    display: inline-block;\n}\n[type=\"checkbox\"] {\n    + label {\n        padding-left: 26px;\n        height: 25px;\n        line-height: 21px;\n        \n        font-weight: normal;\n    }\n\n    &:checked {\n        + label {\n            &:before {\n                top: -4px;\n                left: -2px;\n                width: 11px;\n                height: 19px;\n                \n            }\n        }\n    }\n\n    @each $key, $val in $colors {\n        &:checked.chk-col-#{$key} {\n            + label {\n                &:before {\n                    border-right: 2px solid $val;\n                    border-bottom: 2px solid $val;\n                }\n            }\n        }\n    }\n}\n\n[type=\"checkbox\"].filled-in {\n    &:checked {\n        + label {\n            &:after {\n                top: 0;\n                width: 20px;\n                height: 20px;\n                border: 2px solid #26a69a;\n                background-color: #26a69a;\n                z-index: 0;\n            }\n\n            &:before {\n                border-right: 2px solid #fff !important;\n                border-bottom: 2px solid #fff !important;\n            }\n        }\n    }\n\n    @each $key, $val in $colors {\n        &:checked.chk-col-#{$key} {\n            + label {\n                &:after {\n                    border: 2px solid $val;\n                    background-color: $val;\n                    \n                }\n            }\n        }\n    }\n}\n\n[type=\"radio\"] {\n    &:not(:checked) {\n        + label {\n            padding-left: 26px;\n            height: 25px;\n            line-height: 25px;\n            \n            font-weight: normal;\n        }\n    }\n\n    &:checked {\n        + label {\n            padding-left: 26px;\n            height: 25px;\n            line-height: 25px;\n            \n            font-weight: normal;\n            \n        }\n    }\n}\n\n@each $key, $val in $colors {\n    [type=\"radio\"].radio-col-#{$key} {\n        &:checked {\n            + label {\n                &:after {\n                    background-color: $val;\n                    border-color: $val;\n                    animation: ripple 0.2s linear forwards;\n                }\n            }\n        }\n    }\n}\n\n\n@each $key, $val in $colors {\n    [type=\"radio\"].with-gap.radio-col-#{$key} {\n        &:checked {\n            + label {\n                &:before {\n                    border: 2px solid $val;\n                    animation: ripple 0.2s linear forwards;\n                }\n\n                &:after {\n                    background-color: $val;\n                    border: 2px solid $val;\n                    animation: ripple 0.2s linear forwards;\n                }\n            }\n        }\n    }\n}\n\n.switch {\n    label {\n        font-weight: normal;\n        font-size: 13px;\n\n        .lever {\n            margin: 0 14px;\n        }\n\n        input[type=checkbox] {\n            &:checked {\n                @each $key, $val in $colors {\n                    &:not(:disabled) {\n                        ~ .lever.switch-col-#{$key} {\n                            &:active {\n                                &:after {\n                                    box-shadow: 0 1px 3px 1px rgba(0, 0, 0, 0.4), 0 0 0 15px rgba($val, 0.1);\n                                }\n                            }\n                        }\n                    }\n\n                    + .lever.switch-col-#{$key} {\n                        background-color: rgba($val, 0.5);\n\n                        &:after {\n                            background-color: $val;\n                        }\n                    }\n                }\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/pages.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n\n\n/*============================================================== \n For all pages \n ============================================================== */\n\n#main-wrapper {\n    width: 100%;\n}\n\n.boxed #main-wrapper {\n    width: 100%;\n    max-width: 1300px;\n    margin: 0 auto;\n    box-shadow: 0 0 60px rgba(0, 0, 0, 0.1);\n    .sidebar-footer {\n        position: absolute;\n    }\n    .footer {\n        display: none;\n    }\n}\n\n.page-wrapper {\n    background: $bodycolor;\n    padding-bottom: 60px;\n}\n\n.container-fluid {\n    padding: 0 30px 25px 30px;\n}\n\n\n/*******************\n Topbar\n*******************/\n\n.topbar {\n    position: relative;\n    z-index: 50;\n    box-shadow: 5px 0px 10px rgba(0, 0, 0, 0.5);\n    .top-navbar {\n        min-height: 70px;\n        padding: 0px 15px 0 0;\n        .dropdown-toggle::after {\n            display: none;\n        }\n        .navbar-header {\n            line-height: 65px;\n            text-align: center;\n            .navbar-brand {\n                margin-right: 0px;\n                padding-bottom: 0px;\n                padding-top: 0px;\n                .light-logo {\n                    display: none;\n                }\n                b {\n                    line-height: 70px;\n                    display: inline-block;\n                }\n            }\n        }\n        .navbar-nav > .nav-item > .nav-link {\n            padding-left: .75rem;\n            padding-right: .75rem;\n            font-size: 19px;\n            line-height: 50px;\n        }\n        .navbar-nav > .nav-item.show {\n            background: $dark-transparent;\n        }\n    }\n    .profile-pic {\n        width: 30px;\n        border-radius: 100%;\n    }\n    .dropdown-menu {\n        box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n        -webkit-box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n        -moz-box-shadow: 0 3px 12px rgba(0, 0, 0, 0.05);\n        border-color: $border;\n        .dropdown-item {\n            padding: 7px 1.5rem;\n        }\n    }\n    ul.dropdown-user {\n        padding: 0px;\n        width: 270px;\n        li {\n            list-style: none;\n            padding: 0px;\n            margin: 0px;\n            &.divider {\n                height: 1px;\n                margin: 9px 0;\n                overflow: hidden;\n                background-color: $border;\n            }\n            .dw-user-box {\n                padding: 10px 15px;\n                .u-img {\n                    width: 80px;\n                    display: inline-block;\n                    vertical-align: top;\n                    img {\n                        width: 100%;\n                        border-radius: 5px;\n                    }\n                }\n                .u-text {\n                    display: inline-block;\n                    padding-left: 10px;\n                    h4 {\n                        margin: 0px;\n                    }\n                    p {\n                        margin-bottom: 2px;\n                        font-size: 14px;\n                    }\n                    .btn {\n                        color: $white;\n                        padding: 5px 10px;\n                        display: inline-block;\n                        &:hover {\n                            background: $danger-dark;\n                        }\n                    }\n                }\n            }\n            a {\n                padding: 9px 15px;\n                display: block;\n                color: $bodytext;\n                &:hover {\n                    background: $light;\n                    color: $themecolor;\n                    text-decoration: none;\n                }\n            }\n        }\n    }\n}\n\n.search-box {\n    .app-search {\n        position: absolute;\n        margin: 0px;\n        display: block;\n        z-index: 110;\n        width: 100%;\n        top: -1px;\n        box-shadow: 2px 0px 10px rgba(0, 0, 0, 0.2);\n        display: none;\n        left: 0px;\n        input {\n            width: 100%;\n            padding: 25px 40px 25px 20px;\n            border-radius: 0px;\n            font-size: 17px;\n            transition: 0.5s ease-in;\n        }\n        .srh-btn {\n            position: absolute;\n            top: 23px;\n            cursor: pointer;\n            background: $white;\n            width: 15px;\n            height: 15px;\n            right: 20px;\n            font-size: 14px;\n        }\n    }\n}\n\n.mini-sidebar .top-navbar {\n    .navbar-header {\n        width: 60px;\n        text-align: center;\n    }\n}\n\n.logo-center {\n    .top-navbar {\n        .navbar-header {\n            position: absolute;\n            left: 0;\n            right: 0;\n            margin: 0 auto;\n        }\n    }\n}\n\n\n/*******************\n Breadcrumb and page title\n*******************/\n\n.page-titles {\n    background: $white;\n    margin: 0 -30px 30px;\n    padding: 15px;\n    box-shadow: 1px 0 5px rgba(0, 0, 0, 0.1);\n    h3 {\n        margin-bottom: 0px;\n        margin-top: 8px;\n    }\n    .breadcrumb {\n        padding: 0px;\n        background: transparent;\n        font-size: 14px;\n        li {\n            margin-top: 0px;\n            margin-bottom: 0px;\n        }\n        .breadcrumb-item+.breadcrumb-item::before {\n            content: \"\\e649\";\n            font-family: themify;\n            color: $light-text;\n            font-size: 11px;\n        }\n        .breadcrumb-item.active {\n            color: $muted;\n        }\n    }\n}\n\n\n/*******************\n Right side toggle\n*******************/\n\n@-webkit-keyframes rotate {\n    from {\n        -webkit-transform: rotate(0deg);\n    }\n    to {\n        -webkit-transform: rotate(360deg);\n    }\n}\n\n@-moz-keyframes rotate {\n    from {\n        -moz-transform: rotate(0deg);\n    }\n    to {\n        -moz-transform: rotate(360deg);\n    }\n}\n\n@keyframes rotate {\n    from {\n        transform: rotate(0deg);\n    }\n    to {\n        transform: rotate(360deg);\n    }\n}\n\n.right-side-toggle {\n    position: relative;\n}\n\n.right-side-toggle i {\n    -webkit-transition-property: -webkit-transform;\n    -webkit-transition-duration: 1s;\n    -moz-transition-property: -moz-transform;\n    -moz-transition-duration: 1s;\n    transition-property: transform;\n    transition-duration: 1s;\n    -webkit-animation-name: rotate;\n    -webkit-animation-duration: 2s;\n    -webkit-animation-iteration-count: infinite;\n    -webkit-animation-timing-function: linear;\n    -moz-animation-name: rotate;\n    -moz-animation-duration: 2s;\n    -moz-animation-iteration-count: infinite;\n    -moz-animation-timing-function: linear;\n    animation-name: rotate;\n    animation-duration: 2s;\n    animation-iteration-count: infinite;\n    animation-timing-function: linear;\n    position: absolute;\n    top: 18px;\n    left: 18px;\n}\n\n.right-sidebar {\n    position: fixed;\n    right: -240px;\n    width: 240px;\n    display: none;\n    z-index: 1100;\n    background: $white;\n    top: 0px;\n    padding-bottom: 20px;\n    height: 100%;\n    box-shadow: 5px 1px 40px rgba(0, 0, 0, 0.1);\n    transition: all 0.3s ease;\n    .rpanel-title {\n        display: block;\n        padding: 24px 20px;\n        color: $white;\n        text-transform: uppercase;\n        font-size: 15px;\n        background: $themecolor;\n        span {\n            float: right;\n            cursor: pointer;\n            font-size: 11px;\n            &:hover {\n                color: $white;\n            }\n        }\n    }\n    .r-panel-body {\n        padding: 20px;\n        ul {\n            margin: 0px;\n            padding: 0px;\n            li {\n                list-style: none;\n                padding: 5px 0;\n            }\n        }\n    }\n}\n\n.shw-rside {\n    right: 0px;\n    width: 240px;\n    display: block;\n}\n\n.chatonline {\n    img {\n        margin-right: 10px;\n        float: left;\n        width: 30px;\n    }\n    li a {\n        padding: 13px 0;\n        float: left;\n        width: 100%;\n        span {\n            color: $bodytext;\n            small {\n                display: block;\n                font-size: 10px;\n            }\n        }\n    }\n}\n\n\n/*******************\n Right side toggle\n*******************/\n\nul#themecolors {\n    display: block;\n    li {\n        display: inline-block;\n        &:first-child {\n            display: block;\n        }\n        a {\n            width: 50px;\n            height: 50px;\n            display: inline-block;\n            margin: 5px;\n            color: transparent;\n            position: relative;\n            &.working:before {\n                content: \"\\f00c\";\n                font-family: \"FontAwesome\";\n                font-size: 18px;\n                line-height: 50px;\n                width: 50px;\n                height: 50px;\n                position: absolute;\n                top: 0;\n                left: 0;\n                color: $white;\n                text-align: center;\n            }\n        }\n    }\n}\n\n.default-theme {\n    background: $muted;\n}\n\n.green-theme {\n    background: $success;\n}\n\n.yellow-theme {\n    background: $warning;\n}\n\n.red-theme {\n    background: $danger;\n}\n\n.blue-theme {\n    background: $info;\n}\n\n.purple-theme {\n    background: $purple;\n}\n\n.megna-theme {\n    background: $megna;\n}\n\n.default-dark-theme {\n    background: $dark;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $muted 23%, $muted 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $muted 23%, $muted 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $muted 23%, $muted 99%);\n}\n\n.green-dark-theme {\n    background: $dark;\n    ;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $success 23%, $success 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, #00c292 23%, $success 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $success 23%, $success 99%);\n}\n\n.yellow-dark-theme {\n    background: $dark;\n    ;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n}\n\n.blue-dark-theme {\n    background: $dark;\n    ;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $info 23%, $info 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $info 23%, $info 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $info 23%, $info 99%);\n}\n\n.purple-dark-theme {\n    background: $dark;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $purple 23%, $purple 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $purple 23%, $purple 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $purple 23%, $purple 99%);\n}\n\n.megna-dark-theme {\n    background: $dark;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $megna 23%, $megna 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $megna 23%, $megna 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $megna 23%, $megna 99%);\n}\n\n.red-dark-theme {\n    background: $dark;\n    /* Old browsers */\n    background: -moz-linear-gradient(left, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n    /* FF3.6-15 */\n    background: -webkit-linear-gradient(left, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n    /* Chrome10-25,Safari5.1-6 */\n    background: linear-gradient(to right, $dark 0%, $dark 23%, $danger 23%, $danger 99%);\n}\n\n\n/*******************\n page title\n*******************/\n\n.page-titles {\n    padding-bottom: 20px;\n}\n\n\n/*******************\n Footer\n*******************/\n\n.footer {\n    bottom: 0;\n    color: $bodytext;\n    left: 0px;\n    padding: 17px 15px;\n    position: absolute;\n    right: 0;\n    border-top: 1px solid $border;\n    background: $white;\n}\n\n\n/*******************\n Card title\n*******************/\n\n.card {\n    margin-bottom: 30px;\n    .card-subtitle {\n        font-weight: 300;\n        margin-bottom: 15px;\n        color: $muted;\n    }\n}\n\n.card-inverse .card-blockquote .blockquote-footer,\n.card-inverse .card-link,\n.card-inverse .card-subtitle,\n.card-inverse .card-text {\n    color: rgba(255, 255, 255, .65);\n}\n\n.card-success {\n    background: $success;\n    border-color: $success;\n}\n\n.card-danger {\n    background: $danger;\n    border-color: $danger;\n}\n\n.card-warning {\n    background: $warning;\n    border-color: $warning;\n}\n\n.card-info {\n    background: $info;\n    border-color: $info;\n}\n\n.card-primary {\n    background: $primary;\n    border-color: $primary;\n}\n\n.card-dark {\n    background: $inverse;\n    border-color: $inverse;\n}\n\n.card-megna {\n    background: $megna;\n    border-color: $megna;\n}\n\n\n/*============================================================== \n Buttons page\n ============================================================== */\n\n.button-group {\n    .btn {\n        margin-bottom: 5px;\n        margin-right: 5px;\n    }\n}\n\n.no-button-group {\n    .btn {\n        margin-bottom: 5px;\n        margin-right: 0px;\n    }\n}\n\n.btn {\n    .text-active {\n        display: none;\n    }\n    &.active .text-active {\n        display: inline-block;\n    }\n    &.active .text {\n        display: none;\n    }\n}\n\n\n/*============================================================== \n Cards page\n ============================================================== */\n\n.card-actions {\n    float: $rgt;\n    a {\n        cursor: pointer;\n        color: $bodytext;\n        opacity: 0.7;\n        padding-left: 7px;\n        font-size: 13px;\n        &:hover {\n            opacity: 1;\n        }\n    }\n}\n\n.card-columns .card {\n    margin-bottom: 20px;\n}\n\n.collapsing {\n    -webkit-transition: height .08s ease;\n    transition: height .08s ease;\n}\n\n.card-info {\n    background: $info;\n    border-color: $info;\n}\n\n.card-primary {\n    background: $primary;\n    border-color: $primary;\n}\n\n.card-outline-info {\n    border-color: $info;\n    .card-header {\n        background: $info;\n        border-color: $info;\n    }\n}\n\n.card-outline-inverse {\n    border-color: $inverse;\n    .card-header {\n        background: $inverse;\n        border-color: $inverse;\n    }\n}\n\n.card-outline-warning {\n    border-color: $warning;\n    .card-header {\n        background: $warning;\n        border-color: $warning;\n    }\n}\n\n.card-outline-success {\n    border-color: $success;\n    .card-header {\n        background: $success;\n        border-color: $success;\n    }\n}\n\n.card-outline-danger {\n    border-color: $danger;\n    .card-header {\n        background: $danger;\n        border-color: $danger;\n    }\n}\n\n.card-outline-primary {\n    border-color: $primary;\n    .card-header {\n        background: $primary;\n        border-color: $primary;\n    }\n}\n\n\n/*============================================================== \nBreadcrumb\n ============================================================== */\n\n.bc-colored {\n    .breadcrumb-item,\n    .breadcrumb-item a {\n        color: $white;\n        &.active {\n            opacity: 0.7;\n        }\n    }\n    .breadcrumb-item+.breadcrumb-item::before {\n        color: rgba(255, 255, 255, 0.4);\n    }\n}\n\n.breadcrumb {\n    margin-bottom: 0px;\n}\n\n\n/*============================================================== \n Ui-bootstrap\n ============================================================== */\n\nul.list-icons {\n    margin: 0px;\n    padding: 0px;\n    li {\n        list-style: none;\n        line-height: 30px;\n        margin: 5px 0;\n        transition: 0.2s ease-in;\n        a {\n            color: $bodytext;\n            &:hover {\n                color: $themecolor;\n            }\n        }\n        i {\n            font-size: 13px;\n            padding-right: 8px;\n        }\n    }\n}\n\nul.list-inline {\n    li {\n        display: inline-block;\n        padding: 0 8px;\n    }\n}\n\nul.two-part {\n    margin: 0px;\n    li {\n        width: 48.8%;\n    }\n}\n\n\n/*Accordion*/\n\nhtml body .accordion {\n    .card {\n        margin-bottom: 0px;\n    }\n}\n\n\n/*============================================================== \n flot chart\n ============================================================== */\n\n.flot-chart {\n    display: block;\n    height: 400px;\n}\n\n.flot-chart-content {\n    width: 100%;\n    height: 100%;\n}\n\nhtml body {\n    .jqstooltip,\n    .flotTip {\n        width: auto!important;\n        height: auto!important;\n        background: $dark;\n        color: $white;\n        padding: 5px 10px;\n    }\n}\n\n\n/*============================================================== \nEasy pie chart \n ============================================================== */\n\n.chart {\n    position: relative;\n    display: inline-block;\n    width: 100px;\n    height: 100px;\n    margin-top: 20px;\n    margin-bottom: 20px;\n    text-align: center;\n    canvas {\n        position: absolute;\n        top: 0;\n        left: 0;\n    }\n}\n\n.chart.chart-widget-pie {\n    margin-top: 5px;\n    margin-bottom: 5px;\n}\n\n.pie-chart > span {\n    left: 0;\n    margin-top: -2px;\n    position: absolute;\n    right: 0;\n    text-align: center;\n    top: 50%;\n    transform: translateY(-50%);\n}\n\n.chart > span > img {\n    left: 0;\n    margin-top: -2px;\n    position: absolute;\n    right: 0;\n    text-align: center;\n    top: 50%;\n    width: 60%;\n    height: 60%;\n    transform: translateY(-50%);\n    margin: 0 auto;\n}\n\n.percent {\n    display: inline-block;\n    line-height: 100px;\n    z-index: 2;\n    font-weight: 600;\n    font-size: 18px;\n    color: $dark;\n    &:after {\n        content: '%';\n        margin-left: 0.1em;\n        font-size: .8em;\n    }\n}\n\n\n/*============================================================== \nDashboard1 chart\n ============================================================== */\n\n.ct-charts {\n    position: relative;\n}\n\n.amp-pxl {\n    position: relative;\n    .ct-series-a .ct-bar {\n        stroke: $info;\n    }\n    .ct-series-b .ct-bar {\n        stroke: $success;\n    }\n}\n\n.c3-chart-arcs-title,\n.c3-legend-item {\n    font-family: $bodyfont;\n    fill: $bodytext;\n}\n\nhtml body #visitor .c3-chart-arcs-title {\n    font-size: 18px;\n    fill: $muted;\n}\n\n.stylish-table {\n    thead th {\n        font-weight: 400;\n        color: $muted;\n        border: 0px;\n        border-bottom: 1px;\n    }\n    tbody tr {\n        border-left: 4px solid $white;\n        &:hover,\n        &.active {\n            border-left: 4px solid $themecolor;\n        }\n    }\n    tbody td {\n        vertical-align: middle;\n        h6 {\n            font-weight: 500;\n            margin-bottom: 0px;\n            white-space: nowrap;\n        }\n        small {\n            line-height: 12px;\n            white-space: nowrap;\n        }\n    }\n}\n\n\n/*============================================================== \nDashboard2 chart\n ============================================================== */\n\n.campaign {\n    height: 280px;\n    .ct-series-a .ct-area {\n        fill-opacity: 0.2;\n        fill: url(#gradient);\n    }\n    .ct-series-a .ct-line,\n    .ct-series-a .ct-point {\n        stroke: $success;\n        stroke-width: 2px;\n    }\n    .ct-series-b .ct-area {\n        fill: $info;\n        fill-opacity: 0.1;\n    }\n    .ct-series-b .ct-line,\n    .ct-series-b .ct-point {\n        stroke: $info;\n        stroke-width: 2px;\n    }\n    .ct-series-a .ct-point,\n    .ct-series-b .ct-point {\n        stroke-width: 6px;\n    }\n}\n\n.campaign2 {\n    .ct-series-a .ct-area {\n        fill-opacity: 0.2;\n        fill: url(#gradient);\n    }\n    .ct-series-a .ct-line,\n    .ct-series-a .ct-point {\n        stroke: $success;\n        stroke-width: 2px;\n    }\n    .ct-series-b .ct-area {\n        fill: $info;\n        fill-opacity: 0.1;\n    }\n    .ct-series-b .ct-line,\n    .ct-series-b .ct-point {\n        stroke: $info;\n        stroke-width: 2px;\n    }\n    .ct-series-a .ct-point,\n    .ct-series-b .ct-point {\n        stroke-width: 6px;\n    }\n}\n\n.usage .ct-series-a .ct-line {\n    stroke-width: 3px;\n    stroke: rgba(255, 255, 255, 0.5);\n}\n\n\n/*============================================================== \nDashboard3 chart\n ============================================================== */\n\n.total-sales {\n    position: relative;\n    .chartist-tooltip {\n        background: $inverse;\n    }\n    .ct-series-a .ct-bar {\n        stroke: $info;\n    }\n    .ct-series-b .ct-bar {\n        stroke: $success;\n    }\n    .ct-series-c .ct-bar {\n        stroke: $danger;\n    }\n}\n\n.ct-chart {\n    position: relative;\n    .ct-series-a .ct-slice-donut {\n        stroke: $success;\n    }\n    .ct-series-b .ct-slice-donut {\n        stroke: $light;\n    }\n    .ct-series-c .ct-slice-donut {\n        stroke: $info;\n    }\n}\n\n#visitfromworld {\n    path.jvectormap-region.jvectormap-element {\n        stroke-width: 1px;\n        stroke: $muted;\n    }\n}\n\n.jvectormap-zoomin,\n.jvectormap-zoomout,\n.jvectormap-goback {\n    background: $muted;\n}\n\n.browser {\n    td {\n        vertical-align: middle;\n        padding-left: 0px;\n    }\n}\n\n#calendar .fc-today-button {\n    display: none;\n}\n\n\n/*============================================================== \nDashboard4 chart\n ============================================================== */\n\n.total-revenue4 {\n    position: relative;\n    .ct-series-a .ct-line {\n        stroke: $info;\n        stroke-width: 1px;\n    }\n    .ct-series-a .ct-point {\n        stroke: $info;\n        stroke-width: 5px;\n    }\n    .ct-series-b .ct-line {\n        stroke: $success;\n        stroke-width: 1px;\n    }\n    .ct-series-b .ct-point {\n        stroke: $success;\n        stroke-width: 5px;\n    }\n    .ct-series-a .ct-area {\n        fill: $info;\n        fill-opacity: 0.2;\n    }\n    .ct-series-b .ct-area {\n        fill: $success;\n        fill-opacity: 0.2;\n    }\n}\n\n\n/*============================================================== \nDashboard6 chart\n ============================================================== */\n\n.product-overview.table tbody tr td {\n    vertical-align: middle;\n}\n\n\n/*============================================================== \nWidget-data\n ============================================================== */\n\n.sparkchart {\n    margin-bottom: -2px;\n}\n\n\n/*============================================================== \nFile upload\n ============================================================== */\n\n.btn-file {\n    overflow: hidden;\n    position: relative;\n    vertical-align: middle;\n    > input {\n        position: absolute;\n        top: 0;\n        right: 0;\n        margin: 0;\n        opacity: 0;\n        filter: alpha(opacity=0);\n        font-size: 23px;\n        height: 100%;\n        width: 100%;\n        direction: ltr;\n        cursor: pointer;\n        border-radius: 0px;\n    }\n}\n\n.fileinput {\n    .input-group-addon {\n        border-right: 1px solid $border;\n    }\n}\n\n.fileinput .form-control {\n    padding-top: 7px;\n    padding-bottom: 5px;\n    display: inline-block;\n    margin-bottom: 0px;\n    vertical-align: middle;\n    cursor: text;\n}\n\n.fileinput .thumbnail {\n    overflow: hidden;\n    display: inline-block;\n    margin-bottom: 5px;\n    vertical-align: middle;\n    text-align: center;\n}\n\n.fileinput .thumbnail > img {\n    max-height: 100%;\n}\n\n.fileinput .btn {\n    vertical-align: middle;\n}\n\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n    display: none;\n}\n\n.fileinput-inline .fileinput-controls {\n    display: inline;\n}\n\n.fileinput-filename {\n    vertical-align: middle;\n    display: inline-block;\n    overflow: hidden;\n}\n\n.form-control .fileinput-filename {\n    vertical-align: bottom;\n}\n\n.fileinput.input-group > * {\n    position: relative;\n    z-index: 2;\n}\n\n.fileinput.input-group > .btn-file {\n    z-index: 1;\n}\n\n\n/*============================================================== \nwidget-chart-page product review\n ============================================================== */\n\n.product-review {\n    margin: 0px;\n    padding: 25px;\n    li {\n        display: block;\n        padding: 20px 0;\n        list-style: none;\n        .font,\n        span {\n            display: inline-block;\n            margin-left: 10px;\n        }\n    }\n}\n\n.social-profile {\n    text-align: center;\n    background: rgba(7, 10, 43, 0.8);\n}\n\n.profile-tab,\n.customtab {\n    li {\n        a.nav-link {\n            border: 0px;\n            padding: 15px 20px;\n            color: $bodytext;\n            &.active {\n                border-bottom: 2px solid $themecolor;\n                color: $themecolor;\n            }\n            &:hover {\n                color: $themecolor;\n            }\n        }\n    }\n}\n\n\n/*============================================================== \nForm addons page\n============================================================== */\n\n\n/*Bootstrap select*/\n\n.bootstrap-select:not([class*=col-]):not([class*=form-control]):not(.input-group-btn) {\n    width: 100%;\n}\n\n.bootstrap-select {\n    .dropdown-menu {\n        li a {\n            display: block;\n            padding: 7px 20px;\n            clear: both;\n            font-weight: 400;\n            line-height: 1.42857143;\n            color: $bodytext;\n            white-space: nowrap;\n            &:hover {\n                color: $themecolor;\n                background: $light;\n            }\n        }\n    }\n}\n\n.bootstrap-touchspin .input-group-btn-vertical>.btn {\n    padding: 9px 10px;\n}\n\n\n/*============================================================== \nForm Material page\n ============================================================== */\n\n\n/*Material inputs*/\n\n.form-material .form-group {\n    overflow: hidden;\n}\n\n.form-material .form-control {\n    background-color: rgba(0, 0, 0, 0);\n    background-position: center bottom, center calc(100% - 1px);\n    background-repeat: no-repeat;\n    background-size: 0 2px, 100% 1px;\n    padding: 0;\n    transition: background 0s ease-out 0s;\n}\n\n.form-material .form-control,\n.form-material .form-control.focus,\n.form-material .form-control:focus {\n    background-image: linear-gradient($themecolor, $themecolor), linear-gradient($form-brd, $form-brd);\n    border: 0 none;\n    border-radius: 0;\n    box-shadow: none;\n    float: none;\n}\n\n.form-material .form-control.focus,\n.form-material .form-control:focus {\n    background-size: 100% 2px, 100% 1px;\n    outline: 0 none;\n    transition-duration: 0.3s;\n}\n\n.form-control-line .form-group {\n    overflow: hidden;\n}\n\n.form-control-line .form-control {\n    border: 0px;\n    border-radius: 0px;\n    padding-left: 0px;\n    border-bottom: 1px solid $form-brd;\n    &:focus {\n        border-bottom: 1px solid $themecolor;\n    }\n}\n\n\n/*******************/\n\n\n/*Floating Label*/\n\n\n/*******************/\n\n.floating-labels .form-group {\n    position: relative;\n}\n\n.floating-labels .form-control {\n    padding: 10px 10px 10px 0;\n    display: block;\n    border: none;\n    font-family: $bodyfont;\n    border-radius: 0px;\n    border-bottom: 1px solid $form-brd;\n}\n\n.floating-labels select.form-control>option {\n    font-size: 14px;\n}\n\n.floating-labels .has-error .form-control {\n    border-bottom: 1px solid $danger;\n}\n\n.floating-labels .has-warning .form-control {\n    border-bottom: 1px solid $warning;\n}\n\n.floating-labels .has-success .form-control {\n    border-bottom: 1px solid $success;\n}\n\n.floating-labels .form-control:focus {\n    outline: none;\n    border: none;\n}\n\n.floating-labels label {\n    color: $bodytext;\n    position: absolute;\n    cursor: auto;\n    top: 5px;\n    transition: 0.2s ease all;\n    -moz-transition: 0.2s ease all;\n    -webkit-transition: 0.2s ease all;\n}\n\n.floating-labels .form-control:focus~label,\n.floating-labels .form-control:valid~label {\n    top: -20px;\n    font-size: 12px;\n    color: $dark;\n}\n\n.floating-labels .bar {\n    position: relative;\n    display: block;\n}\n\n.floating-labels .bar:before,\n.floating-labels .bar:after {\n    content: '';\n    height: 2px;\n    width: 0;\n    bottom: 1px;\n    position: absolute;\n    background: $themecolor;\n    transition: 0.2s ease all;\n    -moz-transition: 0.2s ease all;\n    -webkit-transition: 0.2s ease all;\n}\n\n.floating-labels .bar:before {\n    left: 50%;\n}\n\n.floating-labels .bar:after {\n    right: 50%;\n}\n\n.floating-labels .form-control:focus~.bar:before,\n.floating-labels .form-control:focus~.bar:after {\n    width: 50%;\n}\n\n.floating-labels .highlight {\n    position: absolute;\n    height: 60%;\n    width: 100px;\n    top: 25%;\n    left: 0;\n    pointer-events: none;\n    opacity: 0.5;\n}\n\n.floating-labels .input-lg~label,\n.floating-labels .input-lg {\n    font-size: 24px;\n}\n\n.floating-labels .input-sm~label,\n.floating-labels .input-sm {\n    font-size: 16px;\n}\n\n.has-warning .bar:before,\n.has-warning .bar:after {\n    background: $warning;\n}\n\n.has-success .bar:before,\n.has-success .bar:after {\n    background: $success;\n}\n\n.has-error .bar:before,\n.has-error .bar:after {\n    background: $danger;\n}\n\n.has-warning .form-control:focus~label,\n.has-warning .form-control:valid~label {\n    color: $warning;\n}\n\n.has-success .form-control:focus~label,\n.has-success .form-control:valid~label {\n    color: $success;\n}\n\n.has-error .form-control:focus~label,\n.has-error .form-control:valid~label {\n    color: $danger;\n}\n\n.has-feedback label~.t-0 {\n    top: 0;\n}\n\n.form-group.error input,\n.form-group.error select,\n.form-group.error textarea {\n    border: 1px solid $danger;\n}\n\n.form-group.validate input,\n.form-group.validate select,\n.form-group.validate textarea {\n    border: 1px solid $success;\n}\n\n.form-group.error .help-block {\n    ul {\n        padding: 0px;\n        color: $danger;\n        li {\n            list-style: none;\n        }\n    }\n}\n\n.form-group.issue .help-block {\n    ul {\n        padding: 0px;\n        color: $warning;\n        li {\n            list-style: none;\n        }\n    }\n}\n\n\n/*******************\nPagination\n******************/\n\n.pagination-circle {\n    li.active a {\n        background: $success;\n    }\n    li a {\n        width: 40px;\n        height: 40px;\n        background: $light;\n        border: 0px;\n        text-align: center;\n        border-radius: 100%;\n        &:first-child,\n        &:last-child {\n            border-radius: 100%;\n        }\n        &:hover {\n            background: $success;\n            color: $white;\n        }\n    }\n    li.disabled a {\n        background: $light;\n        color: $border;\n    }\n}\n\n\n/*******************\nForm Dropzone\n******************/\n\n.dropzone {\n    border: 1px dashed $form-brd;\n    .dz-message {\n        padding: 5% 0;\n        margin: 0px;\n    }\n}\n\n\n/*******************\nForm Pickers\n******************/\n\n.asColorPicker-dropdown {\n    max-width: 260px;\n}\n\n.asColorPicker-trigger {\n    position: absolute;\n    top: 0;\n    right: -35px;\n    height: 38px;\n    width: 37px;\n    border: 0;\n}\n\n.asColorPicker-clear {\n    display: none;\n    position: absolute;\n    top: 5px;\n    right: 10px;\n    text-decoration: none;\n}\n\ntable th {\n    font-weight: 400;\n}\n\n.daterangepicker td.active,\n.daterangepicker td.active:hover {\n    background-color: $themecolor;\n}\n\n.datepicker table tr td.today,\n.datepicker table tr td.today.disabled,\n.datepicker table tr td.today.disabled:hover,\n.datepicker table tr td.today:hover {\n    background: $themecolor;\n    color: $white;\n}\n\n.datepicker td,\n.datepicker th {\n    padding: 5px 10px;\n}\n\n\n/*******************\nForm icheck\n******************/\n\n.icolors,\n.icheck-list {\n    padding: 0;\n    margin: 0;\n    list-style: none;\n}\n\n.icolors>li {\n    padding: 0;\n    margin: 2px;\n    float: left;\n    display: inline-block;\n    height: 30px;\n    width: 30px;\n    background: $dark;\n    text-align: center;\n}\n\n.icolors>li.active:after {\n    content: \"\\2713 \";\n    color: $white;\n    line-height: 30px;\n}\n\n.icolors>li:first-child {\n    margin-left: 0;\n}\n\n.icolors>li.orange {\n    background: $danger;\n}\n\n.icolors>li.yellow {\n    background: $warning;\n}\n\n.icolors>li.info {\n    background: $info;\n}\n\n.icolors>li.green {\n    background: $success;\n}\n\n.icolors>li.red {\n    background: $red;\n}\n\n.icolors>li.purple {\n    background: $purple;\n}\n\n.icolors>li.blue {\n    background: $blue;\n}\n\n.icheck-list {\n    float: left;\n    padding-right: 50px;\n    padding-top: 10px;\n}\n\n.icheck-list li {\n    padding-bottom: 5px;\n}\n\n.icheck-list li label {\n    padding-left: 10px;\n}\n\n\n/*******************\nForm summernote\n******************/\n\n.note-popover,\n.note-icon-caret {\n    display: none;\n}\n\n.note-editor.note-frame {\n    border: 1px solid $form-brd;\n    .panel-heading {\n        padding: 6px 10px 10px;\n        border-bottom: 1px solid $border;\n    }\n}\n\n.label {\n    display: inline-block;\n}\n\n\n/*******************\nTable-Layout\n******************/\n\n.table thead th,\n.table th {\n    border: 0px;\n}\n\n.color-table.primary-table thead th {\n    background-color: $primary;\n    color: $white;\n}\n\n.table-striped tbody tr:nth-of-type(odd) {\n    background: $light;\n}\n\n.color-table.success-table thead th {\n    background-color: $success;\n    color: $white;\n}\n\n.color-table.info-table thead th {\n    background-color: $info;\n    color: $white;\n}\n\n.color-table.warning-table thead th {\n    background-color: $warning;\n    color: $white;\n}\n\n.color-table.danger-table thead th {\n    background-color: $danger;\n    color: $white;\n}\n\n.color-table.inverse-table thead th {\n    background-color: $inverse;\n    color: $white;\n}\n\n.color-table.dark-table thead th {\n    background-color: $dark;\n    color: $white;\n}\n\n.color-table.red-table thead th {\n    background-color: $red;\n    color: $white;\n}\n\n.color-table.purple-table thead th {\n    background-color: $purple;\n    color: $white;\n}\n\n.color-table.muted-table thead th {\n    background-color: $muted;\n    color: $white;\n}\n\n.color-bordered-table.primary-bordered-table {\n    border: 2px solid $primary;\n    thead th {\n        background-color: $primary;\n        color: $white;\n    }\n}\n\n.color-bordered-table.success-bordered-table {\n    border: 2px solid $success;\n    thead th {\n        background-color: $success;\n        color: $white;\n    }\n}\n\n.color-bordered-table.info-bordered-table {\n    border: 2px solid $info;\n    thead th {\n        background-color: $info;\n        color: $white;\n    }\n}\n\n.color-bordered-table.warning-bordered-table {\n    border: 2px solid $warning;\n    thead th {\n        background-color: $warning;\n        color: $white;\n    }\n}\n\n.color-bordered-table.danger-bordered-table {\n    border: 2px solid $danger;\n    thead th {\n        background-color: $danger;\n        color: $white;\n    }\n}\n\n.color-bordered-table.inverse-bordered-table {\n    border: 2px solid $inverse;\n    thead th {\n        background-color: $inverse;\n        color: $white;\n    }\n}\n\n.color-bordered-table.dark-bordered-table {\n    border: 2px solid $dark;\n    thead th {\n        background-color: $dark;\n        color: $white;\n    }\n}\n\n.color-bordered-table.red-bordered-table {\n    border: 2px solid $red;\n    thead th {\n        background-color: $red;\n        color: $white;\n    }\n}\n\n.color-bordered-table.purple-bordered-table {\n    border: 2px solid $purple;\n    thead th {\n        background-color: $purple;\n        color: $white;\n    }\n}\n\n.color-bordered-table.muted-bordered-table {\n    border: 2px solid $muted;\n    thead th {\n        background-color: $muted;\n        color: $white;\n    }\n}\n\n.full-color-table.full-primary-table {\n    background-color: $light-primary;\n    thead th {\n        background-color: $primary;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $primary;\n        color: $white;\n    }\n}\n\n.full-color-table.full-success-table {\n    background-color: $light-success;\n    thead th {\n        background-color: $success;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $success;\n        color: $white;\n    }\n}\n\n.full-color-table.full-info-table {\n    background-color: $light-info;\n    thead th {\n        background-color: $info;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $info;\n        color: $white;\n    }\n}\n\n.full-color-table.full-warning-table {\n    background-color: $light-warning;\n    thead th {\n        background-color: $warning;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $warning;\n        color: $white;\n    }\n}\n\n.full-color-table.full-danger-table {\n    background-color: $light-danger;\n    thead th {\n        background-color: $danger;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $danger;\n        color: $white;\n    }\n}\n\n.full-color-table.full-inverse-table {\n    background-color: $light-inverse;\n    thead th {\n        background-color: $inverse;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $inverse;\n        color: $white;\n    }\n}\n\n.full-color-table.full-dark-table {\n    background-color: rgba(43, 43, 43, .8);\n    thead th {\n        background-color: $dark;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n        color: $white;\n    }\n    tr:hover {\n        background-color: $dark;\n        color: $white;\n    }\n}\n\n.full-color-table.full-red-table {\n    background-color: $light-danger;\n    thead th {\n        background-color: $red;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $red;\n        color: $white;\n    }\n}\n\n.full-color-table.full-purple-table {\n    background-color: $light-primary;\n    thead th {\n        background-color: $purple;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $purple;\n        color: $white;\n    }\n}\n\n.full-color-table.full-muted-table {\n    background-color: rgba(152, 166, 173, .2);\n    thead th {\n        background-color: $muted;\n        border: 0;\n        color: $white;\n    }\n    tbody td {\n        border: 0;\n    }\n    tr:hover {\n        background-color: $muted;\n        color: $white;\n    }\n}\n\n\n/*******************\nTable-Data Table\n******************/\n\n.dt-buttons {\n    display: inline-block;\n    padding-top: 5px;\n    .dt-button {\n        padding: 5px 15px;\n        border-radius: $radius;\n        background: $themecolor;\n        color: $white;\n        margin-right: 3px;\n        &:hover {\n            background: $inverse;\n        }\n    }\n}\n\n.dataTables_info,\n.dataTables_length {\n    display: inline-block;\n}\n\n.dataTables_filter {\n    float: right;\n    input {\n        border: 1px solid $form-brd;\n    }\n}\n\ntable.dataTable thead .sorting,\ntable.dataTable thead .sorting_asc,\ntable.dataTable thead .sorting_desc,\ntable.dataTable thead .sorting_asc_disabled,\ntable.dataTable thead .sorting_desc_disabled {\n    background: transparent;\n}\n\ntable.dataTable thead .sorting_asc:after {\n    content: \"\\f0de\";\n    margin-left: 10px;\n    font-family: fontawesome;\n    cursor: pointer;\n}\n\ntable.dataTable thead .sorting_desc:after {\n    content: \"\\f0dd\";\n    margin-left: 10px;\n    font-family: fontawesome;\n    cursor: pointer;\n}\n\ntable.dataTable thead .sorting:after {\n    content: \"\\f0dc\";\n    margin-left: 10px;\n    font-family: fontawesome !important;\n    cursor: pointer;\n    color: rgba(50, 50, 50, .5);\n}\n\n.dataTables_wrapper .dataTables_paginate {\n    float: right;\n    text-align: right;\n    padding-top: 0.25em\n}\n\n.dataTables_wrapper .dataTables_paginate .paginate_button {\n    box-sizing: border-box;\n    display: inline-block;\n    min-width: 1.5em;\n    padding: 0.5em 1em;\n    margin-left: 2px;\n    text-align: center;\n    text-decoration: none;\n    cursor: pointer;\n    *cursor: hand;\n    color: $bodytext;\n    border: 1px solid transparent;\n    border-radius: 2px\n}\n\n.dataTables_wrapper .dataTables_paginate .paginate_button.current,\n.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {\n    color: $white !important;\n    border: 1px solid $info;\n    background-color: $info;\n}\n\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover,\n.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:active {\n    cursor: default;\n    color: $bodytext;\n    border: 1px solid transparent;\n    background: transparent;\n    box-shadow: none\n}\n\n.dataTables_wrapper .dataTables_paginate .paginate_button:hover {\n    color: white !important;\n    border: 1px solid $primary;\n    background-color: $primary;\n}\n\n.dataTables_wrapper .dataTables_paginate .paginate_button:active {\n    outline: none;\n    background-color: $bodytext;\n}\n\n.dataTables_wrapper .dataTables_paginate .ellipsis {\n    padding: 0 1em\n}\n\n\n/*******************\nTable- responsive\n******************/\n\n.tablesaw-bar .btn-group label {\n    color: $bodytext!important;\n}\n\n\n/*******************\nTable- editable table\n******************/\n\n.dt-bootstrap {\n    display: block;\n}\n\n.paging_simple_numbers {\n    .pagination {\n        .paginate_button {\n            padding: 0px;\n            background: $white;\n            &:hover {\n                background: $white;\n            }\n            a {\n                padding: 5px 10px;\n                border-radius: $radius;\n                border: 0px;\n            }\n            &.active a,\n            &:hover a {\n                background: $info;\n                color: $white;\n            }\n        }\n    }\n}\n\n\n/*******************\nTable- Footable\n******************/\n\n.footable .pagination {\n    display: inline-block;\n    padding: 8px 0;\n    li {\n        padding: 0px;\n        margin: 0 1px;\n        display: inline-block;\n        a {\n            padding: 5px 10px;\n            &:hover,\n            &.active {\n                background: $info;\n                color: $white;\n                border-radius: $radius;\n            }\n        }\n        &.active a {\n            color: $white;\n            border-radius: $radius;\n        }\n    }\n}\n\n.footable-odd {\n    background: $light;\n}\n\n\n/*******************\nIcon list fontawesom\n******************/\n\n.icon-list-demo {\n    div {\n        cursor: pointer;\n        line-height: 60px;\n        white-space: nowrap;\n        color: $bodytext;\n        &:hover {\n            color: $dark;\n        }\n        p {\n            margin: 10px 0;\n            padding: 5px 0;\n        }\n    }\n    i {\n        -webkit-transition: all 0.2s;\n        -webkit-transition: font-size .2s;\n        display: inline-block;\n        font-size: 18px;\n        margin: 0 15px 0 10px;\n        text-align: left;\n        transition: all 0.2s;\n        transition: font-size .2s;\n        vertical-align: middle;\n        transition: all 0.3s ease 0s;\n    }\n    .col-md-4,\n    .col-3 {\n        border-radius: $radius;\n        &:hover {\n            background-color: $extra-light;\n        }\n    }\n}\n\n.icon-list-demo .div:hover i {\n    font-size: 2em;\n}\n\n\n/*******************\nIcon list material icon\n******************/\n\n.material-icon-list-demo .mdi {\n    font-size: 21px;\n}\n\n\n/*******************\nGridstack Dragable portlet\n******************/\n\n.grid-stack-item-content {\n    background: #fff;\n    color: #2b2b2b;\n    text-align: center;\n    font-size: 20px;\n}\n\n.grid-stack > .grid-stack-item > .grid-stack-item-content {\n    border: 1px solid $border;\n}\n\n\n/*******************\nBootstrap Switch\n******************/\n\n.bootstrap-switch,\n.bootstrap-switch .bootstrap-switch-container {\n    border-radius: 2px;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-on {\n    border-bottom-left-radius: 2px;\n    border-top-left-radius: 2px;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off {\n    border-bottom-right-radius: 2px;\n    border-top-right-radius: 2px;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-primary,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-primary {\n    color: $white;\n    background: $primary;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-info,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-info {\n    color: $white;\n    background: $info;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-success,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success {\n    color: $white;\n    background: $success;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-warning,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-warning {\n    color: $white;\n    background: $warning;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-danger,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-danger {\n    color: $white;\n    background: $danger;\n}\n\n.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-default,\n.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-default {\n    color: $dark;\n    background: $light;\n}\n\n.onoffswitch {\n    position: relative;\n    width: 90px;\n    -webkit-user-select: none;\n    -moz-user-select: none;\n    -ms-user-select: none;\n}\n\n.onoffswitch-checkbox {\n    display: none;\n}\n\n.onoffswitch-label {\n    display: block;\n    overflow: hidden;\n    cursor: pointer;\n    border: 2px solid $success;\n    border-radius: 20px;\n}\n\n.onoffswitch-inner {\n    display: block;\n    width: 200%;\n    margin-left: -100%;\n    transition: margin 0.3s ease-in 0s;\n}\n\n.onoffswitch-inner:before,\n.onoffswitch-inner:after {\n    display: block;\n    float: left;\n    width: 50%;\n    height: 30px;\n    padding: 0;\n    line-height: 30px;\n    font-size: 14px;\n    color: white;\n    box-sizing: border-box;\n}\n\n.onoffswitch-inner:before {\n    content: \"ON\";\n    padding-left: 27px;\n    background-color: $success;\n    color: #FFFFFF;\n}\n\n.onoffswitch-inner:after {\n    content: \"OFF\";\n    padding-right: 24px;\n    background-color: #EEEEEE;\n    color: #999999;\n    text-align: right;\n}\n\n.onoffswitch-switch {\n    display: block;\n    width: 23px;\n    margin: 6px;\n    background: #FFFFFF;\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    right: 56px;\n    border: 2px solid $success;\n    border-radius: 20px;\n    transition: all 0.3s ease-in 0s;\n}\n\n.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {\n    margin-left: 0;\n}\n\n.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {\n    right: 0px;\n}\n\n\n/*******************\nDate paginator page\n******************/\n\n.dp-selected[style] {\n    background-color: $themecolor!important;\n}\n\n.datepaginator-sm,\n.datepaginator-lg,\n.datepaginator {\n    .pagination {\n        li {\n            a {\n                padding: 0 5px;\n                height: 60px;\n                border: 1px solid $border;\n                float: left;\n                position: relative;\n            }\n        }\n    }\n}\n\n\n/*******************\nsweet alert page\n******************/\n\n.model_img {\n    cursor: pointer;\n}\n\n\n/*******************\nGrid page\n******************/\n\n.show-grid {\n    margin-bottom: 10px;\n    padding: 0 15px\n}\n\n.show-grid [class^=col-] {\n    padding-top: 10px;\n    padding-bottom: 10px;\n    border: 1px solid $form-brd;\n    background-color: $light;\n}\n\n\n/*******************\nVertical tabs\n******************/\n\n.vtabs {\n    display: table;\n    .tabs-vertical {\n        width: 150px;\n        border-bottom: 0px;\n        border-right: 1px solid $border;\n        display: table-cell;\n        vertical-align: top;\n        li .nav-link {\n            color: $dark;\n            margin-bottom: 10px;\n            border: 0px;\n            border-radius: $radius 0 0 $radius;\n        }\n    }\n    .tab-content {\n        display: table-cell;\n        padding: 20px;\n        vertical-align: top;\n    }\n}\n\n.tabs-vertical li .nav-link.active,\n.tabs-vertical li .nav-link:hover,\n.tabs-vertical li .nav-link.active:focus {\n    background: $themecolor;\n    border: 0px;\n    color: $white;\n}\n\n\n/*Custom vertical tab*/\n\n.customvtab .tabs-vertical li .nav-link.active,\n.customvtab .tabs-vertical li .nav-link:hover,\n.customvtab .tabs-vertical li .nav-link:focus {\n    background: $white;\n    border: 0px;\n    border-right: 2px solid $themecolor;\n    margin-right: -1px;\n    color: $themecolor;\n}\n\n.tabcontent-border {\n    border: 1px solid #ddd;\n    border-top: 0px;\n}\n\n.customtab2 {\n    li {\n        a.nav-link {\n            border: 0px;\n            margin-right: 3px;\n            color: $bodytext;\n            &.active {\n                background: $themecolor;\n                color: $white;\n            }\n            &:hover {\n                color: $white;\n                background: $themecolor;\n            }\n        }\n    }\n}\n\n\n/*******************\nProgress bar\n******************/\n\n.progress.active .progress-bar,\n.progress-bar.active {\n    -webkit-animation: progress-bar-stripes 2s linear infinite;\n    -o-animation: progress-bar-stripes 2s linear infinite;\n    animation: progress-bar-stripes 2s linear infinite;\n}\n\n.progress-vertical {\n    min-height: 250px;\n    height: 250px;\n    position: relative;\n    display: inline-block;\n    margin-bottom: 0;\n    margin-right: 20px;\n}\n\n.progress-vertical-bottom {\n    min-height: 250px;\n    height: 250px;\n    position: relative;\n    display: inline-block;\n    margin-bottom: 0;\n    margin-right: 20px;\n    transform: rotate(180deg);\n}\n\n.progress-animated {\n    -webkit-animation-duration: 5s;\n    -webkit-animation-name: myanimation;\n    -webkit-transition: 5s all;\n    animation-duration: 5s;\n    animation-name: myanimation;\n    transition: 5s all;\n}\n\n@-webkit-keyframes myanimation {\n    from {\n        width: 0;\n    }\n}\n\n@keyframes myanimation {\n    from {\n        width: 0;\n    }\n}\n\n\n/*******************\nNotification page Jquery toaster\n******************/\n\n.jq-icon-info {\n    background-color: $info;\n    color: $white;\n}\n\n.jq-icon-success {\n    background-color: $success;\n    color: $white;\n}\n\n.jq-icon-error {\n    background-color: $danger;\n    color: $white;\n}\n\n.jq-icon-warning {\n    background-color: $warning;\n    color: $white;\n}\n\n.alert-rounded {\n    border-radius: 60px;\n}\n\n\n/*******************\nlist and media\n******************/\n\n.list-group a.list-group-item:hover {\n    background: $light;\n}\n\n.list-group-item.active,\n.list-group .list-group-item.active:hover {\n    background: $themecolor;\n    border-color: $themecolor;\n}\n\n.list-group-item.disabled {\n    color: $muted;\n    background: $light;\n}\n\n.media {\n    border: 1px solid $border;\n    margin-bottom: 10px;\n    padding: 15px;\n}\n\n\n/*******************\nUser card page\n******************/\n\n.el-element-overlay .white-box {\n    padding: 0px;\n}\n\n.el-element-overlay .el-card-item {\n    position: relative;\n    padding-bottom: 25px;\n    .el-card-avatar {\n        margin-bottom: 15px;\n    }\n    .el-card-content {\n        text-align: center;\n        h3 {\n            margin: 0px;\n        }\n        a {\n            color: $bodytext;\n            &:hover {\n                color: $themecolor;\n            }\n        }\n    }\n    .el-overlay-1 {\n        width: 100%;\n        height: 100%;\n        overflow: hidden;\n        position: relative;\n        text-align: center;\n        cursor: default;\n        img {\n            display: block;\n            position: relative;\n            -webkit-transition: all .4s linear;\n            transition: all .4s linear;\n            width: 100%;\n            height: auto;\n        }\n        &:hover img {\n            -ms-transform: scale(1.2) translateZ(0);\n            -webkit-transform: scale(1.2) translateZ(0);\n            /* transform: scale(1.2) translateZ(0); */\n        }\n        .el-info {\n            text-decoration: none;\n            display: inline-block;\n            text-transform: uppercase;\n            color: $white;\n            background-color: transparent;\n            filter: alpha(opacity=0);\n            -webkit-transition: all .2s ease-in-out;\n            transition: all .2s ease-in-out;\n            padding: 0;\n            margin: auto;\n            position: absolute;\n            top: 50%;\n            left: 0;\n            right: 0;\n            transform: translateY(-50%) translateZ(0);\n            -webkit-transform: translateY(-50%) translateZ(0);\n            -ms-transform: translateY(-50%) translateZ(0);\n            >li {\n                list-style: none;\n                display: inline-block;\n                margin: 0 3px;\n                a {\n                    border-color: $white;\n                    color: $white;\n                    padding: 12px 15px 10px;\n                    &:hover {\n                        background: $themecolor;\n                        border-color: $themecolor;\n                    }\n                }\n            }\n        }\n    }\n    .el-overlay {\n        width: 100%;\n        height: 100%;\n        position: absolute;\n        overflow: hidden;\n        top: 0;\n        left: 0;\n        opacity: 0;\n        background-color: rgba(0, 0, 0, .7);\n        -webkit-transition: all .4s ease-in-out;\n        transition: all .4s ease-in-out;\n    }\n    .el-overlay-1:hover .el-overlay {\n        opacity: 1;\n        filter: alpha(opacity=100);\n        -webkit-transform: translateZ(0);\n        -ms-transform: translateZ(0);\n        transform: translateZ(0);\n    }\n    .el-overlay-1 .scrl-dwn {\n        top: -100%;\n    }\n    .el-overlay-1 .scrl-up {\n        top: 100%;\n        height: 0px;\n    }\n    .el-overlay-1:hover .scrl-dwn {\n        top: 0px;\n    }\n    .el-overlay-1:hover .scrl-up {\n        top: 0px;\n        height: 100%;\n    }\n}\n\n\n/*******************\nTimeline page\n******************/\n\n.timeline {\n    position: relative;\n    padding: 20px 0 20px;\n    list-style: none;\n    max-width: 1200px;\n    margin: 0 auto;\n}\n\n.timeline:before {\n    content: \" \";\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 50%;\n    width: 3px;\n    margin-left: -1.5px;\n    background-color: $light;\n}\n\n.timeline > li {\n    position: relative;\n    margin-bottom: 20px;\n}\n\n.timeline > li:before,\n.timeline > li:after {\n    content: \" \";\n    display: table;\n}\n\n.timeline > li:after {\n    clear: both;\n}\n\n.timeline > li:before,\n.timeline > li:after {\n    content: \" \";\n    display: table;\n}\n\n.timeline > li:after {\n    clear: both;\n}\n\n.timeline > li > .timeline-panel {\n    float: left;\n    position: relative;\n    width: 46%;\n    padding: 20px;\n    border: 1px solid $border;\n    border-radius: $radius;\n    -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);\n    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.05);\n}\n\n.timeline > li > .timeline-panel:before {\n    content: \" \";\n    display: inline-block;\n    position: absolute;\n    top: 26px;\n    right: -8px;\n    border-top: 8px solid transparent;\n    border-right: 0 solid $border;\n    border-bottom: 8px solid transparent;\n    border-left: 8px solid $border;\n}\n\n.timeline > li > .timeline-panel:after {\n    content: \" \";\n    display: inline-block;\n    position: absolute;\n    top: 27px;\n    right: -7px;\n    border-top: 7px solid transparent;\n    border-right: 0 solid $white;\n    border-bottom: 7px solid transparent;\n    border-left: 7px solid $white;\n}\n\n.timeline > li > .timeline-badge {\n    z-index: 10;\n    position: absolute;\n    top: 16px;\n    left: 50%;\n    width: 50px;\n    height: 50px;\n    margin-left: -25px;\n    border-radius: 50% 50% 50% 50%;\n    text-align: center;\n    font-size: 1.4em;\n    line-height: 50px;\n    color: #fff;\n    overflow: hidden;\n}\n\n.timeline > li.timeline-inverted > .timeline-panel {\n    float: right;\n}\n\n.timeline > li.timeline-inverted > .timeline-panel:before {\n    right: auto;\n    left: -8px;\n    border-right-width: 8px;\n    border-left-width: 0;\n}\n\n.timeline > li.timeline-inverted > .timeline-panel:after {\n    right: auto;\n    left: -7px;\n    border-right-width: 7px;\n    border-left-width: 0;\n}\n\n.timeline-badge.primary {\n    background-color: $primary;\n}\n\n.timeline-badge.success {\n    background-color: $success;\n}\n\n.timeline-badge.warning {\n    background-color: $warning;\n}\n\n.timeline-badge.danger {\n    background-color: $danger;\n}\n\n.timeline-badge.info {\n    background-color: $info;\n}\n\n.timeline-title {\n    margin-top: 0;\n    color: inherit;\n    font-weight: 400;\n}\n\n.timeline-body > p,\n.timeline-body > ul {\n    margin-bottom: 0;\n}\n\n.timeline-body > p + p {\n    margin-top: 5px;\n}\n\n\n/*******************\nHorizontal Timeline page\n******************/\n\n.cd-horizontal-timeline .events a {\n    padding-bottom: 6px;\n    color: $themecolor;\n}\n\n.cd-horizontal-timeline .filling-line,\n.cd-horizontal-timeline .events a.selected::after {\n    background: $themecolor;\n}\n\n.cd-horizontal-timeline .events a.selected::after {\n    border-color: $themecolor;\n}\n\n.myadmin-dd .dd-list .dd-item .dd-handle {\n    background: $white;\n    border: 1px solid rgba(120, 130, 140, .13);\n    padding: 8px 16px;\n    height: auto;\n    font-family: $bodyfont;\n    font-weight: 400;\n    border-radius: 0;\n}\n\n.myadmin-dd-empty .dd-list .dd3-content {\n    height: auto;\n    border: 1px solid rgba(120, 130, 140, .13);\n    padding: 8px 16px 8px 46px;\n    background: $white;\n    font-weight: 400;\n}\n\n.myadmin-dd-empty .dd-list .dd3-handle {\n    border: 1px solid rgba(120, 130, 140, .13);\n    border-bottom: 0;\n    background: $white;\n    height: 36px;\n    width: 36px;\n}\n\n.dd3-handle:before {\n    color: $bodytext;\n    top: 7px;\n}\n\n\n/*******************\nribbons page\n******************/\n\n.ribbon-wrapper,\n.ribbon-wrapper-reverse,\n.ribbon-wrapper-bottom,\n.ribbon-wrapper-right-bottom {\n    position: relative;\n    padding: 50px 15px 15px 15px;\n}\n\n.ribbon-vwrapper {\n    padding: 15px 15px 15px 50px;\n    position: relative;\n}\n\n.ribbon-overflow {\n    overflow: hidden;\n}\n\n.ribbon-vwrapper-reverse {\n    padding: 15px 50px 15px 15px;\n}\n\n.ribbon-wrapper-bottom {\n    padding: 15px 15px 50px 50px;\n}\n\n.ribbon-wrapper-right-bottom {\n    padding: 15px 50px 50px 15px;\n}\n\n.ribbon-content {\n    margin-bottom: 0px;\n}\n\n.ribbon {\n    padding: 0 20px;\n    height: 30px;\n    line-height: 30px;\n    clear: left;\n    position: absolute;\n    top: 12px;\n    left: -2px;\n    color: $white;\n}\n\n.ribbon-bookmark:before {\n    position: absolute;\n    top: 0;\n    left: 100%;\n    display: block;\n    width: 0;\n    height: 0;\n    content: '';\n    border: 15px solid $dark;\n    border-right: 10px solid transparent;\n}\n\n.ribbon-right {\n    left: auto;\n    right: -2px;\n}\n\n.ribbon-bookmark.ribbon-right:before {\n    right: 100%;\n    left: auto;\n    border-right: 15px solid $dark;\n    border-left: 10px solid transparent;\n}\n\n.ribbon-vertical-l,\n.ribbon-vertical-r {\n    clear: none;\n    padding: 0 5px;\n    height: 70px;\n    width: 30px;\n    line-height: 70px;\n    text-align: center;\n    left: 12px;\n    top: -2px;\n}\n\n.ribbon-vertical-r {\n    left: auto;\n    right: 12px;\n}\n\n.ribbon-bookmark.ribbon-vertical-l:before,\n.ribbon-bookmark.ribbon-vertical-r:before {\n    top: 100%;\n    left: 0;\n    margin-top: -14px;\n    border-right: 15px solid $dark;\n    border-bottom: 10px solid transparent;\n}\n\n.ribbon-badge {\n    top: 15px;\n    overflow: hidden;\n    left: -90px;\n    width: 100%;\n    text-align: center;\n    -webkit-transform: rotate(-45deg);\n    -ms-transform: rotate(-45deg);\n    -o-transform: rotate(-45deg);\n    transform: rotate(-45deg);\n}\n\n.ribbon-badge.ribbon-right {\n    left: auto;\n    right: -90px;\n    -webkit-transform: rotate(45deg);\n    -ms-transform: rotate(45deg);\n    -o-transform: rotate(45deg);\n    transform: rotate(45deg);\n}\n\n.ribbon-badge.ribbon-bottom {\n    top: auto;\n    bottom: 15px;\n    -webkit-transform: rotate(45deg);\n    -ms-transform: rotate(45deg);\n    -o-transform: rotate(45deg);\n    transform: rotate(45deg);\n}\n\n.ribbon-badge.ribbon-right.ribbon-bottom {\n    -webkit-transform: rotate(-45deg);\n    -ms-transform: rotate(-45deg);\n    -o-transform: rotate(-45deg);\n    transform: rotate(-45deg);\n}\n\n.ribbon-corner {\n    top: 0;\n    left: 0;\n    background-color: transparent!important;\n    padding: 6px 0 0 10px;\n}\n\n.ribbon-corner i {\n    position: relative;\n}\n\n.ribbon-corner:before {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 0;\n    height: 0;\n    content: '';\n    border: 30px solid transparent;\n    border-top-color: $themecolor;\n    border-left-color: $themecolor;\n    ;\n}\n\n.ribbon-corner.ribbon-right:before {\n    right: 0;\n    left: auto;\n    border-right-color: #526069;\n    border-left-color: transparent;\n}\n\n.ribbon-corner.ribbon-right {\n    right: 0;\n    left: auto;\n    padding: 6px 10px 0 0;\n}\n\n.ribbon-corner.ribbon-bottom:before {\n    top: auto;\n    bottom: 0;\n    border-top-color: transparent;\n    border-bottom-color: #526069;\n}\n\n.ribbon-corner.ribbon-bottom {\n    bottom: 0;\n    top: auto;\n    padding: 0 10px 6px 10px;\n}\n\n.ribbon-custom {\n    background: $themecolor;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-custom:before {\n    border-right-color: $themecolor;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-custom:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-custom:before {\n    border-right-color: $themecolor;\n    border-bottom-color: transparent;\n}\n\n.ribbon-primary {\n    background: $primary;\n}\n\n.ribbon-bookmark.ribbon-primary:before {\n    border-color: $primary;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-primary:before {\n    border-right-color: $primary;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-primary:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-primary:before {\n    border-right-color: $primary;\n    border-bottom-color: transparent;\n}\n\n.ribbon-primary.ribbon-corner:before {\n    border-top-color: $primary;\n    border-left-color: $primary;\n}\n\n.ribbon-primary.ribbon-corner.ribbon-right:before {\n    border-right-color: $primary;\n    border-left-color: transparent;\n}\n\n.ribbon-primary.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $primary;\n}\n\n.ribbon-success {\n    background: $success;\n}\n\n.ribbon-bookmark.ribbon-success:before {\n    border-color: $success;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-success:before {\n    border-right-color: $success;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-success:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-success:before {\n    border-right-color: $success;\n    border-bottom-color: transparent;\n}\n\n.ribbon-success.ribbon-corner:before {\n    border-top-color: $success;\n    border-left-color: $success;\n}\n\n.ribbon-success.ribbon-corner.ribbon-right:before {\n    border-right-color: $success;\n    border-left-color: transparent;\n}\n\n.ribbon-success.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $success;\n}\n\n.ribbon-info {\n    background: $info;\n}\n\n.ribbon-bookmark.ribbon-info:before {\n    border-color: $info;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-info:before {\n    border-right-color: $info;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-info:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-info:before {\n    border-right-color: $info;\n    border-bottom-color: transparent;\n}\n\n.ribbon-info.ribbon-corner:before {\n    border-top-color: $info;\n    border-left-color: $info;\n}\n\n.ribbon-info.ribbon-corner.ribbon-right:before {\n    border-right-color: $info;\n    border-left-color: transparent;\n}\n\n.ribbon-info.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $info;\n}\n\n.ribbon-warning {\n    background: $warning;\n}\n\n.ribbon-bookmark.ribbon-warning:before {\n    border-color: $warning;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-warning:before {\n    border-right-color: $warning;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-warning:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-warning:before {\n    border-right-color: $warning;\n    border-bottom-color: transparent;\n}\n\n.ribbon-warning.ribbon-corner:before {\n    border-top-color: $warning;\n    border-left-color: $warning;\n}\n\n.ribbon-warning.ribbon-corner.ribbon-right:before {\n    border-right-color: $warning;\n    border-left-color: transparent;\n}\n\n.ribbon-warning.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $warning;\n}\n\n.ribbon-danger {\n    background: $danger;\n}\n\n.ribbon-bookmark.ribbon-danger:before {\n    border-color: $danger;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-danger:before {\n    border-right-color: $danger;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-danger:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-danger:before {\n    border-right-color: $danger;\n    border-bottom-color: transparent;\n}\n\n.ribbon-danger.ribbon-corner:before {\n    border-top-color: $danger;\n    border-left-color: $danger;\n}\n\n.ribbon-danger.ribbon-corner.ribbon-right:before {\n    border-right-color: $danger;\n    border-left-color: transparent;\n}\n\n.ribbon-danger.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $danger;\n}\n\n.ribbon-default {\n    background: $dark;\n}\n\n.ribbon-bookmark.ribbon-default:before {\n    border-color: $dark;\n    border-right-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-right.ribbon-default:before {\n    border-right-color: $dark;\n    border-left-color: transparent;\n}\n\n.ribbon-bookmark.ribbon-vertical-l.ribbon-default:before,\n.ribbon-bookmark.ribbon-vertical-r.ribbon-default:before {\n    border-right-color: $dark;\n    border-bottom-color: transparent;\n}\n\n.ribbon-default.ribbon-corner:before {\n    border-top-color: $dark;\n    border-left-color: $dark;\n}\n\n.ribbon-default.ribbon-corner.ribbon-right:before {\n    border-right-color: $dark;\n    border-left-color: transparent;\n}\n\n.ribbon-default.ribbon-corner.ribbon-bottom:before {\n    border-top-color: transparent;\n    border-bottom-color: $dark;\n}\n\n\n/*******************\nsession ideal timeout page\n******************/\n\n#idletimeout {\n    background: $themecolor;\n    border: 3px solid $themecolor;\n    color: #fff;\n    font-family: arial, sans-serif;\n    text-align: center;\n    font-size: 12px;\n    padding: 10px;\n    position: relative;\n    top: 0px;\n    left: 0;\n    right: 0;\n    z-index: 100000;\n    display: none;\n}\n\n#idletimeout a {\n    color: $white;\n    font-weight: bold\n}\n\n#idletimeout span {\n    font-weight: bold\n}\n\n\n/*******************\nStylish tooltip\n******************/\n\n//colors for tooltips\n$black_10: rgba(0, 0, 0, 0.1);\n$color_outer_space_20_approx: rgba(48, 54, 61, 0.2);\n$color_baltic_sea_approx: #2b2b2b;\n$color_charade_approx: #2a3035;\n$color_vivid_tangerine_approx: $themecolor;\n$color_cerulean_approx: #00aeef;\n//urls\n$url_0: url(../../assets/images/tooltip/tooltip1.svg);\n$url_1: url(../../assets/images/tooltip/shape1.svg);\n//@extend-elements\n//original selectors\n//.mytooltip:hover .tooltip-content2, .mytooltip:hover .tooltip-content2 i\n%extend_1 {\n    opacity: 1;\n    font-size: 18px;\n    pointer-events: auto;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 0, 0) scale3d(1, 1, 1);\n}\n\n//original selectors\n//.mytooltip:hover .tooltip-content4, .mytooltip:hover .tooltip-text2\n%extend_2 {\n    pointer-events: auto;\n    opacity: 1;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 0, 0);\n}\n\n.mytooltip {\n    display: inline;\n    position: relative;\n    z-index: 9999;\n    &:hover {\n        .tooltip-item::after {\n            pointer-events: auto;\n        }\n        .tooltip-content {\n            pointer-events: auto;\n            opacity: 1;\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: translate3d(0, 0, 0) rotate3d(0, 0, 0, 0);\n        }\n        .tooltip-content2 {\n            @extend %extend_1;\n            i {\n                @extend %extend_1;\n            }\n        }\n        .tooltip-content3 {\n            opacity: 1;\n            pointer-events: auto;\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: scale3d(1, 1, 1);\n        }\n        .tooltip-item2 {\n            color: $white;\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: translate3d(0, -0.5em, 0);\n        }\n        .tooltip-content4 {\n            @extend %extend_2;\n        }\n        .tooltip-text2 {\n            @extend %extend_2;\n        }\n        .tooltip-content5 {\n            opacity: 1;\n            pointer-events: auto;\n            //Instead of the line below you could use @include transition-delay($delay-1, $delay-2, $delay-3, $delay-4, $delay-5, $delay-6, $delay-7, $delay-8, $delay-9, $delay-10)\n            transition-delay: 0s;\n        }\n        .tooltip-text3 {\n            //Instead of the line below you could use @include transition-delay($delay-1, $delay-2, $delay-3, $delay-4, $delay-5, $delay-6, $delay-7, $delay-8, $delay-9, $delay-10)\n            transition-delay: 0s;\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: scale3d(1, 1, 1);\n        }\n        .tooltip-inner2 {\n            //Instead of the line below you could use @include transition-delay($delay-1, $delay-2, $delay-3, $delay-4, $delay-5, $delay-6, $delay-7, $delay-8, $delay-9, $delay-10)\n            transition-delay: 0.3s;\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: translate3d(0, 0, 0);\n        }\n    }\n}\n\n.tooltip-item {\n    background: $black_10;\n    cursor: pointer;\n    display: inline-block;\n    font-weight: 500;\n    padding: 0 10px;\n}\n\n.tooltip-item::after {\n    content: '';\n    position: absolute;\n    width: 360px;\n    height: 20px;\n    bottom: 100%;\n    left: 50%;\n    pointer-events: none;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translateX(-50%);\n}\n\n.tooltip-content {\n    position: absolute;\n    z-index: 9999;\n    width: 360px;\n    left: 50%;\n    margin: 0 0 20px -180px;\n    bottom: 100%;\n    text-align: left;\n    font-size: 14px;\n    line-height: 30px;\n    //Instead of the line below you could use @include box-shadow($shadow-1, $shadow-2, $shadow-3, $shadow-4, $shadow-5, $shadow-6, $shadow-7, $shadow-8, $shadow-9, $shadow-10)\n    box-shadow: -5px -5px 15px $color_outer_space_20_approx;\n    background: $color_baltic_sea_approx;\n    opacity: 0;\n    cursor: default;\n    pointer-events: none;\n    img {\n        position: relative;\n        height: 140px;\n        display: block;\n        float: left;\n        margin-right: 1em;\n    }\n}\n\n.tooltip-effect-5 {\n    .tooltip-content {\n        width: 180px;\n        margin-left: -90px;\n        //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n        transform-origin: 50% calc(106%);\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: rotate3d(0, 0, 1, 15deg);\n        //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n        transition: opacity 0.2s, transform 0.2s;\n        //Instead of the line below you could use @include transition-timing-function($function-1, $function-2, $function-3, $function-4, $function-5, $function-6, $function-7, $function-8, $function-9, $function-10)\n        transition-timing-function: ease, cubic-bezier(0.17, 0.67, 0.4, 1.39);\n    }\n    .tooltip-text {\n        padding: 1.4em;\n    }\n}\n\n.tooltip-content::after {\n    content: '';\n    top: 100%;\n    left: 50%;\n    border: solid transparent;\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n    border-color: transparent;\n    border-top-color: $color_charade_approx;\n    border-width: 10px;\n    margin-left: -10px;\n}\n\n.tooltip-text {\n    font-size: 14px;\n    line-height: 24px;\n    display: block;\n    padding: 1.31em 1.21em 1.21em 0;\n    color: $white;\n}\n\n.tooltip-content2 {\n    position: absolute;\n    z-index: 9999;\n    width: 80px;\n    height: 80px;\n    padding-top: 25px;\n    left: 50%;\n    margin-left: -40px;\n    bottom: 100%;\n    //Instead of the line below you could use @include border-radius($radius, $vertical-radius)\n    border-radius: 50%;\n    text-align: center;\n    background: $color_vivid_tangerine_approx;\n    color: $white;\n    opacity: 0;\n    margin-bottom: 20px;\n    cursor: default;\n    pointer-events: none;\n    i {\n        opacity: 0;\n    }\n}\n\n.tooltip-effect-6 {\n    .tooltip-content2 {\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: translate3d(0, 10px, 0) rotate3d(1, 1, 1, 45deg);\n        //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n        transform-origin: 50% 100%;\n        //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n        transition: opacity 0.3s, transform 0.3s;\n        i {\n            //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n            transform: scale3d(0, 0, 1);\n            //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n            transition: opacity 0.3s, transform 0.3s;\n        }\n    }\n    &:hover .tooltip-content2 i {\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: rotate3d(1, 1, 1, 0);\n    }\n}\n\n.tooltip-content2::after {\n    content: '';\n    position: absolute;\n    top: 100%;\n    left: 50%;\n    margin: -7px 0 0 -15px;\n    width: 30px;\n    height: 20px;\n    background: $url_0 no-repeat center center;\n    background-size: 100%;\n}\n\n.tooltip-content3 {\n    position: absolute;\n    background: $url_1 no-repeat center bottom;\n    background-size: 100% 100%;\n    z-index: 9999;\n    width: 200px;\n    bottom: 100%;\n    left: 50%;\n    margin-left: -100px;\n    padding: 50px 30px;\n    text-align: center;\n    color: $white;\n    opacity: 0;\n    cursor: default;\n    font-size: 14;\n    line-height: 27px;\n    pointer-events: none;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: scale3d(0.1, 0.2, 1);\n    //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n    transform-origin: 50% 120%;\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.4s, transform 0.4s;\n    //Instead of the line below you could use @include transition-timing-function($function-1, $function-2, $function-3, $function-4, $function-5, $function-6, $function-7, $function-8, $function-9, $function-10)\n    transition-timing-function: ease, cubic-bezier(0.6, 0, 0.4, 1);\n}\n\n.tooltip-content3::after {\n    content: '';\n    position: absolute;\n    width: 16px;\n    height: 16px;\n    left: 50%;\n    margin-left: -8px;\n    top: 100%;\n    background: $color_cerulean_approx;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, -60%, 0) rotate3d(0, 0, 1, 45deg);\n}\n\n.tooltip-item2 {\n    color: $color_cerulean_approx;\n    cursor: pointer;\n    z-index: 100;\n    position: relative;\n    display: inline-block;\n    font-weight: 500;\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: background-color 0.3s, color 0.3s, transform 0.3s;\n}\n\n.tooltip-content4 {\n    position: absolute;\n    z-index: 99;\n    width: 360px;\n    left: 50%;\n    margin-left: -180px;\n    bottom: -5px;\n    text-align: left;\n    background: $color_cerulean_approx;\n    opacity: 0;\n    font-size: 14px;\n    line-height: 27px;\n    padding: 1.5em;\n    color: $white;\n    border-bottom: 55px solid $color_baltic_sea_approx;\n    cursor: default;\n    pointer-events: none;\n    //Instead of the line below you could use @include border-radius($radius, $vertical-radius)\n    border-radius: 5px;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, -0.5em, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n    a {\n        color: $color_baltic_sea_approx;\n    }\n}\n\n.tooltip-text2 {\n    opacity: 0;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 1.5em, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n}\n\n.tooltip-content5 {\n    position: absolute;\n    z-index: 9999;\n    width: 300px;\n    left: 50%;\n    bottom: 100%;\n    font-size: 20px;\n    line-height: 1.4;\n    text-align: center;\n    font-weight: 400;\n    color: $white;\n    background: transparent;\n    opacity: 0;\n    margin: 0 0 20px -150px;\n    cursor: default;\n    pointer-events: none;\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s 0.3s;\n    span {\n        display: block;\n    }\n}\n\n.tooltip-text3 {\n    border-bottom: 10px solid $color_vivid_tangerine_approx;\n    overflow: hidden;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: scale3d(0, 1, 1);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: transform 0.3s 0.3s;\n}\n\n.tooltip-inner2 {\n    background: $color_baltic_sea_approx;\n    padding: 40px;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 100%, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: transform 0.3s;\n}\n\n.tooltip-content5::after {\n    content: '';\n    bottom: -20px;\n    left: 50%;\n    border: solid transparent;\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n    border-color: transparent;\n    border-top-color: $color_vivid_tangerine_approx;\n    border-width: 10px;\n    margin-left: -10px;\n}\n\n.tooltip-effect-1 .tooltip-content {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, -10px, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n    color: $white;\n}\n\n.tooltip-effect-2 .tooltip-content {\n    //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n    transform-origin: 50% calc(110%);\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: perspective(1000px) rotate3d(1, 0, 0, 45deg);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.2s, transform 0.2s;\n}\n\n.tooltip-effect-3 .tooltip-content {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 10px, 0) rotate3d(1, 1, 0, 25deg);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n}\n\n.tooltip-effect-4 .tooltip-content {\n    //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n    transform-origin: 50% 100%;\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: scale3d(0.7, 0.3, 1);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.2s, transform 0.2s;\n}\n\n.tooltip.tooltip-effect-2:hover .tooltip-content {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: perspective(1000px) rotate3d(1, 0, 0, 0deg);\n}\n\na.mytooltip {\n    font-weight: 500;\n    color: $color_vivid_tangerine_approx;\n}\n\n.tooltip-effect-7 .tooltip-content2 {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 10px, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n    i {\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: translate3d(0, 15px, 0);\n        //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n        transition: opacity 0.3s, transform 0.3s;\n    }\n}\n\n.tooltip-effect-8 .tooltip-content2 {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, 10px, 0) rotate3d(0, 1, 0, 90deg);\n    //Instead of the line below you could use @include transform-origin($origin-x, $origin-y, $origin-z, $only3d)\n    transform-origin: 50% 100%;\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n    i {\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: scale3d(0, 0, 1);\n        //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n        transition: opacity 0.3s, transform 0.3s;\n    }\n}\n\n.tooltip-effect-9 .tooltip-content2 {\n    //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n    transform: translate3d(0, -20px, 0);\n    //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n    transition: opacity 0.3s, transform 0.3s;\n    i {\n        //Instead of the line below you could use @include transform($scale, $rotate, $transx, $transy, $skewx, $skewy, $originx, $originy)\n        transform: translate3d(0, 20px, 0);\n        //Instead of the line below you could use @include transition($transition-1, $transition-2, $transition-3, $transition-4, $transition-5, $transition-6, $transition-7, $transition-8, $transition-9, $transition-10)\n        transition: opacity 0.3s, transform 0.3s;\n    }\n}\n\n\n/*******************\nError Page\n******************/\n\n.error-box {\n    height: 100%;\n    position: fixed;\n    background: #fff;\n    width: 100%;\n    .footer {\n        width: 100%;\n        left: 0px;\n        right: 0px;\n    }\n}\n\n.error-body {\n    padding-top: 5%;\n    h1 {\n        font-size: 210px;\n        font-weight: 900;\n        line-height: 210px;\n    }\n}\n\n\n/*******************\ngoogle map Page\n******************/\n\n.gmaps,\n.gmaps-panaroma {\n    height: 300px;\n}\n\n.gmaps,\n.gmaps-panaroma {\n    height: 300px;\n    background: $light;\n    border-radius: 3px;\n}\n\n.gmaps-overlay {\n    display: block;\n    text-align: center;\n    color: $white;\n    font-size: 16px;\n    line-height: 40px;\n    background: $primary;\n    border-radius: 4px;\n    padding: 10px 20px;\n}\n\n.gmaps-overlay_arrow {\n    left: 50%;\n    margin-left: -16px;\n    width: 0;\n    height: 0;\n    position: absolute;\n}\n\n.gmaps-overlay_arrow.above {\n    bottom: -15px;\n    border-left: 16px solid transparent;\n    border-right: 16px solid transparent;\n    border-top: 16px solid $primary;\n}\n\n.gmaps-overlay_arrow.below {\n    top: -15px;\n    border-left: 16px solid transparent;\n    border-right: 16px solid transparent;\n    border-bottom: 16px solid $primary;\n}\n\n\n/*******************\nvector map Page\n******************/\n\n.jvectormap-zoomin,\n.jvectormap-zoomout {\n    width: 10px;\n    height: 10px;\n    line-height: 10px;\n}\n\n.jvectormap-zoomout {\n    top: 40px;\n}\n\n\n/*******************\nSeach listing Page\n******************/\n\n.search-listing {\n    padding: 0px;\n    margin: 0px;\n    li {\n        list-style: none;\n        padding: 15px 0;\n        border-bottom: 1px solid $border;\n        h3 {\n            margin: 0px;\n            font-size: 18px;\n            a {\n                color: $info;\n                &:hover {\n                    text-decoration: underline;\n                }\n            }\n        }\n        a {\n            color: $success;\n        }\n    }\n}\n\n\n/*******************\nLogin register and recover password Page\n******************/\n\n.login-register {\n    background-size: cover;\n    background-repeat: no-repeat;\n    background-position: center center;\n    height: 100%;\n    width: 100%;\n    padding: 10% 0;\n    position: fixed;\n}\n\n.login-box {\n    width: 400px;\n    margin: 0 auto;\n    .footer {\n        width: 100%;\n        left: 0px;\n        right: 0px;\n    }\n    .social {\n        display: block;\n        margin-bottom: 30px;\n    }\n}\n\n#recoverform {\n    display: none;\n}\n\n.login-sidebar {\n    padding: 0px;\n    margin-top: 0px;\n    .login-box {\n        right: 0px;\n        position: absolute;\n        height: 100%;\n    }\n}\n\n\n/*******************\nFAQs Page\n******************/\n\n.minimal-faq {\n    .card {\n        border: 0px;\n        .card-header {\n            background: $white;\n            padding: 20px 0;\n            margin-top: 10px;\n        }\n        .card-block {\n            padding: 15px 0px;\n        }\n    }\n}\n\n\n/*******************\nPricing Page\n******************/\n\n.pricing-box {\n    position: relative;\n    text-align: center;\n    margin-top: 30px;\n}\n\n.featured-plan {\n    margin-top: 0px;\n    .pricing-body {\n        padding: 60px 0;\n        background: $extra-light;\n        border: 1px solid #ddd;\n    }\n    .price-table-content .price-row {\n        border-top: 1px solid rgba(120, 130, 140, 0.13);\n    }\n}\n\n.pricing-body {\n    border-radius: 0px;\n    border-top: 1px solid rgba(120, 130, 140, 0.13);\n    border-bottom: 5px solid rgba(120, 130, 140, 0.13);\n    vertical-align: middle;\n    padding: 30px 0;\n    position: relative;\n}\n\n.pricing-body h2 {\n    position: relative;\n    font-size: 56px;\n    margin: 20px 0 10px;\n    font-weight: 500;\n    span {\n        position: absolute;\n        font-size: 15px;\n        top: -10px;\n        margin-left: -10px\n    }\n}\n\n.price-table-content {\n    .price-row {\n        padding: 20px 0;\n        border-top: 1px solid rgba(120, 130, 140, 0.13);\n    }\n}\n\n.pricing-plan {\n    padding: 0 15px;\n    .no-padding {\n        padding: 0px;\n    }\n}\n\n.price-lable {\n    position: absolute;\n    top: -10px;\n    padding: 5px 10px;\n    margin: 0 auto;\n    display: inline-block;\n    width: 100px;\n    left: 0px;\n    right: 0px;\n}\n\n\n/*******************\nchat application Page\n******************/\n\n.chat-main-box {\n    position: relative;\n    overflow: hidden;\n    .chat-left-aside {\n        position: relative;\n        width: 250px;\n        float: left;\n        z-index: 9;\n        top: 0px;\n        border-right: 1px solid $border;\n        .open-panel {\n            display: none;\n            cursor: pointer;\n            position: absolute;\n            left: -webkit-calc(100% - 1px);\n            top: 50%;\n            z-index: 100;\n            background-color: #fff;\n            -webkit-box-shadow: 1px 0 3px rgba(0, 0, 0, .2);\n            box-shadow: 1px 0 3px rgba(0, 0, 0, .2);\n            border-radius: 0 100px 100px 0;\n            line-height: 1;\n            padding: 15px 8px 15px 4px;\n        }\n        .chat-left-inner {\n            position: relative;\n            .form-control {\n                height: 60px;\n            }\n            .style-none {\n                padding: 0px;\n                li {\n                    list-style: none;\n                    overflow: hidden;\n                    a {\n                        padding: 20px;\n                        &:hover,\n                        &.active {\n                            background: $extra-light;\n                        }\n                    }\n                }\n            }\n        }\n    }\n    .chat-right-aside {\n        width: calc(100% - 250px);\n        float: left;\n        .chat-list {\n            max-height: none;\n            height: 100%;\n            padding-top: 40px;\n            .chat-text {\n                border-radius: 6px;\n            }\n        }\n        .send-chat-box {\n            position: relative;\n            .form-control {\n                border: none;\n                border-top: 1px solid $border;\n                resize: none;\n                height: 80px;\n                padding-right: 180px;\n                &:focus {\n                    border-color: $border;\n                }\n            }\n            .custom-send {\n                position: absolute;\n                right: 20px;\n                bottom: 10px;\n                .cst-icon {\n                    color: $bodytext;\n                    margin-right: 10px;\n                }\n            }\n        }\n    }\n}\n\n\n/*******************\nEmail inbox Page\n******************/\n\n.inbox-panel {\n    .list-group {\n        .list-group-item {\n            border: 0px;\n            border-radius: 0px;\n            border-left: 3px solid transparent;\n            a {\n                color: $bodytext;\n            }\n            &.active,\n            &:hover {\n                background: $light;\n                border-left: 3px solid $themecolor;\n            }\n            &:hover {}\n        }\n    }\n}\n\n.inbox-center {\n    .unread td {\n        font-weight: 400;\n    }\n    td {\n        vertical-align: middle;\n        white-space: nowrap;\n    }\n    .max-texts {}\n    a {\n        color: $bodytext;\n        padding: 2px 0 3px 0;\n        overflow: hidden;\n        vertical-align: middle;\n        text-overflow: ellipsis;\n        white-space: nowrap;\n        display: inline-block;\n    }\n    .checkbox {\n        margin-top: -13px;\n        height: 20px;\n    }\n}\n\n\n/*******************\nContact app Page\n******************/\n\n\n/*left-aside-column*/\n\n.contact-page-aside {\n    position: relative;\n}\n\n.left-aside {\n    position: absolute;\n    border-right: 1px solid $border;\n    padding: 20px;\n    width: 250px;\n    height: 100%;\n}\n\n.right-aside {\n    padding: 20px;\n    margin-left: 250px;\n}\n\n.contact-list {\n    td {\n        vertical-align: middle;\n        padding: 25px 10px;\n        img {\n            width: 30px;\n        }\n    }\n}\n\n.list-style-none {\n    margin: 0px;\n    padding: 0px;\n    li {\n        list-style: none;\n        margin: 0px;\n        &.box-label a {\n            font-weight: 500;\n        }\n        &.divider {\n            margin: 10px 0;\n            height: 1px;\n            background: $border;\n        }\n        a {\n            padding: 15px 10px;\n            display: block;\n            color: $bodytext;\n            &:hover {\n                color: $themecolor;\n            }\n            span {\n                float: $rgt;\n            }\n        }\n    }\n}\n\n.slimScrollBar {\n    z-index: 10!important;\n}\n\n.carousel-item-next,\n.carousel-item-prev,\n.carousel-item.active {\n    display: block;\n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/prepros-6.config",
    "content": "{\n  \"name\": \"scss\",\n  \"firstRun\": false,\n  \"exportConfig\": true,\n  \"fileConfigs\": [\n    {\n      \"path\": \"style.scss\",\n      \"configJson\": \"{\\\"forceCompile\\\":false,\\\"customOutput\\\":\\\"../css/style.css\\\",\\\"autoCompile\\\":true,\\\"sourceMap\\\":false,\\\"compiler-node-sass\\\":{\\\"enabled\\\":true,\\\"outputStyle\\\":\\\"nested\\\"},\\\"compiler-autoprefixer\\\":{\\\"enabled\\\":true},\\\"compiler-minify-css\\\":{\\\"enabled\\\":false}}\"\n    },\n    {\n      \"path\": \"colors/blue.scss\",\n      \"configJson\": \"{\\\"forceCompile\\\":false,\\\"customOutput\\\":\\\"../css/colors/blue.css\\\",\\\"autoCompile\\\":true,\\\"sourceMap\\\":false,\\\"compiler-node-sass\\\":{\\\"enabled\\\":true,\\\"outputStyle\\\":\\\"nested\\\"},\\\"compiler-autoprefixer\\\":{\\\"enabled\\\":true},\\\"compiler-minify-css\\\":{\\\"enabled\\\":false}}\"\n    }\n  ],\n  \"fileTree\": {\n    \"expandedDirs\": [\n      \"colors\"\n    ],\n    \"hideSystemFiles\": true,\n    \"systemFiles\": [\n      \".*\",\n      \"desktop.ini\",\n      \"prepros.config\",\n      \"$RECYCLE.BIN\",\n      \"prepros.cfg\",\n      \"prepros-6.config\",\n      \"Prepros Export\"\n    ],\n    \"hideUnwatchedFiles\": false\n  },\n  \"imports\": [\n    {\n      \"path\": \"material.scss\",\n      \"imports\": [\n        \"variable.scss\"\n      ]\n    },\n    {\n      \"path\": \"style.scss\",\n      \"imports\": [\n        \"variable.scss\",\n        \"app.scss\",\n        \"pages.scss\",\n        \"sidebar.scss\",\n        \"icons/font-awesome/css/font-awesome.min.css\",\n        \"icons/simple-line-icons/css/simple-line-icons.css\",\n        \"icons/weather-icons/css/weather-icons.min.css\",\n        \"icons/linea-icons/linea.css\",\n        \"icons/themify-icons/themify-icons.css\",\n        \"icons/flag-icon-css/flag-icon.min.css\",\n        \"icons/material-design-iconic-font/css/materialdesignicons.min.css\",\n        \"widgets.scss\",\n        \"grid.scss\",\n        \"responsive.scss\",\n        \"material.scss\",\n        \"../css/spinners.css\",\n        \"../css/animate.css\"\n      ]\n    },\n    {\n      \"path\": \"colors/blue.scss\",\n      \"imports\": [\n        \"variable.scss\"\n      ]\n    }\n  ],\n  \"projectView\": {\n    \"selectedView\": \"file-tree\"\n  },\n  \"fileWatcher\": {\n    \"enabled\": true,\n    \"watchedExtensions\": [\n      \"less\",\n      \"sass\",\n      \"scss\",\n      \"styl\",\n      \"md\",\n      \"markdown\",\n      \"coffee\",\n      \"js\",\n      \"jade\",\n      \"haml\",\n      \"slim\",\n      \"ls\",\n      \"kit\",\n      \"png\",\n      \"jpg\",\n      \"jpeg\",\n      \"ts\",\n      \"pug\",\n      \"css\",\n      \"html\",\n      \"htm\",\n      \"php\"\n    ]\n  },\n  \"pathFilters\": [\n    \"node_modules\",\n    \".*\",\n    \"bower_components\",\n    \"prepros.config\",\n    \"Prepros Export\",\n    \"prepros-6.config\",\n    \"prepros.cfg\",\n    \"wp-admin\",\n    \"wp-includes\"\n  ],\n  \"server\": {\n    \"port\": 7879,\n    \"assignNewPortAutomatically\": true,\n    \"enable\": true,\n    \"proxy\": {\n      \"enable\": false,\n      \"url\": \"\"\n    }\n  },\n  \"browser-sync\": {\n    \"enable\": false,\n    \"clicks\": true,\n    \"forms\": true,\n    \"scroll\": true\n  },\n  \"live-reload\": {\n    \"enable\": true,\n    \"animate\": true,\n    \"delay\": 0\n  },\n  \"ftp-deploy\": {\n    \"connectionType\": \"ftp\",\n    \"remotePath\": \"\",\n    \"uploadTimeout\": 20000,\n    \"uploadOnChange\": false,\n    \"ftp\": {\n      \"secure\": false,\n      \"host\": \"\",\n      \"port\": 21,\n      \"user\": \"\",\n      \"password\": \"\"\n    },\n    \"sftp\": {\n      \"host\": \"\",\n      \"port\": 22,\n      \"usePrivateKey\": false,\n      \"username\": \"\",\n      \"password\": \"\",\n      \"privateKey\": \"\",\n      \"passphrase\": \"\"\n    },\n    \"pathFilters\": [\n      \"config.rb\",\n      \"prepros.config\",\n      \"prepros-6.config\",\n      \"node_modules\",\n      \"Prepros Export\",\n      \".git\",\n      \".idea\",\n      \".sass-cache\",\n      \".hg\",\n      \".svn\",\n      \".cache\",\n      \".DS_Store\",\n      \"*.sass\",\n      \"*.scss\",\n      \"*.less\",\n      \"*.pug\",\n      \"*.jade\",\n      \"*.styl\",\n      \"*.haml\",\n      \"*.slim\",\n      \"*.coffee\",\n      \"*.ls\",\n      \"*.kit\",\n      \"*.ts\"\n    ],\n    \"history\": []\n  },\n  \"file-type-sass\": \"{\\\"compilers\\\":[\\\"node-sass\\\",\\\"autoprefixer\\\",\\\"minify-css\\\"]}\",\n  \"file-type-less\": \"{\\\"compilers\\\":[\\\"less\\\",\\\"autoprefixer\\\",\\\"minify-css\\\"]}\",\n  \"autoprefixer\": {\n    \"browsers\": \"last 5 versions\"\n  },\n  \"file-type-pug\": \"{\\\"compilers\\\":[\\\"pug\\\"]}\",\n  \"file-type-css\": \"{\\\"compilers\\\":[\\\"autoprefixer\\\",\\\"cssnext\\\",\\\"minify-css\\\"]}\",\n  \"file-type-javascript\": \"{\\\"compilers\\\":[\\\"concat-js\\\",\\\"babel\\\",\\\"uglify-js\\\"]}\",\n  \"file-type-stylus\": \"{\\\"compilers\\\":[\\\"stylus\\\",\\\"autoprefixer\\\",\\\"minify-css\\\"]}\",\n  \"file-type-markdown\": \"{\\\"compilers\\\":[\\\"markdown\\\"]}\",\n  \"file-type-haml\": \"{\\\"compilers\\\":[\\\"haml\\\"]}\",\n  \"file-type-slim\": \"{\\\"compilers\\\":[\\\"slim\\\"]}\",\n  \"file-type-coffee-script\": \"{\\\"compilers\\\":[\\\"coffee-script\\\",\\\"uglify-js\\\"]}\",\n  \"file-type-livescript\": \"{\\\"compilers\\\":[\\\"livescript\\\",\\\"uglify-js\\\"]}\",\n  \"file-type-kit\": \"{\\\"compilers\\\":[\\\"kit\\\"]}\",\n  \"uglify-js\": {\n    \"ie8\": false,\n    \"compress\": {\n      \"sequences\": true,\n      \"properties\": true,\n      \"dead_code\": true,\n      \"drop_debugger\": true,\n      \"unsafe\": false,\n      \"unsafe_comps\": false,\n      \"unsafe_math\": false,\n      \"unsafe_proto\": false,\n      \"unsafe_regexp\": false,\n      \"conditionals\": true,\n      \"comparisons\": true,\n      \"evaluate\": true,\n      \"booleans\": true,\n      \"loops\": true,\n      \"unused\": true,\n      \"toplevel\": false,\n      \"top_retain\": \"\",\n      \"hoist_funs\": true,\n      \"hoist_vars\": false,\n      \"if_return\": true,\n      \"join_vars\": true,\n      \"cascade\": true,\n      \"collapse_vars\": true,\n      \"reduce_vars\": true,\n      \"warnings\": true,\n      \"negate_iife\": true,\n      \"pure_getters\": false,\n      \"pure_funcs\": [],\n      \"drop_console\": false,\n      \"expression\": false,\n      \"keep_fargs\": true,\n      \"keep_fnames\": false,\n      \"passes\": 1,\n      \"keep_infinity\": false,\n      \"side_effects\": true,\n      \"global_defs\": []\n    },\n    \"output\": {\n      \"ascii_only\": false,\n      \"beautify\": true,\n      \"bracketize\": false,\n      \"comments\": \"\",\n      \"indent_level\": 4,\n      \"indent_start\": 0,\n      \"inline_script\": false,\n      \"keep_quoted_props\": false,\n      \"max_line_len\": false,\n      \"preamble\": \"\",\n      \"preserve_line\": false,\n      \"quote_keys\": false,\n      \"quote_style\": 0,\n      \"semicolons\": true,\n      \"shebang\": true,\n      \"width\": 80\n    }\n  },\n  \"cssnext\": {\n    \"customProperties\": true,\n    \"applyRule\": true,\n    \"calc\": false,\n    \"nesting\": true,\n    \"customMedia\": true,\n    \"mediaQueriesRange\": true,\n    \"customSelectors\": true,\n    \"attributeCaseInsensitive\": true,\n    \"colorRebeccapurple\": true,\n    \"colorHwb\": true,\n    \"colorGray\": true,\n    \"colorHexAlpha\": true,\n    \"colorFunction\": true,\n    \"fontVariant\": true,\n    \"filter\": true,\n    \"initial\": true,\n    \"rem\": true,\n    \"pseudoElements\": true,\n    \"pseudoClassMatches\": true,\n    \"pseudoClassNot\": true,\n    \"pseudoClassAnyLink\": true,\n    \"colorRgba\": true,\n    \"overflowWrap\": true\n  },\n  \"file-type-typescript\": \"{\\\"compilers\\\":[\\\"typescript\\\",\\\"uglify-js\\\"]}\",\n  \"babel\": {\n    \"useBabelRc\": true,\n    \"presets\": {\n      \"babel-preset-es2015\": true\n    },\n    \"plugins\": {\n      \"babel-plugin-syntax-jsx\": true,\n      \"babel-plugin-transform-react-jsx\": true,\n      \"babel-plugin-transform-async-to-generator\": true,\n      \"babel-plugin-transform-class-properties\": true,\n      \"babel-plugin-transform-object-rest-spread\": true\n    }\n  },\n  \"file-type-png\": \"{\\\"compilers\\\":[\\\"png\\\"]}\",\n  \"file-type-jpg\": \"{\\\"compilers\\\":[\\\"jpg\\\"]}\"\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/responsive.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n/*============================================================== \n For Laptop & above all (1650px) \n ============================================================== */\n\n@media(min-width:1650px) {\n    .widget-app-columns {\n      column-count:3; \n    } \n    .campaign{\n        height: 365px!important;\n    }\n}\n/*============================================================== \n For Laptop & above all (1370px) \n ============================================================== */\n\n@media(max-width:1370px) {\n    .widget-app-columns {\n      column-count:2;\n    }  \n}\n\n\n/*-- ============================================================== \n Small Desktop & above all (1024px) \n ============================================================== */\n\n@media(min-width:1024px) {\n   .page-wrapper{\n        margin-left:240px;\n        \n    }  \n   .footer{\n            left: 240px;\n      } \n    \n}\n\n@media(max-width:1023px) {\n   .page-wrapper{\n        margin-left:60px;\n        transition: 0.2s ease-in;\n    }  \n   .footer{\n            left: 60px;\n      }\n    .widget-app-columns {\n        column-count:1;\n    }\n    .inbox-center a {\n        width: 200px;\n    }\n}\n\n\n/*-- ============================================================== \n Ipad & above all(768px) \n ============================================================== */\n\n@media(min-width:768px) {\n    .navbar-header {\n        width: 240px;\n        flex-shrink:0;\n        .navbar-brand {\n            padding-top: 0px;\n        }\n    }\n    .material-icon-list-demo .icons div {\n        width: 33%;\n        padding: 15px;\n        display: inline-block;\n        line-height: 40px;\n    }\n   .mini-sidebar {\n        .page-wrapper{\n            margin-left:60px;\n        }\n        .footer{\n            left: 60px;\n        }\n    }\n    .flex-wrap{\n        flex-wrap:nowrap!important;\n        -webkit-flex-wrap:nowrap!important;\n    }\n}\n\n\n/*-- ============================================================== \n Phone and below ipad(767px) \n ============================================================== */\n\n@media(max-width:767px) {\n    \n    /*Header*/\n    .topbar {\n        position: fixed;\n        width: 100%;\n        .top-navbar {\n            padding-right: 15px;\n            -webkit-box-orient: horizontal;\n            -webkit-box-direction: normal;\n            flex-direction: row;\n            flex-wrap: nowrap;\n            -webkit-align-items: center;\n            .navbar-collapse {\n                display: flex;\n                width: 100%;\n            }\n            .navbar-nav {\n                flex-direction: row;\n                > .nav-item.show {\n                    position: static;\n                    .dropdown-menu {\n                        width: 100%;\n                        margin-top: 0px;\n                    }\n                }\n                > .nav-item > .nav-link {\n                    padding-left: .50rem;\n                    padding-right: .50rem;\n                }\n                .dropdown-menu {\n                    position: absolute;\n                }\n            }\n        }\n    }\n    .mega-dropdown {\n        .dropdown-menu {\n            height: 480px;\n            overflow: auto;\n        }\n    }\n    /*Sidebar and wrapper*/\n    .mini-sidebar .page-wrapper{\n        margin-left:0px;\n        padding-top: 70px;\n    }\n    .comment-text{\n        .comment-footer{\n            .action-icons {\n                display: block;\n                padding: 10px 0;\n            } \n        }\n    }\n    \n    .vtabs .tabs-vertical {\n        width: auto;\n    }\n    /*Footer*/\n    .footer{\n            left: 0px;\n        }\n    .material-icon-list-demo .icons div {\n        width: 100%;\n    }\n    .error-page{\n        .footer{\n            position: fixed;\n            bottom: 0px;\n            z-index: 10;\n        }\n    }\n    .error-box{\n        position: relative;\n        padding-bottom: 60px;\n    }\n    .error-body{\n        padding-top: 10%;\n           h1{\n              font-size:100px;\n              font-weight:600;\n              line-height:100px;\n           }\n        }\n    .login-register{\n        position: relative;\n        overflow: hidden;\n    }\n    .login-box{\n        width: 90%;\n        \n    }\n    .login-sidebar{\n        padding: 10% 0;\n        .login-box{\n            position: relative;\n        }\n    }\n    \n    /*This is for chat page*/\n    .chat-main-box .chat-left-aside {\n        left: -250px;\n        position: absolute;\n        \n        transition: 0.5s ease-in;\n        background: $white;\n        &.open-pnl {\n            left: 0px;\n        }\n        .open-panel {\n            display: block;\n        }\n    }\n    .chat-main-box .chat-right-aside {\n        width: 100%;\n    }\n    /*Timeline*/\n    ul.timeline:before {\n        left: 40px;\n    }\n    ul.timeline>li>.timeline-panel {\n        width:\"calc(100% - 90px)\";\n        width:\"calc(100% - 90px)\";\n        width:\"calc(100% - 90px)\";\n    }\n    ul.timeline>li>.timeline-badge {\n        top: 16px;\n        left: 15px;\n        margin-left: 0;\n    }\n    ul.timeline>li>.timeline-panel {\n        float: right;\n    }\n    ul.timeline>li>.timeline-panel:before {\n        right: auto;\n        left: -15px;\n        border-right-width: 15px;\n        border-left-width: 0;\n    }\n    ul.timeline>li>.timeline-panel:after {\n        right: auto;\n        left: -14px;\n        border-right-width: 14px;\n        border-left-width: 0;\n    }\n    \n    /*Contact app page*/\n    .left-aside{\n        width: 100%;\n        position: relative;\n        border:0px;\n    }\n    .right-aside{\n        margin-left: 0px;\n    }\n    .flex-wrap{\n        flex-wrap:wrap!important;\n        -webkit-flex-wrap:wrap!important;\n    }\n    .chat-list li .chat-content{\n        width: calc(100% - 80px);\n    }\n}"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/sidebar.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n\n\n/*******************\nMain sidebar\n******************/\n\n.left-sidebar {\n    position: absolute;\n    width: 240px;\n    height: 100%;\n    top: 0px;\n    z-index: 20;\n    padding-top: 70px;\n    background: $sidebar;\n    box-shadow: 1px 0px 20px rgba(0, 0, 0, 0.08);\n}\n\n.fix-sidebar .left-sidebar{\n    position: fixed;\n}\n/*******************\nuse profile section\n******************/\n\n.user-profile {\n    \n    position: relative;\n    background-size:cover;\n    \n    .profile-img {\n        width: 50px;\n        margin-left: 30px;\n        padding: 35px 0;\n        border-radius: 100%;\n        &::before {\n            -webkit-animation: 2.5s blow 0s linear infinite;\n            animation: 2.5s blow 0s linear infinite;\n            position: absolute;\n            content: '';\n            width: 50px;\n            height: 50px;\n            top: 35px;\n            margin: 0 auto;\n            border-radius: 50%;\n            z-index: 0;\n        }\n        @-webkit-keyframes blow {\n            0% {\n                box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n                opacity: 1;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n            50% {\n                box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n                opacity: 1;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n            100% {\n                box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n                opacity: 0;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n        }\n        @keyframes blow {\n            0% {\n                box-shadow: 0 0 0 0px rgba(0, 0, 0, 0.1);\n                opacity: 1;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n            50% {\n                box-shadow: 0 0 0 10px rgba(0, 0, 0, 0.1);\n                opacity: 1;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n            100% {\n                box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.1);\n                opacity: 0;\n                -webkit-transform: scale3d(1, 1, 0.5);\n                transform: scale3d(1, 1, 0.5);\n            }\n        }\n        img {\n            width: 100%;\n            border-radius: 100%;\n        }\n    }\n    .profile-text {\n        padding: 5px 0px;\n        position: relative;\n        > a {\n            color: $white!important;\n            width: 100%;\n            padding: 6px 30px;\n            background: rgba(0, 0, 0, 0.5);\n            display: block;\n            &:after{\n                position: absolute;\n                right: 20px;\n                top:20px;\n            }\n        }\n    }\n    .dropdown-menu {\n        left: 0px;\n        right: 0px;\n        width: 180px;\n        margin: 0 auto;\n    }\n}\n\n\n/*******************\nsidebar footer\n******************/\n\n.sidebar-footer {\n    position: fixed;\n    z-index: 10;\n    bottom: 0px;\n    left: 0px;\n    transition:0.2s ease-out;\n    width: 240px;\n    background: $sidebar;\n    border-top: 1px solid $border;\n    a {\n        padding: 15px;\n        width: 33.333337%;\n        float: left;\n        text-align: center;\n        font-size: 18px;\n    }\n}\n\n\n/*******************\nsidebar navigation\n******************/\n\n.scroll-sidebar {\n    padding-bottom: 60px;\n    \n}\n\n.collapse.in {\n    display: block;\n}\n\n.sidebar-nav {\n    background: $sidebar;\n    padding: 15px;\n    ul {\n        margin: 0px;\n        padding: 0px;\n        li {\n            list-style: none;\n            \n            \n            a {\n                color: $sidebar-text;\n                padding: 8px 35px 8px 15px;\n                display: block;\n                font-size: 15px;\n                border-radius: $radius;\n                white-space: nowrap;\n                &.active,\n                &:hover {\n                    color: $themecolor-alt;\n                }\n                &.active {\n                    font-weight: 500;\n                    color: $dark;\n                }\n            }\n            ul {\n                padding-left: 5px;\n                padding-top: 10px; \n                li a {\n                    padding: 10px 35px 10px 15px;\n                }\n                ul {\n                    padding-left: 15px;\n                    \n                }\n            }\n            &.nav-small-cap {\n                font-size: 12px;\n                margin-bottom: 0px;\n                padding: 14px 14px 14px 20px;\n                color: $dark; \n                font-weight: 500;\n            }\n            &.nav-devider{\n                height: 1px;\n                background: $border;\n                display: block;\n                margin: 20px 0;\n            }\n        }\n    }\n    > ul > li {\n        margin-bottom: 10px;\n        &.active > a {\n            color: $white;\n            font-weight: 500;\n            box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);\n            i {\n                color: $themecolor-alt;\n            }\n        }\n    }\n    > ul > li > a {\n        \n        &.active,\n        &:hover {\n            \n            i {\n                color: $themecolor-alt;\n            }\n        }\n        i {\n            width: 27px;\n            height: 27px;                                                                                                                                                                           \n            font-size: 21px;\n            display: inline-block;\n            vertical-align: middle;\n            color: $sidebar-icons;\n        }\n        .label {\n            float: right;\n            margin-top: 6px;\n        }\n        &.active {\n            font-weight: 400;\n            background: $white;\n            color: $themecolor-alt;\n        }\n    }\n}\n\n.sidebar-nav .has-arrow {\n    position: relative;\n    &::after {\n        position: absolute;\n        content: '';\n        width: .55em;\n        height: .55em;\n        border-width: 1px 0 0 1px;\n        border-style: solid;\n        border-color: $sidebar-text;\n        right: 1em;\n        -webkit-transform: rotate(-45deg) translate(0, -50%);\n        -ms-transform: rotate(-45deg) translate(0, -50%);\n        -o-transform: rotate(-45deg) translate(0, -50%);\n        transform: rotate(-45deg) translate(0, -50%);\n        -webkit-transform-origin: top;\n        -ms-transform-origin: top;\n        -o-transform-origin: top;\n        transform-origin: top;\n        top: 47%;\n        -webkit-transition: all .3s ease-out;\n        -o-transition: all .3s ease-out;\n        transition: all .3s ease-out;\n    }\n}\n\n.sidebar-nav .active > .has-arrow::after,\n.sidebar-nav li > .has-arrow.active::after,\n.sidebar-nav .has-arrow[aria-expanded=\"true\"]::after {\n    -webkit-transform: rotate(-135deg) translate(0, -50%);\n    -ms-transform: rotate(-135deg) translate(0, -50%);\n    -o-transform: rotate(-135deg) translate(0, -50%);\n    top: 45%;\n    width: .58em;\n    transform: rotate(-135deg) translate(0, -50%);\n}\n\n\n/****************\nWhen click on sidebar toggler and also for tablet\n*****************/\n\n@media(min-width:768px) {\n    .mini-sidebar .sidebar-nav #sidebarnav li {\n        position: relative;\n    }\n    .mini-sidebar .sidebar-nav #sidebarnav > li > ul {\n        position: absolute;\n        left: 60px;\n        top: 45px;\n        width: 200px;\n        z-index: 1001;\n        background: $sidebar-alt;\n        display: none;\n        padding-left: 1px;\n    }\n    .mini-sidebar .sidebar-nav {\n        padding: 5px;\n    }\n    .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul {\n        height: auto !important;\n        \n        overflow: auto;\n    }\n    .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul,\n    .mini-sidebar .sidebar-nav #sidebarnav > li:hover > ul.collapse {\n        display: block;\n    }\n    .mini-sidebar .sidebar-nav #sidebarnav > li > a.has-arrow:after {\n        display: none;\n    }\n    .mini-sidebar {\n        .left-sidebar {\n            width: 60px;\n        }\n        .user-profile {\n            padding-bottom: 15px;\n            width: 60px;\n            margin-bottom: 7px;\n            .profile-img{\n                padding: 15px 0 0 0;\n                margin: 0px 0 0 6px;\n                &:before{\n                    top:15px;\n                }\n            }\n        }\n        .scroll-sidebar{\n            padding-bottom: 0px;\n            position: absolute;\n        }\n        .hide-menu,\n        .nav-small-cap,\n        .sidebar-footer,\n        .user-profile .profile-text {\n            display: none;\n        }\n        .nav-devider{\n            width: 50px;\n            }\n        .sidebar-nav{ background: transparent;}\n        .sidebar-nav #sidebarnav > li > a{\n            padding: 9px 15px;\n            width: 50px;\n        }\n        .sidebar-nav #sidebarnav > li:hover > a {\n            width: 260px;\n            background: $themecolor-alt;\n            color: $white;\n            border-color: $themecolor;\n            i {\n                color: $white;\n            }\n            .hide-menu {\n                display: inline;\n            }\n        }\n        .sidebar-nav #sidebarnav > li.active > a{\n            border-color:transparent;\n            &.active{\n                border-color:$themecolor;\n            }\n        }\n    }\n}\n@media(max-width:767px) {\n    .mini-sidebar{\n        .left-sidebar{position: fixed;}\n        .left-sidebar, .sidebar-footer{\n            left:-240px;\n        }\n        &.show-sidebar{\n           .left-sidebar, .sidebar-footer{\n                left:0px;\n            } \n        }\n    }\n    \n}\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/style.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n\n\n/**\n * Table Of Content\n *\n * \t1. Globals\n *\t2. Headers\n *\t3. Navigations\n *\t4. Banners\n *\t5. Footers\n *\t6. app\n *\t7. Widgets\n *\t8. Custom Templates\n */\n\n@import 'variable';\n@import 'app';\n@import 'pages';\n@import 'sidebar';\n@import '../scss/icons/font-awesome/css/font-awesome.min.css';\n@import '../scss/icons/simple-line-icons/css/simple-line-icons.css';\n@import '../scss/icons/weather-icons/css/weather-icons.min.css';\n@import '../scss/icons/linea-icons/linea.css';\n@import '../scss/icons/themify-icons/themify-icons.css';\n@import '../scss/icons/flag-icon-css/flag-icon.min.css';\n@import \"../scss/icons/material-design-iconic-font/css/materialdesignicons.min.css\";\n@import 'widgets';\n@import 'grid';\n@import 'responsive';\n@import 'material';\n@import '../css/spinners.css';\n@import '../css/animate.css';\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/variable.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n// Variables\n@import url('https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700');\n\n$bodyfont:'Poppins', sans-serif;\n$headingfont:'Poppins', sans-serif; \n\n\n/*Theme Colors*/\n\n$topbar: #2196f3;\n$sidebar: #fff;\n$sidebar-white: #e5edef;\n$sidebar-alt:#f2f6f8;\n$bodycolor: #eef5f9;\n$headingtext: #455a64;\n$bodytext: #67757c; \n$sidebar-text: #607d8b;\n$sidebar-icons: #99abb4 ;\n\n$light-text: #a6b7bf;\n$themecolor: #009efb;\n$themecolor-alt: #26c6da;\n$themecolor-dark: #028ee1;\n\n/*bootstrap Color*/\n$danger: #fc4b6c;\n$success: #26c6da;\n$warning: #ffb22b;\n$primary: #7460ee;\n$info: #1e88e5;\n$inverse: #2f3d4a;\n$muted: #99abb4;\n$dark: #263238;\n$light: #f2f4f8;\n$extra-light: #ebf3f5;\n\n/*Light colors*/\n$light-danger: #f9e7eb;\n$light-success: #e8fdeb;\n$light-warning: #fff8ec;\n$light-primary: #f1effd;\n$light-info: #cfecfe;\n$light-inverse: #f6f6f6;\n$light-megna: #e0f2f4; \n\n\n\n$danger-dark: #e6294b;\n$success-dark: #1eacbe;\n$warning-dark: #e9ab2e;\n$primary-dark: #6352ce;\n$info-dark: #028ee1;\n$red-dark: #d61f1f;\n$inverse-dark: #232a37;\n$dark-transparent:rgba(0, 0, 0, 0.05);\n\n$info-shadow: 0 2px 2px 0 rgba(66,165,245,.14), 0 3px 1px -2px rgba(66,165,245,.2), 0 1px 5px 0 rgba(66,165,245,.12);\n$info-shadow-hover:0 14px 26px -12px rgba(23,105,255,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(23,105,255,.2);\n\n$warning-shadow:0 2px 2px 0 rgba(248,194,0,.14), 0 3px 1px -2px rgba(248,194,0,.2), 0 1px 5px 0 rgba(248,194,0,.12);\n$warning-shadow-hover:0 14px 26px -12px rgba(248,194,0,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(248,194,0,.2);\n\n$danger-shadow:0 2px 2px 0 rgba(239,83,80,.14), 0 3px 1px -2px rgba(239,83,80,.2), 0 1px 5px 0 rgba(239,83,80,.12);\n$danger-shadow-hover:0 14px 26px -12px rgba(239,83,80,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(239,83,80,.2);\n\n$success-shadow:0 2px 2px 0 rgba(40,190,189,.14), 0 3px 1px -2px rgba(40,190,189,.2), 0 1px 5px 0 rgba(40,190,189,.12);\n$success-shadow-hover:0 14px 26px -12px rgba(40,190,189,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(40,190,189,.2);\n    \n$primary-shadow:0 2px 2px 0 rgba(116,96,238,.14), 0 3px 1px -2px rgba(116,96,238,.2), 0 1px 5px 0 rgba(116,96,238,.12);\n$primary-shadow-hover:0 14px 26px -12px rgba(116,96,238,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(116,96,238,.2);\n\n$default-shadow:0 2px 2px 0 rgba(169,169,169,.14), 0 3px 1px -2px rgba(169,169,169,.2), 0 1px 5px 0 rgba(169,169,169,.12);\n$default-shadow-hover:0 14px 26px -12px rgba(169,169,169,.42), 0 4px 23px 0 rgba(0,0,0,.12), 0 8px 10px -5px rgba(169,169,169,.2);\n\n/*Normal Color*/\n$white: #ffffff;\n$red: #fb3a3a;\n$yellow: #a0aec4;\n$purple: #7460ee;\n$blue: #02bec9;\n$megna: #00897b;\n\n/*Extra Variable*/\n$rgt: right;\n$lft: left;\n$border: rgba(120, 130, 140, 0.13);\n$table-border:#f3f1f1;\n$card-brd:#d7dfe3;\n$dark-text: #848a96;\n$radius: 4px;\n$form-brd: #d9d9d9;\n/*Preloader*/\n.preloader{\n    width: 100%;\n    height: 100%;\n    top:0px;\n    position: fixed;\n    z-index: 99999;\n    background: #fff;\n    .cssload-speeding-wheel{\n        position: absolute;\n        top: calc(50% - 3.5px);\n        left: calc(50% - 3.5px);\n    }\n}\n\n"
  },
  {
    "path": "src/main/resources/static/dashboard/html/scss/widgets.scss",
    "content": "/*\nTemplate Name: Material Pro Admin\nAuthor: Themedesigner\nEmail: niravjoshi87@gmail.com\nFile: scss\n*/\n\n\n/*******************\n/*User mail widgets*/\n/*******************/\n\n.topbar {\n    .top-navbar {\n        .mailbox {\n            width: 300px;\n            ul {\n                padding: 0px;\n                li {\n                    list-style: none;\n                }\n            }\n        }\n    }\n}\n\n.mailbox {\n    ul li {\n        .drop-title {\n            font-weight: 500;\n            padding: 11px 20px 15px;\n            border-bottom: 1px solid $border;\n        }\n        .nav-link {\n            border-top: 1px solid $border;\n            padding-top: 15px;\n        }\n    }\n    .message-center {\n        height: 200px;\n        overflow: auto;\n        position: relative;\n        a {\n            border-bottom: 1px solid $border;\n            display: block;\n            text-decoration: none;\n            padding: 9px 15px;\n            &:hover {\n                background: $light;\n            }\n            div {\n                white-space: normal;\n            }\n            .user-img {\n                width: 40px;\n                position: relative;\n                display: inline-block;\n                margin: 0 10px 15px 0;\n                img {\n                    width: 100%;\n                }\n                .profile-status {\n                    border: 2px solid $white;\n                    border-radius: 50%;\n                    display: inline-block;\n                    height: 10px;\n                    left: 30px;\n                    position: absolute;\n                    top: 1px;\n                    width: 10px;\n                }\n                .online {\n                    background: $success;\n                }\n                .busy {\n                    background: $danger;\n                }\n                .away {\n                    background: $warning;\n                }\n                .offline {\n                    background: $warning;\n                }\n            }\n            .mail-contnet {\n                display: inline-block;\n                width: 75%;\n                vertical-align: middle;\n                h5 {\n                    margin: 5px 0px 0;\n                }\n                .mail-desc,\n                .time {\n                    font-size: 12px;\n                    display: block;\n                    margin: 1px 0;\n                    text-overflow: ellipsis;\n                    overflow: hidden;\n                    color: $bodytext;\n                    white-space: nowrap;\n                }\n            }\n        }\n    }\n}\n\n\n/*******************\n/*Analytic info sparkline chart page*/\n/*******************/\n\n.analytics-info {\n    li span {\n        font-size: 24px;\n        vertical-align: middle;\n    }\n}\n\n\n/*******************\n/*States row*/\n/*******************/\n\n.stats-row {\n    margin-bottom: 20px;\n    .stat-item {\n        display: inline-block;\n        padding-right: 15px;\n        &+.stat-item {\n            padding-left: 15px;\n            border-left: 1px solid $border;\n        }\n    }\n}\n\n\n/*******************/\n/*Dashboard1 Weather*/\n/*******************/\n\n.city-weather-days {\n    margin: 0px;\n    li {\n        text-align: center;\n        padding: 15px 0;\n        span {\n            display: block;\n            padding: 10px 0 0;\n            color: $muted;\n        }\n        i {\n            display: block;\n            font-size: 20px;\n            color: $themecolor;\n        }\n        h3 {\n            font-weight: 300;\n            margin-top: 5px;\n        }\n    }\n}\n\n\n/*******************/\n/*Comment widgets*/\n/*******************/\n\n.comment-widgets {\n    position: relative;\n    margin-bottom: 10px;\n    .comment-row {\n        border-left: 3px solid $white;\n        padding: 15px;\n        &:hover,\n        &.active {\n            border-color: $themecolor;\n        }\n    }\n}\n\n.comment-text {\n    padding: 15px 15px 15px 20px;\n    &:hover .comment-footer,\n    &.active .comment-footer {\n        .action-icons {\n            visibility: visible;\n        }\n    }\n    p {\n        max-height: 50px;\n        overflow: hidden;\n    }\n}\n\n.comment-footer {\n    .action-icons {\n        visibility: hidden;\n        a {\n            padding-left: 15px;\n            vertical-align: middle;\n            color: $muted;\n            &:hover,\n            &.active {\n                color: $info;\n            }\n        }\n    }\n}\n\n\n/*******************/\n/*To do widgets*/\n/*******************/\n\n.todo-list {\n    li {\n        border: 0px;\n        margin-bottom: 0px;\n        padding: 20px 15px 15px 0px;\n        .checkbox {\n            width: 100%;\n            label {\n                font-weight: 400;\n                color:$headingtext;\n            }\n        }\n        &:last-child {\n            border-bottom: 0px;\n        }\n        .assignedto {\n            padding: 0px 0 0 27px;\n            margin: 0px;\n            li {\n                list-style: none;\n                padding: 0px;\n                display: inline-block;\n                border: 0px;\n                margin-right: 2px;\n                img {\n                    width: 30px;\n                    border-radius: 100%;\n                }\n            }\n        }\n        .item-date {\n            padding-left: 25px;\n            font-size: 12px;\n            display: inline-block;\n        }\n    }\n}\n\n.list-task .task-done span {\n    text-decoration: line-through;\n}\n\n\n/*******************/\n/*Chat widget*/\n/*******************/\n\n.chat-list {\n    margin: 0px;\n    padding: 0px;\n    li {\n        list-style: none;\n        margin-top: 30px;\n        .chat-img {\n            display: inline-block;\n            width: 45px;\n            vertical-align: top;\n            img {\n                width: 45px;\n                border-radius: 100%;\n            }\n        }\n        .chat-content {\n            width: calc(100% - 140px);\n            display: inline-block;\n            padding-left: 15px;\n            h5 {\n                color: $muted;\n            }\n            .box {\n                display: inline-block;\n                margin-bottom: 10px;\n                color:$dark;\n            }\n        }\n        .chat-time {\n            display: inline-block;\n            text-align: right;\n            width: 80px;\n            font-size: 13px;\n            color: $muted;\n        }\n        &.odd {\n            .chat-content {\n                text-align: right;\n                width: calc(100% - 90px);\n            }\n            .box {\n                clear: both;\n            }\n        }\n        &.odd + .odd {\n            margin-top: 0px;\n        }\n        &.reverse {\n            text-align: right;\n            .chat-time {\n                text-align: left;\n            }\n            .chat-content {\n                padding-left: 0px;\n                padding-right: 15px;\n            }\n        }\n    }\n}\n\n\n/*******************/\n/*Chat widget*/\n/*******************/\n\n.message-box {\n    ul li {\n        .drop-title {\n            font-weight: 500;\n            padding: 11px 20px 15px;\n            border-bottom: 1px solid $border;\n        }\n        .nav-link {\n            border-top: 1px solid $border;\n            padding-top: 15px;\n        }\n    }\n    .message-widget {\n        position: relative;\n        a {\n            border-bottom: 1px solid $border;\n            display: block;\n            text-decoration: none;\n            padding: 9px 15px;\n            &:hover {\n                background: $light;\n            }\n            &:last-child {\n                border-bottom: 0px;\n            }\n            div {\n                white-space: normal;\n            }\n            .user-img {\n                width: 45px;\n                position: relative;\n                display: inline-block;\n                margin: 0 10px 15px 0;\n                img {\n                    width: 100%;\n                }\n                .profile-status {\n                    border: 2px solid $white;\n                    border-radius: 50%;\n                    display: inline-block;\n                    height: 10px;\n                    left: 33px;\n                    position: absolute;\n                    top: -1px;\n                    width: 10px;\n                }\n                .online {\n                    background: $success;\n                }\n                .busy {\n                    background: $danger;\n                }\n                .away {\n                    background: $warning;\n                }\n                .offline {\n                    background: $warning;\n                }\n            }\n            .mail-contnet {\n                display: inline-block;\n                width: 75%;\n                vertical-align: middle;\n                h5 {\n                    margin: 5px 0px 0;\n                }\n                .mail-desc,\n                .time {\n                    font-size: 12px;\n                    display: block;\n                    margin: 1px 0;\n                    text-overflow: ellipsis;\n                    overflow: hidden;\n                    color: $bodytext;\n                    white-space: nowrap;\n                }\n            }\n        }\n    }\n}\n\n\n/*******************/\n/*Calendar widget*/\n/*******************/\n\n.calendar {\n    float: $lft;\n    margin-bottom: 0px;\n}\n\n.fc-view {\n    margin-top: 30px;\n}\n\n.none-border {\n    .modal-footer {\n        border-top: none;\n    }\n}\n\n.fc-toolbar {\n    margin-bottom: 5px;\n    margin-top: 15px;\n    h2 {\n        font-size: 18px;\n        font-weight: 500;\n        line-height: 30px;\n        text-transform: uppercase;\n    }\n}\n\n.fc-day {\n    background: $white;\n}\n\n.fc-toolbar .fc-state-active,\n.fc-toolbar .ui-state-active,\n.fc-toolbar button:focus,\n.fc-toolbar button:hover,\n.fc-toolbar .ui-state-hover {\n    z-index: 0;\n}\n\n.fc-widget-header {\n    border: 0px !important;\n}\n\n.fc-widget-content {\n    border-color: rgba(120, 130, 140, 0.13)!important;\n}\n\n.fc {\n    th.fc-widget-header {\n        color: $bodytext;\n        font-size: 13px;\n        font-weight: 300;\n        line-height: 20px;\n        padding: 7px 0px;\n        text-transform: uppercase;\n    }\n    th.fc-sun,\n    th.fc-tue,\n    th.fc-thu,\n    th.fc-sat {\n        background: #f2f7f8;\n    }\n    th.fc-mon,\n    th.fc-wed,\n    th.fc-fri {\n        background: #f2f7f8;\n    }\n}\n\n.fc-view {\n    margin-top: 0px;\n}\n\n.fc-toolbar {\n    margin: 0px;\n    padding: 24px 0px;\n}\n\n.fc-button {\n    background: $white;\n    border: 1px solid $border;\n    color: $bodytext;\n    text-transform: capitalize;\n    &:hover {\n        background: $light;\n        opacity: 0.8;\n    }\n}\n\n.fc-text-arrow {\n    font-family: inherit;\n    font-size: 16px;\n}\n\n.fc-state-hover {\n    background: #F5F5F5;\n}\n\n.fc-unthemed .fc-today {\n    border: 1px solid $danger;\n    background: $light!important;\n}\n\n.fc-state-highlight {\n    background: #f0f0f0;\n}\n\n.fc-cell-overlay {\n    background: #f0f0f0;\n}\n\n.fc-unthemed {\n    .fc-today {\n        background: $white;\n    }\n}\n\n.fc-event {\n    border-radius: 0px;\n    border: none;\n    cursor: move;\n    color: $white!important;\n    font-size: 13px;\n    margin: 1px -1px 0 -1px;\n    padding: 5px 5px;\n    text-align: center;\n    background: $info;\n}\n\n.calendar-event {\n    cursor: move;\n    margin: 10px 5px 0 0;\n    padding: 6px 10px;\n    display: inline-block;\n    color: $white;\n    min-width: 140px;\n    text-align: center;\n    background: $info;\n    a {\n        float: $rgt;\n        opacity: 0.6;\n        font-size: 10px;\n        margin: 4px 0 0 10px;\n        color: $white;\n    }\n}\n\n.fc-basic-view {\n    td.fc-week-number {\n        span {\n            padding-right: 5px;\n        }\n    }\n    .fc-day-number {\n        padding: 10px 15px;\n        display: inline-block;\n    }\n}\n/*******************/\n/*Steam line widget*/\n/*******************/\n.steamline {\n    position: relative;\n    border-left: 1px solid $border;\n    margin-left: 20px;\n    .sl-left {\n        float: $lft;\n        margin-left: -20px;\n        z-index: 1;\n        width: 40px;\n        line-height: 40px;\n        text-align: center;\n        height: 40px;\n        border-radius: 100%;\n        color: $white;\n        background: $dark;\n        margin-right: 15px;\n        img {\n            max-width: 40px;\n        }\n    }\n}\n\n.steamline .sl-right {\n    padding-left: 50px;\n    .desc,\n    .inline-photos {\n        margin-bottom: 30px;\n    }\n    \n}\n\n.steamline .sl-item {\n    border-bottom: 1px solid $border;\n    margin: 20px 0;\n}\n\n.sl-date {\n    font-size: 10px;\n    color: $muted;\n}\n\n.time-item {\n    border-color: $border;\n    padding-bottom: 1px;\n    position: relative;\n    &:before {\n        content: \" \";\n        display: table;\n    }\n    &:after {\n        background-color: $white;\n        border-color: $border;\n        border-radius: 10px;\n        border-style: solid;\n        border-width: 2px;\n        bottom: 0;\n        content: '';\n        height: 14px;\n        left: 0;\n        margin-left: -8px;\n        position: absolute;\n        top: 5px;\n        width: 14px;\n    }\n}\n\n.time-item-item {\n    &:after {\n        content: \" \";\n        display: table;\n    }\n}\n\n.item-info {\n    margin-bottom: 15px;\n    margin-left: 15px;\n    p {\n        margin-bottom: 10px !important;\n    }\n}\n\n/*******************/\n/*Feed widget*/\n/*******************/\n\n.feeds {\n    margin: 0px;\n    padding: 0px;\n    li {\n        list-style: none;\n        padding: 10px;\n        display: block;\n        &:hover {\n            background: $extra-light;\n        }\n        > div {\n            width: 40px;\n            height: 40px;\n            margin-right: 5px;\n            display: inline-block;\n            text-align: center;\n            vertical-align: middle;\n            border-radius: 100%;\n            i {\n                line-height: 40px;\n            }\n        }\n        span {\n            float: right;\n            width: auto;\n            font-size: 12px;\n        }\n    }\n}\n\n\n/*******************/\n/*Vertical carousel*/\n/*******************/\n\n.vert .carousel-item-next.carousel-item-left,\n.vert .carousel-item-prev.carousel-item-right {\n    -webkit-transform: translate3d(0, 0, 0);\n    transform: translate3d(0, 0, 0);\n}\n\n.vert .carousel-item-next,\n.vert .active.carousel-item-right {\n    -webkit-transform: translate3d(0, 100%, 0);\n    transform: translate3d(0, 100% 0);\n}\n\n.vert .carousel-item-prev,\n.vert .active.carousel-item-left {\n    -webkit-transform: translate3d(0, -100%, 0);\n    transform: translate3d(0, -100%, 0);\n}\n\n\n/*******************/\n/*social-widgets*/\n/*******************/\n\n.social-widget {\n    .soc-header {\n        padding: 15px;\n        text-align: center;\n        font-size: 36px;\n        color: #fff;\n        &.box-facebook {\n            background: #3b5998;\n        }\n        &.box-twitter {\n            background: #00aced;\n        }\n        &.box-google {\n            background: #f86c6b;\n        }\n        &.box-linkedin {\n            background: #4875b4;\n        }\n    }\n    .soc-content {\n        display: flex;\n        text-align: center;\n        div {\n            padding: 10px;\n            h3 {\n                margin-bottom: 0px;\n            }\n        }\n    }\n}\n\n\n/*******************/\n/*Guage chart*/\n/*******************/\n\n.gaugejs-box {\n    position: relative;\n    margin: 0 auto;\n}\n\n.gaugejs-box canvas.gaugejs {\n    width: 100% !important;\n    height: auto !important;\n}\n\n\n/*******************/\n/*social-profile-first*/\n/*******************/\n\n.social-profile-first {\n    text-align: center;\n    padding-top: 22%;\n    margin-bottom: 96px;\n    &.bg-over {\n        background: rgba(56, 83, 161, 0.7);\n    }\n    .middle {\n        vertical-align: middle;\n    }\n}\n\n\n/*******************/\n/*country-state*/\n/*******************/\n\n.country-state {\n    list-style: none;\n    margin: 0;\n    padding: 0 0 0 10px;\n    li {\n        margin-top: 30px;\n        margin-bottom: 10px;\n    }\n    h2 {\n        margin-bottom: 0px;\n        font-weight: 400;\n    }\n}\n\n\n/*******************/\n/*profile timeline widget*/\n/*******************/\n\n.profiletimeline {\n    position: relative;\n    margin-left: 70px;\n    margin-right: 10px;\n    .sl-left {\n        float: left;\n        margin-left: -60px;\n        z-index: 1;\n        margin-right: 15px;\n        img {\n            max-width: 40px;\n        }\n    }\n}\n.profiletimeline .sl-item {\n    margin-top: 8px;\n    margin-bottom: 30px;\n}\n\n.profiletimeline .sl-date {\n    font-size: 12px;\n    color: $muted;\n}\n\n.profiletimeline .time-item {\n    border-color: $border;\n    padding-bottom: 1px;\n    position: relative;\n    &:before {\n        content: \" \";\n        display: table;\n    }\n    &:after {\n        background-color: $white;\n        border-color: $border;\n        border-radius: 10px;\n        border-style: solid;\n        border-width: 2px;\n        bottom: 0;\n        content: '';\n        height: 14px;\n        left: 0;\n        margin-left: -8px;\n        position: absolute;\n        top: 5px;\n        width: 14px;\n    }\n}\n\n.profiletimeline .time-item-item {\n    &:after {\n        content: \" \";\n        display: table;\n    }\n}\n\n.profiletimeline .item-info {\n    margin-bottom: 15px;\n    margin-left: 15px;\n    p {\n        margin-bottom: 10px !important;\n    }\n}\n\n/*Blog widgets*/\n\n.blog-widget{\n    margin-top: 30px;\n    .blog-image img{\n        border-radius: $radius;\n        margin-top: -45px;\n        margin-bottom: 20px;\n        box-shadow: 0 0 15px rgba(0, 0, 0,0.2);\n    }\n}\n\n/*Weather smal;*/\n.weather-small{\n    h1{\n        line-height: 30px;\n    }\n    sup{\n        font-size:60%;\n    }\n}\n\n/*little-profile*/\n.little-profile{\n    .pro-img{\n        margin-top: -80px;\n        margin-bottom: 20px;\n        img{\n            width:128px;\n            height: 128px;\n            box-shadow: 0 0 15px rgba(0, 0, 0,0.2);\n            border-radius: 100%;\n        }\n    }\n}\n.contact-box {\n    position: relative;\n    .add-ct-btn{\n        position: absolute;\n        right: 4px;\n        top:-46px;\n    }\n    .contact-widget{\n    > a{\n        padding: 15px 10px;\n        .user-img{\n            margin-bottom: 0px!important;\n        }\n    }\n}\n}    "
  },
  {
    "path": "src/main/resources/templates/agency.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\" layout:decorator=\"layout/layout\">\n\n<head>\n</head>\n\n<body>\n\n<div class=\"container-fluid\" layout:fragment=\"content\">\n    <!-- ============================================================== -->\n    <!-- Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <div class=\"row page-titles\">\n        <div class=\"col-md-5 col-8 align-self-center\">\n            <h3 class=\"text-themecolor m-b-0 m-t-0\">Agency Details</h3>\n            <ol class=\"breadcrumb\">\n                <li class=\"breadcrumb-item\"><a href=\"home\">Home</a></li>\n                <li class=\"breadcrumb-item active\">Agency</li>\n            </ol>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <!-- ============================================================== -->\n    <!-- Start Page Content -->\n    <!-- ============================================================== -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- Column -->\n        <div class=\"col-lg-4 col-xlg-3 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <center class=\"m-t-30\"><img src=\"/dashboard/assets/images/users/5.jpg\" class=\"img-circle\" width=\"150\"/>\n                        <h4 class=\"card-title m-t-10\" th:inline=\"text\">[[${agency.name}]]</h4>\n                        <h6 class=\"card-subtitle\" th:inline=\"text\">[[${agency.code}]]</h6>\n                        <div class=\"row text-center justify-content-md-center\">\n                            <div class=\"col-4\"><a href=\"javascript:void(0)\" class=\"link\"><i class=\"icon-people\"></i>\n                                <font class=\"font-medium\">254</font></a></div>\n                            <div class=\"col-4\"><a href=\"javascript:void(0)\" class=\"link\"><i class=\"icon-picture\"></i>\n                                <font class=\"font-medium\">54</font></a></div>\n                        </div>\n                    </center>\n                </div>\n            </div>\n        </div>\n        <!-- Column -->\n        <!-- Column -->\n        <div class=\"col-lg-8 col-xlg-9 col-md-7\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <form action=\"#\" method=\"POST\" class=\"form-horizontal form-material\" th:action=\"@{/agency}\" th:object=\"${agencyFormData}\">\n                    <div class=\" form-group\">\n                    <label for=\"agencyName\" class=\"col-md-12\">Agency Name</label>\n                    <div class=\"col-md-12\">\n                        <input type=\"text\" th:field=\"*{agencyName}\" class=\"form-control form-control-line\"\n                               name=\"agencyName\" id=\"agencyName\">\n                    </div>\n                    <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('agencyName')}\" th:errors=\"*{agencyName}\"></small>\n                </div>\n                <div class=\"form-group\">\n                    <label for=\"agencyDetails\" class=\"col-md-12\">Agency Detail</label>\n                    <div class=\"col-md-12\">\n                        <input type=\"text\" th:field=\"*{agencyDetails}\" class=\"form-control form-control-line\"\n                               name=\"agencyDetails\" id=\"agencyDetails\">\n                    </div>\n                    <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('agencyDetails')}\" th:errors=\"*{agencyDetails}\"></small>\n                </div>\n                <div class=\"form-group\">\n                    <div class=\"col-sm-12\">\n                        <button class=\"btn btn-success\">Update</button>\n                    </div>\n                </div>\n                </form>\n            </div>\n        </div>\n    </div>\n    <!-- Column -->\n</div>\n<!-- Row -->\n<!-- ============================================================== -->\n<!-- End PAge Content -->\n<!-- ============================================================== -->\n</div>\n</body>\n\n</html>\n"
  },
  {
    "path": "src/main/resources/templates/bus.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\" layout:decorator=\"layout/layout\">\n\n<head>\n</head>\n\n<body>\n\n<!-- ============================================================== -->\n<!-- Container fluid  -->\n<!-- ============================================================== -->\n<div class=\"container-fluid\" layout:fragment=\"content\">\n    <!-- ============================================================== -->\n    <!-- Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <div class=\"row page-titles\">\n        <div class=\"col-md-5 col-8 align-self-center\">\n            <h3 class=\"text-themecolor m-b-0 m-t-0\">Bus Details</h3>\n            <ol class=\"breadcrumb\">\n                <li class=\"breadcrumb-item\"><a href=\"home\">Home</a></li>\n                <li class=\"breadcrumb-item active\">Buses</li>\n            </ol>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <!-- ============================================================== -->\n    <!-- Start Page Content -->\n    <!-- ============================================================== -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- column -->\n        <div class=\"col-lg-8 col-md-7\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <h4 class=\"card-title\">Buses</h4>\n                    <h6 class=\"card-subtitle\">Agency owned buses</h6>\n                    <div class=\"table-responsive\">\n                        <table class=\"table\">\n                            <thead>\n                            <tr>\n                                <th>#</th>\n                                <th>Bus Code</th>\n                                <th>Capacity</th>\n                            </tr>\n                            </thead>\n                            <tbody>\n                            <th:block th:each=\"bus,iterationStatus : ${agency.buses}\">\n                                <tr>\n                                    <td th:text=${iterationStatus.count}></td>\n                                    <td th:text=${bus.code}></td>\n                                    <td th:text=${bus.capacity}></td>\n                                </tr>\n                            </th:block>\n                            </tbody>\n                        </table>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"col-lg-4 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <h3 class=\"card-title\">Add New Bus</h3>\n                    <h6 class=\"card-subtitle\">Enter details</h6>\n                    <form method=\"POST\" class=\"form-horizontal form-material\" th:action=\"@{/bus}\" th:object=\"${busFormData}\">\n                        <div class=\"form-group\">\n                            <label for=\"code\" class=\"col-md-12\">Bus Code</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{code}\" class=\"form-control form-control-line\" name=\"code\" id=\"code\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('code')}\" th:errors=\"*{code}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"capacity\" class=\"col-md-12\">Capacity</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{capacity}\" class=\"form-control form-control-line\" name=\"capacity\" id=\"capacity\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('capacity')}\" th:errors=\"*{capacity}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"make\" class=\"col-md-12\">Make/Model</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{make}\" class=\"form-control form-control-line\" name=\"make\" id=\"make\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('make')}\" th:errors=\"*{make}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <div class=\"col-sm-12\">\n                                <button class=\"btn btn-success\">Add Bus</button>\n                            </div>\n                        </div>\n                    </form>\n                </div>\n            </div>\n        </div>\n    </div>\n    <!-- Row -->\n    <!-- ============================================================== -->\n    <!-- End PAge Content -->\n    <!-- ============================================================== -->\n</div>\n<!-- ============================================================== -->\n<!-- End Container fluid  -->\n<!-- ============================================================== -->\n</body>\n\n</html>\n"
  },
  {
    "path": "src/main/resources/templates/dashboard.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\" layout:decorator=\"layout/layout\">\n\n<head>\n</head>\n\n<body>\n\n<!-- ============================================================== -->\n<!-- Container fluid  -->\n<!-- ============================================================== -->\n<div class=\"container-fluid\" layout:fragment=\"content\">\n    <!-- ============================================================== -->\n    <!-- Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <div class=\"row page-titles\">\n        <div class=\"col-md-5 col-8 align-self-center\">\n            <h3 class=\"text-themecolor\">Dashboard</h3>\n            <ol class=\"breadcrumb\">\n                <li class=\"breadcrumb-item\"><a href=\"home\">Home</a></li>\n                <li class=\"breadcrumb-item active\">Dashboard</li>\n            </ol>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <!-- ============================================================== -->\n    <!-- Start Page Content -->\n    <!-- ============================================================== -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- Column -->\n        <div class=\"col-lg-8 col-md-7\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <div class=\"row\">\n                        <div class=\"col-12\">\n                            <div class=\"d-flex flex-wrap\">\n                                <div>\n                                    <h3 class=\"card-title\">Sales Overview</h3>\n                                    <h6 class=\"card-subtitle\">Ample Admin Vs Pixel Admin</h6></div>\n                                <div class=\"ml-auto\">\n                                    <ul class=\"list-inline\">\n                                        <li>\n                                            <h6 class=\"text-muted text-success\"><i\n                                                    class=\"fa fa-circle font-10 m-r-10 \"></i>Ample</h6></li>\n                                        <li>\n                                            <h6 class=\"text-muted  text-info\"><i\n                                                    class=\"fa fa-circle font-10 m-r-10\"></i>Pixel</h6></li>\n                                    </ul>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"col-12\">\n                            <div class=\"amp-pxl\" style=\"height: 360px;\"></div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"col-lg-4 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <h3 class=\"card-title\">Our Visitors </h3>\n                    <h6 class=\"card-subtitle\">Different Devices Used to Visit</h6>\n                    <div id=\"visitor\" style=\"height:290px; width:100%;\"></div>\n                </div>\n                <div>\n                    <hr class=\"m-t-0 m-b-0\">\n                </div>\n                <div class=\"card-block text-center \">\n                    <ul class=\"list-inline m-b-0\">\n                        <li>\n                            <h6 class=\"text-muted text-info\"><i class=\"fa fa-circle font-10 m-r-10 \"></i>Mobile</h6>\n                        </li>\n                        <li>\n                            <h6 class=\"text-muted  text-primary\"><i class=\"fa fa-circle font-10 m-r-10\"></i>Desktop</h6>\n                        </li>\n                        <li>\n                            <h6 class=\"text-muted  text-success\"><i class=\"fa fa-circle font-10 m-r-10\"></i>Tablet</h6>\n                        </li>\n                    </ul>\n                </div>\n            </div>\n        </div>\n    </div>\n    <!-- Row -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- Column -->\n        <div class=\"col-lg-4 col-xlg-3 col-md-5\">\n            <!-- Column -->\n            <div class=\"card\">\n                <img class=\"card-img-top\" src=\"/dashboard/assets/images/background/profile-bg.jpg\"\n                     alt=\"Card image cap\">\n                <div class=\"card-block little-profile text-center\">\n                    <div class=\"pro-img\"><img src=\"/dashboard/assets/images/users/4.jpg\" alt=\"user\"/></div>\n                    <h3 class=\"m-b-0\">Angela Dominic</h3>\n                    <p>Web Designer &amp; Developer</p>\n                    <a href=\"javascript:void(0)\"\n                       class=\"m-t-10 waves-effect waves-dark btn btn-primary btn-md btn-rounded\">Follow</a>\n                    <div class=\"row text-center m-t-20\">\n                        <div class=\"col-lg-4 col-md-4 m-t-20\">\n                            <h3 class=\"m-b-0 font-light\">1099</h3>\n                            <small>Articles</small>\n                        </div>\n                        <div class=\"col-lg-4 col-md-4 m-t-20\">\n                            <h3 class=\"m-b-0 font-light\">23,469</h3>\n                            <small>Followers</small>\n                        </div>\n                        <div class=\"col-lg-4 col-md-4 m-t-20\">\n                            <h3 class=\"m-b-0 font-light\">6035</h3>\n                            <small>Following</small>\n                        </div>\n                    </div>\n                </div>\n            </div>\n            <!-- Column -->\n            <div class=\"card\">\n                <div class=\"card-block bg-info\">\n                    <h4 class=\"text-white card-title\">My Contacts</h4>\n                    <h6 class=\"card-subtitle text-white m-b-0 op-5\">Checkout my contacts here</h6>\n                </div>\n                <div class=\"card-block\">\n                    <div class=\"message-box contact-box\">\n                        <h2 class=\"add-ct-btn\">\n                            <button type=\"button\" class=\"btn btn-circle btn-lg btn-success waves-effect waves-dark\">+\n                            </button>\n                        </h2>\n                        <div class=\"message-widget contact-widget\">\n                            <!-- Message -->\n                            <a href=\"#\">\n                                <div class=\"user-img\"><img src=\"/dashboard/assets/images/users/1.jpg\" alt=\"user\"\n                                                           class=\"img-circle\"> <span\n                                        class=\"profile-status online pull-right\"></span></div>\n                                <div class=\"mail-contnet\">\n                                    <h5>Pavan kumar</h5> <span class=\"mail-desc\">info@wrappixel.com</span></div>\n                            </a>\n                            <!-- Message -->\n                            <a href=\"#\">\n                                <div class=\"user-img\"><img src=\"/dashboard/assets/images/users/2.jpg\" alt=\"user\"\n                                                           class=\"img-circle\"> <span\n                                        class=\"profile-status busy pull-right\"></span></div>\n                                <div class=\"mail-contnet\">\n                                    <h5>Sonu Nigam</h5> <span class=\"mail-desc\">pamela1987@gmail.com</span></div>\n                            </a>\n                            <!-- Message -->\n                            <a href=\"#\">\n                                <div class=\"user-img\"><span class=\"round\">A</span> <span\n                                        class=\"profile-status away pull-right\"></span></div>\n                                <div class=\"mail-contnet\">\n                                    <h5>Arijit Sinh</h5> <span class=\"mail-desc\">cruise1298.fiplip@gmail.com</span>\n                                </div>\n                            </a>\n                            <!-- Message -->\n                            <a href=\"#\">\n                                <div class=\"user-img\"><img src=\"/dashboard/assets/images/users/4.jpg\" alt=\"user\"\n                                                           class=\"img-circle\"> <span\n                                        class=\"profile-status offline pull-right\"></span></div>\n                                <div class=\"mail-contnet\">\n                                    <h5>Pavan kumar</h5> <span class=\"mail-desc\">kat@gmail.com</span></div>\n                            </a>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"col-lg-8 col-xlg-9 col-md-7\">\n            <div class=\"card\">\n                <!-- Nav tabs -->\n                <ul class=\"nav nav-tabs profile-tab\" role=\"tablist\">\n                    <li class=\"nav-item\"><a class=\"nav-link active\" data-toggle=\"tab\" href=\"#home\"\n                                            role=\"tab\">Activity</a></li>\n                    <li class=\"nav-item\"><a class=\"nav-link\" data-toggle=\"tab\" href=\"#profile\" role=\"tab\">Profile</a>\n                    </li>\n                    <li class=\"nav-item\"><a class=\"nav-link\" data-toggle=\"tab\" href=\"#settings\" role=\"tab\">Settings</a>\n                    </li>\n                </ul>\n                <!-- Tab panes -->\n                <div class=\"tab-content\">\n                    <div class=\"tab-pane active\" id=\"home\" role=\"tabpanel\">\n                        <div class=\"card-block\">\n                            <div class=\"profiletimeline\">\n                                <div class=\"sl-item\">\n                                    <div class=\"sl-left\"><img src=\"/dashboard/assets/images/users/1.jpg\" alt=\"user\"\n                                                              class=\"img-circle\"></div>\n                                    <div class=\"sl-right\">\n                                        <div><a href=\"#\" class=\"link\">John Doe</a> <span\n                                                class=\"sl-date\">5 minutes ago</span>\n                                            <p>assign a new task <a href=\"#\"> Design weblayout</a></p>\n                                            <div class=\"row\">\n                                                <div class=\"col-lg-3 col-md-6 m-b-20\"><img\n                                                        src=\"/dashboard/assets/images/big/img1.jpg\" alt=\"user\"\n                                                        class=\"img-responsive radius\"></div>\n                                                <div class=\"col-lg-3 col-md-6 m-b-20\"><img\n                                                        src=\"/dashboard/assets/images/big/img2.jpg\" alt=\"user\"\n                                                        class=\"img-responsive radius\"></div>\n                                                <div class=\"col-lg-3 col-md-6 m-b-20\"><img\n                                                        src=\"/dashboard/assets/images/big/img3.jpg\" alt=\"user\"\n                                                        class=\"img-responsive radius\"></div>\n                                                <div class=\"col-lg-3 col-md-6 m-b-20\"><img\n                                                        src=\"/dashboard/assets/images/big/img4.jpg\" alt=\"user\"\n                                                        class=\"img-responsive radius\"></div>\n                                            </div>\n                                            <div class=\"like-comm\"><a href=\"javascript:void(0)\" class=\"link m-r-10\">2\n                                                comment</a> <a href=\"javascript:void(0)\" class=\"link m-r-10\"><i\n                                                    class=\"fa fa-heart text-danger\"></i> 5 Love</a></div>\n                                        </div>\n                                    </div>\n                                </div>\n                                <hr>\n                                <div class=\"sl-item\">\n                                    <div class=\"sl-left\"><img src=\"/dashboard/assets/images/users/2.jpg\" alt=\"user\"\n                                                              class=\"img-circle\"></div>\n                                    <div class=\"sl-right\">\n                                        <div><a href=\"#\" class=\"link\">John Doe</a> <span\n                                                class=\"sl-date\">5 minutes ago</span>\n                                            <div class=\"m-t-20 row\">\n                                                <div class=\"col-md-3 col-xs-12\"><img\n                                                        src=\"/dashboard/assets/images/big/img1.jpg\" alt=\"user\"\n                                                        class=\"img-responsive radius\"></div>\n                                                <div class=\"col-md-9 col-xs-12\">\n                                                    <p> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer\n                                                        nec odio. Praesent libero. Sed cursus ante dapibus diam. </p> <a\n                                                        href=\"#\" class=\"btn btn-success\"> Design weblayout</a></div>\n                                            </div>\n                                            <div class=\"like-comm m-t-20\"><a href=\"javascript:void(0)\"\n                                                                             class=\"link m-r-10\">2 comment</a> <a\n                                                    href=\"javascript:void(0)\" class=\"link m-r-10\"><i\n                                                    class=\"fa fa-heart text-danger\"></i> 5 Love</a></div>\n                                        </div>\n                                    </div>\n                                </div>\n                                <hr>\n                                <div class=\"sl-item\">\n                                    <div class=\"sl-left\"><img src=\"/dashboard/assets/images/users/3.jpg\" alt=\"user\"\n                                                              class=\"img-circle\"></div>\n                                    <div class=\"sl-right\">\n                                        <div><a href=\"#\" class=\"link\">John Doe</a> <span\n                                                class=\"sl-date\">5 minutes ago</span>\n                                            <p class=\"m-t-10\"> Lorem ipsum dolor sit amet, consectetur adipiscing elit.\n                                                Integer nec odio. Praesent libero. Sed cursus ante dapibus diam. Sed\n                                                nisi. Nulla quis sem at nibh elementum imperdiet. Duis sagittis ipsum.\n                                                Praesent mauris. Fusce nec tellus sed augue semper </p>\n                                        </div>\n                                        <div class=\"like-comm m-t-20\"><a href=\"javascript:void(0)\" class=\"link m-r-10\">2\n                                            comment</a> <a href=\"javascript:void(0)\" class=\"link m-r-10\"><i\n                                                class=\"fa fa-heart text-danger\"></i> 5 Love</a></div>\n                                    </div>\n                                </div>\n                                <hr>\n                                <div class=\"sl-item\">\n                                    <div class=\"sl-left\"><img src=\"/dashboard/assets/images/users/4.jpg\" alt=\"user\"\n                                                              class=\"img-circle\"></div>\n                                    <div class=\"sl-right\">\n                                        <div><a href=\"#\" class=\"link\">John Doe</a> <span\n                                                class=\"sl-date\">5 minutes ago</span>\n                                            <blockquote class=\"m-t-10\">\n                                                Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod\n                                                tempor incididunt\n                                            </blockquote>\n                                        </div>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <!--second tab-->\n                    <div class=\"tab-pane\" id=\"profile\" role=\"tabpanel\">\n                        <div class=\"card-block\">\n                            <div class=\"row\">\n                                <div class=\"col-md-3 col-xs-6 b-r\"><strong>Full Name</strong>\n                                    <br>\n                                    <p class=\"text-muted\">Johnathan Deo</p>\n                                </div>\n                                <div class=\"col-md-3 col-xs-6 b-r\"><strong>Mobile</strong>\n                                    <br>\n                                    <p class=\"text-muted\">(123) 456 7890</p>\n                                </div>\n                                <div class=\"col-md-3 col-xs-6 b-r\"><strong>Email</strong>\n                                    <br>\n                                    <p class=\"text-muted\">johnathan@admin.com</p>\n                                </div>\n                                <div class=\"col-md-3 col-xs-6\"><strong>Location</strong>\n                                    <br>\n                                    <p class=\"text-muted\">London</p>\n                                </div>\n                            </div>\n                            <hr>\n                            <p class=\"m-t-30\">Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In\n                                enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede\n                                mollis pretium. Integer tincidunt.Cras dapibus. Vivamus elementum semper nisi. Aenean\n                                vulputate eleifend tellus. Aenean leo ligula, porttitor eu, consequat vitae, eleifend\n                                ac, enim.</p>\n                            <p>Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum\n                                has been the industry's standard dummy text ever since the 1500s, when an unknown\n                                printer took a galley of type and scrambled it to make a type specimen book. It has\n                                survived not only five centuries </p>\n                            <p>It was popularised in the 1960s with the release of Letraset sheets containing Lorem\n                                Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker\n                                including versions of Lorem Ipsum.</p>\n                            <h4 class=\"font-medium m-t-30\">Skill Set</h4>\n                            <hr>\n                            <h5 class=\"m-t-30\">Wordpress <span class=\"pull-right\">80%</span></h5>\n                            <div class=\"progress\">\n                                <div class=\"progress-bar bg-success\" role=\"progressbar\" aria-valuenow=\"80\"\n                                     aria-valuemin=\"0\" aria-valuemax=\"100\" style=\"width:80%; height:6px;\"><span\n                                        class=\"sr-only\">50% Complete</span></div>\n                            </div>\n                            <h5 class=\"m-t-30\">HTML 5 <span class=\"pull-right\">90%</span></h5>\n                            <div class=\"progress\">\n                                <div class=\"progress-bar bg-info\" role=\"progressbar\" aria-valuenow=\"90\"\n                                     aria-valuemin=\"0\" aria-valuemax=\"100\" style=\"width:90%; height:6px;\"><span\n                                        class=\"sr-only\">50% Complete</span></div>\n                            </div>\n                            <h5 class=\"m-t-30\">jQuery <span class=\"pull-right\">50%</span></h5>\n                            <div class=\"progress\">\n                                <div class=\"progress-bar bg-danger\" role=\"progressbar\" aria-valuenow=\"50\"\n                                     aria-valuemin=\"0\" aria-valuemax=\"100\" style=\"width:50%; height:6px;\"><span\n                                        class=\"sr-only\">50% Complete</span></div>\n                            </div>\n                            <h5 class=\"m-t-30\">Photoshop <span class=\"pull-right\">70%</span></h5>\n                            <div class=\"progress\">\n                                <div class=\"progress-bar bg-warning\" role=\"progressbar\" aria-valuenow=\"70\"\n                                     aria-valuemin=\"0\" aria-valuemax=\"100\" style=\"width:70%; height:6px;\"><span\n                                        class=\"sr-only\">50% Complete</span></div>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"tab-pane\" id=\"settings\" role=\"tabpanel\">\n                        <div class=\"card-block\">\n                            <form class=\"form-horizontal form-material\">\n                                <div class=\"form-group\">\n                                    <label class=\"col-md-12\">Full Name</label>\n                                    <div class=\"col-md-12\">\n                                        <input type=\"text\" placeholder=\"Johnathan Doe\"\n                                               class=\"form-control form-control-line\">\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <label for=\"example-email\" class=\"col-md-12\">Email</label>\n                                    <div class=\"col-md-12\">\n                                        <input type=\"email\" placeholder=\"johnathan@admin.com\"\n                                               class=\"form-control form-control-line\" name=\"example-email\"\n                                               id=\"example-email\">\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <label class=\"col-md-12\">Password</label>\n                                    <div class=\"col-md-12\">\n                                        <input type=\"password\" value=\"password\" class=\"form-control form-control-line\">\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <label class=\"col-md-12\">Phone No</label>\n                                    <div class=\"col-md-12\">\n                                        <input type=\"text\" placeholder=\"123 456 7890\"\n                                               class=\"form-control form-control-line\">\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <label class=\"col-md-12\">Message</label>\n                                    <div class=\"col-md-12\">\n                                        <textarea rows=\"5\" class=\"form-control form-control-line\"></textarea>\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <label class=\"col-sm-12\">Select Country</label>\n                                    <div class=\"col-sm-12\">\n                                        <select class=\"form-control form-control-line\">\n                                            <option>London</option>\n                                            <option>India</option>\n                                            <option>Usa</option>\n                                            <option>Canada</option>\n                                            <option>Thailand</option>\n                                        </select>\n                                    </div>\n                                </div>\n                                <div class=\"form-group\">\n                                    <div class=\"col-sm-12\">\n                                        <button class=\"btn btn-success\">Update Profile</button>\n                                    </div>\n                                </div>\n                            </form>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End PAge Content -->\n    <!-- ============================================================== -->\n</div>\n</body>\n\n</html>\n"
  },
  {
    "path": "src/main/resources/templates/error.html",
    "content": "<!DOCTYPE html>\n<html lang=\"en\">\n\n<head>\n    <meta charset=\"utf-8\">\n    <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\n    <!-- Tell the browser to be responsive to screen width -->\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n    <meta name=\"description\" content=\"\">\n    <meta name=\"author\" content=\"\">\n    <!-- Favicon icon -->\n    <link rel=\"icon\" type=\"image/png\" sizes=\"16x16\" href=\"../dashboard/assets/images/favicon.png\">\n    <title>Material Pro Admin Template - The Most Complete & Trusted Bootstrap 4 Admin Template</title>\n    <!-- Bootstrap Core CSS -->\n    <link href=\"../dashboard/assets/plugins/bootstrap/css/bootstrap.min.css\" rel=\"stylesheet\">\n    <!-- Custom CSS -->\n    <link href=\"../dashboard/html/css/style.css\" rel=\"stylesheet\">\n    <!-- You can change the theme colors from here -->\n    <link href=\"../dashboard/html/css/colors/blue.css\" id=\"theme\" rel=\"stylesheet\">\n    <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->\n    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->\n    <!--[if lt IE 9]>\n    <script src=\"https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js\"></script>\n    <script src=\"https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js\"></script>\n    <![endif]-->\n</head>\n\n<body class=\"fix-header card-no-border\">\n<!-- ============================================================== -->\n<!-- Main wrapper - style you can find in pages.scss -->\n<!-- ============================================================== -->\n<section id=\"wrapper\" class=\"error-page\">\n    <div class=\"error-box\">\n        <div class=\"error-body text-center\">\n            <h1>404</h1>\n            <h3 class=\"text-uppercase\">Page Not Found !</h3>\n            <p class=\"text-muted m-t-30 m-b-30\">YOU SEEM TO BE TRYING TO FIND HIS WAY HOME</p>\n            <a href=\"/dashboard\" class=\"btn btn-info btn-rounded waves-effect waves-light m-b-40\">Back to home</a> </div>\n    </div>\n</section>\n<!-- ============================================================== -->\n<!-- End Wrapper -->\n<!-- ============================================================== -->\n<!-- ============================================================== -->\n<!-- All Jquery -->\n<!-- ============================================================== -->\n<script src=\"../dashboard/assets/plugins/jquery/jquery.min.js\"></script>\n<!-- Bootstrap tether Core JavaScript -->\n<script src=\"../dashboard/assets/plugins/bootstrap/js/tether.min.js\"></script>\n<script src=\"../dashboard/assets/plugins/bootstrap/js/bootstrap.min.js\"></script>\n<!--Wave Effects -->\n<script src=\"../dashboard/html/js/waves.js\"></script>\n</body>\n\n</html>\n"
  },
  {
    "path": "src/main/resources/templates/fragments/footer.html",
    "content": "<!DOCTYPE html>\n\n<html xmlns:th=\"http://www.thymeleaf.org\">\n\n<head>\n</head>\n\n<body>\n\n<footer class=\"footer\" th:fragment=\"footer\"> © 2020 Spring Boot Starter Kit Application </footer>\n\n</body>\n\n</html>"
  },
  {
    "path": "src/main/resources/templates/fragments/header.html",
    "content": "<!DOCTYPE html>\n\n<html xmlns:th=\"http://www.thymeleaf.org\">\n\n<head th:fragment=\"header\">\n    <meta charset=\"utf-8\">\n    <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\n    <!-- Tell the browser to be responsive to screen width -->\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n    <meta name=\"description\" content=\"\">\n    <meta name=\"author\" content=\"\">\n    <!-- Favicon icon -->\n    <link rel=\"icon\" type=\"image/png\" href=\"favicon.png\">\n    <title>Dashboard</title>\n    <!-- Bootstrap Core CSS -->\n    <link href=\"/dashboard/assets/plugins/bootstrap/css/bootstrap.min.css\" rel=\"stylesheet\">\n    <!-- chartist CSS -->\n    <link href=\"/dashboard/assets/plugins/chartist-js/dist/chartist.min.css\" rel=\"stylesheet\">\n    <link href=\"/dashboard/assets/plugins/chartist-js/dist/chartist-init.css\" rel=\"stylesheet\">\n    <link href=\"/dashboard/assets/plugins/chartist-plugin-tooltip-master/dist/chartist-plugin-tooltip.css\" rel=\"stylesheet\">\n    <!--This page css - Morris CSS -->\n    <link href=\"/dashboard/assets/plugins/c3-master/c3.min.css\" rel=\"stylesheet\">\n    <!-- Custom CSS -->\n    <link href=\"/dashboard/html/css/style.css\" rel=\"stylesheet\">\n    <!-- You can change the theme colors from here -->\n    <link href=\"/dashboard/html/css/colors/blue.css\" id=\"theme\" rel=\"stylesheet\">\n    <!-- Material icons and fonts -->\n    <link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/MaterialDesign-Webfont/5.5.55/css/materialdesignicons.min.css\"/>\n    <link rel=\"stylesheet\" href=\"https://cdnjs.cloudflare.com/ajax/libs/material-design-iconic-font/2.2.0/css/material-design-iconic-font.min.css\"/>\n    <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->\n    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->\n    <!--[if lt IE 9]>\n    <script src=\"https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js\"></script>\n    <script src=\"https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js\"></script>\n    <![endif]-->\n    <script src=\"/dashboard/assets/plugins/jquery/jquery.min.js\"></script>\n    <!-- Bootstrap tether Core JavaScript -->\n    <script src=\"/dashboard/assets/plugins/bootstrap/js/tether.min.js\"></script>\n    <script src=\"/dashboard/assets/plugins/bootstrap/js/bootstrap.min.js\"></script>\n    <!-- slimscrollbar scrollbar JavaScript -->\n    <script src=\"/dashboard/html/js/jquery.slimscroll.js\"></script>\n    <!--Wave Effects -->\n    <script src=\"/dashboard/html/js/waves.js\"></script>\n    <!--Menu sidebar -->\n    <script src=\"/dashboard/html/js/sidebarmenu.js\"></script>\n    <!--stickey kit -->\n    <script src=\"/dashboard/assets/plugins/sticky-kit-master/dist/sticky-kit.min.js\"></script>\n    <!--Custom JavaScript -->\n    <script src=\"/dashboard/html/js/custom.min.js\"></script>\n    <!-- chartist chart -->\n    <script src=\"/dashboard/assets/plugins/chartist-js/dist/chartist.min.js\"></script>\n    <script src=\"/dashboard/assets/plugins/chartist-plugin-tooltip-master/dist/chartist-plugin-tooltip.min.js\"></script>\n    <!--c3 JavaScript -->\n    <script src=\"/dashboard/assets/plugins/d3/d3.min.js\"></script>\n    <script src=\"/dashboard/assets/plugins/c3-master/c3.min.js\"></script>\n    <!-- Chart JS -->\n    <script src=\"/dashboard/html/js/dashboard1.js\"></script>\n</head>\n\n<body>\n</body>\n\n</html>"
  },
  {
    "path": "src/main/resources/templates/fragments/navigation.html",
    "content": "<!DOCTYPE html>\n\n<html xmlns:th=\"http://www.thymeleaf.org\">\n\n<head>\n    <title>Header</title>\n</head>\n\n<body>\n\n<!-- ============================================================== -->\n<!-- Topbar header - style you can find in pages.scss -->\n<!-- ============================================================== -->\n<header class=\"topbar\" th:fragment=\"navigation\">\n    <nav class=\"navbar top-navbar navbar-toggleable-sm navbar-light\">\n        <!-- ============================================================== -->\n        <!-- Logo -->\n        <!-- ============================================================== -->\n        <div class=\"navbar-header\">\n            <a class=\"navbar-brand\" href=\"/dashboard\">\n                <!-- Logo icon -->\n                <b>\n                    <!--You can put here icon as well // <i class=\"wi wi-sunset\"></i> //-->\n                    <!-- Light Logo icon -->\n                    <img src=\"/dashboard/assets/images/logo.png\" alt=\"homepage\" class=\"light-logo\" />\n                </b>\n                <!--End Logo icon -->\n                <!-- Logo text -->\n                <span>\n                    <!-- Light Logo text -->\n                    <img src=\"/dashboard/assets/images/logo-text.png\" class=\"light-logo\" alt=\"homepage\" />\n                </span>\n            </a>\n        </div>\n        <!-- ============================================================== -->\n        <!-- End Logo -->\n        <!-- ============================================================== -->\n        <div class=\"navbar-collapse\">\n            <!-- ============================================================== -->\n            <!-- toggle and nav items -->\n            <!-- ============================================================== -->\n            <ul class=\"navbar-nav mr-auto mt-md-0\">\n                <!-- This is  -->\n                <li class=\"nav-item\"> <a class=\"nav-link nav-toggler hidden-md-up text-muted waves-effect waves-dark\" href=\"javascript:void(0)\"><i class=\"mdi mdi-menu\"></i></a> </li>\n                <!-- ============================================================== -->\n                <!-- Search -->\n                <!-- ============================================================== -->\n                <li class=\"nav-item hidden-sm-down search-box\"> <a class=\"nav-link hidden-sm-down text-muted waves-effect waves-dark\" href=\"javascript:void(0)\"><i class=\"ti-search\"></i></a>\n                    <form class=\"app-search\">\n                        <input type=\"text\" class=\"form-control\" placeholder=\"Search & enter\"> <a class=\"srh-btn\"><i class=\"ti-close\"></i></a> </form>\n                </li>\n            </ul>\n            <!-- ============================================================== -->\n            <!-- User profile and search -->\n            <!-- ============================================================== -->\n            <ul class=\"navbar-nav my-lg-0\">\n                <!-- ============================================================== -->\n                <!-- Profile -->\n                <!-- ============================================================== -->\n                <li class=\"nav-item dropdown\">\n                    <a class=\"nav-link dropdown-toggle text-muted waves-effect waves-dark\" href=\"profile\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\"><img src=\"/dashboard/assets/images/users/1.jpg\" alt=\"user\" class=\"profile-pic m-r-10\" th:inline=\"text\"/>[[${userName}]]</a>\n                </li>\n            </ul>\n        </div>\n    </nav>\n</header>\n\n</body>\n\n</html>"
  },
  {
    "path": "src/main/resources/templates/fragments/sidebar.html",
    "content": "<!DOCTYPE html>\n\n<html xmlns:th=\"http://www.thymeleaf.org\">\n\n<head>\n    <title>Header</title>\n</head>\n\n<body>\n\n<div th:fragment=\"sidebar\">\n    <!-- ============================================================== -->\n    <!-- Left Sidebar - style you can find in sidebar.scss  -->\n    <!-- ============================================================== -->\n    <aside class=\"left-sidebar\">\n        <!-- Sidebar scroll-->\n        <div class=\"scroll-sidebar\">\n            <!-- Sidebar navigation-->\n            <nav class=\"sidebar-nav\">\n                <ul id=\"sidebarnav\">\n                    <li> <a class=\"waves-effect waves-dark\" href=\"dashboard\" aria-expanded=\"false\"><i class=\"mdi mdi-gauge\"></i><span class=\"hide-menu\">Dashboard</span></a>\n                    </li>\n                    <li> <a class=\"waves-effect waves-dark\" href=\"agency\" aria-expanded=\"false\"><i class=\"mdi mdi-factory\"></i><span class=\"hide-menu\">Agency</span></a>\n                    </li>\n                    <li> <a class=\"waves-effect waves-dark\" href=\"bus\" aria-expanded=\"false\"><i class=\"mdi mdi-bus\"></i><span class=\"hide-menu\">Buses</span></a>\n                    </li>\n                    <li> <a class=\"waves-effect waves-dark\" href=\"trip\" aria-expanded=\"false\"><i class=\"mdi mdi-road-variant\"></i><span class=\"hide-menu\">Trips</span></a>\n                    </li>\n                    <li> <a class=\"waves-effect waves-dark\" href=\"profile\" aria-expanded=\"false\"><i class=\"mdi mdi-account-check\"></i><span class=\"hide-menu\">Profile</span></a>\n                    </li>\n                </ul>\n            </nav>\n            <!-- End Sidebar navigation -->\n        </div>\n        <!-- End Sidebar scroll-->\n        <!-- Bottom points-->\n        <div class=\"sidebar-footer\">\n            <!-- item--><a href=\"\" class=\"link\" data-toggle=\"tooltip\" title=\"Settings\"><i class=\"ti-settings\"></i></a>\n            <!-- item--><a href=\"\" class=\"link\" data-toggle=\"tooltip\" title=\"Email\"><i class=\"mdi mdi-gmail\"></i></a>\n            <!-- item--><a href=\"logout\" class=\"link\" data-toggle=\"tooltip\" title=\"Logout\"><i class=\"mdi mdi-power\"></i></a> </div>\n        <!-- End Bottom points-->\n    </aside>\n</div>\n\n</body>\n\n</html>"
  },
  {
    "path": "src/main/resources/templates/layout/layout.html",
    "content": "<!DOCTYPE html>\n\n<html xmlns:th=\"http://www.thymeleaf.org\" xmlns:layout=\"http://www.ultraq.net.nz/web/thymeleaf/layout\">\n\n<head th:replace=\"fragments/header :: header\">\n    <title>Header</title>\n</head>\n\n<body class=\"fix-header fix-sidebar card-no-border\">\n<!-- ============================================================== -->\n<!-- Preloader - style you can find in spinners.css -->\n<!-- ============================================================== -->\n<div class=\"preloader\">\n    <svg class=\"circular\" viewBox=\"25 25 50 50\">\n        <circle class=\"path\" cx=\"50\" cy=\"50\" r=\"20\" fill=\"none\" stroke-width=\"2\" stroke-miterlimit=\"10\"/>\n    </svg>\n</div>\n<!-- ============================================================== -->\n<!-- Main wrapper - style you can find in pages.scss -->\n<!-- ============================================================== -->\n<div id=\"main-wrapper\">\n    <!-- Topbar header - style you can find in pages.scss -->\n    <div th:replace=\"fragments/navigation :: navigation\"></div>\n    <!-- Left Sidebar - style you can find in sidebar.scss  -->\n    <div th:replace=\"fragments/sidebar :: sidebar\"></div>\n    <!-- Page wrapper  -->\n    <div class=\"page-wrapper\" id=\"mainContent\">\n        <div layout:fragment=\"content\"></div>\n        <div th:replace=\"fragments/footer :: footer\"></div>\n    </div>\n</div>\n<!-- ============================================================== -->\n<!-- End Wrapper -->\n<!-- ============================================================== -->\n</body>\n\n</html>"
  },
  {
    "path": "src/main/resources/templates/login.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <meta http-equiv=\"X-UA-Compatible\" content=\"ie=edge\">\n    <title>Login</title>\n    <!-- Favicon icon -->\n    <link rel=\"icon\" type=\"image/png\" href=\"favicon.png\">\n    <!-- Font Icon -->\n    <link rel=\"stylesheet\" href=\"/auth/fonts/material-icon/css/material-design-iconic-font.min.css\">\n    <!-- Main css -->\n    <link rel=\"stylesheet\" href=\"/auth/css/style.css\">\n</head>\n<body>\n\n<div class=\"main\">\n    <!-- Sing in  Form -->\n    <section class=\"sign-in\">\n        <div class=\"container\">\n            <div class=\"signin-content\">\n                <div class=\"signin-image\">\n                    <figure><img src=\"/auth/images/signin-image.jpg\" alt=\"sing up image\"></figure>\n                    <a href=\"/signup\" class=\"signup-image-link\">Create an account</a>\n                </div>\n\n                <div class=\"signin-form\">\n                    <h2 class=\"form-title\">Login</h2>\n                    <form method=\"POST\" class=\"register-form\" id=\"login-form\" th:action=\"@{/login}\">\n                        <div class=\"form-group\">\n                            <label for=\"email\"><i class=\"zmdi zmdi-account material-icons-name\"></i></label>\n                            <input type=\"text\" name=\"email\" id=\"email\" placeholder=\"Email\"/>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"password\"><i class=\"zmdi zmdi-lock\"></i></label>\n                            <input type=\"password\" name=\"password\" id=\"password\" placeholder=\"Password\"/>\n                        </div>\n                        <div class=\"form-group\">\n                            <input type=\"checkbox\" name=\"remember-me\" id=\"remember-me\" class=\"agree-term\" />\n                            <label for=\"remember-me\" class=\"label-agree-term\"><span><span></span></span>Remember me</label>\n                        </div>\n                        <div class=\"form-group form-button\">\n                            <input type=\"submit\" name=\"signin\" id=\"signin\" class=\"form-submit\" value=\"Log in\"/>\n                        </div>\n                    </form>\n                    <div id=\"errors\" class=\"text-danger\" th:if=\"${(param.error != null) and (param.error[0] == 'true')}\">\n                        Invalid email or password\n                    </div>\n                    <div class=\"social-login\">\n                        <span class=\"social-label\">Or login with</span>\n                        <ul class=\"socials\">\n                            <li><a href=\"#\"><i class=\"display-flex-center zmdi zmdi-facebook\"></i></a></li>\n                            <li><a href=\"#\"><i class=\"display-flex-center zmdi zmdi-twitter\"></i></a></li>\n                            <li><a href=\"#\"><i class=\"display-flex-center zmdi zmdi-google\"></i></a></li>\n                        </ul>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </section>\n</div>\n\n<!-- JS -->\n<script src=\"/auth/vendor/jquery/jquery.min.js\"></script>\n</body>\n</html>"
  },
  {
    "path": "src/main/resources/templates/profile.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\" layout:decorator=\"layout/layout\">\n\n<head>\n</head>\n\n<body>\n\n<!-- ============================================================== -->\n<!-- Container fluid  -->\n<!-- ============================================================== -->\n<div class=\"container-fluid\" layout:fragment=\"content\">\n    <!-- ============================================================== -->\n    <!-- Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <div class=\"row page-titles\">\n        <div class=\"col-md-5 col-8 align-self-center\">\n            <h3 class=\"text-themecolor m-b-0 m-t-0\">Profile</h3>\n            <ol class=\"breadcrumb\">\n                <li class=\"breadcrumb-item\"><a href=\"home\">Home</a></li>\n                <li class=\"breadcrumb-item active\">Profile</li>\n            </ol>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <!-- ============================================================== -->\n    <!-- Start Page Content -->\n    <!-- ============================================================== -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- Column -->\n        <div class=\"col-lg-4 col-xlg-3 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <center class=\"m-t-30\"><img src=\"/dashboard/assets/images/users/5.jpg\" class=\"img-circle\"\n                                                width=\"150\"/>\n                        <h4 class=\"card-title m-t-10\" th:inline=\"text\">[[${name}]]</h4>\n                        <h6 class=\"card-subtitle\">Agency Admin</h6>\n                        <div class=\"row text-center justify-content-md-center\">\n                            <div class=\"col-4\"><a href=\"javascript:void(0)\" class=\"link\"><i class=\"icon-people\"></i>\n                                <font class=\"font-medium\">254</font></a></div>\n                            <div class=\"col-4\"><a href=\"javascript:void(0)\" class=\"link\"><i class=\"icon-picture\"></i>\n                                <font class=\"font-medium\">54</font></a></div>\n                        </div>\n                    </center>\n                </div>\n            </div>\n        </div>\n        <!-- Column -->\n        <!-- Column -->\n        <div class=\"col-lg-4 col-xlg-3 col-md-7\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <form action=\"#\" method=\"POST\" class=\"form-horizontal form-material\" th:action=\"@{/profile}\" th:object=\"${profileForm}\">\n                        <div class=\"form-group\">\n                            <label for=\"firstName\" class=\"col-md-12\">First Name</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{firstName}\" class=\"form-control form-control-line\" name=\"firstName\" id=\"firstName\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('firstName')}\" th:errors=\"*{firstName}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"lastName\" class=\"col-md-12\">Last Name</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{lastName}\" class=\"form-control form-control-line\" name=\"lastName\" id=\"lastName\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('lastName')}\" th:errors=\"*{lastName}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"mobileNumber\" class=\"col-md-12\">Phone No</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{mobileNumber}\" class=\"form-control form-control-line\" name=\"mobileNumber\" id=\"mobileNumber\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('mobileNumber')}\" th:errors=\"*{mobileNumber}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <div class=\"col-sm-12\">\n                                <button class=\"btn btn-success\">Update Profile</button>\n                            </div>\n                        </div>\n                    </form>\n                </div>\n            </div>\n        </div>\n        <!-- Column -->\n        <!-- Column -->\n        <div class=\"col-lg-4 col-xlg-3 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <form action=\"#\" method=\"POST\" class=\"form-horizontal form-material\" th:action=\"@{/password}\" th:object=\"${passwordForm}\">\n                        <div class=\"form-group\">\n                            <label class=\"col-md-12\">Email</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{email}\"\n                                       class=\"form-control form-control-line\" readonly=\"readonly\">\n                            </div>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"password\" class=\"col-md-12\">Password</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"password\" th:field=\"*{password}\"\n                                       class=\"form-control form-control-line\" name=\"password\" id=\"password\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('password')}\" th:errors=\"*{password}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <div class=\"col-sm-12\">\n                                <button class=\"btn btn-success\">Change Password</button>\n                            </div>\n                        </div>\n                    </form>\n                </div>\n            </div>\n        </div>\n        <!-- Column -->\n    </div>\n    <!-- Row -->\n    <!-- ============================================================== -->\n    <!-- End PAge Content -->\n    <!-- ============================================================== -->\n</div>\n<!-- ============================================================== -->\n<!-- End Container fluid  -->\n<!-- ============================================================== -->\n</body>\n\n</html>\n"
  },
  {
    "path": "src/main/resources/templates/signup.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <meta http-equiv=\"X-UA-Compatible\" content=\"ie=edge\">\n    <title>Sign Up</title>\n    <!-- Favicon icon -->\n    <link rel=\"icon\" type=\"image/png\" href=\"favicon.png\">\n\n    <!-- Font Icon -->\n    <link rel=\"stylesheet\" href=\"/auth/fonts/material-icon/css/material-design-iconic-font.min.css\">\n\n    <!-- Main css -->\n    <link rel=\"stylesheet\" href=\"/auth/css/style.css\">\n</head>\n<body>\n\n<div class=\"main\">\n    <!-- Sign up form -->\n    <section class=\"signup\">\n        <div class=\"container\">\n            <div class=\"signup-content\">\n                <div class=\"signup-form\">\n                    <h2 class=\"form-title\">Sign up</h2>\n                    <form action=\"#\" method=\"POST\" class=\"register-form\" id=\"register-form\" th:action=\"@{/signup}\" th:object=\"${adminSignupFormData}\">\n                        <div class=\"form-group\">\n                            <label for=\"firstName\"><i class=\"zmdi zmdi-account material-icons-name\"></i></label>\n                            <input type=\"text\" th:field=\"*{firstName}\" name=\"firstName\" id=\"firstName\" placeholder=\"First Name\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('firstName')}\" th:errors=\"*{firstName}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"lastName\"><i class=\"zmdi zmdi-account-o\"></i></label>\n                            <input type=\"text\" th:field=\"*{lastName}\" name=\"lastName\" id=\"lastName\" placeholder=\"Last Name\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('lastName')}\" th:errors=\"*{lastName}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"email\"><i class=\"zmdi zmdi-email\"></i></label>\n                            <input type=\"email\" th:field=\"*{email}\" name=\"email\" id=\"email\" placeholder=\"Your Email\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('email')}\" th:errors=\"*{email}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"password\"><i class=\"zmdi zmdi-lock\"></i></label>\n                            <input type=\"password\" th:field=\"*{password}\" name=\"password\" id=\"password\" placeholder=\"Password\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('password')}\" th:errors=\"*{password}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"agencyName\"><i class=\"zmdi zmdi-layers\"></i></label>\n                            <input type=\"text\" th:field=\"*{agencyName}\" name=\"agencyName\" id=\"agencyName\" placeholder=\"Agency Name\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('agencyName')}\" th:errors=\"*{agencyName}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"agencyDetails\"><i class=\"zmdi zmdi-assignment\"></i></label>\n                            <input type=\"text\" th:field=\"*{agencyDetails}\" name=\"agencyDetails\" id=\"agencyDetails\" placeholder=\"Agency Details\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('agencyDetails')}\" th:errors=\"*{agencyDetails}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <label for=\"mobileNumber\"><i class=\"zmdi zmdi-phone\"></i></label>\n                            <input type=\"text\" th:field=\"*{mobileNumber}\" name=\"mobileNumber\" id=\"mobileNumber\" placeholder=\"Contact Number\"/>\n                            <small class=\"text-danger\" th:if=\"${#fields.hasErrors('mobileNumber')}\" th:errors=\"*{mobileNumber}\"></small>\n                        </div>\n\n                        <div class=\"form-group\">\n                            <input type=\"checkbox\" name=\"agree-term\" id=\"agree-term\" class=\"agree-term\" />\n                            <label for=\"agree-term\" class=\"label-agree-term\"><span><span></span></span>I agree all statements in  <a href=\"#\" class=\"term-service\">Terms of service</a></label>\n                        </div>\n                        <div class=\"form-group form-button\">\n                            <input type=\"submit\" name=\"signup\" id=\"signup\" class=\"form-submit\" value=\"Register\"/>\n                        </div>\n                    </form>\n                </div>\n                <div class=\"signup-image\">\n                    <figure><img src=\"/auth/images/signup-image.jpg\" alt=\"sing up image\"></figure>\n                    <a href=\"/login\" class=\"signup-image-link\">I am already member</a>\n                </div>\n            </div>\n        </div>\n    </section>\n</div>\n\n<!-- JS -->\n<script src=\"/auth/vendor/jquery/jquery.min.js\"></script>\n</body>\n</html>"
  },
  {
    "path": "src/main/resources/templates/trip.html",
    "content": "<!DOCTYPE html>\n<html xmlns=\"http://www.w3.org/1999/xhtml\" xmlns:th=\"http://www.thymeleaf.org\"\n      xmlns:layout=\"http://www.ultraq.net.nz/thymeleaf/layout\" layout:decorator=\"layout/layout\">\n\n<head>\n</head>\n\n<body>\n<!-- ============================================================== -->\n<!-- Container fluid  -->\n<!-- ============================================================== -->\n<div class=\"container-fluid\" layout:fragment=\"content\">\n    <!-- ============================================================== -->\n    <!-- Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <div class=\"row page-titles\">\n        <div class=\"col-md-5 col-8 align-self-center\">\n            <h3 class=\"text-themecolor m-b-0 m-t-0\">Trip Details</h3>\n            <ol class=\"breadcrumb\">\n                <li class=\"breadcrumb-item\"><a href=\"home\">Home</a></li>\n                <li class=\"breadcrumb-item active\">Trips</li>\n            </ol>\n        </div>\n    </div>\n    <!-- ============================================================== -->\n    <!-- End Bread crumb and right sidebar toggle -->\n    <!-- ============================================================== -->\n    <!-- ============================================================== -->\n    <!-- Start Page Content -->\n    <!-- ============================================================== -->\n    <!-- Row -->\n    <div class=\"row\">\n        <!-- column -->\n        <div class=\"col-lg-8 col-md-7\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <h4 class=\"card-title\">Trips</h4>\n                    <h6 class=\"card-subtitle\">Agency Trips</h6>\n                    <div class=\"table-responsive\">\n                        <table class=\"table\">\n                            <thead>\n                            <tr>\n                                <th>#</th>\n                                <th>Bus Code</th>\n                                <th>Source Stop</th>\n                                <th>Destination Stop</th>\n                                <th>Duration</th>\n                                <th>Fare</th>\n                            </tr>\n                            </thead>\n                            <tbody>\n                            <th:block th:each=\"trip,iterationStatus : ${trips}\">\n                                <tr>\n                                    <td th:text=${iterationStatus.count}></td>\n                                    <td th:text=${trip.busCode}></td>\n                                    <td th:text=${trip.sourceStopName}></td>\n                                    <td th:text=${trip.destinationStopName}></td>\n                                    <td th:text=${trip.journeyTime}></td>\n                                    <td th:text=${trip.fare}></td>\n                                </tr>\n                            </th:block>\n                            </tbody>\n                        </table>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div class=\"col-lg-4 col-md-5\">\n            <div class=\"card\">\n                <div class=\"card-block\">\n                    <h3 class=\"card-title\">Add New Trip</h3>\n                    <h6 class=\"card-subtitle\">Enter details</h6>\n                    <form action=\"#\" method=\"POST\" class=\"form-horizontal form-material\" th:action=\"@{/trip}\" th:object=\"${tripFormData}\">\n                        <div class=\"form-group\">\n                            <label for=\"busCode\" class=\"col-md-12\">Bus Code</label>\n                            <div class=\"col-md-12\">\n                                <select class=\"form-control\" th:field=\"*{busCode}\" id=\"busCode\" name=\"busCode\">\n                                    <option th:each=\"bus : ${agency.buses}\"\n                                            th:value=\"${bus.code}\"\n                                            th:text=\"${bus.code}\"\n                                            th:selected=\"${bus.code == tripFormData.busCode}\">\n                                    </option>\n                                </select>\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('busCode')}\" th:errors=\"*{busCode}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"sourceStop\" th:field=\"*{sourceStop}\" class=\"col-md-12\">Source Stop</label>\n                            <div class=\"col-md-12\">\n                                <select class=\"form-control\" id=\"sourceStop\" name=\"sourceStop\">\n                                    <option th:each=\"stop : ${stops}\"\n                                            th:value=\"${stop.code}\"\n                                            th:text=\"${stop.name}\"\n                                            th:selected=\"${stop.code == tripFormData.sourceStop}\">\n                                    </option>\n                                </select>\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('sourceStop')}\" th:errors=\"*{sourceStop}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"destinationStop\" th:field=\"*{destinationStop}\" class=\"col-md-12\">Destination Stop</label>\n                            <div class=\"col-md-12\">\n                                <select class=\"form-control\" id=\"destinationStop\" name=\"destinationStop\">\n                                    <option th:each=\"stop : ${stops}\"\n                                            th:value=\"${stop.code}\"\n                                            th:text=\"${stop.name}\"\n                                            th:selected=\"${stop.code == tripFormData.destinationStop}\">\n                                    </option>\n                                </select>\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('destinationStop')}\" th:errors=\"*{destinationStop}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"tripDuration\" class=\"col-md-12\">Trip Duration(min)</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{tripDuration}\" class=\"form-control form-control-line\" name=\"tripDuration\" id=\"tripDuration\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('tripDuration')}\" th:errors=\"*{tripDuration}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <label for=\"tripFare\" class=\"col-md-12\">Fare</label>\n                            <div class=\"col-md-12\">\n                                <input type=\"text\" th:field=\"*{tripFare}\" class=\"form-control form-control-line\" name=\"tripFare\" id=\"tripFare\">\n                            </div>\n                            <small class=\"text-danger-padded\" th:if=\"${#fields.hasErrors('tripFare')}\" th:errors=\"*{tripFare}\"></small>\n                        </div>\n                        <div class=\"form-group\">\n                            <div class=\"col-sm-12\">\n                                <button class=\"btn btn-success\">Add Trip</button>\n                            </div>\n                        </div>\n                    </form>\n                </div>\n            </div>\n        </div>\n    </div>\n    <!-- Row -->\n    <!-- ============================================================== -->\n    <!-- End PAge Content -->\n    <!-- ============================================================== -->\n</div>\n<!-- ============================================================== -->\n<!-- End Container fluid  -->\n<!-- ============================================================== -->\n\n</body>\n\n</html>\n"
  },
  {
    "path": "src/test/java/com/starterkit/springboot/brs/BusReservationSystemApplicationTests.java",
    "content": "package com.starterkit.springboot.brs;\n\nimport org.junit.Test;\nimport org.junit.runner.RunWith;\nimport org.springframework.boot.test.context.SpringBootTest;\nimport org.springframework.test.context.junit4.SpringRunner;\n\n@RunWith(SpringRunner.class)\n@SpringBootTest\npublic class BusReservationSystemApplicationTests {\n\n    @Test\n    public void contextLoads() {\n    }\n\n}\n"
  }
]