html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    line-height: 1;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: "";
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.container {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 25px;
}

body {
    font-family: "Lato", "Georgia", "Times New Roman", Times, serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.375;
    color: #4b4e53;
    overflow-x: hidden;
    -webkit-transition: -webkit-transform 0.5s ease-in-out;
    transition: -webkit-transform 0.5s ease-in-out;
    -o-transition: transform 0.5s ease-in-out;
    transition: transform 0.5s ease-in-out;
    transition: transform 0.5s ease-in-out, -webkit-transform 0.5s ease-in-out;
}

body.active {
    -webkit-transform: translateX(-70%);
    -ms-transform: translateX(-70%);
    transform: translateX(-70%);
}

body.fixed {
    position: fixed;
}

body.fixed nav > ul {
    overflow-x: auto;
}

a {
    text-decoration: none;
}

h1,
h2,
h3,
h4 {
    font-family: "Georgia", "Times New Roman", Times, serif;
}

h1 {
    font-size: 3.125rem;
    line-height: 1.2;
}

h2 {
    font-size: 2.5rem;
    line-height: 1.15;
}

h3 {
    font-size: 2.125rem;
    line-height: 1.175;
}

h4 {
    font-size: 1.625rem;
    line-height: 1.15;
}

p {
    font-size: 1rem;
    line-height: 1.375;
}

small {
    font-size: 0.8125rem;
    line-height: 1.4;
}

@media (min-width: 1024px) {
    h1 {
        font-size: 3.875rem;
        line-height: 1.16;
    }

    h2 {
        font-size: 3.125rem;
        line-height: 1.2;
    }

    h3 {
        font-size: 2.5rem;
        line-height: 1.15;
    }

    h4 {
        font-size: 2.125rem;
        line-height: 1.175;
    }
}

strong {
    font-weight: 700;
}

.col33 {
    width: 100%;
}

.cookies {
    color: #fefefe;
    background: #4b4e53;
    font-size: 0.85714em;
    line-height: 1.75em;
    display: none;
}

.cookies p {
    padding: 10px 0;
}

.cookies .container {
    position: relative;
    padding-right: 80px;
}

.cookies a {
    color: #fefefe;
}

.cookies .agreedCookie {
    color: #01c1d6;
    float: right;
    font-size: 18px;
    color: #fff;
    top: 7px;
    right: 10px;
    position: absolute;
    cursor: pointer;
}

.hide {
    display: none;
}

.show {
    display: block;
}

.hand {
    cursor: pointer;
}

@media (min-width: 1024px) {
    .col33 {
        width: calc(100% / 3);
        float: left;
    }
}

@font-face {
    font-family: "Material Icons";
    font-weight: 400;
    font-style: normal;
    src: url("fonts/MaterialIcons-Regular.eot");
    src: local("Material Icons"), local("MaterialIcons-Regular"),
        url("fonts/MaterialIcons-Regular.woff2") format("woff2"),
        url("fonts/MaterialIcons-Regular.woff") format("woff"),
        url("fonts/MaterialIcons-Regular.ttf") format("truetype");
}

.material-icons,
.c__checkbox input[type="checkbox"]:checked + span::after {
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    display: inline-block;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-feature-settings: "liga";
    font-feature-settings: "liga";
}

.c__checkbox label {
    position: relative;
    padding-right: 30px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.c__checkbox input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    z-index: -1;
    left: -9999px;
}

.c__checkbox input[type="checkbox"] + span {
    position: absolute;
    top: 2px;
    right: 0;
    display: inline-block;
    width: 20px;
    height: 20px;
    background: #fff;
    cursor: pointer;
}

.c__checkbox input[type="checkbox"] + span:hover,
.c__checkbox input[type="checkbox"] + span:focus {
    -webkit-box-shadow: 0px 0px 0px 2px #f1352b inset;
    box-shadow: 0px 0px 0px 2px #f1352b inset;
}

.c__checkbox input[type="checkbox"]:disabled + span {
    pointer-events: none;
    opacity: 0.5;
}

.c__checkbox input[type="checkbox"]:checked + span::after {
    content: "check";
    color: #f1352b;
    font-size: 32px;
    position: absolute;
    top: -8px;
    left: -2px;
}

body.active nav > ul {
    display: block;
}

.topbar {
    height: 65px;
    padding-top: 25px;
}

.topbar .logo {
    display: inline-block;
}

.topbar .logo img {
    height: 12px;
}

.topbar .login {
    position: absolute;
    top: 85px;
    right: 75px;
    color: #000;
}

.topbar .login::after {
    font-family: "FontAwesome";
    content: "\f0da";
    margin-left: 5px;
}

nav {
    display: inline;
}

nav > button {
    position: relative;
    margin: 0;
    padding: 0;
    width: 30px;
    height: 16px;
    cursor: pointer;
    float: right;
    font-size: 0;
    background: none;
    min-width: 0;
    border: 0;
    outline: 0;
}

nav > button span {
    display: block;
    position: absolute;
    top: 7px;
    left: 0;
    height: 3px;
    border-radius: 5px;
    background: #000;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    -o-transition-property: transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    -o-transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    -webkit-transition-duration: 0.22s;
    -o-transition-duration: 0.22s;
    transition-duration: 0.22s;
}

nav > button span::before,
nav > button span::after {
    position: absolute;
    display: block;
    left: 0;
    width: 100%;
    height: 3px;
    border-radius: 2px;
    background: #000;
    content: "";
    -webkit-transition-timing-function: ease;
    -o-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-duration: 0.15s;
    -o-transition-duration: 0.15s;
    transition-duration: 0.15s;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    -o-transition-property: transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
}

nav > button span::before {
    top: -6px;
    -webkit-transition: top 0.1s ease-in 0.25s, opacity 0.1s ease-in;
    -o-transition: top 0.1s ease-in 0.25s, opacity 0.1s ease-in;
    transition: top 0.1s ease-in 0.25s, opacity 0.1s ease-in;
}

nav > button span::after {
    bottom: -6px;
    -webkit-transition: bottom 0.1s ease-in 0.25s, opacity 0.1s ease-in;
    -o-transition: bottom 0.1s ease-in 0.25s, opacity 0.1s ease-in;
    transition: bottom 0.1s ease-in 0.25s, opacity 0.1s ease-in;
}

nav > button.active span {
    -webkit-transition-delay: 0.12s;
    -o-transition-delay: 0.12s;
    transition-delay: 0.12s;
    -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -o-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: rotate(225deg);
    -ms-transform: rotate(225deg);
    transform: rotate(225deg);
}

nav > button.active span::before {
    top: 0;
    -webkit-transition: top 0.1s ease-out, opacity 0.1s ease-out 0.12s;
    -o-transition: top 0.1s ease-out, opacity 0.1s ease-out 0.12s;
    transition: top 0.1s ease-out, opacity 0.1s ease-out 0.12s;
    opacity: 0;
}

nav > button.active span::after {
    bottom: 0;
    -webkit-transition: bottom 0.1s ease-out,
        -webkit-transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    transition: bottom 0.1s ease-out,
        -webkit-transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    -o-transition: bottom 0.1s ease-out,
        transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    transition: bottom 0.1s ease-out,
        transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    transition: bottom 0.1s ease-out,
        transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s,
        -webkit-transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
}

nav ul {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 70%;
    height: 100vh;
    background: #fff;
    padding: 40px;
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
    -webkit-transition: -webkit-transform 0.5s ease-in-out;
    transition: -webkit-transform 0.5s ease-in-out;
    -o-transition: transform 0.5s ease-in-out;
    transition: transform 0.5s ease-in-out;
    transition: transform 0.5s ease-in-out, -webkit-transform 0.5s ease-in-out;
    -webkit-box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    display: none;
}

nav li {
    margin-bottom: 10px;
    padding: 10px;
}

nav li:nth-child(1) {
    border-left: 5px solid #01c1d6;
}

nav li:nth-child(2) {
    border-left: 5px solid #6e27c5;
}

nav li:nth-child(3) {
    border-left: 5px solid #ff0198;
}

nav li:nth-child(4) {
    border-left: 5px solid #7acb00;
}

nav li:nth-child(5) {
    border-left: 5px solid #ffb617;
}

nav a {
    font-size: 1rem;
    line-height: 1.375;
    color: #4b4e53;
}

nav .has-children ul {
    display: block;
    position: static;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
    height: auto;
    -webkit-box-shadow: none;
    box-shadow: none;
    margin: 15px 0 0;
    padding: 0;
}

nav .has-children ul li {
    border: 0;
    padding: 0;
}

nav .has-children ul li a {
    font-size: 1rem;
    line-height: 1.375;
}

@media (min-width: 768px) {
    .topbar {
        height: 75px;
    }

    .topbar .logo img {
        height: auto;
    }
}

@media (min-width: 1024px) {
    .topbar {
        height: 105px;
        padding: 25px 0;
    }

    .topbar .login {
        top: 40px;
        right: 40px;
    }

    nav {
        float: right;
        margin-top: 0px;
    }

    nav > button {
        display: none;
    }

    nav ul {
        position: static;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
        width: auto;
        height: auto;
        padding: 0;
        -webkit-box-shadow: none;
        box-shadow: none;
        display: block;
    }

    nav ul::after {
        content: "";
        display: table;
        clear: both;
    }

    nav li {
        width: auto;
        margin: 0;
        padding: 3px 1.5vw 5px 0;
        cursor: pointer;
        float: left;
        border-left: 0 !important;
    }

    nav li:hover a {
        top: 5px;
    }

    nav li:nth-child(1) {
        border-bottom: 5px solid #01c1d6;
    }

    nav li:nth-child(1).has-children::before {
        border-top: 10px solid #01c1d6;
    }

    nav li:nth-child(2) {
        border-bottom: 5px solid #6e27c5;
    }

    nav li:nth-child(2).has-children::before {
        border-top: 10px solid #6e27c5;
    }

    nav li:nth-child(3) {
        border-bottom: 5px solid #ff0198;
    }

    nav li:nth-child(3).has-children::before {
        border-top: 10px solid #ff0198;
    }

    nav li:nth-child(4) {
        border-bottom: 5px solid #7acb00;
    }

    nav li:nth-child(4).has-children::before {
        border-top: 10px solid #7acb00;
    }

    nav li:nth-child(5) {
        border-bottom: 5px solid #ffb617;
    }

    nav li:nth-child(5).has-children::before {
        border-top: 10px solid #ffb617;
    }

    nav a {
        color: #4b4e53;
        -webkit-transition: top 400ms 0s ease;
        -o-transition: top 400ms 0s ease;
        transition: top 400ms 0s ease;
        position: relative;
        top: 0;
    }

    nav .has-children {
        position: relative;
    }

    nav .has-children::before {
        display: none;
        content: "";
        width: 0;
        height: 0;
        border-left: 10px solid transparent;
        border-right: 10px solid transparent;
        position: absolute;
        bottom: -15px;
        left: 44%;
        z-index: 1;
    }

    nav .has-children ul {
        background: #4b4e53;
        padding: 25px;
        position: absolute;
        top: 30px;
        left: 0;
        bottom: auto;
        bottom: initial;
        height: auto;
        width: 280px;
        -webkit-transform-origin: 0 0;
        -ms-transform-origin: 0 0;
        transform-origin: 0 0;
        -webkit-transform: rotateX(90deg) skew(15deg, 0);
        transform: rotateX(90deg) skew(15deg, 0);
        -webkit-transition: 400ms;
        -o-transition: 400ms;
        transition: 400ms;
        margin: 0;
    }

    nav .has-children ul li {
        display: block;
        border: 0;
        float: none;
        padding: 3px 1.5vw 5px 0;
    }

    nav .has-children ul li a {
        position: static;
    }

    nav .has-children ul a {
        color: #fff;
    }

    nav .has-children:hover::before {
        display: block;
    }

    nav .has-children:hover ul {
        -webkit-transform: rotateX(0deg) skew(0, 0);
        transform: rotateX(0deg) skew(0, 0);
    }
}

footer {
    background: #4b4e53;
    padding: 25px 0;
    color: #fff;
    height: auto;
}

footer img {
    height: 25px;
    width: auto;
}

footer p {
    margin-top: 1em;
    font-size: 1em;
    line-height: 1.5em;
}

footer ul {
    margin-top: 25px;
    width: 100%;
}

footer li {
    display: block;
    color: #afafaf;
    padding: 2px 0;
}

footer li a {
    color: inherit;
    font-size: 1em;
}

footer p a {
    color: #fff;
}

@media (min-width: 768px) {
    footer {
        padding: 60px 0;
    }
}

@media (min-width: 1024px) {
    footer {
        height: auto;
    }

    footer li {
        display: inline-block;
        margin-left: 30px;
    }

    footer li:first-child {
        margin-left: 0;
    }
}

.contentGrid {
    width: 100%;
}

.contentGrid::after {
    display: table;
    content: "";
    clear: both;
}

.contentGrid + .contentGrid {
    margin-top: 20px;
}

.contentGrid .column {
    width: 100%;
    float: left;
    margin-bottom: 10px;
}

.contentGrid img {
    width: 100%;
    height: auto;
}

@media (min-width: 768px) {
    .contentGrid table td {
        padding: 15px 25px;
    }

    .contentGrid .column {
        margin-bottom: 0;
    }

    .contentGrid-col-3 .column {
        width: 33.333333%;
    }

    .contentGrid-col-3 .column:nth-child(2) {
        padding-left: 7.5px;
        padding-right: 7.5px;
    }

    .contentGrid-col-4 .column:nth-child(1),
    .contentGrid-col-4 .column:nth-child(2) {
        margin-bottom: 20px;
    }

    .contentGrid-col-2 .column,
    .contentGrid-col-4 .column,
    .contentGrid-col-4_8 .column,
    .contentGrid-col-8_4 .column {
        width: 50%;
    }

    .contentGrid-col-2 .column:nth-child(1),
    .contentGrid-col-3 .column:nth-child(1),
    .contentGrid-col-4 .column:nth-child(odd),
    .contentGrid-col-4_8 .column:nth-child(1),
    .contentGrid-col-8_4 .column:nth-child(1) {
        padding-right: 15px;
    }

    .contentGrid-col-2 .column:nth-child(2),
    .contentGrid-col-3 .column:nth-child(3),
    .contentGrid-col-4 .column:nth-child(even),
    .contentGrid-col-4_8 .column:nth-child(2),
    .contentGrid-col-8_4 .column:nth-child(2) {
        padding-left: 15px;
    }
}

@media (min-width: 992px) {
    .contentGrid + .contentGrid {
        margin-top: 30px;
    }

    .contentGrid-col-4 .column {
        width: 25%;
    }

    .contentGrid-col-4 .column:nth-child(odd) {
        padding-right: 0;
    }

    .contentGrid-col-4 .column:nth-child(even) {
        padding-left: 0;
    }

    .contentGrid-col-4 .column:nth-child(1),
    .contentGrid-col-4 .column:nth-child(2) {
        margin-bottom: 0;
    }

    .contentGrid-col-4_8 .column:nth-child(1) {
        width: 33.333333%;
        padding-right: 30px;
    }

    .contentGrid-col-4_8 .column::nth-child(2) {
        width: 66.666666%;
        padding-left: 30px;
    }

    .contentGrid-col-8_4 .column:nth-child(1) {
        width: 66.666666%;
        padding-right: 30px;
    }

    .contentGrid-col-8_4 .column:nth-child(2) {
        width: 33.333333%;
        padding-left: 30px;
    }

    .contentGrid-col-2 .column:nth-child(1),
    .contentGrid-col-3 .column:nth-child(1),
    .contentGrid-col-4 .column:nth-child(1) {
        padding-right: 30px;
    }

    .contentGrid-col-2 .column:nth-child(2),
    .contentGrid-col-3 .column:nth-child(3),
    .contentGrid-col-4 .column:nth-child(4) {
        padding-left: 30px;
    }

    .contentGrid-col-3 .column:nth-child(2),
    .contentGrid-col-4 .column:nth-child(2),
    .contentGrid-col-4 .column:nth-child(3) {
        padding-left: 15px;
        padding-right: 15px;
    }
}

@media (min-width: 1280px) {
    .contentGrid + .contentGrid {
        margin-top: 40px;
    }

    .contentGrid-col-2 .column:nth-child(1),
    .contentGrid-col-3 .column:nth-child(1),
    .contentGrid-col-4 .column:nth-child(1),
    .contentGrid-col-4_8 .column:nth-child(1),
    .contentGrid-col-8_4 .column:nth-child(1) {
        padding-right: 50px;
    }

    .contentGrid-col-2 .column:nth-child(2),
    .contentGrid-col-3 .column:nth-child(3),
    .contentGrid-col-4 .column:nth-child(4),
    .contentGrid-col-4_8 .column:nth-child(2),
    .contentGrid-col-8_4 .column:nth-child(2) {
        padding-left: 50px;
    }

    .contentGrid-col-3 .column:nth-child(2),
    .contentGrid-col-4 .column:nth-child(2),
    .contentGrid-col-4 .column:nth-child(3) {
        padding-left: 25px;
        padding-right: 25px;
    }
}

.contentGrid h1,
.contentGrid h2,
.contentGrid h3,
.contentGrid h4,
.contentGrid h5,
section .content h1,
section .content h2,
section .content h3,
section .content h4,
section .content h5 {
    color: #000;
}

.contentGrid h1:first-child,
.contentGrid h2:first-child,
.contentGrid h3:first-child,
.contentGrid h4:first-child,
.contentGrid h5:first-child,
section .content h1:first-child,
section .content h2:first-child,
section .content h3:first-child,
section .content h4:first-child,
section .content h5:first-child {
    margin-top: 0;
}

.contentGrid p,
section .content p {
    margin: 0 0 14px;
}

.contentGrid p:first-child,
section .content p:first-child {
    margin-top: 0;
}

.contentGrid h2,
.contentGrid h3,
section .content h2,
section .content h3 {
    margin-top: 28px;
    margin-bottom: 14px;
}

.contentGrid h4,
.contentGrid h5,
section .content h4,
section .content h5 {
    margin-top: 14px;
    margin-bottom: 14px;
}

.contentGrid h2 + h3,
section .content h2 + h3 {
    margin-top: 0;
}

.contentGrid ul,
.contentGrid ol,
section .content ul,
section .content ol {
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 1rem;
}

.contentGrid ul,
section .content ul {
    padding-left: 15px;
}

.contentGrid ul li,
section .content ul li {
    position: relative;
    line-height: 30px;
}

.contentGrid ul li::before,
section .content ul li::before {
    content: "";
    width: 5px;
    height: 5px;
    display: inline-block;
    background-color: #4b4e53;
    position: absolute;
    top: 12px;
    left: -15px;
}

.contentGrid ol,
section .content ol {
    padding-left: 20px;
    list-style-type: decimal;
}

.contentGrid ol li,
section .content ol li {
    padding-left: 5px;
    line-height: 30px;
}

.steps {
    width: 100%;
    color: #afafaf;
    margin-bottom: 20px;
    margin-top: 30px;
    font-size: 1.71429em;
}

.steps__step {
    display: inline-block;
    width: 25px;
    min-height: 35px;
    border-bottom: 4px solid #afafaf;
}

.steps__step a {
    vertical-align: middle;
    display: inline-block;
    color: inherit;
}

.steps__step span {
    display: block;
}

.steps__step span:nth-child(2) {
    display: none;
}

.steps__step--complete {
    color: #6e27c5;
    border-bottom: 4px solid #6e27c5;
}

.steps__step--selected {
    width: auto;
}

.steps__step--selected span {
    display: none;
}

.steps__step--selected span:nth-child(2) {
    display: block;
}

@media (min-width: 1024px) {
    .steps__step {
        width: calc(25% - 5px);
    }

    .steps__step span {
        display: none;
    }

    .steps__step span:nth-child(2) {
        display: block;
    }
}

form {
    position: relative;
}

form .subheading {
    font-size: 2.57143em;
}

.form__row {
    width: 100%;
    margin: 15px 0;
}

.form__row label,
.form__row input,
.form__row .CJS-dropdown {
    display: block;
}

.form__row label {
    margin-bottom: 5px;
}

.form__row input {
    width: 100%;
}

.form__row .js-start-date + img,
.form__row .js-end-date + img {
    display: none;
}

#errorPostcodeLookup,
.form__row .field-validation-error {
    padding: 10px 0 0;
    display: block;
    color: #f1352b;
}

#errorPostcodeLookup::before,
.form__row .field-validation-error::before {
    font-family: "FontAwesome";
    content: "\f0d8";
    margin-right: 5px;
}

.button__row {
    background: #01c1d6;
    padding: 40px 0;
    margin: 0 calc(-50vw + 50%);
    margin-top: 40px;
}

.col__grid + .button__row {
    margin-top: 0;
}

.button__row .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 10px;
}

.button__row button,
.button__row .button {
    margin: 0 auto;
    display: block;

    background-color: #fff;
    color: #000;
}

.button__row .back {
    margin: 0 15px 0 0;

    font-size: 1rem;
    font-weight: 700;
    text-decoration: underline;
    color: #000;
}

.button__row .back::before {
    position: relative;
    left: 0;
    font-family: "FontAwesome";
    content: "\f0d9";
    display: inline-block;
    margin-right: 5px;
    -webkit-transition: left 250ms ease;
    -o-transition: left 250ms ease;
    transition: left 250ms ease;
}

.button__row .back:hover::before {
    left: -3px;
}

@media (min-width: 1024px) {
    .form__row {
        width: 66.666666%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -ms-flex-flow: wrap;
        flex-flow: wrap;
    }

    .form__row label {
        display: inline-block;
        width: 50%;
        margin-bottom: 0;
        padding-right: 37px;
    }

    .form__row input {
        display: inline-block;
        width: 50%;
        max-width: 425px;
    }

    .form__row .CJS-dropdown {
        width: 50%;
    }

    .form__row .js-start-date,
    .form__row .js-end-date {
        width: calc(50%);
    }

    .form__row .js-start-date + img,
    .form__row .js-end-date + img {
        display: inline-block;
        width: auto;
        height: 35px;
        margin-left: 15px;
        max-width: 60px;
    }

    .form__row .field-validation-error {
        padding-left: 50%;
    }
}

label {
    font-size: 1rem;
    line-height: 1.375;
}

input[type="text"],
input[type="email"],
input[type="number"],
input[type="password"] {
    background: #fff;
    background: transparent;
    border: 1px solid #afafaf;
    height: 50px;
    line-height: 50px;
    text-align: left;
    padding: 0 10px;
    font-size: 1rem;
    font-family: "Lato", "Georgia", "Times New Roman", Times, serif;
}

input[type="number"] {
    padding-right: 0;
}

button,
.button {
    cursor: pointer;
    height: 50px;
    line-height: 50px;
    background-color: #fff;
    color: #000;
    border: 0;
    text-decoration: none;
    text-align: center;
    font-family: "Lato", "Georgia", "Times New Roman", Times, serif;
    font-size: 1rem;
    font-weight: 700;
    max-width: 425px;
    width: 100%;
    -webkit-transition: opacity 150ms ease;
    -o-transition: opacity 150ms ease;
    transition: opacity 150ms ease;
}

button:hover,
.button:hover {
    opacity: 0.8;
}

.button {
    display: block;
}

.button--orange {
    background-color: #ffb617;
    color: #000;
}

.CJS-dropdown {
    position: relative;
    text-decoration: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin-bottom: 0;
    left: 0;
    top: 0;
    width: 100%;
    max-width: 425px;
    background: #fff;
    height: 50px;
    line-height: 50px;
    font-size: 1rem;
    display: inline-block;
}

.CJS-dropdown::after {
    font-family: "FontAwesome";
    content: "\f0d7";
    position: absolute;
    font-size: 1em;
    color: #000;
    width: 100px;
    height: 100%;
    background: #01c1d6;
    right: 0;
    text-align: center;
    top: 0;
}

.CJS-dropdown.CJS-focused ins {
    border-color: #01c1d6;
}

.CJS-dropdown.CJS-error {
    color: #f1352b;
}

.CJS-dropdown.CJS-error ins {
    border-color: #f1352b;
    border-width: 2px;
    color: #f1352b;
}

.CJS-dropdown.CJS-open ul {
    display: block;
}

.CJS-dropdown.CJS-open::after {
    font-family: "FontAwesome";
    content: "\f0d8";
}

.CJS-dropdown em {
    font-style: normal;
}

.CJS-dropdown select {
    position: absolute;
    top: 0;
    left: 0;
    height: 0;
    width: 0;
    opacity: 0;
    visibility: hidden;
}

.CJS-dropdown ins {
    width: 100%;
    text-decoration: none;
    z-index: 1;
    position: relative;
    border: 1px solid #afafaf;
    padding: 0 15px;
    height: 50px;
    line-height: 50px;
    float: left;
    cursor: pointer;
}

.CJS-dropdown ul {
    position: absolute;
    width: 100%;
    max-height: 230px;
    left: 0;
    top: 100%;
    display: none;
    overflow: auto;
    z-index: 2;
    height: auto;
    background: #fff;
    border: 1px solid #01c1d6;
    list-style: none;
    padding: 0;
}

.CJS-dropdown li {
    padding: 0px 15px;
    cursor: pointer;
    margin: 0;
    color: #4b4e53;
    width: 100%;
}

.CJS-dropdown li.CJS-highlighted {
    color: #fff;
    background-color: #01c1d6;
}

.ui-datepicker {
    border: none;
    color: #344049;
    font-size: 12px;
    width: 100%;
    max-width: 425px;
}

.ui-datepicker a {
    text-decoration: none;
}

.ui-datepicker-title {
    display: block;
    text-align: center;
    font-size: 26px;
    font-family: "Lato", "Georgia";
    float: left;
    height: 30px;
    font-weight: normal;
}

.ui-datepicker-month,
.ui-datepicker-year {
    text-align: center;
}

.ui-datepicker-header {
    position: relative;
    height: 30px;
    color: #fff;
    font-weight: 700;
    line-height: 30px;
    text-align: center;
    width: 100%;
    float: left;
    margin-bottom: 15px;
}

.ui-datepicker-header a {
    display: block;
    font-size: 0;
    line-height: 0;
    width: 13px;
    height: 15px;
    margin: 8px;
    cursor: pointer;
}

.ui-datepicker-header a.ui-datepicker-prev {
    float: left;
    background: url("img/arrow-left.png");
}

.ui-datepicker-header a.ui-datepicker-next {
    float: right;
    background: url("img/arrow-right.png");
}

.ui-datepicker-header .ui-state-disabled a {
    cursor: default;
    color: #afafaf;
}

.ui-datepicker-header .ui-datepicker-title {
    padding: 0;
    text-align: center;
    width: calc(100% - 60px);
}

.ui-datepicker-calendar {
    border-spacing: 2px;
    width: 100%;
}

.ui-datepicker-calendar .ui-state-default {
    width: 100%;
    height: 100%;
    display: block;
    padding-top: 0px;
    color: #fff;
    border: 1px solid #ff0198;
    font-size: 14px;
    display: block;
}

.ui-datepicker-calendar td.ui-datepicker-unselectable .ui-state-default {
    color: rgba(255, 255, 255, 0.5);
}

.ui-datepicker-calendar td.ui-datepicker-current-day .ui-state-default {
    background-color: #fff;
    color: #ff0198;
}

.ui-datepicker-calendar a:hover {
    border: 1px solid #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.ui-datepicker-calendar th {
    height: 30px;
    font-size: 14px;
    line-height: 30px;
    font-size: 14px;
    font-family: "Lato", "Georgia";
    color: #fff;
}

.ui-datepicker-calendar td {
    width: 23px;
    font-size: 14px;
    height: 30px;
    line-height: 30px;
    padding: 0;
    font-size: 10px;
    font-weight: bold;
    text-align: center;
    vertical-align: middle;
}

td.ui-datepicker-current-day a {
    background-color: #fff;
    color: #ff0198;
}

td.ui-datepicker-unselectable {
    border-color: #e3e3e0;
}

td.ui-datepicker-unselectable span {
    width: 100%;
    height: 100%;
    display: block;
    padding-top: 0px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 14px;
    border: 1px solid #ff0198;
}

td.ui-datepicker-other-month {
    border-color: #b5c4c7;
}

td.ui-datepicker-other-month span {
    background-color: #dfddde;
    color: #bebdbc;
    visibility: hidden;
}

.datepicker {
    width: 100%;
    padding: 20px;
}

.datepicker:first-child {
    float: left;
    margin-right: 40px;
}

@media (max-width: 767px) {
    div.ui-datepicker {
        max-width: 360px;
    }

    .datepicker {
        margin-bottom: 20px;
    }
}

@media (min-width: 1024px) {
    .datepicker {
        margin-bottom: 0;
        width: calc(50% - 20px);
    }
}

@media (min-width: 1280px) {
    #duration-days {
        width: 66.66%;
    }
}

#ui-datepicker-div {
    border-top: 1px solid #fff;
    padding: 20px;
    background: #ff0198;
    display: none;
}

.list__documents {
    margin: 20px 0 0;
}

.list__documents li {
    background: #ebebeb;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 15px 30px;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-flow: wrap;
    flex-flow: wrap;
    font-size: 1.28571em;
}

.list__documents li + li {
    margin-top: 1px;
}

.list__documents li::before {
    display: block;
    content: "";
    width: 33px;
    height: 40px;
    background: transparent url("img/pdf.svg") no-repeat center center/contain;
    margin-right: 10px;
}

.list__documents li > span {
    display: block;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

.list__documents li > a {
    display: block;
    color: #000;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    margin-top: 10px;
}

.list__documents li > a::after {
    font-family: "FontAwesome";
    content: "\f0da";
    margin-left: 5px;
    position: relative;
    left: 0;
    -webkit-transition: left 250ms ease;
    -o-transition: left 250ms ease;
    transition: left 250ms ease;
}

.list__documents li > a:hover::after {
    left: 3px;
}

@media (min-width: 768px) {
    .list__documents li {
        -ms-flex-flow: nowrap;
        flex-flow: nowrap;
    }

    .list__documents li > a {
        margin-top: 0;
        margin-left: 10px;
        -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
    }
}

.col__grid {
    margin-bottom: 40px;
}

.col__grid:only-child,
.col__grid:first-child {
    margin-top: 50px;
}

.col__66 + .col__33 {
    margin-top: 25px;
}

blockquote {
    color: #000;
}

blockquote::after {
    content: "";
    display: table;
    clear: both;
}

blockquote h3 {
    line-height: 42px;
}

.box + blockquote {
    margin-top: 40px;
}

.required__fields {
    position: absolute;
    top: 0;
    right: 0;

    font-size: 0.8125rem;
    line-height: 1.4;
    color: #afafaf;
}

.subheading {
    color: #000;
    margin: 40px 0 0;
}

.subheading:first-of-type {
    margin-top: 0;
}

.subheading + .form__row {
    margin-top: 30px;
}

.subheading + p {
    margin-top: 20px;
}

.box {
    padding: 50px;
}

.box .price {
    color: #6e27c5;
}

.box p {
    padding-right: 100px;
}

.box .button {
    margin-top: 25px;
}

.col__33 .box ul {
    padding-left: 0;
}

.col__33 .box ul li {
    line-height: normal;
}

.col__33 .box ul li::before {
    content: none;
    display: none;
}

.box ul li {
    margin-bottom: 15px;
}

.box ul li:last-of-type {
    margin-bottom: 0;
}

.box h3:first-of-type {
    margin-bottom: 25px;
}

.box--grey {
    background: #ebebeb;
}

.box--grey h3 {
    color: #000;
}

.box--purple {
    background: #6e27c5;
    color: #fff;
}

.box--blue {
    background: #01c1d6;
    color: #000;
}

.box--success {
    padding: 30px 50px 30px 80px;
}

.box:not(:only-child) {
    margin: 15px 0;
}

a.arrow--right {
    color: #000;
}

a.arrow--right::after {
    font-family: "FontAwesome";
    content: "\f0da";
    margin-left: 5px;
    position: relative;
    top: 1px;
    left: 0;
    -webkit-transition: left 250ms ease;
    -o-transition: left 250ms ease;
    transition: left 250ms ease;
}

a.arrow--right:hover:after {
    left: 3px;
}

@media (min-width: 1024px) {
    .col__grid::after {
        content: "";
        display: table;
        clear: both;
    }

    .col__66 {
        float: left;
        width: 66.666666%;
    }

    .col__66 + .col__33 {
        margin-top: 0;
        padding-left: 50px;
    }

    .col__33 {
        float: left;
        width: 33.333333%;
    }

    blockquote h3 {
        max-width: 300px;
        float: right;
    }
}

.flex__grid {
    display: block;
}

.flex__grid::after {
    content: "";
    display: table;
    clear: both;
}

.flex__grid [class^="flex__"] + [class^="flex__"] {
    margin-top: 30px;
}

@media (min-width: 1024px) {
    .flex__grid [class^="flex__"] {
        float: left;
        padding: 0 30px 0;
    }

    .flex__grid [class^="flex__"] + [class^="flex__"] {
        margin-top: 0;
    }

    .flex__grid [class^="flex__"]:first-child {
        padding-left: 0;
    }

    .flex__grid [class^="flex__"]:last-child {
        padding-right: 0;
    }

    .flex__grid .flex__6 {
        width: 60%;
    }

    .flex__grid .flex__4 {
        width: 40%;
    }

    .flex__grid .flex__3 {
        width: 33.333333%;
    }
}

@supports (display: -moz-flex) or (display: flex) {
    .flex__grid {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .flex__grid::after {
        display: none;
        content: none;
    }

    .flex__grid [class^="flex__"] {
        float: none;
    }

    @media (min-width: 1024px) {
        .flex__grid {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-orient: horizontal;
            -webkit-box-direction: normal;
            -ms-flex-direction: row;
            flex-direction: row;
        }

        .flex__grid--va-b {
            -webkit-box-align: end;
            -ms-flex-align: end;
            align-items: flex-end;
        }
        
        .flex__grid--va-c {
            -webkit-box-align: center;
            -ms-flex-align: center;
            align-items: center;

        }
    }
}

.icon--checkmark {
    position: relative;
    left: -55px;
}

.icon--checkmark::before {
    display: inline-block;
    content: "";
    width: 40px;
    height: 40px;
    background: transparent url("img/tick-white.svg") no-repeat center
        center/contain;
    vertical-align: middle;
    margin-right: 15px;
}

.iradio {
    display: inline-block;
    *display: inline;
    vertical-align: middle;
    margin: 0;
    padding: 0;
    width: 24px;
    height: 24px;
    border: 1px solid #afafaf;
    cursor: pointer;
    border-radius: 50%;
    overflow: hidden;
    margin-right: 5px;
}

.iradio + .iradio {
    margin-left: 30px;
}

.iradio.checked::after {
    position: absolute;
    top: 50%;
    left: 50%;
    content: "";
    background: #01c1d6;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 15px;
    height: 15px;
    border-radius: 50%;
}

.image__hero {
    height: auto;
    width: 100%;
    background-color: #afafaf;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    padding-top: 150px;
}

section > .image__hero {
    background-position: center center;
}

.image__hero.image__hero--secondary .cta {
    max-width: 530px;
}

section + section .image__hero {
    margin-top: 40px;
}

.image__hero .container {
    position: relative;
    width: 100%;
    height: 100%;
}

.image__hero .cta {
    background-color: #ffb617;
    padding: 50px 50px 50px 0;
    width: auto;
    width: 100%;
    display: inline-block;
    color: #000;
    max-width: 780px;
}

.image__hero .cta::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: calc(-50vw + 50%);
    height: 100%;
    width: calc(50vw - 50% + 25px);
    background: #ffb617;
}

.image__hero--pink .cta,
.image__hero--pink .cta::before {
    background-color: #ff0198;
}

.image__hero--red .cta,
.image__hero--red .cta::before {
    background-color: #f1352b;
    color: #fff;
}

.image__hero--navy .cta,
.image__hero--navy .cta::before {
    background-color: #150f96;
    color: #fff;
}

.image__hero--purple .cta,
.image__hero--purple .cta::before {
    background-color: #6e27c5;
    color: #fff;
}

@media (min-width: 768px) {
    .image__hero .cta {
        -webkit-box-sizing: content-box;
        box-sizing: content-box;
    }
}

.box h3 .price,
.box.box--purple h3 .price {
    font-size: 1.6em;
}

.priceSub {
    font-size: 0.8125rem;
    line-height: 1.4;
}

.box.box--purple .price {
    color: #fff;
    font-size: 3em;
}

.image__hero h3 .price {
    font-size: 1.66667em;
}

.image__hero h1 + h4 {
    margin-top: 27px;
}

.image__hero h4 {
    line-height: 40px;
}

.image__hero .button {
    margin-top: 12px;
}

.col__grid > h2 {
    color: #000;
    margin-bottom: 25px;
}

.box--success p {
    padding-right: 0;
}

.flex__3 .button {
    margin: 0;
    margin-bottom: 10px;
}

.flex__3 .button:last-child {
    margin-bottom: 0;
}

.box.box--blue li {
    margin-bottom: 0;
}

.box.box--blue li::before {
    background-color: #000;
}

.box.box--blue .button {
    background-color: #fff;
    color: #000;
}

.box ul {
    padding-left: 15px;
}

.box ul li {
    position: relative;
    line-height: 30px;
}

.box ul li::before {
    content: "";
    width: 5px;
    height: 5px;
    display: inline-block;
    background-color: #4b4e53;
    position: absolute;
    top: 12px;
    left: -15px;
}

.image__hero .content h1,
.image__hero .content h2,
.image__hero .content h3,
.image__hero .content h4,
.image__hero .content h5 {
    color: #000;
}

.data-table__header {
    background-color: #6e27c5;
    color: #fff;
    display: table;
    width: 100%;
    padding: 20px;
}

.data-table__row {
    background-color: #fff;
    padding: 15px 20px;
    display: table;
    width: 100%;
    border: 1px solid #afafaf;
    border-top: 0;
}

.data-table__col {
    display: table-cell;
    width: 50%;
    padding-right: 15px;
}

.data-table__col + .data-table__col {
    padding-left: 15px;
}

.data-table__col:last-child {
    text-align: right;
    padding-right: 0;
}

.data-table__col a {
    color: #000;
    font-size: 18px;
}

.data-table__col:last-child {
    min-width: 95px;
}

@supports (display: -moz-flex) or (display: flex) {
    .data-table__header,
    .data-table__row,
    .data-table__col {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    .data-table__header,
    .data-table__row {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .data-table__col {
        width: auto;
    }

    .data-table__col:last-child {
        text-align: left;
    }
}

.icheckbox {
    display: inline-block;
    *display: inline;
    vertical-align: middle;
    margin: 0;
    padding: 0;
    width: 24px;
    height: 24px;
    border: 1px solid #afafaf;
    cursor: pointer;
    overflow: hidden;
    margin-right: 5px;
}

.icheckbox.checked::before {
    position: absolute;
    top: 50%;
    left: 50%;
    content: "";
    background: #01c1d6;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 15px;
    height: 15px;
}

.accordion > h3 {
    position: relative;
    background: #6e27c5;
    padding: 20px 50px 20px 30px;
    color: #fff;
    margin: 0;
    margin-top: 10px;
    cursor: pointer;
}

.accordion > h3:first-child {
    margin-top: 0;
}

.accordion > h3::after {
    font-family: "FontAwesome";
    content: "\f0d7";
    position: absolute;
    right: 20px;
    color: #fff;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    font-size: 18px;
}

.accordion > h3.ui-state-active::after {
    content: "\f0d8";
}

.accordion__body {
    border: 1px solid #afafaf;
    border-top: 0;
    padding: 20px;
}

@media (min-width: 1024px) {
    .accordion__body {
        padding: 40px;
    }
}

/* Additional Styles */

.accordion {
    margin-bottom: 15px;
}

.background--about {
    background-image: url("img/headers/about-us.jpg");
}

.background--whats-covered {
    background-image: url("img/headers/what-is-covered.jpg");
}

.background--activity {
    background-image: url("img/headers/activity-organisation.jpg");
}

.background--make-a-claim {
    background-image: url("img/headers/make-a-claim.jpg");
}

.background--checklist {
    background-image: url("img/headers/document-checklist.jpg");
}

.background--contact-us {
    background-image: url("img/headers/contact-us.jpg");
}

.background--accessibility {
    background-image: url("img/headers/accessibility.jpg");
}

.background--emergency {
    background-image: url("img/headers/emergency-procedures.jpg");
}

.background--cookies {
    background-image: url("img/headers/privacy-cookies.jpg");
}

.background--sitemap {
    background-image: url("img/headers/sitemap.jpg");
}

.background--who-is-chubb {
    background-image: url("img/headers/who-is-chubb.jpg");
}

.bgthree {
    background-image: url("img/header-bg-three.png");
}

.bgtwo {
    background-image: url("img/header-bg-two.png");
}

.bgfour {
    background-image: url("img/header-bg-four.png");
}

.eduvia__bar {
    display: none;
    padding: 10px 25px;
    width: 100%;
    background: #4b4e53;
}

.eduvia__bar::after {
    display: table;
    clear: both;
    content: "";
}

.eduvia__bar .eduvia__logo {
    float: right;
    display: block;
}

.eduvia__logo {
    width: auto;
    height: 40px;
    display: none;
}

.forgotPassword {
    width: 100%;

    color: #000;
    font-weight: 700;
    text-decoration: underline;
}

.forgotPassword:hover {
    text-decoration: none;
}

#loginErrorDiv + .button__row .back {
    position: absolute;
}

.content p a:not(.button) {
    color: #000;
    text-decoration: underline;
    font-weight: 700;
}

.content p a:not(.button):hover {
    text-decoration: none;
}

.panel33 .callToAction {
    margin-top: 15px;
}

@media (max-width: 1024px) {
    .eduvia__bar {
        display: block;
    }
}

@media (min-width: 1024px) {
    .eduvia__logo {
        display: block;
        float: right;
        margin-bottom: 10px;
    }

    .eduvia__logo ~ ul {
        clear: both;
    }

    .forgotPassword {
        display: block;
        padding-left: 50%;
    }

    #errorPostcodeLookup {
        display: block;
        margin-left: 33.33333%;
    }

    .chubbLogo {
        margin-top: 19px;
    }
}

.has-children > a:first-child {
    cursor: default;
}

/* Additional Styles */

#loadingDiv {
    position: fixed;
    top: 0;
    left: 0;
    display: none;
    width: 100%;
    height: 100%;
    background-color: #000000;
    z-index: 999999999;
    opacity: 0.6;
}

.noDisplay {
    display: none;
}

.blockDisplay {
    display: block;
}

.inlineBlock {
    display: inline-block;
}

.topPadding10 {
    padding-top: 10px;
}

.bottomPadding10 {
    padding-bottom: 10px;
}

.fullWidth {
    width: 100%;
}

.halfWidth {
    width: 50%;
}

.errorRed {
    color: #ff0000;
}

.linkWhite {
    color: white;
}

.fontBold {
    font-weight: bold;
}

.fontOneHalfEM {
    font-size: 1.5em;
}

.fontUnderlined {
    text-decoration: underline;
}

.fontAlignRight {
    text-align: right;
}

.floatLeft {
    float: left;
}

.detailsSubPadding {
    padding: 10px 0px 10px 30px;
}

/*TEMPLATE*/
.chubbLogo {
    background: url(img/logo.png) no-repeat top left;
    display: block;
    width: 169px;
    height: 18px;
    text-indent: -9999px; /* hides the link text */
}

/*INDEX*/
.buttonRightPadding {
    padding: 12px 0 0 15px;
}

/*LOGIN*/
.ui-dialog-osx {
    -moz-border-radius: 8px 8px 8px 8px;
    -webkit-border-radius: 8px 8px 8px 8px;
    border-radius: 8px 8px 8px 8px;
    border-width: 8px 8px 8px 8px;
}

.ui-dialog-titlebar {
    display: none;
}

#getQuotePopUp {
    display: none;
    overflow: auto;
    font-size: 1em;
    margin-left: 10px;
    font-family: "Lato", Georgia, "Times New Roman", Times, serif;
}

#getQuotePopUp span {
    font-size: 1em;
    line-height: 1.5em;
}

#brokerTermsPopUp {
    display: none;
    overflow: auto;
    font-size: 1em;
    margin-left: 10px;
    font-family: "Lato", Georgia, "Times New Roman", Times, serif;
}

#brokerTermsPopUp .content > h3 {
    font-size: 1.75em;
}

#brokerTermsPopUp ul li {
    margin-top: 1em;
    font-size: 1em;
    line-height: 1.5em;
}

#brokerTermsPopUp span {
    font-size: 1em;
    line-height: 1.5em;
}

#brokerTermsPopUp .subhead {
    padding-bottom: 10px;
}

/*MANAGE USERS*/
.userDetailsForm {
    padding: 10px 10px 10px 10px;
}

/*POLICY HOLDER DETAILS*/
.grayout {
    opacity: 0.3;
    filter: alpha(opacity = 30);
}

.policyHolderYesNo {
    float: none;
    width: 5% !important;
    padding-left: 5px;
}

/*DECLINE POLICY*/
.declinePolicyBox {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: red;
}

.declinePolicyBox div {
    width: 400px;
    height: 200px;
}

/*POLICY LIST*/
.dataTables_wrapper {
    padding-top: 20px;
}

/*SITEMAP*/
@media (min-width: 768px) {
    .sitemap li {
        width: 50%;
        padding-right: 15px;
    }
}

.sitemap li {
    width: 100%;
    float: left;
}

.sitemap a {
    color: #4b4e53;
}

/*PANEL LIST*/
.panel__list {
    display: flex;
}

.panel__list .panel33 {
    padding: 50px;
    flex: 1 1 auto;
    width: 33.333333%;
    max-width: 33.333333%;
    color: #000;
}

.panel__list .panel33 h2 {
    font-size: 1.875em;
}

.panel__list .panel33 h3 {
    font-size: 1.3em;
}

.panel__list .panel33 p {
    font-size: 1.1em;
    line-height: 1.375em;
    padding-top: 1em;
}

.panel__list .panel33 a:not(.button) {
    text-decoration: underline;
    color: inherit;
}

.panel__list .panel33 a:not(.button):hover {
    text-decoration: none;
}

.panel__list .panel33 + .panel33:not(:first-child):not(:last-child) {
    margin: 0 30px;
}

.panel__list .panel33.pink {
    background-color: #ff0198;
}

.panel__list .panel33.blue {
    background-color: #01c1d6;
}

.panel__list .panel33.green {
    background-color: #7acb00;
}

.panel__list .panel33.yellow {
    background-color: #ffb617;
}

.panel__list .panel33.purple {
    background-color: #6e27c5;
    color: #fff;
}

@media (max-width: 1024px) {
    .panel__list {
        display: block;
    }

    .panel__list .panel33 {
        width: 100%;
        max-width: 100%;
        margin: 15px 0 !important;
    }
}

/*DOCUMENT LIST*/
.documents__list {
    background-color: #01c1d6;
    padding: 50px;
}

.documents__list ul {
    list-style: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
}

@media (min-width: 1024px) {
    .documents__list ul {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
}

.documents__list li {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    align-items: center;
    width: 100%;
    margin-bottom: 10px;
}

.documents__list li::before {
    display: block;
    content: "";
    width: 33px;
    height: 40px;
    background: transparent url("img/pdf-white.svg") no-repeat center
        center/contain;
    margin-right: 10px;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 33px;
    flex: 0 0 33px;
}

.documents__list li a {
    color: #fff;
    text-decoration: none;
}

@media (min-width: 1024px) {
    .documents__list li {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
        flex: 0 0 auto;
        width: calc(50% - 15px);
        max-width: 50%;
    }
}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset {
    float: none !important;
}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button {
    max-width: 100px;
}

#acceptBtn,
#getQuotePopUpBtnAccept,
#getQuotePopUpBtnAcceptLogin {
    margin: 0 auto;
    display: block;
    margin-top: 15px;
    background-color: #01c1d6;
}

.ui-widget-overlay {
    opacity: 0.25 !important;
}

.ui-corner-all {
    border-radius: 0 !important;
}

.ui-widget-content {
    color: inherit !important;
}

.ui-dialog {
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3) !important;
}

.button.blue {
    background-color: #01c1d6;
    color: #fff;
}

.accordion > h3 {
    font-size: 1.5em;
}

.accordion #msg {
    margin-top: 15px;
}

.documents__list li a {
    font-size: 1rem;
    line-height: 1.375rem;
}

.button__row .container {
    padding-left: 25px;
    padding-right: 25px;
}

@media (max-width: 1024px) {
    .button__row.button__row--reverse .container {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }

    .button__row.button__row--reverse .container .button {
        width: 100%;
        margin: 5px 0;
    }
}

.button__row.button__row--reverse .container .button:nth-child(2) {
    margin: 0 15px;
}

.button__row.button__row--reverse .container .button:nth-child(3) {
    margin: 0 15px;
}

.login-page__grid {
    padding: 40px 0px 40px 0px;
}

.policiesDTViewButton {
    background: none !important;
    color: #ff0198;
    padding: 0;
    line-height: 0;
    height: 10px;
    text-align: left;
}

.cookiepolicy h2 {
    margin-top: 25px;
    margin-bottom: 0px;
}

.cookiepolicy ol {
    font-size: 1.28571em;
}

.cookiepolicy li {
    margin-bottom: 10px;
}

@font-face {
    font-family: "Lato";
    src: url("fonts/lato/lato-regular.woff2") format("woff2"),
        url("fonts/lato/lato-regular.woff") format("woff");
    font-weight: 400;
}

@font-face {
    font-family: "Lato";
    src: url("fonts/lato/lato-italic.woff2") format("woff2"),
        url("fonts/lato/lato-italic.woff") format("woff");
    font-weight: 400;
    font-style: italic;
}

@font-face {
    font-family: "Lato";
    src: url("fonts/lato/lato-bold.woff2") format("woff2"),
        url("fonts/lato/lato-bold.woff") format("woff");
    font-weight: 700;
}

@font-face {
    font-family: "Lato";
    src: url("fonts/lato/lato-bolditalic.woff2") format("woff2"),
        url("fonts/lato/lato-bolditalic.woff") format("woff");
    font-weight: 700;
    font-style: italic;
}

.ui-widget input,
.ui-widget select,
.ui-widget textarea,
.ui-widget button {
    font-family: "Lato";
    font-size: 1rem;
}

.declaration-box {
    padding: 28px;
    margin-bottom: 30px;

    background-color: #f4f4f4;

    font-size: 1rem;
}

.declaration-box__desc {
    margin-top: 8px;
}

.declaration-box__desc a {
    color: inherit;
    font-weight: 700;
    text-decoration: underline;

    cursor: pointer;
}
