@import url("https://fonts.googleapis.com/css2?family=Quicksand:wght@300..700&display=swap");
/* --------------------------------------opensans */
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");

/* ------------------------------------------------ Utilities */
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

/* ------------------------------------------------ Smooth Scroll */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
}

/* ------------------------------------------------ Body  */
body {
  font-family: "Quicksand", sans-serif;
  font-size: 16px;
  line-height: 1.3;
  color: #091b32;
}

.font-1 {
  font-family: "Open Sans", sans-serif;
}

/* ----------------------------------------- Admin Bar Height */
:root {
  --admin-bar-height: 0px;
}

.admin-bar {
  --admin-bar-height: 32px;
}

@media screen and (max-width: 782px) {
  html {
    margin-top: 0 !important;
  }

  .admin-bar {
    --admin-bar-height: 46px;
  }
}

@media screen and (max-width: 1023px) {
  .admin-bar {
    --admin-bar-height: 0px;
  }

  #wpadminbar {
    display: none !important;
  }
}

/* ----------------------------------------------------- Mobile Menu */
.mobile-menu {
  transform: translateX(-100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: none;
}

.mobile-menu.active {
  transform: translateX(0);
  box-shadow: 8px 0 30px rgba(0, 0, 0, 0.15);
}

/* ----------------------------------------------------- Gradients  */
:root {
  --grad-1: linear-gradient(
    270.06deg,
    #005b82 -3.25%,
    #006e75 41.42%,
    #008f5d 73.06%,
    #009956 99.95%
  );

  --grad-2:
    linear-gradient(
      271.46deg,
      rgba(217, 217, 217, 0) 0.94%,
      rgba(188, 192, 194, 0) 18.29%,
      rgba(85, 101, 112, 0.570011) 43.06%,
      rgba(56, 75, 89, 0.731684) 54.01%,
      rgba(39, 60, 75, 0.825453) 61.71%,
      rgba(26, 48, 65, 0.897442) 73.45%,
      rgba(20, 44, 61, 0.926957) 84.42%,
      #091b32 98.71%
    ),
    linear-gradient(0deg, rgba(1, 28, 42, 0.2), rgba(1, 28, 42, 0.2));

  --grad-3: linear-gradient(
    286.8deg,
    #005b82 26.94%,
    #006e75 67.68%,
    #008f5d 96.52%,
    #009956 121.05%
  );

  --grad-4: linear-gradient(
    270.56deg,
    #005b82 23.05%,
    #006e75 56.15%,
    #008f5d 79.6%,
    #009956 99.53%
  );

  --grad-5: linear-gradient(
    279.68deg,
    #005b82 0.65%,
    #006e75 50.02%,
    #008f5d 84.99%,
    #009956 114.72%
  );

  --grad-7: linear-gradient(
    21.35deg,
    #091b32 14.67%,
    rgba(17, 52, 97, 0.537929) 37.59%,
    rgba(21, 63, 116, 0.350054) 50.94%,
    rgba(25, 76, 141, 0.109392) 60.77%,
    rgba(27, 82, 152, 0) 67.07%
  );

  --grad-8:
    linear-gradient(
      270.03deg,
      #005b82 0.03%,
      #006e75 43.29%,
      #008f5d 73.92%,
      #009956 99.97%
    ),
    linear-gradient(0deg, rgba(9, 27, 50, 0.2), rgba(9, 27, 50, 0.2));
}

.gradient-1,
.hover-gradient-1:hover {
  background: var(--grad-1);
}

.gradient-2,
.hover-gradient-2:hover {
  background: var(--grad-2);
}

.gradient-3,
.hover-gradient-3:hover {
  background: var(--grad-3);
}

.gradient-4,
.hover-gradient-4:hover {
  background: var(--grad-4);
}

.gradient-5,
.hover-gradient-5:hover {
  background: var(--grad-5);
}

.gradient-7,
.hover-gradient-7:hover {
  background: var(--grad-7);
}

/* ----------------------------------------------- Buttons  */
.grad-btn {
  position: relative;
  overflow: hidden;
  background: transparent;
  transition: all 0.5s ease;
}

.grad-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.grad-btn > span {
  position: relative;
  z-index: 2;
}

.grad-btn:hover::before {
  opacity: 1;
}

/* ----------------------------------------------- Legal tabs (active) */
.js-legal-tab.active {
  position: relative;
  overflow: hidden;
  border-color: transparent;
}

.js-legal-tab.active::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 1;
  transition: opacity 0.5s ease;
  background: var(--grad-4);
}

.js-legal-tab.active > span {
  position: relative;
  z-index: 2;
  color: #ffffff;
}

/* ----------------------------------------------- Gradient Button 1  */
.grad-btn.btn-1 {
  background: var(--grad-1);
}

.grad-btn.btn-1::before {
  background: var(--grad-4);
}

/* ----------------------------------------------- Gradient Button 2  */
.grad-btn.btn-2::before {
  background: var(--grad-4);
}

.grad-btn.btn-2:hover {
  border-color: transparent;
  color: #ffffff;
}

/* ----------------------------------------------- Gradient Button 3  */
.grad-btn.btn-3::before {
  background: #091b32;
}

.grad-btn.btn-3:hover {
  border-color: transparent;
  color: #ffffff;
}

/* Prevent horizontal scrollbar from swiper */
.def-swiper {
  overflow: hidden;
}

.def-swiper.swiper-shadow {
  overflow: visible;
  clip-path: inset(-40px -40px -40px -40px);
}

.def-swiper.swiper-shadow .swiper-wrapper {
  padding: 40px 0;
  margin: -40px 0;
}

.def-swiper .swiper-wrapper {
  align-items: stretch;
}

.def-swiper .swiper-slide {
  height: auto;
}

button {
  cursor: pointer;
}

button:focus {
  outline: none;
}

/* -----------------------------------accordian */
:root {
  /* spacing */
  --acc-padding: 24px;
  --acc-panel-gap: 24px;

  /* icon */
  --icon-size: 18px;
  --icon-thickness: 3px;

  /* colors */
  --icon-color: #091b32;
  --icon-active-color: #4aab3d;

  /* animation */
  --icon-transition: 0.35s ease;
}

/* ===============================
   Accordion Item
================================ */
.accordion-item {
  padding: var(--acc-padding);
  cursor: pointer;
}

.accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* ===============================
   Panel
================================ */
.accordion-panel {
  padding-top: var(--acc-panel-gap);
  display: none;
}

/* ===============================
   Plus / Minus Icon
================================ */
.plusminus {
  position: relative;
  width: var(--icon-size);
  height: var(--icon-size);
}

.plusminus::before,
.plusminus::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: var(--icon-thickness);
  background-color: var(--icon-color);
  transition: all var(--icon-transition);
}

/* horizontal line */
.plusminus::before {
  transform: translateY(-50%);
}

/* vertical line */
.plusminus::after {
  transform: translateY(-50%) rotate(90deg);
}

/* ===============================
   Active State
================================ */
.accordion-item.active .plusminus::before {
  background-color: var(--icon-active-color);
}

.accordion-item.active .plusminus::after {
  opacity: 0;
  transform: translateY(-50%) rotate(0deg);
}

/* ----------------------------------------------- CF7 form styling */
:root {
  --cf7-color-primary: #4aab3d;
  --cf7-color-dark: #001834;
  --cf7-color-input: #091b32;
  --cf7-color-border: #8d8d8d;
  --cf7-color-focus: #011c2a;
  --cf7-color-error: #ef5f5f;
  --cf7-color-muted: #e0e0e0;
  --cf7-color-white: #fff;
  --cf7-color-disabled: #8f8f8f;

  --cf7-border: none;
  --cf7-border-bottom-width: 1px;

  --cf7-input-bg: transparent;
  --cf7-input-color: var(--cf7-color-input);
  --cf7-input-height: 40px;
  --cf7-textarea-height: 120px;
  --cf7-input-font-size: 16px;
  --cf7-input-padding: 0;
  --cf7-border-radius: 12px;
  --cf7-transition: 0.3s;

  --cf7-submit-color: var(--cf7-color-white);
  --cf7-submit-bg: var(--grad-1);
  --cf7-submit-hover-bg: var(--grad-4);
  --cf7-submit-disabled-bg: var(--cf7-color-disabled);
  --cf7-submit-height: 64px;
  --cf7-submit-min-width: 204px;
  --cf7-submit-radius: 16px;

  --cf7-message-color: var(--cf7-color-error);
  --cf7-message-border: var(--cf7-color-primary);
  --cf7-message-border-width: 2px;
  --cf7-message-padding: 10px 20px;
  --cf7-message-margin: 14px 0 4px 0;
  --cf7-message-font-size: 14px;

  --cf7-spinner-bg: var(--cf7-color-primary);
  --cf7-spinner-color: var(--cf7-color-white);

  --cf7-placeholder-color: var(--cf7-color-border);
  --cf7-label-weight: 600;
  --cf7-label-margin-bottom: 6px;

  --cf7-select-icon: url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 6l5 5 5-5 2 1-7 7-7-7 2-1z' fill='%23264467'/%3E%3C/svg%3E");
  --cf7-select-icon-position: right 10px top 50%;
  --cf7-select-padding-right: 36px;

  --cf7-date-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24'%3E%3Cpath fill='%23264467' d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11zm-7-9h5v5h-5z'/%3E%3C/svg%3E");
  --cf7-date-icon-position: right 14px center;
  --cf7-date-padding-right: 35px;
  --cf7-icon-size: 20px;

  --cf7-radio-gap: 10px;
  --cf7-radio-margin-top: 14px;
  --cf7-radio-size: 18px;
  --cf7-radio-margin-top-offset: 3px;
  --cf7-radio-check-font: "Font Awesome 5 Free";
  --cf7-radio-check-weight: 900;
  --cf7-radio-check-content: "\f00c";
  --cf7-radio-check-size: 8px;
  --cf7-list-item-margin: 6px;
}

.wpcf7 {
  flex: 1;
}

.wpcf7 form {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.wpcf7 label,
.wpcf7-form-control-wrap {
  display: block;
}

.wpcf7 label {
  font-weight: var(--cf7-label-weight);
  font-size: var(--label-font-size);
  margin-bottom: var(--cf7-label-margin-bottom);
}

.wpcf7 input,
.wpcf7 select,
.wpcf7 textarea {
  width: 100%;
  padding: var(--cf7-input-padding);
  border: var(--cf7-border);
  border-bottom: var(--cf7-border-bottom-width) solid var(--cf7-color-border);
  border-radius: 0;
  transition: all var(--cf7-transition);
  height: var(--cf7-input-height);
  font-size: var(--cf7-input-font-size);
  background-color: var(--cf7-input-bg);
  color: var(--cf7-input-color);
}

select,
.wpcf7 select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent !important;
  background: var(--cf7-select-icon) no-repeat var(--cf7-select-icon-position);
  padding-right: var(--cf7-select-padding-right) !important;
}

.custom-date {
  background: var(--cf7-date-icon) no-repeat var(--cf7-date-icon-position);
  background-size: var(--cf7-icon-size) var(--cf7-icon-size);
  padding-right: var(--cf7-date-padding-right);
}

.wpcf7 textarea {
  height: var(--cf7-textarea-height);
  resize: vertical;
  font-size: var(--cf7-input-font-size);
}

.wpcf7 input:focus,
.wpcf7 select:focus,
.wpcf7 textarea:focus {
  border-color: var(--cf7-color-focus);
  outline: none;
}

/* Placeholder color for inputs, selects, and textareas inside .wpcf7 */
.wpcf7 input::placeholder,
.wpcf7 select::placeholder,
.wpcf7 textarea::placeholder {
  color: var(--cf7-placeholder-color);
  opacity: 1;
  /* Ensures full opacity */
}

.wpcf7 input::-webkit-input-placeholder,
.wpcf7 select::-webkit-input-placeholder,
.wpcf7 textarea::-webkit-input-placeholder {
  color: var(--cf7-placeholder-color);
  opacity: 1;
}

.wpcf7 input::-moz-placeholder,
.wpcf7 select::-moz-placeholder,
.wpcf7 textarea::-moz-placeholder {
  color: var(--cf7-placeholder-color);
  opacity: 1;
}

.wpcf7 input:-ms-input-placeholder,
.wpcf7 select:-ms-input-placeholder,
.wpcf7 textarea:-ms-input-placeholder {
  color: var(--cf7-placeholder-color);
  opacity: 1;
}

.wpcf7 input::-ms-input-placeholder,
.wpcf7 select::-ms-input-placeholder,
.wpcf7 textarea::-ms-input-placeholder {
  color: var(--cf7-placeholder-color);
  opacity: 1;
}

/* Radio buttons */
.wpcf7-radio {
  display: flex;
  flex-direction: column;
  gap: var(--cf7-radio-gap);
  margin-top: var(--cf7-radio-margin-top);
}

.wpcf7-radio label {
  display: inline-flex;
  gap: 8px;
  cursor: pointer;
  margin: 0;
}

.wpcf7 .wpcf7-radio .wpcf7-list-item {
  margin: 0;
}

.wpcf7-list-item-label {
  font-weight: 600;
}

.wpcf7 input[type="radio"] {
  width: var(--cf7-radio-size);
  height: var(--cf7-radio-size);
  padding: 0;
  border: none;
  border-radius: 50%;
  background: var(--cf7-color-muted);
  appearance: none;
  -webkit-appearance: none;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  margin-top: var(--cf7-radio-margin-top-offset);
}

.wpcf7 input[type="radio"]:checked {
  background: var(--cf7-color-primary);
}

.wpcf7 input[type="radio"]:checked::after {
  font-family: var(--cf7-radio-check-font);
  font-weight: var(--cf7-radio-check-weight);
  content: var(--cf7-radio-check-content);
  /* fa-check */
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: var(--cf7-color-white);
  font-size: var(--cf7-radio-check-size);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.wpcf7 .wpcf7-list-item {
  margin: var(--cf7-list-item-margin) 0;
  display: block;
}

.input-wrap {
  position: relative;
}

.wpcf7 .wpcf7-submit {
  background: transparent;
  background-color: transparent;
  color: var(--cf7-submit-color);
  border: none;
  padding: 0;
  height: var(--cf7-submit-height);
  width: auto;
  min-width: var(--cf7-submit-min-width);
  font-size: var(--cf7-input-font-size);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  position: relative;
  z-index: 3;
}
.submit-wrap {
  position: relative;
  background: var(--cf7-submit-bg);
  border-radius: var(--cf7-submit-radius);
  display: inline-flex;
  overflow: hidden;
}
.submit-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cf7-submit-hover-bg);
  opacity: 0;
  transition: opacity 0.5s ease;
}
.submit-wrap:hover::after {
  opacity: 1;
}

/* Hover button */
/* .wpcf7 .wpcf7-submit:hover {
  background: var(--cf7-submit-hover-bg);
} */

/* Submitting state */
.wpcf7 form.submitting .submit-wrap {
  background: var(--cf7-submit-disabled-bg);
}

/* Spinner */
.wpcf7-spinner {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  padding: 0;
  background-color: var(--cf7-spinner-bg);
  opacity: 1;
  z-index: 9;
}

.wpcf7-spinner:before {
  background-color: var(--cf7-spinner-color);
}

/* ---- Case Study Enquiry CF7 Form ---- */
.cs-enquiry-form .wpcf7 form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem; /* 20px */
}

.cs-enquiry-form .wpcf7 label {
  display: block;
  font-family: "Open Sans", sans-serif;
  font-weight: 600;
  color: #47464e;
  margin-bottom: 0.375rem; /* 6px */
}

.cs-enquiry-form .wpcf7 input[type="text"],
.cs-enquiry-form .wpcf7 input[type="email"],
.cs-enquiry-form .wpcf7 input[type="tel"],
.cs-enquiry-form .wpcf7 select {
  width: 100%;
  height: 50px;
  padding: 0 1.25rem;
  border-radius: 0.5rem;
  background-color: #f1f1f3;
  border: 1px solid transparent;
  font-family: "Open Sans", sans-serif;
  font-weight: 600;
  outline: none;
  transition: border-color 0.2s;
}

.cs-enquiry-form .wpcf7 textarea {
  width: 100%;
  padding: 1rem 1.25rem;
  border-radius: 0.5rem;
  background-color: #f1f1f3;
  border: 1px solid transparent;
  font-family: "Open Sans", sans-serif;
  font-weight: 600;
  outline: none;
  resize: none;
  transition: border-color 0.2s;
}

.cs-enquiry-form .wpcf7 input:focus,
.cs-enquiry-form .wpcf7 textarea:focus {
  border-color: #4aab3d;
}

.cs-enquiry-form .wpcf7 input[type="submit"] {
  width: 100%;
  height: 60px;
  border-radius: 0.75rem;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-family: "Open Sans", sans-serif;
  font-weight: 700;
  color: #f1f1f3;
  cursor: pointer;
  border: none;
  background: var(--grad-1);
  margin-top: 0.5rem;
  transition: opacity 0.3s ease;
}

.cs-enquiry-form .wpcf7 input[type="submit"]:hover {
  background: var(--grad-4);
}

/* CS Enquiry Form Loader */
.cs-form-loader {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 1.5rem;
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
}

.cs-form-loader.active {
  opacity: 1;
  visibility: visible;
}

.cs-form-spinner {
  width: 36px;
  height: 36px;
  border: 4px solid #e5e7eb;
  border-top-color: #4aab3d;
  border-radius: 50%;
  animation: cs-spin 0.7s linear infinite;
}

@keyframes cs-spin {
  to {
    transform: rotate(360deg);
  }
}

.cs-field-error {
  display: block;
  color: #e04040;
  font-size: 13px;
  margin-top: 4px;
  font-weight: 600;
}

/* Error / Messages */
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  border-color: var(--cf7-message-color);
  color: var(--cf7-message-color);
  text-align: center;
}

.wpcf7-response-output {
  text-align: center;
}

.wpcf7-not-valid-tip {
  color: var(--cf7-message-color);
  font-size: var(--cf7-message-font-size);
  font-weight: 500;
  display: block;
  margin-top: 2px;
}

.wpcf7 form .wpcf7-response-output {
  margin: var(--cf7-message-margin);
  padding: var(--cf7-message-padding);
  border: var(--cf7-message-border-width) solid var(--cf7-message-border);
  border-radius: var(--cf7-border-radius);
  line-height: 1.3;
}

/* -------------------------------------------------- Contact Page  */
.ehs-contact-form.active {
  opacity: 1;
  pointer-events: auto;
  background-color: #ffffff;
}

.ehs-contact-form:not(.active) {
  color: #ffffff;
}

.ehs-contact-form:not(.active) .submit-wrap {
  background: none !important;
  border: 2px solid #ffffff !important;
}

.ehs-contact-form:not(.active) .wpcf7-radio input:checked {
  background-color: #e0e0e0 !important;
}

.ehs-contact-form:not(.active) .wpcf7-radio input::after {
  color: #008069 !important;
}

.loc-item.active .ehs-map-btn {
  background: var(--grad-1);
  color: #f1f1f3;
}

/* ------------------------------------------------about-cards */
.flip-card {
  perspective: 1000px;
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: 314 / 414;
  transition: transform 0.9s ease-in-out;
  transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg);
}

.flip-card-front,
.flip-card-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  border-radius: 1rem;
}

.flip-card-back {
  transform: rotateY(180deg);
}

/* ----------------------------------------------- Insight */
.insight-filter > .category-btn.active {
  background: var(--grad-1);
}

@media (max-width: 1279px) {
  .insight-filter > .category-btn.active {
    color: #ffffff;
    border-color: transparent;
  }
}

/* ===== Auth Popup ===== */
#ehs-auth-popup .ehs-auth-modal {
  scrollbar-width: thin;
  scrollbar-color: #d1d5db transparent;
}

#ehs-auth-popup .ehs-auth-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Hide WooCommerce default password toggle – we use our own (.ehs-pw-toggle) */
.show-password-input {
  display: none !important;
}

/* ===== Equal-height Swiper slides ===== */
.def-swiper .swiper-wrapper {
  align-items: stretch;
}
.def-swiper .swiper-slide {
  height: auto;
}
