@font-face {
    font-family: 'Book';
    src: url("../fonts/Book.otf")
}

@font-face {
    font-family: 'Heavy';
    src: url("../fonts/Heavy.otf")
}

@font-face {
    font-family: 'Medium';
    src: url("../fonts/Medium.otf")
}

@font-face {
    font-family: 'Roman';
    src: url("../fonts/Roman.otf")
}

body,
html {
    overflow-x: hidden;
    font-size: 12px
}

.img-responsive {
    display: inline-block
}

h1,
h2,
h3,
h4,
h5,
h6,
li,
ol,
p,
span,
ul {
    margin: 0;
    padding: 0
}

ol,
ul {
    list-style: none;
    padding-left: 0
}

button,
input,
select {
    border: none
}

button:focus,
input:focus,
select:focus {
    outline: none
}

::-moz-selection {
    background-color: #124097;
    color: #ffffff
}

::selection {
    background-color: #124097;
    color: #ffffff
}

@media screen and (min-width:768px) {
    body,
    html {
        font-size: 14px
    }
}

@media screen and (min-width:992px) {
    body,
    html {
        font-size: 15px
    }
}

@media screen and (min-width:1200px) {
    body,
    html {
        font-size: 16px
    }
}

@media screen and (min-width:768px) {
    .divider-desktop {
        -webkit-flex-grow: 1;
        -ms-flex-positive: 1;
        flex-grow: 1
    }
}

@font-face {
    font-family: 'Book';
    src: url("../fonts/Book.otf")
}

@font-face {
    font-family: 'Heavy';
    src: url("../fonts/Heavy.otf")
}

@font-face {
    font-family: 'Medium';
    src: url("../fonts/Medium.otf")
}

@font-face {
    font-family: 'Roman';
    src: url("../fonts/Roman.otf")
}

body,
html {
    overflow-x: hidden;
    font-size: 12px
}

.img-responsive {
    display: inline-block
}

h1,
h2,
h3,
h4,
h5,
h6,
li,
ol,
p,
span,
ul {
    margin: 0;
    padding: 0
}

ol,
ul {
    list-style: none;
    padding-left: 0
}

button,
input,
select {
    border: none
}

button:focus,
input:focus,
select:focus {
    outline: none
}

::-moz-selection {
    background-color: #124097;
    color: #ffffff
}

::selection {
    background-color: #124097;
    color: #ffffff
}

@media screen and (min-width:768px) {
    body,
    html {
        font-size: 14px
    }
}

@media screen and (min-width:992px) {
    body,
    html {
        font-size: 15px
    }
}

@media screen and (min-width:1200px) {
    body,
    html {
        font-size: 16px
    }
}

.header {
    padding: 10px 15px;
    background-color: #124097;
    text-align: center;
    min-height: 100px
}

.header__navigation {
    padding: 0
}

.header__navigation nav {
    border: none;
    margin-bottom: 0
}

.header__navigation nav #main-menu {
    padding: 0
}

.header__navigation a:not(.sub-menu) {
    font-family: "Book";
    font-size: 1.12rem;
    color: #ffffff
}

.header__navigation a:not(.sub-menu):active,
.header__navigation a:not(.sub-menu):focus,
.header__navigation a:not(.sub-menu):hover,
.header__navigation a:not(.sub-menu):link {
    color: #ffffff;
    background-color: transparent!important;
    text-decoration: none
}

.header__navigation i {
    font-size: 0.9rem
}

.header__navigation .navbar-header {
    margin-top: 10px
}

.header__navigation .navbar-header button {
    margin: 0 auto;
    float: none
}

.header__navigation .navbar-header button span {
    background-color: #ffffff!important
}

.header__navigation li.track a {
    display: inline-block;
    border: 1px solid #ffffff;
    border-radius: 30px
}

.header__navigation .dropdown-menu {
    border-radius: 5px!important;
    background-color: white!important;
    box-shadow: 0px 0px 9.5px 0.5px rgba(0, 0, 0, 0.25), 0px 1px 1.86px 0.14px rgba(16, 26, 57, 0.004)!important;
    padding: 0!important;
    border: none!important
}

.header__navigation .dropdown-menu li a {
    padding: 6px 20px;
    color: #124097;
    font-family: "Book";
    font-size: 1.12rem
}

.header__navigation .dropdown-menu li a:hover {
    background-color: #1964b9;
    color: #ffffff
}

.header__navigation .dropdown-menu li:first-child a {
    border-top-left-radius: 5px;
    border-top-right-radius: 5px
}

.header__navigation .dropdown-menu li:last-child a {
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px
}

@media screen and (min-width:768px) {
    .header .container {
        position: relative
    }
    .header__logo {
        position: relative;
        z-index: 12;
        width: auto;
        display: inline-block;
        margin: 0 auto;
        float: none
    }
    .header__navigation {
        position: absolute;
        z-index: 11;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%)
    }
    .header__navigation ul {
        width: 100%;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex
    }
    .header__navigation li>* {
        display: none;
        width: auto
    }
    .header__navigation li a {
        padding: 15px 10px
    }
    .header__navigation li:first-child a:not(.sub-menu) {
        padding-left: 0
    }
    .header__navigation .dropdown-menu {
        /*left: 50%!important;
        -webkit-transform: translateX(-50%)!important;
        -ms-transform: translateX(-50%)!important;
        transform: translateX(-50%)!important*/
    }
    .header__navigation .dropdown-menu:before {
        bottom: 100%;
        left: 50%;
        border: solid transparent;
        content: "";
        height: 0;
        width: 0;
        position: absolute;
        pointer-events: none;
        border-color: rgba(255, 255, 255, 0);
        border-bottom-color: #ffffff;
        border-width: 8px;
        margin-left: -8px
    }

    .header__navigation .dropdown-menu.submenu1 {
        left: 100% !important;
        top: 0;
    }
    .header__navigation .dropdown-menu.submenu1:before {
        border: none;
    }
}

@media screen and (min-width:992px) {
    .header__navigation li a {
        padding: 15px 25px
    }
}

.book {
    background-image: url("../images/book-bg.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    padding: 100px 15px;
    border-top: 3px solid #d21554;
    position: relative
}

.book__form {
    background-color: rgba(0, 0, 0, 0.72);
    border-radius: 10px;
    border-bottom: 4px solid #d21554;
    padding: 30px
}

.book__form h2 {
    text-align: center;
    font-family: "Medium";
    font-size: 2.06rem;
    color: #ffffff
}

.book__form-input {
    float: left;
    display: inline-block;
    height: 45px;
    font-size: 1.12rem;
    color: #5d5d5d;
    font-family: "Book";
    width: 100%;
    position: relative
}

.book__form-input:not(:first-of-type) {
    border-top: 1px solid #bcbcbc
}

.book__form-input:first-of-type {
    border-top-left-radius: 5px;
    border-top-right-radius: 5px
}

.book__form-input:first-of-type select {
    border-top-right-radius: 5px;
    border-top-left-radius: 5px
}

.book__form-input:last-child {
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px
}

.book__form-input:last-child button {
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px
}

.book__form-input i {
    position: absolute;
    top: 50%;
    left: 14px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 1.1rem;
    color: #c5932e
}

.book__form-input input,
.book__form-input select {
    padding: 0 15px 0 40px;
    height: 100%;
    width: 100%
}

.book__form-input select {
    background-color: #ffffff;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -webkit-border-radius: 0px;
    -moz-appearance: none;
    -moz-border-radius: 0px;
    -o-appearance: none;
    -o-border-radius: 0px;
    cursor: pointer
}

.book__form-input button {
    width: 100%;
    height: 100%;
    background-color: #d21554;
    font-size: 1.50rem;
    line-height: 45px;
    font-family: "Medium";
    color: #ffffff;
    text-transform: uppercase;
    text-shadow: 0px 1px 1.86px rgba(0, 0, 0, 0.53)
}

.book__form form {
    margin: 15px 0 20px 0;
    min-height: 45px
}

.book__form a {
    font-family: "Book";
    font-size: 0.87rem;
    color: #ffffff
}

@media screen and (min-width:768px) {
    .book__form-input {
        width: 16.66%
    }
    .book__form-input:not(:first-of-type) {
        border-left: 1px solid #bcbcbc;
        border-top: 0
    }
    .book__form-input:first-of-type {
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0
    }
    .book__form-input:first-of-type select {
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0
    }
    .book__form-input:last-child {
        border-top-right-radius: 5px;
        border-bottom-right-radius: 5px;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0
    }
    .book__form-input:last-child button {
        border-top-right-radius: 5px;
        border-bottom-right-radius: 5px;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0
    }
}

.howto {
    padding: 65px 15px 45px 15px;
    background-color: #ffffff
}

.howto__title {
    margin-bottom: 45px
}

.howto__title h2 {
    font-family: "Heavy";
    color: #373737;
    font-size: 1.87rem
}

.howto__steps-item {
    font-family: "Medium";
    max-width: 625px;
    font-size: 1.25rem;
    color: #373737;
    position: relative;
    padding-left: 70px
}

.howto__steps-item:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    background-repeat: no-repeat;
    background-size: 60%;
    background-position: center;
    width: 45px;
    height: 45px;
    border: 1px solid #124097;
    border-radius: 100%
}

.howto__steps-item--map:before {
    background-image: url("../images/i-map.png")
}

.howto__steps-item--ticket:before {
    background-image: url("../images/i-ticket.png")
}

.howto__steps-item--seat:before {
    background-image: url("../images/i-seat.png");
    background-size: 40%
}

.howto__steps-item--payment:before {
    background-image: url("../images/i-payment.png")
}

.howto__steps-item+.howto__steps-item {
    margin-top: 25px
}

.howto__steps-item span {
    font-family: "Heavy"
}

.howto__video {
    text-align: center
}

.howto__video img {
    cursor: pointer;
    margin-top: 50px
}

@media screen and (min-width:768px) {
    .howto {
        position: relative
    }
    .howto__video {
        position: absolute;
        right: 0;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%)
    }
}

.features {
    padding: 40px 15px 20px 15px;
    background-color: #e6ecf6;
    border-top: 1px solid #92abd8
}

.features__item+.features__item {
    margin-top: 35px
}

.features__item h2 {
    font-size: 1.62rem;
    color: #124097;
    font-family: "Heavy"
}

.features__item img {
    margin: 15px 0 25px 0
}

.features__item li,
.features__item p {
    font-size: 1.12rem;
    color: #373737;
    font-family: "Medium"
}

.features__item--payments img {
    margin: 25px 0 0 0
}

.features__item--list li {
    margin-top: 10px;
    padding-left: 40px;
    position: relative
}

.features__item--list li:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("../images/i-check.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    width: 26px;
    height: 26px
}

.features__item--list li:first-child {
    margin-top: 13px
}

@media screen and (min-width:768px) {
    .features__item+.features__item {
        margin-top: 0
    }
}

.info {
    padding: 35px 15px 20px 15px;
    background-color: #ebebeb;
    border-top: 1px solid #bcbcbc
}

.info__title h2 {
    font-size: 1.62rem;
    color: #373737;
    font-family: "Heavy"
}

.info__item {
    margin-top: 20px;
    padding: 0 0 20px 0
}

.info__item-image {
    width: 90px;
    height: 90px;
    border-radius: 45px;
    background-color: #124097;
    position: relative;
    margin: 0 auto
}

.info__item-image img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.info__item-copy {
    text-align: center;
    color: #373737
}

.info__item-copy h3 {
    font-size: 1.12rem;
    font-family: "Heavy";
    margin: 15px 0
}

.info__item-copy p {
    font-family: "Book";
    font-size: 1rem
}

@media screen and (min-width:768px) {
    .info__item {
        min-height: 197px
    }
    .info__item+.info__item:not(.info__item--breaker) {
        border-left: 1px solid #bcbcbc
    }
}

@media screen and (min-width:992px) {
    .info__item {
        min-height: 200px
    }
}

@media screen and (min-width:1200px) {
    .info__item {
        min-height: 203px
    }
    .info__item+.info__item {
        border-left: 1px solid #bcbcbc
    }
}

.download {
    padding: 40px 15px 45px 15px;
    background-color: #15449f;
    color: #ffffff
}

.download__copy h2 {
    font-family: "Medium";
    font-size: 1.50rem
}

.download__copy h3 {
    font-family: "Roman";
    font-size: 1.12rem;
    margin-top: 15px
}

.download__stores {
    margin-top: 20px
}

.download__stores img:last-child {
    margin-top: 15px
}

@media screen and (min-width:768px) {
    .download__stores {
        margin-top: 0
    }
    .download__stores li {
        width: 30%;
        float: right
    }
    .download__stores img:last-child {
        margin-top: 0
    }
}

.footer {
    padding: 30px 15px 10px 15px;
    background-color: #1964b9;
    border-top: 1px solid #113986;
    color: #fefefe
}

.footer__menu {
    margin-top: 25px
}

.footer__menu-item a {
    color: #fefefe;
    font-family: "Book";
    font-size: 1rem
}

.footer__menu-item+.footer__menu-item {
    margin-top: 8px
}

.footer__menu-item--title {
    font-size: 1.62rem;
    font-family: "Medium";
    margin-bottom: 5px
}

.footer__social {
    margin-top: 25px
}

.footer__social-title {
    font-size: 1.62rem;
    font-family: "Medium";
    margin-bottom: 5px
}

.footer__social ul li {
    width: 70px;
    height: 70px;
    border-radius: 35px;
    background-color: #1964b9;
    border: 5px solid #fefefe;
    position: relative;
    margin: 10px 6px 0 6px
}

.footer__social ul li i {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-size: 2.3rem;
    color: #fefefe
}

@media screen and (min-width:768px) {
    .footer__menu,
    .footer__social {
        margin-top: 0
    }
}

.copyright {
    padding: 20px 15px;
    background-color: #2a2a2a;
    color: #fefefe
}

.copyright h6 {
    font-size: 0.87rem;
    font-family: "Book"
}

.copyright__author,
.copyright__notice {
    text-align: center
}

.copyright__author {
    margin-top: 5px
}

@media screen and (min-width:768px) {
    .copyright__notice {
        text-align: left
    }
    .copyright__author {
        text-align: right
    }
}

.language {
    position: absolute;
    top: 40px;
    right: 0;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    background-color: #124097;
    padding: 10px 0 10px 10px;
    cursor: pointer
}

.language__content {
    padding: 5px;
    background-color: #ffffff;
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px
}

.language__content i {
    color: #373737
}

.language__content span {
    font-family: "Heavy";
    color: #d21554
}

.switch {
    background-color: #d21554;
    border-radius: 5px;
    height: 30px;
    width: auto;
    display: inline-block;
    position: relative;
    font-size: 0.93rem;
    color: #ffffff;
    font-family: "Book";
    line-height: 30px;
    cursor: pointer;
    padding: 0 0 0 5px;
    text-align: center
}

.switch li {
    float: left
}

.switch__cover {
    background-color: #ffffff;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    transition: right .25s, left .25s
}

.switch__cover--moved {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    left: auto;
    right: 0
}