/*
Theme Name: Braidy Cakes
Theme URI: https://braidy.co.uk
Description: Braidy Cakes Theme 2025
Version: 2.0
Author: Paul Maloney
Author URI: https://paulmaloney.net
Tags: colours, cake, new, rwd
*/

/* =============================================================================
   HTML5 CSS Reset Minified - Eric Meyer
   ========================================================================== */

html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}
body{line-height:1}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}
nav ul{list-style:none}
blockquote,q{quotes:none}
blockquote:before,blockquote:after,q:before,q:after{content:none}
a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;text-decoration:none}
mark{background-color:#ff9;color:#000;font-style:italic;font-weight:bold}
del{text-decoration:line-through}
abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}
table{border-collapse:collapse;border-spacing:0}
hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}
input,select{vertical-align:middle}
li{list-style:none}

textarea,
input.text,
input[type="text"],
input[type="button"],
input[type="submit"],
.input-checkbox {
-webkit-appearance: none;
border-radius: 0;
}

:root {
    --black: #000000;
    --white: #ffffff;
    --pink: #f1488a;
    --green: #4bcb43;
    --yellow: #fdc100;
    --blue: #0194f7;
    --orange:#fb6400;
}

/* 
==========================================================================
GLOBAL & WP SPECIFIC STYLES
==========================================================================
*/

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: none;    
	line-height:1.5!important;
}

input, textarea, select {
    -webkit-border-radius:0; 
    border-radius:0;
}

img,
audio,
video,
canvas {
    max-width: 100%;
}

html {
    min-height: 100%;
    margin-bottom: 1px;
    overflow: -moz-scrollbars-vertical!important; 
}

::selection {
    background: var(--blue);
    color: var(--white);
}

::-moz-selection {
    background: var(--blue);
    color: var(--white);
}

::-webkit-selection {
    background: var(--blue);
    color: var(--white);
}

.cf:before,.cf:after {content: " "; /* 1 */    display: table; /* 2 */}
.cf:after {clear: both;}
.cf {clear: both;}

strong, b {
    font-weight:bold;
}

em, i {
    font-style:italic;
}

img.alignright {
    float:right;
    margin:0 0 2em 1em;
}

img.alignleft {
    float:left;
    margin:0 2em 1em 0;
}

img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.alignright {
    float:right;
    margin:0 0 2em 1em;
}

.alignleft {
    float:left;
    margin:0 0 2em 1em;
}

img.wp-smiley {
    float: none;
    margin: 0 0 0 5px;
    vertical-align:middle;
}

p {
    margin: 0 0 20px 0;
}

a {
    color: var(--blue);
    text-decoration: none;
}

a:hover {
    color: var(--black);
    text-decoration: none;
}


@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Medium.woff2') format('woff2'),
        url('fonts/TTNormsPro-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Regular.woff2') format('woff2'),
        url('fonts/TTNormsPro-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-ExtraBold.woff2') format('woff2'),
        url('fonts/TTNormsPro-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro ExtraBlack';
    src: url('fonts/TTNormsPro-ExtraBlack.woff2') format('woff2'),
        url('fonts/TTNormsPro-ExtraBlack.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Black.woff2') format('woff2'),
        url('fonts/TTNormsPro-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Thin.woff2') format('woff2'),
        url('fonts/TTNormsPro-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Light.woff2') format('woff2'),
        url('fonts/TTNormsPro-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'TT Norms Pro';
    src: url('fonts/TTNormsPro-Bold.woff2') format('woff2'),
        url('fonts/TTNormsPro-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}


/* 
==========================================================================
H & LINKS
==========================================================================
*/

h1 {
  font: 40px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0 0 10px 0;
  padding: 0;
  font-weight: 700;
}

h2 {
    font: 35px 'TT Norms Pro', Helvetica , Arial, sans-serif;   
  margin: 0 0 15px 0;
    padding:0;
}

h3 {
    font: 30px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0 0 15px 0;
    padding:0;
}

h4 {
    font: 25px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0 0 15px 0;
    padding:0;
}

h5 {
    font: 20px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0 0 15px 0;
    padding:0;
}


/* 
==========================================================================
GENERAL
==========================================================================
*/

body {
    background: var(--white);
    color: var(--black);
    font: 17px/1.5 'TT Norms Pro', Helvetica, Arial, sans-serif;
    margin:0;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

header {
    width:100%;
    margin: 0 auto;
    padding: 50px 0;
  transition: all 0.3s ease-in-out;
}


.head-grid {
    width: 100%;
    display: grid;
    grid-template-columns: auto auto;
    grid-column-gap: 0;
    grid-row-gap: 0;
    justify-items: stretch;
    align-items: center;
}

.hsoc {
    width: 45px;
    height: 45px;
    display: inline-block;    
    vertical-align: middle;
    padding: 5px;
    margin: 0 5px;
    transition: all 0.3s ease-in-out;    
}

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


.hsoc svg {
width: 100%;
  height: auto;   
}

.ins-cta {
    background: var(--pink);
    color: var(--white);
}

.fb-cta {
    background: var(--blue);
    color: var(--white);
}

.ins-cta:hover,
.fb-cta:hover {
    background: var(--yellow);
    color: var(--black);
    transition: all 0.3s ease-in-out;    
}

.logo {
    width: 250px;
    height: auto;
    margin: 0;
    display: block;
    transition: all 0.3s ease-in-out;    
}


.logo img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}


.container {
    width:100%;
    margin:0 auto;
}

.inner {
    position: relative;
    width: 100%;
    max-width: 1550px;
    margin: 0 auto;
    padding: 0 30px;
}

.head-cta {
    display: inline-block;
    vertical-align: middle;
  background: var(--black);
  color: var(--white);
  text-transform: uppercase;
  font-weight: 600;
  padding: 10px 30px;
  font-size: 16px;
  height: 45px;
  margin: 0 0 0 5px;
    transition: all 0.3s ease-in-out;    
}

.head-cta:hover {
    display: inline-block;
  background: var(--green);
  color: var(--black);
    transition: all 0.3s ease-in-out;    
}

.home-hero {
    padding: 20px 0;
}

.home-hero h5 {
  font: 17px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0;
  padding: 0;
  line-height: 28px;
}

.hero-grid {
    width: 100%;
    display: grid;
    grid-template-columns: 550px auto;
    grid-column-gap: 75px;
    grid-row-gap: 75px;
    justify-items: stretch;
    align-items: center;
}

.hero-imgm img,
.hero-img img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}

.hero-imgm,
.hero-img {
    position: relative;
    padding: 30px;
    z-index: 1;
}

.hero-imgm {
    display: none;
}

.hero-imgm:before,
.hero-img:before {
    content: "";
    background: var(--green);
    width: 100px;
    height: 100px;
    top:0;
    left:0;
    position: absolute;
    z-index: -1;
}

.hero-imgm:after,
.hero-img:after {
    content: "";
    background: var(--yellow);
    width: 100px;
    height: 100px;
    bottom:0;
    right:0;
    position: absolute;
    border-radius: 50%;
    z-index: -1;
}

.hero-col.hc-text {
  padding: 0 100px 0 0;
}

.fancy {
    position: relative;
    display: inline-block;
    padding: 0 0 0 40px;
}

.fan::before {
  content: "";
  background: var(--yellow);
  width: 30px;
  height: 30px;
  left: 0;
top: 50%;
  transform: translateY(-50%);  
  position: absolute;
  z-index: -1;
}

.fan1::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 15px 26.0px 15px;
  border-color: transparent transparent #F1488A transparent;
  left: 0;
top: 50%;
  transform: translateY(-50%);  
  position: absolute;
  z-index: -1;
}

.fan2::before  {
    content: "";
    background: var(--yellow);
  width: 30px;
  height: 30px;
  left: 0;
top: 50%;
  transform: translateY(-50%);  
    position: absolute;
    border-radius: 50%;
    z-index: 0;
}

.fancy span {
    display: block;
    position: relative;
    z-index: 2;
}

.fan3::before {
  content: "";
  background: var(--orange);
  width: 30px;
  height: 30px;
  left: 0;
top: 50%;
  transform: translateY(-50%);  
  position: absolute;
  z-index: -1;
}

.fan4::before {
  content: "";
  background: var(--blue);
  width: 25px;
  height: 25px;
  left: 0;
top: 50%;
  transform: translateY(-50%) rotate(45deg);  
  position: absolute;
  z-index: 0;
 
}

.about-grid {
    width: 100%;
    display: grid;
    grid-template-columns: auto 400px;
    grid-column-gap: 75px;
    grid-row-gap: 75px;
    justify-items: stretch;
    align-items: center;
    padding: 0 30px;
}

.about-img {
  position: absolute;
  right: 40px;
  width: 400px;
  top: 50%;
  transform: translateY(-50%);
}

.about-img img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}

.about-grid p {
  margin: 0;
  line-height: 28px;
}

.yellow-section {
    background: var(--yellow);
    padding: 75px 0;
    margin: 50px auto;
}


.green-section {
    background: var(--green);
    padding: 75px 0;
}

.green-section h2 {
    color: var(--white);
     text-transform: uppercase;
    font-weight: 900;
    font-size: 30px;
    margin: 0 0 20px 0;   
    text-align: center;
}

.test-slider {
    margin: 50px auto;
}

.test-slide {
  display: inline-block;
  background: var(--white);
  padding: 30px 30px 10px 30px;
  margin: 0 25px;

}

.test-slide {
  font-size: 16px;
  line-height: 25px!important;
}

.test-auth {
    display: block;
    font-weight: 700;
    margin: 10px 0 0 0!important;
}

.test-stars {
    color: var(--yellow);
}

.green-section .slick-prev::before,
.green-section .slick-next::before {
  color: #fff !important;
}


.cta-button {
    display: inline-block;
  background: var(--pink);
  color: var(--white);
  text-transform: uppercase;
  font-weight: 600;
  padding: 12px 40px;
  font-size: 16px;
  margin: 30px auto 0 auto;
    transition: all 0.3s ease-in-out;    
}

.cta-button:hover {
    display: inline-block;
  background: var(--green);
  color: var(--black);
    transition: all 0.3s ease-in-out;    
}

.block-intro-center {
    text-align: center;
    margin: 0 auto;
    max-width: 800px;
}

.block-intro-center .cta-button {
  margin: 5px auto 0 auto;
}

.white-section {
    position: relative;
  padding: 75px 0;
  margin: 0 auto;
}

.contact-grid {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-column-gap: 75px;
    grid-row-gap: 75px;
    justify-items: stretch;
    align-items: initial;
    margin:50px auto;
	max-width:1200px;
}

.contact-col h2 {
  font: 25px 'TT Norms Pro', Helvetica , Arial, sans-serif;
  margin: 0 0 10px 0;
  padding: 0;
  font-weight: 600;
}

.contact-col p {
  margin: 0 0 10px 0;
}

input[type="submit"] {
  display:inline-block;
  background:var(--green);
  color:var(--black);
  text-transform:uppercase;
  padding:10px 40px;
	 
  margin:20px auto 0 auto;
  transition:all .3s ease-in-out;
	font: 16px 'TT Norms Pro',Helvetica,Arial,sans-serif;
	font-weight:600;
	border:0;
	cursor:pointer;
}
input[type="submit"]:hover {
  display:inline-block;
  background:var(--pink);
  color:var(--white);
  transition:all .3s ease-in-out
}

.res-div {
  position: relative;
  overflow: hidden;
  width: 100%;
  padding-top: 56.25%; 
	margin: 0 0 20px 0;
}

.res-iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.res-p {
	margin:0!important;
}
.wsc {
  padding: 25px 0;
}

.pink-section {
  background: var(--pink);
  position: relative;
  padding: 50px 0;
  color: var(--white);
}


.gallery-grid {
    text-align: center;
    max-width: 1550px;
    width: 100%;
    margin: 50px auto 0 auto;
}

.grid-item {
  padding: 15px;
  box-sizing: border-box;
    display:inline;
}

.grid-item img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
}




@media (max-width: 1800px) {
  .grid-item {
    width: 24.9%;
  }

.grid-sizer {
  width: 24.9%;
}

}


@media (max-width: 1500px) {
  .grid-item {
    width: 33.333%;
  }

.grid-sizer {
  width: 33.333%;
}

.grid-item {
  padding: 10px;
}

}


@media (max-width: 600px) {
  .grid-item {
    width: 50%;
    padding: 10px;
  }

.grid-sizer {
 width: 50%;
}

}


.fancybox__container {
  z-index: 999999!important;
}

.nf-form-hp {
  display: none;
}

label {
  color: var(--black);
  font: 16px 'TT Norms Pro',Helvetica,Arial,sans-serif;
  font-weight: 500;
  display: block;
  margin: 0 0 5px 0;
}


input[type="email"],
input[type="text"] {
  color: var(--black);
  font: 16px 'TT Norms Pro',Helvetica,Arial,sans-serif;
  font-weight: 400;
  display: block;
  margin: 0 0 25px 0;
  width: 100%;
  padding: 10px;
  border: 2px solid var(--pink);
}

textarea {
  color: var(--black);
  font: 16px 'TT Norms Pro',Helvetica,Arial,sans-serif;
  font-weight: 400;
  display: block;
  margin: 0 0 15px 0;
  width: 100%;
  padding: 10px;
  border: 2px solid var(--pink);
	height:150px;
}

.nf-error {
  color: #f24142;
  font-weight: 500;
  margin: -10px 0 15px 0;
}

.nf-form-fields-required {
  color: #f24142;
  font-weight: 500;
  margin: 0 0 20px 0;
}

/* 
==========================================================================
FOOTER
==========================================================================
*/

footer {
    clear:both;
    background: var(--black);
    color: var(--white);
    padding: 75px 0;
    text-align: center;
    text-transform: uppercase;
    font-size: 15px;
    font-weight: 700;
}

.foot-logo {
    width: 220px;
    margin: 0 auto 10px auto;
}

footer p {
    margin: 0;
}

.cta-footer {
    margin: 20px auto;
}

.link-green {
    color: var(--green);
    transition: all 0.3s ease-in-out;    
}

.link-green:hover {
  color: var(--white);
    transition: all 0.3s ease-in-out;    
}

.foot-adress {
    margin: 0 0 10px 0;
}

/* 
==========================================================================
MEDIA QUERIES
==========================================================================
*/


@media screen and (max-width: 1400px) {

.hero-col.hc-text {
  padding: 0;
}

.hero-grid {
  grid-template-columns: 550px auto;
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

}

@media screen and (max-width: 1250px) {
.hero-grid {
  grid-template-columns: 1fr 1.5fr;
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}
}


@media screen and (max-width: 1050px) {

  .hero-grid {
    grid-template-columns: auto;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    text-align: center;
  }

.hero-img {
    display: none;
}

.hero-imgm {
    display: block;
}

.about-grid {
  width: 100%;
  display: grid;
  grid-template-columns: auto;
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  justify-items: stretch;
  align-items: center;
  padding: 0;
  text-align: center;
}

.about-img {
  display: none;
}

.yellow-section {
	  padding: 50px 0 25px 0;
  margin: 50px auto 0 auto;
}

  .green-section {
    padding: 50px 0 75px 0;
  }


.white-section {
  padding: 50px 0;
}

.gallery-grid {
  margin: 30px auto 0 auto;
}

}


@media screen and (max-width: 950px) {
.contact-grid {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-items: stretch;
  align-items: initial;
  margin: 0 auto;
  max-width: 1200px;
}	
}



@media screen and (max-width: 850px) {

.inner {
    padding: 0 20px;
}

}


@media screen and (max-width: 700px) {
.contact-grid {
  width: 100%;
  display: grid;
  grid-template-columns: auto;
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}	
}	


@media screen and (max-width: 680px) {
.test-slider {
  margin: 30px auto;
}	
}	


@media screen and (max-width: 650px) {

h1 {
  font: 30px 'TT Norms Pro', Helvetica , Arial, sans-serif!important;
  margin: 0 0 10px 0;
  padding: 0;
  font-weight: 700!important;
}

}

@media screen and (max-width: 600px) {

.hsoc {
    display: none;
}

header {
  padding: 30px 0;
}

.hero-imgm {
  position: relative;
  padding: 20px;
  z-index: 1;
}

}


@media screen and (max-width: 550px) {

	* {line-height:1.5!important;}	
	
.fancy {
  padding: 0;
	margin: 0 0 10px 30px;
}

.fan::before,
.fan3::before {
    top: 8px;
    transform: unset;
    left: -30px;
    width: 20px;
    height: 20px;
}
	
	

.fan2::before,
.fan4::before {
    top: 13px;
    transform: unset;
    left: -30px;
    width: 20px;
    height: 20px;
}	
	

.fan1::before {
    border-width: 0 12.5px 21.7px 12.5px;
    top: 8px;
    transform: unset;
    left: -30px;    
}

.pink-section .fan2::before {
    top: 10px;

  }
	
	
}

@media screen and (max-width: 500px) {
.fan::before {	
    display: none;
}
.fan {
  padding: 0;
	margin: 0 0 10px 0px;
}

  .logo {
    width: 220px;
    margin: 0 auto;
  }

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

.head-grid {
  width: 100%;
  display: grid;
  grid-template-columns: auto;
  grid-column-gap: 0;
  grid-row-gap: 0;
  justify-items: stretch;
  align-items: center;
  text-align: center;
  margin: 0 auto;
}


.head-cta {
  display: block;
  vertical-align: middle;
  background: var(--pink);
  color: var(--white);
  text-transform: uppercase;
  font-weight: 600;
  padding: 15px 0;
  font-size: 16px;
  height: auto;
  margin: 0;
  transition: all 0.3s ease-in-out;
  position: fixed;
  width: 100%;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10;
}

.page-template-contact .head-cta {
  display: none;	
	}
	
footer {
  clear: both;
  background: var(--black);
  color: var(--white);
  padding: 50px 0 100px 0;
}
	
.page-template-contact footer {
  padding: 50px 0 50px 0;
}	
	
	
}



@media screen and (max-width: 320px) {

 .container {
    min-width:240px;
    width:100%;
 }
 
}