/*!
Theme Name: VOCA Fire Protection
Theme URI: http://underscores.me/
Author: DISRUPT. Search Studios
Author URI: https://www.disruptsearchstudios.com/
Description: A custom WordPress theme for VOCA Fire Protection.
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: voca-fire-protection
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

VOCA Fire Protection is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

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

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! 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;
  -webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
  font-family: "Inter" !important;
}

@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v18/UcCm3FwrK3iLTcvnUwkT9mI1F55MKw.woff2) format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
  /**
 * 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;
  height: 0;
  overflow: visible;
}

/**
 * 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;
  font-size: 1em;
}

/* 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;
  text-decoration: underline;
  text-decoration: underline dotted;
}

/**
 * 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;
  font-size: 1em;
}

/**
 * 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;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

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

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  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;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

/**
 * 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;
  padding: 0;
}

/**
 * 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;
  outline-offset: -2px;
}

/**
 * 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;
  font: inherit;
}

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

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
  box-sizing: inherit;
}

html {
  box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
  color: #404040;
  font-family:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    Oxygen-Sans,
    Ubuntu,
    Cantarell,
    "Helvetica Neue",
    sans-serif;
  font-size: 18px !important;
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  clear: both;
}

p {
  margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
  font-style: italic;
}

blockquote {
  margin: 0 1.5em;
}

address {
  margin: 0 0 1.5em;
}

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", courier, monospace;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em;
}

code,
kbd,
tt,
var {
  font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

mark,
ins {
  background: #fff9c0;
  text-decoration: none;
}

big {
  font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
  background: #fff;
}

hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin-bottom: 1.5em;
}

ul,
ol {
  margin: 0 0 1.5em 3em;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

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

dt {
  font-weight: 700;
}

dd {
  margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

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

figure {
  margin: 1em 0;
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

/* Links
--------------------------------------------- */
a {
  color: #4169e1;
  text-underline-offset: 3.5px !important;
}

a:hover,
a:focus,
a:active {
  color: #191970;
}

a:focus {
  outline: thin dotted;
}

a:hover,
a:active {
  outline: 0;
}

/* Forms
--------------------------------------------- */
input[type="checkbox"] {
  margin-right: 8px !important;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  border: 1px solid;
  border-color: #ccc #ccc #bbb;
  border-radius: 3px;
  background: #e6e6e6;
  color: rgba(0, 0, 0, 0.8);
  line-height: 1;
  padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
  border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
  border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
  color: #666;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
  color: #111;
}

select {
  border: 1px solid #ccc;
}

textarea {
  width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
  display: block;
  width: 100%;
}

.main-navigation ul {
  display: none;
  list-style: none;
  margin: 0;
  padding-left: 0;
}

.main-navigation ul ul {
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  float: left;
  position: absolute;
  top: 100%;
  left: -999em;
  z-index: 99999;
}

.main-navigation ul ul ul {
  left: -999em;
  top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
  display: block;
  left: auto;
}

.main-navigation ul ul a {
  width: 200px;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
  left: auto;
}

.main-navigation li {
  position: relative;
}

.main-navigation a {
  display: block;
  text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
  display: block;
}

@media screen and (min-width: 37.5em) {
  .menu-toggle {
    display: none;
  }

  .main-navigation ul {
    display: flex;
  }
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
  margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
  display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
  flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
  text-align: end;
  flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
  display: block;
}

.updated:not(.published) {
  display: none;
}

.page-content,
.entry-content,
.entry-summary {
  margin: 1.5em 0 0;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
  word-wrap: break-word;
}

.bypostauthor {
  display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
  margin: 0 0 1.5em;
}

.widget select {
  max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
  display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
  margin-bottom: 1.5em;
  max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption .wp-caption-text {
  margin: 0.8075em 0;
}

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

/* Galleries
--------------------------------------------- */
.gallery {
  margin-bottom: 1.5em;
  display: grid;
  grid-gap: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  width: 100%;
}

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

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

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

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

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

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

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

.gallery-columns-9 {
  grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
  display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: #21759b;
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
  outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {
  /*rtl:ignore*/
  float: left;

  /*rtl:ignore*/
  margin-right: 1.5em;
  margin-bottom: 1.5em;
}

.alignright {
  /*rtl:ignore*/
  float: right;

  /*rtl:ignore*/
  margin-left: 1.5em;
  margin-bottom: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.5em;
}

/* New Global Styling */

/* Header Sizes */

.header-88 {
  font-size: 88px;
}

.header-80 {
  font-size: 88px;
}

.header-78 {
  font-size: 78px;
}

.header-77 {
  font-size: 77px;
}

.header-74 {
  font-size: 74px;
}

.header-66 {
  font-size: 66px;
}
.header-62 {
  font-size: 62px;
}
.header-58 {
  font-size: 58px;
}
.header-55 {
  font-size: 55px;
}
.header-52 {
  font-size: 52px;
}
.header-50 {
  font-size: 50px;
}
.header-48 {
  font-size: 48px;
}
.header-46 {
  font-size: 46px;
}
.header-44 {
  font-size: 44px;
}

.header-40 {
  font-size: 44px;
}

.header-38 {
  font-size: 38px;
}
.header-36 {
  font-size: 36px;
}

.header-33 {
  font-size: 33px;
}

.header-30 {
  font-size: 30px;
}

.header-28 {
  font-size: 28px;
}

.header-25 {
  font-size: 25px;
}

.header-24 {
  font-size: 24px;
}

.header-22 {
  font-size: 22px;
}
.header-20 {
  font-size: 20px;
}
.header-18 {
  font-size: 18px;
}
.header-16 {
  font-size: 16px;
}
@media (max-width: 768px) {
  .mob-header-55 {
    font-size: 55px;
  }
  .mob-header-45 {
    font-size: 45px;
  }
  .mob-header-42 {
    font-size: 42px;
  }
  .mob-header-40 {
    font-size: 40px;
  }

  .mob-header-38 {
    font-size: 38px;
  }

  .mob-header-35 {
    font-size: 35px;
  }
  .mob-header-32 {
    font-size: 32px;
  }

  .mob-header-30 {
    font-size: 30px;
  }
  .mob-header-28 {
    font-size: 28px;
  }

  .mob-header-25 {
    font-size: 25px;
  }
  .mob-header-24 {
    font-size: 24px;
  }

  .mob-header-44 {
    font-size: 44px;
  }

  .mob-header-33 {
    font-size: 33px;
  }

  .mob-header-22 {
    font-size: 22px;
  }

  .mob-header-20 {
    font-size: 20px;
  }

  .mob-header-18 {
    font-size: 18px;
  }

  .mob-header-16 {
    font-size: 16px;
  }

  .mob-header-15 {
    font-size: 15px;
  }

  .mob-header-14 {
    font-size: 14px;
  }
  .mob-header-8 {
    font-size: 8px;
  }
}

.lh-140 {
  line-height: 140%;
}
.lh-130 {
  line-height: 130%;
}
.lh-120 {
  line-height: 120%;
}
.lh-110 {
  line-height: 110%;
}
.lh-100 {
  line-height: 100%;
}
.font-size-14 {
  font-size: 14px;
}
.megamenu-link {
  font-size: 17px !important;
}
.fw-550 {
  font-weight: 550 !important;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700 !important;
  font-family:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    Oxygen-Sans,
    Ubuntu,
    Cantarell,
    "Helvetica Neue",
    sans-serif;
}

/* Padding top and bottom 95px */

.py-95 {
  padding-top: 5.938rem;
  padding-bottom: 5.938rem;
}
.pb-95 {
  padding-bottom: 5.938rem;
}
.p-95 {
  padding: 5.938rem;
}
.px-95 {
  padding-left: 5.938rem;
  padding-right: 5.938rem;
}
@media (min-width: 576px) {
  .py-sm-95 {
    padding-top: 5.938rem !important;
    padding-bottom: 5.938rem !important;
  }
  .p-sm-95 {
    padding: 5.938rem;
  }
}
@media (min-width: 768px) {
  .py-md-95 {
    padding-top: 5.938rem !important;
    padding-bottom: 5.938rem !important;
  }
  .p-md-95 {
    padding: 5.938rem;
  }
}
@media (min-width: 992px) {
  .py-lg-95 {
    padding-top: 5.938rem !important;
    padding-bottom: 5.938rem !important;
  }
  .top-lg-50 {
    top: 50% !important;
  }
  .position-lg-absolute {
    position: absolute;
  }
  .h-lg-80 {
    height: 80% !important;
  }
  .py-lg-72 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .pb-lg-72 {
    padding-bottom: 4.5rem !important;
  }
  .pt-lg-72 {
    padding-top: 4.5rem !important;
  }
  .p-lg-95 {
    padding: 5.938rem !important;
  }
  .p-lg-72 {
    padding: 4.5rem;
  }
  .pb-lg-52 {
    padding-bottom: 3.25rem !important;
  }
  .mb-lg-4-5 {
    margin-bottom: 2rem !important;
  }
  .mb-lg-52 {
    margin-bottom: 52px !important;
  }
  .pb-lg-95 {
    padding-bottom: 5.938rem !important;
  }
}
@media (min-width: 1200px) {
  .py-xl-95 {
    padding-top: 5.938rem !important;
    padding-bottom: 5.938rem !important;
  }
  .p-xl-95 {
    padding: 5.938rem;
  }
}
@media (min-width: 1400px) {
  .py-xxl-95 {
    padding-top: 5.938rem !important;
    padding-bottom: 5.938rem !important;
  }
}

.pt-95 {
  padding-top: 5.938rem;
}
@media (min-width: 576px) {
  .pt-sm-95 {
    padding-top: 5.938rem !important;
  }
}
@media (min-width: 768px) {
  .pt-md-95 {
    padding-top: 5.938rem !important;
  }
}
@media (min-width: 992px) {
  .pt-lg-95 {
    padding-top: 5.938rem !important;
  }
}
@media (min-width: 1200px) {
  .pt-xl-95 {
    padding-top: 5.938rem !important;
  }
}
@media (min-width: 1400px) {
  .pt-xxl-95 {
    padding-top: 5.938rem !important;
  }
}

.pt-190 {
  padding-top: 11.875rem;
}
.pt-280 {
  padding-top: 280px;
}
@media (min-width: 576px) {
  .pt-sm-190 {
    padding-top: 11.875rem !important;
  }
}
@media (min-width: 768px) {
  .pt-md-190 {
    padding-top: 11.875rem !important;
  }
}
@media (min-width: 992px) {
  .pt-lg-190 {
    padding-top: 11.875rem !important;
  }
}
@media (min-width: 1200px) {
  .pt-xl-190 {
    padding-top: 11.875rem !important;
  }
}
@media (min-width: 1400px) {
  .pt-xxl-190 {
    padding-top: 11.875rem !important;
  }
}

.button-black {
  background-color: #000 !important;
  color: #fff !important;
  padding: 12px 32px 12px 32px !important;
  text-decoration: none;
  font-weight: 600;
}
.button-white {
  background-color: #fff;
  color: #000 !important;
  padding: 12px 20px 12px 20px;
  text-decoration: none;
  font-weight: 600;
}
.button-white:hover {
  background-color: #ffffffd6;
  color: #000 !important;
  text-decoration: none;
  font-weight: 600;
  transition: 0.5s all;
}
.contact-us-header {
  background-color: #fff;
  color: #000 !important;
  padding: 12px 20px 12px 20px;
  text-decoration: none;
  font-weight: 600;
}
@media (max-width: 767px) {
  .contact-us-header {
    background-color: #d0e3ff;
    color: #000000 !important;
    padding: 12px 20px 12px 20px;
    text-decoration: none;
    font-weight: 600;
  }
}
.button-purple {
  background-color: #004dd2;
  color: #ffffff !important;
  padding: 16px 32px 16px 32px;
  text-decoration: none;
  font-weight: 600;
}
.button-blue {
  background-color: #d0e3ff !important;
  color: #000 !important;
  padding: 16px 32px 16px 32px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  border: none !important;
}
.button-blue:hover {
  background-color: #bed8ff !important;
  color: #000 !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  border: none !important;
  transition: 0.5s all;
}
.bg-mblue {
  background-color: #d0e3ff;
}
.bg-voca {
  background-image: url(/wp-content/uploads/2025/02/top-banner-V4@3x-scaled.webp);
  background-repeat: no-repeat; /* Do not repeat the image */
  background-size: cover; /* Resize the background image to cover the entire container */
  background-position: center;
}
.bg-vocagroup {
  background-image: url(/wp-content/uploads/2026/04/The-VOCA-Group-bg.webp);
  background-repeat: no-repeat; /* Do not repeat the image */
  background-size: cover; /* Resize the background image to cover the entire container */
  background-position: center;
}
.text-gradient-voca {
  background: linear-gradient(90deg, #0d6efd 0%, #000a1a 100%);
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
}

.text-orange {
  color: #fea500;
}
.text-purple-20 {
  color: #004dd2 !important;
}
.text-grey-02 {
  color: #78787d;
}
.bg-grey-01 {
  background-color: #f0f0f0;
}
.bg-grey-03 {
  background-color: #f6f6f6;
}

.bg-grey-00 {
  background-color: #f9f9f9;
}
.text-grey {
  color: #6a6a6a;
}
.border-shadow {
  box-shadow: 0px 0px 20px 0px #a0c6ff inset;
  border-radius: 48px;
}
.bg-blue-purple {
  background-color: #a0c6ff;
}
.text-lblue {
  color: #a0c6ff;
}
.text-lblue:hover {
  color: #a0c6ff;
}
.prev-1 {
  padding: 16px 32px 16px 32px;
  background-color: transparent;
  border: none;
  font-weight: 600;
  font-size: 24px !important;
  border-bottom: solid 2px #6a6a6a;
  color: #6a6a6a;
}
.next-1 {
  padding: 16px 32px 16px 32px;
  background-color: transparent;
  border: none;
  font-weight: 600;
  font-size: 24px !important;
  border-bottom: solid 2px #6a6a6a;
  color: #6a6a6a;
}
.swiper-button-disabled.next-1 {
  background: linear-gradient(270deg, #0d6efd 0%, #003992 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  border-image: linear-gradient(270deg, #0d6efd 0%, #003992 100%) !important;
  border-style: solid !important;
  border-width: 2px !important;
  border-image-slice: 1 !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.swiper-button-disabled.prev-1 {
  background: linear-gradient(270deg, #0d6efd 0%, #003992 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  border-image: linear-gradient(270deg, #0d6efd 0%, #003992 100%) !important;
  border-style: solid !important;
  border-width: 2px !important;
  border-image-slice: 1 !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.border-bottom-gradient {
  border-image: linear-gradient(270deg, #0d6efd 0%, #003992 100%) !important;
  border-style: solid !important;
  border-width: 2px !important;
  border-image-slice: 1 !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.prev-1:hover {
  padding: 16px 32px 16px 32px;
  background-color: transparent;
  border: none;
  font-weight: 600;
  font-size: 24px !important;
  border-bottom: solid 2px #6a6a6a;
}
.next-1:hover {
  padding: 16px 32px 16px 32px;
  background-color: transparent;
  border: none;
  font-weight: 600;
  font-size: 24px !important;
  border-bottom: solid 2px #6a6a6a;
}

.prev-2 {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.next-2 {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.prev-2:hover {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.next-2:hover {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.prev-2.swiper-button-disabled {
  opacity: 0.2;
  background-color: #e1e1e1;
}
.next-2.swiper-button-disabled {
  opacity: 0.2;
  background-color: #e1e1e1;
}

.prev-2-square {
  width: 58px;
  height: 58px;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.next-2-square {
  width: 58px;
  height: 58px;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.prev-2-square:hover {
  width: 58px;
  height: 58px;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.next-2-square:hover {
  width: 58px;
  height: 58px;
  background-color: #e1e1e1;
  border: none;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.prev-2-square.swiper-button-disabled {
  opacity: 0.2;
  background-color: #e1e1e1;
}
.next-2-square.swiper-button-disabled {
  opacity: 0.2;
  background-color: #e1e1e1;
}
@media (max-width: 767px) {
  .prev-1 {
    font-size: 18px !important;
  }
  .next-1 {
    font-size: 18px !important;
  }
  .prev-1:hover {
    font-size: 18px !important;
  }
  .next-1:hover {
    font-size: 18px !important;
  }
  .swiper-button-disabled.next-1 {
    color: #000000 !important;
    border-bottom: solid 2px #000000 !important;
    font-size: 18px !important;
  }
  .swiper-button-disabled.prev-1 {
    border-bottom: solid 2px #000000 !important;
    font-size: 18px !important;
    color: #000000 !important;
  }
  .swiper-button-disabled.next-1:hover {
    font-size: 18px !important;
  }
  .swiper-button-disabled.prev-1:hover {
    font-size: 18px !important;
  }
}
.footer-link {
  color: #ffffff;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  text-decoration: none;
}
.footer-link:hover {
  color: #ffffff;
  font-weight: 400;
  line-height: 140%; /* 25.2px */
  text-decoration: none;
}
.header-border-bg {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.vw-50 {
  width: 50vw;
}
@media (min-width: 1100px) and (max-width: 1300px) {
  .image-cut-off {
    left: -150px;
  }
  .image-cut-off-2 {
    left: -20px;
  }
}
@media (max-width: 767px) {
  .left-minus-20-mobile {
    left: -20px;
  }
}
/* Mega Menu CSS */

/* ============ Desktop view ============ */
@media (min-width: 992px) {
  .navbar-toggler {
    display: none;
  }
  .navbar-collapse {
    display: flex !important;
  }
  .nav-item.d-md-block,
  .nav-link.d-md-block {
    display: block !important;
  }
  .navbar .has-megamenu {
    position: static !important;
  }
  .navbar .megamenu {
    left: 0;
    top: 83%;
    right: 0;
    width: 100%;
    margin-top: 5px;
  }
  .navbar .megamenu .inner-container {
    width: 90%;
    margin: auto;
  }

  .dropdown:hover .dropdown-menu {
    opacity: 1;
    display: block; /* Show on hover */
  }
}

/* Mobile specific menu handling */
@media (max-width: 992px) {
  .dropdown-menu {
    background-color: black !important;
    display: none; /* Hide initially for mobile */
  }

  .navbar.fixed-top .navbar-collapse,
  .navbar.sticky-top .navbar-collapse {
    overflow-y: auto;
    max-height: 90vh;
    margin-top: 10px;
  }
}

/* General Styling */
.navbar .megamenu {
  padding: 1rem;
}

.nav-link {
  color: #bfbbbb;
  font-size: 17px;
  padding-right: 26px !important;
}

.nav-link:hover,
.nav-link:active {
  color: #ffffff;
  text-decoration: none !important;
}

.navbar-brand img {
  height: 34px;
  width: auto;
}

.my-custom-toggler,
.my-custom-toggler:hover,
.my-custom-toggler:active {
  background-image: none !important;
  background-color: transparent !important;
  border: none !important;
}

.custom-padding-mobile-men li.nav-item {
  padding-top: 10px;
  padding-bottom: 10px;
}

.navbar-nav {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}

@media (max-width: 1199px) {
  .navbar .container {
    max-width: 1200px;
    padding-left: 0;
    padding-right: 0;
  }

  .navbar .row {
    margin-left: 0;
    margin-right: 0;
  }

  .nav-link {
    color: #bfbbbb;
    font-size: 17px;
    padding-right: 10px !important;
  }
}

@media (min-width: 768px) and (max-width: 1200px) {
  .mega-logo {
    margin-left: 10px;
    margin-right: 30px;
  }
  .navbar .container {
    max-width: 1200px;
    padding-left: 0;
    padding-right: 0;
  }
  .navbar .row {
    margin-left: 0;
    margin-right: 0;
  }
  .nav-link {
    color: #bfbbbb;
    font-size: 17px;
    padding-right: 10px !important;
  }
}

/* For large desktops (width greater than 1100px) */
@media (min-width: 1600px) {
  .navbar .megamenu .inner-container {
    width: 60%;
    margin: auto;
  }
}

/* For screens 1400px and below */
@media (max-width: 1599px) {
  .navbar .megamenu .inner-container {
    width: 80%;
    margin: auto;
  }
}

.dropdown-menu[data-bs-popper] {
  top: 75%;
  left: 0;
  margin-top: var(--bs-dropdown-spacer);
}

.navbar-dark .navbar-nav .nav-link.dropdown-toggle:focus,
.navbar-dark .navbar-nav .nav-link.dropdown-toggle:hover {
  outline: none;
  border-radius: 0px;
}

.dropdown-menu {
  border: none;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1); /* Optional: This adds a subtle shadow instead of a border */
}

.navbar-brand img {
  height: 34px; /* Adjust this height value as necessary */
  width: auto;
}

/* Override the styles */
.my-custom-toggler,
.my-custom-toggler:hover,
.my-custom-toggler:active {
  background-image: none !important;
  background-color: transparent !important;
}

/* You may also want to remove any borders */
.my-custom-toggler {
  border: none !important;
}

.nav-link:hover {
  color: #ffffff;
}

.nav-link:active {
  color: #ffffff;
  text-decoration: none !important;
}

.custom-padding-mobile-men li.nav-item {
  padding-top: 10px;
  padding-bottom: 10px;
}

.navbar-nav {
  --bs-nav-link-padding-x: 0;
  --bs-nav-link-padding-y: 0rem;
  --bs-nav-link-font-weight: ;
  --bs-nav-link-color: var(--bs-navbar-color);
  --bs-nav-link-hover-color: var(--bs-navbar-hover-color);
  --bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}

.navbar-brand.mega-logo {
  position: relative; /* To make z-index take effect */
}

@media (max-width: 992px) {
  .dropdown-menu {
    background-color: black !important;
  }
}

@media (max-width: 1199px) {
  .navbar.fixed-top .navbar-collapse,
  .navbar.sticky-top .navbar-collapse {
    overflow-y: auto;
    max-height: 90vh;
    margin-top: 10px;
  }
}

/* Case Study Box Clients */
.case-study-box-clients {
  background-color: #f7f7f7;
  overflow: hidden;
  display: flex;
  align-items: center;
  position: relative;
  transition:
    background-color 0.3s,
    box-shadow 0.3s;
  height: 100%;
  flex-wrap: nowrap;
  padding: 0px;
}
.case-study-box-clients::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s;
  z-index: 1;
}
.case-study-box-clients:hover::before {
  background-color: rgba(0, 0, 0, 0.1);
}

.case-study-box-clients:hover {
  background-color: #e2e2e2;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}
.case-study-content-clients {
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  position: relative;
  z-index: 2;
}
.case-study-title-clients {
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 10px;
  color: #333;
}
.case-study-description-clients {
  font-size: 16px;
  color: #333;
}
.case-study-image-container-clients {
  display: flex;
  justify-content: center;
  width: 40%;
  height: 100%;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
.case-study-image-clients {
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: 0px;
}

/* Case Study Item */
.case-study-item {
  position: relative;
  width: 100%;
  height: 350px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-sizing: border-box;
}
.case-study-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  z-index: 1;
}
.case-study-content {
  position: relative;
  text-align: center;
  color: white;
  z-index: 2;
  padding: 20px;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.case-study-title {
  font-size: 1.5rem !important;
  margin-bottom: 10px;
  font-weight: bold;
}
.case-study-description {
  font-size: 1rem;
  margin-bottom: 15px;
}

.custom-button-case-mega {
  background-color: #1f71ff;
  color: #fff;
  padding: 15px 25px;
  cursor: pointer;
  font-weight: bold;
  font-size: 14px;
  border-radius: 0px;
  transition:
    background-color 0.3s,
    color 0.3s;
  margin-top: 10px;
  float: right;
}

.custom-button-case-mega:hover {
  background-color: #2d2b94;
  color: #fff;
}

.custom-button-case {
  background-color: transparent;
  border: 2px solid #ffffff;
  color: #ffffff;
  padding: 8px 20px;
  cursor: pointer;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 14px;
  border-radius: 0px;
  transition:
    background-color 0.3s,
    color 0.3s;
  margin-top: 10px;
  align-self: center;
}
.custom-button-case:hover {
  background-color: #ffffff;
  color: #1b2032;
}

/* Latest Case Study Box */
.latest-case-study-box {
  background-color: #f7f7f7;
  display: flex;
  flex-direction: column;
  padding: 20px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  transition:
    background-color 0.3s,
    box-shadow 0.3s;
  position: relative;
  overflow: hidden;
  text-decoration: none;
}
.latest-case-study-box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s;
  z-index: 1;
}
.latest-case-study-box:hover::before {
  background-color: rgba(0, 0, 0, 0.1);
}
.latest-case-study-box:hover {
  background-color: #e2e2e2;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}
.latest-case-study-image {
  width: 100%;
  height: auto;
  overflow: hidden;
  margin-bottom: 20px;
}
.latest-case-study-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}
.latest-case-study-content {
  display: flex;
  flex-direction: column;
}
.latest-case-study-title {
  font-size: 24px;
  font-weight: bold;
  color: #333;
  margin: 0 0 10px;
}
.latest-case-study-description {
  font-size: 16px;
  color: #666;
  margin-bottom: 20px;
}
.latest-case-study-link {
  font-size: 16px;
  color: #007bff;
  text-decoration: underline;
  align-self: flex-start;
}
.latest-case-study-link:hover {
  color: #0056b3;
}
/* Color Classes */
.vocablue {
  color: #1f71ff !important;
}

.vocagrey {
  color: #686868 !important;
}

.vocared {
  color: #c9001e !important;
}

.vocagreen {
  color: #00ae31 !important;
}

.vocaorange {
  color: #ff7a00 !important;
}

/* Mega Menu Services */
.mega-menu-services,
.mega-menu-services-small {
  background-color: #f7f7f7;
  margin: 10px;
  padding: 20px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  transition:
    background-color 0.3s,
    box-shadow 0.3s;
  position: relative;
  overflow: hidden;
}
.mega-menu-services {
  min-height: 230px;
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.mega-menu-services-small {
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: start;
}
.mega-menu-services::before,
.mega-menu-services-small::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s;
  z-index: 1;
}
.mega-menu-services:hover::before,
.mega-menu-services-small:hover::before {
  background-color: rgba(0, 0, 0, 0.1);
}
.mega-menu-services:hover,
.mega-menu-services-small:hover {
  background-color: #e2e2e2;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}
.bg-black {
  background-color: #000;
}
.bg-dblue {
  background-color: #004dd2;
}
.bg-top-banner {
  background: rgba(0, 77, 210, 0.7);
}
.top-header-bg {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.1) 0%, rgb(40 92 208 / 0%) 100%),
    linear-gradient(270deg, #3376da 0%, #0d6efd 40%, #003992 80%) 80%;
}
.new-text-gradient-voca {
  background: linear-gradient(270deg, #0d6efd 0%, #003992 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  padding-bottom: 3px;
}

.dynamic-background {
  position: relative;
  width: 100%;
  height: 500px;
  background-size: auto 100%;
  background-position: top right;
  background-repeat: no-repeat;
  background-color: #003992;
  overflow: hidden;
  margin: 0 auto;
}

@media (min-width: 769px) and (max-width: 1150px) {
  .dynamic-background {
    height: 500px;
    background-size: auto 100%;
    background-position: center right;
  }
}

@media (max-width: 768px) {
  .dynamic-background {
    height: 550px !important;
    background-size: cover !important;
    background-position: left center !important;
  }
}

.top-bg-header {
  position: relative;
  width: 100%;
  height: 500px;
  background-size: auto 100%;
  background-position: top right;
  background-repeat: no-repeat;
  background-color: #003992;
  overflow: hidden;
  margin: 0 auto;
}

@media (min-width: 769px) and (max-width: 1150px) {
  .top-bg-header {
    height: 600px;
    background-size: auto 100%;
    background-position: center right;
  }
}

@media (max-width: 768px) {
  .top-bg-header {
    height: 600px;
    background-size: cover !important;
    background-position: left center !important;
  }
}

.me-52 {
  margin-right: 52px;
}
.pe-26 {
  padding-right: 26px;
}
.pe-52 {
  padding-right: 52px;
}
.ps-52 {
  padding-left: 52px;
}
.ps-52-imp {
  padding-left: 52px !important;
}
.pe-190 {
  padding-right: 190px;
}
.pe-190-imp {
  padding-right: 190px !important;
}
.ps-26 {
  padding-left: 26px;
}
@media (max-width: 767px) {
  .pe-26 {
    padding-right: 0px !important;
  }
  .ps-26 {
    padding-left: 0px !important;
  }
}
.p-4-5 {
  padding: 2rem;
}
.pb-4-5,
.py-4-5 {
  padding-bottom: 2rem !important;
}
.pt-4-5 {
  padding-top: 2rem;
}
.py-4-5 {
  padding-top: 2rem !important;
}
.pb-52,
.py-52 {
  padding-bottom: 3.25rem;
}
.p-52 {
  padding: 3.25rem;
}
.pt-52,
.py-52 {
  padding-top: 3.25rem;
}
.pe-4-5 {
  padding-right: 2rem !important;
}
.ps-4-5 {
  padding-left: 2rem !important;
}
.pt-72,
.py-72 {
  padding-top: 4.5rem !important;
}
.p-72 {
  padding: 4.5rem;
}
.pb-72,
.py-72 {
  padding-bottom: 4.5rem !important;
}
.px-52 {
  padding-left: 3.25rem;
  padding-right: 3.25rem;
}
.pb-20,
.py-20 {
  padding-bottom: 1.25rem !important;
}
.mb-4-5 {
  margin-bottom: 2rem !important;
}

.mt-4-5 {
  margin-top: 2rem !important;
}

.mb-52 {
  margin-bottom: 52px !important;
}
.mb-20,
.my-20 {
  margin-bottom: 1.25rem !important;
}
.py-20 {
  padding-top: 1.25rem !important;
}
@media (min-width: 576px) {
  .p-sm-4-5 {
    padding: 2rem !important;
  }
  .pb-sm-4-5 {
    padding-bottom: 2rem !important;
  }
  .pt-sm-4-5 {
    padding-top: 2rem !important;
  }
  .py-sm-4-5 {
    padding-bottom: 2rem !important;
    padding-top: 2rem !important;
  }
  .pe-sm-4-5 {
    padding-right: 2rem !important;
  }
  .ps-sm-4-5 {
    padding-left: 2rem !important;
  }
  .pb-sm-52 {
    padding-bottom: 3.25rem !important;
  }
  .pt-sm-52 {
    padding-top: 3.25rem !important;
  }
  .py-sm-52 {
    padding-top: 3.25rem !important;
    padding-bottom: 3.25rem !important;
  }
  .px-sm-52 {
    padding-left: 3.25rem !important;
    padding-right: 3.25rem !important;
  }
  .py-sm-72 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .pt-sm-72 {
    padding-top: 4.5rem !important;
  }
  .pb-sm-72 {
    padding-bottom: 4.5rem !important;
  }
  .mb-sm-4-5 {
    margin-bottom: 2rem !important;
  }
  .mb-sm-20 {
    margin-bottom: 1.25rem !important;
  }
  .mt-sm-20 {
    margin-top: 1.25rem !important;
  }
  .pb-sm-20 {
    padding-bottom: 1.25rem !important;
  }
  .my-sm-20 {
    margin-bottom: 1.25rem !important;
    margin-top: 1.25rem !important;
  }
  .py-sm-20 {
    padding-bottom: 1.25rem !important;
    padding-top: 1.25rem !important;
  }
}
@media (min-width: 768px) {
  .p-md-4-5 {
    padding: 2rem !important;
  }
  .pb-md-4-5 {
    padding-bottom: 2rem !important;
  }
  .pt-md-4-5 {
    padding-top: 2rem !important;
  }
  .py-md-4-5 {
    padding-bottom: 2rem !important;
    padding-top: 2rem !important;
  }
  .pe-md-4-5 {
    padding-right: 2rem !important;
  }
  .ps-md-4-5 {
    padding-left: 2rem !important;
  }
  .pb-md-52 {
    padding-bottom: 3.25rem !important;
  }
  .pt-md-52 {
    padding-top: 3.25rem !important;
  }
  .py-md-52 {
    padding-top: 3.25rem !important;
    padding-bottom: 3.25rem !important;
  }
  .px-md-52 {
    padding-left: 3.25rem !important;
    padding-right: 3.25rem !important;
  }
  .py-md-72 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .pt-md-72 {
    padding-top: 4.5rem !important;
  }
  .pb-md-72 {
    padding-bottom: 4.5rem !important;
  }
  .mb-md-4-5 {
    margin-bottom: 2rem !important;
  }
  .mb-md-20 {
    margin-bottom: 1.25rem !important;
  }
  .mt-md-20 {
    margin-top: 1.25rem !important;
  }
  .pb-md-20 {
    padding-bottom: 1.25rem !important;
  }
  .my-md-20 {
    margin-bottom: 1.25rem !important;
    margin-top: 1.25rem !important;
  }
  .py-md-20 {
    padding-bottom: 1.25rem !important;
    padding-top: 1.25rem !important;
  }
}
@media (min-width: 1400px) {
  .p-xxl-4-5 {
    padding: 2rem !important;
  }
  .pb-xxl-4-5 {
    padding-bottom: 2rem !important;
  }
  .pt-xxl-4-5 {
    padding-top: 2rem !important;
  }
  .py-xxl-4-5 {
    padding-bottom: 2rem !important;
    padding-top: 2rem !important;
  }
  .pe-xxl-4-5 {
    padding-right: 2rem !important;
  }
  .ps-xxl-4-5 {
    padding-left: 2rem !important;
  }
  .pb-xxl-52 {
    padding-bottom: 3.25rem !important;
  }
  .pt-xxl-52 {
    padding-top: 3.25rem !important;
  }
  .py-xxl-52 {
    padding-top: 3.25rem !important;
    padding-bottom: 3.25rem !important;
  }
  .px-xxl-52 {
    padding-left: 3.25rem !important;
    padding-right: 3.25rem !important;
  }
  .py-xxl-72 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .pt-xxl-72 {
    padding-top: 4.5rem !important;
  }
  .pb-xxl-72 {
    padding-bottom: 4.5rem !important;
  }
  .mb-xxl-4-5 {
    margin-bottom: 2rem !important;
  }
  .mb-xxl-20 {
    margin-bottom: 1.25rem !important;
  }
  .mt-xxl-20 {
    margin-top: 1.25rem !important;
  }
  .pb-xxl-20 {
    padding-bottom: 1.25rem !important;
  }
  .my-xxl-20 {
    margin-bottom: 1.25rem !important;
    margin-top: 1.25rem !important;
  }
  .py-xxl-20 {
    padding-bottom: 1.25rem !important;
    padding-top: 1.25rem !important;
  }
}
@media (min-width: 1200px) {
  .p-xl-4-5 {
    padding: 2rem !important;
  }
  .pb-xl-4-5 {
    padding-bottom: 2rem !important;
  }
  .pt-xl-4-5 {
    padding-top: 2rem !important;
  }
  .py-xl-4-5 {
    padding-bottom: 2rem !important;
    padding-top: 2rem !important;
  }
  .pe-xl-4-5 {
    padding-right: 2rem !important;
  }
  .ps-xl-4-5 {
    padding-left: 2rem !important;
  }
  .pb-xl-52 {
    padding-bottom: 3.25rem !important;
  }
  .pt-xl-52 {
    padding-top: 3.25rem !important;
  }
  .py-xl-52 {
    padding-top: 3.25rem !important;
    padding-bottom: 3.25rem !important;
  }
  .px-xl-52 {
    padding-left: 3.25rem !important;
    padding-right: 3.25rem !important;
  }
  .py-xl-72 {
    padding-top: 4.5rem !important;
    padding-bottom: 4.5rem !important;
  }
  .pt-xl-72 {
    padding-top: 4.5rem !important;
  }
  .pb-xl-72 {
    padding-bottom: 4.5rem !important;
  }
  .mb-xl-4-5 {
    margin-bottom: 2rem !important;
  }
  .mb-xl-20 {
    margin-bottom: 1.25rem !important;
  }
  .mt-xl-20 {
    margin-top: 1.25rem !important;
  }
  .pb-xl-20 {
    padding-bottom: 1.25rem !important;
  }
  .my-xl-20 {
    margin-bottom: 1.25rem !important;
    margin-top: 1.25rem !important;
  }
  .py-xl-20 {
    padding-bottom: 1.25rem !important;
    padding-top: 1.25rem !important;
  }
}
@media (min-width: 768px) {
  .homepage-banner {
    background-image: url("https://vocafire.wpenginepowered.com/wp-content/uploads/2025/01/homepage_banner_photoonly_x2.webp");
    background-repeat: no-repeat;
    object-fit: cover;
    background-size: cover;
  }
}

.top-gradient {
  background: linear-gradient(270deg, #a0c6ff00 0%, #0d6efd00 20%, #004dd2 80%, #003992 100%);
}
.opacity-20-footer-mobile {
  opacity: 100%;
}
@media (max-width: 767px) {
  .opacity-20-footer-mobile {
    opacity: 20%;
  }
  .top-gradient {
    background: linear-gradient(270deg, #a0c6ffb3 0%, #0d6efd7d 20%, #004dd2 80%, #003992 100%);
  }
  .px-30 {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  .top-gradient-footer {
    background: linear-gradient(270deg, #a0c6ff 0%, #0d6efd 40%, #003992 100%);
  }
}
.links-header {
  color: #fff !important;
}
@media (max-width: 767px) {
  .links-header {
    color: #000 !important;
  }
}
.gradient-2-header {
  background: linear-gradient(90deg, var(--Colour-2-White-White-100, #fff) 15%, var(--Colour-2-Blue-00, #d0e3ff) 55.5%, var(--Colour-2-Blue-01, #a0c6ff) 75%);

  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.text-white-60 {
  color: rgba(255, 255, 255, 0.6);
}
.bg-grey-90 {
  background-color: #000a1a;
}
.border-bottom-blue {
  border-bottom: 2px solid #004dd2;
}

.zoom-img img {
  transform: scale(1);
  transition: transform 2.5s ease;
  width: 100%;
}

.zoom-img img:hover {
  transform: scale(1.03);
}
.border-top-black {
  border-top: 2px solid #000a1a;
}
.border-bottom-black {
  border-bottom: 2px solid #000a1a;
}
.border-top-voca {
  border-image: linear-gradient(270deg, #0d6efd 0%, #003992 100%) !important;
  border-style: solid !important;
  border-width: 2px !important;
  border-image-slice: 1 !important;
  border-bottom: none !important;
  border-left: none !important;
  border-right: none !important;
}
.top-modal-img {
  top: 10%;
}
@media (max-width: 767px) {
  .top-modal-img {
    top: 18%;
    left: 0%;
  }
}
.w-800px {
  max-width: 800px !important;
}
.modal-backdrop.show {
  opacity: 0.85 !important;
}
.size-close {
  font-size: 38px !important;
}
.top-10 {
  top: 10% !important;
}
.white-link {
  color: #fff;
  font-weight: 500;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}
.white-link:hover {
  color: #fff;
  font-weight: 500;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}
.grey-link {
  color: #646464 !important;
  font-weight: 550;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}
.grey-link:hover {
  color: #747373;
  font-weight: 550;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}

.blue-link {
  color: #004dd2 !important;
  font-weight: 500;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}
.blue-link:hover {
  color: #135fe2;
  font-weight: 500;
  line-height: 110%; /* 19.8px */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
}
.wpcf7-list-item {
  display: flex;
  font-size: 18px;
  align-items: center;
}
.wpcf7-list-item label {
  display: inline-block;
  margin-top: 5px; /* Adjust this value as needed */
}
.wpcf7-list-item:last-child {
  padding-bottom: 0px;
}
.wpcf7-list-item-label {
  display: inline-block;
  vertical-align: middle;
}
.wpcf7-list-item input[type="radio"] {
  vertical-align: middle;
  margin-right: 5px;
  margin-top: 7px;
}
.cf7-columns {
  display: flex;
  justify-content: space-between;
}
.cf7-column {
  width: 100%;
  box-sizing: border-box;
}
.uacf7-step.step-content button.uacf7-next {
  float: initial;
}
.wpcf7-form label {
  display: block;
  font-size: 16px;
}
.placeholder-css::ms-input-placeholder {
  font-weight: 400;
  color: #e1e1e1 !important;
  line-height: 140%;
  font-size: 16px !important;
}
.input-css {
  padding: 10px 14px 10px 14px !important;
  border-radius: 8px !important;
  box-shadow: 0px 1px 2px 0px rgba(10, 13, 18, 0.05) !important;
  border: 1px solid #e1e1e1 !important;
}
.input-css-glow {
  padding: 10px 14px 10px 14px !important;
  border-radius: 0px !important;
  box-shadow: none !important;
  border-bottom: solid 2px !important;
  background-color: transparent !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.input-css-glow:hover {
  padding: 10px 14px 10px 14px !important;
  border-radius: 0px !important;
  box-shadow: none !important;
  border-bottom: solid 2px #004dd2 !important;
  background-color: transparent !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.input-css-glow:focus-visible {
  padding: 10px 14px 10px 14px !important;
  border-radius: 0px !important;
  box-shadow: none !important;
  border-bottom: solid 2px #004dd2 !important;
  background-color: transparent !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  outline: none !important;
}
.input-css-glow:focus {
  padding: 10px 14px 10px 14px !important;
  border-radius: 0px !important;
  box-shadow: none !important;
  border-bottom: solid 2px #004dd2 !important;
  background-color: transparent !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}
.input-css::ms-input-placeholder {
  color: #000;
  opacity: 1;
}
.input-css-glow::ms-input-placeholder {
  color: #000;
  opacity: 1;
}
.input-css-check {
  padding: 6px 8px 6px 8px !important;
  border-radius: 8px !important;
  box-shadow: 0px 0px 0px 1.5px #00000077 !important;
  border: none !important;
  display: flex;
}
.input-css-check:hover {
  padding: 6px 8px 6px 8px !important;
  border-radius: 8px !important;
  box-shadow: 0px 0px 0px 1.5px #004dd2 !important;
  border: none !important;
  display: flex;
}
.input-css-check::placeholder {
  color: #000;
  opacity: 1;
}
.h-147 {
  height: 147px;
}
.h-73 {
  height: 73px;
}
.homepage-top {
  background-image: url(/wp-content/uploads/2025/01/homepage-banner-1.webp);
  background-position: top;
  background-size: cover;
}
@media (max-width: 1400px) {
  .homepage-top {
    background-position: center !important;
  }
}

.accordion-voca {
  border: none !important;
  background-color: transparent;
  color: #000;
  cursor: pointer;
  padding: 0px 0px 24px 0px;
  width: 100%;
  text-align: left;
  font-size: 24px !important;
  transition: 0.4s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  line-height: 120%;
}
.active-voca {
  color: rgb(0, 0, 0);
}
.accordion-voca:after {
  content: "⌃";
  color: #004dd2;
  font-weight: bold;
  float: left;
  transition: 0.4s;
  font-size: 28px;
  border-radius: 36px;
  display: inline-flex;
  justify-content: space-between;
  width: 26px;
  height: 26px;
  padding-top: 1px;
  padding-left: 1px;
  margin-left: 32px;
  transform: rotate(180deg);
}
.active-voca:after {
  transform: rotate(360deg);
}
.panel-voca {
  border: none;
  border-top: none;
  padding: 0px;
  background-color: transparent;
  color: #646468;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out;
  line-height: 140%;
  text-align: left;
  font-weight: 550;
  border-bottom: 1px solid #646468;
}

.accordion-voca.active-voca {
  border: none;
  background-color: transparent;
  cursor: pointer;
  width: 100%;
  text-align: left;
  transition: 0.4s;
}
.grey-646468 {
  color: #646468;
}
@media (max-width: 767px) {
  .cf7-columns.break {
    display: block !important;
  }
  .ls--312 {
    letter-spacing: -2.12px !important;
  }
  .ls--248 {
    letter-spacing: -1.48px !important;
  }
  .ls--184 {
    letter-spacing: -0.84px !important;
  }
  .ls--144 {
    letter-spacing: -0.44px !important;
  }
}
.ls--312 {
  letter-spacing: -3.12px;
}
.ls--248 {
  letter-spacing: -2.48px;
}
.ls--184 {
  letter-spacing: -1.84px;
}
.ls--144 {
  letter-spacing: -1.44px;
}
.rounded-24 {
  border-radius: 24px;
}
.rounded-end-24 {
  border-top-right-radius: 24px;
  border-bottom-right-radius: 24px;
}
.rounded-start-24 {
  border-top-left-radius: 24px;
  border-bottom-left-radius: 24px;
}
.rounded-36 {
  border-radius: 36px !important;
}
.rounded-top-36 {
  border-top-left-radius: 36px !important;
  border-top-right-radius: 36px !important;
}
.rounded-48 {
  border-radius: 48px;
}

/* Apply gradient overlay only when collapsed */
.voca-comp-table-fade.collapsed:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 80px; /* Height of fade effect */
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgb(255, 255, 255));
  pointer-events: none;
}

/* Ensure fade effect is always visible when collapsed */
.voca-comp-table-fade {
  position: relative;
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.5s ease;
}

/* Keep the third row partially visible when collapsed */
.voca-comp-table-hidden {
  max-height: 70px; /* Adjust height to show part of the hidden content */
  opacity: 1;
  transition: max-height 0.5s ease-in-out;
}

/* When expanded, show all rows and remove fade */
.voca-comp-table-visible {
  max-height: none;
}

.voca-comp-table-fade.collapsed .voca-comp-table-hidden {
  max-height: 70px; /* Ensures part of hidden content is visible */
}

/* Remove fade when expanded */
.voca-comp-table-fade:not(.collapsed)::after {
  display: none;
}

/* Link styling for expand/collapse */
.voca-comp-button {
  background-color: #f0f0f0;
  font-size: 24px;
  font-weight: 550;
  line-height: 120%;
  margin-right: 8px;
  color: #646468;
  font-weight: bold;
  padding: 0px 52px;
  border: none;
  border-radius: 36px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  transition: color 0.3s ease;
  text-decoration: none;
}

@media (max-width: 767px) {
  .voca-comp-button {
    background-color: #f0f0f0;
    font-size: 18px;
    font-weight: 550;
    line-height: 120%;
    margin-right: 8px;
    color: #646468;
    font-weight: bold;
    padding: 0px 40px;
    border: none;
    border-radius: 36px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    transition: color 0.3s ease;
    text-decoration: none;
  }
}

.voca-comp-button:hover {
  color: #000;
}

/* Icon rotation for expand/collapse */
.voca-comp-button i {
  transition: transform 0.3s ease;
}

.voca-comp-button i.expanded {
  transform: rotate(180deg);
}

.grid-3-rows {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}

.bg-grey-50 {
  background: rgba(208, 227, 255, 0.5);
}

.link-button {
  border-radius: 36px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  padding: 16px 32px 16px 16px;
  font-size: 24px;
  font-weight: 600;
  line-height: 120%;
  color: #000 !important;
  background: rgba(240, 240, 240, 0.8);
  box-shadow: 0px 0px 4px 0px rgba(100, 100, 104, 0.1);
  backdrop-filter: blur(2px);
}

.close-popup {
  background-color: #f9f9f9;
  border-radius: 36px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0);
  text-decoration: none;
  padding: 8px 24px 8px 8px;
  font-size: 24px;
  font-weight: 600;
  line-height: 120%;
  color: #000 !important;
}

.pill-blue {
  background: var(--Colour-2-White-White-10, rgba(255, 255, 255, 0.1));
  border-radius: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  text-decoration: none;
  padding: 16px 32px 16px 16px;
  font-size: 24px;
  font-weight: 600;
  line-height: 120%;
  color: #fff;
}

textarea {
  max-height: 150px;
}

.gradient-opacity {
  background: linear-gradient(rgba(255, 255, 255, 0.4) 40%, rgba(255, 255, 255) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.d-grid-love-voca {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  margin-bottom: 16px;
}
@media (max-width: 767px) {
  .d-grid-love-voca {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.d-grid-love-voca-2 {
  display: grid;
  grid-template-columns: 4fr 6fr;
}

@media (max-width: 767px) {
  .d-grid-love-voca-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.mw-modal {
  max-width: 1000px !important;
}
.more-services-bg {
  background-image: url(/wp-content/uploads/2025/03/VOCA-Fire-Protecion-More-Services.webp);
  background-position: bottom right;
  background-repeat: no-repeat;
  background-size: 675px 300px;
}

@media (max-width: 1400px) {
  .more-services-bg {
    background-image: url(/wp-content/uploads/2025/03/VOCA-Fire-Protecion-More-Services.webp);
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: 562.5px 250px;
  }
}

@media (max-width: 767px) {
  .more-services-bg {
    background-image: url(/wp-content/uploads/2025/03/VOCA-Fire-Protecion-More-Services.webp);
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: 450px 200px;
  }
  .d-grid-centered-staff {
    display: block !important;
  }

  .d-grid-staff {
    display: block !important;
  }
  .d-grid-operations-staff-additional {
    display: block;
  }
  .img-single-staff img {
    object-fit: cover;
    width: 100% !important;
  }
}

.d-grid-centered-staff {
  display: grid;
  grid-template-columns: 295px 295px;
  gap: 0px 16px;
  justify-content: center;
}

.d-grid-staff {
  display: grid;
  grid-template-columns: 295px 295px 295px 295px;
  gap: 0px 16px;
  justify-content: center;
}
@media (min-width: 767px) {
  .d-grid-operations-staff-additional {
    display: grid;
    grid-template-columns: 295px 295px 295px 295px;
    gap: 0px 16px;
    justify-content: center;
  }
}

#show-more {
  padding: 8px 0px;
  display: flex;
  gap: 8px;
  background: linear-gradient(270deg, #0d6efd 0%, #003992 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 140%;
  font-weight: 500;
  align-items: center;
  background-color: transparent;
  border: none;
}
.img-staff {
  text-align: center;
}
.img-staff img {
  object-fit: cover;
  width: 295px;
  height: 274px;
}
@media (min-width: 1500px) {
  .img-single-staff img {
    object-fit: cover;
    width: 380px;
    height: 366px;
  }
}

/* mega menu css */

.border-top-blue {
  border-top: 2px solid #004dd2;
}

.mega-grey {
  color: #646468;
}

.dark-blue-arrow {
  color: #003992;
}

.mega-link {
  color: #646468;
  font-weight: 500;
}

.mega-link:hover {
  color: #004dd2;
}

@media (max-width: 767px) {
  .box-shadow-mobile-0 {
    box-shadow: none !important;
  }
}

.small-mega {
  max-width: 950px !important;
}

.mega-study-img {
  width: 300px;
  height: 200px;
  object-fit: cover;
  display: block;
  border-radius: 8px;
}

.mega-study-img-2 {
  width: 144px;
  height: 96px;
  object-fit: cover;
  display: block;
  border-radius: 8px;
}

@media (max-width: 767px) {
  .mega-study-img {
    width: 100%;
  }

  .mega-study-img-2 {
    width: 100%;
    height: 200px;
    margin-bottom: 1rem;
  }
}

@media (min-width: 768px) {
  .px-md-4-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
}

.wh-40 {
  width: 40px !important;
  height: 40px !important;
}

.navbar-nav .nav-link {
  transition: opacity 0.3s ease-in-out;
}

.navbar-nav:hover .nav-link {
  opacity: 0.5;
}

.navbar-nav .nav-link:hover {
  opacity: 1 !important;
}
.h-careers {
  height: 200px;
}
.navbar-nav .nav-link {
  will-change: opacity;
}

.nav-link {
  padding-top: 1.2rem !important;
  padding-bottom: 1.2rem !important;
}

.img-overlay-dark {
  background: linear-gradient(#ffffff00 20%, #000 100%);
  position: absolute;
  bottom: 0;
  left: 0;
  border-radius: 36px;
}

.z-5 {
  z-index: 5;
}

.img-overlay-dark-big {
  background: linear-gradient(#ffffff00 10%, #000 100%);
  position: absolute;
  bottom: 0;
  left: 0;
  border-radius: 36px;
}

@media (min-width: 767px) and (max-width: 1439px) {
  .gradient-fade-swiper:after,
  .gradient-fade-swiper:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #fff 0, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0) 90%, #fff 100%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 1440px) {
  .gradient-fade-swiper:after,
  .gradient-fade-swiper:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #fff 0, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0) 90%, #fff 100%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 1440px) {
  .gradient-fade-swiper-grey:after,
  .gradient-fade-swiper-grey:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #f9f9f9 0, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0) 90%, #f9f9f9 100%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 767px) and (max-width: 1439px) {
  .gradient-fade-swiper-grey:after,
  .gradient-fade-swiper-grey:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #f9f9f9 0, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0) 90%, #f9f9f9 100%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 1440px) {
  .gradient-fade-swiper-grey-career:after,
  .gradient-fade-swiper-grey-career:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #f9f9f9 -15%, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0) 90%, #f9f9f9 120%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 767px) and (max-width: 1439px) {
  .gradient-fade-swiper-grey-career:after,
  .gradient-fade-swiper-grey-career:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 4;
    top: 0;
    background: linear-gradient(90deg, #f9f9f9 -15%, rgba(255, 255, 255, 0) 15%, rgba(255, 255, 255, 0) 85%, #f9f9f9 120%, transparent 100%);
    pointer-events: none; /* Prevent the pseudo-elements from blocking interactions */
  }
}

@media (min-width: 1800px) {
  .swiper-full-width {
    padding-left: calc(67.5% - 960px) !important;
    padding-right: calc(67.5% - 960px) !important;
  }
}

@media (min-width: 1440px) and (max-width: 1799px) {
  .swiper-full-width {
    padding-left: calc(72% - 960px) !important;
    padding-right: calc(72% - 960px) !important;
  }
}

@media (min-width: 1000px) and (max-width: 1439px) {
  .swiper-full-width {
    padding-left: calc(70% - 760px) !important;
    padding-right: calc(70% - 760px) !important;
  }
}

@media (max-width: 767px) {
  .video-mob-size {
    height: 238px !important;
    width: 385px !important;
  }
}

.wpcf7-file::-webkit-file-upload-button {
  visibility: hidden;
}
.wpcf7-file::before {
  content: "Choose File";
  display: inline-block;
  background-color: #f6f6f6;
  padding: 15px 15px;
  outline: none;
  white-space: nowrap;
  -webkit-user-select: none;
  cursor: pointer;
  font-weight: 700;
  font-size: 10pt;
  color: #4e4d4d;
  height: 49px !important;
}

.wpcf7-file:hover::before {
  border-color: black;
}
.wpcf7-file:active::before {
  background: -webkit-linear-gradient(top, #e3e3e3, #f9f9f9);
}

.file-upload {
  padding: 0px !important;
}
@media (max-width: 767px) {
  .h-100.h-180-mob {
    height: 180px !important;
  }
}
.carousel-grid-columns {
  display: grid;
  grid-template-columns: 2fr 1fr; /* 2/3 for large image, 1/3 for stacked images */
  gap: 16px;
}

.large-image {
  height: 100%;
}

.stacked-images {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.stacked-images .col-12 {
  height: 50%;
}

.swiper-slide-visible .image-transition-1 {
  transform: scale(1);
  transition: transform 2.5s ease;
}
.swiper-slide-visible .image-transition-2 {
  transform: scale(1);
  transition: transform 2.5s ease;
}
.swiper-slide-visible .image-transition-2 {
  transform: scale(1);
  transition: transform 2.5s ease;
}

.menu-gradient {
  background: linear-gradient(203deg, #fff 20%, #004dd2 360%);
}

/* Prevents Page Jumping by Maintaining Navbar Height */
#voca-navbar-placeholder {
  height: 155px; /* Dynamically updated */
  display: none;
}

/* Default Navbar */
.navbar-sticky {
  position: relative;
  width: 100%;
  top: 0;
  left: 0;
  transition: all 0.3s ease-in-out;
}
/* When Navbar Becomes Sticky */
.navbar-sticky.navbar-stuck {
  position: fixed !important;
  top: 0;
  left: 0;
  z-index: 1031;
  width: 100%;
  box-shadow:
    0 0.275rem 1.25rem rgba(11, 15, 25, 0.05),
    0 0.25rem 0.5625rem rgba(11, 15, 25, 0.03);
  animation: fadeInDownVOCA 0.3s ease-in-out;
}

/* Smooth Animation (Applies Only to This Navbar) */
@keyframes fadeInDownVOCA {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Scroll Header Visibility (Existing Styles) */
.navbar.navbar-stuck .d-none-scroll-header {
  display: none !important;
}
.d-block-scroll-header {
  display: none;
}
.navbar.navbar-stuck .d-block-scroll-header {
  display: block !important;
}
/* Adjust navbar padding when sticky */
.navbar {
  padding-top: 24px;
  padding-bottom: 24px;
}
.navbar.navbar-stuck {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}
@media (min-width: 768px) {
  .navbar-stuck .hide-item {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .navbar-stuck .hide-item {
    display: block;
  }
  .navbar-height {
    height: 101px !important;
  }
}
.navbar-height {
  height: 148px;
}

@media (min-width: 768px) {
  .navbar-stuck .display-none-nav {
    display: flex !important;
  }
  .display-none-nav {
    display: none;
  }
}

.h-swiper-cs {
  height: 400px;
}
@media (max-width: 767px) {
  .h-swiper-cs {
    height: 300px;
  }
}
.filter-links {
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 32px;
}

@media (max-width: 767px) {
  .filter-links {
    display: flex;
    flex-direction: column !important;
    gap: 16px;
    align-items: start !important;
    margin-bottom: 32px;
  }
}

.filter-links a.active {
  border: 1px solid #004dd2;
  border-radius: 8px;
  padding: 12px;
  text-decoration: none !important;
}

.modal-comms {
  background: linear-gradient(0deg, #11763b 50%, #53bb6d 100%);
}
.modal-positive {
  background: linear-gradient(0deg, #3f77bc 50%, #60cbe7 100%);
}
.modal-family {
  background: linear-gradient(0deg, #6952a3 50%, #ed2637 100%);
}
.modal-respect {
  background: linear-gradient(0deg, #ef4627 50%, #f6903b 100%);
}
.modal-team {
  background: linear-gradient(0deg, #4960ac 50%, #8d50a0 100%);
}

.gallery-next {
  padding: 0px 16px 0px 0px !important;
  border: none !important;
  font-size: 28px !important;
  color: #004dd2;
  background-color: transparent;
}

.gallery-prev {
  padding: 0px 0px 0px 16px;
  border: none !important;
  font-size: 28px !important;
  color: #004dd2;
  background-color: transparent;
}

@media (max-width: 767px) {
  .gallery-next {
    padding: 0px 2px 0px 0px !important;
    border: none !important;
    font-size: 28px !important;
    color: #004dd2;
    background-color: transparent;
  }

  .gallery-prev {
    padding: 0px 0px 0px 2px !important;
    border: none !important;
    font-size: 28px !important;
    color: #004dd2;
    background-color: transparent;
  }
}
.white-close {
  color: white;
}
@media (min-width: 1000px) and (max-width: 1400px) {
  .white-close {
    color: #000 !important;
  }
  .bottom-gallery-button {
    bottom: 15% !important;
  }
}

.top-40 {
  top: 40%;
}

.h-90 {
  height: 90%;
}

.bottom-gallery-button {
  bottom: 22%;
}
@media (max-width: 767px) {
  .mobile-menu-link {
    padding: 14px 16px !important;
    font-size: 14px !important;
    width: 100%;
    display: block !important;
    border-bottom: 1px solid #bdbdbd !important;
    display: flex !important;
    align-items: center !important;
    font-weight: 600 !important;
  }
  .first-mml {
    border-top: 1px solid #bdbdbd !important;
  }
}
.cs-swiper .content {
  height: 100% !important;
}
.cs-swiper .swiper-slide {
  height: auto !important;
}
.cs-swiper img {
  height: 100% !important;
  object-fit: cover;
  max-height: 650px !important;
}

.picture-row {
  height: 285px;
  overflow: hidden;
}
.picture-row img {
  object-fit: cover;
  object-position: bottom;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.picture-row .col-md-3 {
  position: relative;
}
@media (max-width: 998px) {
  .rounded-t-mob-24 {
    border-top-right-radius: 24px;
    border-top-left-radius: 24px;
  }
}
@media (max-width: 998px) {
  .rounded-b-mob-24 {
    border-bottom-right-radius: 24px;
    border-bottom-left-radius: 24px;
  }
}
@media (min-width: 998px) {
  .rounded-start-lg-24 {
    border-top-left-radius: 24px;
    border-bottom-left-radius: 24px;
  }
  .rounded-end-lg-24 {
    border-top-right-radius: 24px;
    border-bottom-right-radius: 24px;
  }
}
.pe-12 {
  padding-right: 12px;
}
.ps-12 {
  padding-left: 12px;
}
@media (max-width: 998px) {
  .px-mob-0 {
    padding-left: 0px;
    padding-right: 0px;
  }
}
.fire-door form[data-gtm-form-interact-id] .custom-file::before {
  content: "File Uploaded" !important;
}
.file-name {
  display: block;
  margin-top: 10px;
  font-weight: 600;
  font-size: 14px;
}
.drag-drop-area.has-file .custom-file::before {
  content: "File selected:" !important;
}
.drag-drop-area {
  border: 2px dashed #ccc;
  text-align: center;
  background: #f9f9f9;
  display: block;
  width: 100%;
  cursor: pointer;
  position: relative;
}
.drag-drop-area .wpcf7-file:active::before {
  background: transparent !important;
}
.drag-drop-area:hover {
  border-color: #004dd2;
  background: #f0f8ff;
}
.custom-file::before {
  content: "Click or drag a file to upload (optional) " !important;
  display: inline-block;
  background: transparent;
  color: #000;
  border-radius: 3px;
  padding: 15px;
  outline: none;
  text-align: center;
  white-space: nowrap;
  cursor: pointer;
  font-weight: 700;
  font-size: 18px;
  margin-right: 0px !important;
}
@media (max-width: 767px) {
  .custom-file::before {
    font-size: 14px !important;
  }
  .custom-file {
    padding: 15px !important;
  }
}
.custom-file {
  display: flex;
  justify-content: center;
  padding: 40px;
  width: 100%;
}
.custom-file:not([value=""]) {
  color: transparent;
}
.drag-drop-area::after {
  content: "";
  position: absolute;
  right: 49%;
  top: 66%;
  transform: translateY(-50%);
  font-weight: bold;
  color: #004dd2;
  font-size: 18px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path fill="%23004dd2" d="M256 109.3L256 320c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-210.7-41.4 41.4c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l96-96c12.5-12.5 32.8-12.5 45.3 0l96 96c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L256 109.3zM224 400c44.2 0 80-35.8 80-80l80 0c35.3 0 64 28.7 64 64l0 32c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64l0-32c0-35.3 28.7-64 64-64l80 0c0 44.2 35.8 80 80 80zm144 24a24 24 0 1 0 0-48 24 24 0 1 0 0 48z"/></svg>');
  background-repeat: no-repeat;
  background-size: contain;
  width: 20.952px;
  height: 24px;
}
.pp-form .call-back-label .wpcf7-list-item {
  margin: 0px;
}
.font-size-16 {
  font-size: 16px;
}

/* ANIMATIONS */

.gsapanimation-translate {
  opacity: 0;
  margin-top: 30px;
}
.gsapanimation-scrub {
  opacity: 0;
}
.gsapanimation-fade {
  opacity: 0;
}
.gsapanimation-fade-1 {
  opacity: 0;
}
.gsapanimation-translate-1 {
  opacity: 0;
  margin-top: 30px;
}
.gsapanimation-btn {
  opacity: 0;
}
.gsapanimation-btn1 {
  opacity: 0;
}
.gsapanimation-btn2 {
  opacity: 0;
}
.gsapanimation-btn3 {
  opacity: 0;
}
.gsapanimation-translate2 {
  opacity: 0;
  margin-top: 30px;
}
.gsapanimation-fade-start {
  opacity: 0;
}
.gsapanimation-fade-after {
  opacity: 0;
}
.gsapanimation-translate3 {
  opacity: 0;
  margin-top: 30px;
}
