@charset "UTF-8";
/**
 * --- Abstracts (tiché — pouze mixiny, funkce; žádný CSS output) ---
 * Není potřeba importovat zde — partialy si je importují samy přes @use "../abstracts".
 * Výjimka: pokud main.scss sám potřebuje mixiny (v sekci stránkových stylů níže).
 */
/**
 * --- Base (globální reset, CSS custom properties) ---
 * Musí být první, protože ostatní části používají CSS custom properties.
 */
:root {
  --transition: all 0.3s ease-in-out;
  --padding-on-side: 40px;
  --margins: 1em;
  --gap: 40px;
  --gap-smaller: 20px;
  --shadow: 6px 6px 48px 0 rgba(235, 94, 58, 0.66);
  --shadow-hover: 6px 6px 84px 0 #EB5E3A;
  --border-radius-smaller: 0px;
  --border-radius-small: 0px;
  --border-radius: 0px;
  --border-radius-big: 0px;
  --border-radius-bigger: 0px;
  --content-smaller: 900px;
  --content-small: 1200px;
  --content-regular: 1640px;
  --content-big: 1640px;
  --content-bigger: 1720px;
  --font-weight-thin: 100;
  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-black: 900;
  --line-height: 1.5;
  --letter-spacing: normal;
  --font-size-10: 10px;
  --font-size-11: 11px;
  --font-size-12: 12px;
  --font-size-13: 13px;
  --font-size-14: 14px;
  --font-size-15: 15px;
  --font-size-16: 16px;
  --font-size-17: 17px;
  --font-size-18: 18px;
  --font-size-20: 20px;
  --font-size-24: 24px;
  --font-size-28: 28px;
  --font-size-32: 32px;
  --font-size-36: 36px;
  --font-size-40: 40px;
  --font-size-48: 48px;
  --font-size-56: 56px;
  --font-size-64: 64px;
  --font-size-72: 72px;
  --font-size-90: 90px;
  --font-size-120: 120px;
  --font-heading: "DM Sans", sans-serif;
  --font-basic: "DM Sans", sans-serif;
  --color-white: #fff;
  --color-black: #000;
  --color-green: #1a5632;
  --color-red: #d8000c;
  --color-success: #164427;
  --color-warning: #cf7500;
  --color-error: #9c0000;
  --color-title: #2E338B;
  --color-heading: #2E338B;
  --color-text: #000000;
  --color-primary-light: #2E338B;
  --color-primary: #2E338B;
  --color-primary-dark: #00032C;
  --color-secondary-light: #EB5E3A;
  --color-secondary: #EB5E3A;
  --color-secondary-dark: #EB5E3A;
  --color-light: #F2F2F2;
  --color-border: var(--color-primary);
  --gradient-circular: radial-gradient(1500px at 20% 400px, rgba(var(--color-primary-dark-rgb), 0.66) 0%, rgba(var(--color-primary-dark-rgb), 0) 100%);
  --color-heading-rgb: 46, 51, 139;
  --color-text-rgb: 0, 0, 0;
  --color-primary-light-rgb: 46, 51, 139;
  --color-primary-rgb: 46, 51, 139;
  --color-primary-dark-rgb: 0, 3, 44;
  --color-white-rgb: 255, 255, 255;
  --color-black-rgb: 0, 0, 0;
  --page-background-color: var(--color-white);
  --page-default-font-size: var(--font-size-18);
  --page-default-font-color: var(--color-text);
  --page-default-font-family: var(--font-basic);
  --page-default-line-height: 1.25;
  --page-letter-spacing: normal;
  accent-color: var(--color-primary);
}

@media screen and (max-width: 1400px) {
  :root {
    --padding-on-side: 30px;
    --gap: 30px;
    --font-size-12: 12px;
    --font-size-14: 13px;
    --font-size-16: 15px;
    --font-size-17: 16px;
    --font-size-18: 16px;
    --font-size-20: 18px;
    --font-size-24: 22px;
    --font-size-28: 24px;
    --font-size-32: 26px;
    --font-size-36: 30px;
    --font-size-40: 36px;
    --font-size-48: 40px;
    --font-size-56: 44px;
    --font-size-64: 48px;
    --font-size-72: 60px;
    --font-size-90: 72px;
    --font-size-120: 80px;
  }
}
@media screen and (max-width: 1024px) {
  :root {
    --padding-on-side: 24px;
    --gap: 24px;
    --font-size-12: 11px;
    --font-size-14: 12px;
    --font-size-16: 14px;
    --font-size-17: 15px;
    --font-size-18: 15px;
    --font-size-20: 18px;
    --font-size-24: 20px;
    --font-size-28: 22px;
    --font-size-32: 21px;
    --font-size-36: 28px;
    --font-size-40: 28px;
    --font-size-48: 32px;
    --font-size-56: 36px;
    --font-size-64: 38px;
    --font-size-72: 56px;
    --font-size-90: 60px;
    --font-size-120: 66px;
  }
}
@media screen and (max-width: 660px) {
  :root {
    --padding-on-side: 16px;
    --gap: 16px;
    --font-size-12: 11px;
    --font-size-14: 12px;
    --font-size-16: 13px;
    --font-size-17: 14px;
    --font-size-18: 14px;
    --font-size-20: 16px;
    --font-size-24: 16px;
    --font-size-28: 18px;
    --font-size-32: 18px;
    --font-size-36: 20px;
    --font-size-40: 20px;
    --font-size-48: 24px;
    --font-size-56: 28px;
    --font-size-64: 32px;
    --font-size-72: 40px;
    --font-size-90: 42px;
    --font-size-120: 44px;
  }
}
:root {
  /*---- Basic ----*/
  --icon-warning: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='22'%3E%3Cpath fill-rule='evenodd' fill='%23000' d='M2 15a2 2 0 01-2-2V1.999a2 2 0 014 0V13a2 2 0 01-2 2zm0 3a2 2 0 110 4 2 2 0 010-4z'/%3E%3C/svg%3E");
  --icon-ok: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14.6 12.8'%3E%3Cpath fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M12.9 1.6l-7.2 9.7-4.1-4.9'/%3E%3C/svg%3E");
  --icon-loading: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23000'%3E%3Cpath d='M463.702 162.655L442.491 14.164c-1.744-12.174-16.707-17.233-25.459-8.481l-30.894 30.894C346.411 12.612 301.309 0 254.932 0 115.464 0 3.491 109.16.005 248.511c-.19 7.617 5.347 14.15 12.876 15.234l59.941 8.569c8.936 1.304 17.249-5.712 17.125-15.058C88.704 165.286 162.986 90 254.932 90c22.265 0 44.267 4.526 64.6 13.183l-29.78 29.78c-8.697 8.697-3.761 23.706 8.481 25.459l148.491 21.211c9.784 1.475 18.381-7.034 16.978-16.978zM499.117 249.412l-59.897-8.555c-7.738-.98-17.124 5.651-17.124 16.143 0 90.981-74.019 165-165 165a165.207 165.207 0 01-64.306-13.052l28.828-28.828c8.697-8.697 3.761-23.706-8.481-25.459L64.646 333.435c-9.753-1.393-18.39 6.971-16.978 16.978l21.21 148.492c1.746 12.187 16.696 17.212 25.459 8.481l31.641-31.626C165.514 499.505 210.587 512 257.096 512c138.794 0 250.752-108.618 254.897-247.28.22-7.632-5.317-14.224-12.876-15.308z'/%3E%3C/svg%3E");
  --icon-quote: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 53.5 40'%3E%3Cpath fill='%23a09488' stroke-width='0' d='M24.8 21.9v11.4c0 3.7-3 6.7-6.7 6.7H6.7C3 40 0 37 0 33.3V17.9C0 9 9.7 1.7 11.9.1c.3-.2.6-.1.8 0 .2.2.2.6 0 .8-1.2 1.3-5.4 6.2-6.1 9.9-.7 4 .9 4.3 4.6 4.3H18c3.7 0 6.7 3 6.7 6.7Zm22-6.7H40c-3.7 0-5.3-.3-4.6-4.3.7-3.7 4.8-8.6 6.1-9.9.2-.2.2-.6 0-.8-.2-.2-.6-.3-.8 0C38.5 1.8 28.8 9.1 28.8 18v15.4c0 3.7 3 6.7 6.7 6.7h11.4c3.7 0 6.7-3 6.7-6.7V22c0-3.7-3-6.7-6.7-6.7Z' /%3E%3C/svg%3E");
  /*---- /Basic ----*/
  --icon-arrow-right: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='19' height='16' viewBox='0 0 19 16' fill='none'%3E%3Cpath d='M10.8301 0.199707C10.9856 0.199707 11.1351 0.261589 11.2451 0.371582L18.1992 7.32666C18.2536 7.38105 18.2977 7.44505 18.3271 7.51611C18.3566 7.5872 18.3711 7.66377 18.3711 7.74072C18.3711 7.81766 18.3566 7.89424 18.3271 7.96533C18.2976 8.03651 18.2537 8.1013 18.1992 8.15576L11.2451 15.1099C11.1351 15.2199 10.9856 15.2817 10.8301 15.2817C10.6746 15.2817 10.525 15.2198 10.415 15.1099C10.3054 15 10.2442 14.8511 10.2441 14.6958C10.2441 14.5403 10.3052 14.3907 10.415 14.2808L16.3682 8.32764L0.785156 8.32764C0.629655 8.32764 0.48008 8.26571 0.370117 8.15576C0.260153 8.0458 0.198242 7.89624 0.198242 7.74072C0.198323 7.58539 0.260324 7.43654 0.370117 7.32666C0.480082 7.2167 0.629643 7.15479 0.785156 7.15479L16.3691 7.15479L10.415 1.20166C10.3051 1.09169 10.2442 0.942133 10.2441 0.786621C10.2441 0.631124 10.3051 0.481571 10.415 0.371582C10.525 0.261619 10.6746 0.199754 10.8301 0.199707Z' fill='%23EB5E3A' stroke='%23EB5E3A' stroke-width='0.4' /%3E%3C/svg%3E");
  --icon-arrow-right-smaller: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='31' height='25' fill='none'%3E%3Cpath fill='%232E338B' d='M29.995 12.933 18.184 24.746a.656.656 0 1 1-.928-.929l10.691-10.692H.656a.657.657 0 0 1 0-1.312h27.29L17.254 1.12a.656.656 0 1 1 .929-.929l11.813 11.813a.655.655 0 0 1 0 .928Z' /%3E%3C/svg%3E");
  --icon-inquiry: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='23' height='23' fill='none'%3E%3Cpath fill='%23EB5E3A' fill-rule='evenodd' d='M23 0v17.889h-6.389V23l-7.794-5.111H0V0h23Zm-2.556 2.556H2.556v12.777H9.58l4.476 2.935v-2.935h6.388V2.556Zm-8.888 9.487c.41 0 .748.135 1.014.404.268.27.401.61.401 1.019 0 .404-.133.74-.4 1.01-.268.27-.606.405-1.015.405-.42 0-.761-.135-1.026-.405-.264-.27-.396-.614-.396-1.033 0-.4.134-.732.404-1 .27-.266.609-.4 1.018-.4Zm.554-8.146c1.138 0 2.004.27 2.598.809.524.484.786 1.113.786 1.887 0 .524-.127.972-.382 1.343-.223.326-.598.675-1.126 1.048l-.236.162c-.5.334-.806.59-.921.767-.115.177-.172.493-.172.947v.307h-2.21v-.659c0-.634.066-1.075.196-1.325a1.35 1.35 0 0 1 .3-.386l.138-.116.205-.156.803-.575c.339-.248.57-.444.691-.586a.993.993 0 0 0 .243-.667c0-.32-.113-.572-.34-.76-.227-.187-.535-.28-.925-.28-.639 0-1.41.257-2.313.77l-.667-1.661c1.108-.58 2.219-.869 3.332-.869Z' clip-rule='evenodd' /%3E%3C/svg%3E");
  --icon-linkedin: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%232E338B' d='M19 3a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h14Zm-.5 15.5v-5.3a3.26 3.26 0 0 0-3.26-3.26c-.85 0-1.84.52-2.32 1.3v-1.11h-2.79v8.37h2.79v-4.93c0-.77.62-1.4 1.39-1.4a1.4 1.4 0 0 1 1.4 1.4v4.93h2.79ZM6.88 8.56a1.68 1.68 0 0 0 1.68-1.68c0-.93-.75-1.69-1.68-1.69a1.69 1.69 0 0 0-1.69 1.69c0 .93.76 1.68 1.69 1.68Zm1.39 9.94v-8.37H5.5v8.37h2.77Z' /%3E%3C/svg%3E");
  --icon-instagram: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 24 24'%3E%3Cpath fill='%232e338b' stroke-width='0' d='M13 2c2.9 0 5.2-.3 7.3 1.7 2 2 1.6 4.4 1.7 7.3v4.2c0 2-.3 3.8-1.7 5.1-2.1 2.1-5 1.6-8 1.7-2.9-.1-6.5.5-8.6-1.7C1.8 18.5 2.1 15.5 2 13V8.8c0-2 .3-3.8 1.7-5.1C5 2.3 6.8 2.1 8.8 2H13Zm-1 5c-6.6.2-6.6 9.8 0 10 6.6-.2 6.6-9.8 0-10Zm0 2c4 .1 4 5.9 0 6-4-.1-4-5.9 0-6m5.3-3.5c-1.6 0-1.6 2.5 0 2.5s1.6-2.5 0-2.5Z' /%3E%3C/svg%3E");
  --icon-facebook: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%232E338B' d='M22 12c0-5.52-4.48-10-10-10S2 6.48 2 12c0 4.84 3.44 8.87 8 9.8V15H8v-3h2V9.5C10 7.57 11.57 6 13.5 6H16v3h-2c-.55 0-1 .45-1 1v2h3v3h-3v6.95c5.05-.5 9-4.76 9-9.95Z' /%3E%3C/svg%3E");
  --icon-youtube: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cmask id='a' width='20' height='16' x='2' y='4' maskUnits='userSpaceOnUse' style='mask-type:luminance'%3E%3Cpath fill='%23fff' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 5c9 0 9 0 9 7s0 7-9 7-9 0-9-7 0-7 9-7Z' /%3E%3Cpath fill='%23000' d='m10 8.5 6 3.5-6 3.5v-7Z' /%3E%3C/mask%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%232E338B' d='M0 0h24v24H0V0Z' /%3E%3C/g%3E%3C/svg%3E");
  --icon-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21' height='18' fill='none'%3E%3Cpath stroke='%23EB5E3A' stroke-width='4.167' d='m1.492 8.754 5.552 5.687 12.448-13' /%3E%3C/svg%3E");
  --icon-arrow-up: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='25' height='14' fill='none'%3E%3Cpath stroke='%232E338B' d='m.352 12.707 12-12 12 12' /%3E%3C/svg%3E");
  --icon-info: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 20 20'%3E%3Cpath fill='%23c7c9f8' stroke-width='0' d='M10 0C4.48 0 0 4.48 0 10s4.48 10 10 10 10-4.48 10-10S15.52 0 10 0Zm1 15H9V9h2v6Zm0-8H9V5h2v2Z' /%3E%3C/svg%3E");
  --icon-globe: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23EB5E3A' stroke-width='2' d='M12 23c6.075 0 11-4.925 11-11S18.075 1 12 1m0 22C5.925 23 1 18.075 1 12S5.925 1 12 1m0 22c3 0 4-5 4-11S15 1 12 1m0 22c-3 0-4-5-4-11S9 1 12 1M2 16h20M2 8h20' /%3E%3C/svg%3E");
  --icon-arrow-language-switcher: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='8' viewBox='0 0 13 8' fill='none'%3E%3Cpath d='M11.91 -0.00016065L12.97 1.06084L7.193 6.83984C7.10043 6.93299 6.99036 7.00692 6.86911 7.05737C6.74786 7.10782 6.61783 7.13379 6.4865 7.13379C6.35517 7.13379 6.22514 7.10782 6.10389 7.05737C5.98264 7.00692 5.87257 6.93299 5.78 6.83984L2.65457e-07 1.06084L1.06 0.000838803L6.485 5.42484L11.91 -0.00016065Z' fill='%23EB5E3A' /%3E%3C/svg%3E");
  --icon-send: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='23' height='20' fill='none'%3E%3Cpath fill='%23EB5E3A' d='M0 20V0l23 10L0 20Zm2.421-3.75L16.766 10 2.42 3.75v4.375L9.684 10l-7.263 1.875v4.375Z' /%3E%3C/svg%3E");
  --icon-upload: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23EB5E3A' d='M11 16V7.85l-2.6 2.6L7 9l5-5 5 5-1.4 1.45-2.6-2.6V16h-2Zm-5 4c-.55 0-1.02-.196-1.412-.587A1.93 1.93 0 0 1 4 18v-3h2v3h12v-3h2v3c0 .55-.196 1.021-.587 1.413A1.92 1.92 0 0 1 18 20H6Z' /%3E%3C/svg%3E");
  --icon-attachment: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23fff' d='M12.5 23c3.04 0 5.5-2.46 5.5-5.5V6h-1.5v11.5c0 2.21-1.79 4-4 4s-4-1.79-4-4V5a2.5 2.5 0 1 1 5 0v10.5c0 .55-.45 1-1 1s-1-.45-1-1V6H10v9.5a2.5 2.5 0 0 0 5 0V5c0-2.21-1.79-4-4-4S7 2.79 7 5v12.5c0 3.04 2.46 5.5 5.5 5.5Z' /%3E%3C/svg%3E");
  --icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='19' height='19' fill='none'%3E%3Cpath fill='%23EB5E3A' d='m10.219 9.152 8.086 8.098-1.055 1.055-8.098-8.086-8.097 8.086L0 17.25l8.086-8.098L0 1.055 1.055 0l8.097 8.086L17.25 0l1.055 1.055-8.086 8.097Z' /%3E%3C/svg%3E");
  --icon-close-menu: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='18' viewBox='0 0 40 18' fill='none'%3E%3Cline x1='11.6132' y1='16.707' x2='27.6132' y2='0.706956' stroke='%232E338B' stroke-width='2' /%3E%3Cline x1='12.0352' y1='0.706956' x2='28.0352' y2='16.707' stroke='%232E338B' stroke-width='2' /%3E%3C/svg%3E");
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}
* {
  box-sizing: border-box;
  position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6,
ul,
li,
a,
input,
textarea,
p,
body,
span,
menu {
  margin: 0;
  padding: 0;
  line-height: var(--page-default-line-height, 1.25);
}

img {
  border: none;
}

ul li,
menu li {
  list-style: none;
}

a {
  text-decoration: none;
}

a,
svg,
path {
  transition: var(--transition);
}

div,
article,
section,
img,
main,
input,
textarea {
  display: block;
}

input,
textarea,
img,
a,
option,
select,
button,
div {
  outline: none;
}

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

html {
  font-size: var(--page-default-font-size, var(--font-size-18));
  font-family: var(--font-basic);
  font-weight: var(--font-weight-regular);
  font-optical-sizing: auto;
  height: fill-available;
  height: -webkit-fill-available;
  width: 100%;
  overflow-x: hidden;
}

body {
  color: var(--page-default-font-color, var(--color-text));
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  background-color: var(--page-background-color, var(--color-white));
  min-height: 100dvh;
  min-height: fill-available;
  min-height: -webkit-fill-available;
  overflow: clip;
  letter-spacing: var(--page-letter-spacing, normal);
}

/**
 * --- Components (izolované UI komponenty) ---
 * Všechny znovupoužitelné komponenty, které nejsou specifické pro WordPress bloky.
 */
.button,
.wp-block-button {
  --button-text-color: var(--color-primary);
  --button-text-color-hover: var(--color-secondary);
  --button-background-color: transparent;
  --button-background-color-hover: transparent;
  --button-font-size: var(--font-size-18);
  --button-border-radius: 3px;
  --button-border-color: var(--color-primary);
  --button-border: 1px solid var(--button-border-color);
  --button-border-color-hover: var(--color-secondary);
  --button-shadow: transparent;
  --button-shadow-hover: transparent;
  --button-padding: 1.2em clamp(0.8em, 4vw, 1.6em);
  --button-min-width: 320px;
}
.button--smaller,
.wp-block-button--smaller {
  --button-font-size: var(--font-size-16);
}
.button--tiny,
.wp-block-button--tiny {
  --button-font-size: var(--font-size-13);
  --button-padding: 0.4em 0.8em 0.45em;
}
.button.is-style-inquiry .wp-block-button__link,
.wp-block-button.is-style-inquiry .wp-block-button__link {
  --button-text-color: var(--color-primary);
  --button-text-color-hover: var(--color-secondary);
  --button-background-color: var(--color-white);
  --button-background-color-hover: var(--color-white);
  --button-font-size: var(--font-size-16);
  --button-icon-color: var(--color-secondary);
  --button-shadow: var(--shadow);
  --button-shadow-hover: var(--shadow-hover);
  --button-min-width: 0;
  --button-border-color: var(--color-white);
  --button-border-color-hover: var(--color-white);
  --button-padding: 1.2em clamp(1em, 4vw, 2em) 1.2em clamp(0.8em, 4vw, 1.6em);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  gap: 1em;
}
.button.is-style-inquiry .wp-block-button__link:hover,
.wp-block-button.is-style-inquiry .wp-block-button__link:hover {
  gap: 1em;
}
.button.is-style-inquiry .wp-block-button__link::after,
.wp-block-button.is-style-inquiry .wp-block-button__link::after {
  display: none !important;
}
.button.is-style-inquiry .wp-block-button__link::before,
.wp-block-button.is-style-inquiry .wp-block-button__link::before {
  content: "";
  width: 1.5em;
  aspect-ratio: 1/1;
  mask: var(--icon-inquiry) center/contain no-repeat;
  background-color: var(--button-icon-color, var(--button-background-color));
  transition: var(--transition);
  z-index: 2;
  flex-shrink: 0;
}

.button,
.wp-block-button .wp-block-button__link {
  font-family: var(--font-basic);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--button-padding);
  line-height: 1;
  font-size: var(--button-font-size, var(--font-size-16));
  border: var(--button-border, none);
  transition: var(--transition);
  cursor: pointer;
  border-radius: var(--button-border-radius, var(--border-radius));
  text-align: center;
  color: var(--button-text-color, var(--color-white));
  background-color: var(--button-background-color, var(--color-main));
  box-shadow: var(--button-shadow, none);
  min-width: var(--button-min-width, 0);
  gap: 0;
}
.button::after,
.wp-block-button .wp-block-button__link::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 1em;
  mask: var(--icon-arrow-right) center/contain no-repeat;
  background-color: var(--button-text-color-hover, var(--color-white));
  opacity: 0;
  transition: var(--transition);
}
.button:hover,
.wp-block-button .wp-block-button__link:hover {
  color: var(--button-text-color-hover, var(--color-white));
  background-color: var(--button-background-color-hover, var(--color-secondary-light));
  box-shadow: var(--button-shadow-hover, none);
  border-color: var(--button-border-color-hover, var(--color-tertiary));
  gap: clamp(0.5em, 2cqw, 0.75em);
}
.button:hover::after,
.wp-block-button .wp-block-button__link:hover::after {
  width: 1em;
  opacity: 1;
}
@media screen and (max-width: 420px) {
  .button,
  .wp-block-button .wp-block-button__link {
    width: 100%;
  }
}

.form {
  --form-gap: clamp(24px, 3cqw, 32px);
  --form-input-font-family: var(--font-basic);
  --form-input-background-color: var(--color-white);
  --form-input-text-color: var(--color-heading);
  --form-input-placeholder-opacity: 0.5;
  --form-input-border: 1px solid transparent;
  --form-input-border-active: 1px solid transparent;
  --form-input-border-radius: 5px;
  --form-input-padding: 1em 1.25em;
  --form-input-font-size: var(--font-size-18);
  --form-input-padding-horizontal: 1.25em;
  --form-input-padding-vertical: 1em;
  --form-choice-background-color: var(--color-white);
  --form-choice-border: 1px solid rgba(71, 60, 56, 0.25);
  --form-choice-border-active: 1px solid var(--color-primary);
  --form-choice-check-color: var(--color-primary);
  --form-label-text-color: var(--color-heading);
  --form-label-font-size: var(--font-size-18);
  --form-submit-button-background-color: var(--color-white);
  --form-submit-button-text-color: var(--color-primary);
  --form-submit-button-background-color-hover: var(--color-white);
  --form-submit-button-text-color-hover: var(--color-secondary);
  --form-submit-button-indicator-size: 1.2em;
  --form-submit-button-padding: 1.2em clamp(1em, 4vw, 2em) 1.2em clamp(0.8em, 4vw, 1.6em);
  --form-submit-button-border-radius: 3px;
  --form-column-gap: clamp(12px, 1.5vw, 16px);
}
.form__column {
  display: flex;
  flex-direction: column;
  gap: var(--form-column-gap);
}
.form__column--flex-2 .form__item,
.form__column--flex-2 .form__input-wrapper,
.form__column--flex-2 .form__textarea {
  height: 100%;
}
.form__submit-button {
  gap: 0.75em;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  box-shadow: var(--shadow);
  font-weight: var(--font-weight-bold);
}
.form__submit-button:hover {
  box-shadow: var(--shadow-hover);
}
.form__submit-button--loading .form__submit-button-indicator {
  animation: form-spin 1s linear infinite;
  mask: var(--icon-loading) center/contain no-repeat;
}
.form__submit-button-indicator {
  mask: var(--icon-send) center/contain no-repeat;
  background-color: var(--color-secondary);
  animation: none;
  flex-shrink: 0;
  width: 1.5em;
  aspect-ratio: 1/1;
  margin-right: 0 !important;
}
.form__file-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1em;
  border-radius: 9px;
  border: 1px solid var(--ffffff, #FFF);
  background: var(--ffffff, rgba(0, 0, 0, 0.1));
  padding: 16px 16px 16px 32px;
  transition: var(--transition);
}
.form__file-wrap--dragover {
  background: var(--ffffff, rgba(0, 0, 0, 0.2));
}
.form__file-input {
  display: none;
}
.form__file-button {
  display: inline-flex;
  align-items: center;
  gap: 0.8em;
  font-size: var(--font-size-18);
  line-height: 1.15;
  font-weight: var(--font-weight-bold);
  color: var(--color-secondary);
  background: transparent;
  border-radius: 3px;
  border: 1px solid var(--ffffff, #FFF);
  padding: 1em 1.5em;
  order: 2;
}
.form__file-button::before {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--icon-upload) center/contain no-repeat;
  background-color: var(--color-secondary);
  transition: var(--transition);
  z-index: 2;
  flex-shrink: 0;
}
.form__file-button:hover {
  border-color: var(--color-secondary);
}
.form__file-label {
  order: 1;
  color: var(--font-color, var(--color-text));
  font-size: var(--font-size-18);
  font-style: italic;
  display: inline-flex;
  gap: 1em;
  align-items: center;
}
.form__file-label::before {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--icon-attachment) center/contain no-repeat;
  background-color: currentColor;
  z-index: 2;
  flex-shrink: 0;
}
.form__file-label--added {
  display: none;
}
.form__file-drop-icon {
  display: none;
}
.form__file-chips {
  display: none;
}
.form__file-chips--added {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
.form__file-chip {
  color: var(--font-color, var(--color-text));
  font-size: var(--font-size-18);
  display: inline-flex;
  gap: 1em;
  align-items: center;
}
.form__file-chip::before {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--icon-attachment) center/contain no-repeat;
  background-color: currentColor;
  z-index: 2;
  flex-shrink: 0;
}
.form__file-chip-remove {
  width: 1.4em;
  aspect-ratio: 1/1;
  mask: var(--icon-close) center/contain no-repeat;
  background-color: var(--color-secondary);
  transition: var(--transition);
  flex-shrink: 0;
  cursor: pointer;
  border: none;
}
.form__file-chip-remove:hover {
  background-color: var(--color-white);
}
.form .acceptance {
  color: var(--font-color, var(--color-text));
  font-size: var(--font-size-16);
  max-width: 620px;
  line-height: var(--line-height);
}
.form .acceptance a {
  color: var(--font-color, var(--color-text)) !important;
  text-decoration: underline;
}
.form .acceptance a:hover {
  text-decoration: none;
}
.form__row--bordered {
  border-radius: 9px;
  border: 1px solid var(--ffffff, #FFF);
  background: var(--ffffff, rgba(0, 0, 0, 0.1));
  padding: clamp(24px, 4cqw, 40px) clamp(16px, 3cqw, 32px);
}
.form__free-sample-checkbox .form__label {
  display: none;
}
.form__checkbox-label {
  --checkbox-size: clamp(20px, 3cqw, 24px);
  gap: 1.5em;
  align-items: center;
}
.form__checkbox-label::before {
  height: var(--checkbox-size);
  width: var(--checkbox-size);
  aspect-ratio: 1/1;
  border-radius: 3px;
  box-shadow: var(--shadow);
}
.form__checkbox-label::after {
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  aspect-ratio: 1/1;
  background-color: var(--color-secondary);
}
.form__checkbox-label:has(input:checked)::before {
  box-shadow: var(--shadow-hover);
}
.form__checkbox-text {
  font-size: var(--font-size-32);
  font-weight: var(--font-weight-bold);
  line-height: 1.25;
  color: var(--color-white);
}
.form__text {
  color: var(--color-white);
  font-size: var(--font-size-18);
  line-height: 1.66;
  margin-top: 1em;
}
.form__column--conditional {
  flex-direction: row;
  flex-wrap: wrap;
  align-self: flex-start;
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
  transition: var(--transition);
}
.form__column--conditional.active {
  opacity: 1;
  pointer-events: auto;
  cursor: pointer;
}
.form__column--conditional .form__row--zip-code {
  flex-basis: calc(33% - var(--form-column-gap) / 2);
}
.form__column--conditional .form__row--city {
  flex-basis: calc(67% - var(--form-column-gap) / 2);
}
.form__image-wrapper img {
  margin-left: auto;
}
.form--main {
  margin-top: clamp(24px, 5cqw, 56px);
}
@media screen and (max-width: 660px) {
  .form__file-wrap {
    flex-direction: column;
    align-items: stretch;
    padding: 24px 16px;
  }
}
@media screen and (max-width: 480px) {
  .form__submit-button {
    width: 100%;
    justify-content: center;
  }
}

.articles {
  --articles-gap: clamp(24px, 5cqw, 72px);
  --article-min-width: 380px;
  display: grid;
  gap: var(--articles-gap);
  grid-template-columns: repeat(auto-fill, minmax(var(--article-min-width), 1fr));
}
.articles--realization {
  --article-min-width: 320px;
  --articles-gap: clamp(24px, 6cqw, 88px);
  grid-template-columns: repeat(2, 1fr);
  margin-top: var(--gap);
}
@media screen and (max-width: 600px) {
  .articles {
    --article-min-width: 300px;
  }
  .articles--realization {
    grid-template-columns: 1fr;
  }
}

.realization {
  --realization-border-height: 1px;
  --realization-font-heading-color: var(--color-primary);
  --realization-image-filter: grayscale(100%);
  container-type: inline-size;
}
.realization:hover {
  --realization-border-height: 8px;
  --realization-font-heading-color: var(--color-secondary);
  --realization-image-filter: grayscale(0%);
}
.realization__inner {
  display: flex;
  gap: clamp(20px, 4cqw, 48px);
}
.realization__thumbnail-wrapper {
  flex-shrink: 0;
  flex-basis: 50%;
  max-width: 354px;
  transition: var(--transition);
  filter: var(--realization-image-filter);
}
.realization__content {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 3cqw, 24px);
  justify-content: space-between;
}
.realization__content::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: var(--realization-border-height);
  background-color: var(--realization-font-heading-color);
  transition: var(--transition);
}
.realization__flag-company {
  display: inline-flex;
  align-items: center;
  gap: clamp(16px, 4cqw, 32px);
}
.realization__flag {
  height: 24px;
  width: auto;
  box-shadow: 2px 2px 16px 0 rgba(46, 51, 139, 0.5);
}
.realization__company {
  font-size: var(--font-size-18);
  color: var(--color-text);
  line-height: 1.66;
}
.realization__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-32);
  color: var(--realization-font-heading-color);
  transition: var(--transition);
  line-height: 1.25;
  margin-top: 1.25em;
}
.realization__meta {
  margin-bottom: clamp(24px, 4cqw, 64px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 3cqw, 32px);
}
.realization__meta-item {
  display: inline-flex;
  flex-wrap: wrap;
  gap: clamp(12px, 2cqw, 24px);
  font-size: var(--font-size-18);
  color: var(--color-text);
}
.realization__meta-link {
  color: #0E103B;
  font-weight: var(--font-weight-bold);
  text-decoration: underline;
}
.realization__meta-link:hover {
  color: var(--color-secondary);
  text-decoration: none;
}
@container (max-width: 480px) {
  .realization__inner {
    flex-direction: column;
  }
  .realization__thumbnail-wrapper {
    aspect-ratio: 4/3;
    overflow: hidden;
  }
  .realization__flag {
    height: 20px;
  }
  .realization__title {
    margin-top: 20px;
  }
  .realization__content::after {
    background-color: var(--color-secondary);
  }
}

.product {
  --product-image-filter: grayscale(100%);
  display: flex;
}
.product:hover .product__content::after {
  background-color: var(--color-secondary);
  height: 8px;
}
.product:hover .product__read-more {
  background-color: var(--color-secondary);
  transform: rotate(-90deg);
}
.product:hover {
  --product-image-filter: grayscale(0%);
}
.product__inner {
  display: flex;
  flex-direction: column;
}
.product__thumbnail-wrapper {
  margin-bottom: clamp(16px, 4cqw, 32px);
  transition: var(--transition);
  filter: var(--product-image-filter);
}
.product__tag {
  font-size: var(--font-size-14);
  text-transform: uppercase;
  color: var(--color-secondary);
  margin-bottom: 1em;
}
.product__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-40);
  color: var(--color-heading);
  line-height: 1.25;
}
.product__description {
  color: var(--color-text);
  font-size: var(--font-size-16);
  line-height: var(--line-height);
  margin: 0;
  margin-top: 1.5em;
}
.product__content {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 3cqw, 24px);
  padding-bottom: clamp(16px, 4cqw, 32px);
  flex-grow: 1;
  justify-content: space-between;
}
.product__content::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: var(--color-border);
  transition: var(--transition);
}
.product__read-more {
  display: inline-block;
  width: 1.5em;
  aspect-ratio: 1/1;
  mask: var(--icon-arrow-right-smaller) center/contain no-repeat;
  background-color: var(--color-primary);
  transition: var(--transition);
}
@media screen and (max-width: 480px) {
  .product__read-more, .product__content::after {
    background-color: var(--color-secondary);
  }
}

.article-card {
  padding: clamp(24px, 5cqw, 64px);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  transition: var(--transition);
}
.article-card .wp-block-paragraph {
  --font-size: var(--font-size-16);
}

/**
 * --- Blocks (WordPress Gutenberg specifika) ---
 * Styly pro bloky, které jsou specifické pro WordPress editor a frontend.
 */
.global-style > *:first-child {
  margin-top: 0;
}
.global-style > *:last-child {
  margin-bottom: 0;
}
.global-style p,
.global-style li {
  line-height: var(--line-height);
}
.global-style a:not([class]) {
  color: var(--color-secondary);
  position: relative;
  text-decoration: underline;
}
.global-style a:not([class]):hover {
  color: var(--color-secondary);
  text-decoration: none;
}
.global-style p {
  margin-top: 1em;
  margin-bottom: 1em;
}
.global-style hr {
  border: 0;
  height: 1px;
  border-bottom: 1px dashed var(--color-border);
  clear: both;
  margin: clamp(24px, 4cqw, 56px) 0;
}

.wp-block-paragraph,
ul,
ol {
  --font-size: var(--font-size-18);
  font-size: var(--font-size);
  color: var(--font-color, var(--color-text));
}
.wp-block-paragraph strong,
ul strong,
ol strong {
  font-weight: var(--font-weight-bold);
}

.wp-block-heading {
  --block-heading-margin-top: 1em;
  --block-heading-margin-bottom: clamp(16px, 3cqw, 32px);
  --block-heading-line-height: 1.1;
  --letter-spacing: -0.025em;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  color: var(--font-color-heading, var(--color-heading));
  margin-top: var(--block-heading-margin-top);
  margin-bottom: var(--block-heading-margin-bottom);
  font-size: var(--font-size);
  line-height: var(--block-heading-line-height);
}
.wp-block-heading mark {
  color: var(--font-color-heading, var(--color-heading));
  font-size: 1.15em;
  padding: 0 0.3em 0.05em;
  border-radius: var(--border-radius);
  display: inline-block;
}
.wp-block-heading strong {
  --font-color-heading: var(--color-primary);
  color: var(--font-color-heading, var(--color-heading));
}
@media screen and (max-width: 1024px) {
  .wp-block-heading br {
    display: none;
  }
}

h1.wp-block-heading {
  --font-size: var(--font-size-64);
  --block-heading-margin-bottom: 0.5em;
}

h2.wp-block-heading {
  --font-size: var(--font-size-56);
}

h3.wp-block-heading {
  --font-size: var(--font-size-48);
}

h4.wp-block-heading {
  --font-size: var(--font-size-40);
}

h5.wp-block-heading {
  --font-size: var(--font-size-32);
}

h6.wp-block-heading {
  --font-size: var(--font-size-24);
}

.has-small-font-size {
  font-size: calc(var(--font-size) * 0.875);
}

.has-medium-font-size {
  font-size: calc(var(--font-size) * 1.15);
}

.has-large-font-size {
  font-size: calc(var(--font-size) * 1.3);
}

.has-x-large-font-size {
  font-size: calc(var(--font-size) * 1.75);
}

@media screen and (max-width: 1024px) {
  .has-medium-font-size {
    font-size: calc(var(--font-size) * 1.125);
  }
  .has-large-font-size {
    font-size: calc(var(--font-size) * 1.375);
  }
  .has-x-large-font-size {
    font-size: calc(var(--font-size) * 1.5);
  }
}
.has-text-align-left {
  text-align: left;
}

.has-text-align-center {
  text-align: center;
}

.has-text-align-right {
  text-align: right;
}

.is-vertical-aligned-top,
.are-vertically-aligned-top {
  align-items: flex-start;
}

.is-vertical-aligned-center,
.are-vertically-aligned-center {
  align-items: center;
}

.is-vertical-aligned-bottom,
.are-vertically-aligned-bottom {
  align-items: flex-end;
}

.is-content-justification-left {
  justify-content: flex-start;
}

.is-content-justification-center {
  justify-content: center;
}

.is-content-justification-right {
  justify-content: flex-end;
}

.aligncenter {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.aligncenter img {
  margin-left: auto;
  margin-right: auto;
}

.wp-block-columns {
  --block-columns-gap: 2em clamp(15px, 3cqw, 40px);
  --block-columns-margin: var(--gap) 0;
  display: flex;
  gap: var(--block-columns-gap);
  margin: var(--block-columns-margin);
}
@media screen and (max-width: 768px) {
  .wp-block-columns {
    flex-direction: column;
  }
}

.wp-block-column > *:first-child {
  margin-top: 0;
}
.wp-block-column > *:last-child {
  margin-bottom: 0;
}
.wp-block-column {
  flex-grow: 1;
  flex-basis: 50%;
}

.wp-block-image {
  --block-image-margin: var(--margins) auto;
  --block-image-border-radius: var(--border-radius);
  margin: var(--block-image-margin);
  border-radius: var(--block-image-border-radius);
  overflow: hidden;
}
.wp-block-image img {
  border-radius: var(--block-image-border-radius);
}
.wp-block-image .wp-element-caption {
  text-align: center;
  font-size: var(--font-size-16);
  color: var(--color-font, var(--color-main));
  padding: 1em;
  background-color: var(--color-white);
  display: block;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
}

.wp-block-gallery {
  --block-gallery-columns: 3;
  --block-gallery-gap: clamp(10px, 2cqw, 20px);
  --block-gallery-image-aspect-ratio: inherit;
  --block-gallery-image-background-color: var(--color-primary);
  display: grid;
  grid-template-columns: repeat(var(--block-gallery-columns), 1fr);
  gap: var(--block-gallery-gap) !important;
  margin: var(--block-gallery-gap);
  align-items: flex-start;
}
.wp-block-gallery.columns-2 {
  --block-gallery-columns: 2;
}
.wp-block-gallery.columns-4 {
  --block-gallery-columns: 4;
}
.wp-block-gallery.columns-5 {
  --block-gallery-columns: 5;
}
.wp-block-gallery.columns-6 {
  --block-gallery-columns: 6;
}
.wp-block-gallery.columns-7 {
  --block-gallery-columns: 7;
}
.wp-block-gallery.columns-8 {
  --block-gallery-columns: 8;
}
.wp-block-gallery .wp-block-image {
  aspect-ratio: var(--block-gallery-image-aspect-ratio);
  overflow: hidden;
  margin: 0;
  width: 100% !important;
  align-items: flex-start;
  justify-content: center;
  display: flex;
}
.wp-block-gallery .wp-block-image a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: var(--block-gallery-image-background-color);
  opacity: 0;
  transition: var(--transition);
  z-index: 2;
}
.wp-block-gallery .wp-block-image:hover a::before {
  opacity: 0.5;
}
.wp-block-gallery .wp-block-image img {
  width: 100%;
  height: auto;
}
.wp-block-gallery.is-cropped .wp-block-image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1200px) {
  .wp-block-gallery.columns-5, .wp-block-gallery.columns-6, .wp-block-gallery.columns-7, .wp-block-gallery.columns-8 {
    --block-gallery-columns: 4;
  }
}
@media screen and (max-width: 1024px) {
  .wp-block-gallery.columns-4, .wp-block-gallery.columns-5, .wp-block-gallery.columns-6, .wp-block-gallery.columns-7, .wp-block-gallery.columns-8 {
    --block-gallery-columns: 3;
  }
}
@media screen and (max-width: 480px) {
  .wp-block-gallery.columns-2, .wp-block-gallery.columns-3, .wp-block-gallery.columns-4, .wp-block-gallery.columns-5, .wp-block-gallery.columns-6, .wp-block-gallery.columns-7, .wp-block-gallery.columns-8 {
    --block-gallery-columns: 2;
  }
}

.wp-block-table {
  margin: var(--gap) 0;
  overflow: hidden;
  border-radius: var(--border-radius);
}
@media screen and (max-width: 768px) {
  .wp-block-table.responsive-table thead {
    display: none;
  }
  .wp-block-table.responsive-table td {
    display: flex;
    justify-content: space-between;
    gap: 0 1em;
  }
  .wp-block-table.responsive-table td div {
    text-align: right;
  }
  .wp-block-table.responsive-table td::before {
    content: attr(data-label);
    font-weight: bold;
  }
  .wp-block-table.responsive-table tbody {
    display: grid;
    gap: 1em;
  }
}

.wp-block-quote {
  --block-quote-margin: 2em auto;
  padding: 0;
  margin: var(--block-quote-margin);
  position: relative;
}
.wp-block-quote::before {
  content: "";
  position: relative;
  display: block;
  left: 50%;
  top: 0;
  transform: translate(-50%, 0);
  height: clamp(30px, 5cqw, 40px);
  aspect-ratio: 4/3;
  mask: var(--icon-quote) center/contain no-repeat;
  background-color: var(--color-brown-light-logo);
  opacity: 0.5;
  margin-bottom: 1em;
}
.wp-block-quote p {
  font-family: var(--font-basic);
  font-weight: var(--font-weight-medium);
  font-optical-sizing: auto;
  margin: 0;
  font-size: var(--font-size-24);
  color: var(--color-heading);
  z-index: 2;
}
.wp-block-quote p a {
  color: var(--color-primary) !important;
  text-decoration: underline;
}
.wp-block-quote p a:hover {
  text-decoration: none;
}
.wp-block-quote cite {
  margin-top: 1em;
  font-size: var(--font-size-14);
  display: block;
  font-family: var(--font-basic);
  font-weight: var(--font-weight-semibold);
  font-optical-sizing: auto;
  color: var(--color-primary);
  font-style: normal;
  text-transform: uppercase;
}
.wp-block-quote cite a {
  font-style: normal;
  color: var(--color-primary);
}
.wp-block-quote cite a:hover {
  text-decoration: underline;
}
.wp-block-quote cite em {
  font-style: normal;
  line-break: loose;
}
@media screen and (max-width: 660px) {
  .wp-block-quote {
    --block-quote-margin: 1em auto;
  }
}

.wp-block-list {
  counter-reset: item;
  list-style: none;
  margin: 1em 0;
  display: flex;
  flex-direction: column;
  gap: 0.75em;
  padding: 0;
}
.wp-block-list li {
  padding: 0 0 0 clamp(26px, 2cqw, 2.2em);
  color: var(--font-color, var(--color-text));
}

ul.wp-block-list {
  --icon-list-item: var(--icon-check);
  --icon-list-item-color: var(--color-secondary);
}
ul.wp-block-list li::before {
  content: "";
  position: absolute;
  left: 0;
  width: 1em;
  height: 1em;
  top: 0.25em;
  mask: var(--icon-list-item) center/contain no-repeat;
  background-color: var(--icon-list-item-color, var(--color-primary));
}

ol.wp-block-list li::before {
  position: absolute;
  left: 0;
  counter-increment: item;
  content: counter(item);
  font-weight: var(--font-weight-bold);
  color: var(--icon-list-item-color, var(--color-secondary));
  min-width: 1em;
}

.wp-block-buttons {
  --block-buttons-margin: clamp(24px, 4cqw, 56px) 0 0 0;
  --block-buttons-gap: 0.5em clamp(24px, 4cqw, 48px);
  margin: var(--block-buttons-margin);
  display: flex;
  flex-wrap: wrap;
  gap: var(--block-buttons-gap);
}

/* ----------------------------- */
/* -------- Barvy textu -------- */
/* ----------------------------- */
.has-primary-color {
  --font-color: var(--color-primary);
  --font-color-heading: var(--color-primary);
}
.has-primary-light-color {
  --font-color: var(--color-primary-light);
  --font-color-heading: var(--color-primary-light);
}
.has-primary-dark-color {
  --font-color: var(--color-primary-dark);
  --font-color-heading: var(--color-primary-dark);
}
.has-main-color {
  --font-color: var(--color-main);
  --font-color-heading: var(--color-main);
}
.has-light-color {
  --font-color: var(--color-light);
  --font-color-heading: var(--color-light);
}
.has-white-color {
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
}
.has-black-color {
  --font-color: var(--color-black);
  --font-color-heading: var(--color-black);
}

/* ------------------------------ */
/* -------- Barvy pozadí -------- */
/* ------------------------------ */
.has-background-color-primary {
  --background-color: var(--color-primary);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-light);
}
.has-background-color-primary-light {
  --background-color: var(--color-primary-light);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-light);
}
.has-background-color-primary-dark {
  --background-color: var(--color-primary-dark);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-light);
}
.has-background-color-main {
  --background-color: var(--color-brown-dark-logo);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
}
.has-background-color-white {
  --background-color: var(--color-white);
  --font-color: var(--color-text);
}
.has-background-color-black {
  --background-color: var(--color-black);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
}
.has-background-color-light {
  --background-color: var(--color-light);
  --font-color: var(--color-text);
  --font-color-heading: var(--color-main);
}

.has-background-gradient-circular {
  --background-color: var(--color-primary);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
  background: var(--gradient-circular);
}
.has-background-gradient-circular .wp-block-heading strong {
  --font-color-heading: var(--color-secondary);
}

section.has-circular-gradient-background {
  --background-color: var(--color-primary);
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
  background: var(--gradient-circular);
  background-color: var(--background-color) !important;
}
section.has-circular-gradient-background .wp-block-heading strong {
  --font-color-heading: var(--color-secondary);
}

/* --------------------------------------------------- */
/* -------- Vlastní .is-style styly pro bloky -------- */
/* --------------------------------------------------- */
.is-style-subheading {
  --line-width: 1.6em;
  font-family: var(--font-basic);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  color: var(--font-color, var(--color-primary-light));
  margin-bottom: 0.25em;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  line-height: 1.2;
  text-transform: uppercase;
  gap: 0.75em;
}
.is-style-subheading::before {
  content: "";
  display: block;
  width: var(--line-width);
  height: 0.1em;
  background-color: var(--font-color, var(--color-primary-light));
}
.is-style-subheading + .wp-block-heading {
  margin-top: 0;
}
.is-style-subheading.has-text-align-center {
  justify-content: center;
}
.is-style-subheading.has-text-align-center::after {
  content: "";
  display: block;
  width: var(--line-width);
  height: 0.1em;
  background-color: var(--font-color, var(--color-primary-light));
}

.image-text {
  align-items: stretch !important;
}
.image-text__text {
  padding-bottom: clamp(20px, 6cqw, 40px);
}
.image-text__text::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color-border);
  position: absolute;
  left: 0;
  bottom: 0;
}

.is-style-about-grios {
  gap: clamp(30px, 6cqw, 120px);
}
.is-style-about-grios .image-text__text {
  max-width: 400px;
}
.is-style-about-grios .image-text__text::after {
  width: calc(100% + 100px);
}

.is-style-info-box {
  border: 1px solid var(--color-primary);
  background-color: rgba(199, 201, 248, 0.1);
  border-radius: 8px;
  padding: clamp(24px, 3cqw, 32px);
  margin: clamp(24px, 4cqw, 48px) 0;
}
.is-style-info-box > *:first-child {
  margin-top: 0;
}
.is-style-info-box > *:last-child {
  margin-bottom: 0;
}
.is-style-info-box p,
.is-style-info-box ul,
.is-style-info-box ol {
  --font-size: var(--font-size-20);
}
.is-style-info-box ol.wp-block-list {
  --icon-list-item-color: var(--color-primary);
}

.numbers {
  --numbers-gap: 0;
  --numbers-margin-top: clamp(20px, 6cqw, 60px);
}
@media screen and (max-width: 1400px) {
  .numbers--columns-6 {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 1024px) {
  .numbers {
    --numbers-gap: 32px 16px;
  }
}
@media screen and (max-width: 600px) {
  .numbers {
    grid-template-columns: 1fr 1fr !important;
  }
}

.logos {
  --logo-max-width: 150px;
}
.logos .wp-block-image img {
  width: auto;
}

.hero {
  --font-color: var(--color-white);
  --font-color-heading: var(--color-white);
  --hero-min-height: none;
  --content-smaller: 800px;
  background: radial-gradient(1500px at left bottom, rgba(var(--color-primary-dark-rgb), 0.66) 0%, rgba(var(--color-primary-dark-rgb), 0) 100%);
  background-color: var(--background-color, var(--color-primary));
}
.hero--none .hero__content-inner {
  margin: 0 auto;
  max-width: 1000px;
}
.hero--none .hero .wp-block-paragraph {
  max-width: 800px;
}
.hero.has-background-color-primary-dark .wp-block-button__link {
  padding: 0;
  border: none;
  color: #C7C9F8;
  text-decoration: underline;
  min-width: 0;
  font-weight: var(--font-weight-regular);
}
.hero.has-background-color-primary-dark .wp-block-button__link::after {
  content: none;
}
.hero.has-background-color-primary-dark .wp-block-button__link:hover {
  color: var(--color-white);
  text-decoration: none;
}
.hero__inner {
  padding: clamp(40px, 10cqw, 80px) 0 clamp(40px, 10cqw, 100px);
}
.hero__content-inner {
  max-width: 570px;
}
.hero__image-wrapper {
  transform: skewX(-10deg);
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 55%;
  transition: all 0.5s ease;
}
.hero__image-wrapper::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-white);
  opacity: 0.8;
  z-index: 7;
  transition: all 0.5s ease;
}
.hero__image {
  transform: skewX(10deg) scale(1.15);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.hero__heading {
  margin: 0;
}
.hero .wp-block-heading strong {
  color: var(--color-secondary);
  font-weight: inherit;
}
.hero__excerpt,
.hero .wp-block-paragraph {
  font-size: var(--font-size-20);
  line-height: 1.6;
  color: var(--color-white);
  margin-top: 1.5em;
}
.hero__link {
  font-size: var(--font-size-18);
  color: var(--color-white);
  margin-bottom: 1.75em;
  text-decoration: underline;
  display: inline-block;
}
.hero__link:hover {
  text-decoration: none;
}
.hero .wp-block-buttons {
  --block-buttons-margin: var(--gap) 0 0 0;
}
.hero--video-split {
  min-height: clamp(400px, 80vh, 705px);
  display: flex;
  align-items: center;
}
.hero--video-split .hero__image-wrapper {
  z-index: 5;
}
.hero__video {
  z-index: 5 !important;
  transform: skewX(10deg) scale(1.15);
}
.hero__video-play-btn {
  --btn-size: clamp(56px, 10cqw, 80px);
  transform: skewX(10deg);
  background-color: var(--color-primary);
  border: none;
  transition: var(--transition);
  z-index: 10;
}
.hero__video-play-btn:hover {
  background-color: var(--color-secondary);
  transform: skewX(10deg);
}
.hero__margin-top {
  margin-top: 1.5em !important;
}
.hero__image-wrapper--video {
  transition: all 0.5s ease;
}
.hero__image-wrapper--video.is-video-open {
  transform: none;
}
.hero__image-wrapper--video.is-video-open::before {
  opacity: 0;
  pointer-events: none;
}
.hero__image-wrapper--video.is-video-open video {
  transform: none;
}
.hero__image-wrapper--video video {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 20;
}
@media screen and (max-width: 1360px) {
  .hero__image-wrapper {
    width: 45%;
  }
}
@media screen and (max-width: 1100px) {
  .hero__image-wrapper {
    position: relative;
    transform: none;
    width: 100%;
    height: clamp(200px, 50vh, 400px);
  }
  .hero__image-wrapper video {
    transform: skewY(5deg) scale(1.15);
  }
  .hero__video-play-btn {
    transform: skewY(5deg);
  }
  .hero__image-wrapper--video {
    transform: skewY(-5deg);
  }
  .hero--video-split {
    padding-bottom: 48px;
    flex-direction: column;
  }
  .hero--video-split .button-inquiry-inner-wrapper .wp-block-button__link {
    width: auto !important;
  }
}
@media screen and (max-width: 660px) {
  .hero__content-inner {
    text-align: left;
  }
  .hero .has-text-align-center {
    text-align: left;
  }
  .hero br {
    display: none;
  }
}
@media screen and (max-width: 480px) {
  .hero .wp-block-button {
    width: 100%;
    justify-content: center;
  }
}

.is-style-with-map .section__background-image-wrapper {
  left: auto;
  right: 0;
  width: 60%;
}
.is-style-with-map .section__background-image {
  object-position: left center;
}
.is-style-with-map .wp-block-buttons {
  margin-top: clamp(24px, 6cqw, 48px);
}
@media screen and (min-width: 1024px) {
  .is-style-with-map.section {
    padding: clamp(60px, 20cqw, 260px) 0;
  }
}
@media screen and (max-width: 1023px) {
  .is-style-with-map.section {
    padding-bottom: var(--section-gap);
  }
  .is-style-with-map .section__background-image-wrapper {
    position: relative;
    left: 0;
    width: 100%;
    height: auto;
  }
  .is-style-with-map .section__background-image {
    position: relative;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
  .is-style-with-map .content {
    padding-bottom: calc(var(--section-gap) * 2);
  }
}

.current-positions-in-header {
  padding: clamp(12px, 2cqw, 24px) clamp(18px, 3cqw, 32px);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2cqw, 16px);
  border: 1px dashed rgba(199, 201, 248, 0.4);
  max-width: 500px;
}
.current-positions-in-header__heading {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-20);
  color: var(--font-color-heading);
  margin: 0;
}
.current-positions-in-header__list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
}
.current-positions-in-header__item {
  font-family: var(--font-basic);
  font-weight: var(--font-weight-regular);
  font-optical-sizing: auto;
  color: var(--color-secondary);
  text-decoration: underline;
  font-size: var(--font-size-18);
  line-height: 1.66;
}
.current-positions-in-header__item:hover {
  color: var(--color-secondary);
  text-decoration: none;
}

.current-positions {
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 6cqw, 72px);
}
.current-positions__item {
  --item-title-color: var(--color-primary);
  --item-icon-transform: rotate(180deg);
  --item-padding: clamp(24px, 2cqw, 56px);
}
.current-positions__item.active {
  --item-icon-transform: rotate(0deg);
}
.current-positions__item.active .current-positions__item-content {
  max-height: none;
}
.current-positions__item-title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-40);
  color: var(--item-title-color);
  margin: 0;
  cursor: pointer;
  line-height: 1.25;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: clamp(16px, 2cqw, 32px);
  padding-bottom: var(--item-padding);
  border-bottom: 1px solid var(--color-border);
}
.current-positions__item-title::after {
  content: "";
  display: block;
  width: 24px;
  height: 12px;
  mask: var(--icon-arrow-up) center/contain no-repeat;
  background-color: var(--item-title-color);
  transition: var(--transition);
  transform: var(--item-icon-transform);
}
.current-positions__item-title:hover {
  --item-title-color: var(--color-secondary);
}
.current-positions__item-content {
  height: auto;
  overflow: hidden;
  transition: height 0.5s ease;
}
.current-positions__item-content-inner {
  padding-top: var(--item-padding);
}
.current-positions__item-content-inner-inner > *:first-child {
  margin-top: 0;
}
.current-positions__item-content-inner-inner > *:last-child {
  margin-bottom: 0;
}
.current-positions__item-link {
  width: 100%;
  margin-top: clamp(24px, 4cqw, 48px);
}

.button-inquiry-inner-wrapper {
  display: flex;
  gap: clamp(20px, 4cqw, 40px);
  align-items: center;
}
@media screen and (max-width: 480px) {
  .button-inquiry-inner-wrapper {
    flex-direction: column;
  }
  .button-inquiry-inner-wrapper .wp-block-button__link {
    width: 100%;
  }
}

.button-inquiry-additional-info {
  --info-background-color: #C7C9F8;
  font-size: var(--font-size-14);
  color: var(--color-white);
  line-height: 1.57;
  padding: 10px 32px 10px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  max-width: 240px;
  background: url(../assets/images/additional-info.svg) center/contain no-repeat;
}
.button-inquiry-additional-info::before {
  content: "";
  display: block;
  width: 24px;
  aspect-ratio: 1;
  mask: var(--icon-info) center/contain no-repeat;
  background-color: var(--info-background-color);
  flex-shrink: 0;
}
@media screen and (max-width: 1024px) {
  .button-inquiry-additional-info {
    padding-left: 36px;
  }
}
@media screen and (max-width: 480px) {
  .button-inquiry-additional-info {
    max-width: none;
    width: 100%;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' data-name='Vrstva 1' version='1.1' viewBox='0 0 328 50'%3E%3Cdefs%3E%3Cmask id='a' width='330' height='52' x='-1' y='-1' maskUnits='userSpaceOnUse'%3E%3Cpath fill='%23fff' stroke-width='0' d='M163 .7c.8-.9 2.2-.9 3 0l6.6 7.3H325c1.7 0 3 1.3 3 3v36c0 1.7-1.3 3-3 3H3c-1.7 0-3-1.3-3-3V11c0-1.7 1.3-3 3-3h153.4L163 .7Z' data-name='path-1-inside-1 29856 10163' /%3E%3C/mask%3E%3C/defs%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%23c7c9f8' stroke-width='0' d='m163 .7-.7-.7.7.7Zm3 0 .7-.7-.7.7Zm6.6 7.3-.7.7.3.3h.4V8ZM328 11h1-1Zm0 36h1-1ZM0 47h-1 1Zm0-36h-1 1Zm156.4-3v1h.4l.3-.3-.7-.7ZM163 .7l.7.7c.4-.4 1.1-.4 1.5 0l.7-.7.8-.7c-1.2-1.3-3.3-1.3-4.5 0l.7.7Zm3 0-.7.7 6.6 7.3.7-.7.7-.7-6.6-7.3-.7.7Zm6.6 7.3v1H325V7H172.6v1ZM325 8v1c1.1 0 2 .9 2 2h2c0-2.2-1.8-4-4-4v1Zm3 3h-1v36h2V11h-1Zm0 36h-1c0 1.1-.9 2-2 2v2c2.2 0 4-1.8 4-4h-1Zm-3 3v-1H3v2h322v-1ZM3 50v-1c-1.1 0-2-.9-2-2h-2c0 2.2 1.8 4 4 4v-1Zm-3-3h1V11h-2v36h1Zm0-36h1c0-1.1.9-2 2-2V7C.8 7-1 8.8-1 11h1Zm3-3v1h153.4V7H3v1Zm153.4 0 .7.7 6.6-7.3-.7-.7-.7-.7-6.6 7.3.7.7Z' /%3E%3C/g%3E%3C/svg%3E");
    padding: 22px 32px 12px 24px;
    justify-content: center;
  }
  .button-inquiry-additional-info::before {
    width: 20px;
  }
}

@media screen and (min-width: 768px) {
  .image-text--image-left {
    grid-template-columns: calc(var(--media-width, 50%) - (var(--gap))) 1fr;
  }
  .image-text--image-right {
    grid-template-columns: 1fr calc(var(--media-width, 50%) - (var(--gap)));
  }
}

.is-style-thank-you .hero__inner {
  padding: clamp(44px, 10cqw, 130px) 0 clamp(44px, 10cqw, 130px);
}
@media screen and (max-width: 660px) {
  .is-style-thank-you .wp-block-buttons {
    justify-content: flex-start;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .is-style-thank-you .wp-block-button {
    width: auto;
  }
}

.pagination {
  --pagination-item-background-color: var(--transparent) !important;
  --pagination-item-text-color: var(--color-primary) !important;
  --pagination-item-border-color: var(--color-primary) !important;
}
.pagination__item a:hover {
  border-color: var(--color-secondary) !important;
}

.video-block__play:before {
  display: none !important;
}

@media screen and (max-width: 660px) {
  .hero .has-text-align-center {
    text-align: left;
  }
}
/**
 * --- Layout (makro layouty a utility) ---
 * Vše, co se týká rozvržení stránek, sekcí, top baru, mobilní menu atd.
 */
.z-index-5 {
  z-index: 5;
}

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

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

.margin-top {
  margin-top: var(--gap);
}

.margin-bottom {
  margin-bottom: var(--gap);
}

.no-margin-top {
  margin-top: 0 !important;
}

.no-margin-bottom {
  margin-bottom: 0 !important;
}

.absolute-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.section {
  --section-gap: var(--gap);
  position: relative;
  z-index: 2;
  background-color: var(--background-color, transparent);
}
.section--smaller {
  padding: calc(var(--section-gap) * 1.75) 0;
}
.section--normal {
  padding: calc(var(--section-gap) * 2.5) 0;
}
.section--bigger {
  padding: calc(var(--section-gap) * 3.5) 0;
}
.section--custom {
  padding-top: calc(var(--section-gap) * var(--custom-padding-top, 2.5));
  padding-bottom: calc(var(--section-gap) * var(--custom-padding-bottom, 2.5));
}
.section--smaller-top {
  padding-top: calc(var(--section-gap) * 2);
}
.section--no-top {
  padding-top: 0;
}
.section--no-bottom {
  padding-bottom: 0;
}
.section--background {
  background-color: var(--color-light);
}
.section--gradient {
  background: var(--linear-gradient);
}
@media screen and (max-width: 768px) {
  .section--normal {
    padding: calc(var(--section-gap) * 2) 0;
  }
}

.content {
  width: 100%;
  padding: 0 var(--padding-on-side);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  max-width: calc(var(--content-width) + 2 * var(--padding-on-side));
}
.content--smaller {
  --content-width: var(--content-smaller);
}
.content--small {
  --content-width: var(--content-small);
}
.content--regular {
  --content-width: var(--content-regular);
}
.content--big {
  --content-width: var(--content-big);
}
.content--bigger {
  --content-width: var(--content-bigger);
}

.section:not([class*=is-style]):not([class*=has-background]):has(+ .section:not([class*=is-style]):not([class*=has-background])) {
  padding-bottom: 0;
}

.top-bar {
  z-index: 999;
  background-color: var(--color-white);
}
.top-bar.fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}
.top-bar__content {
  display: flex;
  align-items: center;
  gap: 1em clamp(20px, 5cqw, 90px);
}
.top-bar__logo-wrapper {
  flex-shrink: 0;
}
.top-bar__logo {
  width: clamp(120px, 10cqw, 154px);
  display: inline-block;
}
.top-bar__menu {
  display: flex;
  gap: clamp(10px, 3.5cqw, 60px);
  align-items: center;
}
.top-bar__menu a {
  color: var(--color-text);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  position: relative;
  padding: 5px 10px;
  font-size: var(--font-size-17);
}
.top-bar__menu a:hover {
  color: var(--color-secondary);
}
.top-bar__menu .current-menu-item a {
  color: var(--color-secondary);
}
.top-bar__languages {
  justify-self: flex-end;
  margin-left: auto;
}
.top-bar__languages:hover .top-bar__languages-dropdown-wrapper {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.top-bar__languages-active {
  display: flex;
  align-items: center;
  gap: 0.9em;
  font-size: var(--font-size-17);
  padding: 3.4em 0;
}
.top-bar__languages-active::before {
  content: "";
  display: block;
  width: 1.3em;
  aspect-ratio: 1;
  mask: var(--icon-globe) no-repeat center/contain;
  background-color: var(--color-secondary);
  flex-shrink: 0;
}
.top-bar__languages-active::after {
  content: "";
  display: block;
  width: 0.8em;
  aspect-ratio: 1;
  mask: var(--icon-arrow-language-switcher) no-repeat center/contain;
  background-color: var(--color-secondary);
}
.top-bar__languages-active span {
  text-transform: uppercase;
}
.top-bar__languages-dropdown-wrapper {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-white);
  padding: clamp(24px, 4cqw, 42px);
  padding-right: clamp(32px, 5cqw, 60px);
  box-shadow: 6px 6px 31.3px 0 rgba(206, 206, 206, 0.65);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: var(--transition);
}
.top-bar__languages-dropdown {
  display: flex;
  flex-direction: column;
  gap: 1em;
  font-size: var(--font-size-17);
}
.top-bar__languages-dropdown-item {
  display: flex;
  gap: 0.9em;
  color: var(--color-text);
  white-space: nowrap;
}
.top-bar__languages-dropdown-item::before {
  content: "";
  display: block;
  width: 1em;
  aspect-ratio: 1;
  mask: var(--icon-check) no-repeat center/contain;
  background-color: var(--color-secondary);
  flex-shrink: 0;
  opacity: 0;
}
.top-bar__languages-dropdown-item:hover {
  color: var(--color-secondary);
}
.top-bar__languages-dropdown-item--active {
  color: var(--color-secondary);
}
.top-bar__languages-dropdown-item--active::before {
  opacity: 1;
}
.top-bar__languages-dropdown-item span {
  text-transform: uppercase;
}
.top-bar__mobile-menu {
  --menu-line-height: 2px;
  display: none;
  cursor: pointer;
  gap: 6px;
  flex-direction: column;
  top: 4px;
}
.top-bar__mobile-menu.active .top-bar__mobile-menu-hamburger::after {
  opacity: 1;
}
.top-bar__mobile-menu.active .top-bar__mobile-menu-hamburger span {
  display: none;
}
.top-bar__mobile-menu.active .top-bar__mobile-menu-text {
  display: none;
}
.top-bar__mobile-menu-text {
  font-size: 10px;
  color: var(--color-text);
  font-weight: var(--font-weight-medium);
  position: relative;
  letter-spacing: 4px;
  text-transform: uppercase;
}
.top-bar__mobile-menu-hamburger {
  width: 40px;
  height: 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.top-bar__mobile-menu-hamburger::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  mask: var(--icon-close-menu) no-repeat center/contain;
  background-color: var(--color-primary);
  opacity: 0;
  transition: var(--transition);
}
.top-bar__mobile-menu-hamburger span {
  display: block;
  height: var(--menu-line-height);
  border-radius: 0;
  margin-left: auto;
  transition: var(--transition);
  background-color: var(--color-primary);
}
.top-bar__mobile-menu-hamburger span:nth-child(1) {
  width: 100%;
}
.top-bar__mobile-menu-hamburger span:nth-child(2) {
  width: 100%;
}
.top-bar__mobile-menu-hamburger span:nth-child(3) {
  width: 100%;
}
@media screen and (max-width: 1540px) {
  .top-bar__menu {
    gap: clamp(10px, 2cqw, 30px);
  }
}
@media screen and (max-width: 1260px) {
  .top-bar__menu {
    display: none;
  }
  .top-bar__mobile-menu {
    display: flex;
  }
}
@media screen and (max-width: 480px) {
  .top-bar {
    padding: 13px 0 19px 0;
  }
  .top-bar__languages {
    display: none;
  }
  .top-bar__content {
    justify-content: space-between;
  }
}

.mobile-menu {
  --menu-padding: 2em;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-white);
  z-index: 900;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
  pointer-events: none;
}
.mobile-menu.visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.mobile-menu__content-wrapper {
  padding: var(--menu-padding) 0;
  width: 100%;
  gap: 2em;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
.mobile-menu__content-wrapper::-webkit-scrollbar {
  width: 6px;
}
.mobile-menu__content-wrapper::-webkit-scrollbar-track {
  background: var(--color-primary);
}
.mobile-menu__content-wrapper::-webkit-scrollbar-thumb {
  background: var(--color-secondary, #cbd5e1);
  border-radius: 10px;
}
.mobile-menu__content-wrapper {
  height: calc(100% - 130px);
  overflow: auto;
  margin-top: auto;
  display: flex;
}
.mobile-menu__content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.mobile-menu__spacer {
  width: 100%;
}
.mobile-menu__menu {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.mobile-menu__menu li {
  text-align: center;
}
.mobile-menu__menu a {
  color: var(--color-text);
  font-family: var(--font-basic);
  font-weight: var(--font-weight-medium);
  font-optical-sizing: auto;
  font-size: 17px;
  padding: 0.5em 1em;
  display: inline-block;
}
.mobile-menu__menu .current-menu-item a {
  color: var(--color-primary);
}
.mobile-menu__languages {
  border-top: 1px solid #EDEDED;
  margin-top: 2em;
  width: 100%;
  display: none;
}
.mobile-menu__languages::after {
  content: "";
  display: block;
  width: 0.8em;
  aspect-ratio: 1;
  mask: var(--icon-arrow-language-switcher) no-repeat center/contain;
  background-color: var(--color-secondary);
  margin: 0 auto;
  transition: var(--transition);
}
.mobile-menu__languages.active::after {
  transform: rotate(180deg);
  margin-top: 2em;
}
.mobile-menu__languages.active .mobile-menu__languages-active {
  gap: 0;
}
.mobile-menu__languages.active .mobile-menu__languages-active div {
  width: 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
}
.mobile-menu__languages-active {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9em;
  font-size: var(--font-size-17);
  padding: 29px 0 16px;
  transition: var(--transition);
  width: auto;
}
.mobile-menu__languages-active::before {
  content: "";
  display: block;
  width: 1.3em;
  aspect-ratio: 1;
  mask: var(--icon-globe) no-repeat center/contain;
  background-color: var(--color-secondary);
  flex-shrink: 0;
}
.mobile-menu__languages-active span {
  text-transform: uppercase;
}
.mobile-menu__languages-active div {
  transition: var(--transition);
}
.mobile-menu__languages-dropdown-wrapper {
  position: relative;
  opacity: 0;
  height: 0;
  visibility: hidden;
  pointer-events: none;
  transition: var(--transition);
  overflow: hidden;
}
.mobile-menu__languages-dropdown-wrapper.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  height: auto;
}
.mobile-menu__languages-dropdown {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1em;
  font-size: var(--font-size-17);
}
.mobile-menu__languages-dropdown-item {
  display: flex;
  gap: 0.9em;
  color: var(--color-text);
  white-space: nowrap;
}
.mobile-menu__languages-dropdown-item:hover {
  color: var(--color-secondary);
}
.mobile-menu__languages-dropdown-item--active {
  color: var(--color-secondary);
}
.mobile-menu__languages-dropdown-item span {
  text-transform: uppercase;
}
@media screen and (max-width: 1320px) {
  .mobile-menu {
    display: flex;
  }
}
@media screen and (max-width: 480px) {
  .mobile-menu__languages {
    display: block;
  }
  .mobile-menu__content-wrapper {
    height: calc(100% - 88px);
  }
}

.footer {
  --border-color: #EDEDED;
}
.footer__top {
  padding: clamp(20px, 5cqw, 46px) 0 clamp(20px, 6cqw, 58px);
  border-bottom: 1px solid var(--border-color);
}
.footer__top-content {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1em var(--gap);
}
.footer__logo-wrapper {
  display: flex;
  align-items: center;
  gap: 1em clamp(24px, 4cqw, 48px);
}
.footer__description {
  font-size: var(--font-size-16);
  color: var(--color-primary);
}
.footer__logo {
  width: clamp(80px, 10cqw, 154px);
  height: auto;
  display: inline-block;
}
.footer__quality-management img {
  height: 85px;
  width: auto;
  filter: grayscale(100%);
}
.footer__center {
  padding: clamp(20px, 6cqw, 58px) 0 clamp(20px, 7cqw, 78px);
  border-bottom: 1px solid var(--border-color);
}
.footer__center-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2em clamp(20px, 5cqw, 72px);
}
.footer__contacts {
  font-size: var(--font-size-16);
  color: var(--color-primary);
}
.footer__contacts > *:first-child {
  margin-top: 0;
}
.footer__contacts > *:last-child {
  margin-bottom: 0;
}
.footer__contacts p {
  margin: 0.75em 0;
}
.footer__contacts p:empty {
  display: none;
}
.footer__contacts a {
  color: var(--color-primary);
  text-decoration: underline;
}
.footer__contacts a:hover {
  color: var(--color-secondary);
  text-decoration: none;
}
.footer__column-heading {
  font-size: var(--font-size-20);
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  color: var(--color-primary);
  margin-bottom: 1em;
}
.footer__menu {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1cqw, 12px);
}
.footer__menu a {
  font-size: var(--font-size-16);
  color: var(--color-primary);
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: none;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  text-underline-position: from-font;
}
.footer__menu a:hover {
  text-decoration: none;
  color: var(--color-secondary);
}
.footer__eu-subsidies {
  padding-top: clamp(20px, 6cqw, 74px);
}
.footer__eu-subsidies-content {
  display: flex;
  align-items: center;
  gap: 1em var(--gap);
}
.footer__eu-subsidies-logos {
  max-width: 850px;
  height: auto;
}
.footer__eu-subsidies-text {
  font-size: var(--font-size-14);
  color: #676767;
  line-height: 1.57;
}
.footer__bottom {
  padding: clamp(20px, 7cqw, 79px) 0 clamp(20px, 7cqw, 84px);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1em var(--gap);
  font-size: var(--font-size-14);
}
.footer__bottom-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1em var(--gap);
}
.footer__cookies {
  display: flex;
  flex-wrap: wrap;
  gap: 1em clamp(16px, 2cqw, 32px);
}
.footer__cookies a {
  color: #676767;
  text-decoration: underline;
}
.footer__cookies a:hover {
  text-decoration: none;
}
.footer__copyright {
  color: #676767;
}
.footer__copyright a {
  color: var(--color-secondary);
  text-decoration: underline;
}
.footer__copyright a:hover {
  text-decoration: none;
}
.footer__social-links {
  display: flex;
  gap: 1em;
  margin: 1.5em 0;
}
.footer__social-link {
  width: 24px;
  height: 24px;
  mask: var(--icon-social) no-repeat center/contain;
  background-color: var(--color-primary);
  transition: var(--transition);
}
.footer__social-link:hover {
  background-color: var(--color-secondary);
}
.footer__social-link--linkedin {
  --icon-social: var(--icon-linkedin);
}
.footer__social-link--youtube {
  --icon-social: var(--icon-youtube);
}
.footer__social-link--instagram {
  --icon-social: var(--icon-instagram);
}
.footer__social-link--facebook {
  --icon-social: var(--icon-facebook);
}
@media screen and (max-width: 600px) {
  .footer__logo-wrapper {
    flex-direction: column;
    gap: 1em;
    align-items: flex-start;
  }
  .footer__logo {
    width: auto;
  }
  .footer__logo img {
    height: 48px;
    width: auto;
  }
  .footer__quality-management {
    position: absolute;
    right: var(--padding-on-side);
    top: 0;
  }
  .footer__quality-management img {
    height: 48px;
  }
  .footer__center-content {
    flex-direction: column;
    gap: 24px;
  }
  .footer__eu-subsidies-content {
    flex-direction: column;
    gap: 16px;
  }
  .footer__eu-subsidies-logos {
    max-width: 100%;
  }
}

body::-webkit-scrollbar {
  width: 6px;
}
body::-webkit-scrollbar-track {
  background: var(--color-primary);
}
body::-webkit-scrollbar-thumb {
  background: var(--color-secondary, #cbd5e1);
  border-radius: 10px;
}

body.no-scroll {
  position: fixed;
  width: 100%;
  overflow-y: scroll;
}

.social-links {
  display: flex;
  gap: 10px;
  margin-top: 0.75em;
}
.social-links__link {
  width: clamp(32px, 3cqw, 44px);
  aspect-ratio: 1/1;
  background-color: var(--color-secondary-light);
  border-radius: 10em;
  position: relative;
}
.social-links__link::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  mask: var(--social-icon) center/60% auto no-repeat;
  background-color: var(--color-secondary);
  z-index: 2;
  transition: var(--transition);
}
.social-links__link:hover {
  background-color: var(--color-secondary);
}
.social-links__link:hover::before {
  background-color: var(--color-white);
}
.social-links__link--instagram {
  --social-icon: var(--icon-instagram);
}
.social-links__link--facebook {
  --social-icon: var(--icon-facebook);
}

.task-description {
  --font-size: var(--font-size-20);
  font-size: var(--font-size);
  font-weight: var(--font-weight-bold);
}
.task-description > *:first-child {
  margin-top: 0;
}
.task-description > *:last-child {
  margin-bottom: 0;
}