@charset "UTF-8";
/* CSS Document */
/* Designed and developed by www.ff.com.mt */

:root {
	--white: #fff;
    
   --red: #B62939;
	
	--red-brighter: #C95E6A;
	
	
	--darkgrey: #282829;
	--darkgrey-brighter: #4B494B;
	
	--black: #000;
	
	--headingFont: "Fira Sans Condensed", "Arial", serif;
	--textFont: "Fira Sans Condensed", "Arial", sans-serif;
    
    --secondaryFont: "Fira Sans Condensed", "Times", serif;
	
	--miniSectionSpacer: 40px;
	--sectionSpacer: 90px;
	--megaSectionSpacer: 180px;
	
    --heroHeight: 95vh;
    --shortSliderHeight: 45vh;
    --containerMargin: 75px; /*margin from sides*/
        
    --roundedCorners: 20px; 
    --scroll-speed: 0s;
	
	--green-success-form: #449451;
}


.gform-theme--api,
.gform-theme--framework {
    /* gf stuff */
    --gf-color-primary: var(--red) !important;
     --gf-color-primary-rgb: 0,40,80 !important;
      --gf-color-primary-darker:var(--red-brighter) !important;
      --gf-color-primary-lighter: var(--red-brighter) !important;
    
      --gf-radius:8px !important;
      --gf-radius-max-sm:8px !important;
      --gf-radius-max-md:8px !important;
      --gf-radius-max-lg:8px !important;
    
    --gf-color-secondary:var(--red) !important;
  --gf-color-secondary-rgb: var(--red-brighter) !imporant;
    
    
    --gf-color-success: green !important; 
  --gf-color-success-rgb:91,208, 230;
  --gf-color-success-contrast:#fff;
  --gf-color-success-contrast-rgb:91,208, 230;
	
	--gf-form-success-bg-color: rgba(57,159,75,1) !important;
   
  --gf-color-in-ctrl-primary:var(--gf-color-primary) !important;
 
  --gf-padding-x: 16px !important;
  --gf-padding-y:42px !important;

  --gf-ctrl-size:var(--gf-ctrl-size-lg) !important;
 
  --gf-ctrl-btn-size-md:var(--gf-ctrl-size-lg) !important;
	 --gf-ctrl-border-color: var(--red) !important;
	
	--gf-form-validation-heading-color: var(--white) !important;
	--gf-form-validation-bg-color: rgba(255,255,255,0.3) !important;
	--gf-form-validation-heading-icon-border-color: var(--white) !important;
	--gf-ctrl-desc-color-error: rgba(255,255,255,0.6) !important;
}

.gform-theme--framework .gform-field-label {
	--gf-local-color: var(--white) !important;
	--gf-ctrl-color: var(--red) !important;
}

.gform-theme--framework input:not([type="submit"]), .gform-theme--framework textarea {
	--gf-local-shadow: none !important;
	--gf-local-color: var(--darkgrey) !important;
}

.darkbluebg .gform-theme--framework {
    
    --gf-color-primary: var(--cyan) !important;
     --gf-color-primary-rgb: 91,208, 230 !important;
      --gf-color-primary-darker: var(--cyan-darker) !important;
      --gf-color-primary-lighter: var(--cyan-darker) !important;
    
    --gf-local-color: var(--white) !important;
    --gf-ctrl-btn-icon-color-primary: var(--white) !important;
    --gf-color-secondary:var(--white) !important;
    --gf-color-secondary-rgb: 255,255,255 !imporant;
   --gf-ctrl-label-color-primary: var(--cyan-darker) !important;
   --gf-ctrl-label-color-secondary: #fff !important;
    --gf-form-validation-color: #FFC1C1 !important;
    --gf-ctrl-desc-color-error: #FFC1C1 !important;
    --gf-form-validation-border-color: #FFC1C1 !important;
    --gf-form-validation-border-color-focus: #FFC1C1 !important;
}

.darkbluebg .gform-theme--framework .gform-field-label {
	--gf-local-color: var(--white) !important;
	--gf-ctrl-label-color-req: #FFC1C1 !important;
}

html {
	scroll-behavior: smooth;
}

/*	
:target:before {
	content: "";
	display: block;
	height: 180px;
	margin: -180px 0 0; 
} */

.scrollanchor {
	position: absolute;
	top: -68px;
}


@media screen and (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin-left: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	font-size: 13px;
	font-family: var(--textFont);
	font-weight: 400;
	color: var(--black);
	background-color: var(--white);
	overflow-x: hidden;
	
   /* overflow: hidden; 
    height: 100%; */
    
}

textarea, input[type=text], button, input[type=submit] { outline: none; -webkit-appearance: none; border-radius: 0; }
input:focus, 
textarea:focus, 
select:focus {
    outline: none !important;
    box-shadow: none !important; /* Removes any box-shadow glow, if applied */
}

a, a:focus, a:active {
    outline: 0 none !important;
}

a {
    color: inherit;
	text-decoration: none;
	font-weight: 500;
}

a:hover {
	text-decoration: underline;
}


.clearfloat { /* this class can be placed on a <br /> or empty div as the final element following the last floated div (within the #container) if the overflow:hidden on the .container is removed */
	clear:both;
	height:0;
	font-size: 1px;
	line-height: 0px;
}



.container {
	/* max-width: 1800px; */
	margin-left: auto;
	margin-right: auto;
	width: calc(100% - var(--containerMargin) * 2);
	position: relative;
}

.container.wider {
    width: calc(100% + 60px - var(--containerMargin) * 2);
}

.container.narrow {
	max-width: 1440px;
	width: 85%;
}

.container.narrower {
	max-width: 1050px;
	width: 55%;
}

.container.narrowest {
	max-width: 1050px;
	width: 35%;
}

.container.edgetoedge {
	width: 100%;
}

/*
.container.wide {
	max-width: none;
	margin-left: auto;
	margin-right: auto;
	width: 93%;
}


.padded {
	padding: 80px 100px;
}
*/

.margined {
    margin: var(--containerMargin);
}

.padded {
    padding: var(--containerMargin);
}

.toleft {
	text-align: left;
}

.toright {
	text-align: right;
}

.alignleft, .alignleft img, .pull_left {
	float:left;
}

.alignright, .alignright img, .pull_right {
	float:right;
}

img.alignleft {
	margin-right: 20px;
	margin-bottom: 5px;
	height: auto;
}

.post_container img.alignleft, .post_container img.alignright {
	width: 280px;
	height: auto;
}

.alignleft p.wp-caption-text {
	background: #eee;
	font-size: 10px;
	line-height:  normal;
	padding: 10px;
	margin-top: 0;
	margin-right: 15px;
}

.alignright p.wp-caption-text {
	background: #eee;
	font-size: 10px;
	line-height:  normal;
	padding: 10px;
	margin-top: 0;
	margin-left: 10px;
}

img.alignright {
	margin-left: 20px;
	margin-bottom: 2px;
	height: auto;
}

img.aligncenter {
	width: 100%;
	height: auto;
	display: block;
	margin-left: auto;
	margin-right: auto;	
	text-align: center;
	margin-top: 50px;
	margin-bottom: 50px;
}

hr {
	border: none;
	border-top: 4px solid var(--red);
	margin: var(--sectionSpacer) 0px;
	padding: 0px;
	height: 1px;
	clear: both;
}

hr.grey {
	border-top: 2px solid var(--darkgrey);
}

.tablet_portrait, .tablet_landscape, .mobile {
	display: none;
}

.desktop {
	display: block;
}

/* --- text sizes ---- */


h1 {
	font-family: var(--headingFont);
	font-weight: bold;
	font-size: 34px;

	line-height: 50px;
	margin-top: 0;
	margin-bottom: var(--miniSectionSpacer);
	
	color: var(--blue);
}

h1.mega {
	font-size: 85px;
	line-height: 95px;
}

h2 {
	font-family: var(--headingFont);
	font-weight: bold;
	font-size: 40px;

	line-height: 45px;
	margin-top: 0;
	margin-bottom: var(--miniSectionSpacer);
    text-transform: uppercase;
    
}


h3 {
	font-family: var(--headingFont);
	font-weight: bold;
	font-size: 20px;

	line-height: 26px;
	margin-top: 0;
	margin-bottom: var(--miniSectionSpacer);
}

h3:first-child {
    margin-top: 0;
	margin-bottom: 0;
}

h4 {
	font-family: var(--textFont);
	font-weight: bold;
	font-size: 16px;
	margin-top: 30px;
}

h4:first-child {
    margin-top: 0;
}



h5 {
	font-family: var(--textFont);
	font-weight: 400;
	font-size: 18px;
	margin-top: 30px;
}

p {
	font-family: var(--textFont);
	font-weight: normal;
	font-size:  16px;
	line-height: 24px;
    margin-bottom: 28px;
}


/*  --------------------------------  */

.flex {
	display: flex;
}

.flex.wrap {
	flex-wrap: wrap;
}

.flex-grow {
	flex-grow: 1;
}

.flex.flex-end {
    align-items: flex-end;
}

.flex.flex-center {
    align-items: center;
}

.flex-start {
    align-self: flex-start;
}

.flex.flex-start {
    justify-content: flex-start;
}

.flex-middle {
    align-self: center;
}

.flex-end {
    align-self: flex-end;
}

.flex.small-gap {
    column-gap: calc(var(--containerMargin)/2);
}

.space-between {
	justify-content: space-between;
}


.space-around {
	justify-content: space-around;
}

.justify-center {
	justify-content: center;
}


.grid {
    display: grid;
    grid-template-rows: 1fr;
    grid-column-gap: calc(var(--containerMargin)/2);
    grid-row-gap: calc(var(--containerMargin)/2);
}

.grid.autofit {
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.grid.col-2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid.col-3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid.col-4 {
    grid-template-columns: repeat(4, 1fr);
}

.grid.col-5 {
    grid-template-columns: repeat(5, 1fr);
}

.grid.col-6 {
    grid-template-columns: repeat(6, 1fr);
}


.grid.col-7 {
    grid-template-columns: repeat(7, 1fr);
}


.grid.col-8 {
    grid-template-columns: repeat(8, 1fr);
}

.grid.center-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* centers items horizontally */
  gap: calc(var(--containerMargin) / 2);
}

.grid.center-items .gallery_image {
	aspect-ratio: 4 / 3;
	padding-top: 0;
  position: relative;
  overflow: hidden;
  border-radius: var(--roundedCorners);
  width: 100%;
}

/* Use this for auto-fit behavior with min width of 200px */
.grid.center-items.autofit .gallery_image {
  flex: 1 1 200px; /* grow/shrink, with 200px minimum width */
  max-width: 200px; /* ensures it doesn't overflow container */
}

/* Use this for 4 equal columns (e.g. on wider screens) */
.grid.center-items.col-2 .gallery_image {
  flex: 0 1 calc((100% - (1 * var(--containerMargin) / 2)) / 2);
  max-width: calc((100% - (1 * var(--containerMargin) / 2)) / 2);
}

.grid.center-items.col-3 .gallery_image {
  flex: 0 1 calc((100% - (2 * var(--containerMargin) / 2)) / 3);
  max-width: calc((100% - (2 * var(--containerMargin) / 2)) / 3);
}

.grid.center-items.col-4 .gallery_image {
  flex: 0 1 calc((100% - (3 * var(--containerMargin) / 2)) / 4);
  max-width: calc((100% - (3 * var(--containerMargin) / 2)) / 4);
}

.grid.center-items.col-5 .gallery_image {
  flex: 0 1 calc((100% - (4 * var(--containerMargin) / 2)) / 5);
  max-width: calc((100% - (4 * var(--containerMargin) / 2)) / 5);
}

.grid.center-items.col-6 .gallery_image {
  flex: 0 1 calc((100% - (5 * var(--containerMargin) / 2)) / 6);
  max-width: calc((100% - (5 * var(--containerMargin) / 2)) / 6);
}

.grid.center-items.col-7 .gallery_image {
  flex: 0 1 calc((100% - (6 * var(--containerMargin) / 2)) / 7);
  max-width: calc((100% - (6 * var(--containerMargin) / 2)) / 7);
}

.grid.center-items.col-8 .gallery_image {
  flex: 0 1 calc((100% - (7 * var(--containerMargin) / 2)) / 8);
  max-width: calc((100% - (7 * var(--containerMargin) / 2)) / 8);
}

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

.text-justify {
	text-align: justify;
}

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

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

.aligncontainer {
       margin: 0;
	  position: absolute;
	  top: 50%;
	  -ms-transform: translateY(-50%);
  		transform: translateY(-50%);
	width: 100%;
}

.section, section {
    position: relative;
	display: flow-root;
	margin: var(--sectionSpacer) 0;
}

.section.nobottom, section.nobottom, .nobottom {
	margin-bottom: 0 !important;
}

.section.mega, section.mega {
	margin: var(--megaSectionSpacer) 0 var(--megaSectionSpacer) 0;
}

.section.megatop, section.megatop {
	margin-top: var(--megaSectionSpacer);
}

.section.megabottom, section.megabottom {
	margin-bottom: var(--megaSectionSpacer);
}

.section.minitop, section.minitop {
	margin-top: calc(var(--sectionSpacer)/2);
}

.section.minibottom, section.minibottom {
	margin-bottom: calc(var(--sectionSpacer)/2);
}

.section.notop, section.notop, .notop {
	margin-top: 0 !important;
}

.topmargin {
	margin-top: var(--sectionSpacer);
}

.bottommargin {
	margin-bottom: var(--sectionSpacer);
}

section.margin_to_padded, .margin_to_padded {
	margin: 0 !important;
	padding: var(--sectionSpacer) 0;
}

section.margin_to_padded.notop, .margin_to_padded.notop {
     padding-top: 0;   
}

section.margin_to_padded.nobottom, .margin_to_padded.nobottom {
     padding-bottom: 0 !important;   
}

section.margin_to_padded.mega, .margin_to_padded.mega {
	padding: var(--megaSectionSpacer) 0;
}

.section.margin_to_padded.minitop, section.margin_to_padded.minitop {
	padding-top: calc(var(--sectionSpacer)/2);
}

.section.margin_to_padded.minibottom, section.margin_to_padded.minibottom {
	padding-bottom: calc(var(--sectionSpacer)/2);
}


.spacer {
	padding-top: var(--sectionSpacer);
}

.backgrounded {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}

.backgrounded.fixed {
	background-attachment: fixed;
}

section.negativemargin {
    margin-top: calc(var(--sectionSpacer) * -2) !important;
}

#panel {
	overflow-x: hidden;
}


/* --- solid button ---- */

.buttoncontainer.mini {
	margin: var(--miniSectionSpacer) 0;
}

.buttoncontainer {
	margin: var(--sectionSpacer) 0;
}

.bigbutton {
	margin-right: 10px;
	background-color: transparent;
	color: #fff;
	font-family: var(--headingFont);
	padding: 10px 30px;
	font-size: 16px;
	font-weight: normal;
	 -webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
	display: inline-block;
	text-transform: uppercase;
	border-radius: 100px;
    vertical-align: middle;
    line-height: 24px;
	box-sizing: border-box !important;
	border: 2px solid transparent; 
}

.bigbutton:hover {
	text-decoration: none;
}

.bigbutton:first-child {
	margin-left: 0;
}

.bigbutton:last-child {
	margin-right: 0;
}

.bigbutton .flex {
   
}

.bigbutton.red {
    background-color: var(--red);
	color: var(--white);
}

.bigbutton.red:hover {
    background-color: var(--red-brighter);
}

.bigbutton.solid.white {
	background-color: #fff;
	color: var(--blue);
}

.bigbutton.solid.white:hover {
	background-color: var(--cyan-lighter);
	color: var(--blue);
}

.bigbutton.hollow.white {
	border: 2px solid var(--white);
	color: var(--white);
}

.bigbutton.hollow.white:hover {
	border: 2px solid var(--white);
	background-color: rgba(255,255,255,0.1);
	color: var(--white);
}

.bigbutton.hollow.red {
	box-sizing: border-box !important;
	border: 2px solid var(--red);
	background-color: transparent;
	color: var(--red);
}

.bigbutton.hollow.red:hover {
	border: 2px solid var(--red);
	background-color: var(--red-darker-10);
	color: var(--red);
}


/* --- colours ---- */

.darkgreybg {
    background-color: var(--darkgrey);
    color: var(--white);
}

.redbg {
    background-color: var(--red);
    color: var(--white);
}

/* --- zigzag ----- */


.zigzag.down {
 --mask:
    radial-gradient(25.61px at 50% calc(100% - 36px),#000 99%,#0000 101%) calc(50% - 32px) 0/64px 100%,
    radial-gradient(25.61px at 50% calc(100% + 20px),#0000 99%,#000 101%) 50% calc(100% - 16px)/64px 100% repeat-x;
  -webkit-mask: var(--mask);
          mask: var(--mask);
	padding-top: 30px;
}

.zigzag.up {
	  --mask:
    radial-gradient(25.61px at 50% 36px,#000 99%,#0000 101%) calc(50% - 32px) 0/64px 100%,
    radial-gradient(25.61px at 50% -20px,#0000 99%,#000 101%) 50% 16px/64px 100% repeat-x;
  -webkit-mask: var(--mask);
          mask: var(--mask);
	padding-top: 30px;
}

.zigzag.red {
	background-color: var(--red);
}

.zigzag.grey {
	background-color: var(--darkgrey);
}


/* ---- divider ----- */

.divider {
	--mask:
    radial-gradient(27.11px at 50% calc(100% + 20px),#0000 calc(99% - 3px),#000 calc(101% - 3px) 99%,#0000 101%) calc(50% - 32px) calc(50% - 9.5px + .5px)/64px 19px repeat-x,
    radial-gradient(27.11px at 50% -20px,#0000 calc(99% - 3px),#000 calc(101% - 3px) 99%,#0000 101%) 50% calc(50% + 9.5px)/64px 19px repeat-x;
  -webkit-mask: var(--mask);
          mask: var(--mask);
	height: 20px;
	width: 300px;
	margin-left: auto;
	margin-right: auto;
	padding: var(--miniSectionSpacer) 0;
}

.divider.red {
	background-color: var(--red);
}

.divider.white {
	background-color: var(--white);
}

/* ---- header nav ----- */

header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	margin-top: var(--sectionSpacer);
	
	-webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

header.active {
	margin-top: 0;
}

header nav {
	
}

nav ul {
  display: flex;
  
  list-style: none;
  margin: 0;
  padding: 5px;
	background-color:  var(--darkgrey);
	border-radius: 100px;
	font-size: 20px;
	text-transform: uppercase;
	
		-webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

header.active nav ul {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
	border-bottom-left-radius: 30px;
	border-bottom-right-radius: 30px;
	
			box-shadow: 1px 1px 15px -4px rgba(0,0,0,0.82);
-webkit-box-shadow: 1px 1px 15px -4px rgba(0,0,0,0.82);
-moz-box-shadow: 1px 1px 15px -4px rgba(0,0,0,0.82);
}

nav a {
  color: white;
  text-decoration: none;
	padding: 15px 25px;
	display: block;
	border-radius: 100px;
	
	-webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

nav a:hover {
	background-color: var(--red);
	text-decoration: none;
}


/* ------ welcome ----- */

.welcome {
	z-index: 100;
	position: relative;
}

.welcome .zigzag.down {
	position: absolute;
	top: 0;
	width: 100%;
}

.welcome .zigzag.up {
	position: absolute;
	bottom: 0;
	width: 100%;
}

.redhalf {
	position: absolute;
	right: 0;
	top: 0;
	border-bottom-left-radius: 250px;
	background-color: var(--red);
	width: 50%;
	height: 120%;
	
	background-image: url("../images_interface/branding/pattern.svg");
	background-repeat: repeat-y;
	background-size: contain;
	background-position: center center;
	z-index: 99;
}

.packet_container {
	position: absolute;
	right: 0;
	top: 0;
	z-index: 100;
	width: 54%;
	height: 100%;
	
}

.packet_container .packet_1 {
	position: absolute;
	top: 30%;
	left: 0;
	z-index: 2;
	opacity: 0;
	/*transform: rotate(-15deg);  Counter-clockwise */
	animation: rotateInLeft 0.4s ease-out forwards;
	animation-delay: 0.1s;
}

.packet_container .packet_2 {
	position: absolute;
	top: 10%;
	left: 45%;
	z-index: 1;
	opacity: 0;
	 /*transform: rotate(22deg); Clockwise */
	  animation: rotateInRight 0.4s ease-out forwards;
}


.packet_container img.packet  {
	width: 65%;
	max-width: 600px;
	
	transition: transform 0.1s ease-out;
	will-change: transform;
}

.content_half {
	width: 50%;
	min-height: calc(var(--heroHeight) - var(--megaSectionSpacer));
	justify-content: center;
	align-items: center;
	align-content: normal;

}

.content_half .logo_container {
	
}

.content_half .logo_container img {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

.content_half .content_container {
	width: 55%;

}


@keyframes rotateInLeft {
  0% {
    transform: translateY(150px) rotate(-0deg);
    opacity: 0;
  }
  100% {
    transform: translateY(0) rotate(-20deg);
    opacity: 1;
  }
}

@keyframes rotateInRight {
  0% {
    transform: translateY(150px) rotate(0deg);
    opacity: 0;
  }
  100% {
    transform: translateY(0) rotate(30deg);
    opacity: 1;
  }
}

.left_element {
	position: absolute;
	left: 2%;
	bottom: -50%;
	width: 30%;
	max-width: 420px;
	height: auto;
	z-index: 100;
}

.right_element {
	position: absolute;
	right: 2%;
	bottom: -50%;
	
	width: 30%;
	max-width: 420px;
	height: auto;
	z-index: 100;
}

.left_element img, .right_element img {
	width: 100%;
}

/* --- flavours ---- */

.flavours {
	z-index: 90;
	margin-bottom: -120px;
}


.flavour_slider {
	margin-left: var(--containerMargin);
	margin-right: var(--containerMargin);
	z-index: 2;
}

.flavour_card {
	padding: 10px;
	background-color: var(--white);
	border-radius: var(--roundedCorners);
	margin: 0 10px 30px 10px;
	
	box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.75);
	-webkit-box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.75);
	-moz-box-shadow: 0px 0px 18px -6px rgba(0,0,0,0.75);
	
	 -webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

a.flavour_card:hover  {
	text-decoration: none;
	
}

a.flavour_card:hover .flavour_info  {
	margin-top: -76%;
	padding: calc(20px + 76%) 40px 40px 40px;

}


.flavour_card .packet_image {
	margin-top: 0;
	left: 0;
	z-index: 10;
	position: relative;
}

.flavour_card .packet_image img {
	width: 60%;
	margin-left: auto;
	margin-right: auto;
	height: auto;

		
	 -webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

a.flavour_card:hover .packet_image img {
	transform: scale(1.05);
}

.flavour_card .flavour_info {
	margin-top: -35%;
	border-radius: calc(var(--roundedCorners) - 4px);
	position: relative;
	padding: calc(20px + 35%) 40px 40px 40px;
	z-index: 1;
	position: relative;
	color: var(--white);

		 -webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

.flavour_info.red {
	background-color: var(--red);
}

.flavour_info.grey {
	background-color: var(--darkgrey);
}

.flavour_card h4 {
	margin-top: 0;
	margin-bottom: 10px;
	text-transform: uppercase;
	font-size: 28px;
}

.flavour_card p {
	margin: 0;
}

.flavours .fakebottom {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: var(--megaSectionSpacer);
	background-color: var(--white);
	z-index: 1;
}

/* --------------------------- popup -------------------------- */


/*---profiles container --- -*/


.modal.active {
  display: block;
}
.hidden {
  display: none;
}
.full_user_profile {
	position: absolute;
	top:0;
	right: 0;
	width: calc(55% - 20px);
	height:  calc(100% - 20px);
	padding: 40px;
	overflow-y: scroll;
	background-color: var(--red);
	z-index: 50;
	border-radius: var(--roundedCorners);
	margin: 10px;
	box-sizing: border-box;
	color: var(--white);
}

.full_user_profile.grey {
	background-color: var(--darkgrey);
}

a.closebutt {
  width: 50px;
  height: 50px;
  line-height: 40px;
  position: absolute;
  right: -25px;
  top: -25px;
  background-color: var(--darkgrey);
  padding: 10px;
  color: var(--white);
	border: 2px solid var(--white);
  font-size: 30px !important;
  text-align: center;
	z-index: 100;
	border-radius: 100px;
	
	        -webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

a.closebutt:hover {
	background-color: var(--darkgrey-brighter);
	cursor: pointer;
}

a.closebutt span {
  line-height: 50px;
}

.full_user_profile h2 {
	
	font-size: 32px;
	line-height: 46px;
	margin: 0;
	margin-bottom: 20px;
	color: var(--white);
	width: 80%;
	font-weight: 700;
}
.full_user_profile h3 {
	font-size: 18px;
	line-height: 24px;
	font-weight: 700;
	margin-top: 15px;
	margin-bottom: 0;
	color: var(--white);
}



.full_user_profile h4 {
	font-size: 18px;
	line-height: 25px;
	font-weight: 400;
	margin: 0;
	
	color: var(--white);
}

.full_user_profile p {
	line-height: 1.6;
	color: var(--white);
	margin-top: 0;
}

.full_user_profile ul {
	margin: 0;
	margin-top: 10px;
	padding: 0;
	list-style-type: none;
	font-size: 16px;
}

.full_user_profile ul li {
	font-family: var(--headingFont);
}


.full_user_profile ul li:before {
	    content: 'adjust'; /* Specify the icon name here */
    font-family: 'Material Symbols Outlined';
	margin-right: 10px;
    font-weight: 200;
    vertical-align: middle;
}

.full_user_profile hr {
	border-top: 2px dotted rgba(255,255,255,0.5);
	margin: calc(var(--miniSectionSpacer) / 2) 0;
}

.full_user_profile .divider {
	margin-left: 0;
}

.full_user_profile .profile_footer {
  font-size: 16px;
  line-height: 22px;
  padding-bottom: 30px;
}

.full_user_profile .profile_footer .member_email,
.full_user_profile .profile_footer .member_number {
  font-weight: 700;
  color: var(--white);
}

.user_image {
  position: absolute;
  top: 0;
  left: 0;
  width: 45%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}

/* ---- who we are ----- */

.whoweare {
	z-index: 50;
}

.whoweare .flex {
	gap: var(--sectionSpacer);
}

.whoweare h2 {
	color: var(--red);
	margin-bottom: 0;
}

.whoweare .divider {
	margin-left: 0;
}

.whoweare .flex .left_side, .whoweare .flex .right_side {
	flex: 1;
}

.whoweare .flex .right_side {
	border-radius: calc(var(--roundedCorners) + 10px);
	background-color: var(--white);
	border: 8px solid var(--red);
}

.whoweare .right_side .fakeborder {
	
	border-radius: var(--roundedCorners);
	margin: 8px;
	height: calc(100% - 16px);
	background-size: cover;
	background-position: center center;
	padding-top: 100%;
}

.whoweare .zigzag.up {
  position: absolute;
  bottom: 0;
  width: 100%;
}

/* ---- news ---- */

.news .packet_1 {
	position: absolute;
	left: -10%;
	top: calc(var(--megaSectionSpacer) * -1);
	width: 30%;
	transform: translateY(150px) rotate(0deg);
  transition: none;
	z-index: 100;
	opacity: 0;
	pointer-events: none;
}

.news .packet_1 img {
	width: 100%;
	height: auto;
}

.news .packet_2 {
	position: absolute;
	right: -10%;sform: rotate(-20deg);
	z-index: 100;
	bottom: calc(var(--megaSectionSpacer) * -1);
	width: 30%;
	opacity: 0;
	
	  transform: translateY(150px) rotate(0deg);
  transition: none;
	pointer-events: none;
}

.animate-in {
  animation: rotateInRight 0.4s ease-out forwards;
	animation-delay: 0.3s;
}

.news .packet_2.animate-in {
	animation: rotateInLeft 0.4s ease-out forwards;
	animation-delay: 0.3s;
}

.news .packet_2 img {
	width: 100%;
	height: auto;
}



.news .news_container {
	margin-top: var(--miniSectionSpacer);
}

.news .news_container .news_item {
	background-color: var(--white);
	border-radius: var(--roundedCorners);
	overflow: hidden;
	background-color: #eee;
	gap: 20px;
	margin: 20px 0;
}

.news .news_container .news_item .news_side, .news .news_container .news_item .image_side {
	flex: 1;
}

.news .news_container .news_item .news_side {
	align-self: center;
}

.news .news_container .news_item .news_side .content_container {
	padding: 30px;
	
	color: var(--red);
}

.news .news_container .news_item .news_side .content_container h4 {
	margin-top: 10px;
	font-weight: normal;
}

.news .news_container .news_item .news_side .content_container p {
	color: var(--darkgrey);
	margin: 0;
}

.news .news_container .news_item .image_side .image_container {
	background-size: cover;
	background-position: center center;
	height: 100%;
	min-height: 235px;
}

.news .zigzag.up {
	position: absolute;
	bottom: 0px;
	left: 0;
	width: 100%;
	z-index: 2;
}

/* ----- social ----- */

.social .insta_feed {
	padding: 8px 0;
}

#sbi_images {
	background-color: var(--darkgrey);
}

#sbi_load {
	margin-top: var(--miniSectionSpacer);
}

#sbi_load a, #sbi_load button {
	padding: 10px 30px !important;
	border-radius: 100px !important;
	border: 2px solid var(--white) !important;
	text-transform: uppercase;
}

table.contact_details {
	font-size: 16px;
	line-height: 22px;
	width: 100%;
}

table.contact_details td {
	width: 33%;
}

.icon-text {
  display: inline-flex;
  align-items: flex-start;
  gap: 20px;
}

.circle-icon {
  background-color: white;
  color: var(--red); /* adjust to your theme */
  border-radius: 50%;
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
  flex-shrink: 0;
}

.material-icons {
  font-size: 18px;
  line-height: 1;
}

.contact_content {
	margin-top: 8px;
	text-align: left;
}

.social .zigzag.up {
	position: absolute;
	bottom: 0px;
	left: 0;
	width: 100%;
	z-index: 2;
}

/* ---- footer ----- */

.footer_left ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
	display: flex;
	column-gap: 20px;
}

.footer_left ul li {
	text-transform: uppercase;
}


footer .credits a.creditdetail {
	webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
	margin-left: 3px;
	font-weight: normal;
}

footer .credits a.creditdetail.ff:hover {
	color: var(--blue);
	text-decoration: none;
}

.credits .creditdetail.ff {
     opacity: 0.6;
}

.credits .creditdetail.ff img {
	vertical-align: middle;
	margin-left: 5px;
	margin-bottom: 1px;
    
    webkit-transition: all 0.2s ease-out;
	-moz-transition: all 0.2s ease-out;
	-o-transition: all 0.2s ease-out;
	transition: all 0.2s ease-out;
}

.credits .creditdetail.ff:hover {
    opacity: 1;
}

/* ------ forms ------- */

.form_container input.gform_button[type=submit] {
	background-color: var(--white) !important;
	color: var(--red) !important;
	border-radius: 100px !important;
	font-size: 16px !important;
	text-transform: uppercase !important;
	padding: 10px 30px !important;
}

.form_container input.gform_button[type=submit]:hover {
	background-color: rgba(255,255,255,0.9) !important;
}

.form_container .gform_footer {
	justify-content: center;
	margin-top: var(--sectionSpacer) !important;
}


.form_container .gform-theme--framework .gform_confirmation_message {
  background-color:var(--gf-color-success) !important;
  border: 1px solid var(--gf-color-success) !important;
  /* border-radius: 0 !important; */
  box-shadow: none !important;
  border-radius: var(--roundedCorners);
  margin-block:var(--gf-form-validation-margin-y);
  padding-block:var(--gf-form-validation-padding-y);
  padding-inline:var(--gf-form-validation-padding-x);
	color: var(--white);
	text-align: center !important;
	font-size: 16px !important;
	font-weight: 400 !important;
	
}

.form_container .gform-theme--framework .gform_confirmation_message {
    margin-bottom: 0px;
}

.form_container .gform-theme--framework .gform_confirmation_message:before {
    content: 'check_circle'; /* Keeps the icon visible */
    font-family: 'Material Symbols Outlined';
    font-size: 24px;
    font-weight: 200;
    vertical-align: middle;
    margin-right: 5px;
}


.tablet_portrait, .tablet_landscape, .mobile {
	display: none;
}

.desktop {
	display: block;
}

@media 
  only screen and (-webkit-min-device-pixel-ratio: 2),
  only screen and (min-resolution: 192dpi),
  only screen and (min-resolution: 2dppx) {
  
  /* Styles for small Retina displays */
	  
	header {
		margin-top: calc(var(--sectionSpacer) / 2);
	}
 	  
}


@media screen and (max-width: 1100px) {
	
	:root {
		--containerMargin: 60px;
	}
    
    .desktop, .tablet_portrait, .tablet_landscape, .mobile {
		display: none;
	}
	
	.tablet_landscape {
		display: block;
	}

	
	.container.narrower, .container {
		max-width: unset;
		 width: calc(100% - var(--containerMargin) * 2);
	}
	
	.news .container.narrower {
		--containerMargin: 150px;
	}
	
	h3 {
	  font-size: 18px;
	  line-height: 24px;
		margin-bottom: calc(var(--miniSectionSpacer) /2);
	}
	
	p {
	  font-size: 14px;
	  line-height: 22px;
	  margin-bottom: 24px;
	}
	
	header {
		margin-top: calc(var(--sectionSpacer) / 3);
	}
	
	nav ul {
	  font-size: 18px;
	}

	.content_half .content_container {
	  width: 75%;
	}
	
	.content_half .logo_container img {
	  max-width: 250px;
	  margin-left: auto;
	  margin-right: auto;
	}
	
	.packet_container .packet_1 {
		top: 40%;
		left: 5%;
	}
	
	.packet_container .packet_2 {
		top: 0%;
		left: 35%;
	}
	
	.packet_container img.packet {
		width: 75%;
	}
	
	.padded {
		padding: 0;
	}

	
	.news .packet_1 {
		left: -15%;
		width: 35%;
		top: 0;
	}
	
	.news .packet_2 {
	  right: -15%;
	  width: 35%;

	}
	
}


@media screen and (max-width: 850px) {
	
	:root {
		--heroHeight: 0;
	}
	
	.desktop, .tablet_portrait, .tablet_landscape, .mobile {
		display: none;
	}
	
	.tablet_portrait {
		display: block;
	}
	
	header {
		margin-top: calc(var(--sectionSpacer) / 2);
	}
	
	.welcome {
		padding-bottom: 0 !important;
	}
	
	.welcome .zigzag.up {
		z-index: 90;
	}
    
	.welcome .content_half {
		width: 100%;
		min-height: 0;
		margin: var(--sectionSpacer) 0;
	}
	
	.packet_container, .redhalf, .packets {
		position: relative;
		width: 100%;
		height: 400px;
		border-radius: 0;
	
	}

    
	.packet_container .packet_1 {
		position: absolute;
		z-index: 102;

	}
	
	.packet_container .packet_2 {
				position: absolute;
		top: -5%;
		left: 35%;
		z-index: 101;
	}
	
	.packet_container img.packet {
		
		top: -5%;
		width: 55%;
	}
	
	.container.narrowest {
		max-width: unset;
		 width: calc(100% - var(--containerMargin) * 2);
	}
	
	.flavour_info .divider {
		width: 90%;
	}
	
		.modal__container {
		width: 84% !important;
		height: 80vh !important;

		min-width: unset !important;
		max-height: 90vh;
		position: relative !important;
	}
	
	.user_image {
		width: 100%;
		height: 35vh;
	}
	
	.full_user_profile {
		top: 35vh;
		width: calc(100% - 20px);
		padding: 30px;
		height: calc(80vh - 35vh - 20px);
	}
	
	
	.whoweare .flex {
		flex-direction: column;
	}
	
	.whoweare .flex .right_side {
	  border-radius: calc(var(--roundedCorners) + 10px);
	  background-color: var(--white);
	  border: 8px solid var(--red);
		width: 100%;
	}
	
	.news .packet_1 {
    	left: -20%;
		width: 45%;
		top: -10%;
	  }
	
	.news .packet_2 {
		right: -20%;
	  width: 45%;
	}
	
	section.social {
		padding-bottom: 0;
	}
	
	section.form_container {
		margin-top: 40px;
	}
	
	table.contact_details td {
		display: block;
		width: 100%;
		text-align: center;
		padding: 20px 0;
	}
	
	.footer_left {
	  display: flex;
	  justify-content: center;
	}

	.footer_left ul {
	  list-style-type: none;
	  margin: 0 0 20px 0;
	  padding: 0;
	  display: flex;
	  column-gap: 20px;
	}
	
	.disclaimer a {
		display: block;
		margin-top: 10px;
	}
	
	footer .flex {
		flex-direction: column;
		text-align: center;
	}
}

@media screen and (max-width: 600px) {
	
	:root {
		--containerMargin: 8%;
	}
	
	.desktop, .tablet_portrait, .tablet_landscape, .mobile {
		display: none;
	}
	
	.mobile {
		display: block;
	}
	
	h2 {
		margin-bottom: calc(var(--miniSectionSpacer) / 2);
	}
	
	.divider {
		width: 60%;
		padding: calc(var(--miniSectionSpacer) / 2) 0 var(--sectionSpacer) 0;
		height: auto;
	}
	
	.buttoncontainer .bigbutton {
		display: block;
		width: 100%;
		
		margin: 10px 0;
		padding: 15px 30px;
		text-align: center;
	}
	
	  .welcome {
		padding-top: 0 !important;
		  overflow: hidden;
	  }
	
	  .content_half .content_container {
		width: calc(100% - var(--containerMargin));
	  }
	
	  .packet_container, .redhalf, .packets {
		height: 550px;
		  width: 100%;
	}
	
	  .packet_container img.packet {
		top: -15%;
		width: 75%;
	  }
	
	.packet_container .packet_1 {
		left: -7%;
	}
	
	.packet_container img.packet_2 {
		right: -7%;
		left: unset;
		top: 20%;
	}
	
	.flavours#flavours_section {
		padding-top: 0 !important;
	}
	
	.flavour_card {
  margin: 0 5px 10px 5px;
	}
	
	.whoweare .flex {
		gap: var(--miniSectionSpacer);
	}
	
	  .news .container.narrower {
		--containerMargin: 8%;
	  }
	
	.news .news_container .news_item {
		flex-direction: column-reverse;
		gap: 0;
	}
	
	nav ul {
		background-color: transparent;
	}
	
	nav a {
		border-radius: var(--roundedCorners);
	}

	.menubuttoncontainer {
	  position: fixed;
	  top: 30px;
	  left: 30px;
	  z-index: 100;
	  color: #fff;
	  background: var(--red);
	  width: 65px;
	  height: 65px;
	  line-height: 65px;
	  -webkit-border-radius: 50px;
	  -moz-border-radius: 50px;
	  border-radius: 50px;
	  text-align: center;
		
		box-shadow: 0px 0px 23px -8px rgba(0,0,0,0.75);
-webkit-box-shadow: -0px 0px 23px -8px rgba(0,0,0,0.75);
-moz-box-shadow: -0px 0px 23px -8px rgba(0,0,0,0.75);
	}
	
	
	
	.menubuttoncontainer .mburger {
			vertical-align: top;
			text-align: center;	
			height: 65px;
			line-height: 65px;
			width: 65px;
			color: #fff;
			 --mb-bar-height: 2px;
			 --mb-button-size: 65px;
			 --mb-bar-width: 0.4;
			z-index: 999;
		}

	.mm-menu {
	

			--mm-color-background: var(--red);
			--mm-listitem-size: 100px;
			 --mm-color-text: #fff;
			 font-size: 18px;
			 text-transform: capitalize;
			 font-weight: 400;
			 --mm-color-button: #fff;
			 --mm-color-border: rgba(255,255,255,0.2);
		}

	.mm-menu_offcanvas {
		min-width: 240px;
		max-width: none;
	}

	.mm-navbar__title {
		font-size: 12px;
		background-color: var(--darkgrey);
		border-radius: 0;
	}
	
	.mm-menu_offcanvas {
		width: 50%;
		min-width: 240px;
		max-width: none;
	}
	
	.mm-wrapper_opening .mm-menu_offcanvas ~ .mm-slideout {
	    -webkit-transform: translate3d(40vw,0,0);
		transform: translate3d(50vw,0,0);
	}
	
	.mm-wrapper_opening [class*="mm-menu_pagedim"].mm-menu_opened ~ .mm-wrapper__blocker {
		opacity: 0.7;
		
	}

}