@charset "UTF-8";
/*!
Theme Name: OGA
Theme URI: https://ogadesign.com.au/
Author: OGA Creative Agency
Author URI: https://ogadesign.com.au/
Description: Custom theme built by <strong><em>OGA Creative Agency</em></strong>.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: oga
*/
/*--------------------------------------------------------------
# 01 - Settings
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Fonts
--------------------------------------------------------------*/
/* Avenir Next - Regular */
@font-face {
  font-family: "Avenir Next";
  src: url("./assets/fonts/avenir-next-regular.woff2") format("woff2"), url("./assets/fonts/avenir-next-regular.woff") format("woff");
  font-display: swap;
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
}
/* Avenir Next - Bold */
@font-face {
  font-family: "Avenir Next";
  src: url("./assets/fonts/avenir-next-bold.woff2") format("woff2"), url("./assets/fonts/avenir-next-bold.woff") format("woff");
  font-display: swap;
  font-style: normal;
  font-weight: 700;
  font-stretch: normal;
}
/* Avenir Next - Black */
@font-face {
  font-family: "Avenir Next";
  src: url("./assets/fonts/avenir-next-bold.woff2") format("woff2"), url("./assets/fonts/avenir-next-bold.woff") format("woff");
  font-display: swap;
  font-style: normal;
  font-weight: 800;
  font-stretch: normal;
}
/* Albert Sans - Regular */
@font-face {
  font-family: "Albert Sans";
  src: url("./assets/fonts/albert-sans-regular.woff2") format("woff2");
  font-display: swap;
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
}
/* Albert Sans - Medium */
@font-face {
  font-family: "Albert Sans";
  src: url("./assets/fonts/albert-sans-regular.woff2") format("woff2");
  font-display: swap;
  font-style: normal;
  font-weight: 500;
  font-stretch: normal;
}
/*--------------------------------------------------------------
# Custom SVG Icons
# Replaces Font Awesome (saves ~80KB)
--------------------------------------------------------------*/
.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.125em;
  color: inherit;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon--sm {
  width: 0.875em;
  height: 0.875em;
}

.icon--lg {
  width: 1.25em;
  height: 1.25em;
}

.icon--xl {
  width: 1.5em;
  height: 1.5em;
}

.icon--2x {
  width: 2em;
  height: 2em;
}

a .icon,
button .icon {
  transition: transform 0.2s ease;
}

a:hover .icon,
button:hover .icon {
  transform: scale(1.05);
}

/*--------------------------------------------------------------
# Colours
--------------------------------------------------------------*/
:root {
  --color-blue: #001489;
  --color-black: #272727;
  --color-dark-grey: #272727;
  --color-grey: #595959;
  --color-light-grey: #EFEFEF;
  --color-lightest-grey: #F1F1F1;
  --color-white: #ffffff;
  --font-primary: 'Avenir Next', 'Helvetica Neue', 'Helvetica', 'Arial', 'Lucida Grande', sans-serif;
  --font-secondary: 'Avenir Next', 'Helvetica Neue', 'Helvetica', 'Arial', 'Lucida Grande', sans-serif;
  --font-mono: 'Avenir Next', 'Helvetica Neue', 'Helvetica', 'Arial', 'Lucida Grande', sans-serif;
  --shadow-sm: rgba(3, 8, 20, 0.1) 0px 0.15rem 0.5rem,
  	rgba(2, 8, 20, 0.1) 0px 0.075rem 0.175rem;
  --shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.02);
  --shadow-lg: 0 12px 24px 0 rgba(0, 0, 0, 0.1);
  --layout-margin: 4.6667vw;
  --layout-width: calc(100vw - (2 * var(--layout-margin)));
  --ease-in-out: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-out: cubic-bezier(0.215, 0.61, 0.355, 1);
  --plyr-color-main: #001489;
}

/*--------------------------------------------------------------
# 01 - Genric
--------------------------------------------------------------*/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
	========================================================================== */
/**
* Remove the margin in all browsers.
*/
body {
  margin: 0;
}

/**
* Render the `main` element consistently in IE.
*/
main {
  display: block;
}

/**
* Correct the font size and margin on `h1` elements within `section` and
* `article` contexts in Chrome, Firefox, and Safari.
*/
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
	========================================================================== */
/**
* 1. Add the correct box sizing in Firefox.
* 2. Show the overflow in Edge and IE.
*/
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
	========================================================================== */
/**
* Remove the gray background on active links in IE 10.
*/
a {
  background-color: transparent;
}

/**
* 1. Remove the bottom border in Chrome 57-
* 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
*/
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  /* 2 */
}

/**
* Add the correct font weight in Chrome, Edge, and Safari.
*/
b,
strong {
  font-weight: bolder;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
* Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}

/**
* Prevent `sub` and `sup` elements from affecting the line height in
* all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
	========================================================================== */
/**
* Remove the border on images inside links in IE 10.
*/
img {
  border-style: none;
}

/* Forms
	========================================================================== */
/**
* 1. Change the font styles in all browsers.
* 2. Remove the margin in Firefox and Safari.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
* Show the overflow in IE.
* 1. Show the overflow in Edge.
*/
button,
input {
  /* 1 */
  overflow: visible;
}

/**
* Remove the inheritance of text transform in Edge, Firefox, and IE.
* 1. Remove the inheritance of text transform in Firefox.
*/
button,
select {
  /* 1 */
  text-transform: none;
}

/**
* Correct the inability to style clickable types in iOS and Safari.
*/
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
* Remove the inner border and padding in Firefox.
*/
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
* Restore the focus styles unset by the previous rule.
*/
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
* Correct the padding in Firefox.
*/
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
* 1. Correct the text wrapping in Edge and IE.
* 2. Correct the color inheritance from `fieldset` elements in IE.
* 3. Remove the padding so developers are not caught out when they zero out
*    `fieldset` elements in all browsers.
*/
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
* Add the correct vertical alignment in Chrome, Firefox, and Opera.
*/
progress {
  vertical-align: baseline;
}

/**
* Remove the default vertical scrollbar in IE 10+.
*/
textarea {
  overflow: auto;
}

/**
* 1. Add the correct box sizing in IE 10.
* 2. Remove the padding in IE 10.
*/
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
* Correct the cursor style of increment and decrement buttons in Chrome.
*/
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
* 1. Correct the odd appearance in Chrome and Safari.
* 2. Correct the outline style in Safari.
*/
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
* Remove the inner padding in Chrome and Safari on macOS.
*/
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
* 1. Correct the inability to style clickable types in iOS and Safari.
* 2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
	========================================================================== */
/*
* Add the correct display in Edge, IE 10+, and Firefox.
*/
details {
  display: block;
}

/*
* Add the correct display in all browsers.
*/
summary {
  display: list-item;
}

/* Misc
	========================================================================== */
/**
* Add the correct display in IE 10+.
*/
template {
  display: none;
}

/**
* Add the correct display in IE 10.
*/
[hidden] {
  display: none;
}

/**
* Manually forked from SUIT CSS Base: https://github.com/suitcss/base
* A thin layer on top of normalize.css that provides a starting point more
* suitable for web applications.
*/
/**
* Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

button {
  background-color: transparent;
  background-image: none;
}

/**
* Work around a Firefox/IE bug where the transparent `button` background
* results in a loss of the default `button` focus styles.
*/
button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color;
}

fieldset {
  margin: 0;
  padding: 0;
}

ol,
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*--------------------------------------------------------------
# 03 - Elements
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Document Setup
--------------------------------------------------------------*/
*,
*:before,
*:after {
  box-sizing: border-box;
}

html {
  font-size: 100%;
  text-size-adjust: 100%;
  overflow-x: hidden;
  scroll-behavior: initial;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  color: var(--color-dark-grey);
  font-family: var(--font-primary);
  font-size: 1.2rem;
  line-height: 1.46666667;
  overflow-x: hidden;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

::selection {
  background: var(--color-black);
  color: var(--color-white);
  text-shadow: none;
}

/**
* Paragraphs
*/
p {
  font-size: 1rem;
  line-height: 1.75;
}
@media (min-width: 1024px) {
  p {
    font-size: clamp(1rem, 0.09vw + 0.98rem, 1.13rem);
  }
}

/**
* Lists
*/
ul {
  font-size: clamp(1rem, 0vw + 1rem, 1rem);
}

/**
* Links
*/
a {
  color: inherit;
  text-decoration: none;
  outline: 0;
  transition: color 0.2s ease-in-out;
}

/**
* Buttons
*/
button {
  background-color: transparent;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  line-height: inherit;
  appearance: none;
}
button:focus {
  outline: none;
}

/**
* HR
*/
hr {
  border-width: 0;
}

/**
* Images
*/
img {
  max-width: 100%;
  vertical-align: middle;
  display: inline-block;
}

/**
* Fieldset
*/
fieldset {
  border: none;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
.h1,
.h2,
.h3,
.h4,
.h5,
h1,
h2,
h3,
h4,
h5 {
  color: var(--color-blue);
  font-family: var(--font-secondary);
  line-height: 110%;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  font-weight: 800;
}

h1,
.h1 {
  font-size: clamp(1.7rem, 1.53vw + 1.35rem, 3.8rem);
}

h2,
.h2 {
  font-size: clamp(1.7rem, 1.53vw + 1.35rem, 3.8rem);
}

h3,
.h3 {
  font-size: clamp(0.97rem, 1.05vw + 0.73rem, 2.4rem);
}

.h4,
h4 {
  font-size: clamp(0.73rem, 0.46vw + 0.62rem, 1.36rem);
}

.h5,
h5 {
  font-size: clamp(0.68rem, 0.26vw + 0.62rem, 1.04rem);
}

.p-lg {
  font-size: clamp(0.93rem, 0.24vw + 0.87rem, 1.25rem);
  font-size: clamp(0.93rem, 0.51vw + 0.81rem, 1.63rem);
  line-height: 1.2;
}

.p-md {
  font-size: clamp(0.88rem, 0.13vw + 0.84rem, 1.06rem);
  font-size: clamp(0.93rem, 0.15vw + 0.89rem, 1.13rem);
  line-height: 1.6;
}

/*--------------------------------------------------------------
# 04 - Layout
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Container
--------------------------------------------------------------*/
.container {
  width: 100%;
  max-width: var(--layout-width);
  margin-left: auto;
  margin-right: auto;
}

/*--------------------------------------------------------------
# Section
--------------------------------------------------------------*/
.section {
  padding-top: clamp(2.63rem, 2.65vw + 2.01rem, 6.25rem);
  padding-bottom: clamp(2.63rem, 2.65vw + 2.01rem, 6.25rem);
}
.section--lg {
  padding-top: clamp(2.93rem, 4.44vw + 1.9rem, 9rem);
  padding-bottom: clamp(2.93rem, 4.44vw + 1.9rem, 9rem);
}
.section--xl {
  padding-top: clamp(3rem, 8.04vw + 1.14rem, 14rem);
  padding-bottom: clamp(3rem, 8.04vw + 1.14rem, 14rem);
}
.section--no-padding {
  padding: 0;
}
.section--no-padding-top {
  padding-top: 0;
}
.section--no-padding-bottom {
  padding-bottom: 0;
}
.section--full-width {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}
.section--full-width .container {
  width: 100%;
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
}
.section--grid-black {
  background-color: var(--color-black);
  background-image: url("data:image/svg+xml,<svg id='patternId' width='100%' height='100%' xmlns='http://www.w3.org/2000/svg'><defs><pattern id='a' patternUnits='userSpaceOnUse' width='20' height='20' patternTransform='scale(2) rotate(0)'><rect x='0' y='0' width='100%' height='100%' fill='hsla(0, 0%, 15%, 1)'/><path d='M 10,-2.55e-7 V 20 Z M -1.1677362e-8,10 H 20 Z'  stroke-width='0.5' stroke='hsla(0, 0%, 0%, 0.2)' fill='none'/></pattern></defs><rect width='800%' height='800%' transform='translate(0,0)' fill='url(%23a)'/></svg>");
}
@media (min-width: 768px) {
  .section--border {
    border-bottom: 1.5px solid #E4E4E4;
  }
}
.section--events {
  padding-top: clamp(2.63rem, 0.37vw + 2.54rem, 3.13rem);
  padding-bottom: clamp(2.63rem, 0.37vw + 2.54rem, 3.13rem);
}
@media (min-width: 1024px) {
  .section--events {
    margin-top: clamp(2.5rem, 4.75vw + 1.4rem, 9rem);
  }
}

/**
* Watermark
*/
.section--watermark {
  background-color: var(--color-light-grey);
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.section--watermark .watermark {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: auto;
  opacity: 0.5;
  z-index: 1;
}
@media (min-width: 1024px) {
  .section--watermark .watermark {
    top: -5%;
    width: 120%;
  }
}
.section--watermark .container {
  position: relative;
  z-index: 5;
}

/**
* Watermark
*/
.section--gradient {
  padding-bottom: 0;
  position: relative;
}
.section--gradient .watermark {
  position: absolute;
  top: 2.5%;
  right: -10%;
  width: 100%;
  height: auto;
  z-index: -1;
}
@media (min-width: 1024px) {
  .section--gradient .watermark {
    top: -2.5%;
    width: 80%;
  }
}
.section--gradient .container {
  position: relative;
  z-index: 5;
}

.section--gradient-red {
  background-color: var(--color-blue);
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.section--gradient-red .watermark {
  position: absolute;
  top: 2.5%;
  right: 10%;
  width: 100%;
  height: auto;
  opacity: 0.8;
  z-index: -1;
}
@media (min-width: 1024px) {
  .section--gradient-red .watermark {
    top: -20%;
    width: 70%;
  }
}
.section--gradient-red .container {
  position: relative;
  z-index: 5;
}

/**
* Section Intro
*/
.section-intro__title {
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  text-transform: uppercase;
}
.section-intro__hr {
  background-color: var(--color-black);
  height: 2px;
  width: 100%;
  margin: 1rem 0 clamp(1.33rem, 2.41vw + 0.77rem, 4.63rem) 0;
  transform-origin: 0 50%;
  transform: scaleX(0);
}

/*--------------------------------------------------------------
# Grid
--------------------------------------------------------------*/
.grid {
  display: grid;
}

.grid--contact {
  grid-template-columns: 1fr;
  grid-gap: clamp(3rem, 2.19vw + 2.49rem, 6rem);
}
@media (min-width: 1024px) {
  .grid--contact {
    grid-template-columns: 0.4fr 1fr;
  }
}

/*--------------------------------------------------------------
# 05 - Components
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Accordion
--------------------------------------------------------------*/
.accordion {
  overflow: hidden;
}
.accordion > :first-child {
  border-top: 1px solid var(--color-black);
}
.accordion__item {
  border-bottom: 1px solid var(--color-black);
}
.accordion__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(1rem, 0.37vw + 0.92rem, 1.5rem);
  cursor: pointer;
  transition: 0.2s var(--ease-out);
}
.accordion__btn .accordion__icon {
  font-size: clamp(2.75rem, 1.1vw + 2.5rem, 4.25rem);
  margin-right: clamp(0.5rem, 0.37vw + 0.42rem, 1rem);
}
.accordion__btn span {
  transition: 0.2s var(--ease-out);
}
.accordion__btn:hover span,
.accordion__btn:hover svg {
  color: var(--color-blue);
}
.accordion__btn:hover span {
  transform: translateX(0.5rem);
}
.accordion__panel {
  position: relative;
  overflow: hidden;
  will-change: height;
  transform: translateZ(0px);
  padding: 0 clamp(1rem, 0.37vw + 0.92rem, 1.5rem);
}
.accordion__panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-black);
  pointer-events: none;
}
.accordion__panel > * {
  padding: clamp(1rem, 1.83vw + 0.58rem, 3.5rem) 0;
}
.accordion__panel .btn {
  margin-top: 2rem;
}
.accordion__input {
  transition: 0.2s;
  margin-left: auto;
}
.accordion__input .icon {
  color: var(--color-black);
  font-size: clamp(0.88rem, 0.73vw + 0.71rem, 1.88rem);
  transition: transform 0.3s ease;
}
.accordion__input .icon > * {
  transition: transform 0.3s, stroke-dashoffset 0.3s;
  transition-timing-function: ease;
}
.accordion__input .icon__group {
  transform: rotate(0);
  transform-origin: 50% 50%;
  will-change: transform;
}
.accordion__input .icon__group > *:first-child {
  transform: rotate(0);
}
.accordion__btn--checked .accordion__input, .accordion__btn--focus .accordion__input, .accordion__btn--checked:hover .accordion__input, .accordion__btn--focus:hover .accordion__input {
  color: var(--color-blue);
}
.accordion__btn--checked .accordion__input .icon__group {
  transform: rotate(-90deg);
  color: var(--color-blue);
}
.accordion__btn--checked .accordion__input .icon__group > * {
  transform-origin: 50% 50%;
}
.accordion__btn--checked .accordion__input .icon__group > *:first-child {
  transform: rotate(-90deg);
}
.accordion .prose {
  max-width: 64rem;
}

.accordion__fallback {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
}

/*--------------------------------------------------------------
# Community Support Section
--------------------------------------------------------------*/
.community-slider {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.swiper--community {
  width: 100%;
  padding-bottom: 3rem;
  overflow: visible;
}
.swiper--community .swiper-wrapper {
  display: flex;
  width: 100%;
}
.swiper--community .swiper-slide {
  flex-shrink: 0;
  width: auto;
  height: auto;
}
.swiper--community .swiper-pagination {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: auto;
  position: absolute;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}
.swiper--community .swiper-pagination-bullet {
  background: #ccc;
  border: none;
  width: 12px;
  height: 12px;
  opacity: 1;
  margin: 0;
}
.swiper--community .swiper-pagination-bullet-active {
  background: #001489;
}

.community-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 120px;
  width: 100%;
  min-width: 250px;
  padding: 1rem;
  background: transparent;
  transition: transform 0.3s ease;
}
.community-logo:hover {
  transform: scale(1.05);
}
.community-logo__img {
  max-width: 100%;
  max-height: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: none;
  transition: transform 0.3s ease;
}

.community-logo:hover .community-logo__img {
  transform: scale(1.1);
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .community-logo {
    height: 100px;
  }
  .community-logo__img {
    max-height: 60px;
  }
}
/*--------------------------------------------------------------
# Milestones Timeline Section
--------------------------------------------------------------*/
.milestones-section {
  position: relative;
  padding: 4rem 0;
  overflow: visible;
}

.milestones-slider {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
}

.splide--milestones {
  padding: 0;
  overflow: visible;
  position: relative;
}
.splide--milestones .splide__track {
  overflow: visible;
}
.splide--milestones .splide__list {
  align-items: flex-start;
  position: relative;
}
.splide--milestones .splide__slide {
  height: auto;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}

/* Custom milestone arrows */
.milestone-arrows {
  position: absolute;
  top: 50px;
  left: 0;
  right: 0;
  pointer-events: none;
  z-index: 15;
}

.milestone-arrow {
  position: absolute;
  top: 25px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  background: white;
  color: #001489;
  box-shadow: 0 4px 15px rgba(0, 20, 137, 0.15);
  cursor: pointer;
  pointer-events: all;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.milestone-arrow:hover {
  background: #001489;
  color: white;
  transform: scale(1.1);
}
.milestone-arrow svg {
  width: 20px;
  height: 20px;
}

.milestone-arrow-prev {
  left: calc(-50vw + 2rem);
}

.milestone-arrow-next {
  right: calc(-50vw + 2rem);
}

/* Timeline line - positioned behind year badges */
.timeline-line {
  position: absolute;
  top: 150px;
  left: 0;
  right: 0;
  height: 3px;
  background: #001489;
  z-index: -1;
  width: 100%;
}
.timeline-line::before {
  content: "";
  position: absolute;
  left: -100vw;
  right: 100%;
  height: 3px;
  background: #001489;
}
.timeline-line::after {
  content: "";
  position: absolute;
  right: -100vw;
  left: 100%;
  height: 3px;
  background: #001489;
}

.milestone-item {
  position: relative;
  text-align: center;
  max-width: 350px;
  z-index: 2;
  padding: 0 1rem;
}

.milestone-icon {
  padding: 1rem 0;
}
.milestone-icon img {
  height: 96px;
  width: auto;
}

.milestone-year {
  background: white;
  border: 3px solid #001489;
  border-radius: 40px;
  padding: 0.6rem 1.2rem;
  margin-bottom: 1rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #001489;
  display: inline-block;
  min-width: 140px;
  position: relative;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 2;
}

.milestone-content {
  background: transparent;
  padding: 0;
  text-align: center;
}

.milestone-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #001489;
  margin-bottom: 0;
  line-height: 1.4;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.milestone-description {
  display: none; /* Hide descriptions to match Figma */
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .milestones-section {
    padding: 2rem 0;
  }
  .timeline-line {
    display: block; /* Show timeline line on mobile */
    top: 152px;
  }
  .milestone-year {
    font-size: 1rem;
    padding: 0.75rem 1.5rem;
    min-width: 120px;
    margin-bottom: 2rem;
  }
  .milestone-item {
    max-width: 300px;
    padding: 0;
  }
  .milestone-title {
    font-size: 1rem;
  }
}
@media (max-width: 1200px) {
  .swiper--milestones .swiper-button-prev {
    left: 1rem;
  }
  .swiper--milestones .swiper-button-next {
    right: 1rem;
  }
}
/*--------------------------------------------------------------
# Announcement
--------------------------------------------------------------*/
.announcement {
  display: none;
}
@media (min-width: 768px) {
  .announcement {
    display: block;
    background-color: var(--color-blue);
    color: var(--color-white);
    padding-top: clamp(0.25rem, 0.18vw + 0.21rem, 0.5rem);
    padding-bottom: clamp(0.25rem, 0.18vw + 0.21rem, 0.5rem);
  }
}
.announcement__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(1rem, 5.84vw + -0.35rem, 9rem);
}
.announcement__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.announcement__title {
  font-family: var(--font-secondary);
  font-size: clamp(0.53rem, 0.27vw + 0.47rem, 0.9rem);
  line-height: 1;
  letter-spacing: 0.02em;
  font-weight: 800;
  text-transform: uppercase;
}
.announcement__content {
  font-family: var(--font-mono);
  font-size: clamp(0.63rem, 0.18vw + 0.58rem, 0.88rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.announcement__btn {
  border: 2px solid var(--color-white);
  border-radius: 9em;
  color: var(--color-white);
  cursor: pointer;
  flex-shrink: 0;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(0.63rem, 0.05vw + 0.61rem, 0.7rem);
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  padding: clamp(0.5rem, 0vw + 0.5rem, 0.5rem) clamp(1rem, 0.18vw + 0.96rem, 1.25rem);
  transition: 0.3s var(--ease-out);
}
.announcement__btn:hover {
  background-color: var(--color-white);
  border-color: var(--color-black);
  color: var(--color-blue);
}

/*--------------------------------------------------------------
# Banner
--------------------------------------------------------------*/
.banner {
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .banner {
    aspect-ratio: 21/8;
  }
}
.banner__img {
  position: absolute;
  top: -20%;
  left: 0;
  height: 120%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
  object-fit: cover;
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
  padding: clamp(1rem, 0.37vw + 0.92rem, 1.5rem) 0;
  background-color: transparent;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  line-height: 1.5;
}
.breadcrumbs__list {
  margin: 0;
  padding: 0;
}
.breadcrumbs__link {
  display: inline;
  color: var(--color-blue);
  text-decoration: none;
  transition: color 0.2s ease;
  font-weight: 500;
}
.breadcrumbs__link:hover {
  color: var(--color-black);
  text-decoration: underline;
}
.breadcrumbs__current {
  display: inline;
  color: var(--color-dark-grey);
  font-weight: 400;
}
.breadcrumbs__separator {
  display: inline;
  color: var(--color-grey);
  opacity: 0.6;
  user-select: none;
  font-size: 0.625rem;
}
.breadcrumbs__separator i {
  font-size: inherit;
}

.breadcrumbs--compact {
  padding: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem) 0;
  font-size: 0.8125rem;
  background-color: transparent;
  border-bottom: none;
  margin-bottom: 1rem;
}

.breadcrumbs--inline {
  padding: 0.5rem 0;
  background-color: transparent;
  border-bottom: none;
}

/*--------------------------------------------------------------
# Buttons
--------------------------------------------------------------*/
.btn {
  background-color: transparent;
  border-radius: 9em;
  border: 1.5px solid;
  cursor: pointer;
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(0.68rem, 0.15vw + 0.64rem, 0.88rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.06em;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  padding: clamp(0.63rem, 0.09vw + 0.6rem, 0.75rem) clamp(0.75rem, 0.91vw + 0.54rem, 2rem);
  transition: 0.2s var(--ease-out);
}
@media (min-width: 768px) {
  .btn {
    border: 2px solid;
  }
}
.btn:focus-visible {
  outline: none;
}
.btn--white {
  border-color: var(--color-white);
  color: var(--color-white);
}
.btn--white:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
}
.btn--white-fill {
  border-color: var(--color-white) !important;
  color: var(--color-blue);
  background-color: var(--color-white);
}
.btn--white-fill:hover {
  background-color: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}
.btn--red {
  border-color: var(--color-blue);
  color: var(--color-black);
}
.btn--red:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.btn--black {
  border-color: var(--color-black);
  color: var(--color-black);
}
.btn--black:hover {
  background-color: var(--color-black);
  color: var(--color-white);
}
.btn--outline {
  border-color: var(--color-blue);
  color: var(--color-blue);
}
.btn--outline:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.btn--icon {
  position: relative;
  gap: 0.5rem;
}

/**
* Btn Container
*/
.btn-container {
  display: flex;
  gap: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem);
}

/*--------------------------------------------------------------
# Card
--------------------------------------------------------------*/
.card {
  aspect-ratio: 4/5;
  border-radius: 0.25rem;
  padding: clamp(1rem, 0.73vw + 0.83rem, 2rem);
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  position: relative;
  overflow: hidden;
  pointer-events: auto;
}
.card::before {
  background: linear-gradient(360deg, rgba(39, 39, 39, 0.9) -9.6%, rgba(39, 39, 39, 0) 100%);
  mix-blend-mode: darken;
  content: "";
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0.5;
  z-index: 2;
  transition: opacity 0.8s var(--ease-out);
}
.card__body {
  color: var(--color-white);
  position: relative;
  z-index: 10;
}
.card__title {
  font-size: clamp(1.25rem, 1.19vw + 0.98rem, 2.88rem);
  margin-bottom: clamp(0.25rem, 0.27vw + 0.19rem, 0.63rem);
}
.card__subtitle {
  font-family: var(--font-mono);
  font-size: clamp(0.63rem, 0.22vw + 0.57rem, 0.93rem);
  font-weight: 500;
  text-transform: uppercase;
}
.card__overlay {
  background-color: var(--color-blue);
  color: var(--color-white);
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translateY(100%);
  padding: clamp(1rem, 0.73vw + 0.83rem, 2rem);
  padding-bottom: clamp(4.5rem, 2.92vw + 3.82rem, 8.5rem);
  transition: transform 0.2s var(--ease-out);
  will-change: transform;
  z-index: 5;
}
.card__img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: 1;
}
.card a {
  height: 100%;
  width: 100%;
}
.card p {
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
}
@media (min-width: 1024px) {
  .card:hover::before {
    opacity: 1;
  }
  .card:hover .card__overlay {
    transform: translateY(0);
  }
}

/* Feature Icon Cards - for truck pages only */
.card--icon .card__img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  transform: none;
}

/*--------------------------------------------------------------
# Categories Page Styles
--------------------------------------------------------------*/
/* Hero Section - Equipment Sales */
.hero--categories {
  background: linear-gradient(135deg, #001489 0%, #0066cc 100%);
  min-height: 60vh;
  position: relative;
  overflow: hidden;
}
.hero--categories .hero__content {
  position: relative;
  z-index: 2;
  max-width: 50%;
}
@media (max-width: 768px) {
  .hero--categories .hero__content {
    max-width: 100%;
  }
}
.hero--categories .hero__logo {
  margin-bottom: 2rem;
}
.hero--categories .hero__logo .icon {
  width: 80px;
  height: auto;
}
.hero--categories .hero__title {
  font-size: 4rem;
  font-weight: 700;
  color: white;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 1.5rem;
}
@media (max-width: 1024px) {
  .hero--categories .hero__title {
    font-size: 3rem;
  }
}
@media (max-width: 768px) {
  .hero--categories .hero__title {
    font-size: 2.5rem;
  }
}
.hero--categories .hero__subtitle {
  font-size: 1.1rem;
  color: white;
  opacity: 0.9;
  line-height: 1.6;
  max-width: 400px;
}
@media (max-width: 768px) {
  .hero--categories .hero__subtitle {
    font-size: 1rem;
  }
}
.hero--categories .hero__img {
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 768px) {
  .hero--categories .hero__img {
    display: none;
  }
}

/* Categories Section */
.section--categories {
  background: #EFEFEF;
  padding: 0;
}

.categories-intro {
  text-align: left;
  margin-bottom: 4rem;
}
.categories-intro .hero__hr {
  background-color: #D9D9D9;
  border-color: #D9D9D9;
}

.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}
.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489 !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.about-intro-title strong {
  font-weight: 700 !important;
}
@media (max-width: 768px) {
  .about-intro-title {
    font-size: 2rem !important;
  }
  .about-intro-title *,
  .about-intro-title h1,
  .about-intro-title h2,
  .about-intro-title h3,
  .about-intro-title h4,
  .about-intro-title h5,
  .about-intro-title h6,
  .about-intro-title p {
    font-size: 2rem !important;
  }
}

/* Categories Grid */
.categories-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  width: 100%;
  margin-bottom: 3rem;
}
@media (max-width: 1024px) {
  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .categories-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
  }
}

/* View All Equipment Button */
.categories-view-all {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  .categories-view-all {
    margin-top: 1.5rem;
  }
}

/* Categories Cards */
.category-card {
  position: relative;
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
  background: white;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.category-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}
.category-card__link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.category-card__media {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.category-card__img {
  width: auto;
  height: auto;
  object-fit: contain;
  transition: transform 0.3s ease;
}
.category-card:hover .category-card__img {
  transform: scale(1.05);
}
.category-card__content {
  padding: 0 2rem 2rem 2rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  text-align: center;
  background: white;
  justify-content: flex-end;
}
.category-card__title {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
  color: #001489;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding-bottom: 1rem;
}
.category-card__separator {
  width: 100%;
  height: 1px;
  background-color: #D9D9D9;
  margin: 1rem 0;
  border: none;
}
.category-card__button {
  margin-top: 0;
}

/* Category Button */
.category-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 2rem;
  border: 2px solid #001489;
  border-radius: 2rem;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  letter-spacing: 0.5px;
  background: transparent;
  color: #001489;
}
.category-btn svg {
  transition: transform 0.3s ease;
}
.category-btn:hover {
  background: #001489;
  color: white;
  text-decoration: none;
}
.category-btn:hover svg {
  transform: translateX(3px);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border: 2px solid var(--color-blue);
  border-radius: 2rem;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  letter-spacing: 0.5px;
}
.btn svg {
  transition: transform 0.3s ease;
}
.btn:hover svg {
  transform: translateX(3px);
}
.btn--primary {
  background: var(--color-blue);
  color: var(--color-white);
  border: 2px solid var(--color-blue);
}
.btn--primary:hover {
  background: var(--color-white);
  color: var(--color-blue);
  text-decoration: none;
}
.btn--secondary {
  background: transparent;
  color: #001489;
  border-color: #001489;
  border-radius: 2rem;
  padding: 0.75rem 2rem;
}
.btn--secondary:hover {
  background: #001489;
  color: white;
  text-decoration: none;
}
.btn--large {
  font-size: 1rem;
  padding: 1rem 2.5rem;
}
@media (max-width: 768px) {
  .btn--large {
    font-size: 0.875rem;
    padding: 0.875rem 2rem;
  }
}

/* Responsive Design - Categories Only */
@media (max-width: 1024px) {
  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 800px;
  }
  .category-card__media {
    height: 200px;
    padding: 1.5rem;
  }
  .category-card__content {
    padding: 1.5rem;
  }
  .category-card__title {
    font-size: 1.25rem;
  }
}
@media (max-width: 768px) {
  .categories-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .category-card__media {
    height: 250px;
    padding: 1rem;
  }
  .category-card__content {
    padding: 1.5rem 1rem;
  }
  .category-card__title {
    font-size: 1.1rem;
    margin-bottom: 1rem;
  }
  .category-btn {
    padding: 0.6rem 1.2rem;
    font-size: 0.8rem;
  }
}
/* Banner Section - Categories Page */
.page-categories .banner {
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .page-categories .banner {
    aspect-ratio: 21/8;
  }
}
.page-categories .banner__img {
  position: absolute;
  top: -20%;
  left: 0;
  height: 120%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}

/*--------------------------------------------------------------
# Centered
--------------------------------------------------------------*/
.centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.centered .btn-container {
  margin-top: clamp(2rem, 1.46vw + 1.66rem, 4rem);
}
.centered h1 {
  font-size: clamp(1.33rem, 1.13vw + 1.06rem, 2.88rem);
  font-size: clamp(1.33rem, 1.32vw + 1.02rem, 3.13rem);
  line-height: 1.2;
}
.centered h2 {
  font-size: clamp(2rem, 1.1vw + 1.75rem, 3.5rem);
  line-height: 1.1;
  font-weight: 400;
  color: var(--color-blue);
  margin-bottom: clamp(1rem, 0.37vw + 0.92rem, 1.5rem);
}
.centered h2 strong {
  font-weight: 700;
}
.centered p {
  max-width: 50rem;
  font-size: clamp(1rem, 0.09vw + 0.98rem, 1.13rem);
  line-height: 1.6;
  color: var(--color-grey);
}
.centered br {
  display: none;
}
@media (min-width: 768px) {
  .centered br {
    display: block;
  }
}

/*--------------------------------------------------------------
# Collapse
--------------------------------------------------------------*/
.collapse {
  padding: 1rem 0;
  overflow: hidden;
  will-change: height, transform;
  transform: translateZ(0px);
}

/*--------------------------------------------------------------
# Our Difference Section
--------------------------------------------------------------*/
.section--difference {
  background: #001489;
  padding: 4rem 0;
}

.difference-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 4rem;
  align-items: center;
}

.difference-title {
  font-size: 2.5rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  color: white !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
}

.difference-title *,
.difference-title h1,
.difference-title h2,
.difference-title h3,
.difference-title h4,
.difference-title h5,
.difference-title h6,
.difference-title p {
  color: white !important;
  font-size: 3rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  text-decoration: none !important;
  display: inline !important;
}

.difference-title strong {
  color: white !important;
  font-size: 2.5rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  text-decoration: none !important;
  display: inline !important;
}

/* Extra specific targeting for WordPress theme overrides */
section .difference-title h2,
.section .difference-title h2,
.container .difference-title h2 {
  color: white !important;
  font-size: 3rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
}

.difference-content {
  font-size: 1.5rem;
  line-height: 1;
  color: white;
  margin-bottom: 2.5rem;
  font-weight: 600;
}
.difference-content p {
  margin-bottom: 1rem;
}
.difference-content p:last-child {
  margin-bottom: 0;
}

.difference-img {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
}

/* Parallax version of difference image */
[data-animate=parallax] .difference-img {
  position: absolute;
  top: -20%;
  left: 0;
  width: 100%;
  height: 120%;
  object-fit: cover;
  will-change: transform;
  border-radius: 0;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .difference-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .difference-title {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
  }
  .difference-content {
    font-size: 1.2rem;
    margin-bottom: 2rem;
  }
}
/*--------------------------------------------------------------
# Drawer
--------------------------------------------------------------*/
.drawer {
  background-color: rgba(39, 39, 39, 0);
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  max-width: none;
  z-index: 30;
  visibility: hidden;
  transition: background-color 0.3s, visibility 0s 0.3s;
}
.drawer:focus {
  outline: none;
}
.drawer--is-visible {
  background-color: rgba(39, 39, 39, 0.25);
  visibility: visible;
  transition: background-color 0.3s;
}
.drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.drawer__close-btn {
  cursor: pointer;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.2s;
}
.drawer__close-btn:hover {
  background-color: var(--color-grey);
}
.drawer__close-btn .icon {
  color: var(--color-white);
  display: block;
}
.drawer__logo {
  display: flex;
  align-items: center;
  width: clamp(12rem, 4.38vw + 10.99rem, 18rem);
  height: auto;
}
.drawer__logo-img {
  height: 100%;
  width: 100%;
}
.drawer__content {
  background-color: var(--color-black);
  width: 100%;
  height: 100%;
  max-width: 900px;
  position: absolute;
  top: 0;
  right: 0;
  padding: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  transform: translateX(100%);
  transition: transform 0.3s;
  transition-timing-function: var(--ease-in-out);
}
.drawer--is-visible .drawer__content {
  transform: translateX(0);
}
.drawer__body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  overflow: auto;
}
.drawer__nav {
  margin-top: auto;
  margin-bottom: 3rem;
  overflow: hidden;
}
.drawer__list li {
  opacity: 0;
  transform: translateX(20%);
  transition-property: opacity, transform;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.75, -0.015, 0.565, 1.055);
  transition-delay: 0.4s;
}
.drawer--is-visible .drawer__list li {
  opacity: 1;
  transform: translateX(0);
}
.drawer--is-visible .drawer__list li:nth-child(1) {
  transition-delay: 0.06s;
}
.drawer--is-visible .drawer__list li:nth-child(2) {
  transition-delay: 0.1s;
}
.drawer--is-visible .drawer__list li:nth-child(3) {
  transition-delay: 0.12s;
}
.drawer--is-visible .drawer__list li:nth-child(4) {
  transition-delay: 0.18s;
}
.drawer--is-visible .drawer__list li:nth-child(5) {
  transition-delay: 0.24s;
}
.drawer__link {
  cursor: pointer;
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(2.25rem, 1.92vw + 1.81rem, 4.88rem);
  font-weight: 700;
  display: flex;
  align-items: center;
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-transform: uppercase;
  transition: 0.3s var(--ease-out);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
}
@media (min-width: 768px) {
  .drawer__link {
    line-height: 1;
  }
}
.drawer__link:hover {
  color: var(--color-grey);
}
.drawer__sublink {
  color: var(--color-white);
  font-family: var(--font-mono);
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 2;
  text-transform: uppercase;
  transition: color 0.3s var(--ease-out);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.drawer__sublink:hover {
  color: var(--color-grey);
}
.drawer__icon-plus {
  margin-left: 1rem;
}
.drawer__icon-plus .icon__group {
  transform: rotate(0);
  transform-origin: 50% 50%;
  transition: transform 0.3s ease;
  will-change: transform;
}
.drawer__icon-plus .icon__group > * {
  transition: transform 0.3s, stroke-dashoffset 0.3s;
  transition-timing-function: ease;
}
.drawer__icon-plus .icon__group > *:first-child {
  transform: rotate(0);
}
.drawer__link[aria-expanded=true] > .drawer__icon-plus .icon__group {
  transform: rotate(-90deg);
  color: var(--color-grey);
}
.drawer__link[aria-expanded=true] > .drawer__icon-plus .icon__group > * {
  transform-origin: 50% 50%;
}
.drawer__link[aria-expanded=true] > .drawer__icon-plus .icon__group > *:first-child {
  transform: rotate(-90deg);
}
.drawer__sublist li {
  font-family: var(--font-mono);
  color: var(--color-white);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transform: translateX(-0.925rem);
  transition: 0.3s var(--ease-out);
}
.drawer__sublist li:hover {
  color: var(--color-grey);
  transform: translateX(0);
}
.drawer__sublist li::before {
  content: "⟶";
  padding-bottom: 5px;
}
.drawer__footer {
  color: var(--color-white);
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  display: flex;
  gap: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.drawer__footer a {
  display: flex;
  line-height: 1.8;
}
.drawer__socials {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  transition: 0.2s var(--ease-out);
}
.drawer__socials:hover {
  color: var(--color-grey);
}
.drawer__socials .icon {
  font-size: 0.875em;
}

/*--------------------------------------------------------------
# Empty
--------------------------------------------------------------*/
.empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 16vh 0;
  position: relative;
  z-index: 5;
}
.empty .btn {
  display: flex;
  margin: 2rem auto 0 auto;
}

/*--------------------------------------------------------------
# Equipment Cards
--------------------------------------------------------------*/
.section--equipment-bg {
  background: linear-gradient(135deg, var(--color-blue) 0%, #000C5A 100%);
  position: relative;
  overflow: hidden;
}
.section--equipment-bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50px;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3) 0%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}
.section--equipment-bg::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 50px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.3) 0%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}

.equipment-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(4rem, 1.46vw + 3.66rem, 6rem);
  margin-top: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .equipment-grid {
    grid-template-columns: 1fr;
    gap: clamp(3rem, 0.73vw + 2.83rem, 4rem);
    max-width: 600px;
    margin: clamp(3rem, 0.73vw + 2.83rem, 4rem) auto 0;
  }
}
@media (min-width: 1200px) {
  .equipment-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(6rem, 2.92vw + 5.32rem, 10rem);
  }
}

.equipment-card {
  position: relative;
  transition: transform 0.3s var(--ease-out);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.equipment-card:hover {
  transform: translateY(-0.25rem);
}
.equipment-card__link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.equipment-card__media {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  border-radius: 0.5rem;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .equipment-card__media {
    aspect-ratio: 1/1;
  }
}
.equipment-card__img {
  position: absolute;
  top: -20%;
  left: 0;
  width: 100%;
  height: 120%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
  will-change: transform;
}
.equipment-card:hover .equipment-card__img {
  transform: scale(1.05);
}
.equipment-card__content {
  padding: clamp(2rem, 0.37vw + 1.92rem, 2.5rem) 0;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  text-align: center;
}
.equipment-card__title {
  font-size: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--color-white);
  margin-bottom: clamp(1rem, 0.37vw + 0.92rem, 1.5rem);
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.equipment-card__desc {
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  line-height: 1.5;
  color: var(--color-white);
  margin-bottom: auto;
  flex-grow: 1;
}
.equipment-card__button {
  margin-top: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
}
.equipment-card__button .btn {
  padding: clamp(0.88rem, 0.09vw + 0.85rem, 1rem) clamp(2rem, 0.37vw + 1.92rem, 2.5rem);
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  font-weight: 600;
  letter-spacing: 0.05em;
  border-width: 2px;
  transition: all 0.3s var(--ease-out);
  display: inline-block;
  border-radius: 2rem;
}

.btn--white {
  border-color: var(--color-white);
  color: var(--color-white);
  background-color: transparent;
}
.btn--white:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
}

/*--------------------------------------------------------------
# Equipment Archive Styles
--------------------------------------------------------------*/
/* Hero Subtitle Styling */
.hero__subtitle {
  color: white;
  font-size: 1.2rem;
  line-height: 1.5;
  margin-top: 1rem;
  opacity: 0.9;
  max-width: 600px;
}
@media (max-width: 768px) {
  .hero__subtitle {
    font-size: 1rem;
    margin-top: 0.75rem;
  }
}

/* Equipment Archive Section */
.equipment-archive {
  background: #EFEFEF;
  padding: 3rem 0;
  min-height: 80vh;
}

/* Full Width Header Section */
.equipment-header-section {
  margin-bottom: 3rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
}
@media (max-width: 768px) {
  .equipment-header-section {
    flex-direction: column;
    gap: 1.5rem;
    align-items: stretch;
  }
}
.equipment-header-section .equipment-intro {
  margin-bottom: 0;
}
.equipment-header-section .equipment-intro .about-intro-title {
  margin-bottom: 0 !important;
}
.equipment-header-section .equipment-intro .hero__hr {
  display: none;
}
.equipment-header-section .equipment-sorting-bar {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .equipment-header-section .equipment-sorting-bar {
    justify-content: flex-start;
  }
}
.equipment-header-section::after {
  content: "";
  position: absolute;
  bottom: -1.5rem;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #D9D9D9;
}

/* Main Grid Layout */
.equipment-main-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 3rem;
}
@media (max-width: 1024px) {
  .equipment-main-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

/* Left Sidebar */
.equipment-sidebar {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media (max-width: 1024px) {
  .equipment-sidebar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
    gap: 1.5rem;
  }
}
@media (max-width: 768px) {
  .equipment-sidebar {
    grid-template-columns: 1fr;
  }
}

.sidebar-section h3 {
  font-size: 0.9rem;
  font-weight: 600;
  color: #001489;
  text-transform: uppercase;
  margin-bottom: 1rem;
  letter-spacing: 0.5px;
}
.sidebar-section .search-input-wrapper input {
  width: 100%;
  padding: 0.875rem 1.25rem;
  border: 2px solid var(--color-blue);
  border-radius: 2rem;
  font-size: 1rem;
  transition: all 0.3s ease;
  background: transparent;
}
.sidebar-section .search-input-wrapper input:focus {
  outline: none;
  border-color: #001489;
  box-shadow: 0 0 0 3px rgba(0, 20, 137, 0.1);
}
.sidebar-section .search-input-wrapper input::placeholder {
  color: #000;
  font-size: 0.95rem;
}
.sidebar-section .filter-categories,
.sidebar-section .filter-brands {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sidebar-section .filter-item {
  padding: 1rem 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid #000;
  border-radius: 0;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sidebar-section .filter-item:last-child {
  border-bottom: none;
}
.sidebar-section .filter-item .category-name,
.sidebar-section .filter-item .brand-name {
  font-weight: 400;
  color: #272727;
  font-size: 1rem;
}
.sidebar-section .filter-item::after {
  content: "";
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 10'%3e%3cpath stroke='%23001489' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.2' d='M1 5H15M15 5L11 1M15 5L11 9'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px;
  opacity: 0;
  transition: all 0.3s ease;
}
.sidebar-section .filter-item:hover:not(.active) .category-name,
.sidebar-section .filter-item:hover:not(.active) .brand-name {
  color: #001489;
  font-weight: bold;
}
.sidebar-section .filter-item:hover:not(.active)::after {
  opacity: 1;
}
.sidebar-section .filter-item.active .category-name,
.sidebar-section .filter-item.active .brand-name {
  color: #001489;
  font-weight: 600;
}
.sidebar-section .filter-item.active::after {
  opacity: 1;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='%23001489' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4l8 8M12 4l-8 8'/%3e%3c/svg%3e");
}
.sidebar-section .filter-item.active:hover::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='%23ff0000' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4l8 8M12 4l-8 8'/%3e%3c/svg%3e");
}

/* Right Content Area */
/* Equipment Results Info Bar */
.equipment-results-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 2rem;
  padding: 1rem;
  background: white;
  border-radius: 0.5rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}
@media (max-width: 768px) {
  .equipment-results-info {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
}
.equipment-results-info .results-count {
  font-size: 0.95rem;
  color: #666;
  white-space: nowrap;
}
.equipment-results-info .results-count strong {
  color: #001489;
  font-weight: 600;
}
@media (max-width: 768px) {
  .equipment-results-info .results-count {
    font-size: 0.9rem;
  }
}
.equipment-results-info .active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  flex: 1;
  justify-content: flex-end;
}
@media (max-width: 768px) {
  .equipment-results-info .active-filters {
    justify-content: flex-start;
    width: 100%;
  }
}

/* Filter Tag Styles */
.filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  background: #f0f7ff;
  border: 1px solid #001489;
  border-radius: 1.5rem;
  font-size: 0.85rem;
  color: #001489;
}
.filter-tag__label {
  font-weight: 600;
}
.filter-tag__value {
  font-weight: 400;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.filter-tag__remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  color: #001489;
  transition: all 0.2s ease;
  border-radius: 50%;
  margin-left: 0.25rem;
}
.filter-tag__remove:hover {
  background: #001489;
  color: white;
}
.filter-tag__remove svg {
  width: 12px;
  height: 12px;
}
.filter-tag--clear-all {
  background: #001489;
  color: white;
  border: 1px solid #001489;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0.5rem 1rem;
}
.filter-tag--clear-all:hover {
  background: transparent;
  color: #001489;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 20, 137, 0.2);
}
@media (max-width: 768px) {
  .filter-tag {
    font-size: 0.8rem;
    padding: 0.4rem 0.6rem;
  }
  .filter-tag__value {
    max-width: 120px;
  }
  .filter-tag--clear-all {
    padding: 0.4rem 0.8rem;
  }
}

/* Equipment Intro Section */
.equipment-intro {
  text-align: left;
  margin-bottom: 2rem;
}
.equipment-intro .about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}
.equipment-intro .about-intro-title *,
.equipment-intro .about-intro-title h1,
.equipment-intro .about-intro-title h2,
.equipment-intro .about-intro-title h3,
.equipment-intro .about-intro-title h4,
.equipment-intro .about-intro-title h5,
.equipment-intro .about-intro-title h6,
.equipment-intro .about-intro-title p {
  font-size: 3rem;
  color: #001489 !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.equipment-intro .about-intro-title strong {
  font-weight: 700 !important;
}
@media (max-width: 768px) {
  .equipment-intro .about-intro-title {
    font-size: 2rem !important;
  }
  .equipment-intro .about-intro-title *,
  .equipment-intro .about-intro-title h1,
  .equipment-intro .about-intro-title h2,
  .equipment-intro .about-intro-title h3,
  .equipment-intro .about-intro-title h4,
  .equipment-intro .about-intro-title h5,
  .equipment-intro .about-intro-title h6,
  .equipment-intro .about-intro-title p {
    font-size: 2rem !important;
  }
}
.equipment-intro .hero__hr {
  background-color: #D9D9D9;
  border-color: #D9D9D9;
  border: none;
  height: 1px;
  margin: 0;
}

/* Equipment Sorting Bar */
.equipment-sorting-bar {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
  margin-bottom: 2rem;
}
@media (max-width: 991px) {
  .equipment-sorting-bar {
    justify-content: center;
    flex-direction: column;
    gap: 0.75rem;
  }
}
.equipment-sorting-bar .sorting-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
  min-width: 200px;
}
@media (max-width: 991px) {
  .equipment-sorting-bar .sorting-wrapper {
    align-items: center;
    width: 100%;
    max-width: none;
  }
}
.equipment-sorting-bar .sorting-wrapper label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #001489;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.equipment-sorting-bar .sorting-wrapper select {
  padding: 0.875rem 1.25rem;
  border: 2px solid var(--color-blue);
  border-radius: 2rem;
  font-size: 1rem;
  transition: all 0.3s ease;
  background: transparent;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23001489' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 1rem center;
  background-repeat: no-repeat;
  background-size: 1rem;
  padding-right: 3rem;
  width: 100%;
}
.equipment-sorting-bar .sorting-wrapper select:focus {
  outline: none;
  border-color: #001489;
  box-shadow: 0 0 0 3px rgba(0, 20, 137, 0.1);
}
@media (max-width: 768px) {
  .equipment-sorting-bar .sorting-wrapper select {
    font-size: 0.95rem;
  }
}

/* Equipment Grid Archive */
.equipment-grid-archive {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: 3rem;
}
@media (max-width: 768px) {
  .equipment-grid-archive {
    gap: 1.5rem;
  }
}

/* Equipment Card Archive */
.equipment-card-archive {
  background: white;
  border-radius: 0.7rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
}
.equipment-card-archive:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}
.equipment-card-archive__link {
  display: flex;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
@media (max-width: 768px) {
  .equipment-card-archive__link {
    flex-direction: column;
  }
}
.equipment-card-archive__image {
  position: relative;
  width: 300px;
  min-width: 300px;
  height: 200px;
  background: #f5f5f5;
  overflow: hidden;
  margin: 1rem;
  border-radius: 0.6rem;
}
@media (max-width: 768px) {
  .equipment-card-archive__image {
    width: auto;
    min-width: auto;
    height: 250px;
    margin: 1rem 1rem 0 1rem;
  }
}
.equipment-card-archive__image picture {
  width: 100%;
  height: 100%;
  display: block;
}
.equipment-card-archive__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
  border-radius: 0.6rem;
  display: block;
}
.equipment-card-archive:hover .equipment-card-archive__img {
  transform: scale(1.05);
}
.equipment-card-archive__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 150px;
  height: 100%;
  background: #f0f0f0;
  border-radius: 0.6rem;
}
@media (max-width: 768px) {
  .equipment-card-archive__placeholder {
    min-height: 200px;
  }
}
.equipment-card-archive__content {
  flex: 1;
  padding: 1.5rem 1.5rem 1.5rem 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 768px) {
  .equipment-card-archive__content {
    padding: 1rem 1.5rem 1.5rem 1.5rem;
  }
}
.equipment-card-archive__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.75rem;
  gap: 1rem;
}
@media (max-width: 768px) {
  .equipment-card-archive__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
}
.equipment-card-archive__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #001489;
  margin: 0;
  line-height: 1.3;
  flex: 1;
}
@media (max-width: 768px) {
  .equipment-card-archive__title {
    font-size: 1.25rem;
  }
}
.equipment-card-archive__price {
  font-size: 1.25rem;
  font-weight: 700;
  color: #001489;
  background: #f0f7ff;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  border: 2px solid #001489;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .equipment-card-archive__price {
    font-size: 1.1rem;
    padding: 0.4rem 0.8rem;
  }
}
.equipment-card-archive__description {
  color: #666;
  font-size: 0.95rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}
.equipment-card-archive__bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}
@media (max-width: 768px) {
  .equipment-card-archive__bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
}
.equipment-card-archive__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  flex: 1;
}
.equipment-card-archive__specs .spec-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: transparent;
  border: 2px solid #001489;
  border-radius: 2rem;
  font-size: 0.85rem;
}
.equipment-card-archive__specs .spec-pill .icon {
  color: #001489;
  font-size: 0.9rem;
  flex-shrink: 0;
}
.equipment-card-archive__specs .spec-pill .spec-label {
  font-weight: 600;
  color: #001489;
}
.equipment-card-archive__specs .spec-pill .spec-value {
  color: #001489;
  font-weight: 500;
}
.equipment-card-archive__specs .spec-pill:nth-child(3):nth-last-child(n+2)::after {
  content: "";
  flex-basis: 100%;
  height: 0;
}
.equipment-card-archive__specs .spec-pill--download {
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.85rem;
  background: #001489 !important;
  border-color: #001489;
}
.equipment-card-archive__specs .spec-pill--download .icon,
.equipment-card-archive__specs .spec-pill--download .spec-label {
  color: white;
}
.equipment-card-archive__specs .spec-pill--download:hover {
  background: transparent !important;
  border-color: #001489;
}
.equipment-card-archive__specs .spec-pill--download:hover .icon,
.equipment-card-archive__specs .spec-pill--download:hover .spec-label {
  color: #001489;
}
.equipment-card-archive__specs button.spec-pill {
  border: 2px solid #001489;
  background: transparent;
  font-family: inherit;
}
.equipment-card-archive__share {
  align-self: flex-start;
  margin-top: 2px;
  margin-bottom: 2px;
}
.equipment-card-archive__share .social-buttons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
@media (max-width: 768px) {
  .equipment-card-archive__share .social-buttons {
    justify-content: flex-start;
  }
}
.equipment-card-archive__share .social-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 35px;
  height: 35px;
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s ease;
  color: #6b7280;
  font-size: 14px;
}
.equipment-card-archive__share .social-button:hover {
  background: #f3f4f6;
  border-color: var(--color-primary);
  color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}
.equipment-card-archive__share .social-button .icon {
  flex-shrink: 0;
}
.equipment-card-archive__share .social-button:nth-child(1):hover {
  background: #1877f2;
  border-color: #1877f2;
  color: white;
}
.equipment-card-archive__share .social-button:nth-child(2):hover {
  background: #000000;
  border-color: #000000;
  color: white;
}
.equipment-card-archive__share .social-button:nth-child(3):hover {
  background: #25d366;
  border-color: #25d366;
  color: white;
}
.equipment-card-archive__share .social-button:nth-child(4):hover {
  background: var(--color-blue);
  border-color: var(--color-blue);
  color: white;
}

/* Download Brochure Button - Floating */
.download-brochure-btn--floating {
  position: absolute;
  bottom: 1.2rem;
  left: 1.2rem;
  z-index: 10;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  background: var(--color-blue);
  color: white;
  border-radius: 0.5rem;
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  letter-spacing: 0.5px;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
  border: 2px solid var(--color-blue);
}
.download-brochure-btn--floating .icon {
  font-size: 0.9rem;
  flex-shrink: 0;
}
.download-brochure-btn--floating:hover {
  background: var(--color-white);
  color: var(--color-blue);
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 20, 137, 0.4);
}
@media (max-width: 768px) {
  .download-brochure-btn--floating {
    font-size: 0.5rem;
    padding: 0.6rem 0.875rem;
    bottom: 0.75rem;
    left: 0.75rem;
    margin: 0.75rem;
  }
  .download-brochure-btn--floating span {
    display: none;
  }
  .download-brochure-btn--floating .icon {
    font-size: 1rem;
  }
}

/* No Equipment Message */
.no-equipment {
  text-align: center;
  padding: 3rem;
  background: white;
  border-radius: 1rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.no-equipment p {
  font-size: 1.2rem;
  color: #666;
  margin: 0;
}

/* Equipment Pagination */
.equipment-pagination {
  display: flex;
  justify-content: center;
  margin: 3rem 0;
}
.equipment-pagination .navigation {
  width: 100%;
}
.equipment-pagination .screen-reader-text {
  display: none;
}
.equipment-pagination .nav-links {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.equipment-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 45px;
  height: 45px;
  padding: 0 1rem;
  background: white;
  border: 2px solid #D9D9D9;
  border-radius: 0.5rem;
  text-decoration: none;
  color: #272727;
  font-weight: 600;
  font-size: 1rem;
  transition: all 0.3s ease;
}
.equipment-pagination .page-numbers:hover:not(.current):not(.dots) {
  border-color: #001489;
  background: #f0f7ff;
  color: #001489;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.15);
}
.equipment-pagination .page-numbers.current {
  background: #001489;
  border-color: #001489;
  color: white;
  font-weight: 700;
  cursor: default;
}
.equipment-pagination .page-numbers.dots {
  border: none;
  background: transparent;
  cursor: default;
  min-width: auto;
  padding: 0 0.5rem;
}
.equipment-pagination .page-numbers.dots:hover {
  background: transparent;
  transform: none;
  box-shadow: none;
}
.equipment-pagination .page-numbers.prev, .equipment-pagination .page-numbers.next {
  padding: 0 1.25rem;
  font-weight: 600;
}
.equipment-pagination .page-numbers.prev:hover, .equipment-pagination .page-numbers.next:hover {
  background: #001489;
  border-color: #001489;
  color: white;
}
@media (max-width: 768px) {
  .equipment-pagination {
    margin: 2rem 0;
  }
  .equipment-pagination .page-numbers {
    min-width: 40px;
    height: 40px;
    font-size: 0.9rem;
    padding: 0 0.75rem;
  }
  .equipment-pagination .page-numbers.prev, .equipment-pagination .page-numbers.next {
    padding: 0 1rem;
    font-size: 0.85rem;
  }
}

/* Loading State */
.equipment-loading {
  position: relative;
}
.equipment-loading::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.8);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}
.equipment-loading::after {
  content: "Loading...";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 11;
  font-weight: 600;
  color: #001489;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .equipment-filters .filters-sidebar {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .equipment-archive {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
  .equipment-filters {
    margin-bottom: 2rem;
  }
  .equipment-filters .filters-row {
    margin-bottom: 1.5rem;
  }
  .equipment-filters .filters-sidebar h3 {
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
  }
  .equipment-grid-archive {
    gap: 1rem;
  }
  .equipment-card-archive__title {
    font-size: 1.1rem;
    margin-bottom: 0.75rem;
  }
  .equipment-card-archive__specs .spec-item .spec-label,
  .equipment-card-archive__specs .spec-item .spec-value {
    font-size: 0.8rem;
  }
}
/* Mobile filter toggle styles */
.filter-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  transition: color 0.3s ease;
}

.filter-toggle-icon {
  transition: transform 0.3s ease;
  margin-left: 0.5rem;
}

.filter-toggle-icon.rotated {
  transform: rotate(180deg);
}

/* Hide filters on mobile by default */
@media (max-width: 991px) {
  .filter-collapsible {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
  }
  .filter-collapsible.filter-open {
    max-height: 1000px;
    transition: max-height 0.5s ease-in;
  }
  .filter-toggle {
    padding: 0.5rem 0;
  }
  .filter-toggle:hover {
    color: #001489;
  }
}
/* Show filters on desktop by default */
@media (min-width: 992px) {
  .filter-toggle {
    cursor: default;
  }
  .filter-toggle-icon {
    display: none;
  }
  .filter-collapsible {
    max-height: none !important;
  }
}
/*--------------------------------------------------------------
# Single Equipment Page Styles
--------------------------------------------------------------*/
.single-equipment-page {
  padding: clamp(2rem, 1.46vw + 1.66rem, 4rem) 0;
  background: var(--color-white);
}
@media (max-width: 768px) {
  .single-equipment-page {
    padding-bottom: 0;
  }
}
.single-equipment-page .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}

.equipment-header {
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  text-align: center;
}

.equipment-title-section {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
}
@media (max-width: 768px) {
  .equipment-title-section {
    flex-direction: column;
    gap: 1rem;
    text-align: center;
  }
}

.equipment-title {
  font-size: clamp(2rem, 0.37vw + 1.92rem, 2.5rem);
  font-weight: 700;
  color: var(--color-blue);
  text-transform: uppercase;
  margin: 0;
  line-height: 1.2;
  text-align: left;
}

.equipment-price {
  font-size: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  font-weight: 700;
  color: var(--color-blue);
  background: #f0f7ff;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  border: 2px solid var(--color-blue);
}

.equipment-main-layout {
  display: grid;
  grid-template-columns: 7fr 3fr;
  gap: clamp(2rem, 1.46vw + 1.66rem, 4rem);
  margin-bottom: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  width: 100%;
}
@media (max-width: 1024px) {
  .equipment-main-layout {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

.equipment-gallery-section {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.equipment-gallery {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.splide--equipment-main {
  margin-bottom: 1rem;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}
.splide--equipment-main .splide__track {
  border-radius: 12px;
}
.splide--equipment-main .splide__slide {
  position: relative;
}
.splide--equipment-main .equipment-slide-link {
  display: block;
  cursor: pointer;
  position: relative;
  text-decoration: none;
}
.splide--equipment-main .equipment-slide-link .zoom-indicator {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  background: rgba(0, 20, 137, 0.85);
  border-radius: 50%;
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}
.splide--equipment-main .equipment-slide-link .zoom-indicator .icon {
  width: 24px;
  height: 24px;
  color: white;
  fill: white;
}
.splide--equipment-main .equipment-slide-link:hover .zoom-indicator {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.05);
}
.splide--equipment-main .equipment-slide-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
}
@media (max-width: 768px) {
  .splide--equipment-main .equipment-slide-wrapper {
    aspect-ratio: 4/3;
  }
}
.splide--equipment-main .equipment-slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}
.splide--equipment-main .equipment-slide-link:hover .equipment-slide-img {
  transform: scale(1.02);
}
.splide--equipment-main .splide__arrow {
  position: absolute !important;
  top: 50% !important;
  background: rgba(0, 0, 0, 0.7) !important;
  color: white !important;
  width: 50px !important;
  height: 50px !important;
  border-radius: 50% !important;
  border: none !important;
  cursor: pointer !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color 0.2s ease !important;
  margin-top: -25px !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  transform: translateY(0) scale(1) !important;
  opacity: 0.7 !important;
  pointer-events: auto !important;
}
.splide--equipment-main .splide__arrow:hover {
  background: rgba(0, 0, 0, 0.9) !important;
  transform: translateY(0) scale(1) !important;
  opacity: 0.9 !important;
}
.splide--equipment-main .splide__arrow[style*=transform] {
  transform: translateY(0) scale(1) !important;
}
.splide--equipment-main .splide__arrow svg {
  fill: white !important;
  width: 1.2em !important;
  height: 1.2em !important;
  pointer-events: none !important;
}
@media (max-width: 768px) {
  .splide--equipment-main .splide__arrow {
    width: 40px !important;
    height: 40px !important;
    margin-top: -20px !important;
  }
}
.splide--equipment-main .splide__arrow--prev {
  left: 1rem !important;
}
@media (max-width: 768px) {
  .splide--equipment-main .splide__arrow--prev {
    left: 0.5rem !important;
  }
}
.splide--equipment-main .splide__arrow--next {
  right: 1rem !important;
}
@media (max-width: 768px) {
  .splide--equipment-main .splide__arrow--next {
    right: 0.5rem !important;
  }
}

.image-overlay {
  position: absolute;
  background: rgba(220, 38, 38, 0.9);
  color: white;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  border-radius: 4px;
  z-index: 10;
}
.image-overlay.overlay-1 {
  top: 1rem;
  left: 1rem;
}
.image-overlay.overlay-2 {
  top: 1rem;
  right: 1rem;
}
@media (max-width: 768px) {
  .image-overlay {
    font-size: 0.75rem;
    padding: 0.4rem 0.8rem;
  }
  .image-overlay.overlay-1 {
    top: 0.5rem;
    left: 0.5rem;
  }
  .image-overlay.overlay-2 {
    top: 0.5rem;
    right: 0.5rem;
  }
}

.splide--equipment-thumbnails {
  margin-top: 1rem;
}
.splide--equipment-thumbnails .splide__track {
  padding: 0.5rem 0;
}
.splide--equipment-thumbnails .splide__slide {
  opacity: 0.6;
  transition: all 0.3s ease;
  cursor: pointer;
  border: 3px solid var(--color-blue);
  border-radius: 8px;
  overflow: hidden;
}
.splide--equipment-thumbnails .splide__slide.is-active {
  opacity: 1;
  border-color: var(--color-blue);
  transform: scale(1.05);
}
.splide--equipment-thumbnails .splide__slide:hover {
  opacity: 1;
  border-color: var(--color-blue);
}
.splide--equipment-thumbnails .equipment-thumb-img {
  width: 100%;
  height: 80px;
  object-fit: cover;
  display: block;
}
@media (max-width: 768px) {
  .splide--equipment-thumbnails .equipment-thumb-img {
    height: 60px;
  }
}
.splide--equipment-thumbnails .splide__arrow {
  position: absolute !important;
  top: 50% !important;
  background: rgba(0, 0, 0, 0.6) !important;
  color: white !important;
  width: 35px !important;
  height: 35px !important;
  border-radius: 50% !important;
  border: none !important;
  cursor: pointer !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color 0.2s ease !important;
  margin-top: -17.5px !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  transform: translateY(0) scale(1) !important;
  opacity: 0.7 !important;
}
.splide--equipment-thumbnails .splide__arrow:hover {
  background: rgba(0, 0, 0, 0.8) !important;
  transform: translateY(0) scale(1) !important;
  opacity: 0.9 !important;
}
.splide--equipment-thumbnails .splide__arrow[style*=transform] {
  transform: translateY(0) scale(1) !important;
}
.splide--equipment-thumbnails .splide__arrow svg {
  fill: white !important;
  width: 1em !important;
  height: 1em !important;
  pointer-events: none !important;
}
@media (max-width: 768px) {
  .splide--equipment-thumbnails .splide__arrow {
    width: 30px !important;
    height: 30px !important;
    margin-top: -15px !important;
  }
}

.contact-form-sidebar {
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  height: fit-content;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}
.contact-form-sidebar h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 0.5rem 0;
  text-transform: uppercase;
}
.contact-form-sidebar h4 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-blue);
  margin: 0 0 1.5rem 0;
  text-transform: uppercase;
  border-bottom: 2px solid var(--color-blue);
  padding-bottom: 0.5rem;
}
@media (max-width: 767px) {
  .contact-form-sidebar--desktop {
    display: none;
  }
}

.mobile-enquiry-section {
  display: none;
  padding: clamp(2rem, 0.73vw + 1.83rem, 3rem) 0;
}
@media (max-width: 767px) {
  .mobile-enquiry-section {
    display: block;
    padding-top: 0;
  }
}
.mobile-enquiry-section .contact-form-container--mobile {
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}
.mobile-enquiry-section .contact-form-container--mobile h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 0.5rem 0;
  text-transform: uppercase;
}
.mobile-enquiry-section .contact-form-container--mobile h4 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-blue);
  margin: 0 0 1.5rem 0;
  text-transform: uppercase;
  border-bottom: 2px solid var(--color-blue);
  padding-bottom: 0.5rem;
}

.equipment-overview-section {
  margin-bottom: clamp(3rem, 0.73vw + 2.83rem, 4rem);
}
@media (max-width: 767px) {
  .equipment-overview-section {
    padding-bottom: 0;
  }
}
.equipment-overview-section .overview-header {
  text-align: center;
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
.equipment-overview-section .overview-header h2 {
  font-size: clamp(1.75rem, 0.37vw + 1.67rem, 2.25rem);
  font-weight: 400;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-blue);
}

.overview-layout {
  display: grid;
  grid-template-columns: 7fr 3fr;
  gap: clamp(2rem, 1.46vw + 1.66rem, 4rem);
  align-items: start;
  width: 100%;
  max-width: 100%;
}
@media (max-width: 1024px) {
  .overview-layout {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

.overview-content {
  background: var(--color-primary);
  color: black;
  border-radius: 12px;
  padding: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  line-height: 1.6;
}
.overview-content p {
  margin-bottom: 1rem;
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
}
.overview-content ul {
  margin: 1rem 0 !important;
  padding-left: 2rem !important;
  list-style: disc !important;
  list-style-position: outside !important;
}
.overview-content ul li {
  margin-bottom: 0.5rem;
  display: list-item !important;
  list-style: disc !important;
  list-style-position: outside !important;
}
.overview-content ol {
  margin: 1rem 0 !important;
  padding-left: 2rem !important;
  list-style: decimal !important;
  list-style-position: outside !important;
}
.overview-content ol li {
  margin-bottom: 0.5rem;
  display: list-item !important;
  list-style: decimal !important;
  list-style-position: outside !important;
}
.overview-content strong {
  font-weight: 700;
}
.overview-content h1, .overview-content h2, .overview-content h3, .overview-content h4, .overview-content h5, .overview-content h6 {
  color: var(--color-blue);
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

.overview-sidebar {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding-top: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  padding-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}

.equipment-specifications {
  margin-bottom: 0;
}
.equipment-specifications h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  margin: 0.5rem 0 1rem 0;
  letter-spacing: 0.5px;
}

.spec-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.spec-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 1rem;
  transition: all 0.3s ease;
}
.spec-item:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.spec-icon {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-blue);
  border-radius: 8px;
  font-size: 24px;
}
.spec-icon .icon {
  width: 1em;
  height: 1em;
}

.spec-details {
  flex: 1;
}
.spec-details .spec-label {
  display: block;
  font-size: 0.875rem;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0.25rem;
}
.spec-details .spec-value {
  display: block;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-primary);
}

.action-pills {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 0;
}

.action-pills-vertical {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.overview-sidebar .action-pills {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.equipment-main-layout .action-pills {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
@media (max-width: 768px) {
  .equipment-main-layout .action-pills {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }
}

.action-pills-left {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .action-pills-left {
    justify-content: center;
  }
}

.action-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--color-white);
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
  padding: 0.75rem 1.5rem;
  border-radius: 2rem;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.action-pill:hover {
  background: var(--color-primary);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 20, 137, 0.3);
}
.action-pill.stock-pill {
  background: var(--color-blue);
  color: white;
  border: 2px solid var(--color-blue);
}
.action-pill.stock-pill:hover {
  background: transparent;
  color: var(--color-blue);
}
.action-pill.download-pill {
  background: var(--color-blue);
  color: white;
  border: 2px solid var(--color-blue);
}
.action-pill.download-pill:hover {
  background: transparent;
  color: var(--color-blue);
}

.pill-label {
  font-size: 0.75rem;
  opacity: 0.8;
}

.pill-value {
  font-weight: 700;
}

.social-section h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  margin: 0 0 1rem 0;
  letter-spacing: 0.5px;
  text-align: left;
}

.social-buttons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}
.overview-sidebar .social-buttons {
  justify-content: start;
}

.social-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s ease;
  color: #6b7280;
  font-size: 16px;
}
.social-button:hover {
  background: #f3f4f6;
  border-color: var(--color-primary);
  color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}
.social-button .icon {
  flex-shrink: 0;
}
.social-button:nth-child(1):hover {
  background: #1877f2;
  border-color: #1877f2;
  color: white;
}
.social-button:nth-child(2):hover {
  background: #000000;
  border-color: #000000;
  color: white;
}
.social-button:nth-child(3):hover {
  background: #25d366;
  border-color: #25d366;
  color: white;
}
.social-button:nth-child(4):hover {
  background: var(--color-blue);
  border-color: var(--color-blue);
  color: white;
}

@media (max-width: 768px) {
  .equipment-main-layout {
    grid-template-columns: 1fr;
  }
  .gallery-thumbnails {
    justify-content: center;
    margin: 0;
    padding: 0 1rem;
  }
  .gallery-thumbnails-slider {
    justify-content: center;
  }
  .spec-grid {
    grid-template-columns: 1fr;
  }
  .action-pills {
    justify-content: center;
  }
  .share-options {
    justify-content: center;
  }
  .equipment-gallery-section {
    margin-bottom: 2rem;
  }
  .gallery-main-image {
    margin-bottom: 1.5rem;
  }
}
.gravity-form-placeholder {
  margin-top: 2rem;
}

/*--------------------------------------------------------------
# FAQ Section
--------------------------------------------------------------*/
.faq-section {
  background: #f8f9fa;
}

.faq-accordion {
  max-width: 900px;
  margin: 0 auto;
}

.faq-item {
  background: var(--color-white);
  border-radius: 0.75rem;
  margin-bottom: 1rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transition: all 0.3s ease;
  overflow: hidden;
}
.faq-item:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.faq-item:last-child {
  margin-bottom: 0;
}

.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(1.25rem, 0.55vw + 1.12rem, 2rem);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: all 0.3s ease;
  position: relative;
}
.faq-question:hover {
  background: rgba(0, 20, 137, 0.02);
  border-radius: 0.75rem;
}
.faq-question:focus {
  outline: 2px solid var(--color-blue);
  outline-offset: -2px;
  border-radius: 0.75rem;
}

.faq-question-text {
  flex: 1;
  font-size: clamp(1.13rem, 0.18vw + 1.08rem, 1.38rem);
  font-weight: 600;
  color: #1a1a1a;
  line-height: 1.4;
  margin: 0;
  padding-right: 1.5rem;
  transition: color 0.3s ease;
}
.faq-item--active .faq-question-text {
  color: var(--color-blue);
}

.faq-toggle-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 20, 137, 0.08);
  border-radius: 50%;
  transition: all 0.3s ease;
}
.faq-item--active .faq-toggle-icon {
  background: var(--color-blue);
  transform: rotate(180deg);
}
.faq-toggle-icon svg {
  width: 24px;
  height: 24px;
  color: var(--color-blue);
}
.faq-item--active .faq-toggle-icon svg {
  color: var(--color-white);
}

.faq-icon-plus {
  transition: opacity 0.3s ease;
  opacity: 1;
}
.faq-item--active .faq-icon-plus {
  opacity: 0;
}

.faq-icon-minus {
  transition: opacity 0.3s ease;
  opacity: 0;
}
.faq-item--active .faq-icon-minus {
  opacity: 1;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-answer-content {
  padding: 0 clamp(1.25rem, 0.55vw + 1.12rem, 2rem) clamp(1.25rem, 0.55vw + 1.12rem, 2rem);
  color: #4b5563;
  font-size: clamp(1rem, 0.05vw + 0.99rem, 1.06rem);
  line-height: 1.7;
}
.faq-answer-content p {
  margin-bottom: 1rem;
}
.faq-answer-content p:last-child {
  margin-bottom: 0;
}
.faq-answer-content ul,
.faq-answer-content ol {
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}
.faq-answer-content ul li,
.faq-answer-content ol li {
  margin-bottom: 0.5rem;
}
.faq-answer-content ul li:last-child,
.faq-answer-content ol li:last-child {
  margin-bottom: 0;
}
.faq-answer-content a {
  color: var(--color-blue);
  text-decoration: underline;
  transition: color 0.3s ease;
}
.faq-answer-content a:hover {
  color: #000d5c;
}
.faq-answer-content strong {
  font-weight: 600;
  color: #1a1a1a;
}

/* Responsive adjustments */
@media (max-width: 640px) {
  .faq-question {
    align-items: center;
  }
}
/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
.footer {
  background-color: var(--color-blue);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .footer__grid {
    grid-template-columns: repeat(2, minmax(1rem, 0.5fr)) 1fr;
  }
}
@media (min-width: 1024px) {
  .footer__grid > :first-child {
    padding-left: 4.6667vw;
  }
}
@media (min-width: 1536px) {
  .footer__grid > :first-child {
    padding-left: 4.6667vw;
  }
}
@media (min-width: 1024px) {
  .footer__grid > :not(:first-child) {
    padding-left: clamp(1.25rem, 1.28vw + 0.95rem, 3rem);
  }
}
.footer__grid > :not(:last-child) {
  border-right: 2px solid rgba(255, 255, 255, 0.25);
  border-bottom: 2px solid rgba(255, 255, 255, 0.25);
}
.footer__grid > :nth-child(2) {
  border-bottom-right-radius: clamp(4rem, 2.92vw + 3.32rem, 8rem);
}
.footer__item {
  text-align: center;
  padding: clamp(1.75rem, 3.01vw + 1.05rem, 5.88rem) 0;
}
@media (min-width: 1024px) {
  .footer__item {
    text-align: left;
  }
}
.footer__list * + * {
  margin-top: clamp(0.63rem, 0.27vw + 0.56rem, 1rem);
}
.footer__link {
  color: rgba(255, 255, 255, 0.75);
  font-family: var(--font-mono);
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  font-weight: 501;
  letter-spacing: 0.02rem;
  line-height: 1.5;
  text-decoration: none;
  position: relative;
  transition: 0.3s var(--ease-out);
}
.footer__link:hover {
  color: #D4D4D8;
}
.footer__link--lg, .footer__link--title {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(0.93rem, 0.42vw + 0.83rem, 1.5rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.75;
  text-transform: uppercase;
}
.footer__link--title:hover {
  color: var(--color-white);
}
.footer__link--address {
  line-height: 1.8;
  margin-top: 0.5rem;
}
.footer__utils {
  display: flex;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  max-width: 80%;
  margin: 0 auto;
  gap: clamp(2.5rem, 1.46vw + 2.16rem, 4.5rem);
}
@media (min-width: 1024px) {
  .footer__utils {
    padding-right: 4.6667vw;
    max-width: 42rem;
    flex-direction: column;
    justify-content: flex-start;
    text-align: left;
    align-items: flex-start;
    gap: 0;
  }
}
@media (min-width: 1536px) {
  .footer__utils {
    padding-right: 4.6667vw;
  }
}
.footer__logo {
  display: block;
  width: clamp(12rem, 0.37vw + 11.92rem, 12.5rem);
  height: auto;
  margin: 0 auto;
}
.footer__logo-img {
  height: 100%;
  width: 100%;
}
@media (min-width: 1024px) {
  .footer__logo {
    margin: 0;
    margin-bottom: 2rem;
  }
}
.footer__socials {
  color: var(--color-white);
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.09vw + 0.73rem, 0.88rem);
  font-weight: 400;
}
.footer__socials > :first-child {
  color: rgba(255, 255, 255, 0.75);
}
.footer__socials a {
  transition: 0.3s var(--ease-out);
}
.footer__socials a:hover {
  color: #D4D4D8;
}
.footer__cta {
  display: flex;
  flex-direction: column;
  text-align: center;
}
@media (min-width: 1024px) {
  .footer__cta {
    text-align: left;
  }
}
.footer__cta-title {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(1.25rem, 0.55vw + 1.12rem, 2rem);
  font-weight: 400;
  text-transform: uppercase;
  margin: 0;
  line-height: 1.2;
}
.footer__cta-subtitle {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(1.75rem, 0.18vw + 1.71rem, 2rem);
  font-weight: 800;
  text-transform: uppercase;
  margin: 0;
  line-height: 1.1;
}
.footer__cta-btn {
  align-self: center;
  margin-top: 0.5rem;
}
@media (min-width: 1024px) {
  .footer__cta-btn {
    align-self: flex-start;
  }
}
.footer__phone {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(2.25rem, 0.18vw + 2.21rem, 2.5rem);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.3s ease;
  display: block;
}
.footer__phone:hover {
  color: #D4D4D8;
}
.footer__bottom {
  color: var(--color-white);
  font-family: var(--font-mono);
  padding: clamp(1.13rem, 0.15vw + 1.09rem, 1.33rem) 0;
  padding-left: 4.6667vw;
  padding-right: 4.6667vw;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (min-width: 1024px) {
  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 0;
  }
}
@media (min-width: 1536px) {
  .footer__bottom {
    padding-left: 4.6667vw;
    padding-right: 4.6667vw;
  }
}
.footer__copyright {
  color: #8F8F8F;
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  font-weight: 400;
  text-align: center;
}
@media (min-width: 1024px) {
  .footer__copyright {
    text-align: left;
  }
}
.footer__legal {
  color: #8F8F8F;
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  font-weight: 400;
  text-align: center;
  display: flex;
  gap: 0.5rem;
  justify-content: center;
}
@media (min-width: 1024px) {
  .footer__legal {
    text-align: right;
  }
}
.footer__legal a {
  color: #8F8F8F;
  text-decoration: none;
  transition: 0.3s var(--ease-out);
}
.footer__legal a:hover {
  color: #D4D4D8;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
.gfield {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  width: 100%;
}

.gform_fields {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  padding: 0;
  width: 100%;
}

.gfield_required {
  display: none;
}

.ginput_full {
  flex-basis: 100%;
  max-width: 100%;
}

.gf_left_half,
.gf_right_half,
.ginput_left,
.ginput_right {
  flex-basis: 100%;
  max-width: 100%;
}
@media (min-width: 768px) {
  .gf_left_half,
  .gf_right_half,
  .ginput_left,
  .ginput_right {
    flex-basis: 49%;
  }
}

.gf_left_half,
.ginput_left {
  margin-right: 0;
}
@media (min-width: 768px) {
  .gf_left_half,
  .ginput_left {
    margin-right: 2%;
  }
}

/**
* Input
*/
.ginput_container input:not([type=checkbox]),
.ginput_container textarea {
  background-color: transparent;
  border: none;
  border-bottom: 1.5px solid #2a2a2d;
  color: #2a2a2d;
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.0063rem;
  height: clamp(2.75rem, 0.37vw + 2.67rem, 3.25rem);
  width: 100%;
  margin-bottom: clamp(1.5rem, 0.18vw + 1.46rem, 1.75rem);
  max-width: 42rem;
  transition: border-color 200ms ease;
}
.ginput_container input:not([type=checkbox]):active, .ginput_container input:not([type=checkbox]):focus,
.ginput_container textarea:active,
.ginput_container textarea:focus {
  outline: 0;
}

/**
* Textarea
*/
.ginput_container textarea {
  height: 14rem;
  padding-top: 1.125rem;
  padding-bottom: 1.125rem;
  resize: none;
}

/**
* Btn
*/
.gform_footer input[type=submit] {
  background-color: transparent;
  border-radius: 9em;
  border: 1.5px solid var(--color-black);
  color: var(--color-black);
  cursor: pointer;
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(0.68rem, 0.15vw + 0.64rem, 0.88rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.06em;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  padding: clamp(0.63rem, 0.09vw + 0.6rem, 0.75rem) clamp(0.93rem, 0.79vw + 0.74rem, 2rem);
  transition: 0.2s var(--ease-out);
}
@media (min-width: 768px) {
  .gform_footer input[type=submit] {
    border: 2px solid var(--color-black);
  }
}
.gform_footer input[type=submit]:hover {
  border-color: var(--color-black);
  color: var(--color-black);
}
.gform_footer input[type=submit]:hover:hover {
  background-color: var(--color-black);
  color: var(--color-white);
}

/**
* Radio Button
*/
.gfield_radio {
  margin: 1rem 0 1.5rem 0;
}

.gchoice {
  display: flex;
  align-items: center;
  line-height: 1.8;
}

.ginput_container input[type=radio] {
  cursor: pointer;
  appearance: none;
  color: var(--color-dark-grey);
  border: 1.5px solid var(--color-dark-grey);
  border-radius: 100%;
  display: inline-block;
  vertical-align: middle;
  user-select: none;
  flex-shrink: 0;
  height: clamp(0.75rem, 0.13vw + 0.72rem, 0.93rem);
  width: clamp(0.75rem, 0.13vw + 0.72rem, 0.93rem);
  padding: 0;
  margin-right: 0.5rem;
  margin-bottom: 0;
}
.ginput_container input[type=radio]:checked {
  border-color: transparent;
  background-color: currentColor;
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.ginput_container input[type=radio] + label {
  font-size: clamp(0.87rem, 0.09vw + 0.85rem, 1rem);
}

/**
* Consent
*/
.ginput_container_consent {
  color: #68717a;
  font-size: 0.75rem;
  line-height: 1;
  display: flex;
  align-items: center;
  width: auto;
  margin-bottom: 1.75rem;
}
@media (min-width: 768px) {
  .ginput_container_consent {
    font-size: 0.875rem;
  }
}

/**
* Label
*/
.hidden_label .gfield_label {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  width: 1px;
  height: 1px;
  overflow: hidden;
  padding: 0;
  border: 0;
  white-space: nowrap;
}

/**
* Placeholder
*/
.gform_fields .gfield input::-webkit-input-placeholder,
.gform_fields .gfield textarea::-webkit-input-placeholder {
  color: var(--color-black);
}

.gform_fields .gfield input::-moz-placeholder,
.gform_fields .gfield textarea::-moz-placeholder {
  color: var(--color-black);
}

.gform_fields .gfield input:-ms-input-placeholder,
.gform_fields .gfield textarea:-ms-input-placeholder {
  color: var(--color-black);
}

/**
* Validation
*/
.validation_error {
  display: none;
}

.validation_message {
  color: #f33;
  font-size: 0.75rem;
  line-height: 1;
  margin-bottom: 1rem;
  margin-top: -1rem;
}
@media (min-width: 1024px) {
  .validation_message {
    font-size: 0.8rem;
    line-height: 1;
    margin-bottom: 2rem;
  }
}

.validation_message--hidden-on-empty {
  display: none;
}

.gform_submission_error {
  display: none;
}

/**
* AJAX spinner
*/
.gform_ajax_spinner {
  display: none;
}

/**
* Newsletter Signup
* Note: These styles are currently not in use as there is no newsletter form in the theme.
* Commenting out to prevent conflicts with equipment enquiry forms (which use form ID 2).
*/
/*
#gform_fields_2 {
	flex-direction: row;
	position: relative;

	// email input
	&>:first-child {
		position: relative;
		order: 0;
	}

	// consent checkbox
	&>:nth-child(2) {
		order: 2;
	}

	// submit btn
	&>:last-child {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		right: 0;
		left: auto;
		width: auto;
		order: 1;

		input {
			width: 1.5em;
		}
	}

	.ginput_container input:not([type="checkbox"]),
	.ginput_container textarea {
		color: var(--color-white);
		border-bottom: 1.5px solid var(--color-white);
		color: rgba(255, 255, 255, 0.5);
		margin-bottom: 0;

		&:active,
		&:focus {
			box-shadow: none;
			outline: 0;
		}
	}

	.validation_message {
		margin-top: 0.45rem;
	}

	::-webkit-input-placeholder,
	::-webkit-input-placeholder {
		color: rgba(255, 255, 255, 0.5);
	}

	::-moz-placeholder,
	::-moz-placeholder {
		color: rgba(255, 255, 255, 0.5);
	}

	:-ms-input-placeholder,
	:-ms-input-placeholder {
		color: rgba(255, 255, 255, 0.5);
	}
}
*/
/**
* reCaptcha
*/
.grecaptcha-badge {
  display: none !important;
}

/*--------------------------------------------------------------
# Half
--------------------------------------------------------------*/
.half {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: clamp(1rem, 3.65vw + 0.16rem, 6rem);
}
@media (min-width: 1024px) {
  .half {
    grid-template-columns: repeat(2, minmax(1rem, 1fr));
    grid-gap: 12vw;
  }
}

/*--------------------------------------------------------------
# Hero
--------------------------------------------------------------*/
.hero {
  display: grid;
  grid-template-areas: "hero";
  place-items: end start;
  width: 100%;
  height: clamp(50vh, 30vw + 20rem, 100vh);
  min-height: 500px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .hero {
    place-items: center start;
    height: 80vh;
    min-height: 600px;
  }
}
@media (min-width: 1200px) {
  .hero {
    height: 100vh;
    min-height: 700px;
  }
}
.hero > * {
  grid-area: hero;
  height: 100%;
}
.hero__wrap {
  background: var(--color-blue);
  mix-blend-mode: multiply;
  border-top-right-radius: clamp(6rem, 7.31vw + 4.31rem, 16rem);
  height: 100%;
  width: 100%;
  position: relative;
  z-index: 5;
}
@media (min-width: 480px) {
  .hero__wrap {
    height: 60%;
  }
}
@media (min-width: 768px) {
  .hero__wrap {
    height: 100%;
    max-width: clamp(32rem, 17.53vw + 27.95rem, 56rem);
  }
}
.hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: auto;
  padding: 1.5rem 1.5rem 7rem 1.3125rem;
  position: relative;
  overflow: hidden;
  z-index: 5;
}
@media (min-width: 480px) {
  .hero__content {
    padding: 2rem 2rem 7.5rem 1.5rem;
  }
}
@media (min-width: 768px) {
  .hero__content {
    height: 100%;
    max-width: clamp(32rem, 13.52vw + 28.87rem, 50.5rem);
    padding: 2rem clamp(2rem, 1.46vw + 1.66rem, 4rem) 2rem 4.3333vw;
    justify-content: center;
  }
}
.hero__content h1 {
  color: var(--color-white);
  font-size: clamp(2rem, 0.37vw + 1.92rem, 2.5rem);
  line-height: 1.1;
  margin-bottom: 1rem;
}
@media (min-width: 768px) {
  .hero__content h1 {
    font-size: clamp(2.5rem, 0.73vw + 2.33rem, 3.5rem);
    margin-bottom: 1.5rem;
  }
}
.hero__subtitle {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(1.13rem, 0.37vw + 1.04rem, 1.63rem);
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 800;
  padding-bottom: 1rem;
}
@media (min-width: 768px) {
  .hero__subtitle {
    border-bottom: none;
  }
}
.hero__subheading {
  color: var(--color-white);
  font-size: clamp(0.88rem, 0.1vw + 0.85rem, 1.01rem);
  line-height: 1.65;
}
.hero__hr {
  grid-column: 1/-1;
  background-color: var(--color-black);
  height: 2px;
  margin-bottom: 1.325rem;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
}
.hero__img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}
.hero .btn {
  align-self: flex-start;
  margin-top: 1rem;
  margin-right: 0.5rem;
  font-size: clamp(1rem, 0.07vw + 0.98rem, 1.1rem);
  padding: clamp(0.75rem, 0.18vw + 0.71rem, 1rem) clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
}
@media (max-width: 767px) {
  .hero .btn {
    padding: 0.7rem 1.4rem;
  }
}
@media (min-width: 768px) {
  .hero .btn {
    margin-top: 1.5rem;
  }
}

/*--------------------------------------------------------------
# Hero
--------------------------------------------------------------*/
.hero-sub {
  display: grid;
  grid-template-areas: "hero";
  place-items: end start;
  width: 100%;
  height: clamp(32vh, 30vw + 20rem, 32vh);
  min-height: 200px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .hero-sub {
    place-items: center start;
    height: 64vh;
    min-height: 300px;
  }
}
@media (min-width: 1200px) {
  .hero-sub {
    height: 64vh;
    min-height: 400px;
  }
}
.hero-sub > * {
  grid-area: hero;
  height: 100%;
}
.hero-sub__wrap {
  background: var(--color-blue);
  mix-blend-mode: multiply;
  border-top-right-radius: clamp(6rem, 7.31vw + 4.31rem, 16rem);
  height: 75%;
  width: 100%;
  position: relative;
  z-index: 5;
}
@media (min-width: 480px) {
  .hero-sub__wrap {
    height: 60%;
  }
}
@media (min-width: 768px) {
  .hero-sub__wrap {
    height: 100%;
    max-width: clamp(32rem, 17.53vw + 27.95rem, 56rem);
  }
}
.hero-sub__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: auto;
  padding: 1.5rem 1.5rem 4rem 1.3125rem;
  position: relative;
  overflow: hidden;
  z-index: 5;
  margin-top: 6rem;
}
@media (min-width: 480px) {
  .hero-sub__content {
    padding: 2rem 2rem 7.5rem 1.5rem;
  }
}
@media (min-width: 768px) {
  .hero-sub__content {
    height: 100%;
    max-width: clamp(32rem, 13.52vw + 28.87rem, 50.5rem);
    padding: 2rem clamp(2rem, 1.46vw + 1.66rem, 4rem) 2rem 4.3333vw;
    justify-content: center;
  }
}
.hero-sub__content h1 {
  color: var(--color-white);
  font-size: clamp(2rem, 0.37vw + 1.92rem, 2.5rem);
  line-height: 1.1;
  margin-bottom: 1rem;
}
@media (min-width: 768px) {
  .hero-sub__content h1 {
    font-size: clamp(2.5rem, 0.73vw + 2.33rem, 3.5rem);
    margin-bottom: 1.5rem;
  }
}
.hero-sub__subtitle {
  color: var(--color-white);
  font-family: var(--font-secondary);
  font-size: clamp(1.13rem, 0.37vw + 1.04rem, 1.63rem);
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 800;
  padding-bottom: 1rem;
}
@media (min-width: 768px) {
  .hero-sub__subtitle {
    border-bottom: none;
  }
}
.hero-sub__subheading {
  color: var(--color-white);
  font-size: clamp(0.88rem, 0.1vw + 0.85rem, 1.01rem);
  line-height: 1.65;
}
.hero-sub__hr {
  grid-column: 1/-1;
  background-color: var(--color-black);
  height: 2px;
  margin-bottom: 1.325rem;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
}
.hero-sub__img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}
.hero-sub .btn {
  align-self: flex-start;
  margin-top: 1rem;
  font-size: clamp(0.88rem, 0.09vw + 0.85rem, 1rem);
  padding: clamp(0.75rem, 0.18vw + 0.71rem, 1rem) clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
}
@media (min-width: 768px) {
  .hero-sub .btn {
    margin-top: 1.5rem;
  }
}

/*--------------------------------------------------------------
# Icons
--------------------------------------------------------------*/
.icon {
  font-size: 1em;
  height: 1em;
  width: 1em;
  display: inline-block;
  color: inherit;
  line-height: 1;
  flex-shrink: 0;
  max-width: initial;
}
.icon--xs {
  font-size: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem);
}
.icon--sm {
  font-size: clamp(0.88rem, 0.04vw + 0.87rem, 0.93rem);
}
.icon--md {
  font-size: clamp(0.88rem, 0.46vw + 0.77rem, 1.5rem);
}
.icon--lg {
  font-size: clamp(2rem, 0.91vw + 1.79rem, 3.25rem);
}
.icon--xl {
  font-size: clamp(2.75rem, 1.46vw + 2.41rem, 4.75rem);
}

/*--------------------------------------------------------------
# Intro
--------------------------------------------------------------*/
.intro {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 2rem;
}
@media (min-width: 768px) {
  .intro {
    grid-template-columns: repeat(12, 1fr);
    grid-gap: 1rem;
  }
  .intro > :first-child {
    grid-column: 1/span 4;
  }
  .intro > :last-child {
    grid-column: 7/span 5;
  }
  .intro--alt > :last-child {
    grid-column: 5/span 5;
  }
  .intro--center {
    align-items: center;
  }
}
.intro__subtitle {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  text-transform: uppercase;
  line-height: 1.6;
}
.intro__hr {
  background-color: var(--color-black);
  height: 2px;
  margin: 1.875rem 0;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
}

/*--------------------------------------------------------------
# Lightbox
--------------------------------------------------------------*/
.glightbox-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  touch-action: none;
  text-size-adjust: 100%;
  backface-visibility: hidden;
  outline: none;
  z-index: 99;
}

.glightbox-container.inactive {
  display: none;
}

.glightbox-container .gcontainer {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 99;
}

.glightbox-container .gslider {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
  position: relative;
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  transition: transform 0.4s ease;
}

.glightbox-container .gslide {
  position: absolute;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  width: 100%;
}

.glightbox-container .gslide.current {
  position: relative;
  opacity: 1;
  z-index: 99;
}

.glightbox-container .gslide.prev {
  display: none;
}

.glightbox-container .gslide-inner-content {
  width: 100%;
}

.glightbox-container .ginner-container {
  display: flex;
  justify-content: center;
  flex-direction: column;
  margin: auto;
  width: 100%;
  max-width: 100%;
  height: 100vh;
  position: relative;
  padding: 1rem;
}
@media (min-width: 768px) {
  .glightbox-container .ginner-container {
    max-width: 95vw;
    max-height: 95vh;
    padding: 1.5rem;
  }
}
@media (min-width: 1024px) {
  .glightbox-container .ginner-container {
    max-width: 92vw;
    max-height: 92vh;
    padding: 2rem;
  }
}

.glightbox-container .ginner-container.gvideo-container {
  width: 100%;
}

.gslide iframe,
.gslide video {
  outline: none;
  border: none;
  min-height: 165px;
  touch-action: auto;
}

.gslide:not(.current) {
  pointer-events: none;
}

.gslide-video {
  position: relative;
  max-width: 100vh;
  width: 100%;
}

.gslide-video .plyr__poster-enabled.plyr--loading .plyr__poster {
  display: none;
}

.gslide-video .gvideo-wrapper {
  width: 100%;
  margin: auto;
}

.gslide-video.playing::before {
  display: none;
}

.gslide-video.fullscreen {
  max-width: 100%;
  min-width: 100%;
  height: 75vh;
}

.gslide-video.fullscreen video {
  max-width: 100%;
  width: 100%;
}

.greset {
  transition: all 0.3s ease;
}

.gabsolute {
  position: absolute;
}

.grelative {
  position: relative;
}

.glightbox-desc {
  display: none;
}

.glightbox-open {
  overflow: hidden;
}

.gloader {
  border: 4px solid var(--color-blue);
  border-right-color: transparent;
  border-radius: 50%;
  position: absolute;
  display: block;
  left: 0;
  right: 0;
  top: 47%;
  height: 3rem;
  width: 3rem;
  margin: 0 auto;
  z-index: 99;
  animation: lightboxLoader 0.8s infinite linear;
}

.goverlay {
  background: rgba(0, 0, 0, 0.8);
  width: 100%;
  height: calc(100vh + 1px);
  position: fixed;
  top: -1px;
  left: 0;
  will-change: opacity;
}

.gclose {
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  z-index: 99;
}

.gclose svg {
  display: block;
  width: clamp(0.75rem, 0.09vw + 0.73rem, 0.88rem);
  height: auto;
  margin: 0;
  padding: 0;
}

.gclose.disabled {
  opacity: 0.1;
}

.gclose .garrow {
  stroke: var(--color-white);
}

.gbtn.focused {
  outline: none;
}

iframe.wait-autoplay {
  opacity: 0;
}

.glightbox-closing .gclose {
  opacity: 0;
}

.glightbox-clean .gslide-video {
  background: var(--color-black);
}

.glightbox-clean .gclose {
  background-color: var(--color-blue);
  border-radius: 50%;
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 3rem;
  height: 3rem;
  z-index: 9999;
  opacity: 1;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}
@media (max-width: 768px) {
  .glightbox-clean .gclose {
    top: 0.5rem;
    right: 0.5rem;
    width: 2.5rem;
    height: 2.5rem;
  }
}

.glightbox-clean .gclose path {
  fill: var(--color-white);
}

.glightbox-clean .gclose:hover {
  opacity: 1;
  background-color: var(--color-white);
  transform: scale(1.1);
}
.glightbox-clean .gclose:hover path {
  fill: var(--color-blue);
}

.gfadeIn {
  animation: gfadeIn 0.5s ease;
}

.gfadeOut {
  animation: gfadeOut 0.5s ease;
}

.gzoomIn {
  animation: gzoomIn 0.5s ease;
}

.gzoomOut {
  animation: gzoomOut 0.5s ease;
}

@keyframes lightboxLoader {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes gfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes gfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes gzoomIn {
  from {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 1;
  }
}
@keyframes gzoomOut {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 0;
  }
}
.gslide-image {
  position: relative;
  display: inline-block;
}

.gslide-image img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  margin: auto;
}

.gslide-media {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  max-height: 100%;
}

@media (min-width: 769px) {
  .glightbox-container .ginner-container {
    width: auto;
    height: auto;
    flex-direction: row;
  }
  .gslide-image img {
    max-width: 92vw;
    max-height: 92vh;
    border-radius: 0.5rem;
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.5);
  }
}
/*--------------------------------------------------------------
# Map
--------------------------------------------------------------*/
.map {
  border-radius: 0.75rem;
  width: 100%;
  height: 0;
  padding-bottom: 44%;
  min-height: 16rem;
  margin-bottom: 2.5rem;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
.header {
  background-color: var(--color-white);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  width: 100%;
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem) 0;
  position: relative;
  z-index: 20;
}

/**
* Wrap
*/
.header__wrap {
  display: flex;
  align-items: center;
}

/**
* Logo
*/
.header__logo {
  display: flex;
  align-items: center;
  width: clamp(16rem, 11.69vw + 13.3rem, 32rem);
  height: auto;
}
.header__logo-img {
  height: 100%;
  width: 100%;
}
@media (max-width: 768px) {
  .header__logo-img {
    width: 70%;
  }
}

/**
* Nav
*/
.header__nav {
  background-color: var(--color-white);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  border-radius: 0 0 0.5rem 0.5rem;
  position: absolute;
  left: 0;
  top: 100%;
  max-height: 100vh;
  transform: translateY(-0.5rem);
  visibility: hidden;
  opacity: 0;
  overflow: auto;
  overscroll-behavior: contain;
  display: block;
  width: 100%;
}
@media (min-width: 1024px) {
  .header__nav {
    background-color: transparent;
    box-shadow: none;
    max-height: none;
    opacity: 1;
    overflow: visible;
    overscroll-behavior: auto;
    padding: 0;
    position: static;
    transform: translateY(0);
    transition: none;
    visibility: visible;
    width: 100%;
  }
  .header__nav::before {
    display: none;
  }
}

.header__nav-inner {
  border-top: 1px solid rgb(233, 236, 241);
  display: flex;
  flex-direction: column;
  padding: 0 1.25rem 1.25rem 1.25rem;
  width: 100%;
}
@media (min-width: 768px) {
  .header__nav-inner {
    max-width: 1024px;
    margin: 0 auto;
  }
}
@media (min-width: 1024px) {
  .header__nav-inner {
    border-top: none;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    max-width: 100%;
    padding: 0;
  }
}

/**
* List
*/
@media (min-width: 1024px) {
  .header__list {
    padding: 0.875rem;
    display: flex;
    align-items: center;
    padding: 0;
    margin-left: auto;
  }
}

/**
* List Item
*/
.header__item {
  border-bottom: 1px solid rgb(233, 236, 241);
  width: 100%;
}
@media (min-width: 1024px) {
  .header__item {
    padding: 0;
    border-bottom: 0;
    margin-bottom: 0;
    margin-left: 2rem;
    position: relative;
  }
  .header__item:first-of-type {
    margin-left: 0;
  }
  .header__item--current:not(.header__dropdown-item, .header__item--btn) a, .header__item--parent--current a {
    color: var(--color-primary);
  }
}
.header__item--dropdown {
  position: relative;
}
.header__item--dropdown .header__link::after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='currentColor' stroke-width='3'%3E%3Cpath d='M10 4v12M4 10h12'/%3E%3C/svg%3E");
  background-position: center center;
  background-repeat: no-repeat;
  width: 1rem;
  height: 1rem;
  position: absolute;
  right: 0;
  opacity: 0.7;
  transform: translateX(-0.15rem) rotate(0deg);
  transition: transform 0.3s ease;
}
@media (min-width: 1024px) {
  .header__item--dropdown .header__link {
    position: relative;
    padding-left: 0.5rem;
    padding-right: 1.5rem;
  }
}
.header__item--dropdown .header__link[aria-expanded=true]::after {
  transform: translateX(-0.15rem) rotate(45deg);
}

/**
* Link
*/
.header__link {
  font-family: var(--font-secondary);
  font-size: clamp(0.93rem, 0.24vw + 0.87rem, 1.25rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.75;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  padding: 0.75rem 0;
  position: relative;
  width: 100%;
  white-space: nowrap;
  transition: 0.25s ease;
}
@media (min-width: 1024px) {
  .header__link {
    padding: 0.75rem 1rem;
  }
}
.header__link--dropdown {
  pointer-events: auto;
}
.header__link:hover {
  color: var(--color-blue);
}

.header__dropdown-link {
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  font-weight: 700;
  line-height: 1.75;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  padding: 0.25rem 0;
  position: relative;
  width: 100%;
  white-space: nowrap;
  transition: 0.3s var(--ease-out);
}
.header__dropdown-link:hover {
  color: var(--color-blue);
}

/**
* Dropdown
*/
.header__dropdown {
  background-color: #f9fafb;
  width: 100%;
  padding: 0.875rem 1.875rem 0.875rem 1.5rem;
  overflow: hidden;
  z-index: 20;
}
@media (min-width: 1024px) {
  .header__dropdown {
    background-color: var(--color-white);
    border-radius: 0 0 0.25rem 0.25rem;
    box-shadow: var(--shadow-sm);
    font-size: 1rem;
    position: absolute;
    top: 100%;
    width: max-content;
    left: -1rem;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0.2s 0.2s, opacity 0.2s 0s;
  }
  .header__item:hover .header__dropdown {
    visibility: visible;
    opacity: 1;
    transition: visibility 0.2s 0s, opacity 0.2s 0s;
  }
}
.header__dropdown-item {
  font-family: var(--font-mono);
  position: relative;
  transition: 0.3s var(--ease-out);
}
.header__dropdown-item:hover .header__dropdown-link {
  color: var(--color-blue);
}
.header__dropdown--is-hidden {
  display: none;
}
@media (min-width: 1024px) {
  .header__dropdown--is-hidden {
    display: block;
  }
}
.header__dropdown-icon {
  display: block;
  margin-left: 0.125rem;
  width: 0.75rem;
  height: 0.75rem;
  flex-shrink: 0;
}

/**
* Trigger
*/
.header__trigger {
  cursor: pointer;
  position: relative;
  width: 2.5rem;
  margin-left: auto;
  z-index: 10;
}
.header__trigger:focus, .header__trigger:active {
  outline: 0;
}
.header__trigger > * {
  background-color: var(--color-black);
  display: block;
  height: 2px;
  width: 100%;
}
.header__trigger > :nth-child(2) {
  margin: 6px 0;
}
@media (min-width: 1024px) {
  .header__trigger {
    display: none;
  }
}

/*--------------------------------------------------------------
# Header Aside
--------------------------------------------------------------*/
.header-aside {
  border-radius: 50%;
  border: 2px solid #001489;
  background-color: var(--color-white);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  position: fixed;
  top: 1rem;
  right: 1rem;
  width: clamp(3rem, 2.28vw + 2.47rem, 6.13rem);
  height: clamp(3rem, 2.28vw + 2.47rem, 6.13rem);
  display: flex;
  opacity: 0;
  visibility: hidden;
  transform: translateX(100%);
  transition: 0.2s ease-in-out;
  z-index: 20;
}
.header-aside .icon {
  height: clamp(2rem, 2.1vw + 1.51rem, 4.88rem);
  width: clamp(2rem, 2.1vw + 1.51rem, 4.88rem);
  display: block;
  margin: auto;
}
.header-aside--is-visible {
  visibility: visible;
  opacity: 1;
  transform: translateX(0);
}

/*--------------------------------------------------------------
# News Page
--------------------------------------------------------------*/
/* News Intro Section */
.news-intro {
  margin-bottom: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  text-align: center;
}
@media (min-width: 768px) {
  .news-intro {
    text-align: left;
  }
}
.news-intro .about-intro-title {
  margin-bottom: 1.5rem;
}

/* News Grid */
.news-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  margin-bottom: clamp(3rem, 0.73vw + 2.83rem, 4rem);
}
@media (min-width: 640px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .news-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* News Card */
.news-card {
  background: var(--color-white);
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  height: 100%;
  display: flex;
  flex-direction: column;
}
.news-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}
.news-card:hover .news-card__img {
  transform: scale(1.05);
}
.news-card:hover .news-card__read-more {
  color: var(--color-blue);
}
.news-card:hover .news-card__read-more svg {
  transform: translateX(4px);
}
.news-card__link {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.news-card__image {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #f0f0f0;
}
.news-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f0f0f0 0%, #e0e0e0 100%);
}
.news-card__placeholder svg {
  width: 80px;
  height: 80px;
  color: #999;
}
.news-card__date {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: var(--color-blue);
  color: var(--color-white);
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  text-align: center;
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
  z-index: 2;
}
.news-card__date-day {
  display: block;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}
.news-card__date-month {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  margin-top: 0.25rem;
  opacity: 0.9;
}
.news-card__content {
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  display: flex;
  flex-direction: column;
  flex: 1;
}
.news-card__category {
  display: inline-block;
  background: rgba(0, 20, 137, 0.1);
  color: var(--color-blue);
  padding: 0.375rem 0.875rem;
  border-radius: 2rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
  align-self: flex-start;
}
.news-card__title {
  font-size: clamp(1.25rem, 0.18vw + 1.21rem, 1.5rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 1rem;
  line-height: 1.3;
  transition: color 0.3s ease;
}
.news-card:hover .news-card__title {
  color: var(--color-blue);
}
.news-card__excerpt {
  font-size: 0.95rem;
  color: #666;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  flex: 1;
}
.news-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 1rem;
  border-top: 1px solid #e5e7eb;
}
.news-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #1a1a1a;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.3s ease;
}
.news-card__read-more svg {
  width: 16px;
  height: 10px;
  transition: transform 0.3s ease;
}

/* No News Message */
.no-news {
  text-align: center;
  padding: clamp(3rem, 1.46vw + 2.66rem, 5rem);
  background: #f8f9fa;
  border-radius: 0.75rem;
}
.no-news p {
  font-size: 1.125rem;
  color: #666;
  margin: 0;
}

/* News Pagination */
.news-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  margin-top: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
.news-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  padding: 0.5rem 1rem;
  background: var(--color-white);
  color: #374151;
  border: 2px solid #e5e7eb;
  border-radius: 0.5rem;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.875rem;
  transition: all 0.3s ease;
}
.news-pagination .page-numbers:hover {
  background: var(--color-blue);
  color: var(--color-white);
  border-color: var(--color-blue);
  transform: translateY(-2px);
}
.news-pagination .page-numbers.current {
  background: var(--color-blue);
  color: var(--color-white);
  border-color: var(--color-blue);
}
.news-pagination .page-numbers.dots {
  border: none;
  background: transparent;
  cursor: default;
}
.news-pagination .page-numbers.dots:hover {
  background: transparent;
  transform: none;
}
.news-pagination .page-numbers.prev, .news-pagination .page-numbers.next {
  padding: 0.5rem 1.5rem;
}

.facebook-feed-section {
  text-align: center;
}
.facebook-feed-section .facebook-feed__title {
  font-size: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  color: var(--color-primary);
  margin-bottom: clamp(1rem, 0.37vw + 0.92rem, 1.5rem);
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.2;
}
.facebook-feed-section .facebook-feed__subtitle {
  font-size: clamp(1rem, 0.09vw + 0.98rem, 1.13rem);
  color: #666;
  margin-bottom: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.6;
}

.smash-balloon-container {
  width: 100%;
  max-width: none;
}
.smash-balloon-container #cff {
  width: 100% !important;
  max-width: none !important;
}
.smash-balloon-container #cff .cff-item {
  background: var(--color-white);
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  margin-bottom: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.08);
  transition: all 0.3s ease;
}
.smash-balloon-container #cff .cff-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}
.smash-balloon-container #cff .cff-author .cff-author-text .cff-page-name {
  color: var(--color-primary) !important;
  font-weight: 700;
}
.smash-balloon-container #cff .cff-author .cff-author-text .cff-date {
  color: #6b7280 !important;
}
.smash-balloon-container #cff .cff-text {
  color: #374151 !important;
  line-height: 1.6;
}
.smash-balloon-container #cff .cff-viewpost-facebook {
  background: var(--color-primary) !important;
  color: white !important;
  border-radius: 8px;
  padding: 0.75rem 1.5rem;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
}
.smash-balloon-container #cff .cff-viewpost-facebook:hover {
  background: var(--color-blue) !important;
  transform: translateY(-2px);
}
.smash-balloon-container #cff .cff-meta {
  border-top: 1px solid #e5e7eb;
  padding-top: 1rem;
}
.smash-balloon-container #cff .cff-meta .cff-like,
.smash-balloon-container #cff .cff-meta .cff-comment {
  color: #6b7280;
  font-size: 0.875rem;
}

.social-feed {
  background: #f8f9fa;
  padding: clamp(3rem, 0.73vw + 2.83rem, 4rem) 0;
  margin: clamp(3rem, 1.46vw + 2.66rem, 5rem) 0;
}
.social-feed__header {
  text-align: center;
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
.social-feed__title {
  font-size: clamp(1.75rem, 0.55vw + 1.62rem, 2.5rem);
  color: var(--color-primary);
  margin-bottom: 1rem;
  font-weight: 700;
  text-transform: uppercase;
}
.social-feed__subtitle {
  font-size: clamp(1rem, 0.09vw + 0.98rem, 1.13rem);
  color: #666;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}
.social-feed__container {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  max-width: 1200px;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .social-feed__container {
    grid-template-columns: repeat(2, 1fr);
  }
}
.social-feed__item {
  background: var(--color-white);
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  border-radius: 0.5rem;
  box-shadow: var(--shadow-sm);
}

.newsletter-signup {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-blue) 100%);
  color: var(--color-white);
  padding: clamp(3rem, 0.73vw + 2.83rem, 4rem);
  border-radius: 0.75rem;
  text-align: center;
  margin: clamp(3rem, 0.73vw + 2.83rem, 4rem) 0;
}
.newsletter-signup__title {
  font-size: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  margin-bottom: 1rem;
  font-weight: 700;
}
.newsletter-signup__description {
  font-size: clamp(1rem, 0.09vw + 0.98rem, 1.13rem);
  margin-bottom: 2rem;
  opacity: 0.9;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}
.newsletter-signup__form {
  display: flex;
  gap: 1rem;
  max-width: 400px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .newsletter-signup__form {
    flex-direction: column;
  }
}
.newsletter-signup__input {
  flex: 1;
  padding: 0.75rem 1rem;
  border: none;
  border-radius: 0.375rem;
  font-size: 1rem;
}
.newsletter-signup__input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.3);
}
.newsletter-signup__button {
  padding: 0.75rem 1.5rem;
  background: var(--color-white);
  color: var(--color-primary);
  border: none;
  border-radius: 0.375rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all 0.3s ease;
}
.newsletter-signup__button:hover {
  background: #f8f9fa;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

@media (max-width: 768px) {
  .facebook-feed-container {
    padding: 0 1rem;
  }
  .news-intro,
  .facebook-feed-section {
    margin-left: 0;
    margin-right: 0;
  }
}
/*--------------------------------------------------------------
# Single News Page
--------------------------------------------------------------*/
.single-news-page {
  padding: clamp(2rem, 1.46vw + 1.66rem, 4rem) 0;
}

/* Single News Layout */
.single-news-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 1.46vw + 1.66rem, 4rem);
  margin-top: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
@media (min-width: 1024px) {
  .single-news-layout {
    grid-template-columns: 1fr 350px;
  }
}

/* Main Content Area */
.single-news-content {
  max-width: 100%;
}

/* News Header */
.single-news-header {
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}

.single-news-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid #e5e7eb;
}

.single-news-category {
  display: inline-block;
  background: var(--color-blue);
  color: var(--color-white);
  padding: 0.375rem 0.875rem;
  border-radius: 2rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.single-news-date {
  display: inline-flex;
  align-items: center;
  color: #6b7280;
  font-size: 0.875rem;
  font-weight: 500;
}
.single-news-date::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background: #6b7280;
  border-radius: 50%;
  margin-right: 0.75rem;
}

.single-news-author {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: #6b7280;
  font-size: 0.875rem;
  font-weight: 500;
}

.single-news-author-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
}

.single-news-title {
  font-size: clamp(2rem, 1.1vw + 1.75rem, 3.5rem);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.2;
  margin-bottom: 1rem;
}

.single-news-intro {
  font-size: clamp(1.13rem, 0.09vw + 1.1rem, 1.25rem);
  color: #4b5563;
  line-height: 1.7;
  font-weight: 400;
  margin-top: 1.5rem;
}
.single-news-intro p {
  margin: 0;
}

/* Featured Image */
.single-news-featured-image {
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.single-news-featured-img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.single-news-image-caption {
  padding: 1rem 1.5rem;
  background: #f8f9fa;
  color: #6b7280;
  font-size: 0.875rem;
  font-style: italic;
  margin: 0;
  border-top: 2px solid #e5e7eb;
}

/* Main Content Body */
.single-news-body {
  font-size: 1.0625rem;
  line-height: 1.8;
  color: #374151;
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
.single-news-body p {
  margin-bottom: 1.5rem;
}
.single-news-body p:last-child {
  margin-bottom: 0;
}
.single-news-body h2 {
  font-size: clamp(1.75rem, 0.37vw + 1.67rem, 2.25rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-top: 2.5rem;
  margin-bottom: 1.25rem;
  line-height: 1.3;
}
.single-news-body h3 {
  font-size: clamp(1.5rem, 0.27vw + 1.44rem, 1.88rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-top: 2rem;
  margin-bottom: 1rem;
  line-height: 1.3;
}
.single-news-body h4 {
  font-size: clamp(1.25rem, 0.18vw + 1.21rem, 1.5rem);
  font-weight: 600;
  color: #1a1a1a;
  margin-top: 1.75rem;
  margin-bottom: 0.875rem;
  line-height: 1.4;
}
.single-news-body ul,
.single-news-body ol {
  margin-bottom: 1.5rem;
  padding-left: 2rem;
}
.single-news-body ul li,
.single-news-body ol li {
  margin-bottom: 0.75rem;
}
.single-news-body blockquote {
  border-left: 4px solid var(--color-blue);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-size: 1.25rem;
  font-style: italic;
  color: #4b5563;
}
.single-news-body blockquote p {
  margin-bottom: 0.5rem;
}
.single-news-body img {
  max-width: 100%;
  height: auto;
  border-radius: 0.5rem;
  margin: 2rem 0;
}
.single-news-body a {
  color: var(--color-blue);
  text-decoration: underline;
  transition: color 0.3s ease;
}
.single-news-body a:hover {
  color: rgb(0, 12.5547445255, 86);
}

/* Tags */
.single-news-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding: 1.5rem 0;
  border-top: 2px solid #e5e7eb;
  border-bottom: 2px solid #e5e7eb;
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}
.single-news-tags strong {
  color: #1a1a1a;
  font-weight: 600;
}

.single-news-tag {
  display: inline-block;
  background: #f3f4f6;
  color: #4b5563;
  padding: 0.375rem 0.875rem;
  border-radius: 2rem;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}
.single-news-tag:hover {
  background: var(--color-blue);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* Social Share */
.single-news-share {
  padding: clamp(2rem, 0.37vw + 1.92rem, 2.5rem);
  background: linear-gradient(135deg, #f8f9fa 0%, #f3f4f6 100%);
  border-radius: 1rem;
  margin-bottom: clamp(2rem, 0.73vw + 1.83rem, 3rem);
}

.single-news-share-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 1.5rem;
}

.social-share-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.social-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  background: var(--color-white);
  color: #374151;
  border: 2px solid #e5e7eb;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}
.social-share-btn svg,
.social-share-btn .icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.social-share-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.social-share-btn--facebook:hover {
  background: #1877f2;
  color: white;
  border-color: #1877f2;
}
.social-share-btn--twitter:hover {
  background: #000;
  color: white;
  border-color: #000;
}
.social-share-btn--linkedin:hover {
  background: #0a66c2;
  color: white;
  border-color: #0a66c2;
}
.social-share-btn--whatsapp:hover {
  background: #25d366;
  color: white;
  border-color: #25d366;
}
.social-share-btn--copy:hover {
  background: var(--color-blue);
  color: white;
  border-color: var(--color-blue);
}

/* Sidebar */
.single-news-sidebar {
  position: relative;
}
@media (min-width: 1024px) {
  .single-news-sidebar {
    position: sticky;
    top: 2rem;
    align-self: start;
  }
}

.sidebar-widget {
  background: var(--color-white);
  border-radius: 0.75rem;
  padding: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.08);
  margin-bottom: 2rem;
}
.sidebar-widget--back {
  background: var(--color-blue);
  padding: 0;
  border-radius: 3rem;
  border: 2px solid var(--color-blue);
}
.sidebar-widget--back:hover {
  background: var(--color-white);
  color: var(--color-blue);
}

.back-to-news-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  width: 100%;
  padding: 1rem 1.5rem;
  color: var(--color-white);
  font-size: 0.9375rem;
  font-weight: 600;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.3s ease;
}
.back-to-news-btn svg {
  width: 16px;
  height: 10px;
  transition: transform 0.3s ease;
}
.back-to-news-btn:hover svg {
  transform: translateX(-4px);
  color: var(--color-blue);
}
.back-to-news-btn:hover {
  color: var(--color-blue);
}

.sidebar-widget-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid #e5e7eb;
}

/* Recent News List */
.sidebar-news-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sidebar-news-item {
  border-radius: 0.5rem;
  overflow: hidden;
  transition: all 0.3s ease;
}
.sidebar-news-item:hover {
  transform: translateX(4px);
}

.sidebar-news-link {
  display: flex;
  gap: 1rem;
  text-decoration: none;
  color: inherit;
}

.sidebar-news-thumb {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 0.5rem;
  overflow: hidden;
  background: #f0f0f0;
}

.sidebar-news-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.sidebar-news-item:hover .sidebar-news-img {
  transform: scale(1.05);
}

.sidebar-news-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.375rem;
}

.sidebar-news-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: #1a1a1a;
  line-height: 1.4;
  margin: 0;
  transition: color 0.3s ease;
}
.sidebar-news-item:hover .sidebar-news-title {
  color: var(--color-blue);
}

.sidebar-news-date {
  font-size: 0.75rem;
  color: #6b7280;
  font-weight: 500;
}

/* Categories List */
.sidebar-categories-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.sidebar-category-item {
  margin: 0;
}

.sidebar-category-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background: #f8f9fa;
  color: #374151;
  text-decoration: none;
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  transition: all 0.3s ease;
}
.sidebar-category-link:hover {
  background: var(--color-blue);
  color: var(--color-white);
  transform: translateX(4px);
}
.sidebar-category-link:hover .sidebar-category-count {
  background: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
}

.sidebar-category-count {
  display: inline-block;
  padding: 0.25rem 0.625rem;
  background: #e5e7eb;
  color: #6b7280;
  border-radius: 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  transition: all 0.3s ease;
}

/* Responsive Adjustments */
@media (max-width: 1023px) {
  .single-news-sidebar {
    margin-top: 3rem;
  }
  .social-share-buttons {
    justify-content: center;
  }
}
@media (max-width: 640px) {
  .single-news-meta {
    flex-direction: column;
    align-items: flex-start;
  }
  .single-news-date::before {
    display: none;
  }
  .social-share-btn {
    flex: 1;
    justify-content: center;
    min-width: calc(50% - 0.375rem);
  }
}
/*--------------------------------------------------------------
# Offset
--------------------------------------------------------------*/
.offset {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 2rem;
  margin: 0 4.6667vw;
}
@media (min-width: 768px) {
  .offset {
    grid-template-columns: repeat(12, 1fr);
    grid-gap: 1rem;
    margin: 0;
  }
}
.offset--center {
  align-items: center;
}
.offset__media {
  border-radius: 0 0.3125rem clamp(6.25rem, 4.57vw + 5.19rem, 12.5rem) 0;
  position: relative;
  overflow: hidden;
  aspect-ratio: 1/1;
}
@media (min-width: 768px) {
  .offset__media {
    grid-column: 1/6;
  }
}
.offset__media--lg {
  aspect-ratio: 4/5;
}
.offset__img {
  position: absolute;
  top: -20%;
  left: 0;
  height: 120%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}
@media (min-width: 768px) {
  .offset__content {
    grid-column: 7/span 4;
  }
}
.offset__subtitle {
  color: var(--color-blue);
  font-family: var(--font-mono);
  font-size: 1rem;
  text-transform: uppercase;
}

/*--------------------------------------------------------------
# Partners
--------------------------------------------------------------*/
.partners {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 2.5rem;
  margin-top: clamp(3rem, 1.64vw + 2.62rem, 5.25rem);
}
@media (min-width: 768px) {
  .partners {
    grid-template-columns: repeat(2, minmax(1rem, 1fr));
    grid-gap: 6vw;
  }
}
.partners__item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}
.partners__img {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: contain;
  max-height: clamp(3rem, 3.65vw + 2.16rem, 8rem);
  max-width: clamp(8rem, 5.84vw + 6.65rem, 16rem);
  margin-bottom: 0.5rem;
}
.partners__link {
  border-bottom: 1px solid var(--color-black);
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.09vw + 0.73rem, 0.88rem);
  padding-bottom: 0.75rem;
  margin-bottom: 0.75rem;
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: clamp(1.5rem, 1.1vw + 1.25rem, 3rem);
  transition: 0.2s var(--ease-out);
}
.partners__link span {
  transition: 0.2s var(--ease-out);
}
.partners__link:hover {
  color: var(--color-blue);
}
.partners__link:hover span {
  transform: translateX(1rem);
}
.partners__link .icon {
  font-size: 1.25rem;
  transition: 0.3s var(--ease-out);
}

/*--------------------------------------------------------------
# Performance Highlights Section
--------------------------------------------------------------*/
.section--performance {
  background: #F5F5F5;
  position: relative;
  overflow: hidden;
}

.watermark {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1600px;
  height: 1160px;
  opacity: 0.05;
  z-index: 1;
  pointer-events: none;
  background-image: url("../../../images/colemans-verified-logo.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.performance-header {
  text-align: center;
  margin-bottom: 4rem;
  z-index: 2;
  position: relative;
}

.performance-title {
  font-size: 3rem;
  font-weight: 400;
  color: #001489;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
@media (max-width: 768px) {
  .performance-title {
    font-size: 2.5rem;
  }
}

.performance-subtitle {
  font-size: 1.25rem;
  color: #333;
  margin: 0;
}
.performance-subtitle strong {
  font-weight: bold;
}
@media (max-width: 768px) {
  .performance-subtitle {
    font-size: 1.1rem;
  }
}

.counters-wrapper {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
  z-index: 2;
  position: relative;
}

.chain-container {
  position: relative;
  flex: 1;
  min-width: 280px;
  height: 320px !important;
  min-height: 320px;
  overflow: hidden;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.chain-track {
  position: absolute;
  width: 100%;
  height: 800px;
  top: -80px;
  animation-fill-mode: forwards;
  transition: opacity 1s ease-out;
}

.chain-link {
  width: 240px;
  height: 240px;
  margin: -32px auto;
}
.chain-link svg {
  width: 100%;
  height: 100%;
  fill: #000000;
}

.counter-display {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 96px;
  font-weight: 900;
  color: #000000;
  opacity: 0;
  transition: opacity 1s ease-in;
  z-index: 10;
  text-align: center;
  width: 90%;
  line-height: 1;
}
.counter-display.show {
  opacity: 1;
}
@media (max-width: 768px) {
  .counter-display {
    font-size: 72px;
  }
}

.title {
  position: absolute;
  top: 75%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #000000;
  font-size: 24px;
  font-weight: 900;
  padding: 10px;
  z-index: 11;
  width: 90%;
  opacity: 0;
  transition: opacity 1s ease-in;
  margin-top: 16px;
  text-transform: uppercase;
}
.title.show {
  opacity: 1;
}
@media (max-width: 768px) {
  .title {
    font-size: 20px;
  }
}

/* Chain Animation Keyframes */
@keyframes chainRotate {
  0% {
    transform: translateY(0px);
  }
  100% {
    transform: translateY(-208px);
  }
}
.chain-track.spinning {
  animation: chainRotate 0.15s linear infinite;
}

.chain-track.fade-out {
  opacity: 0;
  transition: opacity 1s ease-out;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .counters-wrapper {
    flex-direction: column;
    align-items: center;
    gap: 3rem;
    max-width: 100%;
    padding: 0 1rem;
  }
  .chain-container {
    width: 100%;
    max-width: 350px;
    height: 180px !important;
    min-height: 180px;
    background: rgba(255, 255, 255, 0.1);
  }
  .performance-header {
    margin-bottom: 3rem;
    padding: 0 1rem;
  }
  .performance-title {
    font-size: 2rem;
  }
  .performance-subtitle {
    font-size: 1rem;
  }
}
@media (max-width: 480px) {
  .chain-container {
    max-width: 300px;
    height: 280px;
  }
  .counter-display {
    font-size: 64px;
    top: 40%;
  }
  .title {
    font-size: 16px;
    top: 65%;
  }
  .performance-title {
    font-size: 2rem;
  }
}
/*--------------------------------------------------------------
# Play
--------------------------------------------------------------*/
.play {
  background: var(--color-blue);
  border-radius: 9em 0 0 9em;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: clamp(0.5rem, 0.37vw + 0.42rem, 1rem);
  padding-right: clamp(1rem, 0.73vw + 0.83rem, 2rem);
  position: absolute;
  bottom: 2rem;
  right: 0;
  z-index: 5;
}
@media (min-width: 768px) {
  .play {
    bottom: 5rem;
  }
}
@media (max-width: 767px) {
  .play {
    background: var(--color-white);
  }
}
.play__icon {
  background: var(--color-secondary);
  border-radius: 100%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3rem, 0.37vw + 2.92rem, 3.5rem);
  height: clamp(3rem, 0.37vw + 2.92rem, 3.5rem);
  transition: transform 0.35s ease;
  position: relative;
  z-index: 5;
}
.play__icon .icon {
  width: clamp(1.25rem, 0.55vw + 1.12rem, 2rem);
  height: clamp(1.25rem, 0.55vw + 1.12rem, 2rem);
}
@media (max-width: 767px) {
  .play__icon {
    background: var(--color-blue);
    padding-left: 5px;
  }
}
.play__title {
  color: var(--color-white);
  font-size: clamp(0.88rem, 0.27vw + 0.81rem, 1.25rem);
  margin-left: clamp(0.25rem, 0.27vw + 0.19rem, 0.63rem);
  position: relative;
  z-index: 5;
  transition: transform 0.35s ease;
}
.play__title em,
.play__title strong {
  display: block;
  line-height: 1.2;
}
.play__title em {
  font-style: normal;
  animation-delay: 0.7s;
}
.play__title strong {
  font-weight: 900;
  animation-delay: 0.75s;
}
@media (max-width: 767px) {
  .play__title {
    color: var(--color-blue);
  }
}
.play:hover .play__title {
  transform: translateX(0.3rem);
}
.play:hover .play__icon {
  transform: scale(1.1);
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
.prose {
  --prose-links: #111827;
  --prose-bold: #111827;
  --prose-counters: #333;
  --prose-bullets: #333;
  --prose-hr: #e5e7eb;
  font-size: 1.2rem;
  line-height: 1.75;
}

.prose a:not(.btn) {
  color: var(--prose-links);
  text-decoration: underline;
  font-weight: 500;
}

.prose .lead {
  font-size: 1em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.02em;
}

.prose p,
.prose li {
  font-size: clamp(1rem, 0.18vw + 0.96rem, 1.25rem);
}

.prose p a {
  margin-top: 0.5rem;
}

.prose h1 {
  margin-top: 0;
  margin-bottom: 0.2222222em;
}

.prose h2 {
  margin-top: 2em;
  margin-bottom: 1em;
}

.prose h3 {
  margin-top: 1.6em;
  margin-bottom: 0.6em;
}

.prose h4,
.prose h5,
.prose h6 {
  margin-top: 1.5em;
  margin-bottom: 0.5em;
}

.prose h1 + *,
.prose h2 + *,
.prose h3 + *,
.prose h4 + *,
.prose h5 + *,
.prose h6 + * {
  margin-top: 0;
}

.prose p {
  margin-bottom: 1.125em;
}

.prose hr {
  border-top: 1px solid var(--prose-hr);
  margin-top: 3em;
  margin-bottom: 3em;
}

.prose hr + * {
  margin-top: 0;
}

.prose strong {
  font-weight: 600;
}

.prose ul {
  list-style-type: disc;
  margin-bottom: 1.125em;
  padding-left: 1.625em;
}

.prose ol > li::marker {
  color: var(--prose-counters);
  font-weight: 400;
}

.prose ul > li::marker {
  color: var(--prose-bullets);
  font-size: 100%;
}

.prose li {
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}

.prose ol > li {
  padding-left: 0.375em;
}

.prose ul > li {
  padding-left: 0.375em;
}

.prose > ul > li p {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}

.prose ol {
  list-style-type: decimal;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  padding-left: 1.625em;
}

.prose ol[type=A] {
  list-style-type: upper-alpha;
}

.prose ol[type=a] {
  list-style-type: lower-alpha;
}

.prose ol[type=A s] {
  list-style-type: upper-alpha;
}

.prose ol[type=a s] {
  list-style-type: lower-alpha;
}

.prose ol[type=I] {
  list-style-type: upper-roman;
}

.prose ol[type=i] {
  list-style-type: lower-roman;
}

.prose ol[type=I s] {
  list-style-type: upper-roman;
}

.prose ol[type=i s] {
  list-style-type: lower-roman;
}

.prose ol[type="1"] {
  list-style-type: decimal;
}

.prose > :first-child {
  margin-top: 0;
}

.prose > :last-child {
  margin-bottom: 0;
}

.prose .btn {
  text-decoration: none;
  line-height: 1;
}

@media (min-width: 1024px) {
  .prose p {
    margin-bottom: 1.2em;
  }
  .prose .lead {
    font-size: clamp(1rem, 0.18vw + 0.96rem, 1.25rem);
    line-height: 1.65;
    letter-spacing: 0;
  }
  .prose h1 {
    margin-top: 0;
    margin-bottom: 0.3333333em;
  }
  .prose h2 {
    margin-top: 1.5555556em;
    margin-bottom: 0.8888889em;
  }
  .prose h3 {
    margin-top: 1.6em;
    margin-bottom: 0.6666667em;
  }
  .prose h4,
  .prose h5,
  .prose h6 {
    margin-top: 1.8em;
    margin-bottom: 0.75em;
  }
  .prose ol {
    margin-top: 1.2em;
    margin-bottom: 1.2em;
    padding-left: 1.6em;
  }
  .prose ul {
    margin-bottom: 1.2em;
    padding-left: 1.2em;
  }
  .prose li {
    margin-top: 0.6em;
    margin-bottom: 0.6em;
  }
  .prose ol > li {
    padding-left: 0.4em;
  }
  .prose ul > li {
    padding-left: 0.1em;
  }
  .prose .prose > ul > li p {
    margin-top: 0.8em;
    margin-bottom: 0.8em;
  }
  .prose hr {
    margin-top: 2.8em;
    margin-bottom: 2.8em;
  }
  .prose hr + * {
    margin-top: 0;
  }
  .prose h2 + * {
    margin-top: 0;
  }
  .prose h3 + * {
    margin-top: 0;
  }
  .prose h4 + * {
    margin-top: 0;
  }
  .prose > :first-child {
    margin-top: 0;
  }
  .prose > :last-child {
    margin-bottom: 0;
  }
}
/*--------------------------------------------------------------
# Quote
--------------------------------------------------------------*/
.quote {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
}
.quote__title {
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.09vw + 0.73rem, 0.88rem);
  text-transform: uppercase;
}
.quote .icon {
  width: clamp(3rem, 1.83vw + 2.58rem, 5.5rem);
  height: clamp(3rem, 1.83vw + 2.58rem, 5.5rem);
}

/*--------------------------------------------------------------
# Socials
--------------------------------------------------------------*/
.socials {
  display: flex;
  align-items: center;
}
.socials > * + * {
  margin-left: 1.25rem;
}
.socials__link {
  color: var(--color-blue);
  width: 100%;
  height: auto;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
}
.socials__link:hover .socials__icon {
  transform: scale(1.1);
}
.socials__icon {
  color: inherit;
  display: inline-block;
  fill: currentColor;
  font-size: 1.75em;
  height: 1em;
  width: 1em;
  line-height: 1;
  flex-shrink: 0;
  max-width: initial;
  transition: transform 0.2s ease;
}

/*--------------------------------------------------------------
# Slider
--------------------------------------------------------------*/
.slider__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 2rem;
}

/**
* Slide
*/
.slide {
  position: relative;
  height: 100%;
  width: 100%;
}
.slide__media {
  border-radius: 0.5rem;
  aspect-ratio: 4/5;
  position: relative;
  overflow: hidden;
}
.slide__img {
  position: absolute;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.slide__heading {
  color: var(--color-white);
  font-size: clamp(1.53rem, 0.99vw + 1.3rem, 2.88rem);
  text-align: center;
  margin-top: clamp(0.75rem, 0.13vw + 0.72rem, 0.93rem);
}
.slide__title {
  color: var(--color-white);
  font-size: clamp(1rem, 0.82vw + 0.81rem, 2.13rem);
  position: absolute;
  bottom: clamp(1rem, 0.73vw + 0.83rem, 2rem);
  left: clamp(1rem, 0.73vw + 0.83rem, 2rem);
  text-align: left;
  max-width: 80%;
  z-index: 10;
}
.slide__tags {
  color: rgba(255, 255, 255, 0.5);
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  text-align: center;
  display: flex;
  justify-content: center;
  gap: clamp(0.88rem, 0.73vw + 0.71rem, 1.88rem);
  margin-top: 1rem;
}
.slide__tags p {
  display: inline-block;
}
@media (min-width: 768px) {
  .slide__tags p {
    opacity: 0;
    transform: translateY(80%);
    transition-property: opacity, transform;
    transition-duration: 0.3s;
    transition-timing-function: cubic-bezier(0.75, -0.015, 0.565, 1.055);
  }
}
.slide--overlay .slide__media::before {
  background: linear-gradient(360deg, rgba(39, 39, 39, 0.9) -9.6%, rgba(39, 39, 39, 0) 100%);
  mix-blend-mode: darken;
  content: "";
  height: 100%;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0.5;
  z-index: 2;
  transition: opacity 0.8s var(--ease-out);
}
.slide--overlay:hover .slide__media::before {
  opacity: 1;
}
.slide:hover .slide__tags p {
  opacity: 1;
  transform: translateY(0);
}
.slide:hover .slide__tags > :nth-child(1) {
  transition-delay: 0.06s;
}
.slide:hover .slide__tags > :nth-child(2) {
  transition-delay: 0.1s;
}
.slide:hover .slide__tags > :nth-child(3) {
  transition-delay: 0.12s;
}
.slide:hover .slide__tags > :nth-child(4) {
  transition-delay: 0.18s;
}
.slide:hover .slide__tags > :nth-child(5) {
  transition-delay: 0.24s;
}

/**
* Events
*/
.swiper--events .swiper-button-prev,
.swiper--events .swiper-button-next {
  display: none;
}
@media (min-width: 768px) {
  .swiper--events .swiper-button-prev,
  .swiper--events .swiper-button-next {
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
    height: clamp(2rem, 0.55vw + 1.87rem, 2.75rem);
    z-index: 5;
    transition: 0.3s ease;
  }
  .swiper--events .swiper-button-prev:hover,
  .swiper--events .swiper-button-next:hover {
    transform: scale(1.1);
  }
}
.swiper--events .swiper-button-prev {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 13 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.28257 0.630493L6.13474 1.48267L2.72604 4.89136H12.5869V6.10875H2.72604L6.13474 9.51745L5.28257 10.3696L0.413002 5.50006L5.28257 0.630493Z' fill='%23fff'/%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-size: 50% auto;
  background-position: center;
}
.swiper--events .swiper-button-next {
  background-image: url("data:image/svg+xml,%3Csvg width='13' height='11' viewBox='0 0 13 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.71743 0.630493L6.86526 1.48267L10.274 4.89136H0.413086V6.10875H10.274L6.86526 9.51745L7.71743 10.3696L12.587 5.50006L7.71743 0.630493Z' fill='%23fff'/%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-size: 50% auto;
  background-position: center;
}

/**
* Videos
*/
.swiper--videos .swiper-button-prev,
.swiper--videos .swiper-button-next {
  display: none;
}
@media (min-width: 768px) {
  .swiper--videos .swiper-button-prev,
  .swiper--videos .swiper-button-next {
    border: 1px solid rgba(69, 90, 116, 0.08);
    border-radius: 50%;
    box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.08);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.75rem;
    height: 2.75rem;
    margin-top: 0;
    position: absolute;
    top: 40%;
    z-index: 5;
    transition: 0.3s ease;
  }
  .swiper--videos .swiper-button-prev:hover,
  .swiper--videos .swiper-button-next:hover {
    transform: scale(1.1);
  }
}
.swiper--videos .swiper-button-prev,
.swiper--videos .swiper-button-next {
  background-color: var(--color-white);
}
.swiper--videos .swiper-button-prev:hover,
.swiper--videos .swiper-button-next:hover {
  box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.08);
}
.swiper--videos .swiper-button-prev:after,
.swiper--videos .swiper-button-next:after {
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  text-transform: none;
  font-variant: initial;
  line-height: 1;
}
.swiper--videos .swiper-button-prev {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 13 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.28257 0.630493L6.13474 1.48267L2.72604 4.89136H12.5869V6.10875H2.72604L6.13474 9.51745L5.28257 10.3696L0.413002 5.50006L5.28257 0.630493Z' fill='%23575757'/%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-size: 33% auto;
  background-position: center;
  left: 0rem;
  right: auto;
}
@media (min-width: 768px) {
  .swiper--videos .swiper-button-prev {
    left: -2rem;
  }
}
.swiper--videos .swiper-button-next {
  background-image: url("data:image/svg+xml,%3Csvg width='13' height='11' viewBox='0 0 13 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7.71743 0.630493L6.86526 1.48267L10.274 4.89136H0.413086V6.10875H10.274L6.86526 9.51745L7.71743 10.3696L12.587 5.50006L7.71743 0.630493Z' fill='%23575757'/%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-size: 33% auto;
  background-position: center;
  right: 0;
  left: auto;
}
@media (min-width: 768px) {
  .swiper--videos .swiper-button-next {
    right: -2rem;
  }
}

/**
* Announcement
*/
.swiper--announcement {
  overflow: hidden;
}

/*--------------------------------------------------------------
# Split
--------------------------------------------------------------*/
.split {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 3rem;
  position: relative;
}
@media (min-width: 768px) {
  .split {
    grid-template-columns: 0.6fr 1fr;
    grid-gap: 6vw;
  }
}
.split__title {
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  text-transform: uppercase;
  padding-bottom: 1rem;
  position: relative;
  z-index: 0;
}
.split__media {
  aspect-ratio: 1/1;
  border-radius: 0.3125rem 0 0 clamp(6.25rem, 4.57vw + 5.19rem, 12.5rem);
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .split__media {
    max-width: 94%;
  }
}
.split__media--sm {
  aspect-ratio: 5/4;
}
.split__img {
  position: absolute;
  top: -20%;
  left: 0;
  height: 120%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}
.split__hr {
  background-color: var(--color-black);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  margin-bottom: clamp(1.33rem, 2.41vw + 0.77rem, 4.63rem);
  transform-origin: 0 50%;
  transform: scaleX(0);
}
.split h2 {
  max-width: 18.75rem;
}

/*--------------------------------------------------------------
# Split Text
--------------------------------------------------------------*/
/**
* Reveal Text
*/
[data-animate=split-text] {
  overflow: hidden;
}
[data-animate=split-text] .split-line {
  display: inline-block;
  transform-origin: 0% 50%;
  will-change: transform;
}

/**
* Reveal Text
*/
[data-animate=reveal-text] {
  overflow: hidden;
}
[data-animate=reveal-text] .split-line {
  display: inline-block;
  transform-origin: 0% 50%;
  will-change: transform;
}

/*--------------------------------------------------------------
# Subnav
--------------------------------------------------------------*/
@media (min-width: 768px) {
  .subnav {
    padding: 1rem 0;
  }
}
.subnav__nav {
  position: relative;
  display: flex;
}
.subnav__list {
  display: flex;
  overflow: auto;
}
.subnav__item {
  display: flex;
  align-items: center;
  gap: 0.325rem;
  flex-shrink: 0;
  margin-right: clamp(1.5rem, 0.55vw + 1.37rem, 2.25rem);
}
.subnav__link {
  color: #747474;
  font-size: 0.95rem;
  font-family: var(--font-mono);
  text-decoration: none;
  display: block;
  padding: 0 1.25rem;
  transition: 0.2s;
}
.subnav__link:hover {
  color: var(--color-blue);
}
.subnav__link[aria-current=page] {
  color: var(--color-blue);
}
.subnav__tag {
  color: #747474;
  border-radius: 9em;
  font-size: clamp(0.63rem, 0.09vw + 0.6rem, 0.75rem);
  border: 1px solid #747474;
  padding: clamp(0.13rem, 0.05vw + 0.11rem, 0.2rem) clamp(0.5rem, 0.09vw + 0.48rem, 0.63rem);
  transition: 0.2s var(--ease-out);
}
.subnav__tag:hover {
  background-color: var(--color-blue);
  border-color: var(--color-blue);
  color: var(--color-white);
}
.subnav__link + .subnav__tag {
  margin-left: 0.75rem;
}
@media (min-width: 768px) {
  .subnav__link + .subnav__tag {
    margin-left: 0;
  }
}
.subnav__control .icon {
  margin-left: 1rem;
}

.subnav:not(.subnav--collapsed) .subnav__control,
.subnav:not(.subnav--collapsed) .subnav__close-btn {
  display: none;
}

.subnav--collapsed {
  display: inline-block;
}
.subnav--collapsed .subnav__wrapper {
  background-color: var(--color-black);
  color: var(--color-white);
  box-shadow: var(--shadow-sm);
  border-radius: 0.5rem 0.5rem 0 0;
  position: fixed;
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  padding-bottom: 2rem;
  visibility: hidden;
  opacity: 0;
  z-index: 15;
}
.subnav--collapsed .subnav__wrapper--is-visible {
  visibility: visible;
  opacity: 1;
  transition: opacity 0.3s;
}
.subnav--collapsed .subnav__wrapper--is-visible .subnav__nav {
  transform: translateY(0);
  transition: transform 0.3s;
}
.subnav--collapsed .subnav__nav {
  display: block;
  max-height: 100%;
  overflow: auto;
  transform: translateY(-1em);
}
.subnav--collapsed .subnav__nav::after {
  display: none;
}
.subnav--collapsed .subnav__list {
  flex-direction: column;
  overflow: visible;
  padding: 0 1rem;
  padding-left: 40px;
}
.subnav--collapsed .subnav__link {
  color: var(--color-white);
  border-width: 0;
  font-size: 1rem;
  padding: 0.5rem 0;
}
.subnav--collapsed .subnav__link[aria-current=page] {
  color: var(--color-blue);
}

.subnav__close-btn {
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  margin: 0.5rem 0.5rem 0 auto;
  transition: 0.2s;
}
.subnav__close-btn:hover {
  box-shadow: var(--shadow-md);
}
.subnav__close-btn .icon {
  display: block;
}

[class*=subnav--expanded]::before {
  display: none;
  content: "collapsed";
}

@media (min-width: 48rem) {
  .subnav--expanded\@sm::before {
    content: "expanded";
  }
}
/*--------------------------------------------------------------
# SVG on Scroll
--------------------------------------------------------------*/
.separator {
  fill: var(--color-white);
  display: block;
  position: absolute;
  bottom: -1px;
  pointer-events: none;
  width: 100%;
  height: clamp(3rem, 5.39vw + 1.75rem, 10.38rem);
  z-index: 10;
  will-change: transform;
}

/*--------------------------------------------------------------
# Swiper
--------------------------------------------------------------*/
.swiper {
  width: 100%;
  height: 100%;
  position: relative;
}
.swiper--traits {
  margin-top: clamp(3rem, 1.46vw + 2.66rem, 5rem);
}

.swiper-wrapper {
  box-sizing: content-box;
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  transition-property: transform;
  transform: translate3d(0px, 0, 0);
  z-index: 1;
}

.swiper-container-pointer-events {
  touch-action: pan-y;
}

.swiper-slide {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  position: relative;
  transition: all 0.3s;
  transition-property: transform;
  will-change: transform, opacity, box-shadow;
}

.swiper-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-button-disabled {
  display: none !important;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-scrollbar {
  cursor: pointer;
  background: #404040;
  border-radius: 1em;
  height: 0.4rem;
  position: relative;
  width: 60%;
  margin: 3rem auto 0 auto;
  z-index: 10;
}
@media (min-width: 768px) {
  .swiper-scrollbar {
    width: 30%;
  }
}

.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0.1875rem;
  height: 0.4rem;
  width: 60%;
  z-index: 10;
}
@media (min-width: 768px) {
  .swiper-horizontal > .swiper-scrollbar,
  .swiper-scrollbar.swiper-scrollbar-horizontal {
    width: 30%;
  }
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--color-blue);
  border-radius: 1em;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-pagination {
  display: flex;
  align-items: center;
  margin-right: 1rem;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none;
}

.swiper-pagination-bullet {
  background: transparent;
  border: 1.5px solid var(--color-white);
  border-radius: 50%;
  display: inline-flex;
  width: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem);
  height: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem);
  margin: 0 3px;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none;
}

.swiper-pagination-bullet-active {
  background: var(--color-white);
}

.swiper-controls {
  position: absolute;
  display: flex;
  align-items: center;
  bottom: -1rem;
  left: 0;
}
@media (min-width: 768px) {
  .swiper-controls {
    top: 3rem;
    right: 0;
    bottom: auto;
    left: auto;
  }
}

.swiper--community,
.swiper--customers,
.swiper--suppliers {
  mask-image: linear-gradient(to right, transparent 0%, white 10%, white 90%, transparent 100%);
}

.swiper--community .swiper-wrapper,
.swiper--customers .swiper-wrapper,
.swiper--suppliers .swiper-wrapper {
  transition-timing-function: linear !important;
  align-items: center;
}

.swiper--community .swiper-slide,
.swiper--customers .swiper-slide,
.swiper--suppliers .swiper-slide {
  width: auto !important;
  flex-shrink: 0;
}

.swiper--community .community-logo,
.swiper--customers .community-logo,
.swiper--suppliers .community-logo {
  width: 200px;
  flex-shrink: 0;
}

.community-slider {
  width: 100%;
  overflow: hidden;
}

/**
 * Splide Slider Styles
 * Extracted from inline styles in page templates
 */
/* Community Slider - Used in page-about.php */
.splide--community {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, white 10%, white 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, white 10%, white 90%, transparent 100%);
}

.splide--community .splide__list {
  align-items: center;
}

.splide--community .splide__slide {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto !important;
}

.splide--community .community-logo {
  width: auto;
  max-width: 180px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.splide--community .community-logo__img {
  max-width: 100%;
  max-height: 80px;
  width: auto;
  height: auto;
  object-fit: contain;
  transition: all 0.3s ease;
}

/* Larger logos on desktop */
@media (min-width: 992px) {
  .splide--community .community-logo {
    max-width: 250px;
    height: 120px;
  }
  .splide--community .community-logo__img {
    max-height: 120px;
  }
}
/* Customers Slider - Used in page-who-we-deal-with.php */
.splide--customers,
.splide--suppliers {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, white 10%, white 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, white 10%, white 90%, transparent 100%);
}

.splide--customers .splide__list,
.splide--suppliers .splide__list {
  align-items: center;
}

.splide--customers .splide__slide,
.splide--suppliers .splide__slide {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto !important;
}

.splide--customers .community-logo,
.splide--suppliers .community-logo {
  width: auto !important;
  max-width: 180px;
  height: 100px !important;
  padding: 0.75rem !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

.splide--customers .community-logo__img,
.splide--suppliers .community-logo__img {
  max-width: 100%;
  max-height: 70px !important;
  width: auto !important;
  height: auto;
  object-fit: contain;
}

/* Larger logos on desktop */
@media (min-width: 992px) {
  .splide--customers .community-logo,
  .splide--suppliers .community-logo {
    max-width: 250px;
    height: 140px !important;
    padding: 1rem !important;
  }
  .splide--customers .community-logo__img,
  .splide--suppliers .community-logo__img {
    max-height: 100px !important;
  }
}
/* Community Logo Styles */
.community-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 120px;
}

.community-logo:hover {
  transform: translateY(-5px);
}

.community-logo__img {
  max-width: 100%;
  height: auto;
  max-height: 80px;
  object-fit: contain;
}

/* Swiper Pagination Styling (fallback for pages using Swiper instead of Splide) */
.swiper-pagination {
  position: relative !important;
  margin-top: 2rem !important;
  text-align: center !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.swiper-pagination-bullet {
  width: 12px !important;
  height: 12px !important;
  background: #ccc !important;
  opacity: 1 !important;
  margin: 0 4px !important;
}

.swiper-pagination-bullet-active {
  background: #001489 !important;
}

/*--------------------------------------------------------------
# Tabs
--------------------------------------------------------------*/
.tab__header {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
  text-align: left;
}
@media (min-width: 768px) {
  .tab__header {
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    gap: 0;
  }
}
.tab__controls {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(1rem, 0.24vw + 0.95rem, 1.33rem);
  width: 100%;
  max-width: 54rem;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .tab__controls {
    align-items: center;
    justify-content: center;
    flex-direction: row;
  }
}
.tab__control {
  background-color: #E8E8E8;
  color: var(--color-black);
  border-radius: 9em;
  display: flex;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  position: relative;
  padding: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem) clamp(1.5rem, 0.37vw + 1.42rem, 2rem);
  flex-grow: 0.25;
  transition: all 1000ms cubic-bezier(0.2, 1, 0.25, 1);
}
.tab__control[aria-selected=true] {
  max-width: 100%;
  max-height: 100%;
  flex-grow: 1;
}
.tab__control[aria-selected=true] span {
  text-transform: capitalize;
  opacity: 1;
  display: inline-flex;
}
.tab__control:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.tab__control[aria-selected=true] {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.tab__control span {
  display: none;
  opacity: 0;
  margin-left: 0.5rem;
}
.tab__panels {
  position: relative;
  padding: clamp(2.5rem, 2.56vw + 1.91rem, 6rem) 0;
}
.tab__panel {
  animation: scaleIn 0.3s var(--ease-in-out);
}

@keyframes scaleIn {
  0% {
    display: none;
    visibility: hidden;
    opacity: 0;
  }
  1% {
    visibility: hidden;
    display: block;
    opacity: 0;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
/*--------------------------------------------------------------
# Team
--------------------------------------------------------------*/
.team {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  grid-gap: 1rem;
}
@media (min-width: 768px) {
  .team {
    grid-template-columns: repeat(12, 1fr);
  }
}
@media (min-width: 768px) {
  .team > * {
    grid-column: span 3;
  }
}
.team__item {
  padding-right: clamp(1.5rem, 1.1vw + 1.25rem, 3rem);
}
.team__item--padding {
  padding: clamp(1.5rem, 1.1vw + 1.25rem, 3rem);
  text-align: center;
}
.team {
  /* Feature cards layout - 3 cards centered with flexbox */
}
@media (min-width: 768px) {
  .team--features {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 1rem;
  }
  .team--features .card {
    flex: 0 1 calc(33.333% - 0.667rem);
    width: calc(33.333% - 0.667rem);
  }
}

/*--------------------------------------------------------------
# Tease
--------------------------------------------------------------*/
.tease {
  background-color: var(--color-blue);
  border-radius: 0.325rem;
  box-shadow: var(--shadow-sm);
  transition: 0.2s var(--ease-out);
}
.tease__link {
  display: block;
  padding: clamp(1rem, 2.19vw + 0.49rem, 4rem);
}
.tease__date {
  background-color: var(--color-blue);
  color: var(--color-white);
  padding: 0.5rem clamp(0.93rem, 0.24vw + 0.87rem, 1.25rem);
  font-family: var(--font-mono);
  font-size: clamp(0.63rem, 0.18vw + 0.58rem, 0.88rem);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  position: absolute;
  top: -2.25rem;
  left: 0;
}
.tease__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tease__wrap {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 0.55vw + 0.62rem, 1.5rem);
}
.tease__wrap .icon {
  margin-top: 0.25rem;
}
.tease__title {
  color: var(--color-white);
  font-size: clamp(1.25rem, 1.46vw + 0.91rem, 3.25rem);
}
.tease:hover {
  background-color: rgb(185.661971831, 17.138028169, 45.7014084507);
}

/*--------------------------------------------------------------
# Coleman's Verified
--------------------------------------------------------------*/
.colemans-verified {
  position: relative;
  background: #f1f1f1;
  overflow: hidden;
  padding: 4rem 0;
}
.colemans-verified__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 768px) {
  .colemans-verified__inner {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.colemans-verified__content {
  position: relative;
  z-index: 2;
}
.colemans-verified__title {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--color-blue);
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}
@media (min-width: 768px) {
  .colemans-verified__title {
    font-size: 4rem;
    margin-bottom: 2rem;
  }
}
.colemans-verified__text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-black);
  margin-bottom: 2rem;
}
.colemans-verified__text p {
  margin-bottom: 1rem;
}
.colemans-verified__text p:last-child {
  margin-bottom: 0;
}
.colemans-verified__text strong {
  font-weight: 700;
  color: var(--color-blue);
}
@media (min-width: 768px) {
  .colemans-verified__text {
    font-size: 1.125rem;
    margin-bottom: 3rem;
  }
}
.colemans-verified__features {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  .colemans-verified__features {
    gap: 1.5rem;
    margin-bottom: 3rem;
  }
}
.colemans-verified__button .btn {
  padding: 1rem 2rem;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  border-width: 2px;
  border-radius: 2rem;
}
@media (min-width: 768px) {
  .colemans-verified__button .btn {
    padding: 1.25rem 2.5rem;
    font-size: 1rem;
  }
}
.colemans-verified__media {
  position: relative;
  z-index: 2;
}
.colemans-verified__img {
  width: 100%;
  height: auto;
  border-radius: 1rem;
  object-fit: cover;
}
.colemans-verified__bg-svg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  opacity: 0.6;
  pointer-events: none;
}
.colemans-verified__bg-svg svg {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.feature-item__icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-blue);
}
.feature-item__icon .icon {
  width: 100%;
  height: 100%;
}
.feature-item__text {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-black);
}

@media (min-width: 768px) {
  .feature-item {
    gap: 1rem;
  }
  .feature-item__icon {
    width: 2rem;
    height: 2rem;
  }
  .feature-item__text {
    font-size: 1.125rem;
  }
}
/*--------------------------------------------------------------
# Video
--------------------------------------------------------------*/
.video {
  aspect-ratio: 16/12;
  border-radius: clamp(0.5rem, 0.18vw + 0.46rem, 0.75rem);
  display: grid;
  grid-template-areas: "video";
  align-items: end;
  justify-items: end;
  position: relative;
  overflow: hidden;
  width: 100%;
}
@media (min-width: 768px) {
  .video {
    aspect-ratio: 16/9;
  }
}
.video:after {
  content: "";
  background-image: linear-gradient(to top, #272727, rgba(39, 39, 39, 0) 40%);
  position: absolute;
  inset: 0;
}
.video:before {
  content: "";
  background-image: linear-gradient(to top, #272727, rgba(39, 39, 39, 0) 100%);
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.2s var(--ease-out);
  z-index: 1;
}
.video > * {
  grid-area: video;
}
.video__link {
  pointer-events: auto;
  height: 100%;
  width: 100%;
  z-index: 10;
}
.video img {
  position: absolute;
  top: -20%;
  left: 0;
  height: 120%;
  width: 100%;
  object-fit: cover;
  will-change: transform;
}
.video:hover::before {
  opacity: 0.8;
}
.video:hover .play__title {
  transform: translateX(0.3rem);
}
.video:hover .play__icon {
  transform: scale(1.1);
}

/*--------------------------------------------------------------
# Video Background
--------------------------------------------------------------*/
.video-bg {
  height: clamp(50vh, 30vw + 20rem, 100vh);
  min-height: 500px;
  position: relative;
  overflow: hidden;
  width: 100%;
}
@media (min-width: 768px) {
  .video-bg {
    height: 100vh;
    min-height: 600px;
  }
}
@media (min-width: 1200px) {
  .video-bg {
    height: 100vh;
    min-height: 700px;
  }
}
.video-bg > * {
  grid-area: video;
}
.video-bg__video {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  overflow: hidden;
  z-index: 0;
}
.video-bg__video video {
  position: relative;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  min-height: 100%;
  min-width: 100%;
  height: auto;
  width: auto;
  max-width: none;
}
@supports (object-fit: cover) {
  .video-bg__video video {
    object-fit: cover;
    height: 100%;
    width: 100%;
  }
}
@supports (object-fit: cover) and (-ms-ime-align: auto) {
  .video-bg__video video {
    height: auto;
    width: auto;
  }
}
.video-bg__img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: -1;
}
@media (min-width: 768px) {
  .video-bg .play {
    margin-bottom: 12rem;
  }
}

/*--------------------------------------------------------------
# 06 - Pages
--------------------------------------------------------------*/
/**
 * Page About Specific Styles
 * Extracted from inline styles in page-about.php
 */
.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

@media (max-width: 480px) {
  .about-intro-title *,
  .about-intro-title h1,
  .about-intro-title h2,
  .about-intro-title h3,
  .about-intro-title h4,
  .about-intro-title h5,
  .about-intro-title h6,
  .about-intro-title p {
    font-size: 2rem;
  }
}
/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact__info {
  padding-bottom: 3rem;
}
@media (min-width: 768px) {
  .contact__info {
    border-right: 1px solid #E4E4E4;
  }
}
@media (min-width: 1024px) {
  .contact__location {
    display: flex;
    align-items: stretch;
  }
}
@media (min-width: 1024px) {
  .contact__location .map {
    height: 100%;
    min-height: 100%;
    padding-bottom: 0;
  }
}
.contact__form {
  border-top: 1px solid #E4E4E4;
  padding-top: 2.5rem;
}
.contact__subtitle {
  color: var(--color-blue);
  font-family: var(--font-mono);
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  font-weight: 400;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.contact__title {
  color: #8F8F8F;
  font-size: clamp(0.75rem, 0.18vw + 0.71rem, 1rem);
  text-transform: uppercase;
}

/* About Intro Title */
.about-intro-title {
  font-size: 2rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 700;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

/* Contact Intro Title */
.contact-intro-title {
  font-size: 2rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.contact-intro-title *,
.contact-intro-title h1,
.contact-intro-title h2,
.contact-intro-title h3,
.contact-intro-title h4,
.contact-intro-title h5,
.contact-intro-title h6,
.contact-intro-title p {
  font-size: 2.5rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.contact-intro-title strong {
  font-weight: 700 !important;
}

/* Locations Heading */
.locations-heading {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
  font-weight: 400;
  text-align: center !important;
}

.locations-heading h2 strong {
  font-weight: 700 !important;
}

.locations-heading *,
.locations-heading h1,
.locations-heading h2,
.locations-heading h3,
.locations-heading h4,
.locations-heading h5,
.locations-heading h6,
.locations-heading p {
  font-size: 3rem;
  color: #001489 !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Social Media Icons */
.social-item {
  margin-bottom: 1.5rem;
}

.social-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.social-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.social-header .contact__title {
  margin: 0 !important;
  font-weight: 600;
  color: #001489;
}

/* Contact details and location text sizing */
.contact__item .prose p,
.contact__item .prose span {
  font-size: 1.2rem !important;
  line-height: 1.5 !important;
}

/* Locations Grid */
.locations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.location-item {
  position: relative;
  border-radius: 0.3125rem;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.location-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.location-item__image {
  position: relative;
  width: 100%;
  height: 300px;
  overflow: hidden;
}

.location-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.location-item:hover .location-item__img {
  transform: scale(1.05);
}

.location-item__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(transparent, rgba(0, 20, 137, 0.9));
  color: white;
  padding: 2rem 1.5rem 1.5rem;
}

.location-item__title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: white !important;
  margin: 0 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px;
}

@media (max-width: 768px) {
  .locations-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .location-item__image {
    height: 250px;
  }
  .location-item__title {
    font-size: 1.25rem !important;
  }
}
/**
 * Cookie Policy Page Styling
 * Styles for Complianz-generated cookie policy pages
 * ONLY targets the #cmplz-document content div
 */
#cmplz-document.cmplz-document {
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 20px;
  font-family: var(--font-body, "Avenir Next", sans-serif);
  line-height: 1.8;
  color: #333;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document {
    padding: 60px 20px;
  }
}
#cmplz-document.cmplz-document > p:first-of-type {
  font-size: 14px;
  color: #666;
  font-style: italic;
  margin-bottom: 40px;
  padding-bottom: 30px;
  border-bottom: 1px solid #e5e5e5;
}
#cmplz-document.cmplz-document h2 {
  font-size: 32px;
  font-weight: bold;
  color: #001489;
  margin: 60px 0 24px;
  line-height: 1.3;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document h2 {
    font-size: 26px;
    margin: 50px 0 20px;
  }
}
#cmplz-document.cmplz-document h3 {
  font-size: 24px;
  font-weight: 600;
  color: #001489;
  margin: 40px 0 20px;
  line-height: 1.4;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document h3 {
    font-size: 20px;
  }
}
#cmplz-document.cmplz-document h4 {
  font-size: 18px;
  font-weight: 600;
  color: #333;
  margin: 30px 0 16px;
}
#cmplz-document.cmplz-document h5 {
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #666;
  margin: 20px 0 10px;
}
#cmplz-document.cmplz-document p {
  margin-bottom: 20px;
  font-size: 16px;
  color: #555;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document p {
    font-size: 15px;
  }
}
#cmplz-document.cmplz-document .cmplz-subtitle {
  font-size: 20px;
  font-weight: 600;
  color: #001489;
  margin: 30px 0 16px;
}
#cmplz-document.cmplz-document a {
  color: #001489;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s ease;
}
#cmplz-document.cmplz-document a:hover {
  border-bottom-color: #001489;
}
#cmplz-document.cmplz-document ul {
  margin: 20px 0 30px 20px;
  padding: 0;
}
#cmplz-document.cmplz-document ul li {
  margin-bottom: 12px;
  padding-left: 10px;
  font-size: 16px;
  color: #555;
  position: relative;
}
#cmplz-document.cmplz-document ul li:before {
  content: "•";
  color: #001489;
  font-weight: bold;
  position: absolute;
  left: -15px;
}
#cmplz-document.cmplz-document #cmplz-manage-consent-container {
  background: #f5f7fa;
  padding: 30px;
  border-radius: 8px;
  margin: 30px 0;
  border: 1px solid #e0e4e8;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document #cmplz-manage-consent-container {
    padding: 20px;
  }
}
#cmplz-document.cmplz-document #cmplz-cookies-overview {
  margin: 40px 0;
}
#cmplz-document.cmplz-document .cmplz-dropdown {
  background: #fff;
  border: 1px solid #e0e4e8;
  border-radius: 8px;
  margin-bottom: 16px;
  overflow: hidden;
  transition: all 0.3s ease;
}
#cmplz-document.cmplz-document .cmplz-dropdown:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header {
  cursor: pointer;
  padding: 24px 28px;
  background: #fff;
  transition: background-color 0.3s ease;
  list-style: none;
  user-select: none;
  position: relative;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header:hover {
  background: #f8f9fb;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header:before {
  content: "";
  position: absolute;
  right: 28px;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 8px solid #001489;
  transition: transform 0.3s ease;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header::-webkit-details-marker {
  display: none;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header div {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 600;
  color: #001489;
  flex: 1;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header p {
  margin: 0;
  padding: 6px 16px;
  background: #e8edf5;
  color: #001489;
  font-size: 13px;
  font-weight: 600;
  border-radius: 20px;
  text-transform: capitalize;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-header input[type=checkbox] {
  display: none;
}
#cmplz-document.cmplz-document .cmplz-dropdown[open] .cmplz-service-header {
  background: #f8f9fb;
  border-bottom: 1px solid #e0e4e8;
}
#cmplz-document.cmplz-document .cmplz-dropdown[open] .cmplz-service-header:before {
  transform: translateY(-50%) rotate(180deg);
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-description,
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-sharing-data {
  padding: 20px 28px;
  border-bottom: 1px solid #f0f2f5;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-description h4,
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-sharing-data h4 {
  margin: 0 0 12px;
  font-size: 15px;
  font-weight: 600;
  color: #001489;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-service-description p,
#cmplz-document.cmplz-document .cmplz-dropdown .cmplz-sharing-data p {
  margin: 0;
  font-size: 15px;
  color: #555;
  line-height: 1.6;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose {
  padding: 20px 28px;
  background: #fafbfc;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose .purpose {
  margin-bottom: 20px;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose .purpose h4 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #001489;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose) {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px 24px;
  padding: 16px 0;
  border-bottom: 1px solid #e0e4e8;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose):last-child {
  border-bottom: none;
}
@media (max-width: 768px) {
  #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose) {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).name-header, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).retention-header, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).function-header {
  border-bottom: none;
  padding: 8px 0;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).name-header h5, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).retention-header h5, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).function-header h5 {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: #666;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).name, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).retention, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).function {
  font-size: 14px;
  color: #555;
  line-height: 1.6;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).name a, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).retention a, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).function a {
  color: #001489;
  font-weight: 500;
}
#cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).name a:hover, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).retention a:hover, #cmplz-document.cmplz-document .cmplz-dropdown .cookies-per-purpose > div:not(.purpose).function a:hover {
  text-decoration: underline;
}
#cmplz-document.cmplz-document .cmplz-contact-organisation,
#cmplz-document.cmplz-document .cmplz-contact-address,
#cmplz-document.cmplz-document .cmplz-contact-country,
#cmplz-document.cmplz-document .cmplz-contact-domain,
#cmplz-document.cmplz-document .cmplz-contact-email,
#cmplz-document.cmplz-document .cmplz-contact-telephone {
  display: block;
  margin: 8px 0;
  font-size: 16px;
  color: #555;
}
#cmplz-document.cmplz-document .cmplz-contact-domain a,
#cmplz-document.cmplz-document .cmplz-contact-email a {
  color: #001489;
  font-weight: 500;
}
#cmplz-document.cmplz-document .cmplz-contact-domain a:hover,
#cmplz-document.cmplz-document .cmplz-contact-email a:hover {
  text-decoration: underline;
}
#cmplz-document.cmplz-document > p:last-of-type {
  margin-top: 60px;
  padding-top: 30px;
  border-top: 1px solid #e5e5e5;
  font-size: 14px;
  color: #999;
  font-style: italic;
}

/**
 * Privacy Policy Page Styling
 * Styles for privacy policy page content
 * ONLY targets the page content area, not header/footer
 */
.privacy-policy .entry-content,
.privacy-policy main,
.privacy-policy article {
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 20px;
  font-family: var(--font-body, "Avenir Next", sans-serif);
  line-height: 1.8;
  color: #333;
}
@media (max-width: 768px) {
  .privacy-policy .entry-content,
  .privacy-policy main,
  .privacy-policy article {
    padding: 60px 20px;
  }
}
.privacy-policy .entry-content h2,
.privacy-policy main h2,
.privacy-policy article h2 {
  font-size: 32px;
  font-weight: bold;
  color: #001489;
  margin: 60px 0 24px;
  line-height: 1.3;
}
.privacy-policy .entry-content h2:first-of-type,
.privacy-policy main h2:first-of-type,
.privacy-policy article h2:first-of-type {
  margin-top: 0;
}
@media (max-width: 768px) {
  .privacy-policy .entry-content h2,
  .privacy-policy main h2,
  .privacy-policy article h2 {
    font-size: 26px;
    margin: 50px 0 20px;
  }
}
.privacy-policy .entry-content h3,
.privacy-policy main h3,
.privacy-policy article h3 {
  font-size: 24px;
  font-weight: 600;
  color: #001489;
  margin: 40px 0 20px;
  line-height: 1.4;
}
@media (max-width: 768px) {
  .privacy-policy .entry-content h3,
  .privacy-policy main h3,
  .privacy-policy article h3 {
    font-size: 20px;
  }
}
.privacy-policy .entry-content h4,
.privacy-policy main h4,
.privacy-policy article h4 {
  font-size: 18px;
  font-weight: 600;
  color: #333;
  margin: 30px 0 16px;
}
.privacy-policy .entry-content h5,
.privacy-policy main h5,
.privacy-policy article h5 {
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #666;
  margin: 20px 0 10px;
}
.privacy-policy .entry-content p,
.privacy-policy main p,
.privacy-policy article p {
  margin-bottom: 20px;
  font-size: 16px;
  color: #555;
}
@media (max-width: 768px) {
  .privacy-policy .entry-content p,
  .privacy-policy main p,
  .privacy-policy article p {
    font-size: 15px;
  }
}
.privacy-policy .entry-content a,
.privacy-policy main a,
.privacy-policy article a {
  color: #001489;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s ease;
}
.privacy-policy .entry-content a:hover,
.privacy-policy main a:hover,
.privacy-policy article a:hover {
  border-bottom-color: #001489;
}
.privacy-policy .entry-content ul,
.privacy-policy main ul,
.privacy-policy article ul {
  margin: 20px 0 30px 20px;
  padding: 0;
}
.privacy-policy .entry-content ul li,
.privacy-policy main ul li,
.privacy-policy article ul li {
  margin-bottom: 12px;
  padding-left: 10px;
  font-size: 16px;
  color: #555;
  position: relative;
}
.privacy-policy .entry-content ul li:before,
.privacy-policy main ul li:before,
.privacy-policy article ul li:before {
  content: "•";
  color: #001489;
  font-weight: bold;
  position: absolute;
  left: -15px;
}
.privacy-policy .entry-content ul li p,
.privacy-policy main ul li p,
.privacy-policy article ul li p {
  margin: 0;
}
.privacy-policy .entry-content strong,
.privacy-policy main strong,
.privacy-policy article strong {
  color: #001489;
  font-weight: 600;
}
.privacy-policy .entry-content em, .privacy-policy .entry-content i,
.privacy-policy main em,
.privacy-policy main i,
.privacy-policy article em,
.privacy-policy article i {
  font-style: italic;
  color: #666;
}

/**
 * Front Page Specific Styles
 * Extracted from inline styles in front-page.php
 */
/* Coleman's Verified Section */
.verified-title {
  font-size: 2.5rem !important;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.verified-title *,
.verified-title h2 {
  font-size: 3rem !important;
  color: #001489 !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.verified-title strong {
  font-weight: 700 !important;
}

.verified-content ul {
  list-style: none;
  padding: 0;
  margin: 2rem 0 2rem 0;
}

.verified-content li {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

.verified-content li:last-child {
  margin-bottom: 0;
}

.verified-content li::before {
  content: "";
  width: 38px;
  height: 24px;
  background-image: url('data:image/svg+xml;charset=utf-8,<svg width="38" height="24" viewBox="0 0 38 24" fill="none" xmlns="http://www.w3.org/2000/svg"><g clip-path="url(%23clip0_2722_1264)"><path d="M9.69541 23.8958L10.5063 23.9982H18.4641C18.9903 23.9299 19.4794 23.4484 19.5952 22.9343C19.7111 22.4185 19.555 22.1403 19.3121 21.7141C18.8133 20.8339 18.1761 19.7911 17.6082 18.9581C17.0161 18.0877 16.5736 18.1902 15.597 18.2016C14.1136 18.2195 12.5899 18.3074 11.1129 18.104C6.06081 17.4093 4.0625 10.8659 7.90305 7.41039C9.51842 5.95757 11.2931 5.83718 13.367 5.79651C14.3806 5.77699 15.5841 5.92666 16.5575 5.82905C16.8649 5.79814 17.214 5.58013 17.4087 5.34261C18.0056 4.25909 18.8503 3.19836 19.4166 2.10996C19.9235 1.13382 19.3185 0.115384 18.263 0.0324123C15.782 0.113757 13.2399 -0.0717091 10.767 0.0324123C7.28682 0.177206 3.77611 2.51506 1.91617 5.42395C0.847834 7.0964 0.120592 9.22439 0.00957469 11.2173C-0.0209952 11.7607 0.0320999 12.3318 0.00957469 12.8784L0.13829 13.9229C0.902538 18.9581 4.7817 22.9261 9.69541 23.8974V23.8958Z" fill="%23001489"/><path d="M36.6485 0.221191L32.9785 0.242341C32.631 0.268371 32.3204 0.294402 31.7702 1.18432L24.6538 12.6019C23.8381 14.0287 23.2621 13.334 23.2621 13.334L22.0055 11.725V11.7299C21.8623 11.5477 21.6129 11.3687 21.4054 11.2971C20.5993 11.0189 19.3025 10.6529 18.8359 10.6024C18.6235 10.5748 18.2197 10.6447 18.0202 10.7488C17.9445 10.7879 17.7756 10.9018 17.7096 10.9587C17.5552 11.0905 17.3315 11.4354 17.2752 11.6241C17.0725 12.4229 16.8939 13.4967 16.8167 14.3817C16.799 14.59 16.8199 14.7998 16.9036 14.982L22.3563 23.3524C22.8357 23.9593 23.7287 23.9788 24.324 23.1962V23.206L24.3771 23.1263C24.3771 23.1247 24.3803 23.123 24.3803 23.1214L37.8311 2.23529C38.3057 1.238 37.7378 0.333447 36.6469 0.221191H36.6485Z" fill="%23001489"/></g><defs><clipPath id="clip0_2722_1264"><rect width="38" height="24" fill="white"/></clipPath></defs></svg>');
  background-repeat: no-repeat;
  background-size: contain;
  flex-shrink: 0;
}

/* SVG Circle Badge Animation - Front Page Only */
.page-template-page-template-page-front-page .svg-circle-wrapper,
.home .svg-circle-wrapper {
  position: absolute;
  top: 20px;
  right: 20px;
  left: auto;
  width: 280px;
  height: 280px;
  z-index: 10;
  transform: translate3d(0, 0, 0) !important;
  will-change: auto !important;
}

.circular-text-svg {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
  pointer-events: none;
  animation: rotateCircle 20s linear infinite;
}

.circular-text-svg text {
  font-size: 17px;
  letter-spacing: 2px;
  text-transform: uppercase;
  fill: #001489;
}

.center-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.logo-border {
  width: 250px;
  height: 250px;
  background: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.12);
}

.logo-border img {
  width: 74%;
  height: 74%;
  object-fit: contain;
  border-radius: 50%;
  transform: rotate(8deg);
}

@keyframes rotateCircle {
  100% {
    transform: rotate(360deg);
  }
}
/* Mobile responsiveness */
@media (max-width: 768px) {
  .verified-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .verified-image-container {
    border-radius: 0.5rem 0.5rem 0.5rem 8rem !important;
  }
  .page-template-page-template-page-front-page .svg-circle-wrapper,
  .home .svg-circle-wrapper {
    width: 200px !important;
    height: 200px !important;
    top: 10px !important;
    right: 10px !important;
  }
  .logo-border {
    width: 180px !important;
    height: 180px !important;
  }
  .circular-text-svg text {
    letter-spacing: 1.8px !important;
  }
}
@media (max-width: 1024px) and (min-width: 769px) {
  .page-template-page-template-page-front-page .svg-circle-wrapper,
  .home .svg-circle-wrapper {
    width: 220px !important;
    height: 220px !important;
    top: 10px !important;
    right: 10px !important;
  }
  .logo-border {
    width: 180px !important;
    height: 180px !important;
  }
  .circular-text-svg text {
    font-size: 14px !important;
  }
}
/* Difference Section */
.difference-title {
  font-size: 2.5rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  color: white !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
}

.difference-title *,
.difference-title h1,
.difference-title h2,
.difference-title h3,
.difference-title h4,
.difference-title h5,
.difference-title h6,
.difference-title p {
  color: white !important;
  font-size: 3rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  text-decoration: none !important;
  display: inline !important;
}

.difference-title strong {
  color: white !important;
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  text-decoration: none !important;
  display: inline !important;
}

/* Extra specific targeting for WordPress theme overrides */
section .difference-title h2,
.section .difference-title h2,
.container .difference-title h2 {
  color: white !important;
  font-size: 3rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
}

.difference-content {
  font-size: 1.5rem;
  line-height: 1;
  color: white;
  margin-bottom: 2.5rem;
  font-weight: 600;
}

.difference-content p {
  margin-bottom: 1rem;
}

.difference-content p:last-child {
  margin-bottom: 0;
}

/* Intro Button Styles */
.intro-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
}

.intro-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.intro-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.intro-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

/* Mobile responsiveness for Difference section */
@media (max-width: 768px) {
  .difference-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .difference-title {
    font-size: 2.5rem;
    margin-bottom: 1.5rem !important;
  }
  .difference-content {
    font-size: 1.2rem;
    margin-bottom: 2rem !important;
  }
}
@media (min-width: 640px) {
  .intro-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
/**
 * Coleman's Verified Page Specific Styles
 * Extracted from inline styles in page-colemans-verified.php
 */
/* SVG Circle Badge Animation */
.svg-circle-wrapper {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 280px;
  height: 280px;
  z-index: 10;
}

.circular-text-svg {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
  pointer-events: none;
  animation: rotateCircle 20s linear infinite;
}

.circular-text-svg text {
  font-size: 17px;
  letter-spacing: 2px;
  text-transform: uppercase;
  fill: #001489;
}

.center-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.logo-border {
  width: 250px;
  height: 250px;
  background: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.12);
}

.logo-border img {
  width: 74%;
  height: 74%;
  object-fit: contain;
  border-radius: 50%;
  transform: rotate(8deg);
}

@keyframes rotateCircle {
  100% {
    transform: rotate(360deg);
  }
}
/* Offset Flipped Layout */
@media (min-width: 768px) {
  .offset--flipped {
    margin: 0;
    margin-left: 4.6667vw;
  }
}

@media (min-width: 768px) {
  .offset--flipped .offset__content {
    grid-column: 1/span 4;
  }
}

.offset--flipped .offset__media {
  border-radius: 0.3125rem 0 0 6.25rem;
  aspect-ratio: 16/9;
}
@media (min-width: 768px) {
  .offset--flipped .offset__media {
    grid-column: 6/-1;
    margin-right: calc(-50vw + 50%);
  }
}
@media (max-width: 768px) {
  .offset--flipped .offset__media {
    aspect-ratio: 1/1 !important;
  }
}
@media (min-width: 1024px) {
  .offset--flipped .offset__media {
    border-radius: 0.3125rem 0 0 12.5rem;
  }
}

/* Intro Title */
.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

/* Verified Items Grid */
.verified-items-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem 6rem;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 2rem;
}

.verified-item {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  padding: 0;
}

.verified-item__icon {
  flex-shrink: 0;
  width: 40px;
  height: 30px;
  background: transparent;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: 0.25rem;
}

.verified-item__icon svg {
  width: 38px;
  height: 24px;
}

.verified-item__title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #000 !important;
  margin-bottom: 0.75rem !important;
  line-height: 1.3 !important;
  text-transform: uppercase !important;
}

.verified-item__description {
  font-size: 0.95rem !important;
  color: #555 !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}

@media (max-width: 768px) {
  .verified-items-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
    padding: 0 1rem;
  }
}
/* Confidence Section */
.confidence-button-wrap {
  margin-top: 2rem;
}

/* Intro Button Styles */
.intro-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.intro-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.intro-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

/* Custom layout for Buy with Confidence section */
@media (min-width: 768px) {
  .confidence-layout {
    gap: 3rem;
  }
}

.confidence-layout .offset__media {
  aspect-ratio: 16/9;
  border-radius: 0;
}
@media (min-width: 768px) {
  .confidence-layout .offset__media {
    grid-column: 1/span 7;
  }
}
@media (max-width: 768px) {
  .confidence-layout .offset__media {
    aspect-ratio: 1/1;
  }
}

@media (min-width: 768px) {
  .confidence-layout .offset__content {
    grid-column: 8/span 4;
  }
}

/**
 * Service Trucks Page Specific Styles
 * Extracted from inline styles in page-service-trucks.php
 */
/* Intro Layout */
.trucks-intro-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

.intro-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
}

.intro-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.intro-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.intro-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .intro-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
/* Features Icons Section */
.service-trucks-features-icons {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
  text-align: center;
  margin: 4rem 0;
}

.service-trucks-feature-icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.service-trucks-feature-icon-wrapper {
  width: 120px;
  height: 120px;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.service-trucks-feature-icon-img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}

.service-trucks-feature-icon-title {
  font-size: 2rem !important;
  font-weight: 700 !important;
  color: #001489 !important;
  margin-bottom: 1rem !important;
  text-transform: uppercase !important;
}

.service-trucks-feature-icon-text {
  color: #666;
  line-height: 1.4;
  margin: 0;
}

@media (max-width: 768px) {
  .service-trucks-features-icons {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
/* Service Section - 3 Column Layout */
.service-trucks-service-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

@media (min-width: 768px) {
  .service-trucks-service-layout {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
  }
}
.service-trucks-service-content {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.service-trucks-service-image {
  position: relative;
  overflow: hidden;
  border-radius: 0.3125rem 0 6.25rem 0;
  aspect-ratio: 4/3;
}

.service-trucks-service-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Tank Specifications */
.service-trucks-specs-section {
  margin-bottom: 4rem;
}

.service-trucks-specs-section:last-child {
  margin-bottom: 0;
}

.service-trucks-specs-title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: white !important;
  margin-bottom: 2rem !important;
  text-transform: uppercase !important;
}

.service-trucks-specs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

@media (min-width: 768px) {
  .service-trucks-specs-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.service-trucks-spec-item {
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.service-trucks-spec-item:last-child {
  border-bottom: none;
}

@media (min-width: 768px) {
  .service-trucks-spec-item:nth-child(odd) {
    padding-right: 2rem;
  }
  .service-trucks-spec-item:nth-child(even) {
    padding-left: 2rem;
  }
  .service-trucks-spec-item:nth-last-child(2) {
    border-bottom: none;
  }
}
.spec-text {
  color: white;
  line-height: 1.6;
  font-size: 0.95rem;
}

/* Extras Section - Using offset layout from about page */
/* Video Section */
.service-trucks-video-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 768px) {
  .service-trucks-video-section {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.service-trucks-video-title {
  font-size: 2.5rem !important;
  color: #001489 !important;
  margin-bottom: 2rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.service-trucks-video-title p {
  margin: 0;
  color: #001489 !important;
  font-size: 2.5rem !important;
  line-height: 1.1 !important;
}

.service-trucks-video-title strong {
  font-weight: 700 !important;
}

.service-trucks-video-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 640px) {
  .service-trucks-video-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
.service-trucks-video-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.service-trucks-video-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.service-trucks-video-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

.service-trucks-video-player {
  position: relative;
}

.service-trucks-video-player .video {
  position: relative;
  border-radius: 0.5rem;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease;
  aspect-ratio: 16/9;
  display: block;
  text-decoration: none;
  width: 100%;
  height: 100%;
}

.service-trucks-video-player .video:hover {
  transform: scale(1.02);
}

.service-trucks-video-player .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  z-index: 5;
  pointer-events: none;
}

.service-trucks-video-player .video:hover .play {
  background: rgb(255, 255, 255);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.service-trucks-video-player .play__icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 16px;
}

.service-trucks-video-player .play__icon svg {
  width: 100%;
  height: 100%;
}

.service-trucks-video-player .play__icon path {
  fill: #001489;
}

.service-trucks-video-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/**
 * Water Trucks Page Specific Styles
 * Extracted from inline styles in page-water-trucks.php
 */
/* Offset Flipped Layout */
@media (min-width: 768px) {
  .offset--flipped {
    margin: 0;
    margin-left: 4.6667vw;
  }
}

@media (min-width: 768px) {
  .offset--flipped .offset__content {
    grid-column: 1/span 4;
  }
}

@media (min-width: 768px) {
  .offset--flipped .offset__media {
    grid-column: 6/-1;
    margin-right: calc(-50vw + 50%);
  }
}
.offset--flipped .offset__media {
  /* Flip the border radius to bottom left curve */
  border-radius: 0.3125rem 0 0 6.25rem;
  /* Reduce aspect ratio for shorter height */
  aspect-ratio: 16/9;
}
@media (min-width: 1024px) {
  .offset--flipped .offset__media {
    border-radius: 0.3125rem 0 0 12.5rem;
  }
}

/* Intro Layout */
.trucks-intro-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

.intro-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
}

.intro-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.intro-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.intro-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .intro-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
/* Intro Layout With Video - Two Column */
.trucks-intro-layout-with-video {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .trucks-intro-layout-with-video {
    grid-template-columns: 1fr 1.2fr;
    gap: 5rem;
  }
}

.trucks-intro-text-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.trucks-intro-video-column {
  position: relative;
}
.trucks-intro-video-column .video {
  position: relative;
  border-radius: 0.5rem;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease;
  aspect-ratio: 4/3;
  display: flex;
  text-decoration: none;
  width: 100%;
  line-height: 0;
}
.trucks-intro-video-column .video::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 2;
  transition: background 0.3s ease;
}
.trucks-intro-video-column .video:hover {
  transform: scale(1.02);
}
.trucks-intro-video-column .video:hover::before {
  background: rgba(0, 0, 0, 0.4);
}
.trucks-intro-video-column .video:hover .play {
  background: rgb(255, 255, 255);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}
.trucks-intro-video-column .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  z-index: 5;
  pointer-events: none;
}
.trucks-intro-video-column .play__icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 16px;
}
.trucks-intro-video-column .play__icon svg {
  width: 100%;
  height: 100%;
}
.trucks-intro-video-column .play__icon path {
  fill: #001489;
}
@media (max-width: 768px) {
  .trucks-intro-video-column .play__icon {
    width: 22px;
    height: 22px;
  }
}
.trucks-intro-video-column .water-trucks-video-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.trucks-intro-video-column .lazyload,
.trucks-intro-video-column .lazyloading {
  opacity: 0;
}
.trucks-intro-video-column .lazyloaded {
  opacity: 1;
  transition: opacity 0.3s;
}

/* Video Intro Section */
.trucks-video-intro-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .trucks-video-intro-layout {
    grid-template-columns: 1fr 1.2fr;
    gap: 5rem;
  }
}

.trucks-video-intro-content .video-intro-title {
  font-size: 2.5rem;
  color: #001489;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  line-height: 1.2;
  font-weight: 700;
}
@media (max-width: 768px) {
  .trucks-video-intro-content .video-intro-title {
    font-size: 1.8rem;
  }
}
.trucks-video-intro-content .video-intro-text {
  color: #666;
  line-height: 1.7;
  font-size: 1rem;
}
.trucks-video-intro-content .video-intro-text p {
  margin-bottom: 1rem;
}
.trucks-video-intro-content .video-intro-text p:last-child {
  margin-bottom: 0;
}

.trucks-video-intro-media {
  position: relative;
}
.trucks-video-intro-media .video-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.trucks-video-intro-media .video-wrapper:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.25);
}
.trucks-video-intro-media .video-wrapper:hover .play__icon {
  transform: scale(1.1);
  background: rgb(0, 20, 137);
}
.trucks-video-intro-media .video {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}
.trucks-video-intro-media .video-poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.trucks-video-intro-media .video-poster-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.trucks-video-intro-media .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.trucks-video-intro-media .play__icon {
  width: 80px;
  height: 80px;
  background: rgba(0, 20, 137, 0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.trucks-video-intro-media .play__icon svg {
  width: 28px;
  height: 28px;
  margin-left: 4px;
}
@media (max-width: 768px) {
  .trucks-video-intro-media .play__icon {
    width: 60px;
    height: 60px;
  }
  .trucks-video-intro-media .play__icon svg {
    width: 22px;
    height: 22px;
  }
}

/* Features Icons Section */
.water-trucks-features-icons {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
  text-align: center;
  margin: 4rem 0;
}

.water-trucks-feature-icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.water-trucks-feature-icon-wrapper {
  width: 120px;
  height: 120px;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.water-trucks-feature-icon-img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}

.water-trucks-feature-icon-title {
  font-size: 2rem !important;
  font-weight: 700 !important;
  color: #001489 !important;
  margin-bottom: 1rem !important;
  text-transform: uppercase !important;
}

.water-trucks-feature-icon-text {
  color: #666;
  line-height: 1.4;
  margin: 0;
}

@media (max-width: 768px) {
  .water-trucks-features-icons {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
/* Service Section - Using offset layout from who we deal with page */
/* Tank Specifications */
.water-trucks-specs-section {
  margin-bottom: 4rem;
}

.water-trucks-specs-section:last-child {
  margin-bottom: 0;
}

.water-trucks-specs-title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: white !important;
  margin-bottom: 2rem !important;
  text-transform: uppercase !important;
}

.water-trucks-specs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

@media (min-width: 768px) {
  .water-trucks-specs-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.water-trucks-spec-item {
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.water-trucks-spec-item:last-child {
  border-bottom: none;
}

@media (min-width: 768px) {
  .water-trucks-spec-item:nth-child(odd) {
    padding-right: 2rem;
  }
  .water-trucks-spec-item:nth-child(even) {
    padding-left: 2rem;
  }
  .water-trucks-spec-item:nth-last-child(2) {
    border-bottom: none;
  }
}
.spec-text {
  color: white;
  line-height: 1.6;
  font-size: 0.95rem;
}

/* Extras Section - Using offset layout from about page */
/* Video Section */
.water-trucks-video-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 768px) {
  .water-trucks-video-section {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.water-trucks-video-title {
  font-size: 2.5rem !important;
  color: #001489 !important;
  margin-bottom: 2rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.water-trucks-video-title p {
  margin: 0;
  color: #001489 !important;
  font-size: 2.5rem !important;
  line-height: 1.1 !important;
}

.water-trucks-video-title strong {
  font-weight: 700 !important;
}

.water-trucks-video-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 640px) {
  .water-trucks-video-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
.water-trucks-video-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.water-trucks-video-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.water-trucks-video-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

.trucks-intro-video-column .water-trucks-video-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  z-index: 1;
}

/* Global Section */
.water-trucks-global-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: center;
}

@media (min-width: 768px) {
  .water-trucks-global-layout {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.water-trucks-global-image {
  position: relative;
  overflow: hidden;
  border-radius: 0.3125rem 0 6.25rem 0;
  aspect-ratio: 4/3;
}
.water-trucks-global-image .splide--global-presence {
  width: 100%;
  height: 100%;
}
.water-trucks-global-image .splide--global-presence .splide__track {
  height: 100%;
}
.water-trucks-global-image .splide--global-presence .splide__list {
  height: 100%;
}
.water-trucks-global-image .splide--global-presence .splide__slide {
  height: 100%;
}

.water-trucks-global-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Gallery Slider - Used on both water trucks and service trucks pages */
.trucks-gallery-section {
  padding: clamp(3rem, 1.46vw + 2.66rem, 5rem) 0;
}

.trucks-gallery-splide {
  position: relative;
  padding: 0 4rem;
}
@media (max-width: 640px) {
  .trucks-gallery-splide {
    padding: 0 3rem;
  }
}
.trucks-gallery-splide .splide__track {
  overflow: hidden;
}
.trucks-gallery-splide .splide__list {
  align-items: stretch;
}
.trucks-gallery-splide .splide__slide {
  transition: opacity 0.3s ease;
  height: auto;
}

.trucks-gallery-slide-item {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: 0.75rem;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.05);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}
.trucks-gallery-slide-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
  background: rgba(255, 255, 255, 0.08);
}

.trucks-gallery-slide-link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  text-decoration: none;
  cursor: zoom-in;
}

.trucks-gallery-slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.trucks-gallery-slide-item:hover .trucks-gallery-slide-img {
  transform: scale(1.05);
}

/* Splide Navigation Arrows */
.trucks-gallery-splide .splide__arrow {
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  color: var(--color-blue);
  opacity: 1;
}
.trucks-gallery-splide .splide__arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.trucks-gallery-splide .splide__arrow svg {
  width: 20px;
  height: 20px;
}
.trucks-gallery-splide .splide__arrow--prev {
  left: 0;
}
.trucks-gallery-splide .splide__arrow--next {
  right: 0;
}
@media (max-width: 640px) {
  .trucks-gallery-splide .splide__arrow {
    width: 40px;
    height: 40px;
  }
  .trucks-gallery-splide .splide__arrow svg {
    width: 16px;
    height: 16px;
  }
}

/* Splide Pagination */
.trucks-gallery-splide .splide__pagination {
  bottom: -3rem;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}
@media (max-width: 640px) {
  .trucks-gallery-splide .splide__pagination {
    bottom: -2.5rem;
  }
}
.trucks-gallery-splide .splide__pagination__page {
  width: 12px;
  height: 12px;
  background: rgba(255, 255, 255, 0.4);
  border-radius: 50%;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.3s ease;
}
.trucks-gallery-splide .splide__pagination__page:hover {
  background: rgba(255, 255, 255, 0.7);
  transform: scale(1.2);
}
.trucks-gallery-splide .splide__pagination__page.is-active {
  background: var(--color-white);
  width: 32px;
  border-radius: 6px;
}

/**
 * Water & Service Trucks Page Specific Styles
 * Extracted from inline styles in page-water-service-trucks.php
 */
/* Intro Layout */
.trucks-intro-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

.about-intro-title {
  font-size: 3rem;
  color: #001489 !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  line-height: 1.1 !important;
}

.about-intro-title *,
.about-intro-title h1,
.about-intro-title h2,
.about-intro-title h3,
.about-intro-title h4,
.about-intro-title h5,
.about-intro-title h6,
.about-intro-title p {
  font-size: 3rem;
  color: #001489;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.1;
  margin: 0;
  padding: 0;
}

.about-intro-title strong {
  font-weight: 700 !important;
}

.intro-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
}

.intro-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #001489;
  border: 2px solid #001489;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.intro-btn:hover {
  background: #001489;
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 20, 137, 0.3);
}

.intro-btn svg {
  margin-left: 0.5rem;
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .intro-buttons {
    flex-direction: row;
    gap: 1.5rem;
  }
}
/* Video Section */
.video-section-title {
  font-size: 2.5rem !important;
  color: white !important;
  margin-bottom: 4rem !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-align: center !important;
}

.trucks-videos-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
  max-width: 1400px;
  margin: 0 auto;
}

.trucks-video-item {
  text-align: center;
}

.video {
  position: relative;
  margin-bottom: 2rem;
  border-radius: 0.5rem;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.video:hover {
  transform: scale(1.02);
}

/* Scope play button styles to this page's video sections only */
.trucks-video-item .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  z-index: 10;
}

.trucks-video-item .play:hover {
  background: rgb(255, 255, 255);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.trucks-video-item .play__icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 1rem;
}

.trucks-video-item .play__icon svg {
  width: 100%;
  height: 100%;
}

.trucks-video-item .play__icon path {
  fill: #001489;
}

.video-content {
  color: white;
}

.video-title {
  font-size: 1.5rem !important;
  color: white !important;
  margin-bottom: 1.5rem !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}

.trucks-video-button {
  margin-top: 1.5rem;
}

.trucks-video-btn {
  background: transparent;
  color: white;
  border: 2px solid white;
  padding: 1rem 2rem;
  font-weight: 600;
  text-transform: uppercase;
  transition: all 0.3s ease;
  text-decoration: none;
  display: inline-block;
}

.trucks-video-btn:hover {
  background: white;
  color: #001489;
}

@media (max-width: 768px) {
  .video-section-title {
    font-size: 2rem !important;
    margin-bottom: 3rem !important;
  }
  .trucks-videos-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}
/* Features Section */
.trucks-features {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.trucks-feature-item {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: 2rem 0;
  border-bottom: 1px solid #e5e5e5;
}

.trucks-feature-item:first-child {
  border-top: 1px solid #e5e5e5;
}

.trucks-feature-icon {
  flex-shrink: 0;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.feature-icon-img {
  max-width: 100%;
  height: auto;
}

.trucks-feature-title {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: #001489 !important;
  margin-bottom: 1rem !important;
  text-transform: uppercase !important;
}

.trucks-feature-text {
  color: #666;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .trucks-feature-item {
    flex-direction: column;
    text-align: center;
    gap: 1rem;
  }
}
/* Custom Builds Section */
.custom-builds-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: center;
}

@media (min-width: 768px) {
  .custom-builds-layout {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}
.custom-builds-image {
  position: relative;
  overflow: hidden;
  border-radius: 0.3125rem 0 0 6.25rem;
  aspect-ratio: 4/3;
}

.custom-builds-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.custom-button-wrap {
  margin-top: 2rem;
}

/**
 * Page Who We Deal With Specific Styles
 * Extracted from inline styles in page-who-we-deal-with.php
 */
@media (min-width: 768px) {
  .offset--flipped {
    margin: 0;
    margin-left: 4.6667vw;
  }
}

@media (min-width: 768px) {
  .offset--flipped .offset__content {
    grid-column: 1/span 4;
  }
}

@media (min-width: 768px) {
  .offset--flipped .offset__media {
    grid-column: 6/-1;
    margin-right: calc(-50vw + 50%);
  }
}
.offset--flipped .offset__media {
  /* Flip the border radius to bottom left curve */
  border-radius: 0.3125rem 0 0 6.25rem;
  /* Reduce aspect ratio for shorter height */
  aspect-ratio: 16/9;
}
@media (min-width: 1024px) {
  .offset--flipped .offset__media {
    border-radius: 0.3125rem 0 0 12.5rem;
  }
}

/*--------------------------------------------------------------
# 07 - Utilities
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/
/**
* Colours
*/
.bg-red {
  background-color: var(--color-blue);
}

.text-red {
  color: var(--color-blue);
}

.bg-black {
  background-color: var(--color-black);
}

.text-black {
  color: var(--color-black);
}

.bg-dark-grey {
  background-color: var(--color-dark-grey);
}

.text-dark-grey {
  color: var(--color-dark-grey);
}

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

.text-grey {
  color: var(--color-grey);
}

.bg-light-grey {
  background-color: var(--color-light-grey);
}

.text-light-grey {
  color: var(--color-light-grey);
}

.bg-lightest-grey {
  background-color: var(--color-lightest-grey);
}

.text-lightest-grey {
  color: var(--color-lightest-grey);
}

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

.text-white {
  color: var(--color-white);
}

/**
* Flow
*/
.flow-xs > * + * {
  margin-top: clamp(0.13rem, 0.09vw + 0.1rem, 0.25rem);
}

.flow-sm > * + * {
  margin-top: clamp(0.5rem, 0.27vw + 0.44rem, 0.88rem);
}

.flow-md > * + * {
  margin-top: clamp(0.5rem, 0.82vw + 0.31rem, 1.63rem);
}

.flow-lg > * + * {
  margin-top: clamp(1rem, 1.1vw + 0.75rem, 2.5rem);
}

.flow-xl > * + * {
  margin-top: clamp(1.93rem, 1.52vw + 1.57rem, 4rem);
}

.flow-xxl > * + * {
  margin-top: clamp(1.93rem, 2.25vw + 1.41rem, 5rem);
}

/**
* Text
*/
.text-center {
  text-align: center;
}

.text-bold {
  font-weight: 700;
}

.text-semibold {
  font-weight: 600;
}

.text-normal {
  font-weight: 400;
}

.text-uppercase {
  text-transform: uppercase;
}

.text-capitalize {
  text-transform: capitalize;
}

.text-underline {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.text-no-underline {
  text-decoration: none !important;
}

.font-mono {
  font-family: var(--font-mono);
}

/**
* Overflow
*/
.overflow-hidden {
  overflow: hidden;
}

/**
* Accessibility
*/
.sr-only {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  width: 1px;
  height: 1px;
  overflow: hidden;
  padding: 0;
  border: 0;
  white-space: nowrap;
}

/**
* Shadows
*/
.shadow-sm {
  box-shadow: var(--shadow-sm);
}

.shadow {
  box-shadow: var(--shadow);
}

.shadow-lg {
  box-shadow: var(--shadow-lg);
}

/**
* Hide
*/
.hide,
.is-hidden {
  display: none;
}

.hide-mobile {
  display: none;
}
@media (min-width: 768px) {
  .hide-mobile {
    display: block;
  }
}

.hide-desktop {
  display: block;
}
@media (min-width: 768px) {
  .hide-desktop {
    display: none;
  }
}

/**
* Lazy Load
*/
.lazyload,
.lazyloading {
  opacity: 0;
}

.lazyloaded {
  opacity: 1;
  transition-duration: 0.6s;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
}

/**
* Overlay
*/
.overlay {
  background-color: var(--color-white);
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden;
  height: 100%;
  width: 100%;
  z-index: 90;
}

/**
* Transitions
*/
[data-animate=stagger] > * {
  visibility: hidden;
}

/**
* Sticky Section
*/
[data-animate=fade] {
  opacity: 0.3;
  transition: 0.8s var(--ease-out);
}
[data-animate=fade].active {
  opacity: 1;
}

/*# sourceMappingURL=style.css.map */
