/*
Theme Name: Toast
Description: Lightweight, tasty and totally awesome. This theme is proprietary and licensed exclusively to the client who commissioned this website project. Usage, modification, distribution or deployment of this theme on any other website or project is strictly prohibited without express written permission from Toast Design.
Author: Dave Foreman, Aaron Jones and the Toast team
Date: October 2025
Version: 17.1
Theme URI: http://www.toastwebsites.co.uk
Author URI: http://www.toastdesign.co.uk
Text Domain: toast
*/


/*

████████╗  ██████╗   █████╗  ███████╗ ████████╗
╚══██╔══╝ ██╔═══██╗ ██╔══██╗ ██╔════╝ ╚══██╔══╝
   ██║    ██║   ██║ ███████║ ███████╗    ██║   
   ██║    ██║   ██║ ██╔══██║ ╚════██║    ██║   
   ██║    ╚██████╔╝ ██║  ██║ ███████║    ██║   
   ╚═╝     ╚═════╝  ╚═╝  ╚═╝ ╚══════╝    ╚═╝   

This is the Toast WordPress theme. Copyright Toast Design Consultancy. All rights reserved. 
Toast clients who have paid us to build a theme have a perpetual lience to use this Theme for their site.
Everyone else can go build their own. Unlike WordPress, this theme is NOT licenced under the GPL, it is not publically distributed: do not copy, distribute or fork this theme.
However, if you've just inherited this site, and you know what you are doing, you will find this theme very easy to use - have at it, but do not change the Theme information.

*/


@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-plus-jakarta-sans-v11-latin-400-normal-1759500381.woff2') format("woff2");
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-plus-jakarta-sans-v11-latin-800-normal-1759500382.woff2') format("woff2");
}

@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-plus-jakarta-sans-v11-latin-400-italic-1759500382.woff2') format("woff2");
}

:root {
  --ywf--family-plus-jakarta-sans: 'Plus Jakarta Sans';
}



/**Saved Styles**/
/* *:last-child{margin-bottom:0; } Should not use CSS wildcards as they are S L O W */
.site-logo img{width:100%;}

/* Base Styles */
html { font-size: 62.5%; }
body{ font-size: 1.65rem /* fallback for IE */; font-size: clamp(1.5rem, 1.65rem, 2.5vw);line-height: clamp(1.1, 1.6, 1.6);  font-family: 'Inter', sans-serif; color: var(--text-color);margin: 0;padding: 0 !important; }
#page{/*overflow:hidden;*/clear:both;}

/* Site Banner - from Theme options */
.site-banner { background-color: var(--brand-2); color: #fff; text-align: center; padding: 1rem 0; min-height: 3rem; z-index: 999; }
.site-banner p { margin-bottom: 0; }
.site-banner p a { color: #fff; text-decoration: underline; }
.site-banner p a:hover { color: #fff; text-decoration: none; }

/* Header */
.site-header .grid{grid-template-columns:16rem 1fr 16rem;align-items:center;}
.site-header .container { width: 85%; max-width: 85%; }

/* Navbar & Menus */
.top-nav {text-align: center;}
.top-nav ul { margin: 0 auto; padding: 0;}
.top-nav li { display: inline-block; margin: 0;padding:0; position: relative;}
.top-nav li a { display: inline-block; padding: 6rem 2rem; line-height: 1; color: var(--brand-3); font-weight: bold; font-size: 1.75rem;}
.top-nav li:hover > a, .top-nav li.current-menu-item a { color:var(--brand-1); }

.top-nav li:first-of-type a { padding-left: 0; }
.top-nav li:last-of-type a { padding-right: 0; }

/* Submenus Dropdowns*/
.top-nav .sub-menu{ position: absolute;padding: 0;bottom:0;left: 0; white-space: nowrap; background: var(--brand-2);text-align: left;z-index:5;opacity:0;pointer-events:none;transition:all .5s;transform:translatey(100%);}
.top-nav .sub-menu .sub-menu{position: absolute;top:0;right:0;transform:translatex(100%);white-space:nowrap;background: var(--brand-2); text-align: left; z-index:10; }
.top-nav .sub-menu li{ display: block; margin: 0; }
.top-nav .sub-menu li a{ padding: 1rem; display: block; margin: 0;color:#ffffff;}
.top-nav li:hover > .sub-menu{opacity: 1;pointer-events:all;}

/* Sort the hovers on the dropdowns 16/06/23 DF */
.top-nav li ul.sub-menu li  a { background: var(--brand-2); color:#fff;}
.top-nav li ul.sub-menu li  a:hover { background: var(--brand-1); color:#fff;}

/* Sorts any drop down on the last menu li so the dropdown is ranged to the left, keeping it inside the menu container */
.top-nav li:last-child .sub-menu {left: auto; right: 0;}

/* Videos - uploaded mp4 files */
.wp-video { position: relative; width: 100% !important; /* Override inline width */ padding-bottom: 56.25%; /* 16:9 aspect ratio */ height: 0; overflow: hidden;}
.wp-video video, .wp-video .mejs-container { position: absolute; top: 0; left: 0; width: 100% !important; /* Override inline width */ height: 100% !important; /* Maintain correct height */}
.mejs-container { max-width: 100% !important; /* Ensure the player doesn't exceed its container */ }

/**Blog**/
.blog-grid{grid-template-columns:1fr 350px;}
.single .container .container { max-width: 100%; width: 100%; } /* Fixes the content in content issue on blogs */


/* Post Sidebar */
.sidebar ul { padding: 0; margin: 0; list-style: none; }
.sidebar ul li { padding: 0; margin: 0;  }
.sidebar ul li a { display: block; padding: .5rem 0; border-bottom: 1px solid var(--brand-2); color: var(--brand-1); }
.sidebar ul li a:hover { color: var(--brand-2); }

/*404*/
.search-404{padding: calc( var(--base-type-spacing) / 1.2 );background:var(--brand-2);color:#ffffff;max-width:768px;margin:0 auto;text-align:center;}

/*Footer*/
.site-footer .footer-logo{margin-bottom: calc( var(--base-type-spacing) / 3 );display:inline-block;max-width:20rem;}
.site-footer .footer-main{padding: 8rem 0 4rem; font-size: 1.8rem;}
.site-footer .footer-main .grid{grid-template-columns:1fr 1fr; grid-gap: 12rem;}
.site-footer .social-icons{margin-top:calc( var(--base-type-spacing) / 3 );}

.site-footer .footer-main .footer-widget-title { font-size: 2.25rem; margin-bottom: calc( var(--base-type-spacing) / 3 );}
.site-footer .footer-main ul { padding: 0; margin: 0; list-style: none; display: flex; gap: 2rem; flex-wrap: wrap;}
.site-footer .footer-main ul li { margin: 0; padding: 0; }
.site-footer .footer-main ul li a{font-weight: bold;}

.site-footer .footer-main .menu-wrapper{display: flex; gap: 2rem; align-items: end; flex-wrap: wrap;}

.site-footer .footer-main .instagram{background-color: var(--brand-3); border-radius: 5px; display: flex; align-items: center; justify-content: center; width: 33px; height: 33px; padding: 5px;}
.site-footer .footer-main .instagram img{width: 100%; height: 100%; object-fit: contain;}

/* Sub footer */
.site-footer .footer-sub-wrapper{font-size:1.35rem;}
.site-footer .footer-sub-wrapper .container{padding: 2rem 0 5rem; border-top: 1px solid var(--brand-3);}
.site-footer .footer-sub-wrapper .grid{grid-template-columns:1fr 1fr;align-items:center;}
.site-footer .footer-sub-wrapper .copyright{text-align: right;}
.site-footer .footer-sub-wrapper ul { padding: 0; margin: 0; }
.site-footer .footer-sub-wrapper ul li { display: inline-block;margin:0;padding:0;}
.site-footer .footer-sub-wrapper ul li a { display: inline-block; padding: 0 1rem; color: var(--brand-1); text-decoration: underline;}
.site-footer .footer-sub-wrapper ul li a:hover {color: var(--brand-2); scale: 1.1;}
.site-footer .footer-sub-wrapper ul li a:first-of-type {padding-left:0;}

/**Social Icons**/
.social-icons a{width:3rem;height:3rem;background:var(--brand-1);display:inline-block;position:relative;border-radius:100rem;}
.social-icons a:hover { background:var(--brand-5); }
.social-icons a img{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%); width: 50%; max-width: 50%;}

/*Forms*/
input, input[type="text"], textarea, select { width:100%;outline:none;font-family:inherit;border:1px solid var(--brand-3); padding: 1.35rem 2rem; border-radius: 1.5rem; -webkit-border-radius: 1.5rem !important; font-size: 1.8rem; color: var(--brand-3); font-weight: bold;}
input[type="submit"] {border:none;outline:none;cursor:pointer;background:var(--brand-1);width:auto;height:auto; font-size: inherit; font-weight: bold; color: #fff; border-radius: 1.5rem; padding: 1.25rem 2rem; }
input[type="submit"]:hover { background: var(--brand-2); }
input[type='checkbox'], input[type='radio'] { width: auto; height: auto; }

/* Search */
.search-form input.search-field { padding: 1rem; height: auto; font-family: inherit; font-size: 2rem; color: var(--brand-1); font-weight: 600; }
input.search-submit { padding: 1rem; display: block; width: 100%; margin-top: calc( var(--base-type-spacing) / 6 ); color: #fff; }
input.search-submit:hover { background-color: var(--brand-2); color: #fff !important; }
footer input.search-submit:hover { background-color: var(--brand-3); color: var(--brand-2); }
span.screen-reader-text { display: none; }

/* Author Box */
.author-box{background-color: #fff;box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);border-radius: var(--border-radius);margin-top: calc( var(--base-type-spacing) / 2 );}
.author-box.grid{grid-template-columns: 2fr 4fr; grid-gap:0;}
.author-box .author-image img{object-fit:cover;height:100%;}
.author-box .author-text p{font-size:14px}
.author-box .author-text{padding: calc( var(--base-type-spacing) / 2 ) ;}
.author-box .author-socials-area{display: flex; gap: 1rem;}
.author-box .author-socials-area .author-socials a{width:40px;height:40px;background:var(--brand-1);display:inline-block;padding: calc( var(--base-type-spacing) / 6 );position: relative;border-radius:100px;}
.author-box .author-socials-area .author-socials a img{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:23px;height:auto;}
.author-box .author-socials-area .author-socials a:hover{opacity: 0.8;}

/**Fix appearance of buttons iphone**/
input[type=text], input[type=button] { -webkit-appearance: none; -webkit-border-radius: 0; }

/* Popups */ 
.popup{position:fixed;top:0;left:0;width:100%;height:100%;z-index:99999;justify-content:center;align-items:center;display:none; transition: all 1s ease;}
.popup.active{display:flex;}
.popup .popup-bg{position:fixed;top:0;left:0;width:100%;height:100%; background: rgba(0,0,0,.75); backdrop-filter: blur(10px);z-index:-1; transition: all 1s ease;}
.popup .popup-content{background:#ffffff;max-width:1024px;padding: calc( var(--base-type-spacing) / 1.7 );position:relative;width:100%; border-radius: 1rem; }
.popup .popup-content .popup-close{height: calc( var(--base-type-spacing) / 1.7 );width: calc( var(--base-type-spacing) / 1.7 );position: absolute;top:0;right:0;background:var(--brand-1);cursor: pointer; border-radius: 0 1rem 0 0;}
.popup.active { transition: all 1s ease; }
.popup-close:before, .popup-close:after{content:'';width: calc( var(--base-type-spacing) / 3 );height:.3rem;background-color:#ffffff;position: absolute;left:50%;}
.popup-close:before{top: 50%; transform: translate(-50%, -50%) rotate(45deg);}
.popup-close:after{bottom: 50%; transform: translate(-50%, 50%) rotate(-45deg);}

@media screen and (max-width: 1515px){
  .site-header .container{max-width: 100%; width: 100%; padding: 0 2rem;}
  .site-header .grid{grid-template-columns: 14rem 1fr 14rem;}

  .top-nav li a{font-size: 1.5rem; padding: 6rem 1rem;}
}

@media screen and (max-width:1024px ) {
  .site-header { display: none;}
  .admin-bar .toast-mm-banner{display: flex; align-items: center; justify-content: space-between;}
  .toast-mm-logo.right img{height: 35px;}
  .toast-mm-overflow{padding-top: 55px;}
}

@media screen and (max-width:768px ) {
  .site-footer .footer-main .grid{grid-template-columns:1fr; align-items: center; grid-gap: 4rem; text-align: center;}
  .site-footer .footer-main .mailing-list{text-align: left;}
  .site-footer .footer-main .menu-wrapper{display: block;}
  .site-footer .footer-main .social-icon{display: grid; justify-content: center; margin-top: 2rem;}
  .site-footer .footer-main ul{justify-content: center; align-items: center;}
  .site-footer .footer-sub-wrapper ul, .companyname { text-align: center; }
	.footer-sub-wrapper .container .grid { grid-gap: 1rem; }
}

@media screen and (max-width:576px ) {
	.site-banner { margin-top: 4.7rem; font-size: 80%; }
}