﻿/*
    ====================================================================================================
    ----------------------------------------------------------------------------------------------------

    0.- FONTS
    1.- NORMALISE
        >> Bootstrap Adjustments
    2.- GLOBAL
        >> Typography
        >> Colours
    3.- ILLUSTRATIONS
        >> Burger Menu
        >> Cross (close)
        >> Plus/Minus
        >> Icons
    4.- FORM COMPONENTS
        >> Input & Textarea
        >> Search Input
        >> Select List
        >> Radio Buttons & Checkboxes
        >> Buttons & Tab-Labels
        >> Loading Gif
    5.- LAYOUT
        >> Flexbox
        >> Tabs
        >> Decorations
        >> Calendar
        >> Carousel
        >> Slideshow
        >> Addon Button
        >> Join Us
        >> Payment Steps
        >> Basket
    6.- SIDENAV
        >> Menu
        >> Menu Trigger
        >> User Menu (bottom)
        >> Sub-Menu
        >> Right-Menu
    7.- HEADER
        >> Top Section
        >> Middle Section
        >> Bottom Section
    8.- FOOTER
        >> Popup
        

    ----------


    Light Grey:     #e3e3e3
    Off-White Grey: #f1f1f1
    Off-White Blue: #f1eff0
    Cyan:           #96cee9
    Light Blue:     #8e92a6
    Key Blue:       #53589f
    Dark Blue:      #131313
    Light Purple:   #ebe6f3
    Purple:         #542967
    Red:            #db0018
    Pink:           #dc0072
    Gradient:       linear-gradient(to right, #db0018 0%, #dc0072 75%, #542967 100%)

    ----------------------------------------------------------------------------------------------------
    ====================================================================================================
*/





/*  ----------------------------------------------------------------------------------------------------

                                             1.- NORMALISE

    ---------------------------------------------------------------------------------------------------- */

html, body, nav, div, header, main, footer,
table, thead, tbody, tr, th, td, ol, ul, li,
h1, h2, h3, h4, h5, h6, p, a, i, strong, span, 
em, hr, button, input, textarea, option, label { box-sizing: border-box; margin: 0; padding: 0; border: 0; font-size: 62.5%; }

div,
ul { font-size: 0; } /* necessary to avoid white-space between elements */
ul li { list-style: none; }
img { width: 100%; }
button { background: 0; border: none; cursor: pointer; }
textarea { -ms-overflow-style: none; }



/*  >> Bootstrap Adjustments
    ------------------------------ */

.container { width: 100%; max-width: 100%; padding: 0 1.5rem; }

@media (min-width: 576px) {
    .container { width: 54rem; }
}

@media (min-width: 768px) {
    .container { width: 72rem; }
}

@media (min-width: 992px) {
    .container { width: 96rem; }
}

@media (min-width: 1200px) {
    .container { width: 114rem; }
}

@media (min-width: 1400px) {
    .container { width: 132rem; }
}




 
/*  ----------------------------------------------------------------------------------------------------

                                               2.- GLOBAL

    ---------------------------------------------------------------------------------------------------- */

html { width: 100vw; overflow-x: clip; }
body { width: 100%; background: #fff; overflow-x: clip; }
html.no-scroll,
body.no-scroll { overflow: hidden; }

/* mods */
.no-padding { padding: 0 !important; }
#EnvironmentInfoPanel, #VersionInfoPanel { display: none; }

@media (max-width: 767px) {
    .desktop-only { display: none !important; }
}

@media (min-width: 768px) {
    .mobile-only { display: none !important; }
}



/*  >> Typography
    ------------------------------ */

h1, h2, h3, h4, h5, h6, p, a, span, th, td, input,
select, textarea, label, ol, ul, li, button, label { color: #131313; font-family: 'Inter', sans-serif; }
h1, h2, h3, h4 { font-weight: 400; }
h5, h6 { font-weight: 700; }
p, button, input, textarea, li, label, th, td { font-size: 1.6rem; line-height: 2.2rem; }
input, textarea { -webkit-appearance: none; -moz-appearance: none; -webkit-box-shadow: none !important; -moz-box-shadow: none !important; box-shadow: none !important; }
b, i, em, strong, span { font-size: inherit; }
p, a, li { font-weight: 300; }
p b, a b, li b { font-weight: 400; }

h1 { font-size: 3rem; }
h2 { font-size: 2.4rem; }
h3 { font-size: 2rem; }
h4 { font-size: 1.8rem; }
h5 { font-size: 1.6rem; }
h6 { font-size: 1.4rem; }

p.main { font-size: 1.8rem; line-height: 2.4rem; }
p.small-print { font-size: 1.2rem; line-height: unset; }
a { font-size: inherit; text-decoration: none; }
li a { text-decoration: none; }

.error-msg { color: #db0018; font-size: 1.4rem; text-align: left; }
.error-msg.active { display: block; }

.response-area { display: none; position: relative; padding: 1rem 1rem .8rem; border-radius: 1rem; color: #fff; font-size: 1.2rem; font-weight: 400; line-height: initial; text-align: center; }
.response-area.error,
.response-area.success { display: block; }
.response-area.error { background: rgba(236,31,39,.75); }
.response-area.success { background: rgba(78,170,11,.75); }
.response-area:before { content: ''; position: absolute; right: 0; left: 0; width: 1rem; margin: auto; border: .7rem solid transparent; }
.response-area.point-up:before { top: -.7rem; border-top: none; }
.response-area.point-down:before { bottom: -.7rem; border-bottom: none; }
.response-area.error:before { border-top-color: rgba(236,31,39,.75); border-bottom-color: rgba(236,31,39,.75); }
.response-area.success:before { border-top-color: rgba(78,170,11,.75); border-bottom-color: rgba(78,170,11,.75); }

@media (min-width: 768px) {
    h1 { font-size: 3.4rem; }
    h2 { font-size: 3rem; }
    h3 { font-size: 2.2rem; }
    p.main { font-size: 2rem; line-height: 2.6rem; }
}

@media (min-width: 992px) {
    h1 { font-size: 4rem; }
    h2 { font-size: 3.4rem; }
    h3 { font-size: 2.5rem; }
    h4 { font-size: 2rem; }
    h5 { font-size: 1.8rem; }
    h6 { font-size: 1.6rem; }

    p.main { font-size: 2.2rem; line-height: 2.8rem; }
    .error-msg { font-size: 1.4rem; }
    .response-area { padding: 1.5rem; font-size: 1.4rem; }
}





/*  ----------------------------------------------------------------------------------------------------

                                            3.- ILLUSTRATIONS

    ----------------------------------------------------------------------------------------------------
    >> Cross (close)
    ------------------------------ */

.cross { position: absolute; width: 4rem; height: 4rem; padding: 1rem; border-radius: 50%; background-color: white; z-index: 100; }
.cross span { display: block; position: absolute; top: 2rem; right: 0; left: 0; width: 2rem; height: 2px; margin: auto; background: #131313; }
.cross span:first-child { -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }
.cross span:last-child { -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }



/*  >> Plus/Minus
    ------------------------------ */
.plus-minus { position: relative; width: 1.4rem; height: 1.4rem; }
.plus-minus span { position: absolute; right: 0; left: 0; margin: auto; width: 2px; height: 100%; background: #131313; }
.plus-minus span:first-child { -webkit-transform: rotate(90deg); -moz-transform: rotate(90deg); -ms-transform: rotate(90deg); -o-transform: rotate(90deg); transform: rotate(90deg); }
.tab.active .plus-minus span:last-child { display: none; }


/*  >> Icons
    ------------------------------ */
.icon { display: inline-block; vertical-align: middle; position: relative; width: 2rem; height: 2rem; fill: transparent; stroke-width: 4; overflow: hidden; }
.icon.clock { width: 1.8rem; margin-left: .1rem; margin-right: .1rem; }
.icon.click,
.icon.mobile { width: 2.5rem; height: 2.5rem; }
.icon.xl { width: 10rem; height: 10rem; }

.icon.black { fill: none; stroke: #131313; }
.icon.dark-blue:not(.xl) { fill: none; stroke: #131313; }
.icon.dark-blue.xl { fill: #131313; stroke: none; }
.icon.red { fill: none; stroke: #db0018; }
.icon.white { fill: none; stroke: #fff; }

.icon.social { width: 4rem; height: 4rem; }
.icon.social.white { fill: #fff; stroke: none; }
.icon.social.dark-blue { fill: #131313; stroke: none; }

.angle--up { -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.angle--right { -webkit-transform: rotate(0deg); -moz-transform: rotate(0deg); -ms-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg); }
.angle--down { -webkit-transform: rotate(90deg); -moz-transform: rotate(90deg); -ms-transform: rotate(90deg); -o-transform: rotate(90deg); transform: rotate(90deg); }
.angle--left { -webkit-transform: rotate(180deg); -moz-transform: rotate(180deg); -ms-transform: rotate(180deg); -o-transform: rotate(180deg); transform: rotate(180deg); }

.arrow { display: block; position: relative; width: 1.5rem; height: 1.4rem; -webkit-transition: margin .2s; -moz-transition: margin .2s; transition: margin .2s; }
.arrow span { position: absolute; -webkit-transition: background-color .2s; -moz-transition: background-color .2s; transition: background-color .2s; }
.arrow.black span { background: #222; }
.arrow.gray span { background: #7d7d7d; }
.arrow.white span { background: #fff; }
.arrow--up,
.arrow--down { width: 1.4rem; height: 1.5rem; }
.arrow--up span,
.arrow--down span { width: .2rem; }
.arrow--right,
.arrow--left { width: 1.5rem; height: 1.4rem; }
.arrow--right span,
.arrow--left span { height: .2rem; }
.arrow--up span:nth-of-type(1),
.arrow--up span:nth-of-type(3) { height: .9rem; top: -.15rem; }
.arrow--up span:nth-of-type(1) { left: .3rem; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.arrow--up span:nth-of-type(2) { left: calc(50% - .1rem); bottom: 0; height: 100%; }
.arrow--up span:nth-of-type(3) { right: .3rem; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.arrow--right span:nth-of-type(1),
.arrow--right span:nth-of-type(3) { width: .9rem; right: -.15rem; }
.arrow--right span:nth-of-type(1) { top: .3rem;  -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.arrow--right span:nth-of-type(2) { top: calc(50% - .1rem); left: 0; width: 100%; }
.arrow--right span:nth-of-type(3) { bottom: .3rem; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.arrow--down span:nth-of-type(1),
.arrow--down span:nth-of-type(3) { height: .9rem; bottom: -.15rem; }
.arrow--down span:nth-of-type(1) { right: .3rem; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.arrow--down span:nth-of-type(2) { left: calc(50% - .1rem); top: 0; height: 100%; }
.arrow--down span:nth-of-type(3) { left: .3rem; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.arrow--left span:nth-of-type(1),
.arrow--left span:nth-of-type(3) { width: .9rem; left: -.15rem; }
.arrow--left span:nth-of-type(1) { bottom: .3rem; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.arrow--left span:nth-of-type(2) { top: calc(50% - .1rem); right: 0; width: 100%; }
.arrow--left span:nth-of-type(3) { top: .3rem; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }

.payment { width: 100%; max-width: 4.2rem; height: 6.6vw; max-height: 2.8rem; border-radius: .3rem; }




/*  ----------------------------------------------------------------------------------------------------

                                          4.- FORM COMPONENTS

    ---------------------------------------------------------------------------------------------------- */

.input-wrapper,
.textarea-wrapper,
.select,
.radio-btns,
.checkboxes { display: inline-block; vertical-align: top; position: relative; width: 25rem; }



/*  >> Input & Textarea
    ------------------------------ */

input,
textarea { width: 100%; padding: .7rem; border: 1px solid #131313; border-radius: 1rem; resize: none; }
input[type=submit].btn { border: unset; line-height: unset; }
input + .error-msg,
textarea + .error-msg { display: none; margin: .2rem 0 1rem; color: #db0018; font-size: 1.2rem; }
input:not(input[type=submit]):focus,
textarea:focus { background: #f1eff0; border-color: #131313; color: #131313; }
input.error,
textarea.error { border-color: #db0018; }
input.error + .error-msg,
textarea.error + .error-msg { display: block; }
input:disabled,
textarea:disabled { background: #f1f1f1; border-color: #e3e3e3; color: #999; cursor: not-allowed; }

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    input[type=submit].btn { border: none; line-height: normal; }
}


/*  >> Search Input
    ------------------------------ */

.search { position: relative; max-width: 60rem; height: 4rem; margin: auto; }
.search input { height: 100%; }
.search button.btn { position: absolute; top: 0; right: 0; width: 5rem; height: 4rem; border: none; cursor: pointer; }
.search button.btn .icon { width: 2.2rem; height: 2.2rem; }

@media (min-width: 768px) {
    .search { margin-bottom: 1.5rem; }
    .search button.btn:hover { background: #131313; }
    .search button.btn .icon { top: .9rem; right: 0; left: 0; margin: auto; }
    .search button.btn:hover .icon { stroke: #fff !important; }
}



/*  >> Select List
    ------------------------------ */

.select { min-height: 4.8rem; cursor: pointer; }

.select ul { position: relative; width: 100%; background: #fff; }
.select > ul { border-radius: 1rem; }
.select ul li:not(.title--search) { padding: 1.2rem; }
.select ul li.title { position: relative; color: #131313; }
.select ul li.title:not(.title--search) svg { position: absolute; top: calc(50% - 1rem); }
.select ul li.title svg.align--left { left: 1rem; }
.select ul li.title svg:not(.align--left) { right: 0; }
.select ul li.title--search input { height: 100%; padding: .7rem 3.7rem .7rem .7rem; border: none; border-radius: 0; }
.select ul li.title--search svg { position: absolute; top: 0; right: 0; width: 4rem; height: 4rem; padding: 1.1rem; z-index: 2; }
.select ul li.option { display: none; border-top: 1px solid #f1eff0; }
.select ul li.option:first-child { border: none; }
.select ul li.option:last-child { border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; }
.select ul li a { display: block; color: #131313; text-decoration: none; }

.select.focus img { z-index: 2; }
.select.focus ul { position: absolute; border-color: #131313; z-index: 1; }
.select.focus ul li.title { background: #f1eff0; border-top-left-radius: 1rem; border-top-right-radius: 1rem; color: #131313; }
.select.focus ul li.title svg:not(.align--left):not(.angle--up-down) { background: #fff; -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.select.focus.down ul .title:before { -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.select.focus ul li.option:not(.active):not(.hidden) { display: block; }
.select.focus ul li.option.active { background: #f9f9f9; }
.select.focus ul li.option.hidden { display: none !important; }
.select.focus ul li.option svg { position: absolute; top: 1.2rem; right: 0; width: 1rem; }

.select .error-msg { display: none; margin: .2rem 0 1rem; color: #db0018; }
.select.error ul { border-color: #db0018; }
.select.error .error-msg { display: block; }

.select.disabled ul { background: #f1f1f1; border-color: #e3e3e3; color: #e3e3e3; }
.select.disabled ul li.title { color: #e3e3e3; cursor: not-allowed; }

/* mods */
.select.cities ul li.title svg.angle--right,
.select.cities ul li.title svg.angle--down { stroke-width: 8; padding: .6rem; background: #e9e9e9; border-radius: 50%; }

@media (min-width: 768px) {
  .select.focus li.option:hover { background: #f9f9f9; }
  .select.focus li.option:hover svg { stroke: #dc0072 !important; }
}

@media (min-width: 1200px) {
    .select ul li.title:not(.title--search) svg { right: 1.5rem; }
}



/*  >> Radio Button & Checkbox
    ------------------------------ */

.radio-btns .tick { display: block; position: relative; margin-bottom: 1.5rem; padding-left: 4rem; cursor: pointer; font-size: 1.6rem; font-weight: 300; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
.radio-btns .tick input { position: absolute; cursor: pointer; opacity: 0; }
.radio-btns .tick .mark { position: absolute; top: -.3rem; left: 0; width: 2.5rem; height: 2.5rem; background: #fff; border: 1px solid #131313; border-radius: 50%; }
.radio-btns .tick:hover .mark { background: #f1eff0; }
.radio-btns .tick input:checked ~ .mark { background: #131313; }
.radio-btns .tick .mark:after { content: ''; display: none; position: absolute; top: .7rem; left: .7rem; width: .9rem; height: .9rem; background: #fff; border-radius: 50%; }
.radio-btns .tick input:checked ~ .mark:after { display: block; }
.radio-btns .tick.error .mark { border-color: #db0018; }
.radio-btns .tick.error input:checked ~ .mark { background: #db0018; }
.radio-btns .tick.disabled { cursor: not-allowed; }
.radio-btns .tick.disabled .mark { background: #f1f1f1; border-color: #e3e3e3; cursor: not-allowed; }

.checkbox { display: block; position: relative; padding-left: 3.5rem; margin-bottom: 1rem; cursor: pointer; font-size: 1.4rem; line-height: unset; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
.checkbox input { position: absolute; width: 0; height: 0; cursor: pointer; opacity: 0; }
.checkbox .checkmark { position: absolute; top: 0; left: 0; width: 2rem; height: 2rem; background: #fff; border: .1rem solid #131313; border-radius: .5rem; }
.checkbox:hover input ~ .checkmark { background: #fff; }
.checkbox input:checked ~ .checkmark { background: #fff; border-radius: .5rem; }
.checkbox input:checked ~ .checkmark:after { display: block; }
.checkbox .checkmark:after { content: ''; position: absolute; top: .3rem; left: .3rem; width: calc(100% - .6rem); height: calc(100% - .6rem); background: #fff; border-radius: .4rem; }
.checkbox input.error ~ .checkmark:after { border-color: #db0018; }
.checkbox input:checked ~ .checkmark:after { background: #131313; }



/*  >> Buttons & Tab-Labels
    ------------------------------ */

.btn { display: inline-block; vertical-align: middle; position: relative; height: 5rem; border: .1rem solid #131313; border-radius: 1rem; cursor: pointer; font-size: 1.6rem; font-weight: 400; line-height: 4.8rem; text-align: center; }
.btn:disabled { cursor: not-allowed; opacity: .3; }
.btn .icon { -webkit-transition: right .2s; -moz-transition: right .2s; -o-transition: right .2s; transition: right .2s; }

.tab__label { width: 15rem; height: 4rem; border-radius: .5rem; }
.tab__label.border--gradient.active { color: #fff; }
.tab__label.border--gradient.active:after { background: transparent; }

@media (min-width: 768px) {
    .btn { font-size: 1.8rem; }
    .btn:hover .icon { right: 1rem; }
}



/*  >> Loading Gif
    ------------------------------ */

.loading { display: none; position: relative; width: 100%; background: rgba(255,255,255,.7) !important; text-align: center; z-index: 999; }
.loading.absolute { position: absolute; top: 0; left: 0; height: 100%; border-radius: 1rem; }
.loading img { position: absolute; top: calc(50% - 2rem); left: calc(50% - 2rem); width: 4rem; height: 4rem; }
.loading.active { display: block; }





/*  ----------------------------------------------------------------------------------------------------

                                               5.- LAYOUT

    ----------------------------------------------------------------------------------------------------
    >> Flexbox
    ------------------------------ */

.flexbox { display: -webkit-flex; display: flex; }
.flexbox.left { -webkit-justify-content: left; justify-content: left; }
.flexbox.right { -webkit-justify-content: right; justify-content: right; }
.flexbox.between { -webkit-justify-content: space-between; justify-content: space-between }
.flexbox.center { -webkit-justify-content: center; justify-content: center; }
.flexbox.same-width { -webkit-justify-content: stretch; justify-content: stretch; }
.flexbox.top { -webkit-align-items: start; align-items: start; }
.flexbox.middle { -webkit-align-items: center; align-items: center; }
.flexbox.bottom { -webkit-align-items: flex-end; align-items: flex-end; }
.flexbox.same-height { -webkit-align-items: stretch; align-items: stretch; }
.flexbox.wrap { -webkit-flex-wrap: wrap; flex-wrap: wrap; }



/*  >> Tabs
    ------------------------------ */

.tab { display: block; position: relative; width: 100%; overflow: hidden; }
.tab.overflow-visible { overflow: visible; }

.tab__header { height: 5rem; cursor: pointer; }
.tab__header.border-top { border-top: 2px solid #fff; }

.tab__body { height: 100%; max-height: 0; -webkit-transition: max-height .2s ease-out; -moz-transition: max-height .2s ease-out, padding .2s ease-out; -o-transition: max-height .2s ease-out, padding .2s ease-out; transition: max-height .2s ease-out, padding .2s ease-out; }
.tab__body .borders { padding: 1rem 0 2rem; border-top: 2px solid #fff; border-bottom: 2px solid #fff; }

.tab.active .tab__header .angle--down { -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.tab.active .tab__body { max-height: 80rem; }



/*  >> Decorations
    ------------------------------ */

.triangle { position: absolute; right: 0; left: 0; width: 4.4rem; margin: auto; background: transparent; border-right: 2.2rem solid transparent; border-left: 2.2rem solid transparent; z-index: 2; }
.triangle.top { top: 0; }
.triangle.bottom { bottom: 0; }

.triangle--up { border-bottom-width: 2rem; border-bottom-style: solid; }
.triangle--up.bg--dark-blue { border-bottom-color: #131313; }
.triangle--up.bg--light-purple { border-bottom-color: #f1eff0; }
.triangle--up.bg--white { border-bottom-color: #fff; }
.triangle--down { border-top-width: 2rem; border-top-style: solid; }
.triangle--down.bg--dark-blue { border-top-color: #131313; }
.triangle--down.bg--light-purple { border-top-color: #f1eff0; }
.triangle--down.bg--white { border-top-color: #fff; }

.triangle .icon { position: absolute; left: -1.2rem; width: 2.4rem; height: 2.4rem; }
.triangle--up .icon { top: 1.2rem; }
.triangle--down .icon { top: -3.2rem; }

@media (min-width: 992px) {
    .triangle { width: 5rem; border-right: 3rem solid transparent; border-left: 3rem solid transparent; }
    .triangle--up { border-bottom-width: 2.5rem; }
    .triangle--down { border-top-width: 2.5rem; }

    .triangle .icon { position: absolute; left: -1.7rem; width: 4.5rem; width: 3.5rem; height: 3.5rem; }
    .triangle--up .icon { top: 1.5rem; }
    .triangle--down .icon { top: -4.5rem; }
}



/*  >> Calendar
    ------------------------------ */

.calendar { width: 100%; border-radius: 1rem; overflow: hidden; }
.calendar * { font-size: 1.4rem; }

.ui-datepicker table { margin: 0; }

.calendar .ui-widget-header { padding: 1rem 0; background: #f1eff0; border: none; border-radius: 0; }

.calendar .ui-datepicker { padding: 0; }
.calendar .ui-datepicker .ui-datepicker-title,
.calendar .ui-datepicker th span { text-transform: uppercase; }
.calendar .ui-datepicker .ui-datepicker-prev,
.calendar .ui-datepicker .ui-datepicker-next,
.calendar .ui-state-hover,
.calendar .ui-widget-content .ui-state-hover,
.calendar .ui-widget-header .ui-state-hover { top: 1rem; background: transparent; border: none; }
.calendar .ui-datepicker .ui-datepicker-prev,
.calendar .ui-datepicker .ui-datepicker-next { line-height: 2.2rem; cursor: pointer; }
.calendar .ui-datepicker .ui-datepicker-prev { left: 2rem; }
.calendar .ui-datepicker .ui-datepicker-next { right: 2rem; }
.calendar .ui-datepicker .ui-datepicker-prev .icon,
.calendar .ui-datepicker .ui-datepicker-next .icon { width: 1.5rem; height: 1.5rem; }
.calendar .ui-datepicker th { padding: 0; line-height: 3.6rem; }
.calendar .ui-datepicker th span { font-size: 1.2rem; }

.calendar .ui-datepicker tbody { background: #f1eff0; }
.calendar .ui-datepicker tbody td { width: 5rem; height: 13vw; }
.calendar .ui-datepicker tbody td span { margin: auto; }

.calendar .ui-widget-content,
.calendar .ui-state-default { width: 100%; height: 100%; background: transparent; border: none; border-radius: 50%; color: #131313; line-height: 3.4rem; text-align: center; }
.calendar .ui-state-active,
.calendar .ui-widget-content .ui-state-active { background: #131313; border-color: #131313; color: #fff; }

.calendar .ui-state-default,
.calendar .ui-state-active,
.calendar .ui-state-highlight { width: 4rem; height: 4rem; }

@media (min-width: 380px) {
    .calendar .ui-datepicker tbody td { height: 5rem; }
}

@media (min-width: 768px) {
    .calendar .ui-datepicker tbody td { height: 6vw; padding: .5rem; }
}

@media (min-width: 992px) {
    .calendar .ui-datepicker tbody td { height: 5rem; }
}

@media (min-width: 1400px) {
    .calendar .ui-datepicker tbody td { height: 6rem; }
}



/*  >> Carousel
    ------------------------------ */

.carousel { position: relative; margin: auto; }
.carousel .slides { overflow: hidden; }
.carousel .slide { display: none; width: 100%; height: auto; visibility: hidden; opacity: 0; -webkit-transition: opacity .2s;  -moz-transition: opacity .2s;  -o-transition: opacity .2s;  transition: opacity .2s; }
.carousel .slide.active { display: block; visibility: visible; opacity: 1; }
.carousel .dots { position: absolute; bottom: 2rem; right: 0; left: 0; margin: auto; text-align: center; }
.carousel .dot { display: inline-block; vertical-align: middle; width: 1rem; height: 1rem; margin: 0 .5rem; background: rgba(255,255,255,.75); border-radius: 50%; box-shadow: 0 0 2rem #000; cursor: pointer; -webkit-transition: transform .2s;  -moz-transition: transform .2s;  -o-transition: transform .2s;  transition: transform .2s; }
.carousel .dot.active { background: #fff; -webkit-transform: scale(1.4); -moz-transform: scale(1.4); -ms-transform: scale(1.4); -o-transform: scale(1.4); transform: scale(1.4); }

/* mods */
.carousel.infinite { position: relative; width: 100%; padding: 2rem 0; }
.carousel.infinite .slides { display: flex; width: calc(300vw - 21rem); margin-left: calc(-100vw + 9rem); overflow: visible; }
.carousel.infinite .slide { position: relative; width: calc(100vw - 7rem); height: auto; border-radius: 1rem; box-shadow: 0 0 1rem rgba(0,0,0, .2); }
.carousel.infinite .slide.main { order: 1; }
.carousel.infinite .slide.prev { order: 0; }
.carousel.infinite .slide.prev,
.carousel.infinite .slide.next { display: block; }
.carousel.infinite .slide.next { order: 2; }
.carousel.infinite .slide img { border-radius: 1.1rem; }
.carousel.infinite .slide div { position: absolute; bottom: 0; left: 0;width: 100%; height: auto; }
.carousel.infinite .slide h4 { position: relative; height: 10rem; background: linear-gradient(to top, rgba(0,0,0, .75) 0%, transparent 100%); font-size: 1.8rem; line-height: 2.2rem; }
.carousel.infinite .slide h4 span { position: absolute; bottom: 1.5rem; left: 1.5rem; width: calc(100% - 3rem); color: #fff; text-shadow: 0 0 2rem #000; }
.carousel.infinite .slide h5 { height: 5rem; padding: 0 1.5rem; background: #fff; line-height: 5rem; }
.carousel.infinite .slide > a { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 1.1rem; z-index: 1; }
.carousel.infinite .arrow-btn { position: absolute; top: calc(50% - 2rem); width: 4rem; height: 4rem; background: rgba(255,255,255, .75); border-radius: 50%; cursor: pointer; z-index: 1; }
.carousel.infinite .arrow-btn:hover { background: #fff; }
.carousel.infinite .arrow-btn.prev { left: 0; }
.carousel.infinite .arrow-btn.next { right: 0; }
.carousel.infinite .arrow-btn * { pointer-events: none; }

@media (min-width: 576px) {
    .carousel.infinite .slides { width: 120rem; margin-left: calc(-40rem + ((51rem - 40rem) / 2)); }
    .carousel.infinite .slide { width: 40rem; height: auto; }
}

@media (min-width: 768px) {
    .carousel.infinite .slides { width: 150rem; margin-left: calc(-50rem + ((69rem - 50rem) / 2)); }
    .carousel.infinite .slide { width: 50rem; }
}

@media (min-width: 992px) {
    .carousel.infinite .slides { width: 180rem; margin-left: calc(-60rem + ((93rem - 60rem) / 2)); }
    .carousel.infinite .slide { width: 60rem; }
    .carousel.infinite .slide.next + .slide { display: block; order: 3; }
    .carousel.infinite .arrow-btn.prev { left: 2rem; }
    .carousel.infinite .arrow-btn.next { right: 2rem; }
}

@media (min-width: 1200px) {
    .carousel.infinite { margin-top: 1.5rem; border-radius: 1rem; overflow: hidden; }
    .carousel.infinite .slides { width: 198rem; margin-left: calc(-66rem + ((111rem - 66rem) / 2)); }
    .carousel.infinite .slide { width: 66rem; }
    .carousel.infinite .slide.next + .slide + .slide { display: block; order: 4; }
    .carousel.infinite .slide h4 { font-size: 1.6rem; font-weight: 600; line-height: 2rem; }
    .carousel.infinite .slide h4 span { bottom: 2rem; left: 2.5rem; width: calc(100% - 5rem); }
    .carousel.infinite .slide h5 { padding: 0 2.5rem; }
    .carousel.infinite .arrow-btn { top: calc(50% - 2rem); width: 4rem; height: 4rem; background: #fff; border-color: transparent; box-shadow: 0 0 1rem rgba(0,0,0, .1); }
    .carousel.infinite .arrow-btn.prev { left: 3.5rem; }
    .carousel.infinite .arrow-btn.next { right: 3.5rem; }
}

@media (min-width: 1400px) {
    .carousel.infinite { overflow: hidden; }
    .carousel.infinite .slides { width: 210rem; margin-left: calc(-70rem + ((129rem - 70rem) / 2)); }
    .carousel.infinite .slide { width: 70rem; }
    .carousel.infinite .arrow-btn.prev { left: 5rem; }
    .carousel.infinite .arrow-btn.next { right: 5rem; }
}



/*  >> Slider
    ------------------------------ */

.slider { position: relative; }
.slider .slides-wrapper { width: 100%; height: 100%; padding: 1rem 1.5rem 1.5rem; }
.slider__btn { border-radius: 50%; -webkit-transition: background-color .2s, transform .2s; -moz-transition: background-color .2s, transform .2s; transition: background-color .2s, transform .2s; z-index: 9; }
.slider__btn:not(.dot) { width: 3.5rem; height: 3.5rem; background: #f1eff0; }
.slider__btn:not(.dot):hover { background: #eee; -webkit-transform: scale(1.1); -moz-transform: scale(1.1); transform: scale(1.1); }
.slider__btn:not(.dot) .arrow { -webkit-transform: scale(.7); -moz-transform: scale(.7); transform: scale(.7); }
.slider__btn.dot { width: 1.4rem; height: 1.4rem; margin: 2rem .7rem; background: #777; }
.slider__btn.dot:hover,
.slider__btn.dot.active { background: #131313; }

.slider.slider--dots .slide { display: none; }
.slider.slider--dots .slide.active { display: block; }

.slider__header > .flexbox > a { color: #777; font-size: 1.4rem; font-weight: 500; text-decoration: none; }
.slider__header > .flexbox > .flexbox { display: none; }
.slider__header a:hover { color: #131313; }
.slider__header .slider__btn { margin-left: .5rem; }
.slide__content { position: relative; }
.slide__content p strong { font-weight: 600; }
.slide__content p.flexbox span { font-size: 1.4rem; margin-right: 1rem; }

.slide .slide__img { display: block; width: 100%; height: 8rem; }
.slide.attraction { width: 15.5rem; }
.slide.attraction:nth-of-type(n+11) { display: none; }
.slide.attraction.double .slide__content { min-height: 14.5rem; }
.slide.attraction .slide__content + .slide__content { margin-top: 1rem; }
.slide.attraction .slide__content .clickable-area { position: relative; }
.slide.attraction .slide__content .clickable-area > a { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.slide.attraction .slide__img { border: .1rem solid #f1eff0; border-radius: 1rem; -webkit-transition: background-size .2s; -moz-transition: background-size .2s; transition: background-size .2s; }
.slide.attraction .slide__content:hover .slide__img { background-size: 110% auto !important; }
.slide.attraction .slide__content h4 { margin: .8rem 0 0.5rem; font-size: 1.4rem; font-weight: 500; line-height: 1.8rem; }
.slide.attraction .slide__content h4 + p { color: #777; font-size: 1.3rem; line-height: 1.6rem; }

.slide.itinerary { width: 32rem; border-radius: 1rem; border: .1rem solid #ccc; overflow: hidden; }
.slide.itinerary .slide__content { padding: 1.5rem 1rem 1rem; }
.slide.itinerary .slide__content li p:nth-of-type(1) { width: calc(100% - 8rem); }
.slide.itinerary .slide__content li p:nth-of-type(2) { width: 8rem; text-align: right }
.slide.itinerary .slide__content li p { font-size: 1.4rem; line-height: 1.2; }
.slide.itinerary .slide__content .scrollable-content { width: calc(100% + 2rem); height: 16rem; margin: 1rem -1rem 2rem; padding: 0 1rem; overflow: scroll; }
.slide.itinerary .slide__content .scrollable-content li { padding: .5rem 0; }
.slide.itinerary .slide__content .scrollable-content li + li { border-top: .1rem solid #f1eff0; }
.slide.itinerary .slide__content .scrollable-content + ul { padding: 1rem; background: #f1eff0; border-radius: .6rem; }
.slide.itinerary .slide__content .scrollable-content + ul p { padding: .2rem 0; font-weight: 400; }
.slide.itinerary .slide__content .scrollable-content + ul li:last-of-type p { font-weight: 500; }

@media (max-width: 575px) {
    .slider .slider__body { width: calc(100% + 3rem); margin: 0 -1.5rem; }
}

@media (min-width: 576px) {
    .slider .slides-wrapper { padding: 1rem 0 1.5rem; }
    .slide .slide__img { height: 8.5rem; }
    .slide.attraction { width: 20rem; }
    .slide.attraction.double .slide__content { min-height: 15rem; }
    .slide.itinerary { width: 40rem; }
}

@media (max-width: 991px) {
    .slider .slider__body { overflow-x: auto; scroll-padding-left: 0; scroll-padding-left: 1.5rem; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
    .slider .slider__body .slides-wrapper { gap: 1.5rem; width: max-content; }
    .slider .slider__body .slides-wrapper .slide { flex: 0 0 auto; scroll-snap-align: start; }
}

@media (min-width: 992px) {
    .slider__btn.dot { width: 1.6rem; height: 1.6rem; }
    .slider__header > .flexbox > a { margin-right: 3rem; font-size: 1.6rem; }
    .slider__header > .flexbox > .flexbox { display: -webkit-flex; display: flex; }
    .slider .slides-wrapper { padding: 1.5rem 0 0; }
    .slide:not(.double) .slide__img { height: 12.6rem; }
    .slide.attraction:not(.double) { width: calc(33.3% - .67rem); }
    .slide.attraction:not(.double):not(:nth-of-type(n+3)) { margin-right: 1rem; }
    .slide.attraction:not(.double):nth-of-type(n+4) { display: none !important; }
    .slide.attraction .slider__header > .flexbox { display: -webkit-flex; display: flex; }
    .slide.attraction.double .slide__img { height: 10rem; }
    .slide.attraction.double .slide__content { min-height: 17.5rem; }
    .slide.attraction .slide__content h4 { font-size: 1.5rem; }
    .slide.attraction .slide__content h4 + p { font-size: 1.4rem; line-height: 1.8rem; }
    .slide.itinerary { width: calc(50% - 1rem); }
    .slide.itinerary:nth-of-type(n+3) { display: none; }
    .slide.itinerary .slide__content { padding: 1.5rem; }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .slide.attraction.double { width: calc(25% - .75rem); }
    .slide.attraction.double:nth-of-type(n+4) { margin-right: 0; }
    .slide.attraction.double:nth-of-type(n+5) { display: none !important; }
}

@media (min-width: 1200px) {
    .slide:not(.double) .slide__img { height: 15.0rem; }
    .slide.attraction .slide__content h4 { line-height: 2rem; }
    .slide.attraction.double .slide__content { min-height: 19.1rem; }
    .slide.itinerary .slide__content { padding: 2rem; }
    .slide.itinerary .slide__content .scrollable-content { height: 19rem; }
    .slide.itinerary .slide__content li p { font-size: 1.5rem; }
    .slide.itinerary .slide__content li p:nth-of-type(1) { width: calc(100% - 10rem); }
    .slide.itinerary .slide__content li p:nth-of-type(2) { width: 10rem; }
}

@media (min-width: 1200px) and (max-width: 1399px) {
    .slide.attraction.double { width: calc(20% - .8rem); }
    .slide.attraction.double:nth-of-type(n+5) { margin-right: 0; }
    .slide.attraction.double:nth-of-type(n+6) { display: none !important; }
}

@media (min-width: 1400px) {
    .slide:not(.double) .slide__img { height: 17.4rem; }
    .slide.attraction:not(.double) .slide__content h4 { font-size: 1.8rem; line-height: 2.2rem; }
    .slide.attraction.double { width: calc((100%/6) - (5rem/6)); }
    .slide.attraction.double:nth-of-type(n+6) { margin-right: 0; }
    .slide.attraction.double:nth-of-type(n+7) { display: none !important; }
    .slide.itinerary { width: calc(50% - 1.5rem); }
    .slide.itinerary .slide__content { padding: 2.5rem; }
    .slide.itinerary .slide__content .scrollable-content { height: 23rem; }
    .slide.itinerary .slide__content li p { font-size: 1.6rem; }
}



/*  >> Slideshow
    ------------------------------ */

.slideshow { position: relative; width: 100%; max-width: 140rem; height: calc(100vw / 4); overflow: hidden; }
.slideshow ul { position: absolute; top: 0; width: 100%; -webkit-transition: left .5s ease-in-out;  -moz-transition: left .5s ease-in-out;  -o-transition: left .5s ease-in-out;  transition: left .5s ease-in-out; }
.slideshow ul li { display: inline-block; vertical-align: top; width: calc(100vw / 4); height: 100%; }
.slideshow ul li img { width: 100%; height: 100%; }

@media (min-width: 768px) {
    .slideshow { height: calc(100vw / 6); }
    .slideshow ul li { width: calc(100vw / 6); }
}

@media (min-width: 992px) {
    .slideshow { height: calc(100vw / 8); }
    .slideshow ul li { width: calc(100vw / 8); }
}

@media (min-width: 1400px) {
    .slideshow { height: 17.5rem; }
    .slideshow ul li { width: 17.5rem; }
}



/*  >> Addon Button
    ------------------------------ */

.addon-btn { display: inline-block; position: relative; width: 100%; height: 4rem; }
.addon-btn:hover { opacity: .8; }
.addon-btn > div { display: inline-block; vertical-align: middle; }
.addon-btn p { line-height: 4rem; }
.addon-btn .loading img { top: calc(50% - 1.5rem); left: calc(50% - 1.5rem); width: 3rem; height: 3rem; }

.addon-btn .price { width: calc(100% - 10rem); padding-left: 1rem; background: #8e92a6; border-top-left-radius: .5rem; border-bottom-left-radius: .5rem; text-align: left; }
.addon-btn .price > *:not(.loading) { display: inline-block; vertical-align: middle; }
.addon-btn .price .icon { display: none; width: 2rem; height: 2rem; margin-right: .5rem; }
.addon-btn .price p { font-weight: 400; }

.addon-btn .add-remove { position: relative; background: #131313; width: 10rem; height: 4rem; padding-left: 1.4rem; border-top-right-radius: .5rem; border-bottom-right-radius: .5rem; cursor: pointer; text-align: left; }
.addon-btn .add-remove p { color: #fff; }
.addon-btn .add-remove div { position: absolute; top: 1.4rem; right: 1.8rem; width: .9rem; height: .9rem; }
.addon-btn .add-remove div span { position: absolute; top: .5rem; left: 0; width: 100%; height: 1px; background: #fff; }
.addon-btn .add-remove div span:last-of-type { -webkit-transform: rotate(90deg); -moz-transform: rotate(90deg); -ms-transform: rotate(90deg); -o-transform: rotate(90deg); transform: rotate(90deg); }

.addon-btn.active .price { width: calc(100% - 6rem); background: #131313; }
.addon-btn.active .price .icon { display: inline-block; }
.addon-btn.active .price p,
.addon-btn.active .price p span { color: #fff; }
.addon-btn.active .add-remove { width: 6rem; background: #db0018; }
.addon-btn.active .add-remove p { display: none; }
.addon-btn.active .add-remove div { top: 1.3rem; left: 1.8rem; width: 2rem; height: 2rem; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }
.addon-btn.active .add-remove div span { height: 2px; }

@media (min-width: 576px) {
    .addon-btn .price { width: 20rem; }
    .addon-btn.active .price { width: 24rem; }
}



/*  >> Join Us
    ------------------------------ */

.join-us { padding: 3rem 0; text-align: center; }
.join-us ul { font-size: 0; }
.join-us ul li { display: inline-block; vertical-align: middle; position: relative; margin: 1.5rem 1rem 0; }
.join-us ul li a { display: block; width: 4rem; height: 4rem; }
.join-us ul li a .icon { width: 4rem; height: 4rem; }

@media (min-width: 768px) {
    .join-us { padding: 2rem 0; }
    .join-us ul li a:before { content: ''; display: block; position: absolute; top: -.7rem; left: -.5rem; width: 4.9rem; height: 4.9rem; border: 1px solid #fff; border-radius: 50%; opacity: 0; -webkit-transition: .2s; -moz-transition: .2s; -o-transition: .2s; transition: .2s; }
    .join-us ul li a:hover:before { top: -.7rem; left: -.5rem; width: 4.9rem; height: 4.9rem; opacity: 1; }
}



/*  >> Payment Steps
    ------------------------------ */

.payment-steps { display: none; margin-top: 3.7rem; }
.payment-steps hr { position: absolute; top: 6.3rem; left: 20%; width: 60%; height: 2px; margin: auto; }
.payment-steps .payment-step { display: inline-block; vertical-align: top; width: 33.33333%; text-align: center; }
.payment-step a { display: inline-block; text-decoration: none; }
.payment-step a .payment-step__title:before { content: '\a'; white-space: pre; }

.payment-step__num { display: inline-block; position: relative; width: 5rem; height: 5rem; margin: 0 auto 1rem; border-radius: 50%; color: #131313; font-size: 2.2rem; font-weight: 400; line-height: 5rem; z-index: 0; }
.payment-step__num:before { content: ''; position: absolute; top: 2px; left: 2px; width: 4.6rem; height: 4.6rem; background: #fff; border-radius: 50%; z-index: -1; }
.payment-step:first-of-type .payment-step__num { background: #db0018; }
.payment-step:nth-of-type(2) .payment-step__num { background: #dc0072; }
.payment-step:last-of-type .payment-step__num { background: #542967; }

.payment-step__title { font-size: 1.8rem; font-weight: 400; }

.payment-step.active .payment-step__num { color: #fff; }
.payment-step.active .payment-step__num:before { background: transparent; }

@media (min-width: 768px) {
    .payment-steps { display: block; }
}

@media (min-width: 992px) {
    .payment-step__num { font-size: 2.5rem; }
    .payment-step__title { font-size: 2rem; }
}



/*  >> Basket
    ------------------------------ */

.basket { padding: 2rem 1.5rem 1rem; border-radius: .5rem; }
.basket h3 a { display: none; font-size: 1.6rem; }
.basket h3 a .icon { width: 1.4rem; height: 1.4rem; margin: 0 .2rem 0 0; }
.basket h3 a:hover .icon { stroke: #dc0072; }

.basket .main__row.total { padding-top: 1rem; }
.basket .main__row.total *:not(span) { font-weight: 500; }
.basket .main__row.total span { display: inline-block; font-size: 1.4rem; font-weight: 300; }
.basket .main__row .full { width: 100%; margin-bottom: 1rem; }
.basket .main__row .fees { margin-top: 1rem; margin-bottom: 3rem; }
.basket .main__row p.side { font-weight: 400; }
.basket .main__row p.small-print { color: #777; }

.basket .main__row.insurance { padding: 2rem 0; }
.basket .main__row.insurance > p { padding-top: .5rem; font-size: 1.4rem; line-height: 1.2; }
.basket .main__row.insurance button.open { width: 2.5rem; height: 2.5rem; margin-left: 1rem; border: .1rem solid #8a6fdf; border-radius: 50%; cursor: pointer; color: #8a6fdf; }
.basket .main__row.insurance button.open:hover { background: #fff; }
.basket .main__row.insurance .icon { margin-left: 1rem; cursor: pointer; }
.basket .main__row.insurance h5 { font-weight: 400; }
.basket .main__row.insurance .insurance-popup { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; padding: 3rem; background: rgba(0,0,0,.25); z-index: 9999; }
.basket .main__row.insurance .insurance-popup:not(.active) { display: none !important; }
.basket .main__row.insurance .insurance-popup .wrapper { position: relative; width: 100%; max-width: 60rem; height: auto; padding: 3rem; background: #fff; border-radius: 1rem; box-shadow: 0 0 1rem 0 rgba(0,0,0, .25); }
.basket .main__row.insurance .insurance-popup .wrapper .cross { top: 0; right: 0; cursor: pointer; }
.basket .main__row.insurance .insurance-popup .wrapper h3 { padding: 0 3rem 1rem 0; }
.basket .main__row.insurance .insurance-popup .wrapper p { line-height: 2rem; }
.basket .main__row.insurance .insurance-popup .wrapper p b {  }
.basket .main__row.insurance .insurance-popup .wrapper span { text-decoration: underline; }
.basket .main__row.insurance .insurance-popup .wrapper button.warning { width: calc(50% - .5rem); max-width: 18rem; height: 4rem; margin-top: 2rem; }
.basket .main__row.insurance .insurance-popup .wrapper button.cancel { border: .1rem solid #131313; border-radius: .5rem; }
.basket .main__row.insurance .insurance-popup .wrapper button.cancel:hover { background: #f1eff0; }
.basket .main__row.insurance .insurance-popup .wrapper button.confirm { margin-left: 1rem; background: #e05a51; border-radius: .5rem; color: #fff; }
.basket .main__row.insurance .insurance-popup .wrapper button.confirm:hover { opacity: .75; }

.basket .inner__row { padding: 1rem; background: #fff; border: .1rem solid #ccc; border-radius: 1rem; }
.basket .inner__row + .inner__row { margin-top: 1rem; }
.basket .inner__row h5 { margin-bottom: 1rem; }
.basket .inner__row h5 .icon { margin-right: 1rem; }
.basket .inner__row h5 .text { width: calc(100% - 3rem); font-weight: 500; }
.basket .inner__row .side { width: 50%; }
.basket .inner__row .side .old-price { color: #777; font-size: 1.3rem; text-decoration: line-through; }
.basket .inner__row .side .item-price { margin: 0 1rem 0 .5rem; font-weight: 400; }
.basket .inner__row .counter * { display: inline-block; vertical-align: middle; width: 3rem; height: 3rem; line-height: 3rem; text-align: center; }
.basket .inner__row .counter .tickets { font-weight: 400; }
.basket .inner__row .counter div { position: relative; background: #fff; border: .1rem solid #131313; border-radius: 50%; cursor: pointer; }
.basket .inner__row .counter div span { position: absolute; margin: auto; background: #131313; }
.basket .inner__row .counter div span:first-of-type { top: 50%; right: 0; left: 0; width: 1.2rem; height: .1rem; }
.basket .inner__row .counter div span:nth-of-type(2) { top: calc(50% - .5rem); right: 0; left: 0; width: .1rem; height: 1.2rem; }
.basket .inner__row .counter div:hover { background: #131313; }
.basket .inner__row .counter div:hover span { background: #fff; }
.basket .inner__row .counter div.disabled { border-color: #d5d9f2; }
.basket .inner__row .counter div.disabled span { background: #d5d9f2; }
.basket .inner__row .counter div.disabled:hover { background: #fff; cursor: not-allowed; }
.basket .inner__row .counter div.disabled:hover span { background: #d5d9f2; }

@media (min-width: 768px) {
    .basket { margin-top: 6.8rem; padding-bottom: 2rem; }
}



/*  >> Response
    ------------------------------ */

.response { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(30,37,78,.5); cursor: pointer; z-index: 99999; }
.response * { pointer-events: none; }
.response__window { position: relative; width: calc(100% - 5rem); max-width: 50rem; padding: 1rem; background: #fff; border-radius: .5rem; }
.response__window .border { padding: 2rem 1rem 2rem 3rem; border-radius: .5rem; }
.response__window h3 { padding: 0; font-size: 2.2rem; font-weight: 600; }
.response__window h3 + p { padding-top: .5rem; line-height: 2rem; }
.response__window .mark { display: block; position: absolute; top: -1rem; left: -1rem; width: 5rem; height: 5rem; border: .1rem solid #fff; border-radius: 50%; opacity: 0; -webkit-transform: rotate(45deg) scale(5); -moz-transform: rotate(45deg) scale(5); transform: rotate(45deg) scale(5); -webkit-transition: opacity .2s, transform .2s ease-in; -moz-transition: opacity .2s, transform .2s ease-in; transition: opacity .2s, transform .2s ease-in; }
.response__window .mark:after { content: ''; display: block; position: absolute; border: solid #fff; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.response__window .mark.visible { opacity: 1; -webkit-transform: rotate(0) scale(1); -moz-transform: rotate(0) scale(1); transform: rotate(0) scale(1); }
.response__window.error h3 { color: #cc8b23; }
.response__window.error .mark { background: #cc8b23; }
.response__window.error .mark:before { content: ''; display: block; position: absolute; right: calc(50% - 1.3rem); -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); transform: rotate(-45deg); }
.response__window.error .mark:before,
.response__window.error .mark:after { top: calc(50% - .2rem); width: 2.6rem; height: .5rem; background: #fff;  }
.response__window.error .mark:after { left: calc(50% - 1.3rem); border: none; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }
.response__window.success h3 { color: #3bc49d; }
.response__window.success .mark { background: #3bc49d; }
.response__window.success .mark:after { top: 1rem; left: 1.7rem; width: 1.3rem; height: 2.4rem; border-width: 0 .5rem .5rem 0; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); transform: rotate(45deg); }





/*  ----------------------------------------------------------------------------------------------------

                                               6.- SIDENAV

    ---------------------------------------------------------------------------------------------------- */

.side-panel { display: block; position: absolute; top: 7rem; left: -100vw; width: 100vw; height: calc(100vh - 7rem); padding: 1.5rem; background: #fff; opacity: 0; overflow-x: hidden; overflow-y: scroll; -webkit-transition: left .2s ease-in-out, opacity .2s; -moz-transition: left .2s ease-in-out, opacity .2s; -o-transition: left .2s ease-in-out, opacity .2s; transition: left .2s ease-in-out, opacity .2s; z-index: 99; }
.side-panel.active { left: 0; opacity: 1; }
.side-panel * { font-weight: 400; }
.side-panel .icon { margin-right: .5rem; }

@media (min-width: 768px) {
    .side-panel { display: none; left: calc(-100% + 5rem); }
}



/*  >> Menu
    ------------------------------ */

.side-panel__nav { position: relative; width: 100%; }
.side-panel__nav .link--buy { margin: 1rem 0; }
.side-panel__nav .link--buy a { display: block; height: 5rem; padding: 0; background: #131313; border-radius: 1rem; color: #fff; line-height: 5rem; text-align: center; }
.side-panel__nav .menu { background: #f1eff0; border-radius: 1rem; }
.side-panel__nav .menu + .menu { margin-top: 1rem; }
.side-panel__nav .menu.languages { font-size: 0; }
.side-panel__nav .menu.languages button { width: 100%; padding: 0 1.5rem; }
.side-panel__nav .menu.languages.active button .angle--down { -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.side-panel__nav .menu .link { padding: 0 1.5rem; border: none !important; }
.side-panel__nav .menu .link a,
.side-panel__nav .menu button { height: 5rem; line-height: 5rem; }
.side-panel__nav .link:not(.link--buy) { border-bottom: .1rem solid #131313; }
.side-panel__nav .link:not(.link--buy) a { display: block; line-height: 5rem; }
.side-panel__nav .link.current a,
.side-panel__nav .menu.current .title span,
.side-panel__nav .right-menu li.current a { background: #fff; font-weight: 700; }

@media (min-width: 576px) {
    .side-panel__nav { width: 51rem; margin: 0 auto; }
}



/*  >> User Menu (bottom)
    ------------------------------ */

.side-panel__nav .user-menu { padding: 0; height: auto; }
.side-panel__nav .user-menu .account a { font-size: 1.4rem; }
.side-panel__nav .user-menu .account p { width: calc(100% - 5.3rem); }
.side-panel__nav .user-menu .account > p,
.side-panel__nav .user-menu .account > div { display: inline-block; padding: 0; font-size: 1.4rem; }
.side-panel__nav .user-menu .account > div { width: 4.9rem; border-left: 1px solid #fff; }
.side-panel__nav .user-menu .languages > p { padding: 0; font-size: 1.4rem; }
.side-panel__nav .user-menu .languages > div > div:last-of-type { border-color: #fff; }



/*  >> Sub-Menu
    ------------------------------ */

.side-panel__nav .menu .sub-menu { padding: 0 4rem; background: #f1eff0; border-radius: .5rem; }
.side-panel__nav .menu .sub-menu li { height: 4rem; border-top: 1px solid #fff; line-height: 4rem; }
.side-panel__nav .menu.down.active { height: auto; }
.side-panel__nav .menu.down.active .sub-menu { max-height: 35rem; }
.side-panel__nav .menu.down .sub-menu { width: 100%; height: auto; max-height: 0; overflow: hidden; -webkit-transition: max-height .2s ease-in-out; -moz-transition: max-height .2s ease-in-out; -o-transition: max-height .2s ease-in-out; transition: max-height .2s ease-in-out; }





/*  ----------------------------------------------------------------------------------------------------

                                               7.- HEADER

    ---------------------------------------------------------------------------------------------------- */

.header { position: relative; width: 100%; z-index: 9; }
.header a { text-decoration: none; }
.header .angle--down { width: 1rem; margin: 0 0 0 1rem; }
.header .loading { position: absolute; top: 0; left: 0; border-radius: 1rem; height:100%; }

.header .header-menu { position: relative; width: fit-content; }
.header .header-menu ~ div,
.header .header-menu ~ a { font-size: 1.6rem; }
.header .header-menu a:not(.flexbox):not(.header-menu__btn) { display: block; }

.header-menu__body { position: absolute; top: 0; right: 0; width: 14rem; padding: 0; background: #fff; border-radius: 1.3rem; box-shadow: 0 0 1rem .1rem rgba(0,0,0, .2); opacity: 0; overflow: hidden; text-align: left; transition: .2s ease-in-out; visibility: hidden; z-index: 2; }
.header-menu__body li a:not(.btn):not(.link) { padding: .4rem 1rem; border-left: 2px solid transparent; font-size: 1.5rem; font-weight: 400; }
.header-menu__body li.active a { cursor: default; }
.header-menu__body li a span { color: inherit; }

.header-menu.cities .header-menu__body li a svg { width: 1rem; stroke: #fff; }

.header-menu.cities .header-menu__body li a:hover,
.header-menu.cities .header-menu__body li a.active { background: #f1eff0; border-color: #96cee9; color: #96cee9; }
.header-menu.cities .header-menu__body li a:hover svg { stroke: #96cee9; }

.header-menu:not(.cities):not(.login-account) .header-menu__body li.active a,
.header-menu:not(.cities):not(.login-account) .header-menu__body li a:not(.link):hover { background: #f1f1f1; }
.header-menu:not(.cities) .header-menu__body li a:not(.btn) { display: block; text-align: left; }
.header-menu:not(.cities) .header-menu__body li a svg { margin-right: 1rem; }
.header-menu:not(.cities):not(.login-account) .header-menu__body li.active a:hover { color: inherit; }
.header-menu:not(.languages):not(.login-account) .header-menu__body li.active a { background: #fff; font-weight: 700; }

.header-menu.login-account .header-menu__body { width: auto; text-align: center; }
.header-menu.login-account .header-menu__body a { cursor: pointer; }
.header-menu.login-account .header-menu__body li { display: none; }
.header-menu.login-account .header-menu__body li:first-of-type { width: 32rem; padding: 1rem; }
.header-menu.login-account .header-menu__body li:last-of-type { width: 24rem; }
.header-menu.login-account .header-menu__body li.active { display: block; }
.header-menu.login-account .header-menu__body h4 { padding-top: 1rem; font-size: 1.8rem !important; font-weight: 500; text-align: left; }
.header-menu.login-account .header-menu__body input[type=text],
.header-menu.login-account .header-menu__body input[type=password],
.header-menu.login-account .header-menu__body label,
.header-menu.login-account .header-menu__body .btn,
.header-menu.login-account .header-menu__body .response-area { margin: 1rem 0 0; }
.header-menu.login-account .header-menu__body .btn {border: .1rem solid #131313; }
.header-menu.login-account .header-menu__body .btn:hover { background: #f1eff0 !important; border-color: #f1eff0 !important; color: #131313 !important; }
.header-menu.login-account .header-menu__body .btn:not(.btn--register) { background: #131313; color: #fff; }
.header-menu.login-account .header-menu__body .btn--register { background: transparent; color: #131313; }
.header-menu.login-account .header-menu__body .error-msg { margin-bottom: 0; }
.header-menu.login-account .header-menu__body label { text-align: left; }
.header-menu.login-account .header-menu__body .link { display: inline-block !important; margin: .5rem 0 1rem; font-size: 1.4rem; text-decoration: underline; }

.header-menu.login-account .header-menu__body .account__area a .icon { width: 1.7rem; }
.header-menu.login-account .header-menu__body .account__area a:hover { background: #f1f1f1; }
.header-menu.login-account .header-menu__body .account__area a:hover .icon { stroke: #dc0072; }

.header-menu.active .header-menu__btn .angle--down { -webkit-transform: rotate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
.header-menu.active .header-menu__body { top: 5rem; opacity: 1; visibility: visible; }

@media (max-width: 767px) {
    .header { border-bottom: .1rem solid #777; }
}

@media (min-width: 768px) {
    .header-menu.login-account .header-menu__body .account__area a { cursor: pointer; }
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .header-menu.cities .header-menu__body li a svg { display: none; }
}

@media all and (min-width: 768px) and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .header-menu.login-account .header-menu__body .login__btn { line-height: 3rem; }
}



/*  >> Top Section
    ------------------------------ */

.header__top { padding: 1.5rem 0; background: #fff; }
.header__top .logo { display: block; width: fit-content; }
.header__top .logo img { width: auto; height: 4rem; filter: invert(1); }
.header__top .burger-menu { display: block; position: relative; width: 2rem; height: 1.4rem; z-index: 1; }
.header__top .burger-menu span { position: absolute; top: .6rem; left: 0; width: 100%; height: 2px; background: #131313; }
.header__top .burger-menu span:first-child { top: 0; }
.header__top .burger-menu span:last-child { top: 1.2rem; }
.header__top .burger-menu.active span { top: .6rem; -webkit-transition: transform .2s; -moz-transition: transform .2s; -o-transition: transform .2s; transition: transform .2s; }
.header__top .burger-menu.active span:first-child { display: none; }
.header__top .burger-menu.active span:nth-child(2) { -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }
.header__top .burger-menu.active span:nth-child(3) { -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }
.header__top .header-menu__btn { height: 4rem; margin-left: 1rem; padding: 0 1.5rem; background: #f1eff0; border: .1rem solid #f1eff0; border-radius: 2rem; color: #131313; font-size: 1.6rem; font-weight: 500; line-height: 3.8rem; }
.header__top .header-menu__btn:hover { background: #fff; border-color: #131313; }
.header__top .header-menu__btn .icon:not(.angle--down) { margin-right: .5rem; }
.header__top .header-menu__btn .text { font-size: 1.4rem; }
.header__top .header-menu__btn .angle { width: 1rem; height: 1rem; margin-left: 1rem; }
.header__top .header-menu__btn .angle--down { stroke-width: 8; }
.header__top .login-account .header-menu__btn .icon { width: 1.8rem; height: 1.8rem; }

@media (min-width: 576px) {

}

@media (max-width: 767px) {
    .header__top .burger-menu ~ * { display: none; }
}

@media (min-width: 768px) {
    .header__top .burger-menu { display: none; }
    .header__top .header-menu__btn { padding: 0 2rem; }
}

@media (min-width: 992px) {
    .header__top { padding: 2rem 0; }
    .header__top .logo img { height: 5rem; }
    .header__top .header-menu__btn { padding: 0 2.5rem; }
}

@media (min-width: 1200px) {
    .header__top .logo img { height: 6rem; }
    .header__top .header-menu__btn { margin-left: 1.5rem; padding: 0 3rem; }
}

@media (min-width: 1400px) {
    .header__top { padding: 2.5rem 0; }
}



/*  >> Bottom Section
    ------------------------------ */

.header__bottom { position: relative; background: #f1eff0; box-shadow: 0 .2rem .3rem -.2rem rgba(0,0,0,.2); }
.header__bottom .container { min-height: 7rem; padding-top: 1rem; padding-bottom: 1rem; font-size: 0; }
.header__bottom .container > p { display: none; width: 11.5%; text-align: left; }
.header__bottom .container > ul { width: calc(100% - 20rem); margin-left: -1rem; }
.header__bottom .container > ul li { width: fit-content; }
.header__bottom .container > ul li a { display: block; width: fit-content; padding: .5rem 1rem; border-radius: .8rem; font-size: 1.4rem; font-weight: 400; }
.header__bottom .container > ul li a:not(.active):hover { background: #fff; }
.header__bottom .container > ul li a.active { font-weight: 700; }
.header__bottom .container > a { width: 15rem; background: #131313; border: .1rem solid #131313; border-radius: 1rem; color: #fff; font-size: 1.4rem; text-align: center; }
.header__bottom .container > a:hover { background: transparent; color: #131313; }

@media (max-width: 767px) {
    .header__bottom { display: none; }
}

@media (min-width: 768px) {
    .header__bottom { display: block; }
    .header__bottom .container > ul { width: calc(100% - 15rem); }
    .header__bottom .container > a { font-size: 1.5rem; }
}

@media (min-width: 992px) {
    .header__bottom .container > p { display: inline-block; }
    .header__bottom .container > ul { width: calc(100% - 30rem); margin-left: -1.5rem; }
    .header__bottom .container > ul li a { padding: .5rem 1.5rem; font-size: 1.5rem; }
    .header__bottom .container > a { width: 25rem; font-size: 1.6rem; }
}

@media (min-width: 1200px) {
    .header__bottom .container > ul { width: calc(100% - 35rem); margin-left: -2rem; }
    .header__bottom .container > ul li a { padding: .5rem 2rem; font-size: 1.6rem; }
    .header__bottom .container > a { width: 28rem; }
}





/*  ----------------------------------------------------------------------------------------------------

                                               8.- FOOTER

    ----------------------------------------------------------------------------------------------------  */

.footer { margin-top: 3rem; padding: 3rem 0; background: #000; }
.footer ul li a { display: inline-block; padding: .5rem 0; color: #fff; }
.footer .app-links a:not(.footer__logo) img { width: 12rem; border: .1rem solid #d9d9d9; border-radius: .5rem; }
.footer .copy { color: #fff; font-size: 1.2rem; }

.footer__logo { display: inline-block; width: 15rem; height: 4rem; margin-bottom: 3rem; }
.footer__logo img { width: 100%; height: auto; }

.footer .proud-of-msg { padding-top: .5rem; color: #fff; font-size: 1.6rem; }
.footer .partners-wrapper:nth-of-type(1) { padding-top: 2rem; }
.footer .partners-wrapper:nth-of-type(2) { padding-bottom: 2rem; border-bottom: .1rem solid #fff; }
.footer .partners-wrapper img { width: auto; height: auto; margin-bottom: 1rem; }
.footer .partners-wrapper img:not(:last-of-type) { margin-right: 2rem; }
.footer .partners-wrapper:nth-of-type(1) img { max-width: 12rem; max-height: 3rem; }
.footer .partners-wrapper:nth-of-type(2) img:nth-of-type(1) { max-height: 4rem; } 
.footer .partners-wrapper:nth-of-type(2) img:nth-of-type(2) { max-height: 3rem; } 

.footer__bottom { margin-top: 3rem; padding-top: 2rem; border-top: .1rem solid #fff; }
.footer__bottom a img { width: auto; height: 2rem; }

.footer .version--mobile .side { position: relative; width: 100%; padding: 2rem 0; border-bottom: .1rem solid #fff; }
.footer .version--mobile .side a { display: block; width: fit-content; }
.footer .version--mobile .side a + a { margin-left: 2rem; }
.footer .version--mobile .side a img { width: 12rem; }
.footer .version--mobile .copy { margin: 2rem auto 0; color: #fff; font-size: 1rem; text-align: center; }
.footer .version--mobile .social-icons { width: 100%; max-width: 10rem; margin: 3rem auto 0; }
.footer .version--mobile .social-icons a { display: block; width: 3rem; font-size: 0; line-height: 0; }
.footer .version--mobile .social-icons a:not(:last-of-type) { margin-right: 2rem; }
.footer .version--mobile .social-icons a img { width: 100%; }

.footer .version--desktop { display: none; }
.footer .version--desktop > .flexbox > div { width: calc(100% / 3); }
.footer .version--desktop ul { width: calc(50% - .75rem); }
.footer .version--desktop ul a { font-size: 1.4rem; }
.footer .version--desktop ul a:hover { color: #d9d9d9; text-decoration: underline; }
.footer .version--desktop .social-icons a { display: block; width: fit-content; border-radius: .5rem; overflow: hidden; }

.footer .cookies-msg-popup { display: none; position: fixed; bottom: .75rem; right: -62rem; width: calc(100% - 1.5rem); max-width: 50rem; padding: .4rem; background: #fff; box-shadow: 0 0 1rem .2rem rgba(0,0,0,.5); -webkit-transition: right .2s; -moz-transition: right .2s; transition: right .2s; z-index: 99; }
.footer .cookies-msg-popup.show { display: block; }
.footer .cookies-msg-popup.active { right: .75rem; }
.footer .cookies-msg-popup .flexbox { padding: 1.5rem 2rem; background: #f4f4f4; border: .1rem solid #222; }
.footer .cookies-msg-popup p { width: calc(100% - 12rem); color: #222; font-size: 1.3rem; line-height: 1.6rem; }
.footer .cookies-msg-popup p a { color: inherit; font-size: inherit; font-weight: 600; text-decoration: underline; }
.footer .cookies-msg-popup p a:hover { text-decoration: none; }
.footer .cookies-msg-popup button { width: 10rem; height: 5rem; background: #fff; border: .2rem solid #222; color: #222; font-size: 1.3rem; font-weight: 600; -webkit-transition: background-color .2s; -moz-transition: background-color .2s; transition: background-color .2s; }
.footer .cookies-msg-popup button:hover { background-color: #222; color: #fff; }

@media (min-width: 576px) {
    .footer .cookies-msg-popup { bottom: 2rem; box-shadow: -.5rem .5rem 1.5rem .2rem rgba(0,0,0,.5); }
    .footer .cookies-msg-popup.active { right: 2rem; }
    .footer .cookies-msg-popup .flexbox { padding: 2.5rem 3rem; }
    .footer .cookies-msg-popup p { width: calc(100% - 14rem); font-size: 1.4rem; line-height: 1.8rem; }
    .footer .cookies-msg-popup button { width: 12rem; font-size: 1.4rem; }
}

@media (min-width: 768px) {
    .footer { margin-top: 5rem; padding: 5rem 0; }
    .footer .cookies-msg-popup { max-width: 60rem; }
    .footer .cookies-msg-popup p { font-size: 1.5rem; line-height: 1.9rem; }
    .footer .cookies-msg-popup button { font-size: 1.5rem; }
    .footer .app-links a:not(.footer__logo) img { width: 12rem; }
}

@media (min-width: 992px) {
    .footer .version--desktop .app-links > .flexbox a:last-of-type { margin-left: 2rem; }
    .footer .app-links a:not(.footer__logo) img { width: 14rem; }
    .footer .version--mobile { display: none; }
    .footer .version--desktop { display: block; }
    .footer__bottom a img { height: 2.5rem; }
    .footer__bottom .social-icons a + a { margin-left: 2rem; }
    .footer .partners-wrapper:nth-of-type(2) { padding-bottom: 0; border: none; }
    .footer .partners-wrapper:nth-of-type(2) img { margin-bottom: 0; }
}

@media (min-width: 1200px) {
    .footer { margin-top: 6rem; }
    .footer__logo { width: 18rem; margin-bottom: 4rem; }
    .footer .app-links a:not(.footer__logo) img { width: 15rem; }
    .footer .version--desktop .app-links > .flexbox a:last-of-type { margin-right: 1.5rem; }
    .footer .version--desktop ul a { font-size: 1.6rem; }
    .footer__bottom { margin-top: 5rem; }
}

@media (min-width: 992px) and (max-width: 1399px) {
    .footer .partners-wrapper img:not(:last-of-type) { margin-right: 1.5rem; }
    .footer .partners-wrapper:nth-of-type(1) img { max-width: 11rem; max-height: 2.5rem; }
    .footer .partners-wrapper:nth-of-type(2) img:nth-of-type(1) { max-height: 3.5rem; }
    .footer .partners-wrapper:nth-of-type(2) img:nth-of-type(2) { max-height: 2.5rem; }
}

@media (min-width: 1400px) {
    .footer { margin-top: 8rem; padding: 6rem 0; }
    .footer__logo { width: 20rem; }
}