/* Minification failed. Returning unminified contents.
(1468,108): run-time error CSS1038: Expected hex color, found '#fff5'
 */
/*!
 * 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; pointer-events: none; -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 { gap: 1.5rem; width: max-content; height: 100%; padding: 1.5rem 1.5rem 1.5rem; transition: margin .2s ease-out; }
.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__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.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: 1.5rem; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
    .slider .slider__body .slides-wrapper .slide { flex: 0 0 auto; scroll-snap-align: start; }
}

@media (min-width: 992px) {
    .slider__header > .flexbox { margin: .2rem .2rem 0 0; }
    .slider__header > .flexbox > a { margin-right: 3rem; font-size: 1.6rem; }
    .slider__header > .flexbox > .flexbox { display: -webkit-flex; display: flex; }
    .slider { overflow: hidden; }
    .slider .slides-wrapper { padding: 1.5rem 0 0; }
    .slide:not(.double) .slide__img { height: 12.6rem; }
    .slide.attraction:not(.double) { width: 30rem; }
    .slide.attraction .slider__header > .flexbox { display: -webkit-flex; display: flex; }
    .slide.attraction.double { width: 22.15rem; }
    .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: 45.7rem; }
    .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: 1200px) {
    .slide.attraction:not(.double) { width: 36rem; }
    .slide:not(.double) .slide__img { height: 15.0rem; }
    .slide.attraction .slide__content h4 { line-height: 2rem; }
    .slide.attraction.double { width: 21rem; }
    .slide.attraction.double .slide__content { min-height: 19.1rem; }
    .slide.itinerary { width: 54.7rem; }
    .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: 1400px) {
    .slide:not(.double) .slide__img { height: 17.4rem; }
    .slide.attraction:not(.double) { width: 42rem; }
    .slide.attraction:not(.double) .slide__content h4 { font-size: 1.8rem; line-height: 2.2rem; }
    .slide.attraction.double { width: 20.25rem; }
    .slide.itinerary { width: 63.7rem; }
    .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 .version--mobile > .flexbox:nth-of-type(1) > div { width: 100%; margin-top: 3rem; }
.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 .version--mobile > .flexbox:nth-of-type(1) > div { width: fit-content; margin-top: 0; }
    .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; }
}
/*  ----------------------------------------------------------------------------------------------------

                                              PASS HOMEPAGE

    ---------------------------------------------------------------------------------------------------- */

.pass section:not(.hero) { padding-top: 5rem; }
.pass .section-title { width: calc(100% - 7rem); font-size: 1.8rem; font-weight: 600; line-height: 2.2rem; }

@media (min-width: 992px) {
    .pass .section-title { width: auto; font-size: 2rem; line-height: 2.5rem; }
}

@media (min-width: 1200px) {
    .pass section:not(.hero) { padding-top: 6rem; }
    .pass-home .section-title { font-size: 2.2rem; }
}

@media (min-width: 1400px) {
    .pass-home .section-title { font-size: 2.6rem; line-height: 3.2rem; }
}



/*  >> Hero
    ------------------------------ */

.pass__hero { background: #131313; overflow: hidden; }
.pass__hero .content { position: relative; width: 100%; height: auto; height: auto; padding: 20rem 0 5rem; background: url('../../../../Images/pages/pass-index/hero.jpg') center center/cover no-repeat; }
.pass__hero .content::before,
.pass__hero .content::after { content: ''; display: block; position: absolute; top: 0; width: 20rem; height: 100%; }
.pass__hero .content::before { left: 0; background: linear-gradient(to right, #131313, transparent); }
.pass__hero .content::after { right: 0; background: linear-gradient(to left, #131313, transparent); }
.pass__hero .content h1,
.pass__hero .content h4,
.pass__hero .content p { color: #fff; text-align: center; }
.pass__hero .content h1 { font-size: 2.6rem; font-weight: 700; }
.pass__hero .content .promo-banner { position: absolute; left: 0; right: 0; width: 100%; margin: auto; padding: 1rem; background: #8a6fdf; border-radius: 1rem; box-shadow: 0 0 2rem #000; transition: top .3s ease-out, opacity .3s ease-out; z-index: 1; }
.pass__hero .content .promo-banner:not(.visible) { top: -10rem; opacity: 0; }
.pass__hero .content .promo-banner.visible { top: 1.5rem; opacity: 1; }
.pass__hero .content .promo-banner h1 { margin-top: .5rem; }
.pass__hero .content .promo-banner h1 + p { font-size: 1.6rem; font-weight: 400; }
.pass__hero .content .promo-banner p { font-size: 1.3rem; }
.pass__hero .content .promo-banner a { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 1rem; z-index: 1; }
.pass__hero .content div:not(.promo-banner) { position: relative; margin: auto; text-align: center; z-index: 1; }
.pass__hero .content div:not(.promo-banner) h1 { margin-bottom: 1rem; font-weight: 600; }
.pass__hero .content div:not(.promo-banner) h1,
.pass__hero .content div:not(.promo-banner) h4 { text-shadow: 0 0 1rem #000; }
.pass__hero .content div:not(.promo-banner) a { display: block; width: 100%; max-width: 30rem; height: 5rem; margin: 3rem auto 0; background: #fff; border-radius: 1rem; color: #131313; font-size: 1.6rem; font-weight: 500; line-height: 5rem; text-align: center; text-decoration: none; }
.pass__hero .content div:not(.promo-banner) a:hover { opacity: .9; }

@media (min-width: 576px) {
    .pass__hero .content { width: calc(100% + 20rem); margin: 0 -10rem; padding: 18rem 0 5rem; }
    .pass__hero .content .promo-banner,
    .pass__hero .content div:not(.promo-banner) { width: calc(100% - 20rem); max-width: 55rem; }
    .pass__hero .content div:not(.promo-banner) h1,
    .pass__hero .content div:not(.promo-banner) h4 { text-shadow: 0 0 2rem #000; }
}

@media (min-width: 768px) {
    .pass__hero .content h1 { font-size: 2.8rem; }
    .pass__hero .content .promo-banner { max-width: initial; }
    .pass__hero .content div:not(.promo-banner) { max-width: 55rem; }
}

@media (min-width: 992px) {
    .pass__hero .content { padding: 22rem 0 10rem; }
    .pass__hero .content h1 { font-size: 3rem; letter-spacing: .1rem; }
    .pass__hero .content .promo-banner h4 { font-weight: 500; }
    .pass__hero .content div:not(.promo-banner) { max-width: 65rem; }
    .pass__hero .content div:not(.promo-banner) h1 { letter-spacing: .1rem; }
}

@media (min-width: 1200px) {
    .pass__hero .content { width: calc(100% + 30rem); margin: 0 -15rem; padding: 25rem 0 12rem; }
    .pass__hero .content h1 { font-size: 3.5rem; }
    .pass__hero .content .promo-banner { width: calc(100% - 30rem); padding: 1.5rem; }
    .pass__hero .content .promo-banner h4 { font-size: 2.2rem; }
    .pass__hero .content .promo-banner h1 { margin-bottom: .5rem; }
    .pass__hero .content .promo-banner h1 + p { font-size: 1.8rem; }
    .pass__hero .content div:not(.promo-banner) { max-width: 78rem; }
    .pass__hero .content div:not(.promo-banner) h1 { letter-spacing: .2rem; }
    .pass__hero .content div:not(.promo-banner) a { max-width: 35rem; height: 5rem; font-weight: 500; line-height: 5rem; }
}

@media (min-width: 1400px) {
    .pass__hero .content { width: calc(100% + 40rem); margin: 0 -20rem; padding: 28rem 0 15rem; }
    .pass__hero .content h1 { font-size: 4rem; }
    .pass__hero .content .promo-banner { width: calc(100% - 40rem); padding: 2rem; }
    .pass__hero .content div:not(.promo-banner) { max-width: 90rem; }
}



/*  >> Observation Decks
    ------------------------------ */

.pass__comparison .table { margin-top: 1rem; padding: 1.5rem 1.5rem 2rem; background: #8a6fdf22; border-radius: 1rem; }
.pass__comparison .column { position: relative; width: 100%; padding: 1rem 2rem; background: #fff; border: .1rem solid #8a6fdf77; border-radius: 1rem; }
.pass__comparison .column + .column { margin-top: .5rem; }
.pass__comparison .column p { display: flex; justify-content: center; align-items: center; line-height: 1.2; text-align: center; }
.pass__comparison .column p.type { padding-bottom: 1rem; color: #8a6fdf; font-size: 1.8rem; font-weight: 600; }
.pass__comparison .column p:not(.type) { padding: .5rem 0; border-top: .1rem solid #eee; font-size: 1.4rem; }
.pass__comparison .column p:last-of-type { padding-bottom: 0; }
.pass__comparison .column p span b { font-weight: 500; }
.pass__comparison .btn { display: block; width: 100%; max-width: 30rem; margin: 1.5rem auto 0; background: #fff5; border-color: #8a6fdf; border-radius: 2.5rem; color: #8a6fdf; }
.pass__comparison .btn:hover { background: #fff; border-color: #fff; }

@media (min-width: 576px) {
    .pass__comparison .table { padding: 2rem; }
    .pass__comparison .column { padding: 1.5rem 3rem 2rem; }
    .pass__comparison .column + .column { margin-top: 1rem; }
    .pass__comparison .btn { margin-top: 2rem; }
}

@media (min-width: 768px) {
    .pass__comparison .table { margin-top: 1rem; padding: 2rem 3rem; }
    .pass__comparison .column p.type { padding-bottom: 1rem; font-size: 1.6rem; }
    .pass__comparison .column p:not(.type) { justify-content: flex-start; padding: 1.5rem 0; font-size: 1.6rem; text-align: left; }
    .pass__comparison .column p:not(.type):last-of-type { padding-bottom: 0; }
}

@media (min-width: 992px) {
    .pass__comparison .table { margin-top: 2.5rem; padding: 3rem 5rem; }
    .pass__comparison .column { width: calc(33.33333% - 1rem); padding: 1rem !important; border-radius: 2rem; box-shadow: 0 0 1rem #8a6fdfaa; }
    .pass__comparison .column + .column { margin-top: 0; }
    .pass__comparison .column p.type { padding-bottom: 2rem; font-size: 1.8rem; }
    .pass__comparison .column p:not(.type) { min-height: 10rem; font-size: 1.4rem; }
    .pass__comparison .btn { margin-top: 3rem; }
}

@media (min-width: 1200px) {
    .pass__comparison .table { padding: 5rem 8rem; }
    .pass__comparison .column { width: calc(33.33333% - 1.33333rem); padding: 2rem !important; box-shadow: 0 0 1.5rem #8a6fdfbb; }
    .pass__comparison .column p.type { font-size: 2rem; }
    .pass__comparison .column p:not(.type) { font-size: 1.5rem; }
}

@media (min-width: 1400px) {
    .pass__comparison .table { padding: 5rem 12rem; }
    .pass__comparison .column { width: calc(33.33333% - 1.66666rem); padding: 3rem !important; }
    .pass__comparison .column p.type { padding-bottom: 3rem; font-size: 2.2rem; }
    .pass__comparison .column p:not(.type) { min-height: 12rem; font-size: 1.6rem; line-height: 1.3; }
}



/*  >> Observation Decks
    ------------------------------ */

.pass__decks .section-title { width: 100%; padding-bottom: 2rem; color: #fff; font-weight: 600; line-height: 1.2; }
.pass__decks .container > .flexbox { position: relative; padding: 0 1.5rem 1.5rem; border-radius: 1.4rem; }
.pass__decks .container > .flexbox:before { content: ''; display: block; position: absolute; bottom: 0; left: 0; width: 100%; height: calc(100% - 10rem); background: #131313; border-radius: 1rem; z-index: 0; }
.pass__decks .container > .flexbox > div { position: relative; width: 100%; z-index: 1; }
.pass__decks .content > div { width: 100%; }
.pass__decks .content a { display: block; position: relative; width: fit-content; padding-left: 2rem; color: #fff; font-size: 1.6rem; font-weight: 400; }
.pass__decks .content a:before { content: ''; display: block; position: absolute; top: calc(50% - .2rem); left: 0; width: .6rem; height: .6rem; border: .1rem solid #fff; border-radius: 50%; }
.pass__decks .content a + a { margin-top: .5rem; }
.pass__decks .carousel .slide { height: 20rem; border-radius: 1rem; }
.pass__decks .carousel .dots { z-index: 2; }

@media (max-width: 767px) {
    .pass__decks .content { order: 2; }
    .pass__decks .carousel { order: 1; margin-bottom: 2rem; }
}

@media (min-width: 768px) {
    .pass__decks .container > .flexbox { padding: 0; }
    .pass__decks .container > .flexbox:before { width: 100%; height: 100%; }
    .pass__decks .content { width: 40% !important; }
    .pass__decks .content > div { padding: 0 0 0 3rem; }
    .pass__decks .carousel { width: 60% !important; }
    .pass__decks .carousel::after { content: ''; display: block; position: absolute; top: 0; left: 0; width: 50%; height: 100%; background: linear-gradient(to right, #131313 0%, #131313 10%, transparent 100%); z-index: 1; }
    .pass__decks .carousel .slide { height: 30rem; }
}

@media (min-width: 992px) {
    .pass__decks .section-title { padding-bottom: 3.5rem; font-size: 2.4rem; }
    .pass__decks .content > div { padding-left: 5rem; }
    .pass__decks .carousel .slide { height: 35rem; }
}

@media (min-width: 1200px) {
    .pass__decks .section-title { font-size: 2.6rem; }
    .pass__decks .content { width: 30% !important; }
    .pass__decks .content a + a { margin-top: 1rem; }
    .pass__decks .carousel { width: 70% !important; }
    .pass__decks .carousel .slide { height: 40rem; }
}

@media (min-width: 1400px) {
    .pass__decks .section-title { font-size: 2.8rem; }
    .pass__decks .content > div { padding-left: 8rem; }
    .pass__decks .content a { font-size: 1.8rem; }
    .pass__decks .carousel .slide { height: 45rem; }
}



/*  >> How It Works
    ------------------------------ */

.pass__hiw .section-title { padding-bottom: 1.2rem; }
.pass__hiw .box { position: relative; width: 100%; padding: 3rem 1.5rem; border-radius: 1rem; }
.pass__hiw .box:nth-of-type(1) { background: #f6f6f6; }
.pass__hiw .box:nth-of-type(2) { background: #efefef; }
.pass__hiw .box:nth-of-type(3) { background: #e1e1e1; }
.pass__hiw .box + .box { margin-top: 1rem; }
.pass__hiw .box .icon-wrapper { position: absolute; right: 0; bottom: -4rem; left: 0; width: 5rem; height: 5rem; margin: 1rem auto; background: #fff; border-radius: 50%; z-index: 1; }
.pass__hiw .box h4 { margin-bottom: 1rem; }
.pass__hiw .box a { display: block; width: 100%; height: auto; margin: 1.5rem auto 0; background: #131313; border: .1rem solid #131313; border-radius: 1rem; color: #fff; font-size: 1.6rem; font-weight: 500; line-height: 3.8rem; text-align: center; text-decoration: none; }
.pass__hiw .box a:hover { background: transparent; color: #131313; }

@media (max-width: 991px) {
    .pass__hiw .box a { max-width: 20rem; }
}

@media (min-width: 992px) {
    .pass__hiw .section-title { padding-bottom: 2rem; }
    .pass__hiw .box { width: calc(33.33333% - 1.33333rem); padding: 2rem 3rem; }
    .pass__hiw .box + .box { margin: 0 0 0 1rem; }
    .pass__hiw .box .icon-wrapper { top: calc(50% - 3rem); right: -4rem; bottom: initial; left: initial; width: 6rem; height: 6rem; margin: 0; transform: rotate(-90deg); }
    .pass__hiw .box h4 { font-size: 1.8rem; }
    .pass__hiw .box a { margin-top: 2rem; }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .pass__hiw .box h4 { min-height: 4.2rem; }
}

@media (min-width: 1200px) {
    .pass__hiw .box { padding: 3rem 4rem; }
    .pass__hiw .box .icon-wrapper { top: calc(50% - 3.5rem); right: -4.5rem; width: 7rem; height: 7rem; }
    .pass__hiw .box a { line-height: 4.8rem; }
}

@media (min-width: 1400px) {
    .pass__hiw .box { width: calc(33.33333% - 2rem); padding: 4rem 5rem; }
    .pass__hiw .box + .box { margin: 0 0 0 3rem; }
    .pass__hiw .box .icon-wrapper { top: calc(50% - 4rem); right: -5.5rem; width: 8rem; height: 8rem; }
    .pass__hiw .box a { margin-top: 3rem; }
}



/*  >> Itineraries
    ------------------------------ */

.pass__itineraries .slide.itinerary .slide__content .scrollable-content { height: 20rem; }
