<style> 
    /* Loading Icon */
    
    .no-js #loader { display: none;  }
.js #loader { display: block; position: absolute; left: 100px; top: 0; }
.se-pre-con {
	position: fixed;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	z-index: 99999;
	background: url(https://www.hopcraft.eighty3dev.co.uk/wp-content/uploads/2023/04/Hopcraft-ALT.gif) center no-repeat #454955;
}
    
    /*Main Styles */
    
    body {
        background-color: #f3eff5;
        font-family: 'Questrial', sans-serif;;
    }

    /* Typography */
    h1 {
        font-size:50px;
        font-family: 'Quattrocento', serif;;
    }
    h2 {
        font-size:30px;
        font-family: 'Quattrocento', serif;;
    }
    h3 {
        font-size:25px;
        font-family: 'Quattrocento', serif;;
    }
    h4 {
        font-size:25px;
        font-family: 'Questrial', sans-serif;;
    }
    h5 {
        font-size:20px;
        font-family: 'Questrial', sans-serif;;
    }
    h6 {
        font-size:18px;
        font-family: 'Questrial', sans-serif;;
    }
    p {
        font-size:16px;
        font-family: 'Questrial', sans-serif;;
    }
    .heading {
        color: ;
    }
    .heading.sub {
        color: #454955 !important;
    }
    
    .left {
        text-align: left;
    }
    
    .right {
        text-align: right;
    }
    
    .center {
        text-align: center;
    }
    
    /* Buttons */
    
    .button_1 {
        background-color: #ffcb47;
        color: #ffffff;
        border: 1px solid #ffcb47;
        border-radius: 0px !important;
        text-align: center;
        padding: 10px 50px !important;
        line-height: inherit !important;
    }
    
    .button_1:hover {
        background-color: #454955;
        color: #ffcb47;
        border: 1px solid #ffcb47;
        border-radius: 0px !important;
        text-decoration: none !important;
    }
    
    .button_2 {
        background-color: ;
        color: ;
        border: px solid ;
        border-radius: px !important;
        text-align: center;
        padding: px px !important;
        line-height: inherit !important;
    }
    
    .button_2:hover {
        background-color: ;
        color: ;
        border: px solid ;
        border-radius: px;
        text-decoration: none !important;
    }
    
    .button_3 {
        background-color: ;
        color: ;
        border: px solid ;
        border-radius: px !important;
        text-align: center;
        padding: px px !important;
        line-height: inherit !important;
    }
    
    .button_3:hover {
        background-color: ;
        color: ;
        border: px solid ;
        border-radius: px;
        text-decoration: none !important;
    }
    
    /* Navigation */
    
    body:not(.theme-preset-active) #masthead .navbar-nav > li > a {
    color: #f3eff5 !important;
    padding: 0.5rem;
    font-weight: 500;
    font-size: 1rem;
}
    
    body(.theme-preset-active) #masthead .navbar-nav > li > a {
    color: #cdbfe3;
    padding: 0.5rem;
    font-weight: 500;
    font-size: 1rem;
}
    
    body #masthead .navbar-nav > li > a:hover {
    color: #ffffff !important;
    padding: 0.5rem;
    font-weight: 500;
    font-size: 1rem;
}

    /* Colours */
    .col-primary {        
        color: #454955;    
    }
    .col-secondary {
        color: #ffcb47;
    }
    .white {
        color: white;
    }

    /* Background */
    .bg-color {
        background-color: #f3eff5;
    }

    .bg-image {
        background-image: url();
    }

    /* Header Styling */
    .header {
        font-family: ;
        font-size:px;
        color:  !important;
    }

    /* Branding */
    .brand-primary {
        background-color: #454955;
    }

    .brand-secondary {
        background-color: #ffcb47;
    }

    .brand-logo.large {
        width: 300px;
        height: 300px;
    }

    /* Optional CSS */
    .e3-btn-sml {
        border: 2px solid white;
        width: 175px;
    }
    .e3-btn:hover {
        background-color: #ffcb47;
        color: white;
        font-weight: bold;
    }
    

    .e3-txtbox {
        background-color: #ffcb47;
        border-radius: 50px 20px;
        padding-left: 25px;
        padding-right: 25px;
        padding-top: 5px;
        padding-bottom: 5px;
        color: white;
    }

    .e3-txtbox.outline {
        background-color: #f3eff5;
        border: 2px solid #454955;
        border-radius: 20px 50px;
        padding-left: 25px;
        padding-right: 25px;
        padding-top: 5px;
        color: black;
    }

    .e3-rounded {
        border-radius: 25px !important;
    }

    .txt-center {
        text-align: center;
    }

    .txt-left {
        text-align: left;
    }

    .txt-right {
        text-align: right;
    }

    .bx-lg {
        width: 100%;
        height: 300px;
    }

    .bx-md {
        width: 100%;
        height: 200px;
    }

    .bx-sm {
        width: 100%;
        height: 100px;
    }
    
/* Footer Styling */
    #footer-widget a.nav-link {
    color: #f3eff5;
    background-color: rgba(0,0,0,0) !important;
        font-size: 1rem;
        line-height: 1.5rem;
}
    
        #footer-widget a.nav-link:hover {
    color: #ffffff;
    background-color: rgba(0,0,0,0) !important;
       font-size: 1rem;
        line-height: 1.5rem;
}
    
/* Copyright Link */
    .credits {
        font-family: 'Source Sans Pro', sans-serif;
        font-weight: 600;
        text-transform: uppercase;
    }
    
/* Masonry Row */
    /* basic styling */
.masonry-container {
	max-width: 1280px;
	margin: auto;
	padding: 1rem;
}

.masonry-item {
	border: 0px solid #ccc;
}
    
    .masonry-item:hover {
	opacity: 0.7;
}

.masonry-item > p {
	font-size: 14px;
	padding: 0.5rem;
	margin: 0;
}

.masonry-item > img {
	width: 100%;
	height: auto;
}

/* masonry styles */
.masonry-container {
	--masonry-columns: 2;
	--masonry-gap: 1rem;
}

@media (min-width: 768px) {
	.masonry-container {
		--masonry-columns: 3;
		--masonry-gap: 1rem;
	}
}

@media (min-width: 1024px) {
	.masonry-container {
		--masonry-columns: 3;
		--masonry-gap: 2rem;
	}
}

/* load only if grid-template-rows: masonry is supported by the browser else use the fallback */
@supports (grid-template-rows: masonry) {
	.masonry-container {
		display: grid;
		grid-template-columns: repeat(var(--masonry-columns), 1fr);
		grid-gap: var(--masonry-gap);
		grid-template-rows: masonry;
	}

	.masonry-container > * {
		margin-bottom: 0;
	}
}

/* fallback */
.masonry-container {
	column-count: var(--masonry-columns);
	column-gap: var(--masonry-gap);
}

.masonry-container > * {
	margin-bottom: var(--masonry-gap);
	break-inside: avoid;
}


</style>