/*
Theme Name: Toast
Description: Lightweight, tasty and totally awesome.
Author: Dave Foreman, Aaron Jones and the Toast team
Date: November 2024
Version: 16.0.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: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-hanken-grotesk-v11-latin-300-normal-1759332183.woff2') format("woff2");
}

@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-hanken-grotesk-v11-latin-400-normal-1759329669.woff2') format("woff2");
}

@font-face {
  font-family: 'Hanken Grotesk';
  font-style: italic;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-hanken-grotesk-v11-latin-400-italic-1759329669.woff2') format("woff2");
}

:root {
  --ywf--family-hanken-grotesk: 'Hanken Grotesk';
}

@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-newsreader-v25-latin-400-normal-1759330493.woff2') format("woff2");
}

@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 600;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-newsreader-v25-latin-600-normal-1759330493.woff2') format("woff2");
}

@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 400;
  font-display: auto;
  src: url('/wp-content/uploads/yabe-webfont/fonts/google-fonts-newsreader-v25-latin-400-italic-1759330493.woff2') format("woff2");
}

:root {
  --ywf--family-newsreader: 'Newsreader';
}


/* Gsap */

.typewriter-text {
  opacity: 0; /* Hidden until typewriter starts */
  word-wrap: break-word;
  overflow-wrap: break-word;
  word-break: break-word;
  hyphens: auto;
  
  /* Prevents layout shift during typing */
  min-height: 1.2em;
}

/* For smaller screens - ensure proper wrapping */
@media (max-width: 768px) {
  .typewriter-text {
    word-break: normal; /* Allows natural word breaks */
    overflow-wrap: anywhere; /* Breaks long words if needed */
  }
}


.fade-up {
  opacity: 0;
}

/* Fallback if JS doesn't load */
.no-js .fade-up {
  opacity: 1;
}



/**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: 2rem;line-height: 1.6;font-family: 'Hanken Grotesk', Helvetica, Arial, sans-serif;font-weight: 400;color: var(--text-color);margin: 0;padding: 0 !important; -webkit-font-smoothing: antialiased; }
#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{ position: absolute; top: 10rem; left: 0; right: 0; z-index: 3;   }
.site-header .grid{grid-template-columns:16rem 1fr;align-items:center;}
.site-header .container { width: 100%; max-width: 100%; padding-left: 10%;  box-sizing: border-box; }
.site-header .container a.site-logo {  }


  /* Navigation container */
  .top-nav {
    position: fixed;
    right: 0;
    z-index: 1000;
    width: auto;
  }

  .menu-main-menu-container {
    width: auto;
  }

  /* Menu styling */
  #menu-main-menu {
    list-style: none;
    display: flex;
    align-items: top;
    padding: 0;
    margin: 2rem 0 0 0;
    width: auto;
    transform: translateX(calc(100% - 65px));
    transition: transform 0.4s ease;
  }


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



  #menu-main-menu.active {
    transform: translateX(0);
  }

  #menu-main-menu li {
    margin: 0;
	position: relative; 
  }

  #menu-main-menu li a {
    display: block;
    padding: 20px 25px;
    color: #000;
    text-decoration: none;
    font-size: 16px;
    transition: background 0.3s ease;
    white-space: nowrap;
	background:rgba(255,255,255,.5);
  }

  #menu-main-menu li a:hover {
  }

  /* Menu icon (first item) - always visible */
  #menu-item-2567 {
  }

  #menu-item-2567 a {
    color: #000;
    padding: 1rem;
    cursor: pointer;
	background: rgba(255,255,255,.5);
	  border-radius: 100% 0 0 100%; 
	  
  }


  #menu-item-2567 a:hover {
  }

  /* Current page indicator */
  .current-menu-item a {
  }

  /* Overlay */
  .menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /*background: rgba(0, 0, 0, 0.5);*/
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease, visibility 0.4s ease;
    z-index: 999;
  }

  .menu-overlay.active {
    opacity: 1;
    visibility: visible;
  }

  /* Demo content */
  .demo-content {
    max-width: 1200px;
    margin: 100px auto 0;
    padding: 40px;
  }

  .demo-content h1 {
    margin-bottom: 20px;
    color: #333;
  }

  .demo-content p {
    line-height: 1.6;
    color: #666;
    margin-bottom: 15px;
  }






/* Navbar & Menus 
.top-nav {text-align: right;  }
.top-nav ul { display: inline-block; margin: 0 auto; padding: 1rem; background: rgba(255,255,255,.6); border-radius: 10rem 0 0 10rem;}
.top-nav li { display: inline-block; margin: 0;padding:0; position: relative;}
.top-nav li a { display: inline-block; padding: 1rem 2rem;line-height: 1; color:var(--brand-6);}
.top-nav li:hover > a, .top-nav li.current-menu-item a { color:var(--brand-5); }
.top-nav li:first-of-type a { border: 1px solid #fff; border-radius: 100%; line-height: 0; padding: 1rem;}
/*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;}*/


/* Tables */
table { width: 100%; border-collapse: collapse; margin-bottom: calc(var(--base-type-spacing) / 2); text-align: left;  }
thead th { background-color: var(--brand-1); font-weight: bold; text-align: left; padding: 1rem; color: #fff; font-size: 120%; }
tbody tr:nth-child(even) { background-color: #fff; }
tbody tr:nth-child(odd) { background-color: var(--brand-8); }
tbody td, tbody th { padding: 1rem; }
table { border: none; }
td { border: .15rem solid var(--brand-1);  }
th { border-width: .15rem .15rem .3rem .15rem; border-style: solid; border-color: var(--brand-1); }

@media screen and (max-width: 768px) {
  table {
   /* display: block;*/
    overflow-x: auto;
    width: 100%;
  }
}

/* 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 */
}





/**Lists**/
ul { margin:0; padding-left: 2rem; list-style: disc outside; }
li { margin:0;margin-bottom: calc( var(--base-type-spacing) / 6 ); }



/*Links*/
a { text-decoration: none;color:inherit;}
p a { color: var(--brand-1);}
p a:hover { color: var(--brand-2);}

/**Generic Hero**/
.generic-hero{padding: calc( var(--base-type-spacing) / 2 ) 0;background:var(--brand-1);color:#ffffff;}

/**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 ul#menu-main-menu-1 li:first-of-type { display: none; }
.site-footer .container  { width: 80%; max-width: 80%; } 
.site-footer{ font-weight: 300; background: #fff url(/wp-content/uploads/lanas-footer-background.png) bottom right no-repeat; background-size: contain;   }
.site-footer .footer-logo{display:inline-block;max-width:16rem;}
.site-footer .footer-main{ padding: calc( var(--base-type-spacing) / 1.2 ) 0;}
.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; }
.site-footer .footer-main ul li { margin: 0; padding: 0; }
.site-footer .footer-main .container .grid { align-items: center; }
/* Sub footer */
.site-footer .footer-sub-wrapper {padding: calc( var(--base-type-spacing) / 3 ) 0; font-size:1.5rem;}
.site-footer .footer-sub-wrapper .grid{grid-template-columns:1fr 1fr;align-items:center;}
.site-footer .footer-sub-wrapper ul { text-align: right; padding: 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; }

/**Social Icons**/
.social-icons { display: flex; align-items: center; justify-content: flex-end;}
.social-icons a{width:6rem;height:6rem;display:inline-block;position:relative;}
.social-icons a img{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%); width: 50%; max-width: 50%;}

/*Forms*/
input, textarea, select { width:100%;outline:none;font-family:inherit;border:1px solid var(--brand-1); padding: 1rem; border-radius: 1rem;  }
input[type="submit"] {border:none;outline:none;cursor:pointer;background:var(--brand-1);width:auto;height:auto; font-size: inherit; color: #fff; }
input[type="submit"]:hover { background: var(--brand-2); }
input[type='checkbox'], input[type='radio'] { width: auto; height: auto; }
 input[type='text']  { border-radius: 1rem !important;  }
/* 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) / 3 );}
.author-box.grid{grid-template-columns: 20rem 1fr; 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 .author-socials a{width:28px;height:28px;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:17px;height:auto;}

/**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:1024px ) {
		.site-header { display: none;}

}

@media screen and (max-width:768px ) {
.site-footer .footer-main .grid{grid-template-columns:1fr 1fr;}
	.site-footer { background-size: 30%; }
	.site-footer .grid.mt4 { grid-template-columns: 1fr 1fr !important; }
}


@media screen and (max-width:576px ) {
	.site-footer .footer-sub-wrapper ul, .companyname { text-align: center; }
	.footer-sub-wrapper .container .grid { grid-gap: 1rem; }
	.footer-main { text-align: center; }
	.site-banner { margin-top: 4.7rem; font-size: 80%; }
	.block-hero .col { max-width: 100%; }
	.tagline-message { text-align: center; }
	.social-icons { justify-content: center; }
	html { font-size: 50.5%; }

}