html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

html.stopScroll {
    max-height: 100vh;
    overflow: hidden;
}

body {
    margin: 0;
    font-family: sans-serif;
    font-weight: 300;
}

p {
    margin-block-start: 0;
    margin-block-end: 0;
}

img {
    display: block;
    max-height: 100vh;
}

body {
    position: relative;
}

.text *,
h4,
h5,
p,
a.button {
    font-size: 17px;
    font-weight: 300;
    font-family: Roboto-two, sans-serif;
    margin-block-start: 0;
    margin-block-end: 0;
}

h3,
.text h3,
.title h3 {
    font-size: 40px;
    font-family: Runalto, sans-serif;
    font-weight: 500;
    margin-block-start: 0;
    margin-block-end: 0;
}

.title *,
.text h1,
h1,
h2 {
    font-size: 64px;
    font-family: Runalto, sans-serif;
    font-weight: 500;
    margin-block-start: 0;
    margin-block-end: 0;
}

strong *,
b *,
strong,
b {
    font-weight: bold !important;
}

a.button {
    letter-spacing: 2px;
    display: block;
    width: fit-content;
    margin: 0 auto;
    text-align: center;
    color: inherit;
    text-decoration: none;
    border: 2px solid;
    padding: 7px 15px;
    background: #00000096;
    transition: all 0.1s ease-in-out;
    cursor: pointer;
    font-weight: 400;
}

.menus .button {
    letter-spacing: 2px;
    display: block;
    width: fit-content;
    margin: 0 auto;
    text-align: center;
    color: inherit;
    text-decoration: none;
    border: 2px solid;
    padding: 7px 15px;
    background: white;
    transition: all 0.1s ease-in-out;
    cursor: pointer;
    font-weight: 400;
    margin-top: 25px;
}

.menus .button:hover {
    background: black;
    color: white;
}

body.home .fullHeader:not(.colour) {
    opacity: 0;
}

.fullHeader {
    position: fixed;
    z-index: 10;
    top: 0;
    width: 90%;
    padding: 10px 5%;
    height: 80px;
    color: #ECC9AD;
    transition: all 0.2s ease-in-out;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fullHeader .dropper {
    cursor: pointer;
    height: 28px;
    width: 40px;
    display: none;
}

.fullHeader .dropper.closed #one {
    animation-name: headerAnimOne2;
}

.fullHeader .dropper.closed #two {
    animation-name: headerAnimTwo2;
}

.fullHeader .dropper.closed #three {
    animation-name: headerAnimThree2;
}

.fullHeader .dropper.begin #one {
    animation-name: headerAnimOne;
}

.fullHeader .dropper.begin #two {
    animation-name: headerAnimTwo;
}

.fullHeader .dropper.begin #three {
    animation-name: headerAnimThree;
}

@keyframes headerAnimOne {
    0% {
        top: 0;
    }
    50% {
        top: 15px;
        transform: rotate(0deg);
    }
    100% {
        top: 12px;
        transform: rotate(-45deg);
    }
}

@keyframes headerAnimOne2 {
    0% {
        top: 15px;
        transform: rotate(-45deg);
    }
    50% {
        top: 15px;
        transform: rotate(0deg);
    }
    100% {
        top: 0;
        transform: rotate(0deg);
    }
}

@keyframes headerAnimTwo {
    50% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(-45deg);
    }
}

@keyframes headerAnimTwo2 {
    0% {
        transform: rotate(-45deg);
    }
    50% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(0deg);
    }
}

@keyframes headerAnimThree {
    0% {
        top: 0;
    }
    50% {
        top: -12px;
        transform: rotate(0deg);
    }
    100% {
        top: -12px;
        transform: rotate(45deg);
    }
}

@keyframes headerAnimThree2 {
    0% {
        top: -15px;
        transform: rotate(45deg);
    }
    50% {
        top: -15px;
        transform: rotate(0deg);
    }
    100% {
        top: 0;
    }
}

.fullHeader .dropper>div {
    width: 100%;
    height: 4px;
    margin-bottom: 8px;
    background: #a84728;
    position: relative;
    transition-delay: 1s;
    animation-fill-mode: forwards;
    animation-duration: 1s;
}

.fullHeader .inner {
    width: 90%;
    margin: 0 auto;
    max-width: 1400px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.fullHeader.colour {
    background: white;
    color: #a84728;
}

.fullHeader .inner .contactus {
    margin: 0 15px;
    position: relative;
}

.fullHeader .inner .contactus a {
    margin: 0;
}

.fullHeader .inner .contactus .dropdown {
    position: absolute;
    top: 45px;
    padding: 0 15px;
    transition: all 0.5s ease-in-out;
    max-height: 0px;
    overflow: hidden;
    display: none;
    /* remove this displaynone when maidenhead opens */
}

.fullHeader.colour .inner .contactus .dropdown {
    background: white;
}

.fullHeader .inner .contactus:hover .dropdown {
    padding: 15px;
    max-height: 55px;
}

.fullHeader .inner .contactus .dropdown>div {
    margin: 5px 0;
    padding-left: 15px;
    cursor: pointer;
    position: relative;
    transition: all 0.1s linear;
}

.fullHeader .inner .contactus .dropdown>div::before {
    position: absolute;
    content: "";
    width: 7px;
    height: 7px;
    transform: rotate(45deg);
    border: 1px solid #eccbaf;
    left: -3px;
    transition: all 0.1s linear;
    top: 3px;
}

.fullHeader.colour .inner .contactus .dropdown>div::before {
    border: 1px solid #a94728;
}

.fullHeader .inner .contactus .dropdown>div:hover::before,
.fullHeader .inner .contactus .dropdown>div.selected::before {
    background: #eccbaf;
}

.fullHeader.colour .inner .contactus .dropdown>div:hover::before,
.fullHeader.colour .inner .contactus .dropdown>div.selected::before {
    background: #a94728;
}

.fullHeader a {
    color: inherit;
    text-decoration: none;
    font-size: 13px;
    font-family: Roboto-two, sans-serif;
    font-weight: 400;
    transition: all 0.1s linear;
    position: relative;
}

.fullHeader a.logo::after {
    display: none;
}

.fullHeader a.logo {
    display: flex;
    position: relative;
    width: 60px;
    height: 60px;
}

.fullHeader a.logo img {
    width: 60px;
    position: absolute;
    top: 0;
    left: 0;
    transition: all 0.1s linear;
}

.fullHeader a.logo img.colour {
    opacity: 0;
    z-index: 2;
}

.fullHeader.colour a.logo img.colour {
    opacity: 1;
}

.fullHeader a.big {
    border: 2px solid #eccaae;
    padding: 5px 15px;
}

.fullHeader.colour a.big {
    border: 2px solid #a94728;
}

.fullHeader a:hover::after {
    opacity: 1;
}

.fullHeader a::after {
    content: "";
    position: absolute;
    display: block;
    width: 50px;
    height: 10px;
    left: calc(50% - 25px);
    top: calc(100% + 7px);
    -webkit-mask-image: url(/wp-content/uploads/2023/07/Group-127.png);
    mask-image: url(/wp-content/uploads/2023/07/Group-127.png);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-position: 50% 50%;
    mask-position: 50% 50%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background: #ECC9AD;
    transition: all 0.1s linear;
    opacity: 0;
}

.fullHeader.colour a::after {
    background: #a84728;
}

.contactSheets {
    position: fixed;
    top: 0%;
    left: 0%;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10;
    pointer-events: none;
}

.contactSheets>div {
    opacity: 0;
    position: absolute;
    background: #A84628;
    color: #ECC9AD;
    padding: 5%;
    width: 900px;
    max-width: 80%;
    transition: all 0.5s ease-in-out;
}

.contactSheets>div.hidden {
    background: none;
    padding: 0px;
    width: 0px;
    height: 0px;
    z-index: -1;
}

.contactSheets>div .close {
    position: absolute;
    top: 20px;
    right: 30px;
    font-size: 40px;
    cursor: pointer;
    font-family: sans-serif;
}

.contactSheets>div.selected {
    opacity: 1;
    pointer-events: all;
}

.contactSheets>div .inner {
    display: flex;
    justify-content: space-between;
    width: 100%;
}

.contactSheets>div .inner>div {
    width: 48%;
}

.contactSheets>div h1 {
    margin-bottom: 30px;
}

.contactSheets>div h1 span {
    font-family: Ballpen, sans-serif;
    line-height: 64px;
}

body.page-id-2871 .fullHeader a:nth-child(2)::after {
    opacity: 1;
}

body.page-id-2900 .fullHeader a:nth-child(3)::after {
    opacity: 1;
}

body.page-id-2909 .fullHeader a:nth-child(4)::after {
    opacity: 1;
}

body.page-id-2916 .fullHeader a:nth-child(5)::after {
    opacity: 1;
}

body.page-id-2966 .fullHeader a:nth-child(6)::after {
    opacity: 1;
}

body.page-id-2993 .fullHeader a:nth-child(7)::after {
    opacity: 1;
}

body.page-id-2951 .fullHeader a:nth-child(8)::after {
    opacity: 1;
}

body.page-id-2929 .fullHeader .contactus a::after {
    opacity: 1;
}

.pageHeader {
    width: 100%;
    text-align: center;
    min-height: 75vh;
    padding: 10vh 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    background-size: cover !important;
    background-position: 50% 50% !important;
    color: #F2D3BC;
}

.pageHeader>a:first-child {
    width: fit-content;
    margin-bottom: 50px;
}

.pageHeader a img {
    width: 200px;
    margin: 0 auto;
}

.pageHeader .title {
    width: 80%;
    margin: 20px 10%;
}

.pageHeader .buttons {
    width: 420px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.pageHeader .title.one h1 {
    font-size: clamp(90px, 8vw, 150px);
}

.pageHeader .title.two h1 {
    font-family: Ballpen, sans-serif;
    font-size: clamp(90px, 8vw, 150px);
    line-height: clamp(90px, 8vw, 150px);
}

.pageHeader .button {
    margin-top: 50px;
}

.pageHeader .button:hover {
    background: #ECC9AD;
    color: black;
    border-color: #ECC9AD;
}

.textArea {
    width: 100%;
    padding: 100px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

.textArea .inner {
    width: 30%;
    color: black;
    display: flex;
    flex-wrap: wrap;
    justify-content: end;
}

.textArea:not(.fullbg) .inner {
    background: url(/wp-content/uploads/2023/07/Mask-Group-47.png);
    background-size: 55%;
    background-position: 0 50%;
    background-repeat: no-repeat;
    padding: 100px 0;
}

.textArea.fullbg {
    background-size: 40% !important;
    background-position: -15% 0% !important;
    background-repeat: no-repeat !important;
    padding: 130px 0;
}

.textArea.fullbg.left {
    background-size: 300px !important;
    background-position: 0 100% !important;
}

.textArea.fullbg.contained {
    background-size: contain !important;
    background-position: 50% 50% !important;
}

.textArea.fullbg.rightBG {
    background-position: 100% 0% !important;
    background-size: 300px !important;
}

.textArea.fullbg .inner .bgtitle h1 {
    font-family: 'Ballpen', sans-serif;
    line-height: 55px;
    font-size: 90px;
    position: relative;
    z-index: 1;
}

.textArea.fullbg .inner .text {
    width: 100%;
}

.textArea .inner>h1 {
    width: 100%;
    position: relative;
    z-index: 2;
}

.textArea .bgtitle {
    position: relative;
    margin: 10px 0;
}

.textArea.rightslide .bgtitle {
    transition: all 1.3s ease-in-out, opacity 0.3s linear;
    left: 300px;
    opacity: 0;
}

.textArea.rightslide.visible .bgtitle {
    left: 0;
    opacity: 1;
}

.textArea.leftslide .bgtitle {
    position: relative;
    transition: all 1.3s ease-in-out;
    left: -300px;
    opacity: 0;
}

.textArea.leftslide.visible .bgtitle {
    left: 0;
    opacity: 1;
}

.textArea.doubleText {
    width: 80%;
    padding: 130px 10%;
    align-items: flex-start;
}

.textArea.doubleText h1 {
    margin-bottom: 15px;
}

.textArea.doubleText .imageText {
    width: 45%;
    margin-left: 5%;
}

.textArea.doubleText .inner {
    width: 45%;
}

.textArea.doubleText .imageText img {
    width: 100%;
    max-width: 500px;
    margin-bottom: 30px;
}

.textArea.doubleText img {
    width: 100%;
    max-width: 500px;
    margin: 0 auto 30px auto;
}

.textArea>img {
    width: 25%;
    margin-left: 10%;
    max-height: 70vh;
    object-fit: contain;
}

.textArea .inner>img {
    width: 100px;
    margin: 20px calc(100% - 100px) 20px 0;
}

.textArea .inner .text {
    width: 80%;
}

.textArea .inner .text a {
    color: inherit;
}

.textArea .inner .text p {
    margin-bottom: 5px;
}

.textArea.indentTitle .inner .text {
    width: 100%;
    margin-top: 30px;
}

.textArea.indentTitle .inner>h1 {
    width: 90%;
}

.textArea.indentTitle .inner>img {
    margin: 20px calc(90% - 100px) 20px 0;
}

.textArea:not(.fullbg) .inner .button {
    background: transparent;
    color: black;
    margin: 25px 0 0 0;
}

.textArea .inner .button,
.textArea.doubleText .button {
    background: transparent;
    margin: 25px 0 0 0;
}

.textArea .inner .button:hover {
    color: white;
    background-color: black;
    border-color: black;
}

.textArea.rotated {
    flex-direction: row-reverse;
}

.textArea.rotated .inner {
    margin-right: 0px;
    margin-left: 10%;
}

.textArea.rotated img {
    margin-left: 0px;
}

.image {
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    position: relative;
}

.image .rotatingText {
    position: absolute;
    bottom: 10%;
    width: 100%;
    height: 80px;
    color: #f2d3bc;
    white-space: nowrap;
}

.image .rotatingText .title {
    position: absolute;
    left: -100vw;
}

.image .rotatingText .title * {
    font-size: 70px;
}

.image .rotatingText .title:first-child {
    animation: slidingText 20s linear infinite 10s;
}

.image .rotatingText .title:last-child {
    animation: slidingText 20s linear infinite 0s;
}

@keyframes slidingText {
    0% {
        left: -100vw;
    }
    100% {
        left: 100vw;
    }
}

.aside {
    width: 15px;
    height: 15px;
    position: fixed;
    bottom: 0;
    left: 0;
}

.image img {
    width: 100%;
    object-fit: cover;
}

.image .inner {
    display: flex;
    width: 100%;
    position: relative;
}

.image div img {
    width: 100%;
    height: 90vh;
    max-width: 0px;
    overflow: hidden;
    transition: all 0.8s ease-in-out;
}

.image div img.selected {
    max-width: 100vw;
}

.image .buttons {
    display: flex;
    justify-content: center;
    width: 100%;
    position: absolute;
    bottom: 8%;
}

.image .buttons div {
    width: 15px;
    height: 15px;
    margin: 0 10px;
    cursor: pointer;
    border: 2px solid #F2D3BC;
    transition: all 0.1s linear;
    transform: rotate(45deg);
}

.image .buttons div.selected,
.image .buttons div:hover {
    background: #F2D3BC;
}

.keepUpdated {
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: stretch;
    position: relative;
}

.move body {
    width: 50vw;
    height: 50vh;
    overflow: scroll;
    display: block;
}

.keepUpdated>div {
    background: url(/wp-content/uploads/2023/07/Mask-Group-47.png);
    background-size: 40%;
    background-position: 0 15%;
    background-repeat: no-repeat;
    padding: 60px 0px 20px 0px;
    width: 40%;
    margin: 0 5%;
}

.keepUpdated div img {
    width: 100px;
    margin: 20px 0;
}

.keepUpdated img {
    width: 50%;
    object-fit: cover;
    max-height: unset;
}

.keepUpdated .inner {
    width: 85%;
    margin: 50px 0 100px 15%;
}

.keepUpdated .inner h1:nth-child(2) {
    margin-left: 55px;
}

.keepUpdated .form {
    width: 85%;
    max-width: 700px;
    margin: 0 0 45px 15%;
}

.keepUpdated .form .dropdownArea,
.booknow .dropdownArea {
    width: calc(100% - 60px);
    background: #f7e5d8;
    border: 0px;
    font-size: 17px;
    padding: 15px 30px;
    margin-bottom: 20px;
    color: black;
    font-family: Roboto-two, sans-serif;
    font-weight: 300;
    position: relative;
}

.keepUpdated .form .dropdownArea .dropped,
.booknow .dropdownArea .dropped {
    position: absolute;
    background: #f7e5d8;
    width: calc(100% - 60px);
    padding: 0px 30px;
    max-height: 0px;
    overflow: hidden;
    pointer-events: none;
    z-index: 2;
    left: 0;
    top: 100%;
    transition: all 0.5s ease-in-out;
    border: 0px;
}

.booknow .dropdownArea,
.booknow .dropdownArea .dropped {
    background: #f0fbf3;
}

.keepUpdated .form .dropdownArea .dropped .location,
.booknow .dropdownArea .dropped .location {
    margin: 5px 0;
    cursor: pointer;
    transition: all 0.1s linear;
}

.keepUpdated .form .dropdownArea #locationText,
.booknow .dropdownArea #locationText {
    cursor: pointer;
    position: relative;
}

.keepUpdated .form .dropdownArea #locationText::after,
.booknow .dropdownArea #locationText::after {
    content: "";
    top: calc(50% - 4px);
    position: absolute;
    margin-left: 6px;
    width: 8px;
    transform: rotate(45deg);
    transition: all 0.5s ease-in-out;
    height: 8px;
    border: 1px solid black;
}

.keepUpdated .form .dropdownArea.open #locationText::after,
.keepUpdated .form .dropdownArea:hover #locationText::after,
.booknow .dropdownArea.open #locationText::after,
.booknow .dropdownArea.hover #locationText::after {
    background: black;
}

.keepUpdated .form .dropdownArea .dropped .location:hover,
.booknow .dropdownArea .dropped .location:hover {
    font-weight: 400;
}

.keepUpdated .form .dropdownArea.open .dropped,
.booknow .dropdownArea.open .dropped {
    padding: 15px 30px;
    max-height: 100px;
    pointer-events: all;
    border: 1px solid black;
}

.keepUpdated .form#locationArea .wokingham,
.keepUpdated .form#locationArea .maidenhead {
    opacity: 0.5;
    pointer-events: none;
}

.keepUpdated .form#locationArea.wokingham .wokingham,
.keepUpdated .form#locationArea.maidenhead .maidenhead {
    opacity: 1;
    pointer-events: all;
}

.keepUpdated .form#locationArea.maidenhead .wokingham,
.keepUpdated .form#locationArea:not(.maidenhead) .maidenhead {
    display: none;
}

.keepUpdated .form input,
.keepUpdated .form textarea {
    width: calc(100% - 60px);
    background: #f7e5d8;
    border: 0px;
    font-size: 17px;
    padding: 15px 30px;
    margin-bottom: 20px;
    color: black;
    font-family: Roboto-two, sans-serif;
    font-weight: 300;
}

.keepUpdated .form textarea {
    resize: vertical;
    height: 100px;
    min-height: 100px;
}

.keepUpdated .form input[type="submit"] {
    width: fit-content;
    background: white;
    border: 2px solid black;
    padding: 7px 25px;
    margin-top: 30px;
    cursor: pointer;
    transition: all 0.1s linear;
    letter-spacing: 0px;
}

.keepUpdated .form span.wpcf7-form-control.wpcf7-acceptance>span {
    width: 100%;
    margin: 20px 0;
}

.keepUpdated .form span.wpcf7-form-control.wpcf7-acceptance label {
    display: flex;
    align-items: center;
}

.keepUpdated .form input[type="checkbox"] {
    -webkit-appearance: none;
    background: #F2D3BC;
    outline: none;
    cursor: pointer;
    width: 30px;
    height: 30px;
    padding: 0px;
    margin: 0 20px 0 0;
}

.keepUpdated .form .wpcf7 form.sent .wpcf7-response-output {
    border-color: #46b450;
    font-size: 20px;
    border: 0px;
    margin: 0;
    color: green;
    padding: 0;
}

.keepUpdated .form input[type="checkbox"]:checked {
    background: black;
}

.keepUpdated .form input[type="submit"]:hover {
    background: black;
    color: white;
}

.keepUpdated ::placeholder {
    color: black;
}

.menus {
    width: 80%;
    padding: 5% 10% 5% 10%;
    background-size: contain !important;
    background-position: 100% 0% !important;
    background-repeat: no-repeat !important;
}

.menus .inner {
    width: 100%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: flex-start;
}

.menus .menuTitle {
    width: 80%;
    margin: 0 auto;
    text-align: center;
}

.menus .single {
    width: 30%;
    margin: 30px 1%;
    text-align: center;
}

.menus .single img {
    width: 100%;
    height: 24vw;
    object-fit: cover;
    margin-bottom: 25px;
}

.menus .single a {
    margin-top: 25px;
    background: transparent;
}

.menus .single a:hover {
    color: white;
    background: black;
}

.menuText {
    width: 80%;
    margin: 50px auto 7% auto;
}

.events {
    width: 80%;
    margin: 5% auto;
}

.events>.inner {
    width: 100%;
    margin-bottom: 50px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.events .inner .single {
    width: 31%;
    margin: 30px 0%;
    max-width: 0px;
    overflow: hidden;
    text-align: center;
    transition: all 0.8s ease-in-out;
}

.events .inner .single.selected {
    max-width: 31%;
    margin: 30px 1%;
}

.events:not(.latestEvents) .inner .single>*:not(.button) {
    width: 23vw;
    margin: 0px auto 20px auto;
}

.events .inner .single a {
    color: black;
    background: white;
    min-width: 165px;
}

.events .inner .single a:hover {
    color: white;
    background: black;
}

.events.latestEvents .inner .single h3 {
    min-height: 150px;
    margin: 0 auto;
}

.events.latestEvents .inner .single h3 {
    min-height: 50px;
    font-size: 25px;
    line-height: 25px;
}

.events .inner .single img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    object-position: 50% 50%;
    margin: 20px 0;
}

.events.latestEvents .inner .single img {
    height: 250px;
}

.events .inner .single p {
    margin: 20px auto;
    max-height: 10px;
    overflow-y: scroll;
    transition: all 0.5s ease-in-out;
}

.events .inner .single p.date {
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.events .inner .single.selected p {
    max-height: 500px;
}

.events.latestEvents .inner .single p,
.events.latestEvents .inner .single h3 {
    width: 23vw;
}

.events .buttons {
    width: fit-content;
    margin: 0% auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

.events .buttons .inner {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 15px;
}

.events .buttons .inner div {
    width: 15px;
    height: 15px;
    transform: rotate(45deg);
    border: 2px solid black;
    margin: 0 15px;
    transition: all 0.2s linear;
    cursor: pointer;
}

.events .buttons .inner div:hover,
.events .buttons .inner div.selected {
    background: black;
}

.events .buttons .left {
    width: 25px;
    height: 25px;
    background: url(/wp-content/uploads/2023/09/Group-950@2x.png);
    background-size: contain;
    background-repeat: no-repeat;
    cursor: pointer;
}

.events .buttons .right {
    width: 25px;
    height: 25px;
    background: url(/wp-content/uploads/2023/09/Group-948@2x.png);
    background-size: contain;
    background-repeat: no-repeat;
    cursor: pointer;
}

.locations {
    width: 100%;
    min-height: 100vh;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    position: relative;
}

.locations .top {
    position: absolute;
    text-align: center;
    width: 80%;
    padding: 7% 10%;
    color: #ECC9AD;
    background: linear-gradient(#00000099, #0000008a, transparent);
}

.locations .top h1 {
    font-size: clamp(90px, 8vw, 150px);
}

.locations .top h2 {
    font-family: Ballpen, sans-serif;
    font-size: clamp(90px, 8vw, 150px);
    line-height: clamp(90px, 8vw, 150px);
    margin-top: 15px;
}

.locations .left,
.locations .right {
    width: 40%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 25vh 5%;
    text-align: center;
    background-size: cover !important;
    background-position: 0% 50% !important;
}

.locations a {
    background: #A84628;
    border-color: #A84628;
    color: #F2D3BC;
}

.locations a:hover {
    color: #A84628;
    background: #F2D3BC;
    border-color: #F2D3BC;
}

.locations .bottom {
    position: absolute;
    bottom: 0;
    width: 2px;
    left: calc(50% - 1px);
}

.locations .bottom img {
    width: 200px;
    position: relative;
    left: -100px;
    bottom: -3px;
}

.locations .bottom .line {
    height: 100px;
    width: 2px;
    background: #ECC9AD;
}

.footer {
    width: 80%;
    padding: 50px 10%;
    background: #565336;
    color: #f2d3bc;
}

.footer>a {
    display: block;
    width: 200px;
    max-width: 100%;
    margin: 0 auto;
    text-align: center;
}

.footer>a img {
    width: 100%;
}

.footer .links {
    width: 100%;
    margin: 50px auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.footer .links a {
    padding: 0 5px;
}

.footer .socials {
    width: 300px;
    max-width: 100%;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
}

.footer .socials a {
    padding: 0 10px;
}

.footer .socials img {
    width: 50px;
}

.footer a {
    color: #ECC9AD;
    text-decoration: none;
}

.footer a:hover {
    text-decoration: underline;
}

.footer .double {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    margin: 50px auto;
}

.footer .double div {
    width: 48%;
    margin: 10px 0;
    text-align: center;
}

.laserFooter {
    width: 90%;
    padding: 10px 5%;
    background: black;
    color: white;
    text-align: center;
}

.laserFooter a {
    color: white;
    text-decoration: none;
}

.gallery {
    width: 80%;
    margin: 50px auto;
}

.gallery .intro {
    margin: 50px auto;
    display: flex;
    justify-content: center;
}

.gallery .intro a {
    color: black;
    text-decoration: none;
    margin: 0 30px;
    cursor: pointer;
}

.gallery .intro a:hover {
    text-decoration: underline;
}

.gallery .videos {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding-top: 50px;
    border-top: 1px solid black;
    margin-top: 50px;
}

.gallery .videos video {
    width: 48%;
    height: 30vw;
    margin: 0 1% 20px 1%;
    transition: all 0.8s ease-in-out;
    cursor: pointer;
    object-fit: contain;
}

.gallery .videos video.selected {
    width: 100%;
    height: 90vh;
    margin: 30px 0;
}

.gallery .images {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.gallery .images img {
    width: calc(25% - 4px);
    border: 2px solid white;
    height: 18vw;
    object-fit: cover;
    object-position: 50% 50%;
    transition: all 0.2s linear;
    cursor: pointer;
}

.gallery .images img:hover {
    transform: scale(1.05);
}

.gallery .imagepopups {
    position: fixed;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    top: 0;
    left: 0;
    pointer-events: none;
    opacity: 0;
    transition: all 0.5s linear;
}

.gallery .imagepopups.open {
    opacity: 1;
    pointer-events: all;
}

.gallery .imagepopups .close {
    width: 100vw;
    height: 100vh;
    z-index: 2;
    position: relative;
    background: #00000061;
}

.gallery .imagepopups .inner {
    z-index: 3;
    position: absolute;
    width: 80vw;
    height: calc(80vh - 100px);
    top: calc(10vh + 100px);
    left: 10vw;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.gallery .imagepopups .inner .left,
.gallery .imagepopups .inner .right {
    width: 50px;
    height: 50px;
    cursor: pointer;
    font-size: 150px;
    line-height: 57px;
    font-family: 'Runalto';
    font-weight: bold;
    color: white;
}

.gallery .imagepopups .inner .focus {
    width: calc(100% - 150px);
    height: calc(80vh - 100px);
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
}

.gallery .imagepopups .inner .focus img {
    position: absolute;
    opacity: 0;
    width: 100%;
    object-position: 50% 50%;
    object-fit: contain;
    max-height: calc(80vh - 100px);
    transition: all 0.2s linear;
}

.gallery .imagepopups .inner .focus img.selected {
    opacity: 1;
}

.latestEvents {
    width: 80%;
    margin: 100px auto;
}

.latestEvents .inner {
    margin: 20px 0;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
}

.latestEvents .inner .left,
.latestEvents .inner .right {
    width: 50px;
    height: 50px;
    background: red;
}

.latestEvents .inner .events {
    width: calc(100% - 150px);
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
}

.latestEvents .inner.less .events {
    width: 100%;
}

.latestEvents .inner.less .left,
.latestEvents .inner.less .right {
    display: none;
}

.latestEvents .inner .events .single {
    width: 30%;
    margin: 0 1%;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    align-content: space-between;
}

.latestEvents .inner .events .single>div {
    width: 100%;
}

.latestEvents .inner .events .single img {
    width: 100%;
    margin: 20px 0;
    object-fit: cover;
    height: 30vh;
}

.events.latestEvents h1 {
    margin-bottom: 10px;
    text-align: center;
}

.events.latestEvents p {
    text-align: center;
}

.latestEvents .inner .single .date {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}

.latestEvents .inner .single .date p:first-child {
    width: fit-content;
    color: #b04123;
    font-weight: bold;
    max-height: unset;
    margin: unset;
    display: none;
}

.latestEvents .inner .single .date p:nth-child(2) {
    width: fit-content;
    margin: 20px 0 20px 20px;
}

.latestEvents .inner .single .date a {
    display: block;
    margin: 25px auto;
    background: transparent;
    width: fit-content;
    min-width: unset;
}

.latestEvents .inner .single .date a:hover {
    background: black;
    color: white;
}

.booknow {
    width: 80%;
    padding: 100px 10%;
    text-align: center;
}

.booknow .inner {
    width: 400px;
    max-width: 100%;
    margin: 50px auto;
    position: relative;
}

.booknow .inner>a {
    position: absolute;
}

.booknow .bookingAreas .inner>div {
    width: 100%;
    transition: all 0.8s ease-in-out;
    max-height: 0px;
    overflow: hidden;
}

.booknow .inner.wokingham .wokingham,
.booknow .inner.maidenhead .maidenhead {
    max-height: 600px;
}

.booknow>p {
    max-width: 800px;
    margin: 0 auto;
}

.mobileHeader {
    position: fixed;
    top: 100px;
    right: -100vw;
    width: 300px;
    max-width: calc(100% - 100px);
    background: white;
    padding: 20px 50px;
    transition: all 0.8s ease-in-out;
    z-index: 10;
}

.mobileHeader a {
    display: block;
    color: black;
    text-decoration: none;
    margin: 10px 0;
}

.mobileHeader a:hover {
    text-decoration: underline;
}

.mobileHeader.headOpened {
    right: 0px;
}

.booknow .inner .ot-dtp-picker.tall {
    width: calc(100% - 32px);
}

.booknow .inner .picker--opened .picker__holder {
    width: 90% !important;
    max-height: 225px !important;
}

.popup#outerpopup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 5;
    opacity: 0;
    pointer-events: none;
    transition: all 0.8s ease-in-out;
    display: flex;
    justify-content: center;
    align-items: center;
}

.popup#outerpopup.open {
    opacity: 1;
    pointer-events: all;
}

.popup#outerpopup .outer {
    width: 100vw;
    height: 100vh;
    position: absolute;
    z-index: 3;
    background: #00000024;
}

.popup#outerpopup .display {
    width: 100%;
    margin-top: 20px;
    display: flex;
    justify-content: center;
}

.popup#outerpopup .display .single {
    width: 31%;
    margin: 0 1%;
    text-align: center;
}

.popup#outerpopup .display .single p {
    font-size: 16px;
}

.popup#outerpopup .display .single img {
    width: 100%;
    height: 240px;
    object-fit: cover;
    margin: 10px 0 20px 0;
}

.popup#outerpopup .display .single p:first-child {
    font-family: Runalto, sans-serif;
    font-size: 20px;
    min-height: 50px;
}

.popup#outerpopup .inner {
    position: absolute;
    width: 800px;
    padding: 30px;
    z-index: 5;
    background: white;
    text-align: center;
    box-shadow: 3px 3px 12px 5px #00000061;
}

.popup#outerpopup .inner .x {
    position: absolute;
    top: 5px;
    right: 7px;
    font-size: 50px;
    font-family: monospace;
    cursor: pointer;
    padding: 10px 20px;
}

.popup#outerpopup .inner>h1 {
    font-size: 50px;
    line-height: 55px;
}

.popup#outerpopup .inner>img {
    width: 60px;
    margin: 5px auto 30px auto;
}

.popup#outerpopup .inner .button {
    background: transparent;
}

.miniGallery {
    width: 95%;
    margin: 50px auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.miniGallery .inner {
    width: calc(100% - 100px);
    display: flex;
    align-items: stretch;
    position: relative;
    justify-content: center;
}

.miniGallery .inner .single {
    width: 22%;
    height: 20vw;
    max-width: 0px;
    overflow: hidden;
    transition: all 0.4s ease-in-out;
}

.miniGallery .inner .single img {
    width: 20vw;
    height: 20vw;
    object-fit: cover;
    object-position: 50% 50%;
}

.miniGallery .inner .single.selected {
    max-width: 22%;
    position: relative;
    margin: 0 1%;
}

.miniGallery .controls {
    width: 35px;
    height: 50px;
    cursor: pointer;
    font-size: 150px;
    line-height: 57px;
    font-family: 'Runalto';
    font-weight: bold;
    color: black;
    user-select: none;
}

.popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: all 0.8s ease-in-out;
    opacity: 0;
    pointer-events: none;
}

.popup.open {
    opacity: 1;
    pointer-events: all;
}

.popup .outerclose {
    position: absolute;
    width: 100vw;
    height: 100vh;
    background: #00000052;
    cursor: pointer;
}

.popup a.button {
    background: inherit !important;
}

.popup a.button:hover {
    background: #e8d1c1 !important;
    color: #5d2c4e !important;
}

.popup .inner {
    width: 90%;
    max-width: 1000px;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    position: relative;
}

.popup .inner .content {
    background-size: 150px !important;
    background-repeat: no-repeat !important;
    background-position: 100% 0% !important;
    color: #e8d1c1;
    background-color: #5d2c4e;
    width: calc(50% - 60px);
    padding: 40px 30px;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}

.popup .inner .content>* {
    width: 100%;
}

.popup .inner .close,
.popup .innertwo .close {
    position: absolute;
    z-index: 10;
    top: 0;
    right: 0;
    font-size: 0px;
    cursor: pointer;
    width: 30px;
    height: 30px;
    background: url(/wp-content/uploads/2024/12/Group-1344@2x.png);
    background-size: 30px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    padding: 20px;
}

.popup .inner>img {
    width: 50%;
    object-fit: cover;
}

.popup .innertwo {
    width: 90%;
    max-width: 1000px;
    position: relative;
    background: #5D2C4E;
    color: #E8D1C1;
    text-align: center;
    max-height: 80vh;
    overflow-y: scroll;
}

.popup .innertwo .content {
    width: 80%;
    padding: 60px 10%;
    background: url(/wp-content/uploads/2024/12/Sparkle.png);
    background-size: 150px;
    background-repeat: no-repeat;
    background-position: 100% 12%;
    position: relative;
}

.popup .innertwo .content::after {
    content: "";
    width: 150px;
    background: url(/wp-content/uploads/2024/12/Sparkle-1.png);
    position: absolute;
    bottom: 0;
    left: 0;
    height: 150px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    pointer-events: none;
}

.popup .innertwo>img {
    width: 100%;
    object-fit: cover;
    height: 350px;
}

.popup .innertwo .buttons {
    width: calc(100% - 40px);
    display: flex;
    justify-content: center;
    position: relative;
    padding: 40px 20px;
    background: url(/wp-content/uploads/2024/12/Sparkle-1.png);
    background-repeat: no-repeat;
    background-size: 150px;
    background-position: -7% 100%;
}

.popup .innertwo .buttons>img {
    width: 200px;
    position: absolute;
    bottom: 80%;
    right: 0;
}

.popup .innertwo .buttons>div {
    width: calc(48% - 2px);
    max-width: 400px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.popup .innertwo .buttons>div h3 {
    width: 100%;
    margin-bottom: 10px;
}

.popup .innertwo .buttons>div a.button {
    width: 39%;
    margin: 0 1%;
}

.popup .innertwo .buttons>div.seperate {
    width: 1px;
    margin: 0 2%;
    background: #e8d1c1;
}

.textArea.newyears {
    background: url(/wp-content/uploads/2024/12/Sparkle-1-1.png);
    background-size: 200px;
    background-repeat: no-repeat;
    background-position: 0 0;
    background-color: #5D2C4E;
    padding: 0px;
    justify-content: flex-end;
}

.textArea.newyears li {
    padding: 2px 0;
}

.textArea.newyears .inner {
    width: 40%;
    padding: 50px 5%;
    background: none;
    color: #ECC9AC;
    max-width: 600px;
}

.textArea.newyears>img {
    width: 50%;
    object-fit: cover;
    margin-left: 0;
}

.textArea.newyears .inner .text {
    width: 100%;
}

.textArea.newyears .inner .text .newButtons {
    width: 100%;
    margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: 1px solid #ecc9ac;
}

.textArea.newyears .inner .text .newButtons:last-child,
.textArea.newyears .inner .text .newButtons:nth-child(8) {
    border-bottom: 0px;
    margin-bottom: 0px;
}

.textArea.newyears .inner .text .newButtons>div .double {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: flex-start;
}

.textArea.newyears .inner .text .newButtons>div h3 {
    font-size: 30px;
    line-height: 35px;
}

.textArea.newyears .inner .text .newButtons>div .double a.button {
    color: #ecc9ac;
    margin-right: 20px;
}

.textArea.newyears .inner .text .newButtons>div .double a.button:hover {
    background: #ecc9ac;
    color: #5d2c4e;
    border-color: #5d2c4e;
}

.textArea.newyears .inner>h1::after {
    content: "";
    display: block;
    width: 60px;
    height: 20px;
    background: url(/wp-content/uploads/2024/12/Group-1534@2x.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    margin: 5px 0 20px 0;
}

.popup .innertwo .content>h3::after {
    content: "";
    display: block;
    width: 60px;
    height: 20px;
    background: url(/wp-content/uploads/2024/12/Group-1534@2x.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    margin: 5px auto 10px auto;
}

.footer .double div a.button {
    margin-top: 10px;
    background: none;
    font-size: 17px;
    padding: 5px 10px;
}

.footer .double div a.button:hover {
    text-decoration: none;
    background: #ECC9AD;
    color: #565336;
}

@media(max-height: 1100px) {
    .textArea.newyears>img {
        max-height: unset;
    }
}

@media(max-width: 1400px) {
    .popup#outerpopup .inner {
        width: 80%;
        left: calc(10% - 30px);
    }
    .fullHeader .inner {
        width: 100%;
    }
    .fullHeader a {
        font-size: 0.9vw;
    }
    /* ^ need a proper mobile header still */
}

@media(max-width: 1250px) {
    .latestEvents .inner .single .date p:nth-child(2) {
        width: 100%;
        margin: 20px 0;
    }
    .textArea .inner {
        width: 45%;
    }
    .textArea>img {
        margin-left: 3%;
    }
    .image div img {
        height: 75vh;
    }
    .textArea.rotated .inner {
        margin-left: 3%;
    }
    .keepUpdated .inner h1:nth-child(2) {
        margin-left: 10px;
    }
    .events .inner .single {
        width: 48%;
    }
    .events:not(.latestEvents) .inner .single>*:not(.button) {
        width: 37vw;
    }
    .events .inner .single.selected {
        max-width: 48%;
    }
    .events.latestEvents .inner .single p,
    .events.latestEvents .inner .single h3 {
        width: 100%;
    }
    .events .inner .single p,
    .events .inner .single h3 {
        width: 37vw;
    }
    .events>.inner {
        flex-wrap: wrap;
    }
}

@media(max-width: 1000px) {
    .textArea.newyears {
        flex-wrap: wrap;
    }
    .textArea.newyears .inner {
        width: 90%;
        padding: 50px 5%;
        max-width: unset;
    }
    .textArea.newyears>img {
        width: 100%;
    }
    .popup .inner .content {
        width: calc(100% - 60px);
        max-height: 40vh;
        overflow-y: scroll;
    }
    .popup .inner>img {
        width: 100%;
        max-height: 40vh;
        object-position: 100% 0%;
    }
    .popup .inner {
        flex-wrap: wrap;
    }
    .textArea.doubleText .inner {
        width: 100%;
    }
    .footer .double {
        flex-wrap: wrap;
    }
    .footer .double div {
        width: 100%;
        margin: 20px auto;
    }
    .textArea.doubleText .imageText img {
        width: 90%;
        margin: 20px auto;
        max-width: 350px;
    }
    .textArea.doubleText .imageText {
        width: 90%;
        margin: 0 auto;
    }
    .menus .single {
        width: 48%;
    }
    .menus .single img {
        width: 38vw;
        height: 38vw;
    }
    .fullHeader .dropper {
        display: block;
    }
    .fullHeader .inner a:not(.logo) {
        display: none;
    }
    .latestEvents .inner .events {
        flex-wrap: wrap;
    }
    .latestEvents .inner .events .single {
        width: 100%;
        margin-bottom: 50px;
    }
    .latestEvents .inner .events .single img {
        height: 50vw;
    }
    .textArea,
    .keepUpdated {
        flex-wrap: wrap;
    }
    .textArea .inner,
    .keepUpdated>div {
        width: 80%;
        margin: 0 auto;
        padding: 100px 0;
    }
    .textArea>img,
    .keepUpdated>img {
        width: 80%;
        margin: 0 auto !important;
        max-height: 40vh;
        object-fit: cover;
        object-position: 50% 50%;
    }
}

@media(max-width: 700px) {
    .textArea.newyears .mobSwitch {
        flex-wrap: wrap;
    }
    .textArea.newyears .mobSwitch>div {
        width: 100% !important;
    }
    .textArea.newyears {
        background-image: none;
    }
    .textArea.newyears h1 br {
        display: none;
    }
    .popup .innertwo .content br {
        display: none;
    }
    .popup .innertwo .buttons>div a.button {
        margin: 5px 1%;
    }
    .popup .innertwo .content {
        background: none;
    }
    .popup .innertwo .content::after {
        display: none;
    }
    .popup .innertwo .buttons>div:first-child {
        margin-bottom: 30px;
    }
    .popup .innertwo .buttons {
        background: none;
        flex-wrap: wrap;
    }
    .popup .innertwo .buttons>div.seperate {
        display: none;
    }
    .popup .innertwo .buttons>div {
        width: 100%;
    }
    .popup .innertwo .buttons>img {
        bottom: 90%;
    }
    .miniGallery {
        display: none;
    }
    .textArea.fullbg {
        padding: 45px 0;
    }
    .textArea.doubleText {
        padding: 130px 5%;
        width: 90%;
    }
    .image .rotatingText .title * {
        font-size: 35px;
    }
    .image .rotatingText {
        bottom: 0px;
    }
    .footer .links {
        justify-content: center;
    }
    .footer .links a {
        display: block;
        width: 100%;
        text-align: center;
    }
    .gallery .images img {
        width: calc(49% - 4px);
        height: 35vh;
    }
    .popup#outerpopup .display {
        flex-wrap: wrap;
    }
    .popup#outerpopup .display .single {
        width: 100%;
        margin-bottom: 25px;
        border-bottom: 1px solid black;
        padding-bottom: 25px;
    }
    .popup#outerpopup .display .single:last-child {
        margin-bottom: 0px;
        border-bottom: 0px;
        padding-bottom: 0px;
    }
    .popup#outerpopup .display .single p:first-child {
        min-height: unset;
    }
    .popup#outerpopup {
        align-items: flex-start;
    }
    .popup#outerpopup .inner {
        height: 80vh;
        overflow-y: scroll;
    }
    .popup#outerpopup {
        height: calc(100vh - 120px);
        top: 120px;
    }
}

@media(max-width: 500px) {
    .popup .inner .content {
        background-image: none !important;
    }
    .popup#outerpopup .inner>h1 {
        font-size: 35px;
        line-height: 40px;
    }
    .popup#outerpopup .inner .x {
        font-size: 30px;
    }
    .popup#outerpopup .inner>img {
        width: 40px;
        margin: 0 auto 20px auto;
    }
    .popup#outerpopup .display .single {
        width: 100%;
    }
    .popup#outerpopup .display .single img {
        max-height: 25vh;
    }
    .gallery .images img {
        width: 100%;
        height: 20vh;
    }
    .events .inner .single h3 {
        min-height: unset;
    }
    .events .inner .single {
        width: 100%;
        height: 0px;
        margin: 0px;
    }
    .events .inner .single.selected {
        max-width: 100%;
        height: auto;
        margin: 30px 0;
    }
    .events:not(.latestEvents) .inner .single>*:not(.button) {
        width: 76vw;
    }
    .events .inner .single p,
    .events .inner .single h3 {
        width: 74vw;
    }
    .pageHeader .title.one h1,
    .pageHeader .title.two h1 {
        font-size: 50px;
        line-height: 55px;
    }
    .menus .single {
        width: 100%;
    }
    .menus .single img {
        width: 75vw;
        height: 75vw;
    }
    .image .rotatingText {
        display: none;
    }
    .title *,
    h1,
    h2 {
        font-size: 50px;
    }
}