/* =========================
   Tokens
========================= */

:root {
  --cream: #f5f0e8;
  --gold: #ded196;
  --dark: #11151d;
  --light: #fcfcfc;
  --border: #d8d8d8;
  --text: #11151d;
  --muted: #959ba0;
  --white: #ffffff;

  --nav-h: 66px;
  --pad: clamp(16px, 9vw, 128px);
  --container: 1440px;

  /* Type */
  --fontMain: "Bree Serif", serif;
  --fontSecond: "Lato", sans-serif;
  --fontThird: "Lato", sans-serif;

  /* Radius + shadows */
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 12px;
  --shadow-card: 0 20px 40px rgba(0, 0, 0, 0.12);

  --floating-mobile-bottom: 16px;
}

/* =========================
   Base / Reset
========================= */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

html {
  scroll-behavior: smooth;
  overscroll-behavior-y: none;
}

body {
  font-family: var(--fontMain);
  color: var(--text);
  background: #fcfcfc;
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overscroll-behavior-y: none;
}

body.ui_lock {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

h1,
h2,
h3,
h4 {
  font-family: var(--fontMain);
  font-weight: 400;
}

/* Form controls (keep typography consistent) */
button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

/* Accessible focus ring */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* =========================
   Utilities
========================= */
.img-cover {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.img-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.ratio-hero {
  padding-top: 56%;
}

.ratio-project {
  padding-top: 75%;
}

.ratio-team {
  padding-top: 125%;
}

.ratio-wide {
  padding-top: 45%;
}

.ratio-square {
  padding-top: 100%;
}

.ratio-faq {
  padding-top: 80%;
}

/* =========================
   UI: Frame Button (global)
========================= */
.ui_frameBtn {
  --ui-btn-bg: #f3efe7;
  --ui-btn-border: #11151d;
  --ui-btn-text: #11151d;
  --ui-btn-hover-bg: #11151d;
  --ui-btn-hover-border: #11151d;
  --ui-btn-hover-text: #f3efe7;
  --ui-btn-radius: 2px;

  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 26px;
  border: 1px solid var(--ui-btn-border);
  border-radius: var(--ui-btn-radius);
  background: var(--ui-btn-bg);
  cursor: pointer;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 500;
  font-size: 18px;
  line-height: 22px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ui-btn-text);
  transition:
    color 520ms cubic-bezier(.22, 1, .36, 1),
    border-color 520ms cubic-bezier(.22, 1, .36, 1),
    background-color 520ms cubic-bezier(.22, 1, .36, 1),
    box-shadow 520ms cubic-bezier(.22, 1, .36, 1);
}

.ui_frameBtn > * {
  position: relative;
  z-index: 2;
  color: currentColor;
  transition:
    color 520ms cubic-bezier(.22, 1, .36, 1),
    transform 520ms cubic-bezier(.22, 1, .36, 1);
}

.ui_frameBtn::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: var(--ui-btn-hover-bg);
  transform: translateY(102%);
  transition:
    transform 620ms cubic-bezier(.22, 1, .36, 1),
    background-color 520ms cubic-bezier(.22, 1, .36, 1);
}

.ui_frameBtn::after {
  content: none;
}

.ui_frameBtn:hover::before,
.ui_frameBtn:focus-visible::before {
  transform: translateY(0);
}

.ui_frameBtn:hover,
.ui_frameBtn:focus-visible {
  color: var(--ui-btn-hover-text);
  border-color: var(--ui-btn-hover-border);
}

.ui_frameBtn:hover > *,
.ui_frameBtn:focus-visible > * {
  transform: translateY(-1px);
}

.ui_frameBtn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(196, 175, 106, 0.22);
}

/* =========================================================
   FOOTER — CLEAN FINAL
========================================================= */
.footer {
  position: relative;
  width: 100%;
  background: var(--gold);
  font-family: "Lato", system-ui, sans-serif;
  isolation: isolate;
}

.footer_inner {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 80px clamp(40px, 5vw, 128px);
}

.footer_content {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 64px;
}

.footer_left {
  flex: 1 1 560px;
  max-width: 920px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.footer_right {
  flex: 0 0 auto;
  width: max-content;
  min-width: max-content;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 54px;
  margin-left: auto;
}

.footer_links {
  width: 100%;
  max-width: 920px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.footer_linksRow {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 8px;
}

.footer_linksRow--main {
  gap: 24px;
  font-size: 16px;
  line-height: 28px;
  font-weight: 400;
}

.footer_linksRow--legal {
  gap: 18px 28px;
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
}

.footer a:hover {
  text-decoration: underline;
}

.footer_bottom {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 32px;
}

.footer_logoBlock {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.footer_logo {
  width: 84px;
  height: 84px;
  object-fit: contain;
  filter: brightness(0) saturate(100%);
  flex: 0 0 auto;
}

.footer_brandText {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.footer_brandName {
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  color: var(--dark);
}

.footer_brandCopy {
  margin-top: 4px;
  font-size: 14px;
  line-height: 20px;
  color: rgba(17, 21, 29, 0.85);
}

.footer_socials {
  display: flex;
  gap: 22px;
  align-items: center;
}

.footer_socialBtn {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.footer_socialIcon {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.footer_certs {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}

.footer_cert {
  display: block;
  width: clamp(72px, 7.5vw, 94px);
  height: clamp(72px, 7.5vw, 94px);
  object-fit: contain;
  object-position: center;
  flex: 0 0 auto;
}

.footer_sponsors {
  width: max-content;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 32px;
}

.footer_sponsor {
  flex: 0 0 auto;
  object-fit: contain;
  mix-blend-mode: multiply;
  opacity: 0.95;
}

.footer_sponsor--constructionline {
  width: 208px;
  height: 46px;
}

.footer_sponsor--rics {
  width: 129px;
  height: 46px;
}

.footer_sponsor--ciob {
  width: 134px;
  height: 31px;
  opacity: 1;
}

/* DESKTOP: main links stay in one row */
@media (min-width: 1280px) {
  .footer_linksRow--main {
    flex-wrap: nowrap;
  }

  .footer_linksRow--main a {
    white-space: nowrap;
  }
}

/* TABLET + SMALL DESKTOP */
@media (min-width: 641px) and (max-width: 1279px) {
  .footer_inner {
    padding: 56px clamp(28px, 4vw, 48px);
  }

  .footer_content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }

  .footer_left,
  .footer_right,
  .footer_links,
  .footer_bottom {
    display: contents;
  }

  .footer_linksRow--main {
    order: 1;
    display: grid;
    grid-template-columns: repeat(4, max-content);
    column-gap: 24px;
    row-gap: 14px;
    justify-content: start;
    margin-bottom: 28px;
  }

  .footer_linksRow--main a:nth-child(5) {
    grid-column: 1;
  }

  .footer_sponsors {
    order: 2;
    width: 100%;
    grid-template-columns: 208px 129px 134px;
    column-gap: 24px;
    justify-content: flex-start;
    margin-bottom: 24px;
  }

  .footer_certs {
    order: 3;
    justify-content: flex-start;
    gap: 18px;
    margin-bottom: 28px;
  }

  .footer_logoBlock {
    order: 4;
    margin-bottom: 18px;
  }

  .footer_linksRow--legal {
    order: 5;
    display: flex;
    flex-wrap: wrap;
    gap: 16px 24px;
    margin-bottom: 18px;
  }

  .footer_socials {
    order: 6;
    justify-content: flex-start;
    gap: 22px;
  }
}

/* MID TABLET */
@media (min-width: 500px) and (max-width: 899px) {
  .footer_inner {
    padding: 46px clamp(22px, 4vw, 36px);
  }

  .footer_linksRow--main {
    column-gap: 22px;
    row-gap: 12px;
  }

  .footer_sponsors {
    column-gap: 20px;
    justify-content: flex-start;
  }

  .footer_logo {
    width: 78px;
    height: 78px;
  }

  .footer_brandName {
    font-size: 19px;
    line-height: 24px;
  }
}

/* PHONE */
@media (max-width: 640px) {
  .footer_inner {
    padding: 28px 22px 38px;
  }

  .footer_content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }

  .footer_left,
  .footer_right,
  .footer_links,
  .footer_bottom {
    display: contents;
  }

  .footer_linksRow--main {
    order: 1;
    display: grid;
    grid-template-columns: repeat(3, max-content);
    column-gap: 28px;
    row-gap: 16px;
    justify-content: start;
    font-size: 16px;
    line-height: 28px;
    margin-bottom: 26px;
  }

  .footer_linksRow--main a:nth-child(4) {
    grid-column: 1;
  }

  .footer_linksRow--main a:nth-child(5) {
    grid-column: 2;
  }

  .footer_sponsors {
    order: 2;
    width: 100%;
    display: grid;
    grid-template-columns: max-content max-content;
    justify-content: center;
    align-items: center;
    column-gap: 56px;
    row-gap: 18px;
    margin-bottom: 22px;
  }

  .footer_sponsor--rics {
    grid-column: 1;
    grid-row: 1;
  }

  .footer_sponsor--ciob {
    grid-column: 2;
    grid-row: 1;
  }

  .footer_sponsor--constructionline {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-self: center;
  }

  .footer_certs {
    order: 3;
    justify-content: center;
    gap: 34px;
    margin-bottom: 28px;
  }

  .footer_logoBlock {
    order: 4;
    margin-bottom: 18px;
  }

  .footer_linksRow--legal {
    order: 5;
    display: flex;
    flex-wrap: wrap;
    gap: 14px 22px;
    margin-bottom: 18px;
    font-size: 14px;
    line-height: 22px;
  }

  .footer_socials {
    order: 6;
    justify-content: flex-start;
    gap: 24px;
  }

  .footer_logo {
    width: 74px;
    height: 74px;
  }

  .footer_brandName {
    font-size: 18px;
    line-height: 24px;
  }

  .footer_brandCopy {
    font-size: 14px;
    line-height: 20px;
  }
}

/* VERY SMALL PHONE */
@media (max-width: 430px) {
  .footer_inner {
    padding-left: 16px;
    padding-right: 16px;
  }

  .footer_linksRow--main {
    column-gap: 22px;
  }

  .footer_sponsors {
    column-gap: 56px;
    row-gap: 16px;
  }

  .footer_certs {
    gap: 34px;
  }
}

/* LARGE SCREENS */
@media (min-width: 1600px) {
  .footer_logo {
    width: clamp(84px, calc(84px + (100vw - 1600px) * 0.029), 112px);
    height: clamp(84px, calc(84px + (100vw - 1600px) * 0.029), 112px);
  }

  .footer_brandName {
    font-size: clamp(20px, calc(20px + (100vw - 1600px) * 0.0083), 28px);
    line-height: 1.3;
  }

  .footer_brandCopy {
    font-size: clamp(14px, calc(14px + (100vw - 1600px) * 0.0042), 18px);
    line-height: 1.45;
  }

  .footer_socialBtn {
    width: clamp(32px, calc(32px + (100vw - 1600px) * 0.0104), 42px);
    height: clamp(32px, calc(32px + (100vw - 1600px) * 0.0104), 42px);
  }

  .footer_socialIcon {
    width: 100%;
    height: 100%;
  }

  .footer_cert {
    width: clamp(94px, calc(94px + (100vw - 1600px) * 0.033), 126px);
    height: clamp(94px, calc(94px + (100vw - 1600px) * 0.033), 126px);
  }

  .footer_sponsor--constructionline {
    width: clamp(208px, calc(208px + (100vw - 1600px) * 0.073), 278px);
    height: clamp(46px, calc(46px + (100vw - 1600px) * 0.0156), 61px);
  }

  .footer_sponsor--rics {
    width: clamp(129px, calc(129px + (100vw - 1600px) * 0.0448), 172px);
    height: clamp(46px, calc(46px + (100vw - 1600px) * 0.0156), 61px);
  }

  .footer_sponsor--ciob {
    width: clamp(134px, calc(134px + (100vw - 1600px) * 0.0469), 179px);
    height: clamp(31px, calc(31px + (100vw - 1600px) * 0.0115), 42px);
  }

  .footer_linksRow--main {
    font-size: clamp(16px, calc(16px + (100vw - 1600px) * 0.0042), 20px);
    line-height: clamp(28px, calc(28px + (100vw - 1600px) * 0.0062), 34px);
  }

  .footer_linksRow--legal {
    font-size: clamp(14px, calc(14px + (100vw - 1600px) * 0.0031), 17px);
    line-height: clamp(24px, calc(24px + (100vw - 1600px) * 0.0052), 29px);
  }

  .footer_sponsors {
    gap: clamp(32px, calc(32px + (100vw - 1600px) * 0.018), 56px);
  }
}

/* =========================================================
   FLOATING ACTIONS
   Один блок, без дублей ниже по файлу
========================================================= */

.contact {
  --fileAttach-bg: rgba(17, 21, 29, 0.85);
  --fileAttach-border: #2b2e33;
  --fileAttach-text: var(--light);
  --fileAttach-muted: rgba(216, 216, 216, 0.75);

  --contact-close-h: 56px;
  --contact-close-bottom: 24px;
  --contact-close-gap: 16px;

  position: fixed;
  inset: 0;
  background: var(--dark);
  overflow: hidden;
  z-index: 10000;
  display: none;
}

.contact.is-open,
.contact.is-closing {
  display: block;
}

.contact_bgTilt {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  perspective: 900px;
  transform-style: preserve-3d;
}

.contact_bgImg {
  position: absolute;
  left: 40px;
  top: 50%;
  height: min(1044px, 92vh);
  width: auto;
  opacity: 0.75;
  filter: brightness(1.45) contrast(1.05);
  transform: translate3d(0, -50%, 0);
  transform-style: preserve-3d;
  transform-origin: center;
  will-change: transform;
  transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

[data-careers-tilt] {
  position: relative;
  overflow: hidden;
  perspective: 900px;
}

.careers_bgTilt {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.careers_bgImg {
  transform-style: preserve-3d;
  transform-origin: center;
  will-change: transform;
  transition: transform 120ms ease;
}

.contact_shell {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100dvh;
  padding:
    clamp(80px, 12dvh, 240px)
    var(--pad)
    calc(
      var(--contact-close-h) +
      var(--contact-close-bottom) +
      var(--contact-close-gap) +
      env(safe-area-inset-bottom)
    );
  display: flex;
  align-items: flex-start;
  justify-content: center;
  overflow: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  will-change: transform, opacity;
}

.contact.is-open .contact_shell {
  animation: contactOverlayIn 320ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.contact.is-closing .contact_shell {
  animation: contactOverlayOut 260ms cubic-bezier(0.4, 0, 1, 1) both;
}

.contact.is-open .contact_bgTilt {
  animation: contactBgIn 320ms ease both;
}

.contact.is-closing .contact_bgTilt {
  animation: contactBgOut 220ms ease both;
}

@keyframes contactOverlayIn {
  from {
    opacity: 0;
    transform: translate3d(0, 36px, 0) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes contactOverlayOut {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
  to {
    opacity: 0;
    transform: translate3d(0, 24px, 0) scale(0.99);
  }
}

@keyframes contactBgIn {
  from {
    opacity: 0;
    transform: scale(1.02);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes contactBgOut {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(1.01);
  }
}

@media (prefers-reduced-motion: reduce) {
  .contact.is-open .contact_shell,
  .contact.is-closing .contact_shell,
  .contact.is-open .contact_bgTilt,
  .contact.is-closing .contact_bgTilt {
    animation: none !important;
  }
}

.contact_items {
  width: min(var(--container), 100%);
  display: flex;
  gap: 32px;
  justify-content: flex-end;
  align-items: flex-start;
  min-height: 525px;
}

.contact_left {
  width: min(640px, 100%);
  max-width: 640px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact_text {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.contact_title {
  margin: 0;
  font-family: "Bree Serif", serif;
  font-weight: 400;
  font-size: clamp(38px, 4vw, 54px);
  line-height: 62px;
  color: var(--gold);
}

.contact_subtitle {
  margin: 0;
  max-width: 620px;
  font-family: "Open Sans", system-ui, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  color: var(--light);
}

.contact_quick {
  display: grid;
  grid-template-columns: max-content max-content;
  gap: 20px;
  justify-content: flex-start;
}

.contact_quickBtn {
  width: auto;
  min-width: 0;
  max-width: none;
  min-height: 76px;
  padding: 14px 26px;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  background: rgba(17, 21, 29, 0.85);
  border: 1px solid #2b2e33;
  border-radius: 8px;
  transition: background-color 120ms ease, border-color 120ms ease;
}

.contact_quickBadge {
  flex: 0 0 auto;
  min-width: max-content;
  min-height: 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
}

.contact_quickBadge--mail {
  width: 32px;
  min-width: 32px;
  justify-content: center;
}

.contact_quickText {
  flex: 0 0 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

.contact_quickTop {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  max-width: 100%;
  min-height: 0;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 17px;
  line-height: 20px;
  text-transform: uppercase;
  color: var(--light);
}

.contact_quickBottom {
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 20px;
  color: var(--light);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  transition: color 120ms ease;
}

.contact_quickMiniLabel {
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--light);
  transition: color 120ms ease;
}

.contact_quickIcon {
  width: 32px;
  height: 32px;
  flex: 0 0 32px;
  background: #d8d8d8;
  transition: background-color 120ms ease;
}

.contact_quickIcon--whatsapp {
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%20448%20512%27%3E%3Cpath%20d%3D%27M380.9%2097.1C339%2055.1%20283.2%2032%20224.8%2032%20105.9%2032%209.2%20128.7%209.2%20247.6c0%2038%2010%2075%2029%20107.4L0%20480l129.5-36.8c30.9%2017%2065.8%2025.9%20101.6%2025.9h.1c118.9%200%20215.6-96.7%20215.6-215.6%200-58.4-23.1-114.2-65.1-156.4zM224.8%20436.3h-.1c-32.2%200-63.8-8.7-91.5-25.1l-6.6-3.9-76.8%2021.9%2020.5-74.9-4.3-7c-18.1-28.7-27.7-61.9-27.7-96%200-100.4%2081.7-182.1%20182.1-182.1%2048.6%200%2094.2%2018.9%20128.6%2053.3%2034.4%2034.4%2053.3%2080.1%2053.3%20128.6%200%20100.4-81.7%20182.2-182.1%20182.2zm101.7-138.2c-5.6-2.8-33.2-16.4-38.4-18.3-5.2-1.9-9-2.8-12.8%202.8-3.7%205.6-14.7%2018.3-18%2022.1-3.3%203.7-6.6%204.2-12.2%201.4-33.2-16.6-55-29.6-77-67.2-5.8-9.9%205.8-9.2%2016.6-30.6%201.8-3.7.9-6.9-.5-9.7-1.4-2.8-12.8-30.9-17.5-42.3-4.6-11.1-9.2-9.6-12.8-9.8-3.3-.2-7-.2-10.8-.2-3.7%200-9.7%201.4-14.7%206.9-5%205.6-19.3%2018.9-19.3%2046.1%200%2027.2%2019.8%2053.5%2022.6%2057.2%202.8%203.7%2039%2059.6%2094.5%2083.6%2035.1%2015.2%2048.8%2016.5%2066.4%2013.9%2010.7-1.6%2033.2-13.6%2037.9-26.8%204.7-13.2%204.7-24.5%203.3-26.8-1.4-2.3-5.2-3.7-10.8-6.5z%27/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%20448%20512%27%3E%3Cpath%20d%3D%27M380.9%2097.1C339%2055.1%20283.2%2032%20224.8%2032%20105.9%2032%209.2%20128.7%209.2%20247.6c0%2038%2010%2075%2029%20107.4L0%20480l129.5-36.8c30.9%2017%2065.8%2025.9%20101.6%2025.9h.1c118.9%200%20215.6-96.7%20215.6-215.6%200-58.4-23.1-114.2-65.1-156.4zM224.8%20436.3h-.1c-32.2%200-63.8-8.7-91.5-25.1l-6.6-3.9-76.8%2021.9%2020.5-74.9-4.3-7c-18.1-28.7-27.7-61.9-27.7-96%200-100.4%2081.7-182.1%20182.1-182.1%2048.6%200%2094.2%2018.9%20128.6%2053.3%2034.4%2034.4%2053.3%2080.1%2053.3%20128.6%200%20100.4-81.7%20182.2-182.1%20182.2zm101.7-138.2c-5.6-2.8-33.2-16.4-38.4-18.3-5.2-1.9-9-2.8-12.8%202.8-3.7%205.6-14.7%2018.3-18%2022.1-3.3%203.7-6.6%204.2-12.2%201.4-33.2-16.6-55-29.6-77-67.2-5.8-9.9%205.8-9.2%2016.6-30.6%201.8-3.7.9-6.9-.5-9.7-1.4-2.8-12.8-30.9-17.5-42.3-4.6-11.1-9.2-9.6-12.8-9.8-3.3-.2-7-.2-10.8-.2-3.7%200-9.7%201.4-14.7%206.9-5%205.6-19.3%2018.9-19.3%2046.1%200%2027.2%2019.8%2053.5%2022.6%2057.2%202.8%203.7%2039%2059.6%2094.5%2083.6%2035.1%2015.2%2048.8%2016.5%2066.4%2013.9%2010.7-1.6%2033.2-13.6%2037.9-26.8%204.7-13.2%204.7-24.5%203.3-26.8-1.4-2.3-5.2-3.7-10.8-6.5z%27/%3E%3C/svg%3E") center/contain no-repeat;
}

.contact_quickIcon--mail {
  width: 30px;
  height: 22px;
  flex: 0 0 30px;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 6.75A1.75 1.75 0 0 1 4.75 5h14.5A1.75 1.75 0 0 1 21 6.75v10.5A1.75 1.75 0 0 1 19.25 19H4.75A1.75 1.75 0 0 1 3 17.25V6.75Zm1.6.03 7.05 5.3a.6.6 0 0 0 .7 0l7.05-5.3a.25.25 0 0 0-.15-.03H4.75c-.06 0-.11.01-.15.03Zm14.8 1.25-6.33 4.76a1.6 1.6 0 0 1-1.94 0L4.8 8.03a.25.25 0 0 0-.05.16v9.06c0 .28.22.5.5.5h14.5c.28 0 .5-.22.5-.5V8.19a.25.25 0 0 0-.05-.16Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 6.75A1.75 1.75 0 0 1 4.75 5h14.5A1.75 1.75 0 0 1 21 6.75v10.5A1.75 1.75 0 0 1 19.25 19H4.75A1.75 1.75 0 0 1 3 17.25V6.75Zm1.6.03 7.05 5.3a.6.6 0 0 0 .7 0l7.05-5.3a.25.25 0 0 0-.15-.03H4.75c-.06 0-.11.01-.15.03Zm14.8 1.25-6.33 4.76a1.6 1.6 0 0 1-1.94 0L4.8 8.03a.25.25 0 0 0-.05.16v9.06c0 .28.22.5.5.5h14.5c.28 0 .5-.22.5-.5V8.19a.25.25 0 0 0-.05-.16Z'/%3E%3C/svg%3E") center/contain no-repeat;
}

@media (hover: hover) and (pointer: fine) {
  .contact_quickBtn--wa:hover .contact_quickIcon,
  .contact_quickBtn--wa:focus-visible .contact_quickIcon {
    background: #25d366;
  }
}

@media (hover: hover) and (pointer: fine) {
  .contact_quickBtn:hover,
  .contact_quickBtn:focus-visible {
    background-color: var(--gold);
    border-color: #bead5f;
  }

  .contact_quickBtn:hover .contact_quickTop,
  .contact_quickBtn:focus-visible .contact_quickTop,
  .contact_quickBtn:hover .contact_quickBottom,
  .contact_quickBtn:focus-visible .contact_quickBottom,
  .contact_quickBtn:hover .contact_quickMiniLabel,
  .contact_quickBtn:focus-visible .contact_quickMiniLabel {
    color: var(--dark);
  }

  .contact_quickBtn:hover .contact_quickIcon,
  .contact_quickBtn:focus-visible .contact_quickIcon {
    background: var(--dark);
  }

  .contact_quickBtn--wa:hover .contact_quickIcon,
  .contact_quickBtn--wa:focus-visible .contact_quickIcon {
    background: #25d366;
  }
}

.field {
  width: 100%;
  position: relative;
}

.field_input,
.field_select,
.field_textarea {
  width: 100%;
  background: rgba(17, 21, 29, 0.85);
  border: 1px solid #2b2e33;
  border-radius: 6px;
  outline: none;
  color: var(--light);
  font-family: "Lato", system-ui, sans-serif;
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    color 120ms ease;
}

.field_input,
.field_select {
  height: 56px;
  padding: 0 16px;
}

.field_textarea {
  padding: 16px;
  resize: none;
}

.field_input::placeholder,
.field_textarea::placeholder {
  color: var(--border);
  transition: color 120ms ease;
}

.field_select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 44px;
  color: var(--border);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--border) 50%),
    linear-gradient(135deg, var(--border) 50%, transparent 50%);
  background-position: calc(100% - 22px) 24px, calc(100% - 16px) 24px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.field--textarea .field_textarea {
  height: 128px;
}

.field_meta {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-end;
}

.field_hint {
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  line-height: 16px;
  color: var(--muted);
}

.field_count {
  font-family: "Lato", system-ui, sans-serif;
  font-size: 12px;
  line-height: 16px;
  color: var(--muted);
  white-space: nowrap;
}

.field_input:hover,
.field_input:focus,
.field_textarea:hover,
.field_textarea:focus,
.field_select:hover,
.field_select:focus {
  background-color: var(--muted);
  border-color: var(--muted);
  color: var(--dark);
}

.field_input:hover::placeholder,
.field_input:focus::placeholder,
.field_textarea:hover::placeholder,
.field_textarea:focus::placeholder {
  color: rgba(17, 21, 29, 0.85);
}

.field_select:hover,
.field_select:focus {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--dark) 50%),
    linear-gradient(135deg, var(--dark) 50%, transparent 50%);
}

.contact_form {
  width: min(603px, 100%);
  padding-top: 22px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contact_formTitle {
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 32px;
  line-height: 48px;
  color: var(--light);
}

.contact_row {
  display: flex;
  gap: 18px;
  flex-wrap: nowrap;
}

.contact_row .field {
  flex: 1 1 0;
}

.field--phoneIntl {
  position: relative;
  width: 100%;
  min-width: 0;
  cursor: text;
}

.field--phoneIntl .iti {
  position: relative;
  isolation: isolate;
  display: block;
  width: 100%;
  min-width: 0;
}

.field--phoneIntl .iti::before {
  content: "Telephone";
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
  z-index: 4;
  pointer-events: none;
  white-space: nowrap;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 24px;
  color: var(--border);
  transition: color 120ms ease;
}

.field--phoneIntl .iti input.field_input,
.field--phoneIntl .iti input[type="tel"] {
  width: 100%;
  height: 56px;
  padding: 0 16px 0 236px !important;
  background: rgba(17, 21, 29, 0.85);
  border: 1px solid #2b2e33;
  border-radius: 6px;
  outline: none !important;
  box-shadow: none !important;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 24px;
  color: var(--light);
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    color 120ms ease;
}

.field--phoneIntl .iti input.field_input::placeholder,
.field--phoneIntl .iti input[type="tel"]::placeholder {
  color: rgba(216, 216, 216, 0.6);
  transition: color 120ms ease;
}

.field--phoneIntl .iti__country-container {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 88px;
  right: auto;
  z-index: 5;
  display: flex;
  align-items: center;
}

.field--phoneIntl .iti__selected-country {
  height: 56px;
  min-width: 0;
  margin: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  background: transparent !important;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  appearance: none;
  -webkit-appearance: none;
}

.field--phoneIntl .iti__selected-country:focus,
.field--phoneIntl .iti__selected-country:focus-visible,
.field--phoneIntl .iti__search-input:focus,
.field--phoneIntl .iti__search-input:focus-visible,
.field--phoneIntl .iti__country:focus,
.field--phoneIntl .iti__country:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

.field--phoneIntl .iti__selected-country-primary {
  height: 56px;
  margin: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  background: transparent !important;
}

.field--phoneIntl .iti__flag {
  margin-right: 10px;
  border-radius: 2px;
  box-shadow: none;
}

.iti__flag {
  background-image: image-set(
    url("../vendor/intl-tel-input/flags.webp") 1x,
    url("../vendor/intl-tel-input/flags@2x.webp") 2x
  ) !important;
  background-repeat: no-repeat !important;
}

.field--phoneIntl .iti__arrow,
.field--phoneIntl .iti__arrow.iti__arrow--up {
  width: 0;
  height: 0;
  display: block;
  margin-left: 0 !important;
  margin-right: 20px !important;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 7px solid var(--border);
  border-bottom: 0 !important;
  transform: none !important;
  transition: border-top-color 120ms ease, opacity 120ms ease;
}

.field--phoneIntl .iti.iti--show-dropdown .iti__arrow,
.field--phoneIntl .iti.iti--show-dropdown .iti__arrow.iti__arrow--up {
  transform: none !important;
  opacity: 0.72;
}

.field--phoneIntl .iti__selected-dial-code {
  margin-left: 0 !important;
  padding-left: 0 !important;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 24px;
  color: var(--border);
  transition: color 120ms ease;
}

.field--phoneIntl:hover .iti::before,
.field--phoneIntl:focus-within .iti::before {
  color: var(--dark);
}

.field--phoneIntl:hover .iti input.field_input,
.field--phoneIntl:hover .iti input[type="tel"],
.field--phoneIntl:focus-within .iti input.field_input,
.field--phoneIntl:focus-within .iti input[type="tel"] {
  background-color: var(--muted);
  border-color: var(--muted);
  color: var(--dark);
}

.field--phoneIntl:hover .iti input.field_input::placeholder,
.field--phoneIntl:hover .iti input[type="tel"]::placeholder,
.field--phoneIntl:focus-within .iti input.field_input::placeholder,
.field--phoneIntl:focus-within .iti input[type="tel"]::placeholder {
  color: rgba(17, 21, 29, 0.65);
}

.field--phoneIntl:hover .iti__selected-dial-code,
.field--phoneIntl:focus-within .iti__selected-dial-code {
  color: var(--dark);
}

.field--phoneIntl:hover .iti__arrow,
.field--phoneIntl:hover .iti__arrow.iti__arrow--up,
.field--phoneIntl:focus-within .iti__arrow,
.field--phoneIntl:focus-within .iti__arrow.iti__arrow--up {
  border-top-color: var(--dark);
}

.iti--container {
  z-index: 30000 !important;
}

.iti--container.iti--fullscreen-popup {
  background: transparent !important;
}

.iti--container.iti--fullscreen-popup .iti__dropdown-content {
  border-radius: 0 !important;
}

/* mobile fullscreen header */
.iti--container.iti--fullscreen-popup .phoneCountryHeader {
  display: flex;
  justify-content: flex-end;
  padding: calc(env(safe-area-inset-top) + 10px) 12px 4px;
}

.iti--container.iti--fullscreen-popup .phoneCountryClose {
  position: relative;
  width: 40px;
  height: 40px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
}

.iti--container.iti--fullscreen-popup .phoneCountryClose::before,
.iti--container.iti--fullscreen-popup .phoneCountryClose::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  border-top: 2px solid currentColor;
  transform-origin: center;
}

.iti--container.iti--fullscreen-popup .phoneCountryClose::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.iti--container.iti--fullscreen-popup .phoneCountryClose::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.iti--container .iti__dropdown-content {
  max-height: min(360px, calc(100vh - 24px));
  overflow: hidden;
}

.iti--container .iti__country-list {
  background: transparent;
  padding-bottom: 16px;
}

.iti--container .iti__country:last-child {
  margin-bottom: 10px;
}

.iti--container .iti__search-input::-webkit-search-decoration,
.iti--container .iti__search-input::-webkit-search-results-button,
.iti--container .iti__search-input::-webkit-search-results-decoration,
.iti--container .iti__search-input::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.iti--container .iti__search-clear {
  display: none !important;
  pointer-events: none !important;
}

.phoneSearchWrap {
  position: relative;
  width: calc(100% - 12px);
  margin: 6px;
}

.iti--container .phoneSearchWrap .iti__search-input {
  width: 100% !important;
  height: 44px;
  margin: 0 !important;
  padding: 0 58px 0 60px !important;
  background-image: none !important;
}

.phoneSearchWrap::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 24px;
  width: 11px;
  height: 11px;
  border: 2px solid currentColor;
  border-radius: 50%;
  transform: translateY(-58%);
  pointer-events: none;
  opacity: 0.72;
  box-sizing: border-box;
}

.phoneSearchWrap::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 33px;
  width: 7px;
  border-top: 2px solid currentColor;
  transform: translateY(3px) rotate(45deg);
  transform-origin: left center;
  pointer-events: none;
  opacity: 0.72;
}

.phoneSearchClear {
  position: absolute;
  top: 50%;
  right: 22px;
  width: 18px;
  height: 18px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  transform: translateY(-50%);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
}

.phoneSearchClear.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.phoneSearchClear::before,
.phoneSearchClear::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  border-top: 2px solid currentColor;
  transform-origin: center;
}

.phoneSearchClear::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.phoneSearchClear::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.iti--container.phone-dd-dark .iti__dropdown-content {
  margin-top: 6px;
  border: 1px solid #2b2e33;
  border-radius: 8px;
  background: rgba(17, 21, 29, 0.98);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.iti--container.phone-dd-dark .phoneSearchWrap {
  color: rgba(216, 216, 216, 0.72);
}

.iti--container.phone-dd-dark .iti__search-input {
  border: 1px solid #2b2e33;
  border-radius: 6px;
  background: rgba(17, 21, 29, 0.85);
  color: var(--light);
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  outline: none !important;
  box-shadow: none !important;
}

.iti--container.phone-dd-dark .iti__search-input::placeholder {
  color: rgba(216, 216, 216, 0.72);
}

.iti--container.phone-dd-dark .iti__search-input:focus,
.iti--container.phone-dd-dark .iti__search-input:focus-visible {
  border-color: #2b2e33;
  outline: none !important;
  box-shadow: none !important;
}

.iti--container.phone-dd-dark .phoneSearchClear {
  color: rgba(216, 216, 216, 0.78);
}

.iti--container.phone-dd-dark .iti__country {
  padding: 10px 12px;
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  line-height: 18px;
  color: var(--light);
  transition: background-color 140ms ease, color 140ms ease;
}

.iti--container.phone-dd-dark .iti__country:hover,
.iti--container.phone-dd-dark .iti__country.iti__highlight {
  background: var(--gold);
  color: var(--dark);
}

.iti--container.phone-dd-dark .iti__dial-code {
  color: inherit;
  opacity: 0.75;
}

.iti--container.phone-dd-dark .iti__country:hover .iti__dial-code,
.iti--container.phone-dd-dark .iti__country.iti__highlight .iti__dial-code {
  color: var(--dark);
  opacity: 1;
}

.iti--container.phone-dd-light .iti__dropdown-content {
  margin-top: 6px;
  border: 1px solid #bead5f;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: none;
}

.iti--container.phone-dd-light .phoneSearchWrap {
  color: #959ba0;
}

.iti--container.phone-dd-light .iti__search-input {
  border: 1px solid #c2c2c2;
  border-radius: 6px;
  background: #ffffff;
  color: var(--dark);
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  outline: none !important;
  box-shadow: none !important;
}

.iti--container.phone-dd-light .iti__search-input::placeholder {
  color: #959ba0;
}

.iti--container.phone-dd-light .iti__search-input:focus,
.iti--container.phone-dd-light .iti__search-input:focus-visible {
  border-color: #c2c2c2;
  outline: none !important;
  box-shadow: none !important;
}

.iti--container.phone-dd-light .phoneSearchClear {
  color: #959ba0;
}

.iti--container.phone-dd-light .iti__country {
  padding: 10px 12px;
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  line-height: 18px;
  color: var(--dark);
  transition: background-color 140ms ease, color 140ms ease;
}

.iti--container.phone-dd-light .iti__country:hover,
.iti--container.phone-dd-light .iti__country.iti__highlight {
  background: #efefef;
  color: var(--dark);
}

.iti--container.phone-dd-light .iti__country.iti__active {
  background: rgba(190, 173, 95, 0.16);
  color: var(--dark);
}

.iti--container.phone-dd-light .iti__dial-code {
  color: inherit;
  opacity: 0.75;
}

.iti--container.phone-dd-light .iti__country:hover .iti__dial-code,
.iti--container.phone-dd-light .iti__country.iti__highlight .iti__dial-code {
  color: var(--dark);
  opacity: 1;
}

/* Fullscreen dark theme */
.iti--container.iti--fullscreen-popup.phone-dd-dark {
  background: rgba(17, 21, 29, 0.98) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__dropdown-content {
  margin-top: 0 !important;
  background: rgba(17, 21, 29, 0.98) !important;
  border: 1px solid #2b2e33 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__search-input {
  border: 1px solid #2b2e33 !important;
  background: rgba(17, 21, 29, 0.85) !important;
  color: var(--light) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__search-input::placeholder {
  color: rgba(216, 216, 216, 0.72) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__country {
  color: var(--light) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__country:hover,
.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__country.iti__highlight {
  background: var(--gold) !important;
  color: var(--dark) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .iti__dial-code {
  color: inherit !important;
  opacity: 0.75 !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-dark .phoneCountryClose {
  color: rgba(216, 216, 216, 0.85);
}

/* Fullscreen light theme */
.iti--container.iti--fullscreen-popup.phone-dd-light {
  background: #ffffff !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__dropdown-content {
  margin-top: 0 !important;
  background: #ffffff !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__search-input {
  border: 1px solid #c2c2c2 !important;
  background: #ffffff !important;
  color: var(--dark) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__search-input::placeholder {
  color: #959ba0 !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__country {
  color: var(--dark) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__country:hover,
.iti--container.iti--fullscreen-popup.phone-dd-light .iti__country.iti__highlight {
  background: #efefef !important;
  color: var(--dark) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__country.iti__active {
  background: rgba(190, 173, 95, 0.16) !important;
  color: var(--dark) !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .iti__dial-code {
  color: inherit !important;
  opacity: 0.75 !important;
}

.iti--container.iti--fullscreen-popup.phone-dd-light .phoneCountryClose {
  color: var(--dark);
}

#contactsForm .field--phoneIntl .iti::before,
#careersForm .field--phoneIntl .iti::before {
  color: #959ba0;
}

#contactsForm .field--phoneIntl .iti input.field_input,
#contactsForm .field--phoneIntl .iti input[type="tel"],
#careersForm .field--phoneIntl .iti input.field_input,
#careersForm .field--phoneIntl .iti input[type="tel"] {
  background: #efefef;
  border: 1px solid #c2c2c2;
  color: var(--dark);
}

#contactsForm .field--phoneIntl .iti input.field_input::placeholder,
#contactsForm .field--phoneIntl .iti input[type="tel"]::placeholder,
#careersForm .field--phoneIntl .iti input.field_input::placeholder,
#careersForm .field--phoneIntl .iti input[type="tel"]::placeholder {
  color: #959ba0;
}

#contactsForm .field--phoneIntl .iti__selected-dial-code,
#careersForm .field--phoneIntl .iti__selected-dial-code {
  color: #959ba0;
}

#contactsForm .field--phoneIntl .iti__arrow,
#contactsForm .field--phoneIntl .iti__arrow.iti__arrow--up,
#careersForm .field--phoneIntl .iti__arrow,
#careersForm .field--phoneIntl .iti__arrow.iti__arrow--up {
  border-top-color: #959ba0;
}

#contactsForm .field--phoneIntl:hover .iti input.field_input,
#contactsForm .field--phoneIntl:hover .iti input[type="tel"],
#careersForm .field--phoneIntl:hover .iti input.field_input,
#careersForm .field--phoneIntl:hover .iti input[type="tel"] {
  background: #ffffff;
  border-color: #c2c2c2;
  color: var(--dark);
}

#contactsForm .field--phoneIntl:focus-within .iti input.field_input,
#contactsForm .field--phoneIntl:focus-within .iti input[type="tel"],
#careersForm .field--phoneIntl:focus-within .iti input.field_input,
#careersForm .field--phoneIntl:focus-within .iti input[type="tel"] {
  background: #ffffff;
  border-color: #bead5f;
  color: var(--dark);
}

#contactsForm .field--phoneIntl:hover .iti::before,
#contactsForm .field--phoneIntl:focus-within .iti::before,
#careersForm .field--phoneIntl:hover .iti::before,
#careersForm .field--phoneIntl:focus-within .iti::before,
#contactsForm .field--phoneIntl:hover .iti__selected-dial-code,
#contactsForm .field--phoneIntl:focus-within .iti__selected-dial-code,
#careersForm .field--phoneIntl:hover .iti__selected-dial-code,
#careersForm .field--phoneIntl:focus-within .iti__selected-dial-code {
  color: var(--dark);
}

#contactsForm .field--phoneIntl:hover .iti__arrow,
#contactsForm .field--phoneIntl:hover .iti__arrow.iti__arrow--up,
#contactsForm .field--phoneIntl:focus-within .iti__arrow,
#contactsForm .field--phoneIntl:focus-within .iti__arrow.iti__arrow--up,
#careersForm .field--phoneIntl:hover .iti__arrow,
#careersForm .field--phoneIntl:hover .iti__arrow.iti__arrow--up,
#careersForm .field--phoneIntl:focus-within .iti__arrow,
#careersForm .field--phoneIntl:focus-within .iti__arrow.iti__arrow--up {
  border-top-color: var(--dark);
}

.field--file {
  position: relative;
  height: 56px;
  padding: 0 24px 0 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(17, 21, 29, 0.85);
  border: 1px solid #2b2e33;
  border-radius: 6px;
  cursor: pointer;
}

.fileLabel {
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 24px;
  color: var(--border);
  white-space: nowrap;
}

.fileInput {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.field--file:hover,
.field--file:focus-within {
  background-color: var(--muted);
  border-color: var(--muted);
}

.field--file:hover .fileLabel,
.field--file:focus-within .fileLabel {
  color: var(--dark);
}

.contact_row--file {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 14px;
}

.contact_row--file .field--projectType {
  flex: 1 1 auto;
  min-width: 0;
  width: auto;
  max-width: none;
}

.contact_row--file .field--file {
  flex: 0 0 132px;
  width: 132px;
  min-width: 132px;
  max-width: 132px;
  padding: 0 12px;
}

#contactsForm .field_input,
#contactsForm .field_select,
#contactsForm .field_textarea,
#careersForm .field_input,
#careersForm .field_select,
#careersForm .field_textarea {
  background: #efefef;
  border: 1px solid #c2c2c2;
  color: var(--dark);
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 220ms ease,
    transform 220ms ease;
}

#contactsForm .field_input::placeholder,
#contactsForm .field_textarea::placeholder,
#careersForm .field_input::placeholder,
#careersForm .field_textarea::placeholder {
  color: #959ba0;
}

#contactsForm .field_select,
#careersForm .field_select {
  color: #959ba0;
  background-image:
    linear-gradient(45deg, transparent 50%, #959ba0 50%),
    linear-gradient(135deg, #959ba0 50%, transparent 50%);
}

#contactsForm .field_select:valid,
#careersForm .field_select:valid {
  color: var(--dark);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--dark) 50%),
    linear-gradient(135deg, var(--dark) 50%, transparent 50%);
}

#contactsForm .uiSelect:not(.is-placeholder) .uiSelect_btn,
#careersForm .uiSelect:not(.is-placeholder) .uiSelect_btn {
  color: var(--dark);
}

#contactsForm input[name="name"]:hover,
#contactsForm input[name="email"]:hover,
#contactsForm textarea[name="message"]:hover,
#careersForm input[name="name"]:hover,
#careersForm input[name="email"]:hover,
#careersForm textarea[name="message"]:hover {
  background: #ffffff;
  border-color: #c2c2c2;
  box-shadow: none;
  transform: none;
}

#contactsForm input[name="name"]:focus,
#contactsForm input[name="email"]:focus,
#contactsForm textarea[name="message"]:focus,
#careersForm input[name="name"]:focus,
#careersForm input[name="email"]:focus,
#careersForm textarea[name="message"]:focus {
  background: #ffffff;
  border-color: #bead5f;
  box-shadow: none;
  transform: none;
}

#contactsForm .field_select:hover,
#careersForm .field_select:hover {
  background: #ffffff;
  border-color: #c2c2c2;
  box-shadow: none;
  transform: none;
}

#contactsForm .field_select:focus,
#careersForm .field_select:focus {
  background: #ffffff;
  border-color: #bead5f;
  box-shadow: none;
  transform: none;
}

#contactsForm .uiSelect_btn,
#careersForm .uiSelect_btn {
  width: 100%;
  height: 56px;
  padding: 0 44px 0 16px;
  border-radius: 6px;
  border: 1px solid #c2c2c2;
  background: #efefef;
  color: #959ba0;
  box-shadow: none;
  transform: none;
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 220ms ease,
    color 180ms ease,
    transform 220ms ease;
}

#contactsForm .uiSelect_btn:hover,
#careersForm .uiSelect_btn:hover {
  background: #ffffff;
  border-color: #c2c2c2;
  color: var(--dark);
  box-shadow: none;
  transform: none;
}

#contactsForm .uiSelect_btn:focus-visible,
#contactsForm .uiSelect.is-open .uiSelect_btn,
#careersForm .uiSelect_btn:focus-visible,
#careersForm .uiSelect.is-open .uiSelect_btn {
  background: #ffffff;
  border-color: #bead5f;
  color: var(--dark);
  box-shadow: none;
  transform: none;
  outline: none;
}

/* =========================
   Form theme overrides
========================= */
:is(#contactsForm, #careersForm) .uiSelect_list {
  background: #ffffff;
  border: 1px solid #bead5f;
  box-shadow: none;
}

:is(#contactsForm, #careersForm) .uiSelect_opt {
  background: transparent;
  color: var(--dark);
}

:is(#contactsForm, #careersForm) .uiSelect_opt:hover,
:is(#contactsForm, #careersForm) .uiSelect_opt:focus-visible {
  background: #efefef;
  color: var(--dark);
  outline: none;
}

:is(#contactsForm, #careersForm) .uiSelect_opt.is-selected {
  background: rgba(190, 173, 95, 0.16);
  color: var(--dark);
}

:is(#contactsForm, #careersForm) .field_input:focus-visible,
:is(#contactsForm, #careersForm) .field_select:focus-visible,
:is(#contactsForm, #careersForm) .field_textarea:focus-visible {
  outline: none;
}

:is(#contactsForm, #careersForm) .field_select:hover,
:is(#contactsForm, #careersForm) .field_select:focus {
  color: var(--dark);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--dark) 50%),
    linear-gradient(135deg, var(--dark) 50%, transparent 50%);
}

:is(#contactsForm, #careersForm) .field_select option {
  background: #ffffff;
  color: var(--dark);
}

:is(#contactsForm, #careersForm) .field_select option:checked {
  background: rgba(190, 173, 95, 0.16);
  color: var(--dark);
}

:is(#contactsForm, #careersForm) .fileFeedback {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

:is(#contactsForm, #careersForm) .fileFeedback_msg {
  display: none;
  color: #c93430;
}

/* legacy compatibility for #contactForm if it still exists */
#contactForm .field_select:hover,
#contactForm .field_select:focus {
  color: var(--dark);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--dark) 50%),
    linear-gradient(135deg, var(--dark) 50%, transparent 50%);
}

#contactForm .uiSelect_btn:hover,
#contactForm .uiSelect_btn:focus-visible,
#contactForm .uiSelect.is-open .uiSelect_btn {
  background-color: var(--muted);
  border-color: var(--muted);
  color: var(--dark);
}

#contactForm .uiSelect_btn:hover .uiSelect_arrow,
#contactForm .uiSelect_btn:focus-visible .uiSelect_arrow,
#contactForm .uiSelect.is-open .uiSelect_btn .uiSelect_arrow {
  color: var(--dark);
}

/* =========================
   Contact actions
========================= */
.contact_send {
  width: 220px;
  height: 60px;
  --ui-btn-bg: var(--dark);
  --ui-btn-border: var(--muted);
  --ui-btn-text: var(--light);
  --ui-btn-hover-bg: var(--muted);
  --ui-btn-hover-border: var(--muted);
  --ui-btn-hover-text: var(--dark);
}

.contact_sendText,
.contact_sendArrow {
  color: currentColor;
  transition:
    color 520ms cubic-bezier(.22, 1, .36, 1),
    transform 520ms cubic-bezier(.22, 1, .36, 1);
}

.contact_sendArrow {
  position: relative;
  flex: 0 0 auto;
  display: inline-block;
  width: 18px;
  height: 24px;
  font-size: 0;
  line-height: 0;
  color: inherit;
}

.contact_sendArrow::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  width: 8px;
  height: 8px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
  transform-origin: center;
}

.contact_sendArrow::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 2px;
  border-top: 2px solid currentColor;
  transform: translateY(-50%);
}

.contact_close {
  position: fixed;
  left: 50%;
  bottom: calc(var(--contact-close-bottom) + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  width: 112px;
  height: var(--contact-close-h);
  padding: 12px;
  display: grid;
  place-items: center;
  border: 0;
  background: var(--dark);
  border-radius: 32px;
  cursor: pointer;
  z-index: 10001;
}

.contact_closePill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 18px;
  background: var(--gold);
  border: 1px solid #bead5f;
  border-radius: 20px;
}

.contact_closeText {
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 17px;
  color: var(--dark);
}

.contact_closeX {
  position: relative;
  width: 9px;
  height: 9px;
}

.contact_closeX::before,
.contact_closeX::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  border-top: 1.8px solid var(--dark);
  transform-origin: center;
}

.contact_closeX::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.contact_closeX::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* =========================
   Burger menu
========================= */
.bm {
  position: fixed;
  inset: 0;
  z-index: 10050;
  display: block;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 320ms ease,
    visibility 0s linear 320ms;
}

.bm.is-open,
.bm.is-closing {
  visibility: visible;
  transition-delay: 0s;
}

.bm.is-open {
  opacity: 1;
  pointer-events: auto;
}

.bm.is-closing {
  opacity: 0;
  pointer-events: none;
}

.bm img.bm_bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  background-color: var(--white);
  mix-blend-mode: exclusion;
  transform: translateZ(0);
  pointer-events: none;
}

.bm_backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: rgba(17, 21, 29, 0.12);
  opacity: 0;
  transition: opacity 260ms ease;
}

.bm_shell {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: auto;
  opacity: 0;
  transform: translate3d(40px, 0, 0);
  will-change: transform, opacity;
  transition:
    transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease;
}

.bm_content {
  position: absolute;
  top: 55px;
  left: 92px;
  display: flex;
  flex-direction: column;
  gap: 35px;
}

.bm_panel {
  position: relative;
  background: rgba(123, 127, 134, 0.75);
  border: 0;
  border-radius: 8px;
}

.bm_panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%20467%20612%27%20preserveAspectRatio%3D%27none%27%3E%3Crect%20x%3D%270.7%27%20y%3D%270.7%27%20width%3D%27465.6%27%20height%3D%27610.6%27%20rx%3D%278%27%20ry%3D%278%27%20fill%3D%27none%27%20stroke%3D%27%238F908F%27%20stroke-width%3D%271.4%27%20stroke-dasharray%3D%276%206%27/%3E%3C/svg%3E")
    no-repeat;
  background-size: 100% 100%;
}

.bm_menu {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.bm_link {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  width: 100%;
  padding: 7px 8px 8px;
  border-radius: 4px;
  flex-wrap: nowrap;
  font-family: "Bree Serif", serif;
  font-weight: 400;
  font-size: 32px;
  line-height: 43px;
  letter-spacing: 0.02em;
  color: var(--dark);
  opacity: 0;
  transform: translate3d(18px, 0, 0);
  will-change: transform, opacity;
  transition:
    transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 200ms ease;
}

.bm_linkText {
  flex: 0 0 auto;
  min-width: 0;
  white-space: nowrap;
}

.bm_link::after {
  content: "";
  flex: 0 0 36px;
  width: 36px;
  height: 28px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 36px 28px;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%2736%27%20height%3D%2728%27%20viewBox%3D%270%200%2036%2028%27%3E%3Cpath%20d%3D%27M2%2014H30%20M24%208L30%2014L24%2020%27%20fill%3D%27none%27%20stroke%3D%27%23D8D8D8%27%20stroke-width%3D%272.8%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E");
  margin-left: 10px;
  opacity: 0;
  transform: translateX(-10px);
  pointer-events: none;
  transition:
    transform 260ms cubic-bezier(0.2, 0.8, 0.2, 1),
    opacity 200ms ease;
}

.bm_link:hover::after,
.bm_link:focus-visible::after {
  opacity: 1;
  transform: translateX(0);
}

.bm_lang {
  display: flex;
  gap: 42px;
  padding-left: 28px;
  opacity: 0;
  transform: translate3d(22px, 0, 0);
  will-change: transform, opacity;
  transition:
    transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease;
}

.bm_langBtn {
  width: 38px;
  height: 38px;
  padding: 6px;
  border-radius: 6px;
  border: 1px solid var(--dark);
  background: #7b8086;
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 22px;
  letter-spacing: 0.02em;
  color: var(--dark);
  cursor: pointer;
  transition:
    background-color 200ms ease,
    color 200ms ease,
    border-color 200ms ease;
}

.bm_langBtn.is-active {
  background: var(--gold);
}

.bm_side {
  position: absolute;
  top: 32px;
  right: 32px;
  display: flex;
  align-items: center;
  gap: 20px;
  opacity: 0;
  transform: translate3d(0, -18px, 0);
  will-change: transform, opacity;
  transition:
    transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease;
}

.bm_brand {
  display: flex;
  align-items: center;
  gap: 11.05px;
  width: auto;
}

.bm_brandLogo {
  width: 48.19px;
  height: 55.43px;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(1);
}

.bm_brandText {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2.76px;
  text-align: left;
}

.bm_brandTitle {
  font-family: "League Spartan", system-ui, sans-serif;
  font-weight: 400;
  font-size: 23.4887px;
  line-height: 22px;
  letter-spacing: 0.02em;
  color: var(--light);
}

.bm_brandSub {
  font-family: "League Spartan", system-ui, sans-serif;
  font-weight: 300;
  font-size: 16.5803px;
  line-height: 15px;
  color: rgba(252, 252, 252, 0.65);
  white-space: nowrap;
}

.bm_close {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  padding: 8px;
  border: 1px solid transparent;
  border-radius: 4px;
  background: #2b2e33;
  cursor: pointer;
  transition:
    border-color 200ms ease,
    background-color 200ms ease;
}

.bm_closeIcon {
  position: relative;
  width: 14px;
  height: 14px;
}

.bm_closeIcon::before,
.bm_closeIcon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 18px;
  border-top: 2px solid var(--light);
  transform-origin: center;
  transition: border-top-color 200ms ease;
}

.bm_closeIcon::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.bm_closeIcon::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.bm_langBtn:hover,
.bm_langBtn:focus-visible {
  background: rgba(252, 252, 252, 0.65);
  border-color: rgba(17, 21, 29, 0.95);
  color: var(--dark);
}

.bm_langBtn.is-active:hover,
.bm_langBtn.is-active:focus-visible {
  background: rgba(245, 240, 232, 0.85);
  border-color: rgba(17, 21, 29, 0.95);
  color: var(--dark);
}

.bm_contact {
  height: 62px;
  padding: 18px 32px;
  border-radius: 6px;
  border: 1px solid var(--dark);
  background: var(--gold);
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 26px;
  letter-spacing: 0.02em;
  color: var(--dark);
  white-space: nowrap;
  cursor: pointer;
  transition:
    background-color 200ms ease,
    color 200ms ease,
    border-color 200ms ease;
}

.bm_contact:hover,
.bm_contact:focus-visible {
  background: var(--cream);
  border-color: var(--dark);
  color: var(--dark);
}

.bm_close:hover,
.bm_close:focus-visible {
  border-color: var(--gold);
  background-color: #2f333a;
}

.bm_close:hover .bm_closeIcon::before,
.bm_close:hover .bm_closeIcon::after,
.bm_close:focus-visible .bm_closeIcon::before,
.bm_close:focus-visible .bm_closeIcon::after {
  border-top-color: var(--gold);
}

.bm_bottom {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 120px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  will-change: transform, opacity;
  transition:
    transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease;
}

.bm_panel {
  opacity: 0;
  transform: translate3d(28px, 0, 0);
  will-change: transform, opacity;
  transition:
    transform 420ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 220ms ease;
}

.bm.is-open .bm_backdrop {
  opacity: 1;
}

.bm.is-open .bm_shell {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.bm.is-open .bm_side {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: 60ms;
}

.bm.is-open .bm_panel {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: 100ms;
}

.bm.is-open .bm_lang {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: 150ms;
}

.bm.is-open .bm_bottom {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: 170ms;
}

.bm.is-open .bm_link {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.bm.is-open .bm_link:nth-child(1) { transition-delay: 140ms; }
.bm.is-open .bm_link:nth-child(2) { transition-delay: 180ms; }
.bm.is-open .bm_link:nth-child(3) { transition-delay: 220ms; }
.bm.is-open .bm_link:nth-child(4) { transition-delay: 260ms; }
.bm.is-open .bm_link:nth-child(5) { transition-delay: 300ms; }
.bm.is-open .bm_link:nth-child(6) { transition-delay: 340ms; }

.bm_copy {
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 19px;
  letter-spacing: 0.02em;
  color: var(--dark);
}

/* =========================
   Custom select
========================= */
.uiSelect {
  position: relative;
  width: 100%;
}

.uiSelect_native {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.uiSelect_btn {
  width: 100%;
  height: 56px;
  padding: 0 44px 0 16px;
  border-radius: 6px;
  border: 1px solid #2b2e33;
  background: rgba(17, 21, 29, 0.85);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  font-family: "Lato", system-ui, sans-serif;
  color: var(--light);
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    color 120ms ease;
}

.uiSelect.is-placeholder .uiSelect_btn {
  color: var(--border);
}

.uiSelect_btn:hover,
.uiSelect_btn:focus-visible {
  background-color: var(--muted);
  border-color: var(--muted);
  color: var(--dark);
}

.uiSelect_arrow {
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 7px solid currentColor;
  opacity: 0.95;
  transform: translateY(1px);
  transition: transform 160ms ease;
}

.uiSelect.is-open .uiSelect_arrow {
  transform: translateY(1px) rotate(180deg);
}

.uiSelect_list {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 20010;
  display: none;
  max-height: 280px;
  overflow: auto;
  padding: 6px;
  background: rgba(17, 21, 29, 0.98);
  border: 1px solid #2b2e33;
  border-radius: 8px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.uiSelect.is-open .uiSelect_list {
  display: block;
}

.uiSelect_opt {
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--light);
  cursor: pointer;
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  line-height: 18px;
  transition:
    background-color 140ms ease,
    color 140ms ease;
}

.uiSelect_opt:hover,
.uiSelect_opt:focus-visible {
  background: var(--gold);
  color: var(--dark);
  outline: none;
}

.uiSelect_opt.is-selected {
  background: rgba(222, 209, 150, 0.28);
}

.uiSelect_opt:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.field_select option {
  background: rgba(17, 21, 29, 0.98);
  color: var(--light);
}

.field_select option:checked {
  background: var(--gold);
  color: var(--dark);
}

/* =========================
   Reduced motion
========================= */
@media (prefers-reduced-motion: reduce) {
  .bm,
  .bm_backdrop,
  .bm_shell,
  .bm_panel,
  .bm_lang,
  .bm_side,
  .bm_bottom,
  .bm_link,
  .burger,
  .nav_logo,
  .bm_langBtn,
  .bm_contact,
  .bm_close,
  .bm_closeIcon::before,
  .bm_closeIcon::after,
  #contactsForm .field_input,
  #contactsForm .field_select,
  #contactsForm .field_textarea,
  #careersForm .field_input,
  #careersForm .field_select,
  #careersForm .field_textarea,
  #contactsForm .uiSelect_btn,
  #careersForm .uiSelect_btn,
  .scrollUp,
  .scrollUp::before,
  .contact_send {
    transition: none !important;
    transform: none !important;
    animation: none !important;
  }
}

/* =========================
   Hero / start
========================= */
.start {
  --hero-title-color: var(--dark);
  --hero-lines-color: var(--light);
  --hero-lines-thickness: 1.6px;
  --hero-lines-step: 5px;
  --hero-lines-pad-y: 18px;
  --hero-lines-pad-x: 22px;
  --hero-lines-inset-y: 10px;
  --hero-lines-inset-x: 12px;

  position: relative;
  width: 100%;
  height: clamp(560px, 62vw, 760px);
  min-height: 560px;
  overflow: hidden;
  background: var(--dark);
}

.start_bgVideo,
.start_bgImg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 26%;
  pointer-events: none;
}

.start_bgVideo {
  display: none;
}

.start.start--video .start_bgVideo {
  display: block;
}

.start.start--video .start_bgImg {
  display: none;
}

.start_inner {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.hero {
  width: 100%;
  margin-top: 298px;
  display: flex;
}

.hero_titleRow {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0 var(--pad);
}

.hero_titleBox {
  display: inline-block;
  position: relative;
}

.hero_title {
  position: relative;
  margin: 0;
  font-family: "Bree Serif", serif;
  font-weight: 400;
  font-size: 64px;
  line-height: 58px;
  color: var(--hero-title-color);
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.12);
}

.hero_titleText {
  position: relative;
  z-index: 1;
  display: inline-block;
  padding: var(--hero-lines-pad-y) var(--hero-lines-pad-x);
}

.hero_titleText::before {
  content: "";
  position: absolute;
  inset: calc(var(--hero-lines-inset-y) * -1) calc(var(--hero-lines-inset-x) * -1);
  z-index: -1;
  background: repeating-linear-gradient(
    to bottom,
    var(--hero-lines-color) 0 var(--hero-lines-thickness),
    transparent var(--hero-lines-thickness) var(--hero-lines-step)
  );
}

@media (max-width: 900px) {

  .start {
    height: clamp(500px, 78vw, 640px);
    min-height: 500px;
  }

  .start_bgVideo,
  .start_bgImg {
    object-position: 58% 22%;
  }

  .hero {
    margin-top: clamp(210px, 34vw, 270px);
  }
}

@media (max-width: 640px) {

  .start {
    height: clamp(420px, 138vw, 520px);
    min-height: 420px;

    --hero-lines-thickness: 1px;
    --hero-lines-step: 4px;
  }

  .start_bgVideo,
  .start_bgImg {
    object-position: 62% 18%;
  }

  .hero {
    margin-top: clamp(170px, 52vw, 240px);
  }

  .hero_titleRow {
    padding: 0 18px;
  }

  .hero_title {
    font-size: clamp(40px, 11vw, 54px);
    line-height: 0.95;
  }
}

@media (max-width: 420px) {
  .start {
    height: clamp(390px, 145vw, 500px);
  }

  .start_bgVideo,
  .start_bgImg {
    object-position: 64% 16%;
  }
}

/* ==========================================================================
   4) Global layout helpers
========================================================================== */
.page-wrap {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
}

.talk-float + .page-wrap {
  padding-bottom: 80px;
}

@media (min-width: 641px) {
  .talk-float + .page-wrap.legal-page,
  .talk-float + .page-wrap.page-wrap--project-detail {
    padding-bottom: 160px;
  }
}

.section {
  padding: 100px 100px;
}

.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 44px;
}

.section-header h2 {
  font-size: clamp(26px, 3vw, 42px);
  letter-spacing: 0%;
  line-height: 52px;
}

.sub-line {
  margin: -36px 0 44px;
  font-family: var(--fontSecond);
  font-size: 14px;
  font-weight: 400;
  color: var(--text);
}

/* ==========================================================================
   5) Buttons
========================================================================== */
.btn-ghost {
  margin-left: auto;
  padding: 10px 18px;
  border: 1px solid transparent;
  border-radius: var(--r-md);
  background: none;
  font-family: var(--fontSecond);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0%;
  color: var(--text);
  cursor: pointer;
  transition:
    color 0.2s,
    border-color 0.9s,
    background-color 0.5s ease;
}

.btn-ghost:hover {
  background-color: var(--gold);
  opacity: 0.9;
}

.arrow-btn {
  width: 0%;
  height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--dark);
  border-radius: 275%;
  background: none;
  font-size: 18px;
  cursor: pointer;
  transition: 0.2s;
}

.arrow-btn:hover {
  color: #fff;
}

/* ==========================================================================
   6) Index — Portfolio
========================================================================== */
.portfolio-header {
  display: flex;
  align-items: flex-end;
  margin-bottom: 80px;
}

.portfolio-label {
  margin: 0 0 16px;
  font-family: var(--fontSecond);
  font-size: 12px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: #9ca3af;
}

.portfolio-title {
  margin: 0;
  font-family: var(--fontMain);
  font-weight: 400;
  font-size: clamp(26px, 4vw, 42px);
  letter-spacing: 0%;
  line-height: 52px;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 48px;
}

.project-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 24px;
  border: 1px solid #e5e7eb;
  border-radius: var(--r-lg);
  background: #fff;
  cursor: pointer;
  transition:
    transform 300ms ease,
    box-shadow 300ms ease,
    opacity 1300ms ease;
}

.project-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}

.project-card-img-wrap {
  overflow: hidden;
  border-radius: var(--r-md);
}

.project-card svg image {
  transition: opacity 700ms ease;
}

.project-card-img-wrap .image-hover {
  opacity: 0;
}

.project-card:hover .image-hover {
  opacity: 1;
}

.project-card-title {
  font-family: var(--fontSecond);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 700;
  letter-spacing: 0%;
  color: var(--text);
  line-height: 52px;
}

.project-card-desc {
  margin: 0;
  font-family: var(--fontSecond);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text);
}

.project-card-cta {
  padding-top: 8px;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: var(--text);
  font-family: var(--fontSecond);
  font-weight: 500;
  opacity: 0;
  transition: all 0.3s ease;
}

.project-card:hover .project-card-cta {
  opacity: 1;
}

/* ==========================================================================
   7) Index — Integrated Compliance (carousel)
========================================================================== */
.compliance-body {
  display: flex;
  flex-direction: column;
  gap: 48px;
  font-family: var(--fontSecond);
}

@media (min-width: 1024px) {
  .compliance-body {
    flex-direction: row;
    gap: 48px;
  }
}

.compliance-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.compliance-right {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 240px;
  color: var(--muted);
}

.gradient-border {
  position: relative;
  padding: 2px;
  border-radius: var(--r-md);
  background: linear-gradient(
    270deg,
    #e5e7eb,
    #f9fafb,
    #ffffff,
    #f3f4f6,
    #e5e7eb
  );
  background-size: 300% 300%;
  animation: rotateBorder 8s ease infinite;
  box-shadow: rgba(0, 0, 0, 0.15) -15px 25px 40px;
  opacity: 0.85;
}

.gradient-border-inner {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 32px;
  border-radius: 4px;
  background: #f3f3f3;
}

#comp-title {
  font-family: var(--fontSecond);
  font-weight: 400;
  color: var(--text);
  letter-spacing: 2%;
  line-height: 100%;
}

.gradient-border-inner h3 {
  margin: 0 0 16px;
  font-size: 24px;
  font-weight: 600;
}

.gradient-border-inner p {
  margin: 0;
  line-height: 1.6;
}

.comp-body-inner {
  position: relative;
  flex: 1;
  overflow: hidden;
  padding: 24px;
}

.comp-body-inner p {
  margin-bottom: 18px;
  font-size: 16px;
  line-height: 24px;
  letter-spacing: 0%;
  font-weight: 400;
  color: var(--text);
}

.compliance-nav {
  display: flex;
  align-items: center;
  gap: 24px;
  align-self: flex-start;
  margin-top: 10px;
}

.comp-arrows {
  display: flex;
  align-items: center;
  gap: 12px;
}

.comp-arr {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 2px;
  background: transparent;
  font-size: 24px;
  color: var(--dark);
  cursor: pointer;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease,
    transform 0.15s ease;
}

.comp-arr:hover {
  background: var(--dark);
  border-color: var(--dark);
  color: #fff;
}

.comp-arr:active {
  transform: scale(0.92);
}

#comp-counter {
  min-width: 52px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

.comp-progress {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 32px;
}

.comp-progress-seg {
  position: relative;
  flex: 1;
  height: 2px;
  overflow: hidden;
  border-radius: 2px;
  background: var(--border);
}

.comp-progress-seg::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 2px;
  background: var(--dark);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.comp-progress-seg.active::after {
  transform: scaleX(1);
}

#comp-num-tag,
#comp-title,
#comp-desc,
#comp-body {
  will-change: opacity, transform;
  transition: opacity 0.3s ease;
  color: var(--text);
  opacity: 1;
}

.comp-num-tag {
  display: inline-block;
  margin-bottom: 16px;
  padding: 3px 12px;
  border: 1px solid var(--border);
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  transition:
    opacity 0.25s ease,
    transform 0.25s ease;
}

.compliance-body,
.compliance-left,
.compliance-right,
.gradient-border,
.comp-body-inner,
.compliance-nav {
  opacity: 0;
  transform: translateY(22px) scale(0.985);
  transition:
    opacity 640ms cubic-bezier(0.2, 0.65, 0.2, 1),
    transform 640ms cubic-bezier(0.2, 0.65, 0.2, 1);
  transition-delay: var(--anim-delay, 0ms);
  will-change: opacity, transform;
}

.compliance-body.is-inview,
.compliance-left.is-inview,
.compliance-right.is-inview,
.gradient-border.is-inview,
.comp-body-inner.is-inview,
.compliance-nav.is-inview {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.comp-layout,
.comp-sidebar,
.comp-body,
.comp-cta {
  opacity: 0;
  transform: translateY(22px) scale(0.985);
  transition:
    opacity 640ms cubic-bezier(0.2, 0.65, 0.2, 1),
    transform 640ms cubic-bezier(0.2, 0.65, 0.2, 1);
  transition-delay: var(--anim-delay, 0ms);
  will-change: opacity, transform;
}

.comp-layout.is-inview,
.comp-sidebar.is-inview,
.comp-body.is-inview,
.comp-cta.is-inview {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* ==========================================================================
   8) Shared — Team
========================================================================== */
.team-grid {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 42px 55.33px;
}

.team-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: pointer;
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
}

.team-img-wrap {
  position: relative;
  width: 100%;
  height: 346.25px;
  flex-shrink: 0;
  overflow: hidden;
  border-radius: var(--r-md);
  background: #e5e5e5;
}

.team-img-wrap .img-cover {
  position: absolute;
  inset: 0;
}

.team-img-wrap img {
  border-radius: var(--r-md);
  object-position: center;
}

.team-img-wrap:not(:has(img[src])) {
  background: #d8d8d8;
}

.team-card-description {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.team-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 59px;
}

.team-card-meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.team-card-head h3 {
  margin: 0;
  font-family: var(--fontSecond);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  color: var(--text);
}

.team-card-role {
  font-family: var(--fontSecond);
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  color: var(--text);
}

.in-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 22px;
  border: 1px solid #c2c2c2;
  background: #fcfcfc;
  color: #11151d;
  transition:
    background 0.2s ease,
    border-color 0.2s ease;
}

.in-icon:hover {
  background: #c2c2c2;
  border-color: #aaa;
}

.desc-toggle-btn {
  margin-left: 8px;
  padding: 0;
  cursor: pointer;
}

.desc-toggle-btn span {
  font-size: 22px;
  line-height: 1;
}

.team-card-bio {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  margin-top: 0;
  transition:
    max-height 0.4s ease,
    opacity 0.35s ease,
    margin-top 0.4s ease;
}

.team-card-bio p {
  margin: 0;
  font-family: var(--fontSecond);
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
  color: #000;
}

.team-card.is-open .team-card-bio {
  max-height: 200px;
  opacity: 1;
  margin-top: 10px;
}

.team-card.team-card-hidden {
  position: absolute;
  visibility: hidden;
  opacity: 0;
  transform: scale(0.95);
  pointer-events: none;
}

.partners-section {
  padding-top: 20px;
}

.partners-marquee {
  position: relative;
  overflow: hidden;
  width: 100%;
  margin-top: 26px;
  padding: 14px 0;
  border-top: 1px solid rgba(190, 173, 95, 0.38);
  border-bottom: 1px solid rgba(190, 173, 95, 0.38);
  background-color: #fcfcfc;
}

.partners-marquee::before,
.partners-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(22px, 8vw, 88px);
  pointer-events: none;
  z-index: 1;
}

.partners-marquee::before {
  left: 0;
  background: linear-gradient(90deg, #fcfcfc 14%, rgba(252, 252, 252, 0) 100%);
}

.partners-marquee::after {
  right: 0;
  background: linear-gradient(270deg, #fcfcfc 14%, rgba(252, 252, 252, 0) 100%);
}

.partners-track {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  width: max-content;
  min-width: 100%;
  padding: 0 10px;
  animation: partnersMarquee 21s linear infinite;
}

.partners-marquee:hover .partners-track {
  animation-play-state: paused;
}

.partner-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 72px;
  padding: 10px 24px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  white-space: nowrap;
  transition: transform 220ms ease;
}

.partner-logo {
  min-width: 236px;
}

.partner-logo img {
  display: block;
  width: auto;
  max-width: 204px;
  height: 48px;
  object-fit: contain;
  filter: grayscale(1) saturate(0) contrast(1.1) brightness(0.62);
  transition: filter 220ms ease;
}

.partner-pill:hover {
  transform: translateY(-2px);
}

.partner-pill:hover img {
  filter: none;
}

@keyframes partnersMarquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

.more-emp {
  margin-top: 32px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-family: var(--fontSecond);
  font-weight: 700;
  font-size: 15px;
  color: var(--text);
}

.more-badge {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 25px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  background: var(--white);
  font-size: 17px;
}

/* ==========================================================================
   9) Compliance page — Tabs layout
========================================================================== */
.comp-layout {
  display: grid;
  grid-template-columns: 268px 1fr;
  gap: 0;
  padding: 64px 48px;
}

.comp-sidebar {
  margin-right: 24px;
  padding: 20px 24px;
  border-radius: 3px;
  background: #f3f3f3;
  font-family: var(--fontSecond);
  font-weight: 400;
}

.comp-sidebar-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
  padding: 13px 0;
  cursor: pointer;
  font-size: 14px;
  color: var(--text);
  transition:
    color 0.3s ease,
    padding-left 0.3s ease;
}

.comp-sidebar-item::before {
  content: "";
  position: absolute;
  left: -24px;
  top: 0;
  width: 5px;
  height: 100%;
  border-radius: 0 3px 3px 0;
  background: #bead5f;
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.comp-sidebar-item:hover {
  color: var(--dark);
  padding-left: 6px;
}

.comp-sidebar-item:hover::before {
  transform: scaleY(1);
  transform-origin: top;
}

.comp-sidebar-item.active {
  color: var(--dark);
  padding-left: 6px;
}

.comp-sidebar-item.active::before {
  transform: scaleY(1);
}

.comp-num {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #bead5f;
  transition:
    letter-spacing 0.3s ease,
    opacity 0.3s ease;
}

.comp-sidebar-item:hover .comp-num,
.comp-sidebar-item.active .comp-num {
  letter-spacing: 0.08em;
  opacity: 1;
}

.comp-sidebar-item span:last-child {
  display: inline-block;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.comp-sidebar-item:hover span:last-child,
.comp-sidebar-item.active span:last-child {
  transform: translateX(3px);
}

.comp-body {
  padding-left: 56px;
  font-family: var(--fontSecond);
  opacity: 1;
  transition: opacity 300ms ease;
}

.comp-body.is-transitioning {
  opacity: 0;
}

.comp-content-gradient {
  opacity: 1;
  box-shadow: none;
}

.comp-body-rest {
  padding: 32px;
}

.comp-body h2 {
  margin-bottom: 22px;
  font-family: var(--fontThird);
  font-size: clamp(22px, 2.8vw, 34px);
  font-weight: 500;
}

.comp-body p {
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--text);
}

.comp-cta {
  margin: 0 48px 0;
  padding: 80px 48px;
  font-family: var(--fontSecond);
  text-align: center;
}

.comp-cta h2 {
  margin-bottom: 10px;
  font-size: clamp(24px, 3vw, 42px);
}

.comp-cta p {
  margin-bottom: 28px;
  font-size: 13px;
  color: var(--text);
}

/* ==========================================================================
   10) About page — Mission
========================================================================== */
.mission {
  position: relative;
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 84px 128px;
  display: grid;
  grid-template-columns: minmax(260px, 420px) 1fr;
  align-items: center;
  gap: clamp(28px, 6vw, 96px);
  overflow: visible;
}

.mission-left {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  width: 100%;
  max-width: 460px;
}

.mission-icon {
  position: relative;
  width: 44px;
  height: 64px;
  flex-shrink: 0;
}

.mission-icon svg {
  display: block;
}

.mission-left h2 {
  margin: 0;
  width: auto;
  font-family: var(--fontMain);
  font-size: 42px;
  line-height: 52px;
  font-weight: 400;
  color: var(--text);
}

.mission-left h2::after {
  content: "";
  display: block;
  width: 104px;
  height: 0;
  margin-top: 24px;
  border-top: 1.6px solid #ded196;
}

.mission-left p {
  margin: 0;
  width: auto;
  max-width: 46ch;
  font-family: var(--fontSecond);
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  color: var(--text);
}

.mission-right {
  position: relative;
  left: auto;
  top: auto;
  width: 100%;
  height: auto;
  pointer-events: none;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mission-right .img-cover {
  position: relative;
  left: auto;
  top: auto;
  width: min(720px, 100%);
  aspect-ratio: 1 / 1;
}

.mission-right .img-cover svg {
  display: block;
  width: 100%;
  height: 100%;
}

/* ==========================================================================
   11) Contacts page — FAQ
   ========================================================================== */
.faq-section {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 128px 80px;
}

.faq-section h2 {
  margin-bottom: 64px;
  text-align: center;
  font-family: var(--fontMain);
  font-size: 38px;
  line-height: 52px;
  font-weight: 400;
}

.faq-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 64px;
}

.faq-inner > div:first-child {
  width: 529px;
}

.faq-cat {
  margin: 24px 0 12px;
  font-family: var(--fontThird);
  font-size: 18px;
  font-weight: 600;
}

.faq-item {
  margin-bottom: 8px;
  border-radius: var(--r-md);
  overflow: hidden;
}

.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 18px 12px 12px;
  border: 1px solid #e5e5e5;
  border-radius: var(--r-md);
  background: #fff;
  font-family: var(--fontSecond);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition:
    background-color 0.3s ease,
    border-color 0.3s ease;
}

.faq-q > span:first-child {
  flex: 1 1 auto;
  min-width: 0;
}

.faq-item.open .faq-q {
  background: #ded196;
  border-color: #ded196;
}

.faq-toggle {
  flex: 0 0 20px;
  min-width: 20px;
  text-align: center;
  line-height: 1;
  font-size: 14px;
  font-weight: 800;
  transition: transform 0.3s ease;
}

.faq-item.open .faq-toggle {
  transform: rotate(45deg);
}

.faq-a {
  max-height: 0;
  overflow: hidden;
  padding: 0 24px;
  font-family: var(--fontSecond);
  font-size: 14px;
  line-height: 28px;
  transition:
    max-height 0.4s ease,
    padding 0.4s ease;
}

.faq-item.open .faq-a {
  max-height: 300px;
  padding: 16px 24px 24px;
}

.faq-still {
  margin-top: 24px;
  text-align: center;
}

.faq-still h3 {
  margin-bottom: 12px;
  font-family: var(--fontMain);
  font-size: 18px;
  font-weight: 500;
}

.faq-still p {
  font-family: var(--fontSecond);
  font-size: 14px;
  line-height: 22px;
}

.faq-still a {
  color: var(--text);
  text-decoration: underline;
}

.btn-frmn-wrap {
  width: 147px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  z-index: 1;
  background: var(--light);
  border: 1px solid var(--border);
  border-radius: 32px;
}

.btn-frmn {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--gold);
  border: 1px solid #bead5f;
  color: #1b1c1e;
  font-weight: 600;
  text-decoration: none;
  transform: translateY(0) scale(1);
  box-shadow: 0 2px 0 #9f8f45, 0 8px 18px rgba(38, 33, 13, 0.12);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
  will-change: transform, box-shadow;
}

.btn-frmn::before {
  content: "";
  position: absolute;
  inset: -120% auto -120% -35%;
  width: 36%;
  background: linear-gradient(120deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.75) 50%, rgba(255, 255, 255, 0) 100%);
  transform: translateX(-120%) rotate(18deg);
  transition: transform 460ms cubic-bezier(0.2, 0.85, 0.25, 1);
  pointer-events: none;
}

.btn-frmn:hover,
.btn-frmn:focus-visible {
  border-color: #8d7f3b;
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 3px 0 #8d7f3b, 0 14px 30px rgba(38, 33, 13, 0.2);
}

.btn-frmn:hover::before,
.btn-frmn:focus-visible::before {
  transform: translateX(360%) rotate(18deg);
}

.btn-frmn:active {
  transform: translateY(0) scale(0.99);
  box-shadow: 0 1px 0 #8d7f3b, 0 6px 12px rgba(38, 33, 13, 0.15);
}

@media (prefers-reduced-motion: reduce) {
  .btn-frmn,
  .btn-frmn::before {
    transition: none;
  }

  .btn-frmn:hover,
  .btn-frmn:focus-visible,
  .btn-frmn:active {
    transform: none;
  }
}

.faq-still-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  text-align: center;
}

.faq-right-img {
  position: relative;
  width: clamp(380px, 40vw, 520px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(12px, 1.8vw, 18px);
  border: 0.8px solid #ceced0;
  background: #fff;
}

.faq-right-img .img-cover {
  border: 0.8px solid #ceced0;
  aspect-ratio: 2 / 3;
}

.label-center {
  position: static;
  align-self: center;
  font-family: "League Spartan", sans-serif;
  font-size: clamp(9px, 1.2vw, 12px);
  line-height: 1.1;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--text);
  white-space: nowrap;
}

/* ==========================================================================
   12) Projects page — Filters + Masonry
   ========================================================================== */
.page-wrap {
  --projects-inline-pad: 110px;
}

.filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  padding: 48px var(--projects-inline-pad) 0;
  font-family: var(--fontSecond);
}

.proj-search-wrap {
  flex: 1 1 360px;
  max-width: 620px;
  min-width: 240px;
}

.proj-search {
  width: 100%;
  height: 42px;
  padding: 0 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: #fff;
  color: var(--dark);
  font-family: var(--fontSecond);
  font-size: 15px;
  line-height: 1.2;
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.proj-search::placeholder {
  color: var(--muted);
}

.proj-search:hover {
  border-color: #ccb86d;
  box-shadow: 0 6px 18px rgba(222, 209, 150, 0.3);
}

.proj-search:focus {
  outline: none;
  border-color: #ccb86d;
  box-shadow: 0 6px 18px rgba(222, 209, 150, 0.3);
}

.proj-filter-select-wrap {
  position: relative;
  flex: 0 1 240px;
  min-width: 180px;
}

.proj-filter-menu {
  position: relative;
  width: 100%;
  min-width: 0;
}

.proj-filter-trigger {
  width: 100%;
  min-width: 0;
  height: 42px;
  padding: 0 42px 0 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background-color: #fff;
  color: var(--dark);
  font-family: var(--fontSecond);
  font-size: 15px;
  line-height: 1.2;
  text-align: left;
  cursor: pointer;
  background-image:
    linear-gradient(45deg, transparent 50%, #b39a3f 50%),
    linear-gradient(135deg, #b39a3f 50%, transparent 50%);
  background-position: calc(100% - 22px) 18px, calc(100% - 16px) 18px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  transition:
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.proj-filter-trigger:hover {
  border-color: var(--gold);
  box-shadow: 0 6px 18px rgba(222, 209, 150, 0.3);
}

.proj-filter-trigger:focus,
.proj-filter-trigger:focus-visible,
.proj-filter-menu.is-open .proj-filter-trigger {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 6px 18px rgba(222, 209, 150, 0.3);
  background-color: #fffdf6;
}

.proj-filter-list {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 40;
  display: none;
  border: 1px solid #ccb86d;
  border-radius: 8px;
  background: #fffdf6;
  box-shadow: 0 18px 28px rgba(17, 21, 29, 0.14);
  overflow: hidden;
}

.proj-filter-menu.is-open .proj-filter-list {
  display: flex;
  flex-direction: column;
}

.proj-filter-option {
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(204, 184, 109, 0.38);
  background: transparent;
  color: var(--dark);
  text-align: left;
  padding: 11px 14px;
  font-family: var(--fontSecond);
  font-size: 15px;
  line-height: 1.2;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease;
}

.proj-filter-option:last-child {
  border-bottom: 0;
}

.proj-filter-option:hover,
.proj-filter-option:focus-visible {
  background: #f4eac6;
  color: #11151d;
  outline: none;
}

.proj-filter-option.is-selected {
  background: #efe0a6;
}

.proj-filter-select-native {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  opacity: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  pointer-events: none;
  white-space: nowrap;
}

.proj-wrap {
  padding: 48px var(--projects-inline-pad) 80px;
  font-family: var(--fontSecond);
}

.proj-masonry {
  max-width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 56px 40px;
}

.proj-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.6s ease-in-out;
}

.proj-item.visible {
  opacity: 1;
}

.proj-item:nth-child(1) {
  transition-delay: 0s;
}

.proj-item:nth-child(2) {
  transition-delay: 0.1s;
}

.proj-item:nth-child(3) {
  transition-delay: 0.2s;
}

.proj-item.proj-item--large {
  grid-column: span 2;
}

.proj-item.proj-item--large .proj-photo {
  padding-top: calc(520 / 1160 * 100%);
}

.proj-item.proj-item--small {
  grid-column: span 1;
}

.proj-item.proj-item--small .proj-photo {
  padding-top: calc(420 / 560 * 100%);
}

.proj-item[style*="display: none"] {
  opacity: 0;
  display: none !important;
}

.proj-photo {
  position: relative;
  width: 100%;
  padding-top: calc(460 / 568 * 100%);
  overflow: hidden;
  isolation: isolate;
  border-radius: var(--r-md);
}

.proj-photo img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--r-md);
  transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.proj-item:hover .proj-photo img {
  transform: scale(1.04);
}

.proj-hover-overlay {
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  z-index: 1;
  height: 63.9%;
  display: flex;
  align-items: flex-end;
  padding: 0 26px 24px;
  border: solid var(--border);
  border-width: 0 1px 1px;
  border-radius: 0 0 var(--r-md) var(--r-md);
  background: linear-gradient(
    183.77deg,
    rgba(255, 255, 255, 0) 15.92%,
    #fcfcfc 69.39%
  );
  opacity: 0;
  transition: opacity 0.3s ease;
}

.proj-item:hover .proj-hover-overlay {
  opacity: 1;
}

.proj-hover-text {
  display: -webkit-box;
  overflow: hidden;
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
  color: #000;
  line-clamp: 5;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
}

.proj-desc {
  display: flex;
  align-items: center;
  gap: 18px;
  min-height: 52px;
}

.proj-name {
  font-size: 24px;
  font-weight: 700;
  line-height: 52px;
  color: var(--dark);
  white-space: nowrap;
}

/* =========================
   File attachment chip (shared)
========================= */
.fileAttach {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 6px;
  border: 1px solid var(--fileAttach-border);
  background: var(--fileAttach-bg);
  color: var(--fileAttach-text);
  font-family: "Lato", system-ui, sans-serif;
}

.fileAttach.is-visible {
  display: flex;
}

.fileAttach_size {
  flex: 0 0 auto;
  font-size: 12px;
  line-height: 16px;
  color: var(--fileAttach-muted);
  white-space: nowrap;
}

.fileAttach_name {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  font-size: 14px;
  line-height: 18px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.fileRemoveBtn {
  position: relative;
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  margin: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  outline: none;
  box-shadow: none;
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

.fileRemoveBtn_icon {
  position: relative;
  display: block;
  width: 14px;
  height: 14px;
}

.fileRemoveBtn_icon::before,
.fileRemoveBtn_icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  border-top: 1.8px solid currentColor;
  transform-origin: center;
}

.fileRemoveBtn_icon::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.fileRemoveBtn_icon::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.contactsSection,
.careersForm {
  --fileAttach-bg: #efefef;
  --fileAttach-border: #c2c2c2;
  --fileAttach-text: var(--dark);
  --fileAttach-muted: #959ba0;
}

/* ==========================================================================
   13) Responsive (generic set)
   ========================================================================== */
@media (min-width: 1600px) {
  :root {
    --pad: clamp(32px, 6vw, 180px);
  }

  .start {
    height: 820px;
  }
}

@media (max-width: 1440px) {
  .bm_content {
    top: 28px;
    left: 40px;
    right: 40px;
    bottom: 28px;
    gap: 24px;
  }

  .bm_panel {
    width: min(400px, calc(100vw - 180px));
    padding: 24px 34px 24px 24px;
  }

  .bm_menu {
    gap: 18px;
  }

  .bm_link {
    font-size: clamp(24px, 2.5vw, 30px);
    line-height: 1.18;
  }

  .bm_linkText {
    white-space: normal;
  }

  .bm_side {
    top: 28px;
    right: 40px;
    left: auto;
  }

  .bm_bottom {
    left: 40px;
    right: 40px;
    bottom: 28px;
    padding: 0;
    justify-content: space-between;
    align-items: flex-end;
    gap: 20px;
  }

  .bm_copy {
    max-width: 52%;
    font-size: 14px;
    line-height: 18px;
    white-space: normal;
  }

  .bm_contact {
    height: 56px;
    padding: 14px 28px;
    font-size: 18px;
    line-height: 22px;
  }
}

@media (max-width: 1200px) {
  .faq-section {
    padding: 0 48px 72px;
  }

  .faq-section h2 {
    margin-bottom: 48px;
  }

  .faq-inner {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }

  .faq-inner > div:first-child {
    width: 100%;
    max-width: 600px;
  }
}

@media (max-width: 1024px) {
  .team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mission {
    grid-template-columns: 1fr;
    padding: 56px 24px;
    justify-items: center;
    text-align: center;
  }

  .mission-left {
    align-items: center;
    max-width: 640px;
  }

  .mission-left p {
    max-width: 60ch;
  }
}

@media (max-width: 980px) {
  .bm_content {
    top: 24px;
    left: 24px;
    right: 24px;
    bottom: 24px;
    min-height: calc(100dvh - 48px);
    gap: 24px;
  }

  .bm_panel {
    width: min(420px, calc(100vw - 120px));
    min-height: auto;
    padding: 28px 36px 28px 28px;
    background: rgba(123, 127, 134, 0.42);
  }

  .bm_menu {
    gap: 18px;
  }

  .bm_link {
    font-size: clamp(22px, 3.1vw, 30px);
    line-height: 1.2;
  }

  .bm_linkText {
    white-space: normal;
  }

  .bm_side {
    top: 24px;
    right: 24px;
    left: auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 16px;
  }

  .bm_lang {
    gap: 20px;
    padding-left: 0;
  }

  .bm_bottom {
    left: 24px;
    right: 24px;
    bottom: 24px;
    padding: 0;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
  }

  .bm_copy {
    max-width: 58%;
    font-size: 14px;
    line-height: 18px;
  }

  .bm_contact {
    width: auto;
    min-width: 180px;
    height: 54px;
    padding: 14px 26px;
    font-size: 18px;
    line-height: 22px;
  }
}

@media (max-width: 900px) {
  .page-wrap {
    --projects-inline-pad: 24px;
  }

  .faq-section {
    padding: 0 24px 64px;
  }

  .faq-section h2 {
    margin-bottom: 36px;
    font-size: 32px;
    line-height: 42px;
  }

  .faq-cat {
    margin: 20px 0 10px;
    font-size: 17px;
  }

  .faq-q {
    padding: 14px 16px 14px 12px;
    font-size: 15px;
    line-height: 22px;
  }

  .faq-a {
    padding: 0 16px;
    line-height: 24px;
  }

  .faq-item.open .faq-a {
    padding: 14px 16px 20px;
  }

  .proj-masonry {
    gap: 40px 24px;
  }

  .proj-wrap {
    padding: 32px var(--projects-inline-pad) 60px;
  }

  .filter-bar {
    padding: 16px var(--projects-inline-pad);
    gap: 18px;
    align-items: stretch;
  }

  .proj-search-wrap {
    flex: 1 1 100%;
    max-width: none;
    min-width: 0;
  }

  .proj-filter-select-wrap {
    margin-left: 0;
    width: 100%;
    min-width: 0;
    flex: 1 1 100%;
  }

  .proj-filter-menu,
  .proj-filter-trigger {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .page-wrap {
    --projects-inline-pad: 18px;
  }

  .filter-bar {
    padding: 14px var(--projects-inline-pad);
    gap: 12px;
  }

  .proj-wrap {
    padding: 24px var(--projects-inline-pad) 52px;
  }

  .proj-search,
  .proj-filter-trigger {
    height: 44px;
    font-size: 14px;
  }

  .proj-filter-option {
    padding: 12px 14px;
    font-size: 14px;
  }
}

@media (max-width: 768px) {
  .comp-layout {
    grid-template-columns: 1fr;
  }

  .comp-sidebar {
    margin-right: 0;
  }

  .comp-body {
    padding-left: 0;
    padding-top: 32px;
  }

  .comp-cta,
  .comp-layout {
    margin: 0 0 24px;
    padding: 40px 24px;
  }

  .section {
    padding: 48px 24px;
  }

  .partners-marquee {
    margin-top: 22px;
  }

  .partner-pill {
    min-height: 62px;
    padding: 8px 18px;
  }

  .partner-logo {
    min-width: 206px;
  }

  .partner-logo img {
    max-width: 178px;
    height: 42px;
  }
}

@media (max-width: 740px) {
  .bm_backdrop {
    background: rgba(17, 21, 29, 0.16);
  }

  .bm_content {
    position: absolute;
    top: 14px;
    left: 16px;
    right: 16px;
    bottom: 20px;
    min-height: calc(100dvh - 34px);
    gap: 0;
  }

  .bm_side {
    position: absolute;
    top: 14px;
    left: 16px;
    right: 16px;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
  }

  .bm_brand {
    margin-left: 0;
    gap: 0;
  }

  .bm_brandText {
    display: none;
  }

  .bm_brandLogo {
    width: 40px;
    height: 46px;
  }

  .bm_close {
    width: 42px;
    height: 42px;
    padding: 8px;
    border-radius: 6px;
  }

  .bm_closeIcon {
    width: 13px;
    height: 13px;
  }

  .bm_panel {
    width: 240px;
    min-height: calc(100dvh - 150px);
    padding: 96px 0 112px 8px;
    display: flex;
    flex-direction: column;
    border: 0;
    outline: none;
    box-shadow: none;
    border-radius: 0;
    background: rgba(123, 127, 134, 0.08);
  }

  .bm_panel::before {
    content: none;
  }

  .bm_menu {
    width: 100%;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0;
  }

  .bm_link {
    padding: 0;
    gap: 0;
    font-size: 20px;
    line-height: 1.2;
    white-space: normal;
  }

  .bm_link::after {
    content: none;
  }

  .bm_lang {
    position: absolute;
    top: 92px;
    right: 0;
    padding-left: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
  }

  .bm_langBtn {
    width: 44px;
    height: 44px;
    padding: 6px;
    font-size: 17px;
    line-height: 1;
    border-radius: 8px;
    background: rgba(123, 128, 134, 0.18);
  }

  .bm_bottom {
    position: absolute;
    left: 16px;
    right: auto;
    bottom: 20px;
    padding: 0;
    gap: 0;
    z-index: 2;
  }

  .bm_copy {
    display: none;
  }

  .bm_contact {
    width: 160px;
    min-width: 160px;
    height: 48px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
    border-radius: 6px;
  }
}

@media (max-width: 640px) {
  :root {
    --nav-h: 56px;
  }

  .field--phoneIntl .iti::before {
    left: 14px;
  }

  .field--phoneIntl .iti__country-container {
    left: 86px;
  }

  .field--phoneIntl .iti input.field_input,
  .field--phoneIntl .iti input[type="tel"] {
    padding-left: 214px !important;
  }

  .iti--container:not(.iti--fullscreen-popup) {
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-width: none !important;
  }

  .iti--container:not(.iti--fullscreen-popup) .iti__dropdown-content {
    width: 100% !important;
    max-width: none !important;
  }

  .iti--container.iti--fullscreen-popup .iti__dropdown-content {
    width: 100% !important;
    max-width: none !important;
    max-height: none !important;
    height: 100% !important;
  }

  .iti--container.iti--fullscreen-popup .iti__country-list {
    max-height: none !important;
    height: 100% !important;
  }

  body.phone-country-open {
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
    overflow: hidden;
  }

  body.phone-country-open .contact_shell {
    overflow: hidden !important;
  }

  .iti--container.iti--fullscreen-popup,
  .iti--container.iti--fullscreen-popup .iti__dropdown-content,
  .iti--container.iti--fullscreen-popup .iti__country-list {
    overscroll-behavior: contain;
  }

  .iti--container.iti--fullscreen-popup .iti__country-list {
    -webkit-overflow-scrolling: touch;
  }

  #contactsForm .fileFeedback_msg,
  #careersForm .fileFeedback_msg {
    max-width: none;
  }

  .faq-section {
    padding: 0 16px 56px;
  }

  .faq-section h2 {
    margin-bottom: 28px;
    font-size: 28px;
    line-height: 36px;
  }

  .faq-inner {
    gap: 28px;
  }

  .faq-q {
    padding: 12px 14px 12px 10px;
    font-size: 14px;
    line-height: 20px;
  }

  .faq-a {
    padding: 0 14px;
    font-size: 14px;
    line-height: 22px;
  }

  .faq-item.open .faq-a {
    padding: 12px 14px 18px;
  }

  .faq-still {
    margin-top: 20px;
  }

  .faq-still h3 {
    font-size: 17px;
  }

  .faq-still p {
    font-size: 14px;
    line-height: 22px;
  }

  .faq-right-img {
    display: none;
  }

  .team-grid {
    grid-template-columns: 1fr;
  }

  .proj-masonry {
    grid-template-columns: 1fr;
  }

  .proj-item.proj-item--large,
  .proj-item.proj-item--small {
    grid-column: auto;
  }

  .proj-item.proj-item--large .proj-photo,
  .proj-item.proj-item--small .proj-photo {
    padding-top: calc(460 / 568 * 100%);
  }

  .section {
    padding: 48px 24px;
  }

  .partners-section {
    padding-top: 4px;
  }

  .partners-marquee {
    margin-top: 18px;
    padding: 12px 0;
  }

  .partners-track {
    gap: 10px;
    padding: 0 8px;
    animation-duration: 17.5s;
  }

  .partner-pill {
    min-height: 54px;
    padding: 6px 14px;
  }

  .partner-logo {
    min-width: 176px;
  }

  .partner-logo img {
    max-width: 148px;
    height: 36px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .partners-track {
    animation: none;
  }
}

/* ==========================================================================
   14) Animations
   ========================================================================== */
@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

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

.project-gallery_item {
  cursor: zoom-in;
}

.project-gallery_lightbox {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(10px, 2.2vw, 24px);
  padding-bottom: calc(clamp(10px, 2.2vw, 24px) + env(safe-area-inset-bottom));
  background: rgba(17, 21, 29, 0.92);
}

.project-gallery_lightbox.is-open {
  display: flex;
}

.project-gallery_frame {
  position: relative;
  width: min(1280px, 100%);
  max-height: 94vh;
  display: grid;
  grid-template-columns: 64px 1fr 64px;
  gap: 12px;
  align-items: center;
}

.project-gallery_stage {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(0, 0, 0, 0.35);
}

.project-gallery_stage img {
  display: block;
  width: 100%;
  max-height: calc(100dvh - 170px);
  object-fit: contain;
}

.project-gallery_btn,
.project-gallery_close {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(222, 209, 150, 0.6);
  border-radius: 8px;
  background: rgba(17, 21, 29, 0.65);
  color: #fcfcfc;
  font-size: 24px;
  cursor: pointer;
}

.project-gallery_btn:hover,
.project-gallery_close:hover {
  border-color: var(--gold);
}

.project-gallery_close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
}

.project-gallery_caption {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 12px;
  max-width: 95%;
  margin-inline: auto;
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(17, 21, 29, 0.6);
  color: #fcfcfc;
  font-family: var(--fontSecond);
  font-size: 14px;
  line-height: 1.5;
}

@media (max-width: 1100px) {
  .project-gallery_frame {
    grid-template-columns: 52px 1fr 52px;
    gap: 8px;
  }

  .project-gallery_btn,
  .project-gallery_close {
    width: 44px;
    height: 44px;
    font-size: 22px;
  }
}

@media (max-width: 760px) {
  .project-gallery_lightbox {
    padding: 10px;
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
  }

  .project-gallery_frame {
    grid-template-columns: 1fr;
    max-height: 100dvh;
  }

  .project-gallery_btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
  }

  .project-gallery_btn--prev {
    left: 8px;
  }

  .project-gallery_btn--next {
    right: 8px;
  }

  .project-gallery_close {
    top: 8px;
    right: 8px;
    width: 40px;
    height: 40px;
  }

  .project-gallery_stage img {
    max-height: calc(100dvh - 94px);
  }

  .project-gallery_caption {
    left: 10px;
    right: 10px;
    bottom: 8px;
    padding: 7px 9px;
    font-size: 12px;
    line-height: 1.4;
  }
}

@media (max-width: 460px) {
  .project-gallery_btn {
    width: 38px;
    height: 38px;
    font-size: 20px;
  }

  .project-gallery_stage {
    border-radius: 8px;
  }
}

.project-detail .project-media,
.project-detail .project-category,
.project-detail .project-title,
.project-detail .project-copy,
.project-detail .project-meta_item,
.project-detail .project-gallery_item,
.project-detail .project-section {
  opacity: 1;
  transform: none;
}

.project-detail .project-meta_item,
.project-detail .project-visual_text {
  transition:
    transform 280ms ease,
    opacity 640ms cubic-bezier(0.2, 0.65, 0.2, 1);
}

.project-detail .project-gallery_item {
  overflow: hidden;
}

.project-detail .project-gallery_item img,
.project-detail .project-media img,
.project-detail .project-visual_media img {
  transition: transform 560ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.project-detail .project-gallery_item:hover img,
.project-detail .project-media:hover img,
.project-detail .project-visual_media:hover img {
  transform: scale(1.035);
}

@media (prefers-reduced-motion: reduce) {
  .project-detail .project-media,
  .project-detail .project-category,
  .project-detail .project-title,
  .project-detail .project-copy,
  .project-detail .project-meta_item,
  .project-detail .project-gallery_item,
  .project-detail .project-section {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .project-detail .project-gallery_item img,
  .project-detail .project-media img,
  .project-detail .project-visual_media img,
  .project-detail .project-meta_item,
  .project-detail .project-visual_text {
    transition: none;
  }
}

/* =========================
   Legal pages
========================= */
.legal-page {
  padding: 88px 32px 124px;
}

.legal-shell {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: 32px;
}

.legal-side {
  position: sticky;
  top: 32px;
  height: fit-content;
  display: grid;
  gap: 20px;
}

.legal-panel,
.legal-card {
  background: rgba(252, 252, 252, 0.88);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(17, 21, 29, 0.08);
  border-radius: 24px;
  box-shadow: 0 24px 60px rgba(17, 21, 29, 0.08);
}

.legal-panel {
  padding: 24px;
}

.legal-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(226, 209, 149, 0.22);
  border: 1px solid rgba(190, 173, 95, 0.4);
  font-family: var(--fontSecond);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dark);
}

.legal-side h2,
.legal-content h2 {
  margin: 0;
  font-family: var(--fontMain);
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--dark);
}

.legal-side p,
.legal-content p,
.legal-content li {
  font-family: var(--fontSecond);
  font-size: 16px;
  line-height: 1.72;
  color: rgba(17, 21, 29, 0.82);
}

.legal-side p {
  margin: 14px 0 0;
}

.legal-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.legal-metaItem {
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--light);
  border: 1px solid rgba(17, 21, 29, 0.08);
}

.legal-metaLabel {
  display: block;
  margin-bottom: 6px;
  font-family: var(--fontSecond);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(17, 21, 29, 0.55);
}

.legal-metaValue {
  font-family: var(--fontMain);
  font-size: 17px;
  line-height: 1.2;
  color: var(--dark);
}

.legal-toc {
  display: grid;
  gap: 10px;
}

.legal-toc a {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid transparent;
  font-family: var(--fontSecond);
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  transition:
    transform 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease;
}

.legal-toc a:hover,
.legal-toc a:focus-visible {
  transform: translateX(4px);
  background: rgba(226, 209, 149, 0.16);
  border-color: rgba(190, 173, 95, 0.35);
}

.legal-tocNum {
  flex: 0 0 auto;
  font-family: var(--fontMain);
  font-size: 16px;
  line-height: 1;
  color: var(--gold);
}

.legal-card {
  display: grid;
  gap: 28px;
  padding: 32px;
}

.legal-intro {
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(17, 21, 29, 0.08);
}

.legal-intro p {
  margin: 14px 0 0;
}

.legal-section {
  display: grid;
  gap: 14px;
  scroll-margin-top: 32px;
}

.legal-section + .legal-section {
  padding-top: 28px;
  border-top: 1px solid rgba(17, 21, 29, 0.08);
}

.legal-sectionHeader {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.legal-number {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(226, 209, 149, 0.2);
  border: 1px solid rgba(190, 173, 95, 0.35);
  font-family: var(--fontMain);
  font-size: 16px;
  color: var(--dark);
}

.legal-content h3 {
  margin: 0;
  font-family: var(--fontMain);
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--dark);
}

.legal-content p,
.legal-content ul {
  margin: 0;
}

.legal-content ul {
  display: grid;
  gap: 10px;
  padding-left: 22px;
}

.legal-note {
  padding: 18px 20px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(17, 21, 29, 0.96), rgba(43, 46, 51, 0.92));
  color: var(--light);
}

.legal-note p {
  color: rgba(252, 252, 252, 0.86);
}

.legal-contactBox {
  display: grid;
  gap: 10px;
  padding: 24px;
  border-radius: 22px;
  background: linear-gradient(
    135deg,
    rgba(226, 209, 149, 0.16),
    rgba(252, 252, 252, 0.92)
  );
  border: 1px solid rgba(190, 173, 95, 0.35);
}

.legal-contactBox a {
  color: var(--dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (max-width: 1080px) {
  .legal-shell {
    grid-template-columns: 1fr;
  }

  .legal-side {
    position: static;
  }

  .legal-content {
    position: static;
    height: auto;
  }

  .legal-card {
    height: auto;
    overflow: visible;
    padding-right: 0;
  }
}

@media (min-width: 1081px) {
  .legal-content {
    position: static;
    height: auto;
    align-self: start;
  }

  .legal-card {
    height: auto;
    overflow-y: visible;
    padding-right: 32px;
  }
}

/* =========================
   Touch behaviour for send button
========================= */
@media (hover: none), (pointer: coarse) {
  .contact_send {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  .contact_send:hover::before {
    transform: translateY(102%);
  }

  .contact_send:hover,
  .contact_send:focus-visible {
    color: var(--ui-btn-text);
    border-color: var(--ui-btn-border);
    box-shadow: none;
    outline: none;
  }

  .contact_send:hover > *,
  .contact_send:focus-visible > * {
    transform: none;
  }

  .contact_send:active::before {
    transform: translateY(0);
  }

  .contact_send:active {
    color: var(--ui-btn-hover-text);
    border-color: var(--ui-btn-hover-border);
  }

  .contact_send:active > * {
    transform: none;
  }
}

/* =========================================================
   FLOATING ACTIONS — SCROLL UP + TALK TO US
   ВАЖНО: здесь scrollUp уже с правильной РЕАЛЬНОЙ высотой,
   чтобы JS парковал кнопку точно перед footer
========================================================= */

/* =========================
   SCROLL UP
========================= */
.scrollUp {
  --scrollup-right: 16px;
  --scrollup-bottom: 24px;
  --scrollup-visual-h: 126px;

  position: fixed;
  right: var(--scrollup-right);
  bottom: var(--scrollup-bottom);
  width: 48px;
  min-width: 48px;
  height: var(--scrollup-visual-h);
  padding: 0;
  border: 0;
  background: transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  cursor: pointer;
  z-index: 9000;
  isolation: isolate;
  transition: opacity 300ms ease;
  box-sizing: border-box;
}

.scrollUp:hover {
  opacity: 1;
}

.scrollUp.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.scrollUp_icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  position: relative;
  z-index: 1;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cpath d='M9 24V5.2' stroke='%2311151D' stroke-width='2.2' stroke-linecap='round'/%3E%3Cpath d='M4.2 8.4L9 3.6L13.8 8.4' stroke='%2311151D' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.scrollUp_icon::before,
.scrollUp_icon::after {
  content: none;
}

.scrollUp_text {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  color: var(--dark);
  white-space: nowrap;
  position: relative;
  z-index: 1;
}

.scrollUp::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  background: var(--light);
  box-shadow: 0 0 0 2.5px var(--gold);
  opacity: 0;
  pointer-events: none;
  z-index: 0;
  transition: opacity 180ms ease;
}

.scrollUp:hover::before,
.scrollUp:focus-visible::before {
  opacity: 1;
}

/* =========================
   TALK TO US FLOAT BUTTON
========================= */
.talk-float {
  --talk-footer-offset: 0px;

  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%) translateY(var(--talk-footer-offset));
  width: auto;
  min-width: 147px;
  max-width: calc(100vw - 32px);
  height: auto;
  min-height: 56px;
  padding: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  white-space: nowrap;
  background: var(--light);
  border: 1px solid var(--border);
  border-radius: 32px;
  z-index: 9999;
  transition: opacity 200ms ease;
  box-sizing: border-box;
}

.talk-float_pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 100%;
  flex: 0 0 auto;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--gold);
  border: 1px solid #bead5f;
  will-change: box-shadow;
}

.talk-float_text {
  font-family: "Lato", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1;
  font-weight: 600;
  color: var(--dark);
  white-space: nowrap;
}

.talk-float_icon {
  width: 18px;
  height: 18px;
  object-fit: contain;
  filter: brightness(0) saturate(100%);
}

.talk-float.is-hidden,
body.is-bm-open .talk-float,
body.ui_lock .talk-float {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(calc(var(--talk-footer-offset) + 12px));
}

/* =========================
   LARGE SCREENS
========================= */
@media (min-width: 1600px) {
  .talk-float {
    min-width: 147px;
    min-height: 56px;
    padding: clamp(12px, calc(12px + (100vw - 1600px) * 0.004), 16px);
    bottom: 24px;
    border-radius: clamp(32px, calc(32px + (100vw - 1600px) * 0.010), 42px);
  }

  .talk-float_pill {
    gap: clamp(8px, calc(8px + (100vw - 1600px) * 0.004), 12px);
    padding:
      clamp(8px, calc(8px + (100vw - 1600px) * 0.004), 11px)
      clamp(14px, calc(14px + (100vw - 1600px) * 0.010), 22px);
  }

  .talk-float_text {
    font-size: clamp(14px, calc(14px + (100vw - 1600px) * 0.004), 18px);
  }

  .talk-float_icon {
    width: clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 24px);
    height: clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 24px);
  }

  .scrollUp {
    --scrollup-bottom: 24px;
    --scrollup-visual-h: clamp(126px, calc(126px + (100vw - 1600px) * 0.040), 188px);

    width: clamp(48px, calc(48px + (100vw - 1600px) * 0.012), 66px);
    min-width: clamp(48px, calc(48px + (100vw - 1600px) * 0.012), 66px);
    height: var(--scrollup-visual-h);
    gap: clamp(12px, calc(12px + (100vw - 1600px) * 0.006), 18px);
  }

  .scrollUp_icon {
    width: clamp(18px, calc(18px + (100vw - 1600px) * 0.005), 24px);
    height: clamp(18px, calc(18px + (100vw - 1600px) * 0.005), 24px);
    flex: 0 0 clamp(18px, calc(18px + (100vw - 1600px) * 0.005), 24px);
    background-size:
      clamp(18px, calc(18px + (100vw - 1600px) * 0.005), 24px)
      clamp(18px, calc(18px + (100vw - 1600px) * 0.005), 24px);
  }

  .scrollUp_text {
    font-size: clamp(16px, calc(16px + (100vw - 1600px) * 0.004), 20px);
  }

  .scrollUp::before {
    border-radius: clamp(10px, calc(10px + (100vw - 1600px) * 0.004), 16px);
  }
}

/* =========================
   TABLET
========================= */
@media (min-width: 641px) and (max-width: 1024px) {
  .scrollUp::before {
    opacity: 1;
  }
}

/* =========================
   PHONE
========================= */
@media (max-width: 640px) {

  .talk-float {
    --talk-footer-offset: 0px;

    left: 50%;
    bottom: var(--floating-mobile-bottom);
    transform: translateX(-50%) translateY(var(--talk-footer-offset));
    width: 48px;
    min-width: 48px;
    max-width: 48px;
    height: 48px;
    min-height: 48px;
    max-height: 48px;
    padding: 0;
    margin: 0;
    display: grid;
    place-items: center;
    box-sizing: border-box;
    background: transparent;
    border: 0;
    border-radius: 50%;
    box-shadow: none;
  }

  .talk-float + .page-wrap {
    padding-bottom: 88px;
  }

  .talk-float_pill {
    width: 48px;
    min-width: 48px;
    max-width: 48px;
    height: 48px;
    min-height: 48px;
    max-height: 48px;
    padding: 0;
    margin: 0;
    display: grid;
    place-items: center;
    box-sizing: border-box;
    gap: 0;
    border-radius: 50%;
    background: var(--gold);
    border: 1px solid #bead5f;
    box-shadow: 0 2px 6px rgba(17, 21, 29, 0.05);
  }

  .talk-float_text {
    display: none;
  }

  .talk-float_icon {
    width: 20px;
    height: 20px;
  }

  .talk-float.is-hidden,
  body.is-bm-open .talk-float,
  body.ui_lock .talk-float {
    transform: translateX(-50%) translateY(calc(var(--talk-footer-offset) + 12px));
  }

  .scrollUp {
    --scrollup-right: 16px;
    --scrollup-bottom: var(--floating-mobile-bottom);
    --scrollup-visual-h: 48px;

    right: var(--scrollup-right);
    bottom: var(--scrollup-bottom);
    width: 48px;
    min-width: 48px;
    max-width: 48px;
    height: 48px;
    min-height: 48px;
    max-height: 48px;
    padding: 0;
    margin: 0;
    gap: 0;
    display: grid;
    place-items: center;
    box-sizing: border-box;
    background: #fcfcfc;
    border: 1px solid #d8d8d8;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(17, 21, 29, 0.05);
  }

  .scrollUp::before {
    content: none;
  }

  .scrollUp_text {
    display: none;
  }

  .scrollUp_icon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
    background-size: 20px 20px;
  }
}

/* =========================================================
   BURGER MENU — CLEAN FINAL
========================================================= */

/* =========================
   TABLET
========================= */
@media (min-width: 741px) and (max-width: 1024px) {
  .bm_panel {
    padding: 34px 44px 34px 32px;
  }

  .bm_menu {
    gap: 28px;
  }

  .bm_link {
    padding: 10px 8px 12px;
    font-size: 30px;
    line-height: 1.28;
  }
}

/* =========================
   WIDE DESKTOP
========================= */
@media (min-width: 1441px) and (max-width: 1920px) {
  .bm_content {
    top: 28px;
    right: 40px;
    bottom: 28px;
    left: 40px;
    gap: 24px;
  }

  .bm_panel {
    width: clamp(430px, 24vw, 520px);
    padding: 28px 48px 28px 28px;
  }
  
  .bm_side {
    top: 28px;
    right: 40px;
  }

  .bm_bottom {
    right: 40px;
    bottom: 28px;
    left: 40px;
    padding: 0;
  }
}

/* =========================
   TRUE LARGE SCREENS
========================= */
@media (min-width: 1921px) {
  .bm_content {
    top: 28px;
    right: 40px;
    bottom: 28px;
    left: 40px;
    gap: clamp(24px, 1.1vw, 32px);
  }

  .bm_panel {
    width: clamp(460px, 24vw, 620px);
    min-height: 0;
    height: auto;
    padding:
      clamp(28px, 1.4vw, 42px)
      clamp(56px, 2vw, 72px)
      clamp(28px, 1.4vw, 42px)
      clamp(32px, 1.6vw, 48px);
    border-radius: clamp(8px, 0.7vw, 14px);
  }

  .bm_menu {
    gap: clamp(18px, 1vw, 28px);
  }

  .bm_link {
    gap: clamp(14px, 0.8vw, 20px);
    padding:
      clamp(8px, 0.45vw, 12px)
      clamp(10px, 0.6vw, 14px)
      clamp(8px, 0.55vw, 14px);
    font-size: clamp(32px, 1.9vw, 44px);
    line-height: clamp(43px, 2.3vw, 56px);
  }

  .bm_link::after {
    flex: 0 0 clamp(36px, 2vw, 48px);
    width: clamp(36px, 2vw, 48px);
    height: clamp(28px, 1.5vw, 36px);
    background-size: 100% 100%;
  }

  .bm_side {
    top: 28px;
    right: 40px;
    gap: clamp(16px, 0.9vw, 24px);
  }

  .bm_brand {
    gap: clamp(11px, 0.6vw, 16px);
  }

  .bm_brandLogo {
    width: clamp(48.19px, 2.5vw, 66px);
    height: clamp(55.43px, 2.9vw, 76px);
  }

  .bm_brandTitle {
    font-size: clamp(23.4887px, 1.3vw, 32px);
    line-height: clamp(22px, 1.2vw, 30px);
  }

  .bm_brandSub {
    font-size: clamp(16.5803px, 0.9vw, 22px);
    line-height: clamp(15px, 0.9vw, 22px);
  }

  .bm_lang {
    gap: clamp(20px, 1vw, 32px);
  }

  .bm_langBtn {
    width: clamp(38px, 2vw, 48px);
    height: clamp(38px, 2vw, 48px);
    font-size: clamp(18px, 0.9vw, 22px);
    line-height: clamp(22px, 1vw, 26px);
  }

  .bm_close {
    width: clamp(42px, 2.2vw, 52px);
    height: clamp(42px, 2.2vw, 52px);
  }

  .bm_closeIcon {
    width: clamp(14px, 0.8vw, 18px);
    height: clamp(14px, 0.8vw, 18px);
  }

  .bm_bottom {
    right: 40px;
    bottom: 28px;
    left: 40px;
    padding: 0;
    gap: clamp(20px, 1vw, 28px);
  }
  
  .bm_copy {
    max-width: 56%;
    font-size: clamp(14px, 0.75vw, 22px);
    line-height: clamp(18px, 0.95vw, 28px);
  }

  .bm_contact {
    height: clamp(56px, 3.2vw, 80px);
    padding:
      clamp(14px, 0.9vw, 22px)
      clamp(28px, 1.8vw, 48px);
    font-size: clamp(18px, 1.1vw, 28px);
    line-height: clamp(22px, 1.2vw, 32px);
    border-radius: clamp(6px, 0.4vw, 10px);
  }
}

/* =========================================================
   CONTACT OVERLAY — FINAL CLEAN RESPONSIVE BLOCK
========================================================= */

/* =========================
   DESKTOP / LAPTOP
========================= */
@media (min-width: 1025px) {
  .contact_bgImg {
    left: 40px;
    top: 50%;
    width: auto;
    height: min(1044px, 92vh);
    opacity: 0.75;
    filter: brightness(1.45) contrast(1.05) saturate(1.04);
    transform: translate3d(0, -50%, 0);
    transform-style: preserve-3d;
    transform-origin: center;
    will-change: transform;
    transition: transform 180ms ease;
  }
}

/* =========================
   TABLET + MOBILE
========================= */
@media (max-width: 1024px) {
  .contact_shell {
    padding:
      calc(32px + env(safe-area-inset-top))
      24px
      calc(24px + env(safe-area-inset-bottom));
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 16px;
  }

  .contact_items {
    width: 100%;
    min-height: 0;
    display: block;
    flex: 0 0 auto;
  }

  .contact_left {
    width: 100%;
    max-width: none;
    padding: 0;
    display: block;
  }

  .contact_text {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 18px;
  }

  .contact_title {
    max-width: min(100%, 520px);
    font-size: clamp(34px, 4.8vw, 42px);
    line-height: 1.05;
    text-wrap: balance;
  }

  .contact_subtitle {
    max-width: min(100%, 560px);
    font-size: 14px;
    line-height: 22px;
  }

  .contact_form {
    width: 100%;
    padding-top: 8px;
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .contact_row {
    flex-direction: column;
    gap: 10px;
  }

  .contact_row--file {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 10px;
  }

  .contact_row--file .field--projectType {
    flex: 1 1 auto;
    min-width: 0;
  }

  .contact_row--file .field--file {
    flex: 0 0 clamp(112px, 24vw, 132px);
    width: clamp(112px, 24vw, 132px);
    min-width: clamp(112px, 24vw, 132px);
    max-width: clamp(112px, 24vw, 132px);
    padding: 0 12px;
  }

  .contact_send {
    width: 100%;
    height: 54px;
    margin-top: 2px;
    margin-bottom: 28px;
  }

  .contact_close {
    position: static;
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 92px;
    height: 46px;
    margin: 0 auto calc(8px + env(safe-area-inset-bottom));
    padding: 6px;
    transform: none;
    z-index: auto;
  }

  .contact_closePill {
    height: 32px;
    padding: 0 14px;
    gap: 8px;
    border-radius: 20px;
  }

  .contact_closeText {
    font-size: 12px;
    line-height: 12px;
  }

  .contact_closeX {
    width: 7px;
    height: 7px;
  }

  .contact_closeX::before,
  .contact_closeX::after {
    width: 8px;
    border-top-width: 1.4px;
  }

  .contact_bgImg {
    left: 50%;
    top: 54%;
    width: min(94vw, 760px);
    max-width: none;
    height: auto;
    opacity: 0.38;
    filter: brightness(1.48) contrast(1.06) saturate(1.08);
    transform: translate3d(-50%, -50%, 0) !important;
    transition: none;
    will-change: auto;
  }
}

/* =========================
   PHONE
========================= */
@media (max-width: 640px) {
  .contact_shell {
    padding:
      calc(20px + env(safe-area-inset-top))
      16px
      calc(20px + env(safe-area-inset-bottom));
    gap: 12px;
  }

  .contact_text {
    gap: 8px;
    margin-bottom: 14px;
  }

  .contact_title {
    max-width: 320px;
    font-size: clamp(28px, 8vw, 34px);
    line-height: 1.04;
  }

  .contact_subtitle {
    max-width: 310px;
    font-size: 12px;
    line-height: 18px;
  }

  .contact_quick {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
  }

  .contact_quickBtn {
    min-height: 48px;
    padding: 10px;
    gap: 8px;
    border-radius: 4px;
  }

  .contact_quickBadge--mail {
    width: 20px;
    min-width: 20px;
  }

  .contact_quickIcon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }

  .contact_quickTop {
    gap: 4px;
    font-size: 11px;
    line-height: 13px;
  }

  .contact_quickBottom {
    font-size: 10px;
    line-height: 12px;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .contact_quickMiniLabel {
    font-size: 10px;
    line-height: 12px;
  }

  .contact_form {
    padding-top: 8px;
    gap: 10px;
  }

  .contact_formTitle {
    font-weight: 600;
    font-size: 14px;
    line-height: 20px;
  }

  .field_input,
  .field_select,
  .uiSelect_btn,
  .field--phoneIntl .iti input.field_input,
  .field--phoneIntl .iti input[type="tel"] {
    height: 48px;
    font-size: 12px;
    border-radius: 4px;
  }

  .field_input,
  .field_select,
  .uiSelect_btn {
    padding-left: 14px;
    padding-right: 40px;
  }

  .field_textarea {
    padding: 12px 14px;
    font-size: 12px;
    border-radius: 4px;
  }

  .field--textarea .field_textarea {
    height: 108px;
  }

  .field_select {
    background-position: calc(100% - 18px) 21px, calc(100% - 12px) 21px;
    background-size: 5px 5px, 5px 5px;
  }

  .field--phoneIntl .iti::before {
    left: 14px;
    font-size: 12px;
    line-height: 15px;
  }

  .field--phoneIntl .iti__country-container {
    left: 82px;
  }

  .field--phoneIntl .iti input.field_input,
  .field--phoneIntl .iti input[type="tel"] {
    padding: 0 14px 0 160px !important;
  }

  .field--phoneIntl .iti__selected-country,
  .field--phoneIntl .iti__selected-country-primary {
    height: 48px;
  }

  .field--phoneIntl .iti__selected-dial-code {
    font-size: 12px;
    line-height: 15px;
  }

  .field--phoneIntl .iti__flag {
    margin-right: 8px;
  }

  .field--file {
    height: 48px;
    border-radius: 4px;
  }

  .fileLabel {
    font-size: 12px;
    line-height: 15px;
  }

  .field_meta {
    margin-top: 6px;
  }

  .field_hint,
  .field_count {
    font-size: 12px;
    line-height: 15px;
  }

  .contact_send {
    height: 52px;
    margin-bottom: 12px;
  }

  .contact_sendText {
    font-size: 11px;
    line-height: 13px;
    letter-spacing: 0.02em;
  }

  .contact_sendArrow {
    width: 15px;
    height: 15px;
  }

  .contact_close {
    position: static;
    left: auto;
    bottom: auto;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 85px;
    height: 44px;
    margin: 0 auto calc(6px + env(safe-area-inset-bottom));
    padding: 6px;
    flex: 0 0 auto;
    z-index: auto;
  }

  .contact_bgImg {
    width: 145%;
    opacity: 0.32;
    filter: brightness(1.5) contrast(1.06) saturate(1.08);
  }
}

/* =========================
   VERY SMALL PHONES
========================= */
@media (max-width: 375px), ((max-width: 430px) and (max-height: 700px)) {
  .contact_shell {
    padding:
    calc(18px + env(safe-area-inset-top))
    12px
    calc(16px + env(safe-area-inset-bottom));
    gap: 10px;
  }

  .contact_text {
    gap: 6px;
    margin-bottom: 10px;
  }

  .contact_title {
    max-width: 220px;
    font-size: 20px;
    line-height: 22px;
  }

  .contact_subtitle {
    max-width: 280px;
    font-size: 10px;
    line-height: 14px;
  }

  .contact_quick {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-bottom: 8px;
  }

  .contact_quickBtn {
    min-height: 44px;
    padding: 8px 10px;
    gap: 8px;
  }

  .contact_quickBadge--mail {
    width: 18px;
    min-width: 18px;
  }

  .contact_quickIcon {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
  }

  .contact_quickTop {
    font-size: 10px;
    line-height: 12px;
  }

  .contact_quickBottom {
    font-size: 10px;
    line-height: 12px;
  }

  .contact_quickMiniLabel {
    font-size: 9px;
    line-height: 11px;
  }

  .contact_form {
    padding-top: 6px;
    gap: 8px;
  }

  .contact_formTitle {
    font-size: 13px;
    line-height: 18px;
  }

  .contact_row {
    gap: 8px;
  }

  .contact_row--file {
    gap: 8px;
  }

  .contact_row--file .field--file {
    flex: 0 0 104px;
    width: 104px;
    min-width: 104px;
    max-width: 104px;
  }

  .field_input,
  .field_select,
  .uiSelect_btn,
  .field--phoneIntl .iti input.field_input,
  .field--phoneIntl .iti input[type="tel"] {
    height: 44px;
    font-size: 12px;
  }

  .field_input,
  .field_select,
  .uiSelect_btn {
    padding-left: 12px;
    padding-right: 36px;
  }

  .field_textarea {
    padding: 10px 12px;
    font-size: 12px;
  }

  .field--textarea .field_textarea {
    height: 96px;
  }

  .field_select {
    background-position: calc(100% - 16px) 19px, calc(100% - 11px) 19px;
    background-size: 5px 5px, 5px 5px;
  }

  .field--phoneIntl .iti::before {
    left: 12px;
    font-size: 11px;
    line-height: 14px;
  }

  .field--phoneIntl .iti__country-container {
    left: 74px;
  }

  .field--phoneIntl .iti input.field_input,
  .field--phoneIntl .iti input[type="tel"] {
    padding: 0 12px 0 146px !important;
  }

  .field--phoneIntl .iti__selected-country,
  .field--phoneIntl .iti__selected-country-primary {
    height: 44px;
  }

  .field--phoneIntl .iti__selected-dial-code {
    font-size: 12px;
    line-height: 14px;
  }

  .field--phoneIntl .iti__flag {
    margin-right: 6px;
  }

  .field--file {
    height: 44px;
  }

  .fileLabel {
    font-size: 11px;
    line-height: 14px;
  }

  .field_hint,
  .field_count {
    font-size: 11px;
    line-height: 14px;
  }

  .contact_send {
    height: 48px;
    margin-bottom: 10px;
  }

  .contact_sendArrow {
    width: 14px;
    height: 14px;
  }

  .contact_close {
    position: static;
    left: auto;
    bottom: auto;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 78px;
    height: 40px;
    margin: 0 auto calc(4px + env(safe-area-inset-bottom));
    padding: 5px;
    flex: 0 0 auto;
    z-index: auto;
  }

  .contact_closePill {
    height: 30px;
    padding: 0 12px;
    gap: 6px;
  }

  .contact_closeText {
    font-size: 11px;
    line-height: 11px;
  }

  .contact_closeX {
    width: 6px;
    height: 6px;
  }

  .contact_closeX::before,
  .contact_closeX::after {
    width: 7px;
    border-top-width: 1.3px;
  }

  .contact_bgImg {
    width: 155%;
    opacity: 0.28;
  }
}

.fileUploadNote {
  width: 100%;
  margin: 0;
  font-family: "Lato", system-ui, sans-serif;
  font-size: 12px;
  line-height: 18px;
}

#contactForm .fileUploadNote {
  color: rgba(216, 216, 216, 0.78);
}

:is(#contactsForm, #careersForm) .fileUploadNote {
  color: #6f7478;
}

#contactForm .fileFeedback,
:is(#contactsForm, #careersForm) .fileFeedback {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.fileUploadNote + .fileFeedback {
  margin-top: 0;
  margin-bottom: 0;
}

.fileUploadNote + .field--textarea,
.fileUploadNote + .fileFeedback + .field--textarea {
  margin-top: -10px;
}

@media (max-width: 640px) {
  .fileUploadNote {
    font-size: 11px;
    line-height: 16px;
    margin: 0;
  }

  .fileUploadNote + .fileFeedback {
    margin-top: 0;
    margin-bottom: 0;
  }

  .fileUploadNote + .field--textarea,
  .fileUploadNote + .fileFeedback + .field--textarea {
    margin-top: -6px;
  }
}

/* =========================================================
   HERO TOP BAR — FINAL FIX
========================================================= */

.start_topbar {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 3;
  pointer-events: none;
}

/* LEFT BLOCK: burger + logo */
.start_nav {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 18px;
  width: fit-content;
  max-width: calc(100% - 160px);
  min-height: 91.43px;
  padding: 18px 26px 18px 18px;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 0 0 8px 0;
}

/* RIGHT BLOCK: languages */
.nav_langBox {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 91.43px;
  padding: 18px 18px 18px 24px;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 0 0 0 8px;
}

.nav_lang {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: nowrap;
}

.nav_langBtn {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 6px;
  border: 1px solid #11151d;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.6);
  font-family: "Lato", system-ui, sans-serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 22px;
  letter-spacing: 0.02em;
  color: #11151d;
  cursor: pointer;
  transition:
    background-color 200ms ease,
    border-color 200ms ease,
    color 200ms ease,
    opacity 200ms ease;
}

.nav_langBtn.is-active {
  background: #ded196;
}

.nav_langBtn:hover,
.nav_langBtn:focus-visible {
  border-color: #11151d;
  color: #11151d;
  opacity: 0.9;
  transform: none;
}

.nav_langBtn.is-active:hover,
.nav_langBtn.is-active:focus-visible {
  background: #ded196;
  border-color: #11151d;
  color: #11151d;
  opacity: 1;
}

.nav_logo {
  display: flex;
  align-items: center;
  gap: 13px;
  width: auto;
  min-width: 0;
  max-width: min(540px, calc(100vw - 286px));
}

.nav_logoIcon {
  flex: 0 0 54px;
  width: 54px;
  height: 62px;
  object-fit: contain;
  filter: brightness(0) saturate(100%);
}

.nav_logoText {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2.76px;
  min-width: 0;
  width: auto;
  height: auto;
  box-sizing: border-box;
}

.nav_logoTitle {
  font-family: "League Spartan", system-ui, sans-serif;
  font-weight: 400;
  font-size: 26px;
  line-height: 1.05;
  color: var(--dark);
  white-space: nowrap;
}

.nav_logoSub {
  font-family: "League Spartan", system-ui, sans-serif;
  font-weight: 300;
  font-size: 18px;
  line-height: 1.15;
  color: var(--dark);
  white-space: nowrap;
  padding-bottom: 2px;
}

.nav_logoLink {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

.nav_logoLink:hover,
.nav_logoLink:focus-visible {
  color: inherit;
  text-decoration: none;
}

.burger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 9px;
  width: 50px;
  height: 42px;
  padding: 8px;
  border: 0;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  flex: 0 0 auto;
}

.burger span {
  display: block;
  width: 34px;
  height: 0;
  border-top: 2px solid #000;
  border-radius: 2px;
}

.burger span:nth-child(1) {
  width: 24px;
}

/* =========================
   TABLET
========================= */
@media (max-width: 900px) and (min-width: 641px) {
  .start_nav {
    gap: 14px;
    max-width: calc(100% - 160px);
    padding: 18px 26px 18px 18px;
  }

  .nav_langBox {
    padding: 18px;
  }

  .nav_lang {
    gap: 16px;
  }

  .nav_logo {
    max-width: min(360px, calc(100vw - 240px));
  }

  .nav_logoTitle {
    font-size: 22px;
    line-height: 20px;
  }

  .nav_logoSub {
    font-size: 15px;
    line-height: 14px;
  }
}

/* =========================
   LARGE SCREENS
========================= */
@media (min-width: 1600px) {
  .start_nav,
  .nav_langBox {
    min-height: clamp(91.43px, calc(91.43px + (100vw - 1600px) * 0.020), 118px);
  }

  .start_nav {
    max-width: calc(100% - clamp(120px, 10vw, 190px));
    padding:
      clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 28px)
      clamp(26px, calc(26px + (100vw - 1600px) * 0.016), 46px)
      clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 28px)
      clamp(18px, calc(18px + (100vw - 1600px) * 0.010), 30px);
    gap: clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 28px);
  }

  .nav_langBox {
    padding:
      clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 28px)
      clamp(18px, calc(18px + (100vw - 1600px) * 0.010), 30px)
      clamp(18px, calc(18px + (100vw - 1600px) * 0.006), 28px)
      clamp(24px, calc(24px + (100vw - 1600px) * 0.014), 38px);
  }

  .nav_lang {
    gap: clamp(24px, calc(24px + (100vw - 1600px) * 0.008), 34px);
  }

  .nav_langBtn {
    width: clamp(38px, calc(38px + (100vw - 1600px) * 0.008), 50px);
    height: clamp(38px, calc(38px + (100vw - 1600px) * 0.008), 50px);
    font-size: clamp(18px, calc(18px + (100vw - 1600px) * 0.004), 22px);
    border-radius: clamp(6px, calc(6px + (100vw - 1600px) * 0.004), 10px);
  }

  .burger {
    width: clamp(50px, calc(50px + (100vw - 1600px) * 0.012), 64px);
    height: clamp(42px, calc(42px + (100vw - 1600px) * 0.010), 54px);
    padding: clamp(8px, calc(8px + (100vw - 1600px) * 0.004), 10px);
    gap: clamp(9px, calc(9px + (100vw - 1600px) * 0.004), 12px);
    border-radius: clamp(4px, calc(4px + (100vw - 1600px) * 0.003), 8px);
  }

  .burger span {
    width: clamp(34px, calc(34px + (100vw - 1600px) * 0.010), 44px);
  }

  .burger span:nth-child(1) {
    width: clamp(24px, calc(24px + (100vw - 1600px) * 0.008), 32px);
  }

  .nav_logo {
    gap: clamp(11.05px, calc(11.05px + (100vw - 1600px) * 0.006), 16px);
    max-width: min(700px, calc(100vw - 360px));
  }

  .nav_logoIcon {
    flex: 0 0 clamp(48.19px, calc(48.19px + (100vw - 1600px) * 0.015), 64px);
    width: clamp(48.19px, calc(48.19px + (100vw - 1600px) * 0.015), 64px);
    height: clamp(55.43px, calc(55.43px + (100vw - 1600px) * 0.017), 74px);
  }

  .nav_logoTitle {
    font-size: clamp(23.4887px, calc(23.4887px + (100vw - 1600px) * 0.010), 30px);
    line-height: 1;
  }

  .nav_logoSub {
    font-size: clamp(16.58px, calc(16.58px + (100vw - 1600px) * 0.006), 20px);
    line-height: 1.05;
  }
}

/* =========================
   PHONE
========================= */
@media (max-width: 640px) {
  .start_topbar {
    top: 0;
    right: 0;
    left: 0;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 91.43px;
    padding: 18px 16px;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 0 0 8px 8px;
    pointer-events: auto;
  }

  .start_nav {
    position: static;
    flex: 1 1 auto;
    width: auto;
    max-width: none;
    min-height: 0;
    padding: 0;
    background: transparent;
    border-radius: 0;
    gap: 12px;
  }

  .nav_langBox {
    position: static;
    margin-left: auto;
    min-height: 0;
    padding: 0;
    background: transparent;
    border-radius: 0;
  }

  .nav_lang {
    justify-content: flex-end;
    gap: 10px;
  }

  .burger {
    width: 44px;
    height: 44px;
    padding: 8px;
    gap: 8px;
    flex: 0 0 44px;
    border-radius: 6px;
  }

  .burger span {
    width: 28px;
  }

  .burger span:nth-child(1) {
    width: 20px;
  }

  .nav_logo {
    flex: 1 1 auto;
    min-width: 0;
    max-width: none;
    gap: 10px;
  }

  .nav_logoIcon {
    flex: 0 0 42px;
    width: 42px;
    height: 48px;
  }

  .nav_logoText {
    min-width: 0;
  }

  .nav_logoTitle {
    font-size: 19px;
    line-height: 1.05;
  }

  .nav_logoSub {
    font-size: 12.5px;
    line-height: 1.2;
    padding-bottom: 2px;
  }

  .nav_langBtn {
    width: 38px;
    height: 38px;
    font-size: 16px;
    line-height: 1;
    border-radius: 8px;
  }
}

/* =========================
   VERY SMALL PHONES
========================= */
@media (max-width: 420px) {
  .start_topbar {
    gap: 10px;
    padding: 16px 12px;
  }

  .start_nav {
    gap: 10px;
  }

  .nav_lang {
    gap: 8px;
  }

  .burger {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    padding: 7px;
  }

  .burger span {
    width: 24px;
  }

  .burger span:nth-child(1) {
    width: 17px;
  }

  .nav_logo {
    gap: 8px;
  }

  .nav_logoIcon {
    flex: 0 0 39px;
    width: 39px;
    height: 44px;
  }

  .nav_logoTitle {
    font-size: 20px;
    line-height: 1.05;
  }

  .nav_logoSub {
    font-size: 14px;
    line-height: 1.15;
    padding-bottom: 2px;
  }

  .nav_langBtn {
    width: 34px;
    height: 34px;
    font-size: 14px;
  }
}

/* =========================================================
   TERMS OF USE — MIXED CORNERS VERSION
========================================================= */

.legal-page--terms-sharp .legal-panel,
.legal-page--terms-sharp .legal-card {
  border-radius: 18px !important;
  box-shadow: 0 16px 36px rgba(17, 21, 29, 0.05) !important;
}

.legal-page--terms-sharp .legal-metaItem,
.legal-page--terms-sharp .legal-toc a,
.legal-page--terms-sharp .legal-contactBox,
.legal-page--terms-sharp .legal-number {
  border-radius: 0 !important;
}

.legal-page--terms-sharp .legal-kicker {
  border-radius: 4px !important;
}

.legal-page--terms-sharp .legal-toc a {
  padding: 12px 14px !important;
}

.legal-page--terms-sharp .legal-number {
  width: 42px !important;
  height: 42px !important;
  display: inline-grid !important;
  place-items: center !important;
}

.legal-page--terms-sharp .legal-metaItem {
  background: #ffffff !important;
}

.legal-page--terms-sharp .legal-contactBox {
  border-left: 3px solid rgba(190, 173, 95, 0.95);
  background: linear-gradient(
    135deg,
    rgba(222, 209, 150, 0.14),
    rgba(252, 252, 252, 0.96)
  );
}

.legal-page--terms-sharp .legal-note {
  padding: 18px 20px;
  border: 1px solid rgba(190, 173, 95, 0.35);
  border-left: 3px solid rgba(190, 173, 95, 0.95);
  border-radius: 0 !important;
  background: linear-gradient(
    135deg,
    rgba(222, 209, 150, 0.14),
    rgba(252, 252, 252, 0.96)
  );
  color: var(--dark);
}

.legal-page--terms-sharp .legal-note p {
  color: rgba(17, 21, 29, 0.9) !important;
  font-weight: 500;
}
