/*
Theme Name: YesDesign
Author: Jakub Havlíček
Version: 1.0
*/

/*------------------------RESET---------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code,del, dfn, em, img, ins, kbd, q, s, samp,small, strike, strong, sub, sup, tt, var,b, u, i, center,dl, dt, dd, ul,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary,time, mark, audio, video {
	margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; text-decoration:none; list-style-type: none;}
article, aside, details, figcaption, figure, hgroup, menu, nav, section { display: block; }
/*------------------------------------------------------*/

:root                                           {
                                                --font1:                "stevie-sans", sans-serif; /* 400, 500, 700 */
                                                --font2:                "the-seasons", sans-serif; /* 700 */

                                                --color0:               rgb(28,36,49);
                                                --color0b:              rgb(40,51,68);
                                                --color0c:              #80b0cb;
                                                --color0d:              #b1dffa;
                                                --color0e:              #8DB8FF;
                                                --color0f:              rgb(59,105,181);
                                                --color0f-15:           rgba(59,105,181,0.15);
                                                --color0f-25:           rgba(59,105,181,0.25);
                                                --color1:               #c5a572; 
                                                --color1b:              #e0bb86; 
                                                --color-error:          rgb(229, 23, 75);
                                                --color-success:        rgb(0, 169, 144);
                                                --color-white-10:       rgba(255,255,255,0.1);
                                                --color-white-20:       rgba(255,255,255,0.2);

                                                --wrapper-side:         4.5vw;
                                                --section-padding:      min(7rem, calc(1.6rem + 7vw));
                                                --header:               clamp(5rem, calc(4rem + 5vw), 7rem);
                                                --gap1:                 0.75rem;
                                                --gap2:                 1.2rem;
                                                --gap3:                 3rem;
                                                --border-radius0:       0.3em; 
                                                --border-radius1:       0.6rem; 
                                                --spacing1:             0.06em;
                                                --border1:              solid 0.1em rgba(0,0,0,0.1);
                                                }

button                                          {background: none; outline: none; cursor: pointer; position: relative; border: none; box-sizing: border-box; padding: 0; white-space: nowrap; font-family: var(--font1); transition: .15s ease-in-out;}

html, body                                      {width: 100%;}
html                                            {height: 100%; overflow-x: hidden; scroll-behavior: smooth;}
body                                            {display: flex; min-height: 100%; flex-direction: column; font-size: min(16px, calc(6px + 2vw)); font-weight: 400; line-height: 1.5; position: relative; font-family: var(--font1); overflow-x: hidden; padding-top: var(--header); box-sizing: border-box;}
body.hp                                         {background: var(--color0);}
body.fixed                                      {height: 100%; position: fixed;}

.wrapper                                        {display: flex; width: calc(100vw - 2 * var(--wrapper-side)); max-width: 66rem; flex-direction: column; align-items: center; margin-inline: auto; position: relative;}
.wrapper.narrow                                 {max-width: 46rem;}
.wrapper.medium                                 {max-width: 58rem;}
.wrapper.wide                                   {max-width: 78rem;}

.header                                         {display: block; width: 100%; height: var(--header); box-sizing: border-box; position: absolute; left: 0; top: 0; z-index: 1000; isolation: isolate; transition: .4s ease-in-out;}
.header .wrapper                                {height: 100%; flex-direction: row; justify-content: space-between; align-items: center;}
.header .logo                                   {display: block; width: min(calc(8em + 7vw), 12em); height: auto; position: relative; z-index: 15;}
.header .logo img                               {display: block; width: 100%; height: auto;} 
.header .collapse                               {display: block; height: 100%; box-sizing: border-box;}
.header nav                                     {display: flex; justify-content: center; align-items: center; box-sizing: border-box;}
.header nav ul                                  {display: flex; justify-content: center; align-items: center; gap: 0 1.6em;}
.header nav ul li                               {display: block;}
.header nav ul li a                             {display: flex; align-items: center; gap: 0.4em; color: var(--color0); font-weight: 400; letter-spacing: var(--spacing1); transition: .15s ease-in-out;}
.header nav ul li a:hover,            
.header nav ul li a[aria-current="page"]        {color: var(--color1) !important;}
.header nav ul li.rubrika a:after               {display: block; font-size: 0.6em; color: var(--color0f); font-weight: 500; text-transform: uppercase; padding: 0.2em 0.55em 0.1em; border: solid 0.12em var(--color0f); border-radius: 0.5em; position: relative; top: -0.07em; content: "Rubrika";}
.header .header-elements                        {display: flex; align-items: center; gap: 2em 0.9em;}
.header .header-elements .soc                   {display: flex; align-items: center; gap: 0.3em;}
.header .header-elements .soc a                 {display: flex; width: 2em; aspect-ratio: 1; justify-content: center; align-items: center; background: var(--color0f-15); border-radius: 100%;  transition: .15s ease-in-out;}
.header .header-elements .soc a img             {display: block; width: 50%;}
.header .header-elements .soc a:hover           {background: var(--color0f-25);}
.header .button                                 {height: 2em;}
  @media screen and (min-width: 1081px)         {
  .header .collapse                             {width: 100%; position: absolute; left: 0; top: 0;}
  .header nav                                   {height: 100%; gap: 0.2em;}
  .header nav ul li a                           {font-size: 1.1em; padding: 0.5em 0.8em;}
  .header .header-elements                      {height: 100%; position: absolute; right: 0; top: 0;}
  .header :is(.home, #navicon)                  {display: none;}
  }
  @media screen and (max-width: 1080px)         {
  .header :is(.home, #navicon)                  {display: flex; width: 2.4em; height: 2.4em; justify-content: center; align-items: center; border-radius: 100%; position: relative; top: -0.35em; z-index: 15; transition: .2s ease-in-out;}
  .header :is(.home, #navicon):hover            {background: var(--color0f-25);}
  .header .home img                             {display: block; width: 50%;}
  .header .collapse                             {width: 100%; height: 100%; backdrop-filter: blur(15px); opacity: 0; padding: var(--header) 15%; position: fixed; right: -1000%; top: 0; overflow-y: auto; transition: opacity .5s ease-in-out;}
  .header .collapse:before                      {display: block; position: absolute; inset: 0; background: white; opacity: 0.5; content: "";}
  .header :is(nav, .header-elements)            {position: relative; z-index: 15;}
  .header nav                                   {width: 100%; flex-direction: column; align-items: flex-start; padding: 8% 0 3em;}
  .header nav ul                                {flex-direction: column; align-items: flex-start;}
  .header nav ul a                              {font-size: 1.5em; padding: 0.7em 0;}
  .header .header-elements                      {flex-direction: column; align-items: flex-start;}
  .header .header-elements .button              {font-size: 1.2em;}
  .header .header-elements .soc                 {font-size: 1.15em;}
  .header #navicon                              {position: relative; z-index: 10; cursor: pointer;}
  .header #navicon span                         {display: block; width: 60%; height: 0.1em; background: var(--color0); border-radius: 2px; position: absolute; left: 20%; z-index: 1; }
  .header #navicon span:nth-child(1)            {top: 30%;}
  .header #navicon span:nth-child(2),
  .header #navicon span:nth-child(3)            {top: calc(50% - 0.05em);}
  .header #navicon span:nth-child(4)            {bottom: 30%;}
  .header #navicon .close                       {display: none; position: absolute; inset: 0; z-index: 2;}
  .header.show #navicon span:nth-child(2)       {transform: rotate(45deg);}
  .header.show #navicon span:nth-child(3)       {transform: rotate(-45deg);}
  .header.show #navicon span:nth-child(1), 
  .header.show #navicon span:nth-child(4)       {opacity: 0 !important;}
  .header.show #navicon .close                  {display: block;}
  .header.show .collapse                        {right: 0; opacity: 1;}
  .header.show.hide .collapse                   {opacity: 0;}
  }

body:not(.hp) .header .only-hp                  {display: none !important;}

.hp .header nav ul li a                         {color: white;}
.hp .header nav ul li.rubrika a:after           {color: var(--color0e); border-color: var(--color0e);}
.hp .header .header-elements .soc a             {background: var(--color-white-10);}
.hp .header .header-elements .soc a:hover       {background: var(--color-white-20);}
.hp .header :is(.home, #navicon):hover          {background: var(--color-white-20);}
.hp .header #navicon span                       {background: white;}
.hp .header .collapse:before                    {background: var(--color0);}
.hp .only-hp                                    {display: block;}
.hp *:has(+ .only-hp)                           {display: none !important;}

.footer                                         {display: flex; width: 100%; flex-direction: column; align-items: center; background: white; padding-block: clamp(1em, calc(0.2em + 5vw), 2.5em);}
.footer span                                    {display: block; text-align: center; color: var(--color0);}
.footer .name                                   {font-size: 2em; font-weight: 700; font-family: var(--font2);}
.footer .dscr                                   {font-size: 0.9em;;}
.footer .bottom                                 {display: flex; justify-content: center; gap: 0.5em 1em; margin-top: 1.5em;}
.footer .bottom span                            {font-size: 0.8em;}
.footer .bottom span a                          {color: inherit; text-decoration: underline; text-decoration-color: transparent; transition: .15s ease-in-out;}
.footer .bottom span a:hover                    {color: var(--color0b); text-decoration-color: var(--color0b);}

.hp .footer,
body:has(#kontaktni-formular) .footer           {padding-top: 0;}


.main                                           {display: flex; width: 100%; flex-direction: column; flex-grow: 2; flex-wrap: wrap; margin: 0 auto; box-sizing: border-box; position: relative; z-index: 2; transition: .3s ease-in-out;}
.main :is(p, li)                                {font-size: 1em; letter-spacing: var(--spacing1);}
.main p                                         {display: block; width: 100%; box-sizing: border-box;}
.main p a, .main li a                           {text-decoration: underline; color: white; text-decoration-color: var(--color1b); transition: .15s ease-in-out;}
.main p a:hover, .main li a:hover               {color: var(--color1); text-decoration-color: transparent;}
        
.section                                        {display: flex; width: 100%; flex-direction: column; align-items: center; position: relative; padding-top: var(--section-padding); box-sizing: border-box;}
.section.padding-bottom                         {padding-bottom: var(--section-padding);}

.anim                                           {transition-delay: 2s; opacity: 0; transform: scale(0.9,0.9); transition: .6s ease-in-out;}
.anim.play                                      {opacity: 1; transform: scale(1,1);}

strong                                          {font-weight: 700;}

h1, h2, h3                                      {display: block; width: 100%; text-align: center; font-weight: 700; line-height: 1.25; box-sizing: border-box; position: relative; font-family: var(--font2); margin-inline: auto;}
h1                                              {max-width: 14em; font-size: min(3.5rem, calc(0.9rem + 7vw)); margin-bottom: 0.8rem;}
h2                                              {max-width: 40rem; font-size: min(3rem, calc(0.9rem + 5vw)); color: var(--color0); margin-bottom: var(--gap3);}

.section:has(.about, .question-form, .features) h2
                                                {color: var(--color1b);}


.subheadline                                    {display: block; width: 100%; text-align: center; color: var(--color1); font-weight: 500;}

h1:has(+ .subheadline)                          {margin-bottom: calc(-0.35 * var(--gap2));}
h1 + .subheadline                               {font-size: min(1.3rem, calc(0.4rem + 3vw)); margin-block: -0.8rem var(--gap2);}

.icon1                                          {display: flex; width: 3em; aspect-ratio: 1; justify-content: center; align-items: center; order: -1; background: var(--color0f-15); position: relative;
                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% auto; mask-size: 100% auto;
                                                 mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M59.3,4.7C54.6,0,47.1,0,32,0S9.4,0,4.7,4.7C0,9.4,0,16.9,0,32s0,22.6,4.7,27.3c4.7,4.7,12.2,4.7,27.3,4.7s22.6,0,27.3-4.7c4.7-4.7,4.7-12.2,4.7-27.3s0-22.6-4.7-27.3h0Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");                                           
                                                 -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M59.3,4.7C54.6,0,47.1,0,32,0S9.4,0,4.7,4.7C0,9.4,0,16.9,0,32s0,22.6,4.7,27.3c4.7,4.7,12.2,4.7,27.3,4.7s22.6,0,27.3-4.7c4.7-4.7,4.7-12.2,4.7-27.3s0-22.6-4.7-27.3h0Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");
                                                }
.icon1 img                                      {display: block; width: 55%;}

body:not(.hp) .section:first-child              {padding-top: calc(0.2 * var(--section-padding));}

.content                                        {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2);}
.content p                                      {text-align: center;}
.content .page-subtext                          {margin-bottom: var(--gap1);}

/* Zopakovat u .form */
.button                                         {display: flex; justify-content: center; align-items: center; font-size: 1em; color: var(--color0); font-weight: 400; background: var(--color1b); text-transform: uppercase; padding: 0.45em 1.3em; border-radius: var(--border-radius0); border: none; box-sizing: border-box; overflow: hidden; cursor: pointer; position: relative; z-index: 1; font-family: var(--font1); transition: .15s ease-in-out;}
.button:hover                                   {background: var(--color1);}

.section:has(.hero)                             {padding-top: 0;}
.section:has(.hero) > img                       {display: block; width: var(--hero-img); margin-bottom: calc(-0.25 * var(--hero-img)); --hero-img: min(70em, 170%);}

.hero                                           {display: flex; width: 100%; flex-direction: column; align-items: center; flex-wrap: wrap; gap: var(--gap2);}
.hero h1                                        {color: white; margin-bottom: 0;}
.hero p                                         {text-align: center; font-size: clamp(1em, calc(0.5em + 2vw), 1.3em); color: var(--color1b); letter-spacing: 0.1em; padding-inline: 1em;}

.infographics                                   {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap1);}
.infographics > div                             {display: flex; width: 100%; align-items: center; gap: var(--gap2); padding: 1.8em; box-sizing: border-box; position: relative; z-index: 2;}
.infographics > div:before                      {display: block; position: absolute; inset: 0; z-index: -1; border-radius: var(--border-radius1); content: "";}
.infographics > div p                           {color: white;}
.infographics > div img                         {display: block; width: 3.8em; flex-shrink: 0;}
  @media screen and (min-width: 961px)          {
  .infographics > div:before                    {background-image: linear-gradient(to right, var(--color0b), transparent);}
  .infographics > div:nth-child(odd):before     {transform: rotate(180deg);}
  .infographics > div:nth-child(odd) p          {order: -1; text-align: right;}
  }
  @media screen and (max-width: 960px)          {
  .infographics > div                           {flex-direction: column;}
  .infographics > div:before                    {background-image: linear-gradient(to bottom, var(--color0b), transparent);}
  .infographics > div p                         {text-align: center;}
  }
  @media screen and (min-width: 641px)          {
  .infographics > div                           {width: calc(50% - 0.5 * var(--gap1));}
  }

.media                                          {display: block; border-radius: var(--border-radius1); overflow: hidden; position: relative;}
.media video                                    {display: block; width: 100%; height: 100%; opacity: 0; transition: .35s ease-in-out;}
.media .video-cover                             {display: flex; width: 100%; height: 100%; flex-direction: column; justify-content: flex-end; align-items: center; padding: 1.5em 1.5em 50%; /* background: url("images/img1.webp") no-repeat center center; background-size: cover; */ box-sizing: border-box; position: absolute; left: 0; top: 0; z-index: 2; cursor: pointer; container-type: inline-size; transition: opacity .3s ease-in-out; transition-delay: left 0.3s;}
.media .video-cover .image                      {display: block; width: 100%; height: 100%; position: absolute; inset: 0; z-index: -1;}
.media .video-cover .image:before               {display: block; position: absolute; inset: 0; background-image: linear-gradient(to top, var(--color0), transparent); content: "";}
.media .video-cover .image img                  {display: block; width: 100%; height: 100%; object-fit: cover;}
.media .video-cover .icon                       {display: block; width: 3em;}
.media .video-cover .title                      {font-size: 0.9em; color: white; margin-top: 0.5em;}
.media.play .video-cover                        {opacity: 0; top: 0; left: -9999px;}
.media.play video                               {opacity: 1;}

.about                                          {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap3) 0;}
.about > div                                    {display: flex; width: 100%; flex-direction: column; justify-content: center; align-items: center; gap: var(--gap1);}
.about .media                                   {aspect-ratio: 9/16;}
.about .content                                 {box-sizing: border-box;}
.about .content p                               {color: white;}
.about .content .button                         {margin-top: 0.8em;}
  @media screen and (min-width: 961px)          {
  .about                                        {justify-content: space-between;}  
  .about .media                                 {width: 42%; order: -1;}
  .about .content                               {width: 52%; align-items: flex-start; padding-block: 1em 4em;}
  .about .content p                             {font-size: 1.1em;}
  }
  @media screen and (max-width: 960px)          {
  .about .content p                             {text-align: center;}
  .about .media                                 {max-width: 25em;}
  }

.section:has(.question-form)                    {background: url("images/img2.webp") no-repeat center center; background-size: cover;}
.question-form:before                           {display: block; position: absolute; inset: 0; z-index: -1; background: var(--color0b); opacity: 0.7; content: "";}
.question-form                                  {padding: min(3em, calc(1em + 5vw)); backdrop-filter: blur(8px); border-radius: var(--border-radius1);}

.form                                           {display: flex; width: 100%; flex-direction: column; align-items: center; flex-wrap: wrap; position: relative; z-index: 2; box-sizing: border-box; overflow: hidden;}

/* Forminator General */                                                
.form .forminator-ui.forminator-custom-form[data-design=default]
                                                {display: block; max-width: 30em; margin: 0;}
.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-field
                                                {display: flex; width: 100%; flex-wrap: wrap; gap: var(--gap1);}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-label
                                                {width: 100%; text-align: center; font-size: 1.2em; color: white;}

/* Forminator Option buttons */                                                
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-label .forminator-required
                                                {color: var(--color1b);}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio
                                                {display: flex; width: 100%; align-items: center; background: rgba(0,0,0,0.3); color: white; border-radius: var(--border-radius0); padding: 0.95em 1em 0.8em; margin: 0; border: solid 0.08em transparent; box-sizing: border-box; cursor: pointer; position: relative; z-index: 1; transition: .15s ease-in-out;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio:hover
                                                {border-color: var(--color1b);}
.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-radio .forminator-radio-label
                                                {flex: auto; font-size: 1em; line-height: 1.2; margin-left: 0.4em;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio .forminator-radio-bullet
                                                {display: block; width: 1em; height: 1em; flex: none; flex-shrink: 0; background: none; border: solid 0.1em var(--color1b); border-radius: 100%; box-sizing: border-box; position: relative; top: -0.05em;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio input:checked + .forminator-radio
                                                {font-weight: 700;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio input:checked + .forminator-radio-bullet
                                                {background: var(--color1b); border: none;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio .forminator-radio-bullet:before 
                                                {background: url("images/icons/icon-opt-check.svg") no-repeat center center; background-size: contain;}
  @media screen and (min-width: 641px)          {
  .form .forminator-ui#forminator-module-126.forminator-design--default .forminator-radio
                                                {width: calc(50% - 0.5 * var(--gap1));}
  }

/* Forminator Error */                                                
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-has_error .forminator-radio .forminator-radio-bullet
                                                {border-color: var(--color-error);}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-error-message
                                                {width: 100%; text-align: center; font-size: 0.8em; background: var(--color-error); color: white; padding: 0.15em 1em 0.1em; border-radius: 0.3em;;}

/* Forminator Footer */                                                
.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-pagination-footer
                                                {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap1);}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-button-submit,                                                
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-button-next 
                                                {display: flex; width: 15em; justify-content: center; align-items: center; font-size: 1em; color: var(--color0); font-weight: 400; background: var(--color1b); text-transform: uppercase; padding: 0.45em 1.3em; border-radius: var(--border-radius0); border: none; box-sizing: border-box; overflow: hidden; cursor: pointer; position: relative; z-index: 1; font-family: var(--font1); transition: .15s ease-in-out;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-button-next:hover  
                                                {background: var(--color1);}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-button-back
                                                {width: auto; font-size: 0.9em; color: var(--color0c); text-transform: uppercase; text-decoration: underline; border: none; transition: .15s ease-in-out;}
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-button-back:hover
                                                {color: var(--color0d); text-decoration-color: transparent; box-shadow: none;}

/* Forminator Footer */
.form .forminator-ui#forminator-module-126.forminator-design--default .forminator-response-message.forminator-success
                                                {width: 100%; text-align: center; font-size: 0.85em; background: var(--color-success); color: white; padding: 0.25em 1em 0.2em; border-radius: 0.3em;;}

/* Forminator Step Message */
.form .form-step-message                        {display: block; width: 100%; margin-bottom: 0;}                                         
.form .form-step-message .forminator-field      {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap1);}                                         

.form .forminator-ui#forminator-module-126.forminator-design--default .form-step-message .forminator-label
                                                {font-size: min(1.6em, calc(1em + 3vw));}
.form .forminator-ui#forminator-module-126.forminator-design--default .form-step-message p  
                                                {text-align: center;}


.form .form-item:has(input[type="text"]) .forminator-label
                                                {text-align: left !important;}

.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-input              
                                                {display: block; width: 100%; background: rgba(0,0,0,0.3); font-size: 1em; color: white; border: none; border: solid 0.08em rgba(255,255,255,0.3); outline: none; border-radius: 0.3em; padding: 0.6em; box-sizing: border-box; position: relative; z-index: 2; font-family: var(--font1); transition: .15s ease-in-out;}
.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-input:focus        
                                                {border-color: var(--color1b); background: rgba(0,0,0,0.5);}
.form .forminator-ui.forminator-custom-form[data-design=default] .forminator-input::placeholder 
                                                {color: var(--color0e);}

.cols2                                          {display: block; width: 100%; column-gap: var(--gap2); margin-top: calc(-1 * var(--gap2));}     
.cols2 > *                                      {display: inline-block; width: 100%; margin-top: var(--gap2);}
  @media screen and (min-width: 961px)          {
  .cols2                                        {column-count: 2;}
  }
  @media screen and (max-width: 960px)          {
  .cols2.real-estates                           {max-width: 36rem;}
  }

.box                                            {box-sizing: border-box; border-radius: var(--border-radius1); border: var(--border1); padding: var(--box-padding); --box-padding: min(3em, calc(1em + 5vw));}
.box .inner                                     {display: flex; width: 100%; justify-content: space-between; flex-wrap: wrap; gap: var(--gap1);}

.section:has(.reviews)                          {background: white;}

.reviews + .button                              {margin-top: var(--gap3);}

.reviews                                        {display: block; width: 100%;}
.reviews .review :is(h3, p)                     {display: block; width: 100%; text-align: left;}
.reviews .review h3                             {font-size: 1.1em; color: var(--color0); font-weight: 700; font-family: var(--font1);}
.reviews .review p                              {flex-grow: 2;}
.reviews .review img                            {display: block; width: 5em;}

.section:has(.features)                         {background: white; padding-top: 0;}

.features                                       {display: flex; width: 100%; justify-content: center; flex-wrap: wrap;}
.features .upper                                {display: flex; width: 100%; flex-direction: column; align-items: center; background: var(--color0b); padding: var(--section-padding) 3em calc(1.7 * var(--section-padding)); box-sizing: border-box; border-radius: var(--border-radius1);}
.features .feature-list                         {display: block; width: 100%; max-width: 54em;}
.features .feature-list ul                      {display: flex; width: 100%; justify-content: space-between; flex-wrap: wrap; gap: var(--gap2) 0;}
.features .feature-list ul li                   {display: flex; width: 100%; min-height: 3.2em; align-items: center; color: white; padding-left: 3.4em; box-sizing: border-box; position: relative;}
.features .feature-list ul li:before            {display: block; width: 2.5em; height: 2.5em; background: url("images/icons/icon-check.svg") no-repeat center center; background-size: contain; position: absolute; left: 0; top: 0.29em; content: "";}
.features .compare                              {display: flex; width: 90%; max-width: 60em; justify-content: center; flex-wrap: wrap; gap: var(--gap2);}
.features .compare > div                        {display: block; width: 100%; max-width: 30em; position: relative; border-radius: var(--border-radius1); overflow: hidden; margin-top: calc(-1 * var(--section-padding));}
.features .compare > div > img                  {display: block; width: 100%;}
.features .compare > div:nth-child(1) > img     {filter: grayscale(1) contrast(0.5);}
.features .compare > div > div                  {display: flex; flex-direction: column; justify-content: flex-end; align-items: center; font-size: min(1em, calc(0.5em + 3vw)); padding: 3em 3em 30%; box-sizing: border-box; position: absolute; inset: 0; z-index: 2;}
.features .compare > div > div > img            {display: block; width: 3.6em;}
.features .compare > div > div h3               {font-size: 1.65em; color: var(--color0); margin-block: 0.2em 0.1em;}
.features .compare > div > div p                {text-align: center; font-size: 1.15em; color: var(--color0); font-weight: 700;}
  @media screen and (min-width: 769px)          {
  .features .upper ul                           {max-width: 54em;}
  .features .upper ul li                        {width: 47%;}
  .features .compare > div                      {width: calc(50% - 0.5 * var(--gap2));}
  }

.features + .button                             {font-size: 1.25em;}
.button-info                                    {text-align: center; font-size: 0.95em; color: var(--color0); margin-top: 0.6em;}

.services                                       {display: flex; width: 100%; flex-direction: column; gap: var(--gap3);}
.services .group                                {display: flex; width: 100%; flex-direction: column; justify-content: space-between; align-items: center; gap: var(--gap3) 0;}
.services .group .media                         {width: 90%; max-width: 30rem; aspect-ratio: 4/3; order: -1; position: relative;}
.services .group .media picture img             {display: block; width: 100%; height: 100%; object-fit: cover; background: black;}
.services .group .media:has(video)              {aspect-ratio: 3/4 !important; background: black;}
.services .group .content                       {width: 100%; gap: 2em;}
.services .service                              {display: flex; width: 90%; flex-direction: column; align-items: center; gap: var(--gap1); position: relative; box-sizing: border-box;}
.services .service .icon                        {width: 3em;}
.services .service .title                       {display: block; width: 100%; text-align: center; font-size: min(1.8rem, calc(0.3rem + 4vw)); margin: 0 0 -0.1em;}
  @media screen and (min-width: 1081px)         {
  .services .group .media                       {width: 43%;}
  .services .group .content                     {width: 50%;}
  }
  @media screen and (min-width: 769px) and (max-width: 1080px){
  .services .group .media                       {width: 40%;}
  .services .group:nth-child(odd) .media        {margin-left: calc(50% - 50vw - var(--border-radius1));}
  .services .group:nth-child(even) .media       {margin-right: calc(50% - 50vw - var(--border-radius1));}
  .services .group .content                     {width: 60%;}
  .services .service                            {font-size: 0.9em;}
  }
  @media screen and (min-width: 769px)          {
  .services .group                              {flex-direction: row;}
  .services .group:nth-child(even)              {flex-flow: row-reverse;}   
  .services .group .media                       {aspect-ratio: 3/4;}
  .services .service                            {width: 100%; align-items: flex-start; padding-left: 4.2em;}  
  .services .service .icon                      {position: absolute; top: -0.235em; left: 0;}
  .services .service .title                     {text-align: left; font-size: 1.9em;}
  .services .service ul li p                    {text-align: left;}
  }
  @media screen and (max-width: 768px)          {
  .services .service ul li                      {text-align: center; padding: 0;}
  .services .service ul li:before               {display: none;}
  .services .service ul li:not(:last-child)     {padding-bottom: 0.7em; margin-bottom: 0.5em;}
  .services .service ul li:not(:last-child)::after
                                                {display: block; width: 3em; height: 0.08em; background: var(--color0b); position: absolute; left: calc(50% - 1.5em); bottom: 0; content: "";}
  }

.videos                                         {display: flex; width: 100%; flex-wrap: wrap; gap: var(--gap2);}
.videos > *                                     {display: block; width: 100%; border-radius: var(--border-radius1); overflow: hidden;}
  @media screen and (min-width: 769px)          {
  .videos > *                                   {width: calc(50% - 0.5 * var(--gap2));}
  }

.my-player-design .plyr__control--overlaid            {background: var(--color1b); transition: .15s ease-in-out !important;}
.my-player-design .plyr__control--overlaid:hover      {background: var(--color1) !important;}
.my-player-design .plyr--full-ui input[type=range]    {color: var(--color1b);}
.my-player-design .plyr__control:hover                {background: var(--color1b) !important;}

.article-styles :is(ul, ol)                     {display: flex; flex-wrap: wrap; gap: 0.2em; padding: 0;}
.article-styles :is(ul li, ol li)               {display: inline-block; width: 100%; text-align: left; padding-left: 1.4em; position: relative; box-sizing: border-box;}
.article-styles li:before                       {display: block; position: absolute; content: "";}
.article-styles ul li:before                    {width: 0.3em; height: 0.3em; top: 0.6em; left: 0.1em; background: var(--color0); border-radius: 0.1em;}
.article-styles ol                              {list-style-type: none; counter-reset: li;}
.article-styles ol li                           {counter-increment: li;}
.article-styles ol li:before                    {top: 0; left: -0.05em; content: counter(li)".";}

.quick-contacts                                 {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.4em 1.4em; font-size: min(1.45em, calc(0.7em + 2vw));}
.quick-contacts a                               {display: flex; align-items: center; gap: 0.5em; font-weight: 700; color: var(--color0); transition: .15s ease-in-out;}
.quick-contacts a .icon                         {width: 1.5em; top: -0.04em;}
.quick-contacts a:hover                         {color: var(--color1);}

.basic-contacts                                 {display: flex; width: 100%; flex-direction: column; justify-content: center; align-items: center; flex-wrap: wrap;}
.basic-contacts li                              {display: flex; flex-direction: column; justify-content: center; align-items: center;}
.basic-contacts li:not(:last-child):after       {display: block; width: 3em; height: 0.08em; background: var(--color1); margin-block: 0.45em 0.5em; content: "";}
  @media screen and (min-width: 541px)          {
  .basic-contacts,  .basic-contacts li          {flex-direction: row;}                   
  .basic-contacts li:not(:last-child):after     {width: 0.08em; height: 1em; margin-inline: 0.6em 0.65em;}
  }

.contact-boxes                                  {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap1) 2%; margin-top: var(--gap3);}
.contact-boxes > div                            {display: flex; flex: 2; min-width: 20em; flex-direction: column; align-items: center; justify-content: center; gap: var(--gap1); border: solid 0.1em var(--color0f-15); padding: min(3em, calc(1em + 5vw)); border-radius: var(--border-radius1); box-sizing: border-box;}
.contact-boxes > div .icon                      {width: 3.4em;}
.contact-boxes > div h2                         {max-width: 6em; font-size: min(2.2rem, calc(0.5rem + 5vw)); color: var(--color0); margin: 0;}
.contact-boxes > div .button                    {min-width: 11.6em; font-size: 0.9em; margin-top: 0.5em;}

.wpcf7                                          {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2); --wpcf7-gap: 3%;}
.wpcf7 form                                     {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap1) var(--wpcf7-gap);}

label:has(input[type="checkbox"])               {display: block; padding-left: 1.5em; position: relative; box-sizing: border-box;}
label:has(input[type="checkbox"]) input         {position: absolute; left: -9999px; top: 0;}
label:has(input[type="checkbox"]):before        {display: block; width: 1em; height: 1em; background: var(--color0f-15); border-radius: 0.2em; position: absolute; left: 0; top: 0.19em; overflow: hidden; content: "";}
label:has(input[type="checkbox"]:checked):before{background: URL('images/check.svg') no-repeat center center; background-size: 100% 100%; background-color: var(--color0);}

.form-item                                      {display: block; width: 100%;}
.form-item label                                {display: flex; flex-direction: column; align-items: flex-start; gap: 0.4em;}
.form-item label > br                           {display: none;}
.form-item label > span                         {display: block; width: 100%; box-sizing: border-box;}
.form-item label .title                         {font-size: 0.95em; font-weight: 500; padding-inline: 0.7em;}
.form-item:has(.wpcf7-validates-as-required) .title:after
                                                {color: var(--color1); position: relative; top: -0.22em; right: -0.1em; content: "*";}
.form-item :is(input, textarea)                 {display: block; width: 100%; font-size: 1.1em; color: var(--color0); font-weight: 500; background: var(--color0f-15); padding: 0 0.9em; border-radius: var(--border-radius0); border: none; outline: none; box-sizing: border-box; font-family: var(--font1); transition: .25s ease-in-out;}
.form-item input                                {height: 2.8em;}
.form-item textarea                             {height: 9em; padding-block: 1em;}
.form-item :is(input, textarea)::placeholder    {color: var(--color0c); font-weight: 500;}
.form-item :is(input, textarea):focus           {background: var(--color0f-25);}
.form .wpcf7-not-valid-tip                      {font-size: 0.85em; color: var(--color-error); font-weight: 500; padding-inline: 0.7em; margin-top: 0.3em;}
.form .send                                     {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.8em 0; margin-top: 1rem;}
.form .send br                                  {display: none;}
.form .send p                                   {display: flex; width: 100%; justify-content: center; text-align: center; position: relative;} 
.form .send .consent                            {font-size: 0.8em;} 
.form .send .consent a                          {color: inherit; text-decoration: underline;}
.form .send .consent a:hover                    {opacity: 0.7; text-decoration-color: transparent;}
.form .send .consent span                       {display: block; margin: 0;}
.form .send .wpcf7-spinner                      {width: 1.6em; height: 1.6em; background-color: var(--color0); position: absolute; left: calc(50% - 0.8em); bottom: calc(50% - 0.8em); margin: 0; z-index: 5;}
.form .send .wpcf7-spinner:before               {background-color: var(--color1);}
.form .send .button                             {font-size: 1.15em;}
.form .wpcf7 form .wpcf7-response-output        {font-size: 0.9em; font-weight: 500; padding: 0.5em 0.9em 0.35em; border-radius: var(--border-radius0); border: solid 0.13em var(--colorOf); margin: var(--gap1) 0 0;}
.form .wpcf7 form.failed .wpcf7-response-output {border-color: var(--color-error);}
.form form.submitting .send .button             {opacity: 0.5; pointer-events: none;}
  @media screen and (min-width: 769px)          {
  .form-item.w33-100                            {width: calc(33.33% - 2/3 * var(--wpcf7-gap));}
  }
  @media screen and (min-width: 641px)          {
  .form-item.w50-100                            {width: calc(50% - 0.5 * var(--wpcf7-gap));}
  }

.swiper                                         {width: 100%; overflow: hidden;}  
.swiper-slide                                   {display: block; height: auto; overflow: hidden; flex-shrink: 0;}

.swiper-button                                  {display: flex; width: var(--button-size); height: var(--button-size); justify-content: flex-start; align-items: center; font-size: 1em; background: url("images/chevron-right-white.svg") no-repeat center center, var(--color1); background-size: auto calc(0.3 * var(--button-size)); background-position: left 25% top calc(0.35 * var(--button-size)); margin: 0; padding: 0; border: none; border-radius: 100%; box-sizing: border-box; cursor: pointer; transition: .25s ease-in-out;}                                
.swiper-button:hover                            {background-color: var(--color1b);}
.swiper-button-prev                             {transform: rotate(-180deg);}
.swiper-button img                              {display: block; width: 32%;}
.swiper-button:before,
.swiper-button:after                            {display: none;}
.swiper-button-disabled                         {opacity: 0.15 !important; filter: saturate(0);}

.swiper-gallery                                 {display: block; width: 100%; position: relative; border-radius: var(--border-radius1); overflow: hidden; --button-size: 3em;}
.swiper-gallery .swiper-slide a                 {display: block; width: 100%; padding-top: 56.25%; position: relative; background: var(--color0);}     
.swiper-gallery .swiper-slide a span            {display: block; position: absolute; inset: 0;}
.swiper-gallery .swiper-slide a span img        {display: block; width: 100%; height: 100%; object-fit: contain;}     
.swiper-gallery .swiper-slide:first-child a span img
                                                {object-fit: cover;}
.swiper-gallery .swiper-button                  {top: calc(50% - 0.5 * var(--button-size)); box-shadow: 0 0 1em rgba(0,0,0,0.5);}
.swiper-gallery .swiper-button-prev             {left: calc(-0.5 * var(--button-size));}
.swiper-gallery .swiper-button-next             {right: calc(-0.5 * var(--button-size));}

.real-estate-preview .swiper-gallery            {width: calc(100% + 2 * var(--box-padding)); margin: calc(-1 * var(--box-padding)); margin-bottom: 0;}
.real-estate-preview *                          {text-align: left !important;}
.real-estate-preview .type                      {font-size: 0.85em; font-weight: 700; margin-top: 0.3rem;}
.real-estate-preview .type span                 {font-weight: 500;}
.real-estate-preview h2                         {text-align: left; font-size: 1.6em; margin: 0 0 0.25rem;}
.real-estate-preview .price                     {display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.1em 1em; font-size: 1.1em; font-weight: 700; padding-block: var(--gap1); border-top: var(--border1); border-bottom: var(--border1);}
.real-estate-preview .price span                {font-weight: 500;}

