/*
Theme Name: BLUEPRINT INTERACTIVE Theme
Author: Blueprint Interactive
Author URI: https://blueprintinteractive.com
Description: Blueprint Interactive Custom Theme.
Version: 2.0
License: GNU General Public License
/* -------------------------------------------------------------- */
/* Normalize Reset 
-------------------------------------------------------------- */

* {
  box-sizing: border-box;
}

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}
/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
  background-color: #032167;
  font-family: "sentinel", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #2a2a2a;
}

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

/* -------------------------------------------------------------- */
/* Animate CSS
-------------------------------------------------------------- */
.fade-in-from-left {
  opacity: 0;
  animation-timing-function: ease-out;
  -webkit-transform: translateX(-15px);
  -moz-transform: translateX(-15px);
  -o-transform: translateX(-15px);
  -ms-transform: translateX(-15px);
  transform: translateX(-15px);
}

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.fade-in-from-left.animated {
  animation-name: fade-from-left;
  animation-duration: 0.5s;
  opacity: 1;
  -webkit-transform: translateX(0);
  -moz-transform: translateX(0);
  -o-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

@keyframes fade-from-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-15px);
    -moz-transform: translateX(-15px);
    -o-transform: translateX(-15px);
    -ms-transform: translateX(-15px);
    transform: translateX(-15px);
  }

  45% {
    opacity: 0.5;
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

.fade-in-from-bottom {
  opacity: 0;
  animation-timing-function: ease-out;
  -webkit-transform: translateY(15px);
  -moz-transform: translateY(15px);
  -o-transform: translateY(15px);
  -ms-transform: translateY(15px);
  transform: translateY(15px);
}

.fade-in-from-bottom.animated {
  animation-name: fade-from-bottom;
  animation-duration: 1s;
  opacity: 1;
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -o-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}

@keyframes fade-from-bottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -o-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}

.fade-in-from-right {
  opacity: 0;
  animation-timing-function: ease-out;
  -webkit-transform: translateX(40px);
  -moz-transform: translateX(40px);
  -o-transform: translateX(40px);
  -ms-transform: translateX(40px);
  transform: translateX(40px);
}

.fade-in-from-right.animated {
  animation-name: fade-from-right;
  animation-duration: 0.5s;
  opacity: 1;
  -webkit-transform: translateX(0);
  -moz-transform: translateX(0);
  -o-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

@keyframes fade-from-right {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -moz-transform: translateX(40px);
    -o-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(40px);
  }

  90% {
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

main {
  background-color: #ffffff;
  min-height: 100vh;
}

.basic-page-wrapper {
  padding: 40px 0;
}

.footer {
  background: radial-gradient(
    268.84% 71.46% at 50% 50%,
    #032167 0%,
    #1b3f92 100%
  );
  text-align: center;
  padding: 20px 0;
}
.page-id-70 .inner a {
  color: #032167;
  transition: color 0.3s ease;
}

.page-id-70 .footer a:hover {
  color: #c2d9ff !important;
}

.footer p a {
  color: #c2d9ff;
  text-decoration: none;
}

.footer p a:hover {
  text-decoration: underline;
}
.int-header a {
  transition: opacity 0.3s ease;
}
.int_header a:hover {
  opacity: 0.8;
  transition: opacity 0.3s ease;
}

footer a:hover svg {
  opacity: 0.8;
  transition: opacity 0.3s ease;
}

#footerlogo {
  text-decoration: none;
  display: inline-block;
  margin-bottom: 20px;
}

.inner {
  width: 80%;
  margin: 0 auto;
}

.hero-wrap {
  height: 100vh;
  overflow: hidden;
  background-color: #032167;
  margin-bottom: 40px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-bottom: 5px solid #c2d9ff;
}

.hero-wrap .inner {
  text-align: center;
  width: 60%;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

.hero-wrap svg.logo {
  width: 400px;
  height: auto;
}

.hero-wrap h1 {
  font-size: 25px;
  line-height: 1.2;
  font-weight: normal;
  color: #ffffff;
}

.hero-wrap svg.state {
  width: 150px;
  height: auto;
  margin-top: 15px;
}

.section-content h2 {
  font-size: 50px;
  line-height: 1.2;
  font-weight: bold;
  margin-bottom: 20px;
  margin-top: 0;
  color: #032167;
  font-family: "tablet-gothic-compressed", sans-serif;
}

.section-content h3.eyebrow-text {
  font-size: 25px;
  line-height: 1.2;
  font-weight: bold;
  margin-bottom: 10px;
  color: #032167;
  font-family: "tablet-gothic-compressed", sans-serif;
  text-transform: uppercase;
  display: inline-block;
  padding: 10px 0 10px 15px;
  background-color: #c2d9ff; /* Adjust color as needed */
  position: relative;
  letter-spacing: 0.05em;
}

.section-content h3.eyebrow-text::before,
.section-content h3.eyebrow-text::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100px; /* Adjust fade distance */
}

.section-content h3.eyebrow-text::before {
  right: 100%;
}

.section-content h3.eyebrow-text::after {
  left: 100%;
  background: linear-gradient(to left, transparent, #c2d9ff);
}

.section-content p {
  font-size: 20px;
  line-height: 25px;
}

.section-content-left {
  display: inline-block;
  width: 47%;
  vertical-align: middle;
  margin-right: 3%;
}

.section-content-right {
  display: inline-block;
  width: 49%;
  vertical-align: middle;
}

.section-content-right img {
  width: 100%;
}

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

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

a.btn {
  display: inline-block;
  padding: 15px 25px 19px;
  background-color: #d22d48;
  color: #ffffff;
  text-decoration: none;
  border-radius: 5px;
  font-size: 30px;
  transition: background-color 0.3s ease;
  margin-top: 20px;
  font-family: "tablet-gothic-compressed", sans-serif;
}

a.btn:hover {
  background-color: #f00028;
  transition: background-color 0.3s ease;
}

.int_header {
  background-color: #032167;
  padding: 20px 0;
  text-align: center;
  border-bottom: 5px solid #c2d9ff;
}

.int_header .inner {
  width: 80%;
  margin: 0 auto;
}

.int_header .inner a {
  color: #ffffff;
  text-decoration: none;
}

.int_content h1 {
  font-size: 80px;
  line-height: 85px;
  color: #032167;
  font-family: "tablet-gothic-compressed", sans-serif;
  border-left: solid 7px #c2d9ff;
  padding-left: 17px;
  font-weight: bold;
}

.int_content p,
.int_content ul,
.int_content ol,
.int_content li {
  font-size: 20px;
  line-height: 25px;
}

.int_content p a {
  color: #032167;
  text-decoration: underline;
}

/* Custom Fluent Forms Styles */

.fluentform *,
.fluentform label,
.fluentform textarea {
  font-size: 16px !important;
}

.ff-el-group.ff-el-form-top.has-conditions.ff_cond_v {
  padding-left: 22px;
}

.fluentform input,
.fluentform select,
.fluentform input:placeholder-shown,
.fluentform select:placeholder-shown,
.fluentform textarea:placeholder-shown,
.fluentform input:placeholder-shown::placeholder,
.fluentform select:placeholder-shown::placeholder,
.fluentform textarea:placeholder-shown::placeholder,
.fluentform input:placeholder-shown::placeholder,
.fluentform select:placeholder-shown::placeholder,
.fluentform textarea:placeholder-shown::placeholder,
.fluentform textarea::placeholder {
  font-size: 14px !important;
}
.fluentform hr,
.ff-section_break_desk hr {
  display: none;
}

.ff-t-cell.ff-t-column-1 .ff-el-group.ff-el-form-hide_label {
  margin-bottom: 5px;
}

.frm-fluent-form p strong.ff-default .ff-el-input--label label,
.ff-default .ff-el-form-control {
  font-weight: 600 !important;
  font-size: 14px;
}

.fluentform {
  max-width: 900px !important;
  margin: 0 auto;
}

.ff-el-group.ff-dropzone {
  margin-top: 15px;
}

.ff-el-group.ff-dropzone {
  margin-bottom: 10px !important;
}

.ff-field textarea[name="selected_jobs_summary"],
.fluentform-field textarea[name="selected_jobs_summary"],
textarea[name="selected_jobs_summary"] {
  display: none !important;
}

.ff-field.selected_jobs_summary,
.fluentform-field.selected_jobs_summary,
.selected_jobs_summary {
  display: none !important;
}

.ff-field:has(textarea[name="selected_jobs_summary"]),
.fluentform-field:has(textarea[name="selected_jobs_summary"]) {
  display: none !important;
}

.ff-section_break_desk h4 {
  margin: 0 0px;
}
.ff-default .ff-el-form-control {
  max-width: 500px !important;
}
.ff-el-group.ff-el-form-hide_label.has-conditions.ff_cond_v {
  margin-bottom: 10px;
}
.governor-roles .ff-el-form-check {
  padding-bottom: 10px;
}

.ff-el-form-check {
  padding-bottom: 0px;
}

.ff-el-form-check span {
  padding-left: 5px;
}
.ff-default {
  font-family: "sentinel", sans-serif;
}

.ff-el-group.has-conditions.ff-el-section-break.ff_left.ff_cond_v {
  margin-bottom: 10px;
}
.ff-el-input--label label {
  font-weight: 800 !important;
}

.address-box.ff-name-address-wrapper.fluent-address
  .ff-el-input--content
  .ff-el-input--label
  label {
  font-weight: 500 !important;
}

.address-box.ff-name-address-wrapper.fluent-address > .ff-el-input--content {
  padding-left: 5px;
}

.address-box > .ff-el-input--label {
  padding-bottom: 10px;
}

.ff-t-cell.ff-t-column-1 .has-conditions > div {
  padding-left: 30px;
}

.has-conditions .ff-el-section-title {
  display: none;
}

.frm-fluent-form p,
.frm-fluent-form ul {
  margin-bottom: 0px;
  margin-top: 0px;
}

#ff_24_additional_comments {
  width: 100%;
  max-width: 100% !important;
}

.page:not(.home) .basic-page-wrapper.int_content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px 20px 50px;
}

.ff-el-form-control.ff_has_formula {
  display: none !important;
}
.error404 .main-content {
  background-image: linear-gradient(
      rgba(0, 10, 40, 0.75),
      rgba(0, 10, 40, 0.75)
    ),
    url("/wp-content/uploads/2025/11/Hero-e1762385017837.jpg");
  background-size: cover;
  background-repeat: no-repeat;
}

.ff-el-input--content:has(.ff-uploaded-list) {
  margin-bottom: 20px;
}

.error404 .main-content-inner * {
  color: white;
}

.error404 .main-content-inner a {
  color: #c2d9ff;
  text-decoration: none;
  transition: 0.25s ease-in-out;
}

.page-id-198 h1 {
  border-left: none;
  padding-left: 0px;
}

.page-id-198 h2 {
  border-left: solid 7px #c2d9ff;
  padding-left: 10px;
}

.page-id-198 .ff-section_break_desk em {
  border-left: solid 7px #c2d9ff;
  padding-left: 10px;
}

.content-contact a {
  color: #032167;
}
.error404 .main-content-inner a:hover {
  transition: 0.25s ease-in-out;
  color: #c2d9ff;
  text-decoration: underline;
}

.address-box.ff-name-address-wrapper.fluent-address > .ff-el-input--content {
  padding-left: 0px;
}

.two-column {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  max-width: 1100px;
  margin: 0 auto;
  align-items: center;
  gap: 30px;
}

.two-column > * {
  flex-grow: 1;
}

form.fluent_form_24 .ff-btn-submit:not(.ff_btn_no_style) {
  display: inline-block;
  padding: 6px 25px 10px;
  background-color: #d22d48 !important;
  color: #ffffff;
  text-decoration: none;
  border-radius: 5px;
  font-size: 25px !important;
  transition: 0.25s ease-in-out ease;
  margin-top: 20px;
  font-family: "tablet-gothic-compressed", sans-serif;
}

form.fluent_form_24 .ff-btn-submit:not(.ff_btn_no_style):hover {
  opacity: 0.7;
}

.page-id-70 footer a {
  color: white !important;
}
.hero-wrap img {
  width: 420px;
  height: auto;
  max-width: 90%;
}

.hero-wrap img.logo {
  margin-bottom: 10px;
}

.hero-wrap img.state {
  width: 100px;
  margin-top: 12px;
  margin-bottom: 20px;
  max-width: 30%;
}
