/*!
Theme Name: Spitfire
Author: Lukasz Sieron
Description: Spitfire website theme
Version: 1.0.0
License: MIT
License URI: https://mit-license.org/
Text Domain: spitfire
*/
/**
 * Breakpoints
 */
/**
 * Typography
 */
/**
 * Grid
 */
/**
 * Colors
 */
/**
 * Spacing
 */
/**
* Font Sizes
*/
/**
 * Components
 */
/**
 * Animations
 */
/*
 * Function to get spacings from the map
 */
.m-b-xl {
  margin-bottom: 80px;
}

.m-b-lg {
  margin-bottom: 60px;
}

.m-b-md {
  margin-bottom: 40px;
}

.m-b-sm {
  margin-bottom: 20px;
}

.m-b-xs {
  margin-bottom: 10px;
}

.m-b-none {
  margin-bottom: 0;
}

/*
 * Media query to respond to a minimum size (mobile first)
 */
/*
 * Media query to respond to a maximum size
 */
/*
 * Output font size in px/rem
 */
/*
 * Placeholder mixin for <input>
 */
/**
 * Clearfix
 */
/**
 * Default variables and helper mixins
 */
/**
 * Space between columns
 */
/**
 * Max width of container
 */
/**
 * Number of total columns
 */
/**
 * Breakpoints
 */
/**
 * Grid loop mixin
 */
/**
 * Clearfix
 */
/**
 * Grid scaffolding
 */
.container {
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 20px;
}
.container:before, .container:after {
  content: " ";
  display: table;
}
.container:after {
  clear: both;
}

.row {
  list-style: none;
  margin-left: -20px;
}
.row:not(.row--flex):before, .row:not(.row--flex):after {
  content: " ";
  display: table;
}
.row:not(.row--flex):after {
  clear: both;
}
.row.row--gutterless {
  margin-left: 0;
}
.row.row--flex {
  display: flex;
  flex-wrap: wrap;
}

.col {
  float: left;
  padding-left: 20px;
  box-sizing: border-box;
}
.row--gutterless .col {
  padding-left: 0;
}

/**
 * Columns generator
 */
@media only screen and (min-width: 1025px) {
  .col--lg-offset-0 {
    margin-left: 0%;
  }
  .row--reverse .col--lg-offset-0 {
    margin-left: 0;
    margin-right: 0%;
  }
  .col--lg-1 {
    width: 8.3333333333%;
  }
  .row--flex .col--lg-1 {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
    width: auto;
    float: none;
  }
  .col--lg-offset-1 {
    margin-left: 8.3333333333%;
  }
  .row--reverse .col--lg-offset-1 {
    margin-left: 0;
    margin-right: 8.3333333333%;
  }
  .col--lg-2 {
    width: 16.6666666667%;
  }
  .row--flex .col--lg-2 {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
    width: auto;
    float: none;
  }
  .col--lg-offset-2 {
    margin-left: 16.6666666667%;
  }
  .row--reverse .col--lg-offset-2 {
    margin-left: 0;
    margin-right: 16.6666666667%;
  }
  .col--lg-3 {
    width: 25%;
  }
  .row--flex .col--lg-3 {
    flex-basis: 25%;
    max-width: 25%;
    width: auto;
    float: none;
  }
  .col--lg-offset-3 {
    margin-left: 25%;
  }
  .row--reverse .col--lg-offset-3 {
    margin-left: 0;
    margin-right: 25%;
  }
  .col--lg-4 {
    width: 33.3333333333%;
  }
  .row--flex .col--lg-4 {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
    width: auto;
    float: none;
  }
  .col--lg-offset-4 {
    margin-left: 33.3333333333%;
  }
  .row--reverse .col--lg-offset-4 {
    margin-left: 0;
    margin-right: 33.3333333333%;
  }
  .col--lg-5 {
    width: 41.6666666667%;
  }
  .row--flex .col--lg-5 {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
    width: auto;
    float: none;
  }
  .col--lg-offset-5 {
    margin-left: 41.6666666667%;
  }
  .row--reverse .col--lg-offset-5 {
    margin-left: 0;
    margin-right: 41.6666666667%;
  }
  .col--lg-6 {
    width: 50%;
  }
  .row--flex .col--lg-6 {
    flex-basis: 50%;
    max-width: 50%;
    width: auto;
    float: none;
  }
  .col--lg-offset-6 {
    margin-left: 50%;
  }
  .row--reverse .col--lg-offset-6 {
    margin-left: 0;
    margin-right: 50%;
  }
  .col--lg-7 {
    width: 58.3333333333%;
  }
  .row--flex .col--lg-7 {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    width: auto;
    float: none;
  }
  .col--lg-offset-7 {
    margin-left: 58.3333333333%;
  }
  .row--reverse .col--lg-offset-7 {
    margin-left: 0;
    margin-right: 58.3333333333%;
  }
  .col--lg-8 {
    width: 66.6666666667%;
  }
  .row--flex .col--lg-8 {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
    width: auto;
    float: none;
  }
  .col--lg-offset-8 {
    margin-left: 66.6666666667%;
  }
  .row--reverse .col--lg-offset-8 {
    margin-left: 0;
    margin-right: 66.6666666667%;
  }
  .col--lg-9 {
    width: 75%;
  }
  .row--flex .col--lg-9 {
    flex-basis: 75%;
    max-width: 75%;
    width: auto;
    float: none;
  }
  .col--lg-offset-9 {
    margin-left: 75%;
  }
  .row--reverse .col--lg-offset-9 {
    margin-left: 0;
    margin-right: 75%;
  }
  .col--lg-10 {
    width: 83.3333333333%;
  }
  .row--flex .col--lg-10 {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
    width: auto;
    float: none;
  }
  .col--lg-offset-10 {
    margin-left: 83.3333333333%;
  }
  .row--reverse .col--lg-offset-10 {
    margin-left: 0;
    margin-right: 83.3333333333%;
  }
  .col--lg-11 {
    width: 91.6666666667%;
  }
  .row--flex .col--lg-11 {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
    width: auto;
    float: none;
  }
  .col--lg-offset-11 {
    margin-left: 91.6666666667%;
  }
  .row--reverse .col--lg-offset-11 {
    margin-left: 0;
    margin-right: 91.6666666667%;
  }
  .col--lg-12 {
    width: 100%;
  }
  .row--flex .col--lg-12 {
    flex-basis: 100%;
    max-width: 100%;
    width: auto;
    float: none;
  }
  .col--lg-offset-12 {
    margin-left: 100%;
  }
  .row--reverse .col--lg-offset-12 {
    margin-left: 0;
    margin-right: 100%;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .col--md-offset-0 {
    margin-left: 0%;
  }
  .row--reverse .col--md-offset-0 {
    margin-left: 0;
    margin-right: 0%;
  }
  .col--md-1 {
    width: 8.3333333333%;
  }
  .row--flex .col--md-1 {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
    width: auto;
    float: none;
  }
  .col--md-offset-1 {
    margin-left: 8.3333333333%;
  }
  .row--reverse .col--md-offset-1 {
    margin-left: 0;
    margin-right: 8.3333333333%;
  }
  .col--md-2 {
    width: 16.6666666667%;
  }
  .row--flex .col--md-2 {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
    width: auto;
    float: none;
  }
  .col--md-offset-2 {
    margin-left: 16.6666666667%;
  }
  .row--reverse .col--md-offset-2 {
    margin-left: 0;
    margin-right: 16.6666666667%;
  }
  .col--md-3 {
    width: 25%;
  }
  .row--flex .col--md-3 {
    flex-basis: 25%;
    max-width: 25%;
    width: auto;
    float: none;
  }
  .col--md-offset-3 {
    margin-left: 25%;
  }
  .row--reverse .col--md-offset-3 {
    margin-left: 0;
    margin-right: 25%;
  }
  .col--md-4 {
    width: 33.3333333333%;
  }
  .row--flex .col--md-4 {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
    width: auto;
    float: none;
  }
  .col--md-offset-4 {
    margin-left: 33.3333333333%;
  }
  .row--reverse .col--md-offset-4 {
    margin-left: 0;
    margin-right: 33.3333333333%;
  }
  .col--md-5 {
    width: 41.6666666667%;
  }
  .row--flex .col--md-5 {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
    width: auto;
    float: none;
  }
  .col--md-offset-5 {
    margin-left: 41.6666666667%;
  }
  .row--reverse .col--md-offset-5 {
    margin-left: 0;
    margin-right: 41.6666666667%;
  }
  .col--md-6 {
    width: 50%;
  }
  .row--flex .col--md-6 {
    flex-basis: 50%;
    max-width: 50%;
    width: auto;
    float: none;
  }
  .col--md-offset-6 {
    margin-left: 50%;
  }
  .row--reverse .col--md-offset-6 {
    margin-left: 0;
    margin-right: 50%;
  }
  .col--md-7 {
    width: 58.3333333333%;
  }
  .row--flex .col--md-7 {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    width: auto;
    float: none;
  }
  .col--md-offset-7 {
    margin-left: 58.3333333333%;
  }
  .row--reverse .col--md-offset-7 {
    margin-left: 0;
    margin-right: 58.3333333333%;
  }
  .col--md-8 {
    width: 66.6666666667%;
  }
  .row--flex .col--md-8 {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
    width: auto;
    float: none;
  }
  .col--md-offset-8 {
    margin-left: 66.6666666667%;
  }
  .row--reverse .col--md-offset-8 {
    margin-left: 0;
    margin-right: 66.6666666667%;
  }
  .col--md-9 {
    width: 75%;
  }
  .row--flex .col--md-9 {
    flex-basis: 75%;
    max-width: 75%;
    width: auto;
    float: none;
  }
  .col--md-offset-9 {
    margin-left: 75%;
  }
  .row--reverse .col--md-offset-9 {
    margin-left: 0;
    margin-right: 75%;
  }
  .col--md-10 {
    width: 83.3333333333%;
  }
  .row--flex .col--md-10 {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
    width: auto;
    float: none;
  }
  .col--md-offset-10 {
    margin-left: 83.3333333333%;
  }
  .row--reverse .col--md-offset-10 {
    margin-left: 0;
    margin-right: 83.3333333333%;
  }
  .col--md-11 {
    width: 91.6666666667%;
  }
  .row--flex .col--md-11 {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
    width: auto;
    float: none;
  }
  .col--md-offset-11 {
    margin-left: 91.6666666667%;
  }
  .row--reverse .col--md-offset-11 {
    margin-left: 0;
    margin-right: 91.6666666667%;
  }
  .col--md-12 {
    width: 100%;
  }
  .row--flex .col--md-12 {
    flex-basis: 100%;
    max-width: 100%;
    width: auto;
    float: none;
  }
  .col--md-offset-12 {
    margin-left: 100%;
  }
  .row--reverse .col--md-offset-12 {
    margin-left: 0;
    margin-right: 100%;
  }
}
@media only screen and (min-width: 481px) and (max-width:768px) {
  .col--sm-offset-0 {
    margin-left: 0%;
  }
  .row--reverse .col--sm-offset-0 {
    margin-left: 0;
    margin-right: 0%;
  }
  .col--sm-1 {
    width: 8.3333333333%;
  }
  .row--flex .col--sm-1 {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
    width: auto;
    float: none;
  }
  .col--sm-offset-1 {
    margin-left: 8.3333333333%;
  }
  .row--reverse .col--sm-offset-1 {
    margin-left: 0;
    margin-right: 8.3333333333%;
  }
  .col--sm-2 {
    width: 16.6666666667%;
  }
  .row--flex .col--sm-2 {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
    width: auto;
    float: none;
  }
  .col--sm-offset-2 {
    margin-left: 16.6666666667%;
  }
  .row--reverse .col--sm-offset-2 {
    margin-left: 0;
    margin-right: 16.6666666667%;
  }
  .col--sm-3 {
    width: 25%;
  }
  .row--flex .col--sm-3 {
    flex-basis: 25%;
    max-width: 25%;
    width: auto;
    float: none;
  }
  .col--sm-offset-3 {
    margin-left: 25%;
  }
  .row--reverse .col--sm-offset-3 {
    margin-left: 0;
    margin-right: 25%;
  }
  .col--sm-4 {
    width: 33.3333333333%;
  }
  .row--flex .col--sm-4 {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
    width: auto;
    float: none;
  }
  .col--sm-offset-4 {
    margin-left: 33.3333333333%;
  }
  .row--reverse .col--sm-offset-4 {
    margin-left: 0;
    margin-right: 33.3333333333%;
  }
  .col--sm-5 {
    width: 41.6666666667%;
  }
  .row--flex .col--sm-5 {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
    width: auto;
    float: none;
  }
  .col--sm-offset-5 {
    margin-left: 41.6666666667%;
  }
  .row--reverse .col--sm-offset-5 {
    margin-left: 0;
    margin-right: 41.6666666667%;
  }
  .col--sm-6 {
    width: 50%;
  }
  .row--flex .col--sm-6 {
    flex-basis: 50%;
    max-width: 50%;
    width: auto;
    float: none;
  }
  .col--sm-offset-6 {
    margin-left: 50%;
  }
  .row--reverse .col--sm-offset-6 {
    margin-left: 0;
    margin-right: 50%;
  }
  .col--sm-7 {
    width: 58.3333333333%;
  }
  .row--flex .col--sm-7 {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    width: auto;
    float: none;
  }
  .col--sm-offset-7 {
    margin-left: 58.3333333333%;
  }
  .row--reverse .col--sm-offset-7 {
    margin-left: 0;
    margin-right: 58.3333333333%;
  }
  .col--sm-8 {
    width: 66.6666666667%;
  }
  .row--flex .col--sm-8 {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
    width: auto;
    float: none;
  }
  .col--sm-offset-8 {
    margin-left: 66.6666666667%;
  }
  .row--reverse .col--sm-offset-8 {
    margin-left: 0;
    margin-right: 66.6666666667%;
  }
  .col--sm-9 {
    width: 75%;
  }
  .row--flex .col--sm-9 {
    flex-basis: 75%;
    max-width: 75%;
    width: auto;
    float: none;
  }
  .col--sm-offset-9 {
    margin-left: 75%;
  }
  .row--reverse .col--sm-offset-9 {
    margin-left: 0;
    margin-right: 75%;
  }
  .col--sm-10 {
    width: 83.3333333333%;
  }
  .row--flex .col--sm-10 {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
    width: auto;
    float: none;
  }
  .col--sm-offset-10 {
    margin-left: 83.3333333333%;
  }
  .row--reverse .col--sm-offset-10 {
    margin-left: 0;
    margin-right: 83.3333333333%;
  }
  .col--sm-11 {
    width: 91.6666666667%;
  }
  .row--flex .col--sm-11 {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
    width: auto;
    float: none;
  }
  .col--sm-offset-11 {
    margin-left: 91.6666666667%;
  }
  .row--reverse .col--sm-offset-11 {
    margin-left: 0;
    margin-right: 91.6666666667%;
  }
  .col--sm-12 {
    width: 100%;
  }
  .row--flex .col--sm-12 {
    flex-basis: 100%;
    max-width: 100%;
    width: auto;
    float: none;
  }
  .col--sm-offset-12 {
    margin-left: 100%;
  }
  .row--reverse .col--sm-offset-12 {
    margin-left: 0;
    margin-right: 100%;
  }
}
@media only screen and (max-width: 480px) {
  .col--xs-offset-0 {
    margin-left: 0%;
  }
  .row--reverse .col--xs-offset-0 {
    margin-left: 0;
    margin-right: 0%;
  }
  .col--xs-1 {
    width: 8.3333333333%;
  }
  .row--flex .col--xs-1 {
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
    width: auto;
    float: none;
  }
  .col--xs-offset-1 {
    margin-left: 8.3333333333%;
  }
  .row--reverse .col--xs-offset-1 {
    margin-left: 0;
    margin-right: 8.3333333333%;
  }
  .col--xs-2 {
    width: 16.6666666667%;
  }
  .row--flex .col--xs-2 {
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
    width: auto;
    float: none;
  }
  .col--xs-offset-2 {
    margin-left: 16.6666666667%;
  }
  .row--reverse .col--xs-offset-2 {
    margin-left: 0;
    margin-right: 16.6666666667%;
  }
  .col--xs-3 {
    width: 25%;
  }
  .row--flex .col--xs-3 {
    flex-basis: 25%;
    max-width: 25%;
    width: auto;
    float: none;
  }
  .col--xs-offset-3 {
    margin-left: 25%;
  }
  .row--reverse .col--xs-offset-3 {
    margin-left: 0;
    margin-right: 25%;
  }
  .col--xs-4 {
    width: 33.3333333333%;
  }
  .row--flex .col--xs-4 {
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
    width: auto;
    float: none;
  }
  .col--xs-offset-4 {
    margin-left: 33.3333333333%;
  }
  .row--reverse .col--xs-offset-4 {
    margin-left: 0;
    margin-right: 33.3333333333%;
  }
  .col--xs-5 {
    width: 41.6666666667%;
  }
  .row--flex .col--xs-5 {
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
    width: auto;
    float: none;
  }
  .col--xs-offset-5 {
    margin-left: 41.6666666667%;
  }
  .row--reverse .col--xs-offset-5 {
    margin-left: 0;
    margin-right: 41.6666666667%;
  }
  .col--xs-6 {
    width: 50%;
  }
  .row--flex .col--xs-6 {
    flex-basis: 50%;
    max-width: 50%;
    width: auto;
    float: none;
  }
  .col--xs-offset-6 {
    margin-left: 50%;
  }
  .row--reverse .col--xs-offset-6 {
    margin-left: 0;
    margin-right: 50%;
  }
  .col--xs-7 {
    width: 58.3333333333%;
  }
  .row--flex .col--xs-7 {
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
    width: auto;
    float: none;
  }
  .col--xs-offset-7 {
    margin-left: 58.3333333333%;
  }
  .row--reverse .col--xs-offset-7 {
    margin-left: 0;
    margin-right: 58.3333333333%;
  }
  .col--xs-8 {
    width: 66.6666666667%;
  }
  .row--flex .col--xs-8 {
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
    width: auto;
    float: none;
  }
  .col--xs-offset-8 {
    margin-left: 66.6666666667%;
  }
  .row--reverse .col--xs-offset-8 {
    margin-left: 0;
    margin-right: 66.6666666667%;
  }
  .col--xs-9 {
    width: 75%;
  }
  .row--flex .col--xs-9 {
    flex-basis: 75%;
    max-width: 75%;
    width: auto;
    float: none;
  }
  .col--xs-offset-9 {
    margin-left: 75%;
  }
  .row--reverse .col--xs-offset-9 {
    margin-left: 0;
    margin-right: 75%;
  }
  .col--xs-10 {
    width: 83.3333333333%;
  }
  .row--flex .col--xs-10 {
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
    width: auto;
    float: none;
  }
  .col--xs-offset-10 {
    margin-left: 83.3333333333%;
  }
  .row--reverse .col--xs-offset-10 {
    margin-left: 0;
    margin-right: 83.3333333333%;
  }
  .col--xs-11 {
    width: 91.6666666667%;
  }
  .row--flex .col--xs-11 {
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
    width: auto;
    float: none;
  }
  .col--xs-offset-11 {
    margin-left: 91.6666666667%;
  }
  .row--reverse .col--xs-offset-11 {
    margin-left: 0;
    margin-right: 91.6666666667%;
  }
  .col--xs-12 {
    width: 100%;
  }
  .row--flex .col--xs-12 {
    flex-basis: 100%;
    max-width: 100%;
    width: auto;
    float: none;
  }
  .col--xs-offset-12 {
    margin-left: 100%;
  }
  .row--reverse .col--xs-offset-12 {
    margin-left: 0;
    margin-right: 100%;
  }
}
* {
  background-color: transparent;
  border: 0;
  box-sizing: border-box;
  font: inherit;
  margin: 0;
  padding: 0;
}

html {
  background-color: white;
  font-size: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
}

input,
select,
textarea,
button {
  color: inherit;
  display: inline-block;
}
input[disabled],
select[disabled],
textarea[disabled],
button[disabled] {
  cursor: not-allowed;
}

button {
  cursor: pointer;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}
table th,
table td {
  text-align: left;
}

.visible-lg {
  display: none;
}
@media only screen and (min-width: 1025px) {
  .visible-lg {
    display: block !important;
  }
}

@media only screen and (min-width: 1025px) {
  .hidden-lg {
    display: none !important;
  }
}

.visible-md {
  display: none;
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .visible-md {
    display: block !important;
  }
}

@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .hidden-md {
    display: none !important;
  }
}

.visible-sm {
  display: none;
}
@media only screen and (min-width: 481px) and (max-width:768px) {
  .visible-sm {
    display: block !important;
  }
}

@media only screen and (min-width: 481px) and (max-width:768px) {
  .hidden-sm {
    display: none !important;
  }
}

.visible-xs {
  display: none;
}
@media only screen and (max-width: 480px) {
  .visible-xs {
    display: block !important;
  }
}

@media only screen and (max-width: 480px) {
  .hidden-xs {
    display: none !important;
  }
}

/**
* Clearing and floating
*/
.alignleft,
.float-left {
  float: left;
}
img .alignleft,
img .float-left {
  margin-right: 24px;
}

.alignright,
.float-right {
  float: right;
}
img .alignright,
img .float-right {
  margin-left: 24px;
}

.aligncenter,
.float-center {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
img .aligncenter,
img .float-center {
  margin-bottom: 24px;
}

.clearfix:before, .clearfix:after {
  content: " ";
  display: table;
}
.clearfix:after {
  clear: both;
}

/**
* Text aligments
*/
.align-text-left {
  text-align: left;
}

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

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

/**
* Aligments
*/
.items-center {
  align-items: center;
}

/**
 * Elements visibility
 */
.visible-on-mobile {
  display: none !important;
}
@media screen and (max-width: 768px) {
  .visible-on-mobile {
    display: block !important;
  }
}

.visible-on-tablet {
  display: none !important;
}
@media screen and (max-width: 1024px) {
  .visible-on-tablet {
    display: block !important;
  }
}
@media screen and (max-width: 768px) {
  .visible-on-tablet {
    display: none !important;
  }
}

@media screen and (max-width: 1024px) {
  .visible-on-desktop {
    display: none !important;
  }
}

/**
 * Accessibility
 */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/**
 * Breakpoints
 */
/**
 * Spacing
 */
.py-xl {
  padding-top: 80px;
  padding-bottom: 80px;
}

.pt-xl {
  padding-top: 80px;
}

.pb-xl {
  padding-bottom: 80px;
}

.px-xl {
  padding-left: 80px;
  padding-right: 80px;
}

.pl-xl {
  padding-left: 80px;
}

.pr-xl {
  padding-right: 80px;
}

.my-xl {
  margin-top: 80px;
  margin-bottom: 80px;
}

.mt-xl {
  margin-top: 80px;
}

.mb-xl {
  margin-bottom: 80px;
}

.mx-xl {
  margin-left: 80px;
  margin-right: 80px;
}

.ml-xl {
  margin-left: 80px;
}

.mr-xl {
  margin-right: 80px;
}

.py-lg {
  padding-top: 60px;
  padding-bottom: 60px;
}

.pt-lg {
  padding-top: 60px;
}

.pb-lg {
  padding-bottom: 60px;
}

.px-lg {
  padding-left: 60px;
  padding-right: 60px;
}

.pl-lg {
  padding-left: 60px;
}

.pr-lg {
  padding-right: 60px;
}

.my-lg {
  margin-top: 60px;
  margin-bottom: 60px;
}

.mt-lg {
  margin-top: 60px;
}

.mb-lg {
  margin-bottom: 60px;
}

.mx-lg {
  margin-left: 60px;
  margin-right: 60px;
}

.ml-lg {
  margin-left: 60px;
}

.mr-lg {
  margin-right: 60px;
}

.py-md {
  padding-top: 40px;
  padding-bottom: 40px;
}

.pt-md {
  padding-top: 40px;
}

.pb-md {
  padding-bottom: 40px;
}

.px-md {
  padding-left: 40px;
  padding-right: 40px;
}

.pl-md {
  padding-left: 40px;
}

.pr-md {
  padding-right: 40px;
}

.my-md {
  margin-top: 40px;
  margin-bottom: 40px;
}

.mt-md {
  margin-top: 40px;
}

.mb-md {
  margin-bottom: 40px;
}

.mx-md {
  margin-left: 40px;
  margin-right: 40px;
}

.ml-md {
  margin-left: 40px;
}

.mr-md {
  margin-right: 40px;
}

.py-sm {
  padding-top: 20px;
  padding-bottom: 20px;
}

.pt-sm {
  padding-top: 20px;
}

.pb-sm {
  padding-bottom: 20px;
}

.px-sm {
  padding-left: 20px;
  padding-right: 20px;
}

.pl-sm {
  padding-left: 20px;
}

.pr-sm {
  padding-right: 20px;
}

.my-sm {
  margin-top: 20px;
  margin-bottom: 20px;
}

.mt-sm {
  margin-top: 20px;
}

.mb-sm {
  margin-bottom: 20px;
}

.mx-sm {
  margin-left: 20px;
  margin-right: 20px;
}

.ml-sm {
  margin-left: 20px;
}

.mr-sm {
  margin-right: 20px;
}

.py-xs {
  padding-top: 10px;
  padding-bottom: 10px;
}

.pt-xs {
  padding-top: 10px;
}

.pb-xs {
  padding-bottom: 10px;
}

.px-xs {
  padding-left: 10px;
  padding-right: 10px;
}

.pl-xs {
  padding-left: 10px;
}

.pr-xs {
  padding-right: 10px;
}

.my-xs {
  margin-top: 10px;
  margin-bottom: 10px;
}

.mt-xs {
  margin-top: 10px;
}

.mb-xs {
  margin-bottom: 10px;
}

.mx-xs {
  margin-left: 10px;
  margin-right: 10px;
}

.ml-xs {
  margin-left: 10px;
}

.mr-xs {
  margin-right: 10px;
}

.py-none {
  padding-top: 0;
  padding-bottom: 0;
}

.pt-none {
  padding-top: 0;
}

.pb-none {
  padding-bottom: 0;
}

.px-none {
  padding-left: 0;
  padding-right: 0;
}

.pl-none {
  padding-left: 0;
}

.pr-none {
  padding-right: 0;
}

.my-none {
  margin-top: 0;
  margin-bottom: 0;
}

.mt-none {
  margin-top: 0;
}

.mb-none {
  margin-bottom: 0;
}

.mx-none {
  margin-left: 0;
  margin-right: 0;
}

.ml-none {
  margin-left: 0;
}

.mr-none {
  margin-right: 0;
}

/**
 * Fonts
 */
.font-base {
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.font-alt {
  font-family: "Anton", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/**
 * Font Sizes
 */
.text-2xl {
  font-size: 32px;
  font-size: 2rem;
}

.text-xl {
  font-size: 24px;
  font-size: 1.5rem;
}

.text-lg {
  font-size: 22px;
  font-size: 1.375rem;
}

.text-md {
  font-size: 18px;
  font-size: 1.125rem;
}

.text-sm {
  font-size: 16px;
  font-size: 1rem;
}

.text-xs {
  font-size: 14px;
  font-size: 0.875rem;
}

/**
 * Colors
 */
.text-base {
  color: #fdffff;
}

.bg-base {
  background-color: #fdffff;
}

.text-background {
  color: #fff;
}

.bg-background {
  background-color: #fff;
}

.text-bg-alt {
  color: #070707;
}

.bg-bg-alt {
  background-color: #070707;
}

.text-brand {
  color: #444;
}

.bg-brand {
  background-color: #444;
}

.text-brand-orange {
  color: #f76528;
}

.bg-brand-orange {
  background-color: #f76528;
}

.text-brand-darkorange {
  color: #FD6420;
}

.bg-brand-darkorange {
  background-color: #FD6420;
}

.text-success {
  color: #5CB85C;
}

.bg-success {
  background-color: #5CB85C;
}

.text-info {
  color: #444;
}

.bg-info {
  background-color: #444;
}

.text-warning {
  color: #F0AD4E;
}

.bg-warning {
  background-color: #F0AD4E;
}

.text-danger {
  color: #D9534F;
}

.bg-danger {
  background-color: #D9534F;
}

body {
  color: #fdffff;
  background-color: #070707;
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  line-height: 1.5;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
          text-size-adjust: none;
  font-size: 16px;
  font-size: 1rem;
}
@media screen and (max-width: 1280px) {
  body {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 1024px) {
  body {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  body {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 480px) {
  body {
    font-size: 16px;
    font-size: 1rem;
  }
}
body.menu-open {
  overflow: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Anton", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

h1 {
  font-size: 42px;
  font-size: 2.625rem;
}
@media screen and (max-width: 1280px) {
  h1 {
    font-size: 37px;
    font-size: 2.3125rem;
  }
}
@media screen and (max-width: 1024px) {
  h1 {
    font-size: 32px;
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  h1 {
    font-size: 27px;
    font-size: 1.6875rem;
  }
}
@media screen and (max-width: 480px) {
  h1 {
    font-size: 22px;
    font-size: 1.375rem;
  }
}

h2 {
  font-size: 40px;
  font-size: 2.5rem;
}
@media screen and (max-width: 1280px) {
  h2 {
    font-size: 35px;
    font-size: 2.1875rem;
  }
}
@media screen and (max-width: 1024px) {
  h2 {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
@media screen and (max-width: 768px) {
  h2 {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media screen and (max-width: 480px) {
  h2 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}

h3 {
  font-size: 35px;
  font-size: 2.1875rem;
}
@media screen and (max-width: 1280px) {
  h3 {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
@media screen and (max-width: 1024px) {
  h3 {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media screen and (max-width: 768px) {
  h3 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 480px) {
  h3 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

h4 {
  font-size: 25px;
  font-size: 1.5625rem;
}
@media screen and (max-width: 1280px) {
  h4 {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media screen and (max-width: 1024px) {
  h4 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  h4 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 480px) {
  h4 {
    font-size: 16px;
    font-size: 1rem;
  }
}

h5 {
  font-size: 25px;
  font-size: 1.5625rem;
}
@media screen and (max-width: 1280px) {
  h5 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 1024px) {
  h5 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 768px) {
  h5 {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 480px) {
  h5 {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

h6 {
  font-size: 20px;
  font-size: 1.25rem;
}
@media screen and (max-width: 1280px) {
  h6 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 1024px) {
  h6 {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  h6 {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 480px) {
  h6 {
    font-size: 12px;
    font-size: 0.75rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
hr,
ul,
ol,
dl {
  margin-bottom: 20px;
}
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
p:last-child,
hr:last-child,
ul:last-child,
ol:last-child,
dl:last-child {
  margin-bottom: 0;
}

/**
 * Basic styles for links
 */
a {
  color: #fdffff;
  text-decoration: none;
}

a[href^=tel] {
  font-size: inherit;
  font-family: inherit;
  color: inherit;
  text-decoration: none;
  font-style: inherit;
}

/**
 * Rules
 */
hr {
  height: 1px;
  background-color: #fdffff;
}

.col:empty {
  min-height: 1px;
}

.grid {
  display: grid;
  grid-gap: 24px;
}
@media screen and (max-width: 768px) {
  .grid {
    grid-gap: 12px;
  }
}
@media only screen and (min-width: 1025px) {
  .grid.grid--lg-1x {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid.grid--lg-2x {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid.grid--lg-3x {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid.grid--lg-4x {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid.grid--lg-5x {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .grid.grid--lg-6x {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .grid.grid--md-1x {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid.grid--md-2x {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid.grid--md-3x {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid.grid--md-4x {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid.grid--md-5x {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .grid.grid--md-6x {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
@media only screen and (min-width: 481px) and (max-width:768px) {
  .grid.grid--sm-1x {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid.grid--sm-2x {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid.grid--sm-3x {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid.grid--sm-4x {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid.grid--sm-5x {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .grid.grid--sm-6x {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}
@media only screen and (max-width: 480px) {
  .grid.grid--xs-1x {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid.grid--xs-2x {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid.grid--xs-3x {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid.grid--xs-4x {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid.grid--xs-5x {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .grid.grid--xs-6x {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

/**
 * This file contains all @font-face declarations, if any.
 */
@font-face {
  font-family: "Alfa Slab One";
  src: url("../spitfire/assets/fonts/AlfaSlabOne-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Poppins";
  src: url("../spitfire/assets/fonts/Poppins-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Poppins";
  src: url("../spitfire/assets/fonts/Poppins-Bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Poppins";
  src: url("../spitfire/assets/fonts/Poppins-Italic.ttf") format("truetype");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "Poppins";
  src: url("../spitfire/assets/fonts/Poppins-BoldItalic.ttf") format("truetype");
  font-weight: bold;
  font-style: italic;
}
@font-face {
  font-family: "Inter";
  src: url("../spitfire/assets/fonts/Inter-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Inter";
  src: url("../spitfire/assets/fonts/Inter-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: "Inter";
  src: url("../spitfire/assets/fonts/Inter-Bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Inter";
  src: url("../spitfire/assets/fonts/Inter-Italic.ttf") format("truetype");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "Anton";
  src: url("../spitfire/assets/fonts/Anton-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

/**
 * Responsive images
 */
.is-fluid {
  display: block;
  width: 100%;
  height: auto;
}

*:focus {
  outline: 0;
}

input,
select,
textarea {
  background-color: #fff;
  border: solid 1px #fdffff;
  border-radius: 0;
  color: #070707;
  line-height: 36px;
  height: 36px;
  padding: 0 12px;
  width: 100%;
}

input[type=checkbox],
input[type=radio] {
  background: transparent;
  border: 0;
  line-height: normal;
  height: auto;
  width: auto;
}

input[type=file] {
  line-height: normal;
  height: auto;
  padding: 6px 12px;
}

input[type=submit] {
  border-radius: 0;
}

input[disabled] {
  background-color: whitesmoke;
  cursor: not-allowed;
}

select {
  line-height: normal;
  padding: 0;
  padding-left: 12px;
}

textarea {
  min-height: 96px;
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

/**
 * Form utility classes
 */
.form--inline .form__group {
  display: inline-block;
}

.form .form__group {
  display: block;
  margin-bottom: 24px;
}
.form .form__group .form__label {
  display: block;
  margin-bottom: 12px;
}

.wpforms-error-container {
  display: none !important;
  color: white !important;
}

.wpforms-container {
  max-width: 1240px;
}

.wpforms-field-label {
  color: #FD6420 !important;
}

.wpforms-field-required {
  border: 2px solid #FD6420 !important;
}

textarea {
  border: 2px solid #FD6420 !important;
}

.wpforms-field-medium {
  max-width: 100% !important;
}

.wpforms-submit {
  background: #f76528 !important;
  color: white !important;
  border: 2px solid #f76528 !important;
  padding: 12px 36px;
  font-weight: bold;
  text-transform: uppercase;
  transition: background-color 0.3s ease-in-out;
}
.wpforms-submit:hover {
  border: 2px solid #FD6420 !important;
  background: #FD6420 !important;
}

label {
  color: white !important;
}

ul,
ol {
  margin-left: 24px;
}

li > ul,
li > ol {
  margin-bottom: 0;
}

.list--unstyled {
  margin-left: 0;
  list-style: none;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

small {
  font-size: 0.75em;
}

.header {
  padding: 18px 40px;
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
  z-index: 1000;
}
.header__content {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
.header__left {
  display: flex;
  align-items: center;
  gap: 40px;
}
.header__socials {
  display: flex;
  gap: 20px;
}
.header__socials a.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.25s ease, color 0.25s ease;
}
.header__socials a.social-icon svg {
  width: 29px;
  height: 30px;
  transition: transform 0.25s ease, fill 0.25s ease;
}
.header__socials a.social-icon svg rect {
  fill: white;
  transition: fill 0.25s ease;
}
.header__socials a.social-icon svg path {
  fill: black;
  transition: fill 0.25s ease;
}
.header__socials a.social-icon:hover {
  transform: scale(1.1);
}
.header__socials a.social-icon:hover svg rect {
  fill: #f76528;
}
.header__socials a.social-icon:hover svg path {
  fill: white;
}
.header__mobile {
  display: none;
}
@media screen and (max-width: 1000px) {
  .header__mobile {
    display: flex;
    gap: 24px;
    align-items: center;
  }
}
.header__nav {
  margin-left: -90px;
}
@media screen and (max-width: 1000px) {
  .header__left, .header__socials, .header__nav {
    display: none;
  }
}
.header .header__logo--mobile {
  display: none;
}
@media screen and (max-width: 1000px) {
  .header .header__logo--mobile {
    display: block;
  }
}
@media screen and (max-width: 450px) {
  .header .header__logo--mobile {
    display: none;
  }
}
.header__other {
  display: flex;
}

.header__mobile-nav {
  z-index: 100;
  display: none;
}
.header__mobile-nav nav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 24px;
}
@media screen and (max-width: 1000px) {
  .header__mobile-nav nav {
    background: url("/wp-content/themes/spitfire/img/mobile-nav-bg.png") repeat;
    animation: moveBackground 10s linear infinite;
  }
}
@media screen and (max-width: 1000px) {
  .header__mobile-nav {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    background-color: #070707;
  }
  .header__mobile-nav nav {
    display: flex;
    flex-direction: column;
    height: 100%;
    align-items: center;
    justify-content: center;
  }
  .header__mobile-nav nav .nav {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .header__mobile-nav nav .nav li {
    margin: 0;
    margin-bottom: 20px;
  }
}

@keyframes moveBackground {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 0 -323px;
  }
}
.footer {
  margin-top: 48px;
}
.footer__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
}
.footer__main {
  width: 100%;
}
.footer__map {
  margin-left: 0;
  width: 100%;
  height: 495px;
  background: url("/wp-content/themes/spitfire/assets/images/map.png") no-repeat center center;
  background-size: cover;
  border-bottom: 4px solid #FD6420;
}
.footer__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.footer__logo {
  width: 100%;
  max-width: 220px;
  margin-top: 20px;
}
.footer__socials {
  display: flex;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .footer__socials {
    gap: 10px;
  }
}
.footer__socials a.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.25s ease;
}
.footer__socials a.social-icon svg {
  width: 29px;
  height: 30px;
  transition: transform 0.25s ease, fill 0.25s ease;
}
.footer__socials a.social-icon svg rect {
  fill: white;
  transition: fill 0.25s ease;
}
.footer__socials a.social-icon svg path {
  fill: black;
  transition: fill 0.25s ease;
}
.footer__socials a.social-icon:hover {
  transform: scale(1.1);
}
.footer__socials a.social-icon:hover svg rect {
  fill: #f76528;
}
.footer__socials a.social-icon:hover svg path {
  fill: white;
}
.footer__address {
  text-align: center;
  font-size: 14px;
}
.footer__phone {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 21px;
}
@media screen and (max-width: 768px) {
  .footer__email {
    margin-bottom: 30px;
  }
}
.footer__navigation {
  display: flex;
}
.footer__copyright {
  text-align: center;
  padding: 12px 0;
}

.section {
  padding: 100px 20px;
}
@media screen and (max-width: 768px) {
  .section {
    padding: 80px 20px;
  }
}
.section + .bg-logo {
  background-image: url("/wp-content/themes/spitfire/assets/images/spitfire-logo-bg.svg");
  background-repeat: space;
  background-position: center center;
  background-size: 1200px auto;
}
.section.bg-logo {
  background-image: url("/wp-content/themes/spitfire/assets/images/spitfire-logo-bg.svg");
  background-repeat: space;
  background-position: center center;
  background-size: 1200px auto;
}
.section--align-center {
  text-align: center;
  align-items: center;
  justify-content: center;
}
.section--text-center {
  text-align: center;
}
.section--shop-hero {
  background: linear-gradient(180deg, #000000 -11.07%, rgba(0, 0, 0, 0.543269) 44.74%, rgba(0, 0, 0, 0) 100%), url("/wp-content/themes/spitfire/img/spitfire-shop.jpg") no-repeat center center;
  background-size: cover;
}
.section--drinks {
  position: relative;
  overflow: hidden;
}
.section--drinks::before {
  content: "";
  position: absolute;
  display: initial;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 48.24%, #000000 94.57%), url("/wp-content/themes/spitfire/assets/images/ben-drinks.png") no-repeat center center;
  background-size: cover;
  background-blend-mode: hard-light;
  opacity: 0.25;
  z-index: 0;
}
.section--drinks > * {
  position: relative;
  z-index: 1;
}
.section--drinks .beer-companies {
  display: flex;
  justify-content: center;
  gap: 80px;
}
@media screen and (max-width: 768px) {
  .section--drinks .beer-companies {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
}
.section--drinks .beer-companies .beer-company {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.section--reviews .stars {
  display: flex;
  justify-content: center;
  gap: 12px;
  /* Star wave animation */
}
@media screen and (max-width: 768px) {
  .section--reviews .stars {
    gap: 8px;
  }
}
.section--reviews .stars .star {
  animation: starBounce 2s ease-in-out infinite; /* longer total time = pause */
}
.section--reviews .stars .star:nth-child(1) {
  animation-delay: 0s;
}
.section--reviews .stars .star:nth-child(2) {
  animation-delay: 0.1s;
}
.section--reviews .stars .star:nth-child(3) {
  animation-delay: 0.2s;
}
.section--reviews .stars .star:nth-child(4) {
  animation-delay: 0.3s;
}
.section--reviews .stars .star:nth-child(5) {
  animation-delay: 0.4s;
}
@keyframes starBounce {
  0%, 20% {
    transform: translateY(0);
  }
  30% {
    transform: translateY(-10px);
  } /* jump up */
  40% {
    transform: translateY(0);
  } /* land */
  100% {
    transform: translateY(0);
  } /* pause until restart */
}
.section--reviews .reviews {
  max-width: 1240px;
  margin: 0 auto;
}
.section--reviews .reviews .review {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 20px;
  min-height: 400px;
  padding: 60px 40px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .section--reviews .reviews .review {
    padding: 60px 20px;
    min-height: 300px;
  }
}
.section--reviews .reviews .review__logo {
  height: 40px;
}
.section--reviews .reviews .review__text {
  font-weight: bold;
}
.section--reviews .reviews .review__separator {
  max-width: 32px;
  margin: 10px auto;
}
.section--reviews .reviews .review::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 61px;
  height: 39px;
  background: url("/wp-content/themes/spitfire/assets/icons/quote.svg") no-repeat center center;
  background-size: contain;
  z-index: 1;
}
.section__separator {
  max-width: 1240px;
  background-color: #FCFCFC;
  margin: 0 auto;
}
.section__ribs-promo {
  display: flex;
  justify-content: center;
  position: relative;
  overflow: hidden;
  max-width: 850px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .section__ribs-promo {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}
.section__ribs-promo--image {
  max-width: 352px;
  transform: rotate(-14deg) translateX(70px) translateY(20px);
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .section__ribs-promo--image {
    transform: rotate(-14deg) translateX(0px) translateY(20px);
    max-width: 100%;
  }
}
.section__ribs-promo--text {
  padding: 40px;
  text-align: initial;
}
@media screen and (max-width: 768px) {
  .section__ribs-promo--text {
    text-align: center;
  }
}
.section__ribs-promo--btn-cont {
  display: flex;
  gap: 20px;
  align-items: end;
}
@media screen and (max-width: 1024px) {
  .section__ribs-promo--btn-cont {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
}
.section__ribs-promo--btn-cont p {
  font-size: 14px;
  text-transform: uppercase;
  color: #85878A;
}
.section--menu-hero {
  padding-bottom: 0px;
}
.section--menu .row {
  max-width: 1240px;
  margin: 0 auto;
}
.section--bookings {
  background: linear-gradient(180deg, #000000 -11.07%, rgba(0, 0, 0, 0.543269) 44.74%, rgba(0, 0, 0, 0) 100%), url("/wp-content/themes/spitfire/assets/images/spitfire-tables.png") no-repeat center center;
}
.section--brisket-promo {
  padding: 0 20px;
  overflow: hidden;
}
.section .row {
  margin-bottom: 80px;
}
.section .row:last-child {
  margin-bottom: 0;
}

.bookings .brisket-promo {
  position: relative;
  padding: 120px 320px;
  background: linear-gradient(0deg, #000000 50.07%, rgba(0, 0, 0, 0.543269) 70.74%, rgba(0, 0, 0, 0) 100%), url("/wp-content/themes/spitfire/assets/images/noise-bg.png") no-repeat center center;
}
@media screen and (max-width: 1280px) {
  .bookings .brisket-promo {
    padding: 120px 0px;
  }
}
@media screen and (max-width: 1600px) {
  .bookings .brisket-promo {
    padding: 120px 200px;
  }
}
@media screen and (max-width: 1024px) {
  .bookings .brisket-promo {
    padding: 120px 60px;
  }
}
@media screen and (max-width: 768px) {
  .bookings .brisket-promo {
    padding: 40px 0px;
  }
}
.bookings .brisket-promo__box {
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 610px;
}
@media screen and (max-width: 1024px) {
  .bookings .brisket-promo__icon {
    margin: 0 auto;
  }
}
.bookings .brisket-promo__image {
  position: absolute;
  top: 0;
  right: -20px;
  max-width: 800px;
}
@media screen and (max-width: 1400px) {
  .bookings .brisket-promo__image {
    right: -160px;
  }
}
@media screen and (max-width: 1280px) {
  .bookings .brisket-promo__image {
    position: static;
    transform: scaleX(-1.2);
    margin-top: 40px;
  }
}

.hero-slideshow {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 763px;
  text-align: center;
  /* Different movement per slide */
}
.hero-slideshow .slideshow-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  animation: fadeSlide 12s infinite ease-in-out, kenBurns 12s infinite linear;
}
.hero-slideshow .slideshow-slide:nth-child(1) {
  animation-delay: 0s, 0s;
  animation-name: fadeSlide, kenBurnsLeft;
}
.hero-slideshow .slideshow-slide:nth-child(2) {
  animation-delay: 4s, 4s;
  animation-name: fadeSlide, kenBurnsRight;
}
.hero-slideshow .slideshow-slide:nth-child(3) {
  animation-delay: 8s, 8s;
  animation-name: fadeSlide, kenBurnsUp;
}
.hero-slideshow .row {
  position: relative;
  z-index: 2;
}

/* Crossfade animation (unchanged, no black gap) */
@keyframes fadeSlide {
  0% {
    opacity: 0;
  }
  5% {
    opacity: 1;
  }
  30% {
    opacity: 1;
  }
  35% {
    opacity: 1;
  }
  40% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
/* Ken Burns variations */
@keyframes kenBurnsLeft {
  0% {
    transform: scale(1.1) translateX(5%);
  }
  100% {
    transform: scale(1.1) translateX(-5%);
  }
}
@keyframes kenBurnsRight {
  0% {
    transform: scale(1.1) translateX(-5%);
  }
  100% {
    transform: scale(1.1) translateX(5%);
  }
}
@keyframes kenBurnsUp {
  0% {
    transform: scale(1.1) translateY(5%);
  }
  100% {
    transform: scale(1.1) translateY(-5%);
  }
}
.splide {
  border-bottom: 4px solid #FD6420;
}
.splide img {
  height: 650px;
}
@media screen and (max-width: 768px) {
  .splide img {
    height: 400px;
  }
}

.menu .row {
  max-width: 1240px;
  margin: 0 auto;
}
.menu .row .col {
  padding-bottom: 100px;
}
@media screen and (max-width: 1024px) {
  .menu .row .col {
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 768px) {
  .menu .row .col {
    padding: 0;
  }
}
.menu .row .col:nth-child(2n) {
  padding-left: 50px;
}
@media screen and (max-width: 1024px) {
  .menu .row .col:nth-child(2n) {
    padding-left: 50px;
  }
}
@media screen and (max-width: 768px) {
  .menu .row .col:nth-child(2n) {
    padding-left: 0px;
  }
}
.menu__category {
  font-size: 40px;
  font-size: 2.5rem;
  color: #FD6420;
  text-transform: uppercase;
}
@media screen and (max-width: 1280px) {
  .menu__category {
    font-size: 35px;
    font-size: 2.1875rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__category {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__category {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media screen and (max-width: 480px) {
  .menu__category {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.menu__category-description {
  font-size: 12px;
  font-size: 0.75rem;
  font-style: italic;
  margin-top: -20px;
}
@media screen and (max-width: 1280px) {
  .menu__category-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__category-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__category-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 480px) {
  .menu__category-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.menu__items {
  list-style: none;
  margin-left: initial;
}
.menu__items li {
  margin-bottom: 0.5rem;
}
.menu__item {
  font-size: 25px;
  font-size: 1.5625rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  margin-bottom: -0.5rem;
  text-transform: uppercase;
}
@media screen and (max-width: 1280px) {
  .menu__item {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__item {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__item {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 480px) {
  .menu__item {
    font-size: 16px;
    font-size: 1rem;
  }
}
.menu__item-name {
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .menu__item-name {
    white-space: normal;
  }
}
.menu__item-price {
  font-size: 16px;
  font-size: 1rem;
  white-space: nowrap;
}
@media screen and (max-width: 1280px) {
  .menu__item-price {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__item-price {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__item-price {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 480px) {
  .menu__item-price {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__item-price {
    white-space: normal;
  }
}
.menu__item-description {
  font-size: 12px;
  font-size: 0.75rem;
  font-style: italic;
  margin-top: 3px;
}
@media screen and (max-width: 1280px) {
  .menu__item-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 1024px) {
  .menu__item-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__item-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 480px) {
  .menu__item-description {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 768px) {
  .menu__item-description {
    margin-top: 6px;
  }
}
.menu__dots {
  flex: 1;
  border-bottom: 1px dashed #aaa;
  height: 0.8em;
  margin: 0 0.5rem;
}
.menu__legend {
  list-style: none;
  margin-left: 0;
}
.menu__legend li {
  display: inline-block;
  margin-right: 1rem;
  font-size: 0.875rem;
}
.menu__legend li span {
  margin-right: 5px;
}
.menu__section {
  margin-bottom: 50px;
}
.menu .label--gf,
.menu .label--gfa {
  font-size: 0.75rem;
  font-weight: bold;
  background-color: #FD6420;
  color: #fff;
  padding: 2px 4px;
  border-radius: 3px;
  margin-left: 5px;
  vertical-align: middle;
  display: inline-block;
}
.menu .label--v {
  font-size: 0.75rem;
  font-weight: bold;
  background-color: #2ecc71;
  color: #fff;
  padding: 2px 4px;
  border-radius: 3px;
  margin-left: 5px;
  vertical-align: middle;
  display: inline-block;
}

.menu-tabs .col:nth-child(2n) {
  padding-left: 10px !important;
}

.menu-tab-button {
  width: 100% !important;
}

.menu-tab-content {
  display: none;
}

.menu-tab-content.active {
  display: block;
}

.faq-section {
  padding: 40px 0;
}
.faq-section .faq-accordion {
  max-width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 800px) {
  .faq-section .faq-accordion {
    margin: 0 20px;
  }
}
.faq-section .faq-item {
  border-bottom: 1px solid #ddd;
  margin-bottom: 10px;
}
.faq-section .faq-item.active .faq-arrow {
  transform: rotate(-135deg);
  margin-top: 5px;
}
.faq-section .faq-item.active .faq-answer {
  max-height: 500px;
  opacity: 1;
  padding-bottom: 20px;
}
.faq-section .faq-question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.2rem;
  font-weight: 700;
  text-align: left;
  color: #f76528;
}
.faq-section .faq-question .faq-left {
  display: flex;
  align-items: center;
  gap: 15px;
}
.faq-section .faq-question .faq-left .faq-icon {
  width: 25px;
  height: auto;
}
.faq-section .faq-question .faq-arrow {
  width: 8px;
  height: 8px;
  border-right: 2px solid #f76528;
  border-bottom: 2px solid #f76528;
  transform: rotate(45deg);
  transition: transform 0.3s ease, margin 0.3s ease;
  margin-right: 10px;
}
.faq-section .faq-answer {
  display: none;
  overflow: hidden;
  opacity: 0;
}
.faq-section .faq-answer p {
  margin: 0;
  line-height: 1.6;
}

.btn {
  background-color: #444;
  color: #fff;
  border: 1px solid transparent;
  display: inline-block;
  padding: 6px 19.992px;
  border-radius: 3px;
  font-family: "Anton", "Helvetica Neue", Helvetica, Arial, sans-serif;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  width: auto;
  transition: all 0.5s;
}
.btn::-moz-focus-inner {
  border: 0;
  padding: 0;
}
.btn:hover {
  text-decoration: none;
  background-color: #fff;
  color: #444;
  border-color: #444;
}
.btn.is-disabled, .btn:disabled {
  pointer-events: none;
  opacity: 0.65;
}

.btn--primary {
  background: #f76528;
  font-size: 21px;
  line-height: 1.4;
}
.btn--primary:hover {
  background: rgb(227.533632287, 73.0224215247, 8.466367713);
  color: #fff;
  border-color: transparent;
}
.btn--primary:active {
  background: rgb(178.3632286996, 57.2421524664, 6.6367713004);
}

.btn--secondary {
  background: transparent;
  border: 1px solid #f76528;
}
.btn--secondary:hover {
  background: #f76528;
  color: #fff;
  border-color: transparent;
}
.btn--secondary:active {
  background: rgb(178.3632286996, 57.2421524664, 6.6367713004);
}

.btn--inverse {
  background-color: #070707;
  color: #f76528;
  border: 1px solid #f76528;
}
.btn--inverse:hover {
  background-color: #f76528;
  color: #fff;
  border-color: transparent;
}
.btn--inverse:active {
  background-color: rgb(178.3632286996, 57.2421524664, 6.6367713004);
}

.btn--block {
  display: block;
  width: 100%;
}
.btn--block + .btn--block {
  margin-top: 6px;
}

.btn--link {
  font-family: "Anton", "Helvetica Neue", Helvetica, Arial, sans-serif;
  background-color: transparent;
  color: #fdffff;
  text-decoration: none;
  position: relative;
}
.btn--link:hover {
  color: #f76528;
  text-decoration: none;
  transition: color 0.3s ease-in-out;
}
.btn--link:hover:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: #f76528;
  animation: underline 0.3s;
}
@keyframes underline {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
.btn--link:focus {
  outline: none;
}

/**
 * Hamburger menu
 */
.nav-burger {
  float: left;
  transition: all 250ms ease-in-out;
  z-index: 999;
}

.nav-burger__line {
  width: 35px;
  height: 3px;
  background-color: #fdffff;
  display: none;
  margin: 8px auto;
  transition: all 250ms ease-in-out;
}
@media screen and (max-width: 1000px) {
  .nav-burger__line {
    display: block;
  }
}
.nav-burger.open .nav-burger__line:nth-child(2) {
  opacity: 0;
}
.nav-burger.open .nav-burger__line:nth-child(1) {
  transform: translateY(11px) rotate(45deg);
}
.nav-burger.open .nav-burger__line:nth-child(3) {
  transform: translateY(-11px) rotate(-45deg);
}

/**
 * Navs
 */
.nav {
  list-style: none;
  margin: 0;
}
.nav > li {
  display: inline-block;
  margin-right: 24px;
}
.nav > li:last-child {
  margin-right: 0;
}
.nav > li > a {
  display: block;
}

.nav--header {
  font-size: 20px;
}
@media screen and (max-width: 1000px) {
  .nav--header ul {
    list-style: none;
  }
}

.nav--footer {
  display: flex;
}
@media screen and (max-width: 768px) {
  .nav--footer {
    align-items: center;
    flex-direction: column;
    gap: 10px;
  }
  .nav--footer li {
    margin-right: 0;
  }
}

.logo-mobile-nav {
  display: none;
}
@media screen and (max-width: 1000px) {
  .logo-mobile-nav {
    display: block;
    width: 250px;
  }
}

.alert {
  padding: 24px;
  margin-bottom: 24px;
  border: 1px solid transparent;
}
.alert > p,
.alert > ul {
  margin-bottom: 0;
}
.alert > p + p {
  margin-top: 24px;
}
.alert.alert--success {
  color: #5CB85C;
  border-color: #5CB85C;
}
.alert.alert--info {
  color: #444;
  border-color: #444;
}
.alert.alert--warning {
  color: #F0AD4E;
  border-color: #F0AD4E;
}
.alert.alert--danger {
  color: #D9534F;
  border-color: #D9534F;
}

.icon-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}
.icon-container::before, .icon-container::after {
  content: "";
  height: 1px;
  background-color: #ccc;
  flex: 1;
}
.icon-container--left::before {
  display: none;
}
.icon-container--right::after {
  display: none;
}
.icon-container .icon {
  display: inline-block;
  height: auto;
  max-height: 80px;
  width: auto;
}

.cart-button {
  display: flex;
  align-items: center;
  margin-right: 1rem;
  text-decoration: none;
  color: inherit;
}

.cart-icon {
  width: 30px;
  height: 30px;
  margin-right: 5px;
}

.cart-count {
  font-weight: bold;
}

.contact__card {
  position: relative;
  display: grid;
  place-content: center;
  margin-bottom: 10px;
  min-width: 280px;
  min-height: 500px;
  color: white;
  text-align: center;
  border: 2px solid #FD6420;
  border-radius: 20px;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .contact__card {
    min-height: 300px;
  }
}
.contact__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  z-index: 0;
  transition: transform 1.5s ease-in-out, filter 1s ease-in-out;
  transform: scale(1);
  filter: brightness(0.4);
}
.contact__card:hover::before {
  transform: scale(1.1);
  filter: brightness(0.6);
}
.contact__card > * {
  position: relative;
  z-index: 2;
}
.contact__card__phone {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.contact__card__phone a {
  display: flex;
  align-items: center;
  gap: 8px;
}
.contact__card__phone .phone-icon {
  width: 18px;
  height: 18px;
  display: inline-block;
}
.contact__card--bristol::before {
  background-image: url("/wp-content/themes/spitfire/assets/images/bristol-spitfire.png");
}
.contact__card--cardiff::before {
  background-image: url("/wp-content/themes/spitfire/assets/images/cardiff-spitfire.jpg");
}
.contact__card__address, .contact__card__email, .contact__card__phone {
  font-size: 20px;
  font-size: 1.25rem;
  font-family: "Anton", "Helvetica Neue", Helvetica, Arial, sans-serif;
}
@media screen and (max-width: 1280px) {
  .contact__card__address, .contact__card__email, .contact__card__phone {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 1024px) {
  .contact__card__address, .contact__card__email, .contact__card__phone {
    font-size: 16px;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .contact__card__address, .contact__card__email, .contact__card__phone {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 480px) {
  .contact__card__address, .contact__card__email, .contact__card__phone {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.contact__card h2 {
  border-bottom: 1px solid #FD6420;
}
@media screen and (max-width: 768px) {
  .contact__card--bristol-bookings {
    margin-top: 20px;
  }
}

.shop__category-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #FD6420;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  text-align: center;
  margin-bottom: 20px;
}
.shop__category-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  border-color: #FD6420;
}
.shop__category-card:hover .shop__category-title {
  background: #FD6420;
}
.shop__category-card a {
  color: inherit;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.shop__category-card .shop__category-image-wrapper {
  aspect-ratio: 1/1;
  overflow: hidden;
}
.shop__category-card .shop__category-image-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.shop__category-card:hover img {
  transform: scale(1.05);
}
.shop__category-card .shop__category-title {
  background: #000;
  color: #fff;
  padding: 1rem;
  font-size: 1.1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s ease;
}
@media screen and (max-width: 768px) {
  .shop__category-card {
    max-width: 400px;
    margin: 0 auto 20px;
  }
}

@media screen and (max-width: 768px) {
  .shop__category-card {
    max-width: 400px;
    margin: 0 auto;
    margin-bottom: 20px;
  }
}

.product-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #FD6420;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  display: flex;
  flex-direction: column;
  text-align: center;
  height: 100%;
}
.product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  border-color: #FD6420;
}
.product-card:hover .product-card__info {
  background: #FD6420;
}
.product-card:hover .product-card__price {
  color: #fff;
}
.product-card__image-wrapper {
  aspect-ratio: 1/1;
  overflow: hidden;
}
.product-card__image-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.product-card:hover img {
  transform: scale(1.05);
}
.product-card__info {
  background: #000;
  color: #fff;
  padding: 1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s ease;
}
.product-card__title {
  font-size: 1.1rem;
  margin: 0;
}
.product-card__price {
  color: #f76528;
  font-size: 1rem;
  margin-top: 0.25rem;
}

.product-details__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.product-details__left .product-details__image-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 20px;
}
.product-details__left .product-details__image-wrapper .product-details__image {
  max-width: 100%;
  height: auto;
  max-height: 300px;
  -o-object-fit: contain;
     object-fit: contain;
  border: 1px solid #f76528;
  border-radius: 10px;
}
.product-details__left .product-details__image-wrapper .product-details__placeholder {
  width: 100%;
  height: 300px;
  background: #fff;
  border: 1px solid #f76528;
  border-radius: 10px;
}
.product-details__left .product-details__gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 15px 0;
  justify-content: center;
}
.product-details__left .product-details__gallery a {
  display: block;
  border-radius: 8px;
  overflow: hidden;
  border: 2px solid #f76528;
  transition: transform 0.2s;
}
.product-details__left .product-details__gallery a:hover {
  transform: scale(1.05);
}
.product-details__left .product-details__gallery a .product-details__gallery-thumb {
  display: block;
  width: 60px;
  height: 60px;
  -o-object-fit: cover;
     object-fit: cover;
}
.product-details__left .product-details__meta .product-details__price {
  font-size: 24px;
  color: #f76528;
  margin: 0 0 10px 0;
}
.product-details__left .product-details__meta .product-details__sku,
.product-details__left .product-details__meta .product-details__categories {
  font-size: 16px;
  color: #fff;
  margin: 0 0 10px 0;
}
.product-details__left .product-details__add-to-cart {
  width: 100%;
}
.product-details__left .product-details__add-to-cart .button,
.product-details__left .product-details__add-to-cart a:not(.go-back-button) {
  width: 100%;
  padding: 12px;
  background: #f76528 !important;
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: 18px;
  transition: background 0.3s ease;
  margin: 10px 0;
  text-transform: uppercase;
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 800;
}
.product-details__left .product-details__add-to-cart .button:hover,
.product-details__left .product-details__add-to-cart a:not(.go-back-button):hover {
  background: rgb(227.533632287, 73.0224215247, 8.466367713) !important;
  color: #fff !important;
}
.product-details__left .product-details__add-to-cart input[type=number] {
  color: black;
  background: #fff;
  border-radius: 8px;
  padding: 10px;
  font-size: 18px;
  -moz-appearance: auto;
       appearance: auto;
  -webkit-appearance: auto;
}
.product-details__left .product-details__add-to-cart input[type=number]::-webkit-inner-spin-button, .product-details__left .product-details__add-to-cart input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: auto;
  opacity: 1;
  filter: none;
  margin: 0;
}
.product-details__left .product-details__add-to-cart input[type=number]:hover, .product-details__left .product-details__add-to-cart input[type=number]:focus {
  border-color: rgb(227.533632287, 73.0224215247, 8.466367713);
  outline: none;
}
.product-details__left .product-details__title {
  font-size: 32px;
  margin: 0 0 20px 0;
  color: #fff;
}
.product-details__left .product-details__description {
  font-size: 16px;
  line-height: 1.6;
  color: #fff;
}

.go-back-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.2s ease;
}
.go-back-button .go-back-icon {
  flex-shrink: 0;
}
.go-back-button:hover {
  transform: translateX(-3px);
}

.wp-block-woocommerce-empty-cart-block div[data-block-name="woocommerce/product-new"] {
  display: none;
}
.wp-block-woocommerce-empty-cart-block h2:not(.with-empty-cart-icon) {
  display: none;
}

.wc-block-cart__submit-button {
  background: #f76528;
}
.wc-block-cart__submit-container {
  font-weight: 800;
  text-transform: uppercase;
}

.wc-block-components-quantity-selector__button {
  font-size: 18px !important;
  opacity: 1 !important;
}
.wc-block-components-quantity-selector__button--minus {
  background: #f76528 !important;
}
.wc-block-components-quantity-selector__button--plus {
  background: #f76528 !important;
}

.wp-block-woocommerce-checkout-order-summary-block {
  border: 1px solid white !important;
}

.wc-block-components-button {
  background: #f76528 !important;
  border-radius: 5px;
  font-weight: 800;
  text-transform: uppercase;
}

/* WooCommerce Variations Styling */
.variations_form.cart {
  margin: 20px 0;
  /* Price + availability */
  /* Add to cart button consistency */
}
.variations_form.cart table.variations {
  display: flex !important;
  flex-direction: column;
  gap: 15px;
  border: none;
  width: 100%;
}
.variations_form.cart table.variations tbody, .variations_form.cart table.variations tr, .variations_form.cart table.variations th, .variations_form.cart table.variations td {
  display: block;
  border: none !important;
  padding: 0;
  margin: 0;
}
.variations_form.cart table.variations .label {
  margin-bottom: 5px;
}
.variations_form.cart table.variations .label label {
  font-weight: 700;
  font-size: 16px;
}
.variations_form.cart table.variations .value select {
  width: 100%;
  text-align: center;
  border: 2px solid #f76528;
  border-radius: 50px;
  background: #fff;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 600;
  color: black;
  cursor: pointer;
}
.variations_form.cart table.variations .value select:hover, .variations_form.cart table.variations .value select:focus {
  border-color: rgb(227.533632287, 73.0224215247, 8.466367713);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.05);
  outline: none;
}
.variations_form.cart table.variations .value .reset_variations {
  display: inline-block;
  text-align: center;
  cursor: pointer;
}
.variations_form.cart table.variations .value .reset_variations:hover {
  color: rgb(231.92, 72.8, 2.08);
}
.variations_form.cart .single_variation_wrap {
  margin-top: 15px;
}
.variations_form.cart .single_variation_wrap .woocommerce-variation-price {
  font-size: 20px;
  font-weight: bold;
  color: #f76528;
  margin-bottom: 10px;
}
.variations_form.cart .single_add_to_cart_button {
  width: 100%;
  padding: 12px;
  background: #f76528 !important;
  color: #fff !important;
  border-radius: 50px;
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  margin-top: 10px;
}
.variations_form.cart .single_add_to_cart_button:hover {
  background: rgb(227.533632287, 73.0224215247, 8.466367713) !important;
}
