@charset "UTF-8";
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Theme variables and design tokens.
 *
 * - Layout widths ($breakpoint-wide, $breakpoint-content): from theme.json via
 *   _theme-tokens.generated.scss (npm run sync:tokens).
 * - Responsive breakpoints below: Sass has no access to the WP DB during npm build.
 *   **Set them in 4WP Responsive (Settings), then mirror Desktop min + Tablet max here**
 *   so SCSS @media matches the plugin (e.g. img-desktop-breakout-right).
 */
/**
 * AUTO-GENERATED from theme.json (layout only) — do not edit by hand.
 * Regenerate: npm run sync:tokens
 */
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Base (global) styles.
 * Typography and colors are mainly defined in theme.json.
 */
html {
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
}

@media (max-width: 599px) {
  html,
  body {
    overflow-x: hidden;
  }
}
/* Softer separator (hr) — lighter for perception */
.wp-block-separator,
.wp-block-separator.has-alpha-channel-opacity {
  border: none;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  opacity: 1;
  margin: 1.5em 0;
}

/* Video lightbox trigger: плавний scale зображення при ховері */
.forwp-video-lightbox-trigger .wp-block-image img,
.forwp-video-lightbox-trigger figure img {
  transition: transform 0.3s ease;
}

.forwp-video-lightbox-trigger:hover .wp-block-image img,
.forwp-video-lightbox-trigger:hover figure img {
  transform: scale(1.08);
}

/* Утиліта: виступ вправо лише на справжньому desktop ($breakpoint-desktop), не при 782px (колонки WP) — інакше таблет отримує горизонтальний скролл. */
@media (min-width: 1200px) {
  .wp-block-image.img-desktop-breakout-right,
  figure.img-desktop-breakout-right {
    margin-right: -20px;
    overflow: visible;
  }
  .wp-block-image.img-desktop-breakout-right img,
  figure.img-desktop-breakout-right img {
    transform: scale(1);
    transform-origin: left center;
    max-width: none;
  }
}
/* Планшет / вузький ноутбук: без негативних відступів і з повною видимістю зображення */
@media (min-width: 782px) and (max-width: 1199px) {
  .wp-block-image.img-desktop-breakout-right,
  figure.img-desktop-breakout-right {
    margin-right: 0;
    overflow: hidden;
    max-width: 100%;
  }
  .wp-block-image.img-desktop-breakout-right img,
  figure.img-desktop-breakout-right img {
    max-width: 100%;
    width: 100%;
    height: auto;
    transform: none;
    display: block;
  }
}
/* Мобільна версія: колонки (Fits, картки) — фото не виходять за межі контейнера. */
@media (max-width: 781px) {
  .wp-block-columns .wp-block-column {
    min-width: 0; /* flex-дитина може стискатися */
  }
  .wp-block-columns .wp-block-column .wp-block-group,
  .wp-block-columns .wp-block-column .wp-block-stack {
    overflow: hidden;
    min-width: 0;
  }
  .wp-block-columns .wp-block-column .wp-block-image,
  .wp-block-columns .wp-block-column figure.wp-block-image,
  .wp-block-columns .wp-block-column .wp-block-group .wp-block-image {
    max-width: 100%;
    overflow: hidden;
  }
  .wp-block-columns .wp-block-column img,
  .wp-block-columns .wp-block-column .wp-block-image img,
  .wp-block-columns .wp-block-column figure img {
    max-width: 100%;
    width: 100%;
    display: block;
    object-fit: cover;
  }
  .wp-block-columns {
    /* Якщо на картці випадково використано breakout-клас — на мобільному примусово тримаємо в межах */
  }
  .wp-block-columns .wp-block-column .img-desktop-breakout-right,
  .wp-block-columns .wp-block-column figure.img-desktop-breakout-right {
    margin-right: 0;
    overflow: hidden;
  }
  .wp-block-columns .wp-block-column .img-desktop-breakout-right img,
  .wp-block-columns .wp-block-column figure.img-desktop-breakout-right img {
    transform: none;
    max-width: 100%;
  }
}
/**
 * Button background hover: theme.json palette colours with -hover variant.
 * Зміна кольору зліва направо (градієнт), без смужки під кнопкою.
 */
@property --btn-sweep {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 0%;
}
.has-custom-dark-secondary-background-color {
  --btn-sweep: 0%;
  background: linear-gradient(to right, var(--wp--preset--color--custom-dark-secondary-hover) 0%, var(--wp--preset--color--custom-dark-secondary-hover) var(--btn-sweep), var(--wp--preset--color--custom-dark-secondary) var(--btn-sweep), var(--wp--preset--color--custom-dark-secondary) 100%) !important;
  transition: --btn-sweep 0.25s ease;
}

.has-custom-dark-secondary-background-color:hover {
  --btn-sweep: 100%;
}

.has-custom-yellow-background-color {
  --btn-sweep: 0%;
  background: linear-gradient(to right, var(--wp--preset--color--custom-yellow-hover) 0%, var(--wp--preset--color--custom-yellow-hover) var(--btn-sweep), var(--wp--preset--color--custom-yellow) var(--btn-sweep), var(--wp--preset--color--custom-yellow) 100%) !important;
  transition: --btn-sweep 0.25s ease;
}

.has-custom-yellow-background-color:hover {
  --btn-sweep: 100%;
}

.has-custom-grey-background-color {
  --btn-sweep: 0%;
  background: linear-gradient(to right, var(--wp--preset--color--custom-grey-hover) 0%, var(--wp--preset--color--custom-grey-hover) var(--btn-sweep), var(--wp--preset--color--custom-grey) var(--btn-sweep), var(--wp--preset--color--custom-grey) 100%) !important;
  transition: --btn-sweep 0.25s ease;
}

.has-custom-grey-background-color:hover {
  --btn-sweep: 100%;
}

/**
 * Contact Form 7 — базові стилі (порт з includes/css/styles.css).
 * Увімкнено, коли в темі вимкнено плагіновий CSS через wpcf7_load_css.
 * Секція CTA в patterns/_cta.scss лишається поверх цих правил (вища специфічність).
 */
.wpcf7 .screen-reader-response {
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  width: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  word-wrap: normal !important;
}

.wpcf7 .hidden-fields-container {
  display: none;
}

.wpcf7 form .wpcf7-response-output {
  margin: 2em 0.5em 1em;
  padding: 0.2em 1em;
  border: 2px solid #00a0d2;
}

.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
  display: none;
}

.wpcf7 form.sent .wpcf7-response-output {
  border-color: #46b450;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
  border-color: #dc3232;
}

.wpcf7 form.spam .wpcf7-response-output {
  border-color: #f56e28;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  border-color: #ffb900;
}

.wpcf7-form-control-wrap {
  position: relative;
}

.wpcf7-not-valid-tip {
  color: #dc3232;
  font-size: 1em;
  font-weight: normal;
  display: block;
}

.use-floating-validation-tip .wpcf7-not-valid-tip {
  position: relative;
  top: -2ex;
  left: 1em;
  z-index: 100;
  border: 1px solid #dc3232;
  background: #fff;
  padding: 0.2em 0.8em;
  width: 24em;
}

.wpcf7-list-item {
  display: inline-block;
  margin: 0 0 0 1em;
}

.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
  content: " ";
}

.wpcf7-spinner {
  visibility: hidden;
  display: inline-block;
  background-color: #23282d;
  opacity: 0.75;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 100%;
  padding: 0;
  margin: 0 24px;
  position: relative;
}

form.submitting .wpcf7-spinner {
  visibility: visible;
}

.wpcf7-spinner::before {
  content: "";
  position: absolute;
  background-color: #fbfbfc;
  top: 4px;
  left: 4px;
  width: 6px;
  height: 6px;
  border: none;
  border-radius: 100%;
  transform-origin: 8px 8px;
  animation-name: wpcf7-spin;
  animation-duration: 1000ms;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

@media (prefers-reduced-motion: reduce) {
  .wpcf7-spinner::before {
    animation-name: wpcf7-blink;
    animation-duration: 2000ms;
  }
}
@keyframes wpcf7-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes wpcf7-blink {
  from {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.wpcf7 [inert] {
  opacity: 0.5;
}

.wpcf7 input[type=file] {
  cursor: pointer;
}

.wpcf7 input[type=file]:disabled {
  cursor: default;
}

.wpcf7 .wpcf7-submit:disabled {
  cursor: not-allowed;
}

.wpcf7 input[type=url],
.wpcf7 input[type=email],
.wpcf7 input[type=tel] {
  direction: ltr;
}

.wpcf7-reflection > output {
  display: list-item;
  list-style: none;
}

.wpcf7-reflection > output[hidden] {
  display: none;
}

/**
 * Import pattern (section) styles.
 * Add a new partial for each landing section.
 */
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: Header (parts/header.html)
 * 0.1 Fixed, 0.2 scroll background, 0.3 admin bar offset
 */
/* Offset for anchor targets (#how-we-start, #intro-call, etc.) so they aren't hidden under fixed header */
[id] {
  scroll-margin-top: 80px;
}

body.admin-bar [id] {
  scroll-margin-top: 112px;
}

@media (max-width: 782px) {
  body.admin-bar [id] {
    scroll-margin-top: 126px;
  }
}
@media (min-width: 783px) {
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) a,
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) .wp-block-navigation-item__content {
    position: relative;
    padding-bottom: 2px;
    border-bottom: 2px solid transparent;
    transition: border-color 0.25s ease, color 0.25s ease;
  }
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) a::after,
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) .wp-block-navigation-item__content::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 2px;
    width: 0;
    background-color: var(--wp--preset--color--custom-yellow, #f6d013);
    transition: width 0.25s ease;
  }
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) a:hover::after,
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) .wp-block-navigation-item__content:hover::after {
    width: 100%;
  }
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) a:hover,
  header .wp-block-navigation .wp-block-navigation-item:not(.has-child) .wp-block-navigation-item__content:hover {
    color: var(--wp--preset--color--custom-yellow, #f6d013);
  }
  header .wp-block-navigation .wp-block-navigation-item.is-current-section a,
  header .wp-block-navigation .wp-block-navigation-item.is-current-section .wp-block-navigation-item__content {
    color: var(--wp--preset--color--custom-yellow, #f6d013);
    border-bottom-color: var(--wp--preset--color--custom-yellow, #f6d013);
  }
  header .wp-block-navigation .wp-block-navigation-item.is-current-section a::after,
  header .wp-block-navigation .wp-block-navigation-item.is-current-section .wp-block-navigation-item__content::after {
    width: 100%;
  }
}
header.wp-block-template-part,
.wp-block-template-part header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background-color: transparent;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
body.is-scrolled header.wp-block-template-part,
body.is-scrolled .wp-block-template-part header {
  background-color: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
body.admin-bar header.wp-block-template-part,
body.admin-bar .wp-block-template-part header {
  top: 32px;
}
@media (max-width: 782px) {
  body.admin-bar header.wp-block-template-part,
  body.admin-bar .wp-block-template-part header {
    top: 46px;
  }
}
@media (max-width: 782px) {
  header.wp-block-template-part .header-menu,
  .wp-block-template-part header .header-menu {
    max-width: 100%;
    width: 100%;
  }
  header.wp-block-template-part .wp-block-group.alignfull,
  .wp-block-template-part header .wp-block-group.alignfull {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  header.wp-block-template-part .wp-block-site-logo img,
  .wp-block-template-part header .wp-block-site-logo img {
    height: auto;
    max-width: 110px;
  }
  header.wp-block-template-part .wp-block-navigation__responsive-container-open,
  .wp-block-template-part header .wp-block-navigation__responsive-container-open {
    position: relative;
    background-color: #EAECED !important;
    border-radius: 0;
    padding: 10px 12px;
    width: 42px;
    height: 42px;
    box-sizing: border-box;
    background-image: linear-gradient(#314549 0 0), linear-gradient(#314549 0 0), linear-gradient(#314549 0 0);
    background-size: 20px 2px;
    background-repeat: no-repeat;
    background-position: center 12px, center 50%, center calc(100% - 12px);
  }
  header.wp-block-template-part .wp-block-navigation__responsive-container-open svg, header.wp-block-template-part .wp-block-navigation__responsive-container-open .icon,
  .wp-block-template-part header .wp-block-navigation__responsive-container-open svg,
  .wp-block-template-part header .wp-block-navigation__responsive-container-open .icon {
    visibility: hidden;
    position: absolute;
    width: 1px;
    height: 1px;
    clip-path: inset(50%);
  }
  header.wp-block-template-part .wp-block-buttons .wp-block-button__link,
  .wp-block-template-part header .wp-block-buttons .wp-block-button__link {
    background-color: var(--wp--preset--color--custom-dark-secondary, #314549) !important;
    color: #fff !important;
  }
}

@media (max-width: 782px) {
  .wp-block-navigation__responsive-container.is-menu-open {
    left: auto;
    right: 0;
    width: 80%;
    max-width: 100%;
    background-color: #fff !important;
    padding: clamp(1rem, var(--wp--style--root--padding-top), 20rem) clamp(1.25rem, var(--wp--style--root--padding-right), 20rem) clamp(1rem, var(--wp--style--root--padding-bottom), 20rem) clamp(1.25rem, var(--wp--style--root--padding-left), 20rem);
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.08);
  }
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    padding-top: calc(2rem + 24px);
  }
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    color: var(--wp--preset--color--custom-dark-primary, #2d3f42);
  }
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-page-list {
    gap: 0.75rem;
  }
  .wp-block-navigation__responsive-container-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
  }
}
/**
 * Page template: smaller h2, h3, h4 in post content (body.page = page template).
 * Front and editor.
 */
body.page-simple .wp-block-post-content h2,
body.page-simple .wp-block-post-content h3,
body.page-simple .wp-block-post-content h4 {
  margin-top: 1.25em;
  margin-bottom: 0.5em;
  line-height: 1.3;
}
body.page-simple .wp-block-post-content h2 {
  font-size: 1.5rem;
}
body.page-simple .wp-block-post-content h3 {
  font-size: 1.25rem;
}
body.page-simple .wp-block-post-content h4 {
  font-size: 1.125rem;
}

/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: Hero section (first content block, "Secction Solution")
 * Top offset for fixed header; video container; admin bar offset.
 * Background: 70% yellow (border-radius bottom-right) / 30% white.
 */
.hero-section,
.hero-section-simple {
  position: relative;
  background-color: #fff;
}
.hero-section::before,
.hero-section-simple::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 70%;
  height: 100%;
  background-color: #fffce9;
  border-bottom-right-radius: 120px;
  z-index: 0;
}
@media (max-width: 599px) {
  .hero-section::before,
  .hero-section-simple::before {
    width: 100%;
  }
}
.hero-section > *,
.hero-section-simple > * {
  position: relative;
  z-index: 1;
}
body.admin-bar .hero-section,
body.admin-bar .hero-section-simple {
  padding-top: 252px !important;
}
@media (max-width: 782px) {
  body.admin-bar .hero-section,
  body.admin-bar .hero-section-simple {
    padding-top: 126px !important;
  }
}

.hero-video-container {
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  overflow: hidden;
}

.hero-section-simple {
  padding-top: 120px !important;
}
body.admin-bar .hero-section-simple {
  padding-top: 152px !important;
}
@media (max-width: 782px) {
  body.admin-bar .hero-section-simple {
    padding-top: 126px !important;
  }
}

/**
 * Pattern: What section ("What changes with CPQ")
 * 3.1 Signature block — yellow highlight; pseudo extends it left past container.
 */
/**
 * Reusable SCSS mixins.
 * Use via @use '../mixins' as m; then @include m.extend-bg-left(...);
 */
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
.what-signature {
  position: relative;
  overflow: visible;
  background-color: var(--wp--preset--color--custom-yellow-secondaty, #fcf0b6);
}
.what-signature::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 100%;
  width: max(0px, 50vw - 50%);
  background-color: var(--wp--preset--color--custom-yellow-secondaty, #fcf0b6);
}

.wp-block-group:has(> .what-signature) {
  overflow: visible;
}

/**
 * Pattern: What section ("What changes with CPQ")
 * 3.1 Signature block — yellow highlight; pseudo extends it left past container.
 */
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: What's section ("What's typically included in a CPQ build")
 * 5.1 Right column — vertical timeline line in the center.
 */
.whats-included-col {
  position: relative;
}

.whats-included-list {
  position: relative;
}
.whats-included-list::before {
  content: "";
  position: absolute;
  left: 31px;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: #d0d5d8;
  transform: translateX(-50%);
  z-index: 0;
}
.whats-included-list > * {
  position: relative;
  z-index: 1;
}

/**
 * Pattern: What section ("What changes with CPQ")
 * 3.1 Signature block — yellow highlight; pseudo extends it left past container.
 */
/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: How section ("How We Start")
 * 6.1 Extend dark background to the right of steps (content edge to viewport).
 */
.how-section {
  overflow: visible;
}
@media (max-width: 599px) {
  .how-section {
    overflow-x: hidden;
  }
}

.how-section-inner {
  position: relative;
  overflow: visible;
}
.how-section-inner::after {
  content: "";
  position: absolute;
  left: 100%;
  top: 0;
  bottom: 0;
  width: max(0px, 50vw - 50%);
  background-color: var(--wp--preset--color--custom-dark-secondary, #314549);
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 599px) {
  .how-section-inner::after {
    display: none;
  }
}

/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * #solution — текст + зображення в колонках.
 * На планшеті/лаптопі інколи layout «стекується» або flex ламається через вкладені групи;
 * фіксуємо горизонтальний ряд і акуратніше показуємо breakout-зображення.
 */
@media (min-width: 782px) and (max-width: 1199px) {
  #solution .wp-block-columns {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center;
  }
  #solution .wp-block-columns > .wp-block-column {
    min-width: 0;
  }
  #solution figure.img-desktop-breakout-right img,
  #solution .wp-block-image.img-desktop-breakout-right img {
    object-fit: contain;
    object-position: right center;
  }
}

/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Use cases grid (#cases / .user-cases)
 * Laptop / tablet: 2×2 сітка; відступ знизу; картки не дають зображенню вилазити за border-radius.
 */
#cases .wp-block-columns.user-cases,
.wp-block-columns.user-cases {
  /*
   * WP (theme.json layout): :where(.is-layout-constrained) > :last-child { margin-block-end: 0 }
   * через це сітка прилипає до наступної секції / футера.
   */
  margin-block-end: clamp(2rem, 5vw, 3.5rem) !important;
  margin-bottom: clamp(2rem, 5vw, 3.5rem) !important;
  /* Кожна колонка = картка: обрізка по заокругленню (зображення не «рве» кути) */
}
#cases .wp-block-columns.user-cases > .wp-block-column,
.wp-block-columns.user-cases > .wp-block-column {
  border-radius: 16px;
  overflow: hidden;
  min-width: 0;
}
#cases .wp-block-columns.user-cases,
.wp-block-columns.user-cases {
  /* Група всередині колонки — overflow, щоб контент не виходив за кліп колонки */
}
#cases .wp-block-columns.user-cases > .wp-block-column > .wp-block-group,
#cases .wp-block-columns.user-cases > .wp-block-column > .wp-block-stack,
.wp-block-columns.user-cases > .wp-block-column > .wp-block-group,
.wp-block-columns.user-cases > .wp-block-column > .wp-block-stack {
  overflow: hidden;
  min-height: 0;
}
#cases .wp-block-columns.user-cases > .wp-block-column .wp-block-image,
#cases .wp-block-columns.user-cases > .wp-block-column figure.wp-block-image,
.wp-block-columns.user-cases > .wp-block-column .wp-block-image,
.wp-block-columns.user-cases > .wp-block-column figure.wp-block-image {
  overflow: hidden;
  margin-block-end: 0;
}
#cases .wp-block-columns.user-cases > .wp-block-column img,
.wp-block-columns.user-cases > .wp-block-column img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}
@media (min-width: 782px) and (max-width: 1199px) {
  #cases .wp-block-columns.user-cases,
  .wp-block-columns.user-cases {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--wp--style--block-gap, 1.5rem);
    align-items: stretch;
  }
  #cases .wp-block-columns.user-cases > .wp-block-column,
  .wp-block-columns.user-cases > .wp-block-column {
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: auto !important;
  }
}

/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: CTA section (Contact form + headline + image)
 * 9.1 CF7 form. 9.2 Align with design: form layout, image card, legal text.
 */
.section-above-cta {
  position: relative;
  z-index: 1;
}
@media (max-width: 599px) {
  .section-above-cta .wp-block-columns .wp-block-column:first-child > .wp-block-group {
    margin-top: -50px !important;
  }
  .section-above-cta .wp-block-columns .wp-block-column > .wp-block-group {
    margin-top: 0 !important;
  }
}

/* Overlap (pull-up) only on front page; on other pages (e.g. Privacy Policy) CTA must not cover content */
.cta-section {
  padding-top: 100px;
  border-top-left-radius: 24px;
  overflow: visible;
}
.cta-section .wp-block-group.alignwide {
  overflow: visible;
}
.cta-section .intro-call-section {
  z-index: 8;
  position: relative;
  margin-top: -125px;
}

body:not(.home) .cta-section {
  margin-top: 0;
  padding-top: 80px;
}
body:not(.home) .cta-section .intro-call-section {
  margin-top: 0;
}

.cta-section .wpcf7-form.sent .row {
  display: none !important;
}
.cta-section .wpcf7-form {
  max-width: 560px;
  display: flex;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  font-family: var(--wp--preset--font-family--poppins, "Poppins", sans-serif);
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.cta-section .wpcf7-form > fieldset {
  grid-column: 1/-1;
}
.cta-section .wpcf7-form {
  /* Name = left column, Email = right column (actual DOM: 2nd and 3rd child divs) */
}
.cta-section .wpcf7-form > div:nth-child(2) {
  grid-column: 1;
  margin: 0;
  min-width: 0;
}
.cta-section .wpcf7-form > div:nth-child(3) {
  grid-column: 2;
  margin: 0;
  min-width: 0;
}
.cta-section .wpcf7-form {
  /* Textarea full width */
}
.cta-section .wpcf7-form > div:nth-child(4) {
  grid-column: 1/-1;
  margin: 0;
}
.cta-section .wpcf7-form {
  /* Submit + legal on one row */
}
.cta-section .wpcf7-form > div.cta-form-submit-wrap {
  grid-column: 1/-1;
  margin: 0;
}
@media (max-width: 599px) {
  .cta-section .wpcf7-form > div.cta-form-submit-wrap {
    display: flex;
    flex-direction: column;
    align-content: space-around;
    gap: 16px;
  }
}
.cta-section .wpcf7-form > div.wpcf7-response-output {
  grid-column: 1/-1;
  margin: 0;
}
.cta-section .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
  position: relative;
}
.cta-section .wpcf7-form input[type=text],
.cta-section .wpcf7-form input[type=email] {
  width: 100%;
  min-height: 48px;
  padding: 12px 16px;
  background-color: transparent;
  border: 1px solid #aaaaaa;
  border-radius: 8px;
  color: #e0e6eb;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  box-sizing: border-box;
}
.cta-section .wpcf7-form input[type=text]::placeholder,
.cta-section .wpcf7-form input[type=email]::placeholder {
  color: #99a3a6;
}
.cta-section .wpcf7-form textarea.wpcf7-form-control {
  width: 100%;
  min-height: 72px;
  max-height: 100px;
  height: 100px;
  padding: 12px 16px;
  background-color: transparent;
  border: 1px solid #aaaaaa;
  border-radius: 6px;
  color: #e0e6eb;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  box-sizing: border-box;
  resize: none;
}
.cta-section .wpcf7-form textarea.wpcf7-form-control::placeholder {
  color: #99a3a6;
}
.cta-section .wpcf7-form input[type=submit],
.cta-section .wpcf7-form .wpcf7 input[type=submit] {
  align-self: stretch;
  padding: 16px 36px;
  background-color: #fdcb04 !important;
  color: #2d3b3f;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  border: none;
  border-radius: 6px;
  cursor: pointer;
}
.cta-section .wpcf7-form input[type=submit]:disabled, .cta-section .wpcf7-form input[type=submit][disabled],
.cta-section .wpcf7-form .wpcf7 input[type=submit]:disabled,
.cta-section .wpcf7-form .wpcf7 input[type=submit][disabled] {
  opacity: 0.45;
  filter: grayscale(0.4);
  cursor: not-allowed;
}
.cta-section .wpcf7-form .cta-form-submit-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.25rem;
}
.cta-section .wpcf7-form .cta-form-submit-wrap .button {
  width: auto;
  max-width: min-content;
  margin-bottom: 0;
  padding: 0;
  height: 55px;
}
.cta-section .wpcf7-form .cta-form-submit-wrap .button input[type=submit] {
  width: auto;
  box-sizing: border-box;
  border-radius: 6px;
}
.cta-section .wpcf7-form .wpcf7-acceptance,
.cta-section .wpcf7-form div:has(.wpcf7-acceptance),
.cta-section .wpcf7-form div.legal-text,
.cta-section .wpcf7-form .cta-form-submit-wrap .legal-text {
  text-align: left;
  margin-top: 0;
  margin-bottom: 0;
  max-width: 100%;
}
.cta-section .wpcf7-form {
  /* Custom checkbox styling for acceptance field */
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-form-control {
  display: inline-block;
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}
.cta-section .wpcf7-form .wpcf7-acceptance label {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
  position: relative;
  padding-left: 0;
}
.cta-section .wpcf7-form .wpcf7-acceptance input[type=checkbox] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label {
  position: relative;
  padding-left: 26px;
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 2px;
  width: 16px;
  height: 16px;
  box-sizing: border-box;
  border-radius: 3px;
  border: 2px solid #aaaaaa;
  background-color: transparent;
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 6px;
  height: 10px;
  border: 2px solid #2d3b3f;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
  opacity: 0;
  transition: opacity 0.15s ease;
}
.cta-section .wpcf7-form .wpcf7-acceptance input[type=checkbox]:checked + .wpcf7-list-item-label::before {
  background-color: #fdcb04;
  border-color: #fdcb04;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.25);
}
.cta-section .wpcf7-form .wpcf7-acceptance input[type=checkbox]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.cta-section .wpcf7-form .cta-form-submit-wrap .legal-text {
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.4;
  color: #aaaaaa;
  flex: 1;
  min-width: 0;
}
.cta-section .wpcf7-form .cta-form-submit-wrap .legal-text a {
  text-decoration: none;
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label,
.cta-section .wpcf7-form label,
.cta-section .wpcf7-form .legal-text {
  font-family: inherit;
  color: #aaaaaa;
  font-size: 0.875rem;
  font-weight: 400;
}
.cta-section .wpcf7-form a {
  color: #e0e6eb;
  font-weight: 700;
  text-decoration: underline;
}
.cta-section .wpcf7-form .wpcf7-response-output,
.cta-section .wpcf7-form .wpcf7-not-valid-tip {
  margin: 0.5rem 0 0;
  padding: 0;
  border: none;
  background: none;
  color: #99a3a6;
  font-size: 0.875rem;
}
.cta-section .wpcf7-form .row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 100%;
  width: 100%;
}
.cta-section .wpcf7-form .row .half {
  flex: 1;
  min-width: 0;
}
.cta-section .wpcf7-form .row .full {
  width: 100%;
  flex: 0 0 100%;
}
.cta-section .wpcf7-form .wpcf7-not-valid-tip {
  position: absolute;
  font-size: 12px;
  top: -3px;
  right: 6px;
  color: var(--wp--preset--color--custom-yellow) !important;
}
.cta-section .wpcf7-form {
  /* Acceptance field validation tip should appear under checkbox label */
}
.cta-section .wpcf7-form .wpcf7-acceptance .wpcf7-not-valid-tip,
.cta-section .wpcf7-form div:has(.wpcf7-acceptance) .wpcf7-not-valid-tip {
  position: static;
  margin-top: 6px;
  right: auto;
  top: auto;
}
.cta-section .wpcf7-form .wpcf7-response-output {
  padding-top: 10px;
  color: var(--wp--preset--color--custom-yellow) !important;
  font-size: 18px;
}
.cta-section .wpcf7-form {
  /* Після успішної відправки: ховати тіло форми, показувати лише повідомлення великим шрифтом */
}
.cta-section .wpcf7-form form.wpcf7-form.sent > fieldset,
.cta-section .wpcf7-form form.wpcf7-form.sent > div.row,
.cta-section .wpcf7-form form.wpcf7-form.sent > div.cta-form-submit-wrap,
.cta-section .wpcf7-form form.wpcf7-form[data-status=sent] > fieldset,
.cta-section .wpcf7-form form.wpcf7-form[data-status=sent] > div.row,
.cta-section .wpcf7-form form.wpcf7-form[data-status=sent] > div.cta-form-submit-wrap {
  display: none !important;
}
.cta-section .wpcf7-form form.wpcf7-form.sent > .wpcf7-response-output,
.cta-section .wpcf7-form form.wpcf7-form[data-status=sent] > .wpcf7-response-output {
  display: block !important;
  font-size: 2em;
  font-weight: 600;
  line-height: 1.35;
  padding-top: 1em;
  padding-bottom: 1em;
  margin: 0;
}
@media (max-width: 600px) {
  .cta-section .wpcf7-form {
    grid-template-columns: 1fr;
  }
  .cta-section .wpcf7-form > div:nth-child(2),
  .cta-section .wpcf7-form > div:nth-child(3) {
    grid-column: 1;
  }
  .cta-section .row {
    flex-direction: column !important;
  }
  .cta-section .row .half,
  .cta-section .row .full {
    flex: 0 0 100%;
    width: 100%;
  }
  .cta-section .cta-form-submit-wrap {
    flex-direction: column;
    align-items: stretch;
  }
  .cta-section .cta-form-submit-wrap .button {
    width: 100%;
    max-width: 100%;
  }
  .cta-section .cta-form-submit-wrap .button input[type=submit] {
    width: 100%;
  }
}
@media (max-width: 600px) and (max-width: 599px) {
  .cta-section .cta-form-submit-wrap .button {
    width: 100% !important;
    max-width: 100% !important;
  }
  .cta-section .cta-form-submit-wrap .button input[type=submit] {
    width: 100% !important;
  }
}

@media (max-width: 599px) {
  .cta-section .wpcf7-form .cta-form-submit-wrap .legal-text {
    text-align: center;
  }
}

/* Form card: rounded container for heading + form (design: floats on dark section). Width not limited — only the form inside is max 540px. */
.cta-section-form {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--30, 1.5rem);
  background-color: #354244;
  border-radius: 24px;
  padding: 2rem 1.75rem;
  font-family: var(--wp--preset--font-family--poppins, "Poppins", sans-serif);
}
.cta-section-form .wp-block-heading,
.cta-section-form h1, .cta-section-form h2, .cta-section-form h3 {
  color: #e0e6eb;
  font-family: inherit;
  font-weight: 600;
}
.cta-section-form p:not(.wpcf7-form p) {
  color: #99a3a6;
  font-family: inherit;
  font-size: 1rem;
}
@media (max-width: 599px) {
  .cta-section-form {
    max-width: 90%;
    margin-top: -50px !important;
    padding-top: 80px !important;
    border-bottom-right-radius: 42px !important;
  }
}

.cta-section-image-card {
  align-self: flex-end;
  margin-top: -48px;
  width: 570px;
  height: 570px;
  max-width: 100%;
  background-color: #2a3638;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
  flex-shrink: 0;
}
.cta-section-image-card .cta-section-image-img,
.cta-section-image-card figure {
  margin: 0;
  line-height: 0;
  width: 100%;
  height: 100%;
}
.cta-section-image-card img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  vertical-align: middle;
}
@media (max-width: 599px) {
  .cta-section-image-card {
    max-width: 90%;
    margin: 0 auto !important;
    margin-top: -150px !important;
  }
}

/**
 * Entry point: front-end styles.
 * Compiles to assets/css/style.css
 */
/**
 * Pattern: Footer (parts/footer.html)
 * Dark background, copyright left, links right.
 * Підкреслення та ховер — як у хедера: лінія зліва направо, primary yellow.
 */
footer.wp-block-template-part a,
.wp-block-template-part footer a {
  position: relative;
  padding-bottom: 1px;
  border-bottom: 1px solid currentColor;
  transition: color 0.25s ease, border-color 0.25s ease;
}
footer.wp-block-template-part a::after,
.wp-block-template-part footer a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  height: 1px;
  width: 0;
  background-color: var(--wp--preset--color--custom-yellow, #f6d013);
  transition: width 0.25s ease;
}
footer.wp-block-template-part a:hover,
.wp-block-template-part footer a:hover {
  color: var(--wp--preset--color--custom-yellow, #f6d013) !important;
  border-bottom-color: transparent;
}
footer.wp-block-template-part a:hover::after,
.wp-block-template-part footer a:hover::after {
  width: 100%;
}

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