/* Minification failed. Returning unminified contents.
(1785,158): run-time error CSS1038: Expected hex color, found '#0005'
 */
/*!
 * Bootstrap Grid v4.0.0 (https://getbootstrap.com)
 * Copyright 2011-2018 The Bootstrap Authors
 * Copyright 2011-2018 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */@-ms-viewport{width:device-width}html{box-sizing:border-box;-ms-overflow-style:scrollbar}*,::after,::before{box-sizing:inherit}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-right:0;padding-left:0}.col,.col-1,.col-10,.col-11,.col-12,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-auto,.col-lg,.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.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-auto,.col-md,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.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-auto,.col-sm,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.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-auto,.col-xl,.col-xl-1,.col-xl-10,.col-xl-11,.col-xl-12,.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-auto{position:relative;width:100%;min-height:1px;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-1{margin-left:8.333333%}.offset-2{margin-left:16.666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.333333%}.offset-5{margin-left:41.666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.333333%}.offset-8{margin-left:66.666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.333333%}.offset-11{margin-left:91.666667%}@media (min-width:576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-sm-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-sm-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-sm-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-sm-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-sm-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-sm-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-sm-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-sm-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-sm-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-sm-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-sm-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-sm-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-sm-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-sm-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-sm-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-sm-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-sm-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-sm-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-sm-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-sm-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-sm-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-sm-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-sm-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.333333%}.offset-sm-2{margin-left:16.666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.333333%}.offset-sm-5{margin-left:41.666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.333333%}.offset-sm-8{margin-left:66.666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.333333%}.offset-sm-11{margin-left:91.666667%}}@media (min-width:768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-md-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-md-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-md-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-md-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-md-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-md-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-md-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-md-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-md-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-md-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-md-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-md-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-md-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-md-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-md-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.333333%}.offset-md-2{margin-left:16.666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.333333%}.offset-md-5{margin-left:41.666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.333333%}.offset-md-8{margin-left:66.666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.333333%}.offset-md-11{margin-left:91.666667%}}@media (min-width:992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-lg-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-lg-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-lg-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-lg-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-lg-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-lg-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-lg-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-lg-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-lg-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-lg-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-lg-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-lg-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-lg-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-lg-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-lg-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.333333%}.offset-lg-2{margin-left:16.666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.333333%}.offset-lg-5{margin-left:41.666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.333333%}.offset-lg-8{margin-left:66.666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.333333%}.offset-lg-11{margin-left:91.666667%}}@media (min-width:1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-xl-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-xl-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-xl-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-xl-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-xl-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-xl-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-xl-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-xl-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-xl-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-xl-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-xl-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-xl-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-xl-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-xl-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-xl-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-xl-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-xl-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-xl-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-xl-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-xl-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-xl-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-xl-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-xl-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.333333%}.offset-xl-2{margin-left:16.666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.333333%}.offset-xl-5{margin-left:41.666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.333333%}.offset-xl-8{margin-left:66.666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.333333%}.offset-xl-11{margin-left:91.666667%}}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}@media (min-width:576px){.d-sm-none{display:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-sm-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:768px){.d-md-none{display:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-md-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:992px){.d-lg-none{display:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-lg-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:1200px){.d-xl-none{display:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-xl-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media print{.d-print-none{display:none!important}.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-print-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}.flex-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}@media (min-width:576px){.flex-sm-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-sm-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-sm-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-sm-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-sm-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-sm-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-sm-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-sm-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-sm-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-sm-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-sm-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-sm-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-sm-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-sm-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-sm-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-sm-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-sm-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-sm-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-sm-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-sm-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-sm-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-sm-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-sm-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-sm-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-sm-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-sm-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-sm-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-sm-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:768px){.flex-md-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-md-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-md-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-md-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-md-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-md-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-md-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-md-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-md-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-md-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-md-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-md-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-md-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-md-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-md-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-md-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-md-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-md-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-md-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-md-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-md-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-md-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-md-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-md-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-md-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-md-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-md-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-md-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:992px){.flex-lg-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-lg-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-lg-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-lg-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-lg-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-lg-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-lg-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-lg-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-lg-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-lg-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-lg-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-lg-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-lg-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-lg-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-lg-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-lg-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-lg-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-lg-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-lg-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-lg-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-lg-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-lg-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-lg-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-lg-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-lg-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-lg-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-lg-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-lg-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:1200px){.flex-xl-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-xl-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-xl-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-xl-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-xl-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-xl-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-xl-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-xl-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-xl-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-xl-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-xl-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-xl-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-xl-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-xl-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-xl-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-xl-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-xl-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-xl-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-xl-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-xl-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-xl-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-xl-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-xl-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-xl-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-xl-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-xl-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-xl-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-xl-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}
/*# sourceMappingURL=bootstrap-grid.min.css.map */
/*
    ====================================================================================================
    ----------------------------------------------------------------------------------------------------

    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: 1.4; }
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; }
}

@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; }
    .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; }
label .error-msg,
input + .error-msg,
textarea + .error-msg,
.select + .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; }
label.error .checkmark,
input.error,
textarea.error { border-color: #db0018; }
label.error .error-msg,
input.error + .error-msg,
textarea.error + .error-msg,
.select.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; }
}

@media (min-width: 992px) {
    input, textarea { padding: 1.2rem 1rem; }
}



/*  >> 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: 3.8rem; cursor: pointer; }

.select ul { position: relative; width: 100%; background: #fff; }
.select > ul { border-radius: 1rem; }
.select ul li { font-weight: 400; }
.select ul li:not(.title--search) { padding: 0 1.5rem; line-height: 4rem; }
.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: .5rem; padding: .1rem; }
.select ul li.title--search input { height: 100%; padding: .7rem 3.7rem .7rem 1.4rem; 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: 992px) {
    .select { min-height: 4.8rem; }
    .select ul li:not(.title--search) { line-height: 5rem; }
    .select ul li.title--search input { height: 4.8rem; }
    .select ul li.title--search svg { height: 5rem; }
}

@media (min-width: 1200px) {
    .select ul li.title:not(.title--search) svg { right: 1rem; }
}



/*  >> 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; font-weight: 300; 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; }




/*  >> 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-widget-content,
.calendar .ui-state-default { width: 100%; height: 100%; margin: auto; 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: 6rem; padding: .5rem; }
}

@media (min-width: 992px) {
    .calendar .ui-widget-header { padding: 1.5rem 0; }
    .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: 1.5rem; }
    .calendar .ui-datepicker th { line-height: 4.6rem; }
}

@media (min-width: 1200px) {
    .calendar * { font-size: 1.5rem; }
    .calendar .ui-datepicker tbody td { height: 7rem; }
    .calendar .ui-widget-content,
    .calendar .ui-state-default { line-height: 4.4rem; }
    .calendar .ui-state-default,
    .calendar .ui-state-active,
    .calendar .ui-state-highlight { width: 5rem; height: 5rem; }
}



/*  >> 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 .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 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.2rem; height: 1.2rem; margin: 1rem .8rem; background: transparent; border: .1rem solid #131313; }
.slider__btn.dot:hover,
.slider__btn.dot.active { transform: scale(1.4); }
.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.ticket:first-of-type:last-of-type { width: calc(100vw - 3rem); }
.slide.ticket,
.slide.itinerary { width: 32rem; }
.slide.itinerary { 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: auto; max-height: 22rem; margin: 1rem -1rem 2rem; padding: 0 1rem; }
.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.ticket:first-of-type:last-of-type { width: 50rem; margin-left: .5rem; }
    .slide.ticket,
    .slide.itinerary { width: 40rem; }
}

@media (min-width: 768px) {
    .slide.ticket:first-of-type:last-of-type { width: 49rem; }
}

@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__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; }
    .slide.ticket { width: 100% !important; }
    .slide.ticket:nth-of-type(n+2) { display: none; }
}

@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 { max-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 { max-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 { 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, .basket .main__row.discount { padding: 2rem 0 0 0; }
.basket .main__row.insurance { margin-top: 1rem; padding: 1rem; background: #fff; border: .1rem solid #8a6fdf; border-radius: 1rem; }
.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 { cursor:pointer; }
.basket .inner__row h5 .text { width: calc(100% - 2rem); 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; }



/*  >> 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: .8rem 1.2rem; 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: .5rem; }
.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: fit-content; min-width: 100%; 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: 100%; }
.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.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 (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; }
.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; 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: 1rem; }
.header__top .header-menu__btn .text { font-size: 1.4rem; }
.header__top .header-menu__btn .angle { width: 1rem; height: 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 (max-width: 767px) {
    .header__top { border-bottom: .1rem solid #777; }
    .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 { 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; }
}



/*  >> Savings Message
    ------------------------------ */

.savings-msg { background: #8a6fdf22; }
.savings-msg * { color: #8a6fdf; font-size: 1.3rem; line-height: 1.1; }
.savings-msg a { display: block; padding: 1rem 0; font-weight: 400; text-align: center; }
.savings-msg a strong { font-weight: 600; }

@media (min-width: 768px) {
    .savings-msg * { font-size: 1.4rem; }
}

@media (min-width: 992px) {
    .savings-msg * { font-size: 1.5rem; line-height: 1.2; }
}

@media (min-width: 1400px) {
    .savings-msg * { font-size: 1.6rem; }
}





/*  ----------------------------------------------------------------------------------------------------

                                               8.- FOOTER

    ----------------------------------------------------------------------------------------------------  */

.footer { margin-top: 3rem; padding: 3rem 0; background: #000; }
.footer ul li p,
.footer ul li a { display: inline-block; padding: .5rem 0; color: #fff; }
.footer ul li p b { font-weight: 600; }
.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: 1rem; }
.footer__logo img { width: 100%; height: auto; }

.footer .proud-of-msg { color: #fff; font-size: 1.6rem; font-weight: 400; }
.footer .partners-wrapper { padding-top: 1rem; }
.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 img { max-width: 12rem; max-height: 5rem; }

.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:nth-of-type(1) {margin-top: 2rem; border-top: .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:nth-of-type(1) { width: 40%; }
.footer .version--desktop > .flexbox > div + div { width: 20%; }
.footer .version--desktop ul { width: 100%; }
.footer .version--desktop ul p { font-size: 1.6rem; }
.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; }
    .footer .version--mobile > .flexbox + .flexbox { margin-top: 2rem; border-top: .1rem solid #fff; }
    .footer .version--mobile .side { width: 33.33333%; margin: 0 !important; border: none !important; }
}

@media (min-width: 992px) {
    .footer__logo { margin-bottom: 0; }
    .footer .proud-of-msg { padding-top: 9rem; }
    .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 img { margin-bottom: 0; }
}

@media (min-width: 1200px) {
    .footer { margin-top: 6rem; }
    .footer__logo { width: 18rem; }
    .footer .proud-of-msg { padding-top: 8rem; }
    .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 p { font-size: 1.8rem; }
    .footer .version--desktop ul a { font-size: 1.6rem; }
    .footer__bottom { margin-top: 5rem; }
}

@media (min-width: 1400px) {
    .footer { margin-top: 8rem; padding: 6rem 0; }
    .footer__logo { width: 20rem; }
    .footer .proud-of-msg { padding-top: 6.5rem; }
    .footer .partners-wrapper img:not(:last-of-type) { margin-right: 1.5rem; }
    .footer .partners-wrapper img { max-width: 14rem; max-height: 6rem; }
}
/*  ----------------------------------------------------------------------------------------------------

                                                 ACCOUNT

    ---------------------------------------------------------------------------------------------------- */

.account-home { height: auto; min-height: calc(100vh - 66.2rem); }
.account-home h2 { padding: 3rem 0 2rem; font-weight: 600; }
.account-home .wrapper { width: 100%; margin: auto; padding: 3rem 0 2rem; font-weight: 600; }
.account-home-selection .wrapper { padding-top: 0; }
.account-home .wrapper h2 + p { width: 100%; margin: 0 auto 1.5rem; padding: 1rem; background: #8a6fdf; border-radius: 1rem; color: #fff; line-height: 1.2; }
.account-home .wrapper h2 + p span { display: inline-block; margin-bottom: .5rem; color: #fff; font-weight: 500; }
.account-home .wrapper h2 + p i { display: inline-block; width: 3rem; height: 3rem; margin-right: 1rem; background: #fff; border-radius: 50%; color: #8a6fdf; font-style: normal; font-weight: 900; line-height: 2.8rem; text-align: center; }
.account-home .wrapper h2 + p b { color: #fff; font-weight: 700; }

.account-home .account__sidenav { width: 100%; }
.account-home .account__sidenav a { display: block; width: calc(33.33333% - .33333rem); height: 4rem; border: .1rem solid #131313; border-radius: 1rem; font-size: 1.5rem; font-weight: 400; line-height: 3.8rem; text-align: center; text-decoration: none; }
.account-home .account__sidenav a:hover { background: #f1eff0; }
.account-home .account__sidenav a.active { background: #131313; color: #fff; }

.account-home .form-group { width: 100%; margin: auto; }
.account-home .form-group input { width: 100%; height: 4rem; margin-bottom: .5rem; }
.account-home .form-group .btn { width: 100%; height: 4rem; margin-top: 1.5rem; line-height: initial; }
.account-home .form-group button.btn:not(.btn-cancel),
.account-home .form-group input.btn { background: #131313; border: .1rem solid #131313; color: #fff; }
.account-home .form-group a.btn { background : #f1eff0; border-color: #f1eff0; color: #131313; }
.account-home .form-group .btn:not(.btn-cancel):hover { background: #fff; border-color: #131313; color: #131313; }
.account-home .form-group .btn + p { margin-top: 2rem; }
.account-home .form-group p + p { margin-top: .5rem; }
.account-home .form-group p.error-msg { margin-top: -1.5rem; }
.account-home .form-group#forgotPasswordDiv > p:first-of-type,
.account-home .form-group#changePasswordDiv > p:first-of-type { margin-bottom: 1rem; }

@media (min-width: 576px) {
    .account-home .wrapper { max-width: 47rem; }
    .account-home .wrapper h2 + p { padding: 1rem 2rem; }
    .account-home .account__sidenav { width: 47rem; margin: auto; }
    .account-home .form-group { width: 47rem; }
}

@media (min-width: 768px) {
    .account-home { min-height: calc(100vh - 50rem); }
    .account-home h2 { padding: 5rem 0 2rem; font-size: 2.2rem; }
    .account-home .wrapper { max-width: 50rem; }
    .account-home .account__sidenav { width: 50rem; }
    .account-home .form-group { width: 50rem; }
}

@media (min-width: 992px) {
    .account-home h2 { font-size: 2.5rem; }
    .account-home .wrapper { max-width: 60rem; }
    .account-home .wrapper h2 + p { padding: 1rem 3rem; }
    .account-home .form-group { width: 60rem; }
    .account-home .form-group input { height: 5rem; }
    .account-home .form-group .btn { height: 5rem; margin-top: 1.5rem; }
    .account-home .form-group .btn + p { margin-top: 3rem; }
    .account-home .account__sidenav { width: 60rem; }
    .account-home .account__sidenav a { width: calc(33.33333% - .66666rem); height: 5rem; font-size: 1.6rem; line-height: 4.8rem; }
}

@media (min-width: 1200px) {
    .account-home h2 { font-size: 2.8rem; }
}

@media (min-width: 1400px) {
    .account-home h2 { font-size: 3.2rem; }
    .account-home .wrapper { max-width: 65rem; }
    .account-home .form-group,
    .account-home .account__sidenav { width: 65rem; }
}



/*  >> User Account
    ------------------------------ */

/* panel */
.account-home .account__content { width: 100%; }
.account-home .account__content .area:not(.active) { display: none !important; }
.account-home .account__content .panel { position: relative; min-height: 100%; margin-top: 1rem; padding: 1.5rem; background: #f1eff0; border-radius: 1rem; }
.account-home .account__content .response-area { margin: 0; }
.account-home .account__content .response-area:before { display: none !important; }
.account-home .account__content .panel .tab .tab__header { height: auto; cursor: default; }
.account-home .account__content .panel .tab .tab__header h4 { font-size: 1.8rem; font-weight: 500; }
.account-home .account__content .panel .tab .tab__header button { color: #777; }
.account-home .account__content .panel .tab .tab__body { max-height: initial; }
.account-home .account__content .panel .tab .tab__body .readonly-details-area .flexbox > div { width: 100%; }

.account-home .your-passes .rows-wrapper > p { padding: 0 0 1rem !important; font-size: 1.6rem; }
.account-home .your-passes .purchase { padding: 1rem .5rem 1rem 1rem; background: #fff; border-radius: 1rem; }
.account-home .your-passes .purchase + .purchase { margin-top: 1rem; }
.account-home .your-passes .purchase h4 { margin-bottom: .5rem; font-weight: 600; }
.account-home .your-passes .purchase h4 ~ p { font-size: 1.5rem; }
.account-home .your-passes .purchase .pass-row > div { padding-right: 3rem; }
.account-home .your-passes .purchase .pass-row > a { position: absolute; top: 0; left: 0; width: 100%; height: 100%; text-align: right; }
.account-home .your-passes .create-rsv { width: 100%; background: #fff; border-radius: 1rem; padding: 1rem; font-size: 1.6rem; text-decoration: none; }
.account-home .your-passes .create-rsv:hover .text { color: #dc0072; }
.account-home .your-passes .create-rsv .plus-minus { display: inline-block; }
.account-home .your-passes .create-rsv .plus-minus span { display: block !important; }
.account-home .your-passes .create-rsv:hover .plus-minus span { background: #dc0072; }
.account-home .your-passes .rows-wrapper > p.no-rsv-msg { margin-top: 1.5rem; text-align: center; }
.account-home .your-passes .no-pass-msg { padding-top: 1.5rem !important; text-align: center; }

.account-home .account__reservations h4 { margin-bottom: 1.5rem; font-size: 1.8rem; font-weight: 500; }
.account-home .account__reservations p { line-height: 1.2; }
.account-home .account__reservations a { width: 100%; height: 5rem; margin-top: 2rem; background: #131313; border: .1rem solid #131313; color: #fff; font-size: 1.6rem; font-weight: 400; line-height: 4.8rem; text-align: center; }
.account-home .account__reservations a:hover { background: transparent; color: #131313; }

@media (min-width: 576px) {
    .account-home .account__content { width: 47rem; margin: auto; }
    .account-home .your-passes .no-rsv-msg { margin-top: 2rem; }
}

@media (min-width: 768px) {
    .account-home .account__content { width: 50rem;}
    .account-home .account__content .panel { padding: 2rem; }
    .account-home .your-passes .purchase,
    .account-home .your-passes .create-rsv { padding: 1.5rem; }
    .account-home .your-passes .no-rsv-msg { margin-top: 2.5rem; }
    .account-home .your-passes .rows-wrapper > p.no-pass-msg { padding-top: 5rem !important }
}

@media (min-width: 992px) {
    .account-home .account__content { width: 60rem; }
    .account-home .account__content .panel { margin-top: 2rem; padding: 2rem 3rem; }
    .account-home .your-passes .no-rsv-msg { margin-top: 3.5rem; }
    .account-home .your-passes .rows-wrapper > p.no-pass-msg { padding-top: 6rem !important }
}

@media (min-width: 1200px) {
    .account-home .account__content .panel { padding: 3rem 5rem; }
    .account-home .your-passes .no-rsv-msg { margin-top: 6rem; }
    .account-home .your-passes .rows-wrapper > p.no-pass-msg { padding-top: 8rem !important }
}

@media (min-width: 1400px) {
    .account-home .account__content { width: 65rem; }
}



.account-home .container .col-sm-6:first-of-type,
.account-home .container .col-sm-6:last-of-type { padding-left: 0; }

.user-account .response-area { margin: 0 0 1rem; padding: 0; }
.user-account .response-area p { padding: 2rem; color: #fff; }

.user-account section .container { padding: 0 1.5rem; }
.user-account section h4 { font-size: 2rem; }

.account-home .tab__body { border-bottom-right-radius: .5rem; border-bottom-left-radius: .5rem; -webkit-transition: max-height .2s, padding .2s, border-color .2s; -moz-transition: max-height .2s, padding .2s, border-color .2s; transition: max-height .2s, padding .2s, border-color .2s; }
.account-home .tab:not(.active) .tab__body { border-color: transparent; }
.account-home .your-passes .tab__body .col-12 { padding: 1rem; }
.account-home .your-passes .rows-wrapper > h3:nth-of-type(1) { padding: 1rem 0; }

.user-account .tab__body a:not(.group) { line-height: 3.1rem; text-align: center; }
.user-account .tab__body a.app-link { display: block; width: calc(50% - 5rem); max-width: 15rem; margin-top: .5rem; line-height: initial; }
.user-account .tab__body a.app-link + a.app-link { margin-left: 2rem; }
.user-account .tab__body a.btn { width: 100%; max-width: 35rem; line-height: 5rem; }
.user-account .tab__body a.btn .icon { top: 1.8rem; fill: #fff; }
.user-account .tab__body .checkbox { margin: 0; }
.user-account .tab__body .pass-row { position: relative; padding: 1.5rem 0; border-bottom: 1px solid #f1eff0; }
.user-account .tab__body .pass-row:first-of-type { padding-top: .5rem; }
.user-account .tab__body .pass-row:last-of-type { padding-bottom: .5rem; border: none; }
.user-account .tab__body .pass-row > div { width: 100%; }
.user-account .tab__body .pass-row > a .icon { height: 100%; }
.user-account .tab__body .pass-row h4 { padding-bottom: .5rem; font-weight: 400; }
.user-account .tab__body .pass-row__btn--refund { width: fit-content; height: 3.5rem; margin-top: 2rem; padding: 0 3rem; background: #fff; border: .1rem solid #131313; color: #1e254e; font-size: 1.6rem; line-height: initial; }
.user-account .tab__body .pass-row__btn--refund:hover { background: #131313; color: #fff; }

.user-account .tab .tab__body .rows-wrapper { margin-top: 1.5rem; }
.user-account .tab .tab__body .rows-wrapper + .rows-wrapper { margin-top: 2rem; }

.user-account__app-links { margin-top: 1rem; }
.user-account-links a { display: inline-block; vertical-align: middle; width: 38%; max-width: 14rem; }
.user-account-links a:first-of-type { margin-right: 1rem; }
.user-account-links a img { width: 100%; }

.user-details.edit-mode #accountInfoUpdateBtn { display: none; }
.user-account .user-details .tab { overflow: visible; }
.user-account .user-details .tab .tab__header { border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
.user-account .user-details .tab .tab__body { max-height: 100%; }

.edit-details-area,
.readonly-details-area { display: none; position: relative; }
.edit-details-area.active,
.readonly-details-area.active { display: block; }
.edit-details-area .form-group { width: 100% !important; }
.edit-details-area input { display: inline-block; vertical-align: middle; width: 100%; height: 4rem; margin-top: .5rem; }
.edit-details-area input#accountFirstName,
.edit-details-area input#accountLastName,
.edit-details-area input#accountCity,
.edit-details-area input#accountPostCode,
.edit-details-area input#accountRegion,
.edit-details-area .select { width: calc(50% - .5rem); }
.edit-details-area input#accountFirstName,
.edit-details-area input#accountCity,
.edit-details-area input#accountRegion { margin-right: 1rem; }
.edit-details-area .select { margin-top: .5rem; }
.edit-details-area .select > ul { border: 1px solid #131313; }
.edit-details-area .select ul li .icon { top: 1.6rem; }
.edit-details-area .select > ul > li { padding: 0 .7rem; line-height: 3.8rem; }
.edit-details-area .select.focus > ul { border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
.edit-details-area .select > ul > li:nth-of-type(2) { padding: 0; }
.edit-details-area .select.focus ul ul { width: calc(100% + 2px); max-height: 18rem; margin-left: -1px; border: 1px solid #131313; border-top: none; border-top-right-radius: 0; border-top-left-radius: 0; border-bottom-right-radius: 1rem; border-bottom-left-radius: 1rem; overflow-y: scroll; }
.edit-details-area .btn#updateInfoBtn { width: calc(50% - .25rem); margin-top: 2rem; background: #131313; color: #fff; }
.edit-details-area .btn#updateInfoBtn:hover { background: transparent; color: #131313; }
.edit-details-area .btn#accountInfoControlCancel { width: fit-content; height: fit-content; margin-right: 1.5rem; border: none; font-weight: 400; opacity: .7; text-decoration: underline; }
.edit-details-area .btn#accountInfoControlCancel:hover { opacity: 1; text-decoration: none; }

@keyframes dotLeft { 
  0% { left: 2rem; }
  55% { left: 2rem; }
  60% { left: .6rem; }
  75% { left: 0; }
  90% { left: .7rem; }
  95% { left: 2rem; }
  100% { left: 2rem; }
}

@keyframes dotCenter {
  0% { height: 3rem; }
  5% { height: 3rem; }
  10% { height: 2rem; }
  40% { height: 2rem; }
  50% { height: 3rem; }
  55% { height: 3rem; }
  60% { height: 2rem; }
  90% { height: 2rem; }
  100% { height: 3rem; }
}

@keyframes dotRight { 
  0% { right: 2rem; }
  5% { right: 2rem; }
  10% { right: .6rem; }
  25% { right: 0; }
  40% { right: .7rem; }
  45% { right: 2rem; }
  100% { right: 2rem; }
}

.loader { width: 100%; height: 10rem; }
.loader__wrapper { text-align: center; }
.loader__wrapper p { font-weight: 400; opacity: 0; text-align: center; -webkit-transition: opacity 2s; -moz-transition: opacity 2s; transition: opacity 2s; }
.loader__wrapper p.visible { opacity: 1; }
.loader__wrapper .animation { position: relative; width: 11rem; height: 2rem; margin: 1rem auto 0; }
.loader__wrapper .animation span { display: block; position: absolute; top: calc(50% - 1rem); width: 2rem; height: 2rem; border-radius: 50%; }
.loader__wrapper .animation span:nth-of-type(1) { left: 2rem; background: #db0018; animation: dotLeft 1.5s linear 0s infinite; }
.loader__wrapper .animation span:nth-of-type(2) { top: 0; right: 0; bottom: 0; left: 0; margin: auto; background: #dc0072; animation: dotCenter 1.5s linear 0s infinite;  }
.loader__wrapper .animation span:nth-of-type(3) { right: 2rem; background: #542967; animation: dotRight 1.5s linear 0s infinite; }

/* AJAX */
.ajax-cover { display: none; position: absolute; width: 100%; height: 100%; background: rgba(255,255,255,.7) !important; text-align: center; z-index: 999; }
.ajax-cover img { position: absolute; top: calc(50% - 4rem); left: calc(50% - 2rem); width: 4rem; height: 4rem; }
.ajax-cover-btn { display: none; position: absolute; top: 0 !important; left: 0; width: 100%; height: 100%; background: rgba(255,255,255,.7); text-align: center; z-index: 999; }
.ajax-cover-btn > img { display: initial !important; width: 2rem; margin-top: 1rem; }

@media (min-width: 576px) {
    .account-home .container .col-sm-6:last-of-type { padding-left: 2rem; }
    .user-account .tab__body .border-right { padding-right: 2rem; border-right: 1px solid #131313; }
    .account-home .travel-extras { padding-bottom: 5rem; }
    .user-account .travel-extras .extra .extra__qty-selector { width: 100%; max-width: initial; }
    .user-account .travel-extras .live-shows .extra { width: calc(50% - .5rem); padding-bottom: 6rem; }
    .user-account .travel-extras .live-shows .extra:nth-child(2) { margin-top: 0; }
    .user-account .travel-extras .live-shows .extra:nth-child(n+2) { margin-left: 1rem; }
    .user-account .travel-extras .live-shows .extra__content { padding-bottom: 0; }
    .user-account .travel-extras .live-shows .extra__content > .flexbox.right { position: absolute; right: 0; bottom: 0; padding: 0 1rem 1rem; }
}

@media (min-width: 768px) {
    .edit-details-area input,
    .edit-details-area .select { margin-top: .5rem; }
    .account-home .your-passes .rows-wrapper > h3:not(:nth-of-type(1)) { padding-top: 4rem; }
    .account-home .your-passes .rows-wrapper > h3:nth-of-type(1) { padding-top: 2rem; }
}


@media (min-width: 992px) {
    .account-home h2 { padding-bottom: 3rem; }
    .edit-details-area input { height: 5rem; }
    .edit-details-area .select > ul > li { padding: 0 1rem; line-height: 4.8rem; }
    .account-home .pass { padding: 4rem 2rem; }
    .account-home__head { padding: 0 5rem 3rem; }
    .account-home__body ul { min-height: 15rem; }
}





/*  ----------------------------------------------------------------------------------------------------

                                              RESERVATIONS

    ---------------------------------------------------------------------------------------------------- */

body > .loader { display: flex; justify-content: center; align-items: center; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(255,255,255, .5) !important; z-index: 99999; }
body > .loader img { width: 4rem; height: 4rem; }
body > .response + .loader { opacity: 0; }

.reservations { position: relative; width: 100%; max-width: 100vw; height: fit-content; min-height: calc(100vh - 12rem); overflow-x: hidden; }
.reservations > .container > .flexbox { width: 100%; max-width: 60rem; margin: auto; }
.reservations > .container > .flexbox > div { width: 100%; }
.reservations .dynamic-content { position: absolute; top: 0; left: 0; width: 100%; height: calc(100vh - 12rem); padding-top: 12rem; opacity: 0; -webkit-transition: opacity .2s; -moz-transition: opacity .2s; transition: opacity .2s; z-index: -1; }
.reservations .dynamic-content.active { opacity: 1; z-index: 9999; }
.reservations .dynamic-content.bg-color { background: rgba(0,0,0, .5); }
.reservations .dynamic-content .wrapper { padding-top: 0; }
.reservations .btn { width: 100%; height: 4rem; margin: 0; line-height: 4rem; }
.reservations .btn#rsvInit { height: 5rem; margin: 1rem 0 3rem; background: #131313; color: #fff; }
.reservations .btn#rsvInit:hover { background: transparent; color: #131313; opacity: .8; }
/* cancellation */
.reservations .cancellation-check { left: 0; z-index: 999; }
.reservations .cancellation-check > div { position: absolute; bottom: 0; left: 0; width: 100%; height: auto; background: #fff; border-top-right-radius: 1rem; border-top-left-radius: 1rem; }
.reservations .cancellation-check .btn { width: calc(50% - .5rem); }
.reservations .cancellation-check .btn.btn--cancellation-check-undo { border: .1rem solid #131313; }
.reservations .cancellation-check .btn.btn--cancellation-check-undo:hover { background: #f1eff0; color: #131313 }
.reservations .cancellation-check .btn.btn--cancellation-check-confirm { margin-top: 0 !important; background: #d95252; color: #fff; opacity: .8; }
.reservations .cancellation-check .btn.btn--cancellation-check-confirm:hover { opacity: 1; }
/* passes */
.reservations .pass  { padding: 0 !important; overflow: visible !important; }
.reservations .pass + .pass { margin-top: 1rem; }
.reservations .pass .border { width: calc(100% - 4.3rem); height: auto; border: .1rem solid #131313; border-radius: 1rem; }
.reservations .pass .border:hover { background: #f1eff0; }
.reservations .pass label { width: 100%; height: 3.8rem; margin: 0; padding-left: 4rem; font-size: 1.8rem; font-weight: 400; line-height: 3.8rem; }
.reservations .pass label input { margin-bottom: 0; }
.reservations .pass label .checkmark { top: .6rem; left: .6rem; width: 2.6rem; height: 2.6rem; }
.reservations .pass label input:checked ~ .checkmark:after { top: .3rem; left: .3rem; width: calc(100% - .6rem); height: calc(100% - .6rem); }
.reservations .pass .tab__header { width: 4rem; height: 4rem; padding: 1.2rem; border: .1rem solid #131313; border-radius: 1rem; }
.reservations .pass .tab__header:hover { background: #f1eff0; }
.reservations .pass .tab__header * { pointer-events: none; }
.reservations .pass .tab__header .icon { width: 1.4rem; margin-top: -.8rem; stroke-width: 5; }
.reservations .pass .tab__body { width: 100%; padding: 0 1rem 0 4rem; border: none; overflow: hidden; }
.reservations .pass .tab__body p { padding: 1rem 0; font-size: 1.5rem; line-height: 2rem; }
.reservations .pass .tab__body p + p { border-top: .1rem solid #131313; }
.reservations .pass.tab.active label { border-bottom: none; border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
.reservations .pass.tab.active:not(.disabled) .tab__body { padding: 0 1rem 1rem 4rem; }
.reservations .pass.tab.active.disabled .tab__body { padding: 0 1rem 1rem 1rem; }
.reservations .pass.disabled { opacity: .7; }
.reservations .pass.disabled .border,
.reservations .pass.disabled .tab__header { background: #eee; border-color: #999; }
.reservations .pass.disabled .tab__header .icon { stroke: #666; }
.reservations .pass.disabled label { display: block; padding-left: 1rem; }
.reservations .pass.disabled .tab__body { padding-left: 1rem; }

@media (min-width: 768px) {
    .reservations { min-height: calc(100vh - 20rem); }
    .reservations .dynamic-content { height: calc(100vh - 11.5rem); }
}

@media (min-width: 992px) {
    .reservations { height: auto; min-height: initial; overflow: initial; }
    .reservations h3 { font-size: 2.2rem !important; line-height: 3.3rem; }
    .reservations .dynamic-content.bg-color { background: transparent; }
    .reservations .container > .flexbox { max-width: initial; }
    .reservations .container > .flexbox > div { width: calc(50% - 1.5rem); min-height: 62rem; }
    .reservations .dynamic-content { position: relative; top: initial; left: initial; height: fit-content; background: transparent; opacity: 1 !important; z-index: 0 !important; }
    .reservations .btn { width: 100%; }
    .reservations .pass .tab__header .icon { margin-top: -1.2rem; }
}

@media (min-width: 1200px) {
    .reservations .btn { height: 5rem; line-height: 5rem; }
    .reservations .btn#rsvInit { height: 5rem; line-height: 5rem; }
    .reservations .container > .flexbox > div { width: calc(50% - 2.5rem); min-height: 67rem; }
    .reservations .dynamic-content { padding-top: 12.3rem; }
}

@media (min-width: 1400px) {
    .reservations .dynamic-content { padding-top: 12.8rem; }
}



/*  >> Groups
    ------------------------------ */

.reservations__groups { position: relative; min-height: calc(100vh - 29rem); }
.reservations__groups .empty-msg { position: absolute; top: 0; right: 0; bottom: 0; left: 0; height: fit-content; margin: auto; text-align: center; }
.reservations__groups .group { display: block; width: 100%; padding: 1rem; background: #fff; border: .1rem solid #131313; border-radius: 1rem; cursor: pointer; text-decoration: none; }
.reservations__groups .group + .group { margin-top: 1rem; }
.reservations__groups .group:hover { background: #f1eff0; }
.reservations__groups .group * { pointer-events: none; }
.reservations__groups .group h4 { margin-bottom: .5rem; }
.reservations__groups .group p { font-size: 1.6rem; }

.user-account .reservations__groups { min-height: initial !important; }

@media (min-width: 768px) {
    .reservations__groups { min-height: calc(100vh - 39rem); }
}

@media (min-width: 992px) {
    .reservations__groups { min-height: 42rem; }
}

@media (min-width: 992px) {
    .reservations__groups { min-height: 50rem; }
}



/*  >> List
    ------------------------------ */

.reservations__list { position: absolute; top: 1rem; right: -100vw; width: calc(100% - 2rem); max-width: 50rem; height: calc(100% - 2rem); padding: 1.5rem 1.5rem 5rem; background: #f1eff0; border-top-left-radius: 1rem; border-bottom-left-radius: 1rem; overflow-y: scroll; -webkit-transition: right .5s; -moz-transition: right .5s; transition: right .5s; }
.reservations__list.slide-in { right: 0; }
.reservations__list h3 .btn { width: 3rem; height: 2.8rem; margin: 0; border: none; font-size: 2.2rem; font-weight: 400; line-height: 2.8rem; text-align: left; }
.reservations__list h3 .btn .icon { position: relative; top: initial; right: initial; width: 1.2rem; height: 1.3rem; margin: 0; pointer-events: none; stroke-width: 8; }
.reservations__list h3 .btn + span { width: calc(100% - 3rem); }
.reservations__list .reservation { position: relative; width: 100%; height: auto; padding: 1rem; background: #fff; border-radius: 1rem; box-shadow: 0 0 1rem #0005; overflow: hidden; }
.reservations__list .reservation:nth-of-type(1) { margin-top: 3rem; }
.reservations__list .reservation + .reservation { margin-top: 1rem; }
.reservations__list .reservation.to-delete:after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(30,37,78,.5); z-index: 1; }
.reservations__list .reservation p { line-height: 1.2; }
.reservations__list .reservation p b { display: inline-block; margin-bottom: .5rem; font-weight: 500; }
.reservations__list .reservation p + p { font-size: 1.5rem; line-height: 2rem; }
.reservations__list .reservation ul { padding: 1.5rem 0; }
.reservations__list .reservation .pass .border { background: #f1eff0; border: none; }
.reservations__list .reservation .pass .border .checkbox { height: 4rem; padding-left: 1rem; cursor: default; pointer-events: none; }
.reservations__list .reservation .pass .border .checkbox .checkmark { display: none; }
.reservations__list .reservation .pass .tab__header { background: #f1eff0; border: none; }
.reservations__list .reservation .pass .tab__body { padding-left: 1rem !important; -webkit-transition: none; -moz-transition: none; transition: none; }
.reservations__list .reservation .tickets-link { display: block; width: 100%; margin-bottom: .5rem; font-size: 1.6rem; line-height: 2rem; text-align: center; }
.reservations__list .reservation .btn { font-size: 1.6rem; line-height: 3.8rem; }
.reservations__list .reservation .btn:hover { color: #fff !important; }
.reservations__list .reservation .btn.tickets-link { margin-top: .5rem; }
.reservations__list .reservation .btn.tickets-link:hover { background: #131313; }
.reservations__list .reservation .btn.btn--delete-reservation { border: .1rem solid #d95252; color: #d95252; }
.reservations__list .reservation .btn.btn--delete-reservation:hover { background: #d95252; } 
.reservations__list .reservation .btn + .btn { margin-top: .5rem; }
.reservations__list .reservation .cancellation-check { position: absolute; bottom: 1rem; left: 1rem; width: calc(100% - 2rem); height: auto; }
.reservations__list .reservation .cancellation-check > div { position: relative; min-height: 15rem; padding: 1rem; border-radius: 1rem; }
.reservations__list .reservation .cancellation-check > div > div { position: absolute; bottom: 1rem; left: 1rem; width: calc(100% - 2rem); }
.reservations__list .reservation .loader { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #fff; z-index: 1000; }

@media (min-width: 768px) {
    .reservations__list { padding: 0 3rem 5rem; }
    .reservations__list h3 { padding-top: 6rem; }
    .reservations__list .reservation .cancellation-check p { font-size: 1.6rem; line-height: 2.2rem; }
}

@media (min-width: 992px) {
    .reservations__list { position: relative !important; top: initial !important; left: initial !important; width: 100%; max-width: initial; height: auto; padding: .5rem .5rem 3rem; background: #fff; border-radius: 1rem; overflow: hidden; }
    .reservations__list h3 { padding: 1rem 0; border-bottom: .1rem solid #131313; }
    .reservations__list h3 .btn { margin-top: .3rem; }
    .reservations__list h3 + p { padding: 2rem 0 3rem; }
    .reservations__list .reservation {  margin: auto; }
    .reservations__list .reservation:nth-of-type(1) { margin-top: 0; }
    .reservations__list .reservation + .reservation { margin-top: 2rem; }
}

@media (min-width: 1200px) {
    .reservations__list h3 { padding: 1rem 0; }
    .reservations__list h3 + p { padding: 2rem 0 3rem; }
    .reservations__groups .group,
    .reservations__list .reservation { padding: 2rem; }
    .reservations__list .reservation .btn { line-height: 4.8rem; }
}

@media (min-width: 1400px) {
    .reservations__groups .group,
    .reservations__list .reservation { padding: 2rem 3rem; }
}



/*  >> Popup
    ------------------------------ */

.reservations__popup { display: block; width: 100%; height: 100%; }
.reservations__popup .panel { position: absolute; bottom: .5rem; left: .5rem; width: calc(100% - 1rem); height: 53rem; padding: .5rem; background: #fff; border-radius: 1rem; overflow: hidden; }
.reservations__popup .panel .cross { top: 0; right: 0; }
.reservations__popup .panel .cross * { pointer-events: none; }
.reservations__popup .panel .wrapper { position: relative; width: 100%; height: 100%; margin: auto; }
.reservations__popup .panel .wrapper .loader { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.reservations__popup .panel .loader { position: absolute; top: 0; left: 0; height: 53rem; }
.reservations__popup .panel .loader img { position: relative; top: initial; left: initial; }
.reservations__popup:not(.loading) .panel .loader { display: none; }
.reservations__popup .content h3 { padding: 1rem; border-bottom: .1rem solid #131313; }
.reservations__popup .content h3 .btn { width: 3rem; height: 2.8rem; margin: 0; border: none; font-size: 2.2rem; font-weight: 400; line-height: 2.8rem; }
.reservations__popup .content h3 .btn .icon { position: relative; top: initial; right: initial; width: 1.2rem; height: 1.3rem; margin: 0; pointer-events: none; stroke-width: 8; }
.reservations__popup .content h3 .btn + span { width: calc(100% - 3rem); text-align: left; }
.reservations__popup .content h3 ~ p,
.reservations__popup .content h3 ~ .scroll-wrapper > p { padding: 2rem 1rem; font-size: 1.6rem; line-height: 2rem; }
.reservations__popup .content .scroll-wrapper { height: 40rem; border-bottom: .1rem solid #131313; overflow-y: scroll; }
.reservations__popup .content .scroll-wrapper + .flexbox { padding: 0 1rem; }
.reservations__popup .content ul { padding: 2rem 1rem; }
.reservations__popup .content.attractions-panel ul { overflow-y: scroll; }
.reservations__popup .content ul + p { padding-top: 1rem; }
.reservations__popup .content > .btn:not(.flexbox) { display: block; width: calc(100% - 2rem); margin: 2rem auto 0; background: #131313; color: #fff; }
.reservations__popup .content > .btn:not(.flexbox):not(.disabled):hover { background: transparent; color: #131313; }
.reservations__popup .content > .btn:not(.flexbox).disabled { opacity: .1; }
/* attractions */
.reservations__popup .attractions-panel ul { height: 47rem; }
.reservations__popup .attractions-panel .attraction { display: block; padding: 1rem; background: #f1eff0; border: .1rem solid #f1eff0; border-radius: 1rem; cursor: pointer; }
.reservations__popup .attractions-panel .attraction + .attraction { margin-top: .5rem; }
.reservations__popup .attractions-panel .attraction:hover { background: #fff; border-color: #131313; }
/* confirmation */
.reservations__popup .confirmation-panel .scroll-wrapper > p:first-of-type { padding-bottom: 1rem !important; }
.reservations__popup .confirmation-panel .scroll-wrapper > p + p { padding-top: 0; }
.reservations__popup .confirmation-panel .scroll-wrapper > p .title { display: inline-block; font-size: 2rem; line-height: 2.5rem; }
.reservations__popup .confirmation-panel .scroll-wrapper > .border { width: calc(100% - 2rem); margin: auto; padding: 1rem 2rem 1.5rem; border: .1rem solid; border-radius: 1rem; }
.reservations__popup .confirmation-panel .scroll-wrapper > .border.prev-summary { margin-top: 3rem; border-color: #888; color: #777; }
.reservations__popup .confirmation-panel .scroll-wrapper > .border.prev-summary * { color: #888; }
.reservations__popup .confirmation-panel .scroll-wrapper > .border.new-summary { margin-top: 3rem; border-color: #131313; }
.reservations__popup .confirmation-panel .scroll-wrapper > .border span { display: block; width: fit-content; margin: -2.2rem auto 0; padding: 0 2rem 1rem; background: #fff; font-weight: 400; }
.reservations__popup .confirmation-panel .pass .border { background: #f1eff0; border: none; }
.reservations__popup .confirmation-panel .pass .border .checkbox { height: 4rem; padding-left: 1rem; cursor: default; pointer-events: none; }
.reservations__popup .confirmation-panel .pass .border .checkbox .checkmark { display: none; }
.reservations__popup .confirmation-panel .pass .tab__header { background: #f1eff0; border: none; }
.reservations__popup .confirmation-panel .pass .tab__body { padding-left: 1rem !important; }
.reservations__popup .confirmation-panel .btn { width: calc(50% - .5rem); margin: 2rem 0 0; }
.reservations__popup .confirmation-panel .btn--delete-reservation { border: .1rem solid #131313; }
.reservations__popup .confirmation-panel .btn--delete-reservation:hover { border-color: #d95252; color: #d95252; }
.reservations__popup .confirmation-panel .btn--rsv-confirm { width: 100%; background: #131313; color: #fff; } /* temporary, remove when cancel btn is back */
.reservations__popup .confirmation-panel .btn--rsv-confirm:hover { background: #fff; color: #131313; }
.reservations__popup .cancellation-check { position: fixed; top: 0; width: 100vw; height: 100vh; background: rgba(0,0,0, .8); }
.reservations__popup .cancellation-check > div { padding: 1.7rem 1.5rem; border-top-right-radius: 1rem; border-top-left-radius: .5rem; }
/* date */
.reservations__popup .date-panel .date-response { width: calc(100% - 2rem); margin: 1rem auto; padding: 1rem 1.5rem !important; border-radius: 1rem; background: #db0018; color: #fff !important; font-weight: 400; }
.reservations__popup .date-panel .date-response:not(.active) { display: none; }
.reservations__popup .date-panel #datepicker { width: 34rem; margin: auto; }
.reservations__popup .date-panel #datepicker .ui-datepicker-title { font-size: 1.6rem; font-weight: 400; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header { position: relative; margin-bottom: 1rem; line-height: 3rem; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all { display: inline-block; position: absolute; top: calc(50% - 1.5rem); width: 3rem; height: 3rem; background: #f1eff0; border-radius: 50%; cursor: pointer; font-size: 1.4rem; font-weight: 600; line-height: 2.6rem; text-align: center; text-decoration: none; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all.ui-datepicker-prev { right: 4rem; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all.ui-datepicker-next { right: 0; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all.ui-state-disabled { cursor: default; opacity: .5; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all.ui-state-disabled span { color: #aaa; }
.reservations__popup .date-panel #datepicker .ui-datepicker-header .ui-corner-all:not(.ui-state-disabled):hover { -webkit-transform: scale(1.2); -moz-transform: scale(1.2); transform: scale(1.2); }
.reservations__popup .date-panel #datepicker table { width: calc(100% + .8rem); margin: 0 -.4rem; }
.reservations__popup .date-panel #datepicker th { font-size: 1.4rem; font-weight: 600; }
.reservations__popup .date-panel #datepicker td { padding: 0 .4rem; }
.reservations__popup .date-panel #datepicker td .ui-state-default { display: block; height: 3.9rem; border-radius: 50%; font-size: 1.4rem; font-weight: 400; line-height: 3.9rem; text-align: center; text-decoration: none; }
.reservations__popup .date-panel #datepicker td .ui-state-default.ui-state-active { background: #131313; color: #fff; }
.reservations__popup .date-panel #datepicker td.ui-state-disabled .ui-state-default { color: #aaa; cursor: not-allowed; }
/* scheme */
.reservations__popup .scheme-panel .list { height: 40.5rem; padding: 0 1rem; overflow-y: scroll; }
.reservations__popup .scheme-panel .btn { height: 7rem; background: #f1eff0; border: .1rem solid #f1eff0; font-size: 2.5rem; font-weight: 400; }
.reservations__popup .scheme-panel .btn:hover { background-color: #fff; border-color: #131313; }
/* -- 2 options */
.reservations__popup .scheme-panel .btn:nth-of-type(1):nth-last-of-type(2),
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(1) { height: 17.5rem; }
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(1) { margin-top: 1rem; }
/* -- 3 options */
.reservations__popup .scheme-panel .btn:nth-of-type(1):nth-last-of-type(3),
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(2),
.reservations__popup .scheme-panel .btn:nth-of-type(3):nth-last-of-type(1) { height: 11.8rem; }
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(2),
.reservations__popup .scheme-panel .btn:nth-of-type(3):nth-last-of-type(1) { margin-top: .5rem; }
/* -- 4 options */
.reservations__popup .scheme-panel .btn:nth-of-type(1):nth-last-of-type(4),
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(3),
.reservations__popup .scheme-panel .btn:nth-of-type(3):nth-last-of-type(2),
.reservations__popup .scheme-panel .btn:nth-of-type(4):nth-last-of-type(1) { height: 8.7rem; }
.reservations__popup .scheme-panel .btn:nth-of-type(2):nth-last-of-type(3),
.reservations__popup .scheme-panel .btn:nth-of-type(3):nth-last-of-type(2),
.reservations__popup .scheme-panel .btn:nth-of-type(4):nth-last-of-type(1) { margin-top: .5rem; }
.reservations__popup .scheme-panel .btn + .btn { margin-top: .5rem; }
.reservations__popup .scheme-panel .btn span { font-weight: 700; }
/* time */
.reservations__popup .time-panel__header { position: relative; height: 3rem; margin-bottom: 2rem; padding: 0 1rem; }
.reservations__popup .time-panel__header p { font-weight: 400; }
.reservations__popup .time-panel__header button { display: inline-block; width: 3rem; height: 3rem; background: #f1eff0; border-radius: 50%; cursor: pointer; font-size: 1.4rem; font-weight: 600; line-height: 3rem; text-align: center; text-decoration: none; }
.reservations__popup .time-panel__header button.prev,
.reservations__popup .time-panel__header button.next { -webkit-transform: rotate(90deg); -moz-transform: rotate(90deg); transform: rotate(90deg); }
.reservations__popup .time-panel__header button.next { margin-left: 1rem; }
.reservations__popup .time-panel__header button.disabled { cursor: default; opacity: .5; }
.reservations__popup .time-panel__header button.disabled span { color: #aaa; }
.reservations__popup .time-panel__header button:not(.disabled):hover { -webkit-transform: rotate(90deg) scale(1.2); -moz-transform: rotate(90deg) scale(1.2); transform: rotate(90deg) scale(1.2); }
.reservations__popup .time-panel li { width: calc(25% - .375rem); height: 4rem; margin-right: .4rem; border: .1rem solid #131313; border-radius: 1rem; cursor: pointer; font-size: 1.6rem; line-height: 4rem; text-align: center; }
.reservations__popup .time-panel li:nth-of-type(4n+4) { margin-right: 0; }
.reservations__popup .time-panel li:nth-of-type(n+5) { margin-top: .5rem; }
.reservations__popup .time-panel li:nth-of-type(1):nth-last-of-type(1) { width: 100%; margin-right: 0; }
.reservations__popup .time-panel li:nth-of-type(1):nth-last-of-type(2),
.reservations__popup .time-panel li:nth-of-type(2):nth-last-of-type(1) { width: calc(50% - .25rem); }
.reservations__popup .time-panel li:nth-of-type(2):nth-last-of-type(1) { margin-right: 0; }
.reservations__popup .time-panel li:nth-of-type(1):nth-last-of-type(3),
.reservations__popup .time-panel li:nth-of-type(2):nth-last-of-type(2),
.reservations__popup .time-panel li:nth-of-type(3):nth-last-of-type(1) { width: calc(33.33333% - .33333rem); }
.reservations__popup .time-panel li:nth-of-type(3):nth-last-of-type(1) { margin-right: 0; }
.reservations__popup .time-panel li:hover { background: #f1eff0; }
.reservations__popup .time-panel li:not(.visible) { display: none; }
.reservations__popup .time-panel li.visible { background: #fff; color: #131313; }
.reservations__popup .time-panel li.active { background: #131313; color: #fff; }

@media screen and (orientation: landscape) {
   .reservations__popup .panel,
   .reservations__popup .panel .loader { height: 35rem; }
   .reservations__popup .attractions-panel ul { height: 23.5rem; }
   .reservations__popup .content .scroll-wrapper { height: 22rem; }
}

@media (max-width: 991px) {
    .reservations__popup { position: fixed; top: 0; left: 0; background: rgba(0,0,0, .5) !important; z-index: 99999; }
    .reservations__popup .panel .wrapper,
    .reservations__popup .cancellation-check > div > * { max-width: 50rem; margin: auto; }
    .reservations__popup .cancellation-check > div > * { padding: 0 1rem; }
}

@media (min-width: 992px) {
    .reservations__popup { position: relative; border-radius: 1rem; box-shadow: 0 0 1rem rgba(0,0,0, .1); overflow: hidden; }
    .reservations__popup .panel { position: relative; width: 100%; max-height: initial; }
    .reservations__popup .panel,
    .reservations__popup .panel .loader { height: auto; min-height: 57rem; }
    .reservations__popup .panel .cross { top: .5rem; right: .5rem; }
    .reservations__popup .panel .content { height: 100%; }
    .reservations__popup .content h3 { padding: 1rem 3rem 1rem 0; }
    .reservations__popup .content.scheme-panel h3 { padding-left: 3rem; }
    .reservations__popup .content h3 .btn { margin-top: .3rem; }
    .reservations__popup .content h3 ~ p, 
    .reservations__popup .content h3 ~ .scroll-wrapper > p { padding: 2rem 3rem; }
    .reservations__popup .content .scroll-wrapper { height: auto; min-height: 43rem; }
    .reservations__popup .content > .btn:not(.flexbox) { width: calc(100% - 6rem); }
    .reservations__popup .content .list,
    .reservations__popup .content ul { padding: 3rem; }
    .reservations__popup .content > .btn:not(.flexbox):not(.btn--scheme-type) { margin-top: 3rem; }
    .reservations__popup .content.attractions-panel ul { height: 48.5rem; padding: 2rem 3rem; }
    .reservations__popup .time-panel__header,
    .reservations__popup .content .scroll-wrapper + .flexbox { padding: 0 3rem; }
    .reservations__popup .date-panel .date-response { width: calc(100% - 6rem); }
    .reservations__popup .confirmation-panel .scroll-wrapper > .border { width: calc(100% - 6rem); }
    .reservations__popup .cancellation-check { position: absolute; top: 0; width: 100%; height: 100%; background: transparent; }
    .reservations__popup .cancellation-check > div { padding: 2.1rem 3.5rem; }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .reservations__popup .content h3 .btn { padding-left: .7rem; }
}

@media (min-width: 1200px) {
    .reservations__popup .content h3 { padding: 1rem 5rem 1rem 2rem; }
    .reservations__popup .content.scheme-panel h3 { padding-left: 5rem; }
    .reservations__popup .content h3 ~ p, 
    .reservations__popup .content h3 ~ .scroll-wrapper > p { padding: 2rem 5rem; }
    .reservations__popup .content > .btn:not(.flexbox) { width: calc(100% - 10rem); }
    .reservations__popup .content .list,
    .reservations__popup .content ul { padding: 3rem 5rem; }
    .reservations__popup .content.attractions-panel ul { padding: 2rem 5rem; }
    .reservations__popup .time-panel__header,
    .reservations__popup .content .scroll-wrapper + .flexbox { padding: 0 5rem; }
    .reservations__popup .confirmation-panel .scroll-wrapper > .border { width: calc(100% - 10rem); }
    .reservations__popup .cancellation-check > div { padding: 2.1rem 5.5rem; }
}





/*  ----------------------------------------------------------------------------------------------------

                                                TICKETS

    ---------------------------------------------------------------------------------------------------- */

.account-home.tickets { position: relative; width: 100%; max-width: 100vw; height: fit-content; min-height: calc(100vh - 20rem); padding-bottom: 5rem; overflow-x: hidden; }
.account-home.tickets .wrapper { width: 100%; max-width: initial; margin: auto; padding: 0; }
.account-home.tickets .wrapper .slider__body { overflow: initial; }
.account-home.tickets .slides-wrapper { position: relative; width: 100%; max-width: 53rem; margin: auto; padding-bottom: 1.5rem; overflow-y: hidden; }
.account-home.tickets .slide { width: 100%; max-width: 50rem; margin: auto; transition: margin .3s ease-out, opacity .3s ease-out; }
.account-home.tickets .slide:not(.active) { display: block; position: absolute; top: 1.5rem; left: 1.5rem; width: calc(100% - 3rem); transition-delay: .1s; opacity: 0; z-index: 0; }
.account-home.tickets .slide.active { position: relative; opacity: 1; z-index: 1; }
.account-home.tickets .slide.active.slide-right { margin-left: -20rem; }
.account-home.tickets .slide.active.slide-left { margin-right: -20rem; }
.account-home.tickets .slide.active:not(.slide-right):not(.slide-left) { margin: 0rem; }
.account-home.tickets .slide .ticket {width: 100%; padding: 1rem; background: #fff; border: .1rem solid #8a6fdf55; border-radius: 2rem; box-shadow: 0 0 1.5rem #8a6fdf88; }
.account-home.tickets .slide .ticket__num { font-size: 1.4rem; color: #777; }
.account-home.tickets .slide .ticket__header { width: 100%; }
.account-home.tickets .slide .ticket__header .logo { display: block; width: 100%; max-width: 25rem; margin: 2rem auto; }
.account-home.tickets .slide .ticket__header .qr-code { display: block; width: 100%; max-width: 15rem; margin: 0 auto .5rem; }
.account-home.tickets .slide .ticket__header .qr-code + p { color: #777; font-size: 1.4rem; text-align: center; margin-bottom: 2rem; }
.account-home.tickets .slide .ticket__body { width: 100%; margin-top: 2rem; padding: 1rem; background: #8a6fdf22; border-radius: 1.2rem; }
.account-home.tickets .slide .ticket__body .title { margin-bottom: 1rem; font-weight: 600; }
.account-home.tickets .slide .ticket__body .desc { margin-top: 3rem; }
.account-home.tickets .slide .ticket__body .desc,
.account-home.tickets .slide .ticket__body .desc * { color: #777 !important; }
.account-home.tickets .slide .ticket__body .desc .tab__header { height: auto; padding: 1rem 1.5rem; background: #fff; border-radius: 1rem; }
.account-home.tickets .slide .ticket__body .desc .tab__header * { margin: 0; font-weight: 300; }
.account-home.tickets .slide .ticket__body .desc.active .tab__body { max-height: 400rem; padding-top: 2rem; }
.account-home.tickets .slide .ticket__body .desc h2 { padding: 2rem 0 1rem; font-size: 2.2rem; }
.account-home.tickets .slide .ticket__body .desc h2 + p { margin-bottom: 0; padding: 0 !important; background: transparent !important; }
.account-home.tickets .slide .ticket__body .desc p + p { margin-top: .5rem; }
.account-home.tickets .slide .ticket__body .desc h4 { margin-top: 1rem; }
.account-home.tickets .slide .ticket__body .desc h4,
.account-home.tickets .slide .ticket__body .desc a { font-size: 1.6rem; }
.account-home.tickets .slide .ticket__body .desc a { display: block; color: #8a6fdf !important; text-decoration: underline; }
.account-home.tickets .slide .ticket__body .desc a:hover { text-decoration: none; }
.account-home.tickets .slide .links { width: 100%; margin-top: 1.5rem; display: none; }
.account-home.tickets .slide .links a { display: block; width: auto; height: 4.5rem; }
.account-home.tickets .slide .links a:nth-of-type(n+2) { margin-left: 1rem; }
.account-home.tickets .slide .links a img { width: auto; height: 100%; }
.account-home.tickets .dots { width: 100%; max-width: 40rem; margin: auto; }
.account-home.tickets .dot { font-size: 1.1rem; font-weight: 400; color: #999; text-align: center; }
.account-home.tickets .dot.active { color: #fff; }

@media (min-width: 768px) {
    .account-home.tickets { height: auto; min-height: calc(100vh - 30rem); }

}

@media (min-width: 992px) {
    .account-home.tickets { min-height: calc(100vh - 35rem); }
    .account-home.tickets .slide .ticket > .flexbox { -webkit-justify-content: space-between; justify-content: space-between; -webkit-align-items: stretch; align-items: stretch; }
    .account-home.tickets .slide .ticket__header .qr-code + p { margin-bottom: 0rem; }
    .account-home.tickets .slide .links a { height: 5rem; }
    .account-home.tickets .slide .ticket__body { padding: 1.5rem 2rem; }
}

@media print {
    .header,
    .account-home.tickets .wrapper > h2,
    .account-home.tickets .slider .dots,
    .footer { display: none !important; }
    .account-home.tickets { height: auto !important; padding: 0 !important; }
    .account-home.tickets .slides-wrapper { display: block !important; }
    .account-home.tickets .slide.ticket { display: block !important; position: relative !important; top: initial !important; left: initial !important; width: 50rem !important; break-inside: avoid !important; border: .1rem solid #131313; box-shadow: none !important; opacity: 1 !important; z-index: 1 !important; }
    .account-home.tickets .slide.ticket + .slide.ticket { margin-top: 3rem !important; }
    .account-home.tickets .slide.ticket .desc { display: none !important; }
}
