﻿.clear { clear: both;height: 1px; line-height: 1px; overflow: hidden; margin-bottom: -1px; }
.chyba { background-color:#c81816; color:#ffffff; text-align:center; font-size:14px; padding:5px 0px 5px 0px; margin:2px auto 0px auto; -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; }
.embedBlok {display: block; width: 100%;}
.embedBlok--audio { max-width: 660px; margin: 15px auto; }
.embedBlok--audio iframe { display: block; }

.in_website_hp { position: absolute; left: -9999px; opacity: 0; height: 0px; width: 0px; z-index: -1; }

.editor { padding:20px; }

.news-detail {
    max-width: 705px; margin: 10px auto;
    border: 1px solid black;
    padding: 10px;
    height: auto!important;
}

.enRozvrzeni {
}

.deRozvrzeni {
}
    
body {
    display: block !important;
}

/*------------------------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; }

/*------------------------------------------------------*/

.chyba { background-color:#c81816; color:#ffffff; text-align:center; font-size:14px; padding:5px 0px 5px 0px; margin:1px auto 10px auto; -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; }






::-moz-selection                                {color: white; background: var(--color1);}

::selection                                     {color: white; background: var(--color1);}



:root                                           {

                                                --font1:                 'ff-tisa-sans-web-pro', sans-serif; /* 400,500,700 */

                                                --wrapper-side:          3vw;

                                                --header:                4.5em;



                                                --border-radius0:        0.6rem;

                                                --border-radius1:        1.2rem;

                                                --button-height:         2.4em;



                                                --gap1:                   1rem;

                                                --gap2:                   1.8rem;

                                                

                                                --color0:                hsl(0,0%,16%);

                                                --color1:                #797EFF;

                                                --color1b:               #798dff;

                                                --color1-2:              #ca67ff;

                                                --color2:                #E22450;

                                                --color2b:               #FF3161;                         

                                                --white-10:              rgba(255,255,255,0.1);

                                                --white-20:              rgba(255,255,255,0.2);

                                                --white-60:              rgba(255,255,255,0.6);

                                                --white-70:              rgba(255,255,255,0.7);

                                                --black-30:              rgba(0,0,0,0.3);

                                                --black-40:              rgba(0,0,0,0.4);

                                                --black-60:              rgba(0,0,0,0.6);

                                                --color-error:           #df0e3b;



                                                --header:                 6rem;

                                                --section-padding:        min(7rem, calc(3rem + 6vw));                                                

                                                --section-padding-lower:  calc(0.7 * var(--section-padding));

                                                --wrapper-width:          86vw;

                                                --wrapper-max:            62rem;

                                                --wrapper-wide-max:       72rem;

                                                --wrapper-medium-max:     54rem;

                                                --wrapper-narrow-max:     47rem;

                                                --wrapper-thin-max:       38rem;

                                                --preview-padding:        0.4rem;

                                                --icon-size:              3rem;

                                                  

                                                --button-height:          2.4em;

                                                --box-shadow:             0 0 1.2em black;

                                                --headline-line:          1.3;



                                                --form-gap:                   1em;

                                                --form-items-gap:             0.8em;

                                                --form-item-height:           3.2em;

                                                --form-item-border:           solid 0.1em var(--white-20);

                                                --form-item-padding:          1em;

                                                }

                                               

html                                            {display: block; width: 100%; height: 100%; text-align: center; font-size: min(18px, calc(11px + 1vw)); font-weight: 400; color: white; background: var(--color0); letter-spacing: 0.08em; line-height: 1.45; overflow-x: hidden; font-family: var(--font1);}

body                                            {display: block; width: 100%; position: relative; box-sizing: border-box;}

body.header-show :is(.main, .footer)            {filter: blur(6px); opacity: 0.35;}

body:not(.hp)                                   {padding-top: var(--header); background: url("images/page-head.webp") no-repeat center top; background-size: min(120vw, 1600px) auto;}



form                                            {display: flex; min-height: 100vh; flex-direction: column; flex-wrap: wrap;}



.wrapper                                        {display: flex; width: var(--wrapper-width); flex-direction: column; justify-content: center; align-items: center; flex-wrap: wrap; gap: var(--gap2); margin: 0 auto; box-sizing: border-box; position: relative; z-index: 5;}

  @media screen and (min-width: 1367px)         {

  .wrapper                                      {max-width: var(--wrapper-max);}

  .wrapper.wide                                 {width: 94%; max-width: var(--wrapper-wide-max);}

  .wrapper.medium                               {max-width: var(--wrapper-medium-max);}

  .wrapper.narrow                               {max-width: var(--wrapper-narrow-max);}

  .wrapper.thin                                 {max-width: var(--wrapper-thin-max);}

  }



strong                                          {font-weight: 700;}

em                                              {font-style: italic;}



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;}



.header                                         {display: block; width: 100%; height: var(--header); position: fixed; top: 0; left: 0; box-sizing: border-box; z-index: 1000; transition: .5s ease-in-out;}

.header:before                                  {display: block; position: absolute; inset: 0; background: var(--color0); opacity: 0; content: ""; transition: .5s ease-in-out;}

.header .wrapper                                {width: 94%; height: 100%;}

.header .inner                                  {display: flex; width: 100%; height: 100%; align-items: center; position: relative; box-sizing: border-box;}

.header .logo                                   {width: 8.6em;}

.header .collapse                               {display: flex;}

.header nav                                     {display: flex; justify-content: center; box-sizing: border-box;}

.header nav > ul                                {display: flex; align-items: center; position: relative;}

.header nav > ul > li                           {display: flex; align-items: center; transition: .15s ease-in-out;}

.header nav > ul > li > a                       {display: flex; height: 2.4em; align-items: center; color: inherit; font-weight: 700; line-height: 1; position: relative; padding-inline: 1.1em; border-radius: 1.2em; box-sizing: border-box; cursor: pointer; transition: .15s ease-in-out;}

.header nav > ul > li > a:hover,

.header nav > ul > li > a.sel                   {background: var(--white-10);}

.header .btn-cart .count                        {display: flex; width: 1.5em; height: 1.5em; justify-content: center; align-items: center; text-align: center; font-size: 0.75em; color: white; background: var(--color0); border-radius: 100%; padding: 0 0 0.13em 0.1em; box-sizing: border-box;}

.header-elements                                {display: flex; justify-content: flex-end; align-items: center; gap: 0.4em;}

.header.scroll                                  {backdrop-filter: blur(6px);}

.header.scroll:before                           {opacity: 0.7;}

.header:not(.show).scroll-down                  {top: calc(-1 * var(--header));}

  @media screen and (min-width: 1081px) and (max-width: 1280px){

  .header                                       {font-size: 0.85em;}

  .header nav > ul > li > a                     {padding-inline: 1em;}

  } 

  @media screen and (min-width: 1081px)         {

  .header .collapse                             {flex-grow: 2;}

  .header :is(.collapse, nav, nav > ul)         {height: 100%;}

  .header nav                                   {flex-grow: 2;}

  .header nav > ul                              {justify-content: center;}

  .header #navicon                              {display: none;}                 

  }

  @media screen and (max-width: 1080px)         {

  .header .collapse                             {width: 100%; height: calc(100svh - var(--header)); position: fixed; left: -9999px; top: var(--header); bottom: 0; padding: 0 calc(50vw - 0.5 * var(--wrapper-width)) 1rem; box-sizing: border-box; opacity: 0; transform: scale(0.85); transition: opacity .5s ease-in-out, transform .5s ease-in-out;}

  .header nav                                   {width: 100%; background: var(--black-40);; box-shadow: var(--box-shadow); padding: 0 7vw; overflow-y: auto; transition: .5s ease-in-out;}

  .header nav > ul                              {width: 100%; flex-direction: column;}

  .header nav > ul > li                         {width: 100%;}

  .header nav > ul > li > a                     {width: 100%; text-align: left; font-size: 1.2em;}

  .header nav > ul > li > a:hover               {color: var(--color1);}

  .header nav > ul > li:first-child a           {margin-top: 8vw;}

  .header nav > ul > li:last-child a            {margin-bottom: 8vw;}

  .header-elements                              {flex-grow: 2;}

  .header #navicon                              {display: block; width: 1.4em; height: 1em; position: relative; cursor: pointer; margin-left: 0.6em;}

  .header #navicon span                         {display: block; width: 100%; height: 0.16em; background: white; border-radius: 2px; position: absolute; left: 0; transition: .15s ease-in-out;}

  .header #navicon span:nth-child(1)            {top: 0;}

  .header #navicon span:nth-child(2),

  .header #navicon span:nth-child(3)            {top: calc(50% - 0.08em);}

  .header #navicon span:nth-child(4)            {bottom: 0;}

  .header #navicon div                          {display: none; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2;}

  .header.show                                  {background: transparent; backdrop-filter: blur(0px);}

  .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 div                     {display: block;}

  .header.show .collapse                        {left: 0; opacity: 1; transform: scale(1);}

  .header.show .collapse nav                    {border-radius: 2em;}

  .header.show.hide .collapse                   {opacity: 0; transform: scale(1.15);}

  }

  @media screen and (max-width: 540px)          {

  .header .btn-cart                             {width: var(--button-height); padding-inline: 0;}

  .header .btn-cart .text                       {display: none;}

  .header .btn-cart .count                      {background: white; color: var(--color0); outline: solid 0.25em var(--color0); position: absolute; right: -0.15em; bottom: -0.15em; content: "";}

  }



.footer                                         {display: block; width: 100%; position: relative; z-index: 10; padding-block: var(--section-padding-lower) 0; background-image: linear-gradient(to right, transparent, var(--black-40), transparent);}

.footer-contacts1                               {display: flex; max-width: 24em; flex-direction: column; align-items: center; gap: var(--gap1);}

.footer-contacts1 span                          {display: block;}

.footer-contacts1 .title                        {font-size: 1.6em; font-weight: 700;}

.footer-contacts1 .small                        {font-size: 0.7em;}

.footer-contacts2                               {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.45em var(--gap1); padding: 1.45em 1.8em 1.35em; box-sizing: border-box; background: var(--white-10); border-radius: var(--border-radius1); position: relative; z-index: 2; margin-block: var(--gap1);}

.footer-contacts2 a                             {display: flex; align-items: center; gap: 0.5em; font-size: 1.15em; color: inherit; font-weight: 500; transition: .25s ease-in-out;}

.footer-contacts2 a img                         {display: block; height: 1.1em;}

.footer-contacts2 a:hover                       {opacity: 0.7;}

.footer .logo                                   {display: block; width: 10em;}

.footer .logo img                               {display: block; width: 100%;}

.footer .soc                                    {display: flex; width: 100%; justify-content: center; gap: 0.4em;}

.footer .soc .icon                              {--icon-size: 3em; font-size: 0.6em; transition: .25s ease-in-out;}

.footer .soc .icon:hover                        {transform: scale(0.9); opacity: 0.8;}

.footer .bottom                                 {display: flex; width: 100%; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.2em 1.2em; font-size: 0.7em; padding-block: var(--gap2);}

.footer .bottom li                              {display: block; color: var(--white-60);}

.footer .bottom li a                            {color: inherit; text-decoration: underline; transition: .25s ease-in-out;}

.footer .bottom li a:hover                      {color: var(--white-70); text-decoration-color: transparent;}

  @media screen and (max-width: 540px)          {

  .footer .wrapper                              {font-size: 0.9em;}

  }



.main                                           {display: flex; width: 100%; align-items: flex-start; align-content: flex-start; flex-wrap: wrap; flex-grow: 1; transition: .15s ease-in-out;}



.section                                        {display: block; width: 100%; position: relative; padding-top: var(--section-padding); overflow: hidden;}

.section.padding-top-lower,

.section:first-child                            {padding-top: var(--section-padding-lower);}

.section.padding-bottom-lower                   {padding-bottom: var(--section-padding-lower);}

.section.padding-top-0                          {padding-top: 0;}

.section.padding-bottom                         {padding-bottom: var(--section-padding);}

.section.color0                                 {background: var(--color0); overflow: hidden;}

.section.color0:before,

.section.color0:after                           {display: block; width: 30rem; height: 30rem; opacity: 0.1; background: url("images/icons/pictogram-outline-white.svg") no-repeat center center; background-size: contain; position: absolute; content: "";}

.section.color0:before                          {left: 65%; top: -15rem;}

.section.color0:after                           {right: 65%; bottom: -15rem;}

.section.color0-10                              {background: var(--color0-10);}

.section.start-top:before,

.section.bottom-end:after                       {display: block; width: 100%; height: 20em; background-image: linear-gradient(to bottom, white, transparent); position: absolute; left: 0; top: 0; content: "";}

.section.bottom-end:after                       {top: auto; bottom: 0; transform: rotate(180deg);}

.section.bottom-start                           {background-image: linear-gradient(to top, var(--color0-10), transparent var(--section-padding-lower), transparent);}

.section.bottom-start + .section                {padding-top: 0;}



.section.overflow + .section                    {padding-top: calc(2 * var(--section-padding)); margin-top: calc(-1 * var(--section-padding));}



.section.color0 :is(h2, p)                      {color: white;}



body:not(.hp) .section:first-child              {padding-top: min(2.5rem, 3vw);}



.main p, .main li                               {display: block; width: 100%; box-sizing: border-box; position: relative;}

.main p a, .main ul:not([class]) li a           {color: inherit; text-decoration: underline; transition: .15s ease-in-out;}

.main p a:hover, .main ul:not([class]) li a:hover

                                                {opacity: 0.8; text-decoration-color: transparent;}

.main strong                                    {font-weight: 700;}

.main em                                        {font-style: italic;}



ul.checks                                       {display: block; margin-top: -0.2em;}

ul.checks li                                    {display: inline-block; text-align: left; padding-left: 1.5em; margin-top: 0.2em;}

ul.checks li:before                             {display: block; width: 1.15em; height: 1.15em; background: url("images/icons/check-color2.svg") no-repeat left center; background-size: contain; position: absolute; left: 0; top: 0.14em; content: "";}



.txt-gradient1                                  {background: -webkit-linear-gradient(0deg, var(--color2b), var(--color1-2), var(--color1b)); -webkit-background-clip: text; -webkit-text-fill-color: transparent;}



h1, h2, h3                                      {display: block; width: 100%; font-weight: 700; letter-spacing: 0; line-height: var(--headline-line); box-sizing: border-box; font-family: var(--font1); text-shadow: 0 0 0.7em var(--black-60);}

h1                                              {font-size: min(calc(1.5em + 4vw), 3.6em);}

h2                                              {font-size: min(calc(1.2em + 4vw), 2.8em);}

h3                                              {font-size: min(calc(1em + 4vw), 1.45em);}



.subheadline                                    {font-size: min(calc(0.6em + 3vw), 1.45em); font-weight: 500;}

h1 + .subheadline                               {margin-top: -1em;}

.subheadline:has(+ h2)                          {margin-bottom: -1em;}



.icon                                           {display: flex; width: var(--icon-size); height: var(--icon-size); justify-content: center; align-items: center; font-weight: 700; border-radius: 100%; position: relative; box-sizing: border-box; isolation: isolate; z-index: 2;}

.icon img                                       {display: block; width: auto; height: 44%;}

.icon.black-60                                  {background: var(--black-60);}

.icon.white                                     {background: white;}

.icon.color2                                    {background-image: linear-gradient(to top, var(--color2), var(--color2b));}

.icon.shadow:before                             {display: block; width: 116%; height: 116%; border-radius: 100%; position: absolute; inset: -8%; z-index: -1; content: ""; box-shadow: 0 0 0.8em black;}

.icon:not(:has(img))                            {font-size: 1.3em; padding-bottom: 0.2em;}



.breadcrumbs                                    {display: block; max-width: 100%; font-size: 0.75em; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;}

.breadcrumbs::-webkit-scrollbar                 {display: none;}

.breadcrumbs ul                                 {display: flex; gap: 1.3em; margin: 0; padding: 0 !important;}

.breadcrumbs ul li                              {display: flex; width: auto; align-items: center; line-height: 1.3 !important; position: relative; padding: 0; margin: 0;}

.breadcrumbs ul li:before                       {display: none;}

.breadcrumbs ul li:not(:last-child) a:after     {display: inline-block; width: 0.5em; height: 0.5em; position: absolute; right: -0.88em; top: 0.42em; background: url("images/icons/chevron-white.svg") no-repeat center center; background-size: contain; content: "";transition: .25s ease-in-out;}

.breadcrumbs ul li a                            {display: block; color: inherit; text-decoration: none; font-weight: 500; border: none; white-space: nowrap; opacity: 0.7; letter-spacing: 0; transition: .25s ease-in-out;}

.breadcrumbs ul li a[href]:hover                {opacity: 1;}



.breadcrumbs:has(+ .article)                    {width: 100%;}



.pagination                                     {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.3em;}

.pagination a                                   {display: flex; width: 2.4em; aspect-ratio: 1; border-radius: 100%; justify-content: center; align-items: center; align-items: center; font-size: 0.9em; color: white; text-decoration: none; font-weight: 700; background: var(--white-10); padding-bottom: 0.2em; box-sizing: border-box; cursor: pointer; transition: .25s ease-in-out;}

.pagination a:hover                             {background: var(--white-20);}

.pagination a.sel                               {background: white; color: var(--color0);}                       



.submenu                                        {display: flex; width: 100vw; --submenu-height: 7.5em; --submenu-item-width: 7.2em; justify-content: center; margin-inline: calc(0.5 * var(--wrapper-width) - 50vw); overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center center; mask-position: center center; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to right, transparent, black calc(50vw - 0.5 * var(--wrapper-width)), black calc(100vw - 50vw + 0.5 * var(--wrapper-width)), transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black calc(50vw - 0.5 * var(--wrapper-width)), black calc(100vw - 50vw + 0.5 * var(--wrapper-width)), transparent);

                                                }

.submenu nav                                    {display: flex; width: auto; max-width: calc(100% + 0.4em); margin-inline: -0.2em; flex-direction: row; margin: 0 !important; padding: 0 !important; box-sizing: border-box;}

.submenu nav::-webkit-scrollbar                 {display: none;}

.submenu nav div                                {display: flex; width: var(--submenu-item-width); padding: 0.2em 0.2em 0.5em; margin: 0; scroll-snap-align: start; box-sizing: border-box; flex-shrink: 0;}

.submenu nav div a                              {display: flex; width: 100%; height: var(--submenu-height); flex-direction: column; justify-content: center; align-items: center; gap: 0.6em; border: solid 0.12em transparent; border-radius: var(--border-radius0); font-size: 0.8em; color: white; line-height: 1.3; letter-spacing: 0; text-decoration: none; font-weight: 700; background: var(--white-20); padding: 1em 0.8em 0.85em; opacity: 0.7; position: relative; box-sizing: border-box; cursor: pointer; transition: .25s ease-in-out;}

.submenu nav div a img                          {display: block; height: 2.2em; flex-shrink: 0;}

.submenu nav div a:hover                        {opacity: 1; cursor: pointer;}

.submenu nav div a .reset                       {display: none; width: 1.2em; height: 1.2em; border-radius: 100%; background: url("images/icons/cross-white.svg") no-repeat center center, var(--color2); background-size: 40%; position: absolute; right: calc(50% - 0.6em); bottom: -0.6em; transition: .25s ease-in-out;}

.submenu nav div a .reset:hover                 {background-color: var(--color2b);}

.submenu:not(.nav) nav div a.sel                {opacity: 1; border-color: var(--color2);}

.submenu nav div a.sel .reset                   {display: block;}

.submenu.nav nav div a                          {justify-content: center; height: 2.6em;  text-align: center; font-size: 0.9em; border-radius: calc(0.5 * var(--submenu-height)); padding: 0 1.2em;}

  @media screen and (min-width: 1081px)         {

  .submenu                                      {width: 100%; --submenu-height: 3.5em; margin-inline: 0; mask-image: none; -webkit-mask-image: none;}

  .submenu nav                                  {width: 100%; justify-content: center; flex-wrap: wrap;}

  .submenu nav div                              {width: 20%; padding: 0.2em;}

  .submenu nav div a                            {flex-direction: row; justify-content: flex-start; text-align: left; padding-inline: 1.1em 2.5em;}

  .submenu nav div a .reset                     {right: 0.8em; bottom: calc(50% - 0.6em);}

  .submenu nav div a img                        {height: 1.5em; position: relative; top: -0.1em;}

  }

  @media screen and (max-width: 1080px)         {

  .submenu nav div:first-child                  {width: calc(50vw - 0.5 * var(--wrapper-width) + var(--submenu-item-width)); padding-left: calc(50vw - 0.5 * var(--wrapper-width));}

  .submenu nav div:last-child                   {width: calc(50vw - 0.5 * var(--wrapper-width) + var(--submenu-item-width)); padding-right: calc(50vw - 0.5 * var(--wrapper-width));}

  }

  @media screen and (max-width: 640px)          {

  .submenu                                      {font-size: 0.9em;}

  }



.content                                        {display: flex; width: 100%; max-width: 42rem; flex-direction: column; align-items: center; gap: var(--gap2); box-sizing: border-box;}

.content .icon                                  {--icon-size: 3em; font-size: 1.4em;}

.content .large                                 {font-size: clamp(1em, calc(0.2em + 4vw), 1.5em); letter-spacing: 0;}

.content:not(:first-child),

.content + *                                    {margin-top: var(--gap1);}

.content .breadcrumbs + h1                      {margin-top: 0;}

.content .logo                                  {display: flex; width: 7em; aspect-ratio: 1; justify-content: center; align-items: center; box-sizing: border-box; position: relative; z-index: 2;}

.content .logo img                              {display: block; height: 100%;}

.content .logo:has(+ .cover)                    {background: var(--color0); padding: 1.2em; border-radius: 100%; margin-block: calc(-1 * var(--gap1)) calc(-3.5em - var(--gap2));}

.content .cover                                 {display: block; width: 100%; padding-top: 66.66%; position: relative;}

.content .cover a                               {display: block; position: absolute; inset: 0; background: white; border-radius: var(--border-radius1); overflow: hidden;}

.content .cover a img                           {display: block; width: 100%; height: 100%; object-fit: cover; transition: .25s ease-in-out;}

.content .cover a:hover img                     {opacity: 0.85;}

  @media screen and (min-width: 1081px)         {

  .content .cover                               {width: 120%; margin-inline: -10%;}

  }



.event-infographics                             {display: flex; width: 100%; justify-content: center; row-gap: var(--gap2);}

.event-infographics > div                       {display: flex; width: 8em; max-width: 33.33%; flex-direction: column; align-items: center; padding-inline: 0.7em; box-sizing: border-box; position: relative; letter-spacing: 0; line-height: 1.3;}

.event-infographics > div .icon                 {--icon-size: 2.9em; font-size: 0.85em; margin-bottom: 0.8em;}

.event-infographics > div .icon img             {height: 54%;}

.event-infographics > div .title                {display: block; font-size: 0.8em; color: var(--color2); font-weight: 500; margin-bottom: 0.15em;}

.event-infographics > div p                     {font-size: 1.1em; font-weight: 700;}

  @media screen and (min-width: 769px)          {

  .event-infographics                           {column-gap: var(--gap2);}

  .event-infographics > div                     {width: auto; max-width: unset; align-items: flex-start; padding-inline: 3.2em 0;}

  .event-infographics > div .icon               {position: absolute; left: 0; top: 0.16em;}

  .event-infographics > div *                   {text-align: left;}

  }



.button                                         {display: flex; height: var(--button-height); justify-content: center; align-items: center; gap: 0.5em; outline: none; cursor: pointer; font-size: 0.85em; font-weight: 700; letter-spacing: 0.1em;; line-height: 1; color: white; text-transform: uppercase; text-shadow: none !important; background: var(--color0); padding: 0 1.4em 0; position: relative; outline: none; border: none; border-radius: calc(var(--button-height) / 2); box-sizing: border-box; white-space: nowrap; font-family: var(--font1); transition: .15s ease-in-out;}

.button :is(img, svg)                           {display: block; height: 1.1em; fill: white;}

.button:hover                                   {background: black; transform: scale(0.98);}

.button.white                                   {background: white; color: var(--color0);}

.button.white > svg                             {fill: var(--color0);}

.button.white:hover                             {background: hsl(0,0%,90%);}

.button.white-10                                {background: var(--white-10);}

.button.white-10:hover                          {background: var(--white-20);}

.button.color1                                  {background: var(--color1); color: white;}

.button.color1:hover                            {background: var(--color1b);}

.button.color2                                  {background: var(--color2); color: white;}

.button.color2:hover                            {background: var(--color2b);}

.button.circle                                  {width: var(--button-height); padding-inline: 0;}



.link                                           {text-decoration: underline; transition: .15s ease-in-out;}

.link:hover                                     {text-decoration-color: transparent;}

.link.color1                                    {color: var(--color1)}

.link.color1:hover                              {color: var(--color0b);}



.flex                                           {display: flex; width: 100%; justify-content: center; align-items: center; gap: 0.5em; flex-wrap: wrap;}



.mask-sides                                     {display: block; width: 100%; height: 100%; background-repeat: no-repeat; background-size: cover; background-position: center center;

                                                -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to right, transparent, black 30%, black 70%, transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black 30%, black 70%, transparent);

                                                }



.hp .anim                                       {opacity: 0; transform: translate(0, 3em); transition: 0.6s ease-in-out; transition-delay: 0.15s;}

.hp .anim.zoom                                  {transform: translate(0) scale(0.85);}

.hp .anim.from-bottom                           {transform: translate(0, 3em);}

.hp .anim.play                                  {opacity: 1; transform: translate(0) scale(1) !important;}



.hero-slider                                    {display: flex; justify-content: center; position: absolute; inset: 0;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to top, transparent, black, transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to top, transparent, black, transparent);



}

.hero-slider .inner                             {display: flex; width: 100%; max-width: 1500px; height: 100%; overflow: hidden;}

.hero-slider .inner div                         {display: block; width: 50%; height: 200%; position: relative; animation-name: hero-move; animation-duration: 20s; animation-iteration-count: infinite;}

.hero-slider .inner div:nth-child(2)            {animation-delay: 10s;}

.hero-slider .inner div:nth-child(3)            {display: none; animation-delay: 5s;}

.hero-slider .inner div:nth-child(4)            {display: none; animation-delay: 15s;}

.hero-slider .inner div span                    {display: block; width: 100%; height: 50%; background-repeat: no-repeat; background-position: center top; background-size: cover;}

.hero-slider .inner div:nth-child(1) span:nth-child(1)  {background-image: url("images/hero/img1.webp");}

.hero-slider .inner div:nth-child(1) span:nth-child(2)  {background-image: url("images/hero/img2.webp");}

.hero-slider .inner div:nth-child(2) span:nth-child(1)  {background-image: url("images/hero/img3.webp");}

.hero-slider .inner div:nth-child(2) span:nth-child(2)  {background-image: url("images/hero/img4.webp");}

@keyframes hero-move                            {

                                                0%      {top: 0;}

                                                10%     {top: -100%;}

                                                45%     {top: -100%;}

                                                55%     {top: 0;}



}

  @media screen and (max-width: 1800px)         {

  .hero-slider .inner                           {mask-image: none; -webkit-mask-image: none;}

  }

  @media screen and (min-width: 1081px)         {

  .hero-slider .inner div                       {width: 25%;}

  .hero-slider .inner div:nth-child(n+3)        {display: block;}

  .hero-slider .inner div:nth-child(3) span:nth-child(1){background-image: url("images/hero/img5.webp");}

  .hero-slider .inner div:nth-child(3) span:nth-child(2){background-image: url("images/hero/img6.webp");}

  .hero-slider .inner div:nth-child(4) span:nth-child(1){background-image: url("images/hero/img7.webp");}

  .hero-slider .inner div:nth-child(4) span:nth-child(2){background-image: url("images/hero/img8.webp");}

  }

  @media screen and (min-width: 769px) and (max-width: 1080px){

  .hero-slider .inner div                       {width: 33.33%;}

  .hero-slider .inner div:nth-child(3)          {display: block;}

  .hero-slider .inner div:nth-child(3) span:nth-child(1){background-image: url("images/hero/img5.webp");}

  .hero-slider .inner div:nth-child(3) span:nth-child(2){background-image: url("images/hero/img6.webp");}

  }



.hero                                           {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2); margin-top: min(17rem, calc(10rem + 20vw));}

.hero :is(h1, p)                                {text-shadow: 0 0 0.4em var(--black-60);}

.hero h1                                        {font-size: min(calc(1.2em + 4vw), 2.8em);}

.hero h1 span                                   {font-weight: 400;}

.hero p                                         {max-width: 25em;}



.section:has(.logos)                            {padding-top: var(--section-padding-lower);}



.logos                                          {display: flex; width: 100%; max-width: 56rem; justify-content: center; flex-wrap: wrap;}

.logos a                                        {display: block; width: 33.33%; height: min(6em, calc(3em + 10vw)); padding: 0.2em; box-sizing: border-box;}

.logos a span                                   {display: block; width: 100%; height: 100%; background: var(--black-40); padding: 1em; box-sizing: border-box; border-radius: var(--border-radius0);}

.logos a img                                    {display: block; width: 100%; height: 100%; object-fit: contain;}

.logos a:nth-child(1) span                      {background: none; background-image: linear-gradient(to right, transparent, var(--black-40));}

.logos a:nth-child(6) span                      {background: none; background-image: linear-gradient(to left, transparent, var(--black-40));}

  @media screen and (min-width: 769px)          {

  .logos a                                      {width: 16.66%;}

  }

  @media screen and (max-width: 768px)          {

  .logos a:nth-child(4) span                    {background: none; background-image: linear-gradient(to right, transparent, var(--black-40));}

  .logos a:nth-child(3) span                    {background: none; background-image: linear-gradient(to left, transparent, var(--black-40));}

  }



.img-box                                        {display: flex; container-type: inline-size; padding: 0.4em; box-sizing: border-box; position: relative;}

.img-box .inner                                 {display: flex; width: 100%; min-height: 100%; flex-direction: column; position: relative;}

.img-box .inner .img                            {display: block; position: absolute; inset: 0; border-radius: var(--border-radius1); overflow: hidden; transition: .15s ease-in-out;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to top, transparent 1em, black 70%);                                           

                                                 -webkit-mask-image: linear-gradient(to top, transparent 1em, black 70%);

}

.img-box .inner .img img                        {display: block; width: 100%; height: 100%; object-fit: cover;}

.img-box .inner .info                           {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap1); position: relative; z-index: 2; padding-inline: max(1.2em, 10cqw); box-sizing: border-box; margin-top: 90cqw; text-shadow: 0 0 0.5em var(--black-60);}

.img-box .inner .icon                           {--icon-size: 3em; font-size: 1.3em;}

.img-box .inner .title                          {display: block; width: 100%; font-size: clamp(1em, 9cqw, 1.6em); font-weight: 700; line-height: var(--headline-line);}

.img-box .inner .text                           {font-size: 0.9em;}

.img-box .inner .flex                           {margin-top: 0.5em;}

.img-box .inner .flex .button                   {font-size: 0.75em;}

.img-box .inner .locality                       {display: flex; justify-content: center; flex-wrap: wrap; gap: 0.4em; font-size: 0.75em;}

.img-box .inner .locality img                   {display: block; height: 1em; position: relative; top: 0.26em;}

.img-box > a                                    {display: block; position: absolute; inset: 0; z-index: 2;}

.img-box:has(> a:hover) .img                    {filter: brightness(1.2);}



.img-box:has(.text) .inner .img                 {max-height: 26rem;}



.box                                            {display: flex; width: 100%; background: white; border-radius: var(--border-radius1); box-sizing: border-box; box-shadow: var(--box-shadow); margin-block: 1rem;}

.box > h2:first-child                           {margin-top: -0.15em;}



.arrow-list                                     {gap: 0.2em;}

.arrow-list li                                  {padding-left: 1.35em; text-align: left;}

.arrow-list li:before                           {width: 1em; height: 1em; background: url("images/icons/button-arrow-color0.svg") no-repeat center center; background-size: contain; top: 0.28em;}



.chevrons-list                                  {gap: 0.2em;}

.chevrons-list li                               {padding-left: 1.35em; text-align: left;}

.chevrons-list li:before                        {width: 1em; height: 0.7em; background: url("images/icons/chevron-color1.svg") no-repeat center center; background-size: contain; top: 0.42em;}



.preview                                        {display: flex; width: 100%; padding: var(--preview-padding); box-sizing: border-box; container-type: inline-size;}

.preview .inner                                 {display: flex; width: 100%; flex-direction: column; gap: 1em; background: white; border-radius: var(--border-radius1); padding: 0 min(1.6em, calc(0.3em + 4cqw)) min(1.6em, calc(0.3em + 4cqw)); box-sizing: border-box;}

.preview .img                                   {display: block; width: 100%; position: relative;}

.preview .img a                                 {display: block; width: 100%; aspect-ratio: 4/3; border-radius: 0 0 var(--border-radius1) var(--border-radius1); overflow: hidden;}

.preview .img a img                             {display: block; width: 100%; height: 100%; object-fit: cover; transition: .15s ease-in-out;}

.preview .img a:hover img                       {opacity: 0.9;}

.preview .info                                  {display: flex; width: 100%; flex-direction: column; gap: 0.8em; flex-grow: 2; color: var(--color0); padding-inline: 0.3em; box-sizing: border-box;}

.preview .title                                 {display: block; width: 100%; text-align: left; font-size: min(6.5cqw, 1.2em); font-weight: 700; line-height: var(--headline-line); letter-spacing: 0; margin-bottom: -0.1em;}

.preview .title a                               {color: inherit; transition: .15s ease-in-out;}

.preview .title a:hover                         {color: var(--color1);}

.preview .perex                                 {display: block; width: 100%; text-align: left; font-size: min(4.5cqw, 0.85em); opacity: 0.8; margin-top: -0.3em;}

.preview .bottom                                {display: flex; width: calc(100% + 0.6em); margin: 0 -0.3em; align-items: flex-end; align-content: flex-end; flex-grow: 2; margin-top: 0.3em;}

.preview .bottom .flex                          {justify-content: space-between; gap: 0.8em 5%; background: white; padding: 0.5em; box-sizing: border-box; border-radius: 1.5em; box-shadow: 0 0 0.7em rgba(0,0,0,0.3); container-type: inline-size;}

.preview .bottom .flex .price                   {display: block; text-align: left; font-size: min(1em, 6.4cqw); font-weight: 700; letter-spacing: 0; padding-left: 0.4em;}

.preview .bottom .flex .button                  {font-size: min(0.75em, 4.8cqw);}



.preview-blog                                   {display: flex; width: 100%; padding: var(--preview-padding); box-sizing: border-box; container-type: inline-size;}

.preview-blog .inner                            {display: flex; width: 100%; flex-direction: column; gap: 1em; background: var(--black-60); border-radius: var(--border-radius1); padding: 0 min(2em, calc(0.2em + 7cqw)) min(1.6em, calc(0.3em + 4cqw)); box-sizing: border-box;}

.preview-blog .img                              {display: block; width: 100%; position: relative;}

.preview-blog .img a                            {display: block; width: 100%; aspect-ratio: 3/2; border-radius: 0 0 var(--border-radius1) var(--border-radius1); overflow: hidden;}

.preview-blog .img a img                        {display: block; width: 100%; height: 100%; object-fit: cover; transition: .15s ease-in-out;}

.preview-blog .img a:hover img                  {opacity: 0.9;}

.preview-blog .info                             {display: flex; width: 100%; flex-direction: column; gap: 0.8em; flex-grow: 2; padding-left: 3.7em; box-sizing: border-box; position: relative;}

.preview-blog .title                            {display: block; width: 100%; text-align: left; font-size: min(6cqw, 1.48em); font-weight: 700; line-height: var(--headline-line); letter-spacing: 0; margin-bottom: -0.1em;}

.preview-blog .title a                          {color: inherit; transition: .15s ease-in-out;}

.preview-blog .title a:hover                    {color: var(--color1);}

.preview-blog .date                             {display: flex; flex-direction: column; align-items: center; position: absolute; left: 0; top: 0.145em;}

.preview-blog .date span                        {display: block; font-weight: 700; letter-spacing: 0;}

.preview-blog .date div                         {display: flex; flex-direction: column; align-items: center; padding: 0.15em 0.5em 0.3em; border: solid 0.12em white; border-radius: 0.5em; box-sizing: border-box;}

.preview-blog .date .day                        {font-size: 1.1em;}

.preview-blog .date .month                      {font-size: 0.8em; text-transform: uppercase; margin-top: -0.2em;}

.preview-blog .date .year                       {font-size: 0.7em;}

.preview-blog .flex                             {align-content: flex-end; justify-content: flex-start; flex-grow: 2; margin-top: 0.3em;}

.preview-blog .flex .button                     {font-size: min(0.7em, 4.5cqw);}



.preview-review                                 {display: flex; width: 100%; padding: var(--preview-padding); box-sizing: border-box; container-type: inline-size;}

.preview-review .inner                          {display: flex; width: 100%; flex-direction: column; background: var(--black-60); border-radius: var(--border-radius1); overflow: hidden;}

.preview-review .img                            {display: block; width: 100%; position: relative;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to top, transparent 1em, black 70%);                                           

                                                 -webkit-mask-image: linear-gradient(to top, transparent 1em, black 70%);

                                                }

.preview-review .img a                          {display: block; width: 100%; aspect-ratio: 3/4;}

.preview-review .img a img                      {display: block; width: 100%; height: 100%; object-fit: cover; transition: .15s ease-in-out;}

.preview-review .img a:hover img                {opacity: 0.9;}

.preview-review .info                           {display: flex; width: 100%; flex-direction: column; align-items: flex-start; gap: 0.8em; flex-grow: 2; margin-top: -65cqw; padding: max(1.8em, 10cqw); box-sizing: border-box; position: relative; z-index: 2;}

.preview-review .icon                           {padding: 1.3em;}

.preview-review .icon img                       {height: 100%;}

.preview-review :is(.title, .perex)             {display: block; width: 100%; text-align: left;}

.preview-review .title                          {font-size: min(7.5cqw, 1.5em); font-weight: 700; line-height: var(--headline-line); letter-spacing: 0;}

.preview-review .title a                        {color: inherit; transition: .15s ease-in-out;}

.preview-review .title a:hover                  {color: var(--color1);}

.preview-review .perex                          {font-size: min(4.5cqw, 0.85em); opacity: 0.8; margin-top: -0.3em;}

.preview-review .flex                           {justify-content: flex-start; align-content: flex-end; flex-grow: 2; margin-top: 0.75em;}

.preview-review .flex .button                   {font-size: min(0.7em, 4.5cqw);}



.swiper-slide                                   {display: flex; height: auto; flex-shrink: 0; transition: .35s ease-in-out;}

.swiper-slide > *                               {width: 100%;}



.swiper-button                                  {display: flex; width: var(--swiper-button-size); height: var(--swiper-button-size); --swiper-button-size: 3.2em; justify-content: center; align-items: center; background: var(--color1); position: absolute; top: calc(50% - 0.5 * var(--swiper-button-size)); z-index: 5; margin: 0; box-sizing: border-box; cursor: pointer; transition: .35s ease-in-out;} 

.swiper-button-prev                             {right: auto; transform: rotate(-180deg);}

.swiper-button-next                             {left: auto;}                                 

.swiper-button img                              {display: block; height: 30%;}

.swiper-button:after                            {display: none;}

.swiper-button:hover                            {background: var(--color1b);}

.swiper-button-lock                             {opacity: 0 !important;}

.swiper-buttons-edges .swiper-button            {width: calc(0.5 * var(--swiper-button-size)); height: var(--swiper-button-size); padding-left: 0.2em; border-radius: calc(50% - 0.5 * var(--swiper-button-size)) 0 0 calc(50% - 0.5 * var(--swiper-button-size));}

.swiper-buttons-edges .swiper-button-prev       {left: 0 !important;}

.swiper-buttons-edges .swiper-button-next       {right: 0 !important;}

  @media screen and (min-width: 1801px)         {

  .swiper-button                                {width: var(--swiper-button-size); --swiper-button-size: 2.6em; border-radius: 100%;}

  }

  @media screen and (max-width: 1800px)         {

  .swiper-button                                {font-size: 1.2em; padding-right: 1.5em; border-radius: var(--swiper-button-size);}

  .swiper-button-prev                           {left: calc(-50vw + 50% - (0.45 * var(--swiper-button-size)));}

  .swiper-button-next                           {right: calc(-50vw + 50% - (0.45 * var(--swiper-button-size)));}

  }

  @media screen and (max-width: 1800px) and (pointer: coarse){

  .swiper-button-prev                           {left: calc(-50vw + 50% - (0.55 * var(--swiper-button-size)));}

  .swiper-button-next                           {right: calc(-50vw + 50% - (0.55 * var(--swiper-button-size)));}

  }



.section:has(.carousel)                         {overflow: hidden;}



.carousel                                       {display: block; width: 100%; position: relative; box-sizing: border-box;}

.carousel-inner                                 {display: block; width: 100%; box-sizing: border-box; overflow: hidden;}

.carousel .swiper                               {display: block; width: 100%; box-sizing: border-box; overflow: visible;}

.carousel + .flex                               {margin-top: var(--gap1);}

.carousel + .flex .button                       {font-size: 0.8em;}

.carousel.c2 .swiper                            {overflow: hidden;}

  @media screen and (min-width: 1801px)         {

  .carousel .swiper                             {overflow: visible;}

  .about-slider .swiper-button-prev,

  .carousel .swiper-button-prev                 {left: -8%;}

  .about-slider .swiper-button-next,

  .carousel .swiper-button-next                 {right: -8%;}

  }

  @media screen and (max-width: 1800px)         {

  .carousel-inner                               {width: 100vw; margin-inline: calc(-1 * var(--carousel-edge)); padding-inline: var(--carousel-edge);

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to right, transparent, black var(--carousel-edge), black calc(100% - var(--carousel-edge)), transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black var(--carousel-edge), black calc(100% - var(--carousel-edge)), transparent);

                                                }

  }

  @media screen and (min-width: 1367px) and (max-width: 1800px){

  .carousel                                     {--carousel-edge: calc(50vw - 0.5 * var(--wrapper-max));}

  .carousel-blog                                {--carousel-edge: calc(50vw - 0.5 * var(--wrapper-medium-max));}

  .carousel.c2                                  {--carousel-edge: 0;}

  .carousel.c2 .carousel-inner                  {width: 100%;}

  .carousel.c2 .swiper-button                   {font-size: 0.9em; width: var(--swiper-button-size); --swiper-button-size: 2.6em; padding-right: 0; border-radius: 100%;}

  .carousel.c2 .swiper-button-prev              {left: calc(-0.5 * var(--swiper-button-size));}

  .carousel.c2 .swiper-button-next              {right: calc(-0.5 * var(--swiper-button-size));}

  }

  @media screen and (max-width: 1366px)         {

  .carousel                                     {--carousel-edge: calc(50vw - 0.5 * var(--wrapper-width));}

  }

  @media screen and (max-width: 640px)          {

  .section .wrapper:has(.carousel)              {--wrapper-width: min(24rem, 80vw);}

  .carousel .swiper-slide:not(.swiper-slide-active)

                                                {opacity: 0.3;}

  }



.rental-categories .img-box .info .button       {font-size: 0.55em;}



.bg-img                                         {display: flex; justify-content: center; position: absolute; inset: 0;}

.bg-img span                                    {display: block; width: 100%; min-width: 600px; max-width: 1600px; height: 100%; background-repeat: no-repeat; background-position: center center; background-size: cover;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to right, transparent, black, transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black, transparent);

                                                }



.section:has(.cta-allinone) .bg-img span        {background-image: url("images/podium2.webp"); opacity: 0.8;}



.cta-allinone                                   {display: flex; width: 100%; max-width: 32rem; flex-direction: column; align-items: center; gap: var(--gap2);}

.cta-allinone *                                 {text-shadow: 0 0 0.5em black;}

.cta-allinone .claim strong                     {display: flex; flex-direction: column; align-items: center;}

.cta-allinone .claim span                       {display: block; font-size: 1.8em; margin-top: 0.15rem; text-shadow: none;}



.section:has(.cta-about) .bg-img                {height: 60rem; top: 10%; bottom: auto;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to top, transparent, black 50%, transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to top, transparent, black 50%, transparent);

                                                }

.section:has(.cta-about) .bg-img span           {background-image: url("images/rays.webp"); opacity: 0.8;}

  @media screen and (min-width: 961px)          {

  .section:has(.cta-about)                      {padding-bottom: calc(2 * var(--section-padding));}

  .section:has(.cta-about) .bg-img              {height: 90%;}

  .section:has(.cta-about) + .section           {margin-top: calc(-2 * var(--section-padding));}

  }



.cta-about                                      {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2); position: relative; z-index: 2;}



.carousel-about                                 {margin-top: var(--gap2);}

.carousel-about:before                          {display: block; background: var(--white-20); box-shadow: var(--box-shadow); border-radius: var(--border-radius1); position: absolute; inset: -0.6em; content: "";}

.carousel-about .swiper                         {border-radius: calc(0.7 * var(--border-radius1));}

.carousel-about .img                            {display: block; width: 100%; padding-top: 66.66%; position: relative;}

.carousel-about .img span                       {display: block; position: absolute; inset: 0; overflow: hidden;}

.carousel-about .img span img                   {display: block; width: 100%; height: 100%; object-fit: cover;}

  @media screen and (min-width: 1367px) and (max-width: 1800px){

  .carousel-about .swiper-button-prev           {margin-left: -0.3em;}

  .carousel-about .swiper-button-next           {margin-right: -0.3em;}

  }



.box-about                                      {display: flex; width: 90%; max-width: 44rem; flex-direction: column; align-items: center; gap: var(--gap1); font-size: 0.9em; background: var(--color0); padding: min(3em, calc(1em + 5vw)); border-radius: var(--border-radius1); box-sizing: border-box; margin-block: max(-8em, calc(-2em - 10vw)) var(--gap2); box-shadow: var(--box-shadow); position: relative; z-index: 3;}

.box-about > img                                {display: block; width: 7em;}

.box-about .button                              {margin-top: var(--gap1);}



.infographics                                   {display: flex; width: 100%; max-width: 34rem; justify-content: center; flex-wrap: wrap; gap: var(--gap2) 0;}

.infographics > div                             {display: flex; width: 50%; flex-direction: column; align-items: center; gap: var(--gap1); padding-inline: 3.5%; box-sizing: border-box;}

.infographics > div .icon                       {--icon-size: 3em; font-size: 1.6em;}

.infographics > div p                           {font-size: 0.85em; font-weight: 500; letter-spacing: 0;}

  @media screen and (min-width: 961px)          {

  .infographics                                 {max-width: 48rem;}

  .infographics > div                           {width: 25%;}

  }

  

.image-text                                     {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2) 0; box-sizing: border-box;}

.image-text :is(.image, .text)                  {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap1); position: relative;}

.image-text .image                              {max-width: 40em;}

.image-text .image .inner                       {display: block; width: 100%; padding-top: 75%; position: relative;}

.image-text .image .inner > div                 {display: block;  position: absolute; inset: 0; border-radius: var(--border-radius1); overflow: hidden;}

.image-text .image .inner > div img             {display: block; width: 100%; height: 100%; object-fit: cover;}

.image-text .text                               {z-index: 2;}

.image-text + .infographics                     {margin-toP: var(--gap2);}

  @media screen and (min-width: 1081px)         {

  .image-text                                   {flex-direction: row; justify-content: space-between; padding-inline: var(--padding1);}

  .image-text .image                            {width: 60%; margin-inline-end: -10%;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% 100%; mask-size: 100% 100%;

                                                 mask-image: linear-gradient(to left, transparent, black 50%);                                           

                                                 -webkit-mask-image: linear-gradient(to left, transparent, black 50%);  

  }

  .image-text .text                             {width: 50%; align-items: flex-start;}

  .image-text .text :is(h1, h2, p)              {text-align: left;}

  .image-text.reversed                          {flex-direction: row-reverse;}

  .image-text.reversed .image                   {margin-inline: -10% 0;

                                                 mask-image: linear-gradient(to right, transparent, black 50%);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black 50%);    

  }

  }

  @media screen and (max-width: 1080px)         {

  .image-text .text                             {max-width: 40rem;}

  .image-text .image                            {max-width: min(80vw, 34rem); order: -1;}

  }      

  @media screen and (min-width: 641px) and (max-width: 1080px){

  .image-text .text ul.checks                   {column-count: 2; column-gap: 1.2em;}

  }



.carousel-gallery-full .img                     {display: block; width: calc(100% - 0.8em); margin-inline: 0.4em; padding-top: calc(100% * 4 / 3); position: relative;}

.carousel-gallery-full .img a                   {display: block; aspect-ratio: unset !important; position: absolute; inset: 0; background: white; border-radius: var(--border-radius1); overflow: hidden;}

.carousel-gallery-full .img a img               {display: block; width: 100%; height: 100%; object-fit: cover; transition: .25s ease-in-out;}

.carousel-gallery-full .img a:hover img         {opacity: 0.85;}



.carousel-gallery                               {width: calc(100% + 0.8em); margin-inline: -0.4em;}

.carousel-gallery .img                          {display: block; width: calc(100% - 0.8em); margin-inline: 0.4em; padding-top: calc(100% * 3 / 4); position: relative;}

.carousel-gallery .img a                        {display: block; aspect-ratio: unset !important; position: absolute; inset: 0; background: white; border-radius: var(--border-radius1); overflow: hidden;}

.carousel-gallery .img a img                    {display: block; width: 100%; height: 100%; object-fit: cover; transition: .25s ease-in-out;}

.carousel-gallery .img a:hover img              {opacity: 0.85;}

.carousel-gallery .swiper-button-prev           {left: }

  @media screen and (max-width: 1366px)         {

  .carousel-gallery .swiper                     {overflow: visible !important;}

  }



.about-page .quote                              {display: flex; width: 100%;}

.about-page .quote span                         {display: block; max-width: 20em; text-align: left; font-size: 1.1em; font-weight: 500; padding-left: 3.7em; position: relative; box-sizing: border-box;}

.about-page .quote span:before                  {display: block; width: 3em; height: 2.3em; background: url("images/icons/quotes-color1.svg") no-repeat left top; background-size: auto contain; position: absolute; left: 0; top: 0.35em; content: "";}

.about-page .icon-info                          {text-align: center; font-size: 0.9em; line-height: 1.3; height: auto; flex-wrap: wrap; padding: 0.5em 1em 0.5em;}

.about-page .icon-info img                      {font-size: 1.2em;}

.about-page .swiper-button                      {padding-right: 0;}

.about-page .swiper-button-prev                 {left: -1em;}

.about-page .swiper-button-next                 {right: -1em;}

  @media screen and (max-width: 1080px)         {

  .about-page .quote                            {justify-content: center;}

  }



.about-page .image .bg                          {background-image: linear-gradient(45deg, var(--color0-30), transparent 80%);}

.about-page .image .bg:before,

.about-page .image .bg:after                    {display: block; opacity: 0.08; filter: saturate(3); background-repeat: no-repeat; background-position: center center; background-size: contain; position: absolute; content: "";}

.about-page .image .bg:before                   {width: 65%; height: 65%; background-image: url("images/icons/pictogram-color0.svg"); left: 5%; bottom: 18%;}

.about-page .image .bg:after                    {width: 58%; height: 58%; background-image: url("images/icons/pictogram-outline-color0.svg"); right: 4%; top: 0;}

.about-page .image .pictogram1                  {top: 9%; right: 18.5%;}

.about-page .image .label                       {font-size: 4.5cqw; background: rgba(225,225,255,0.6); padding: 0.6em 1.2em 0.6em; left: 4%; bottom: 6%;}

.about-page .image .label:before                {display: block; width: 4em; text-align: center; font-size: 0.6em; color: white; font-weight: 700; background: var(--color0); padding: 0.34em 0; border-radius: 1.2em; position: absolute; left: calc(50% - 2em); bottom: 80%; content: "TĂ˝m";}

.about-page .image .person                      {font-size: 3cqw; background: var(--color0); padding: 0.9em 1.5em 0.95em 1em; border-radius: 1em; position: absolute; right: 0; bottom: 16%;}



.article                                        {display: flex; width: 100%; align-items: flex-start; align-content: flex-start; flex-wrap: wrap; gap: 1.6rem;}

.article *                                      {text-align: left;}

.article h1                                     {font-size: min(2.5em, calc(0.8em + 4vw)); margin-top: 0 !important; text-wrap: unset;}

.article .date                                  {display: flex; align-items: center; gap: 0.4em; font-size: 0.9em; font-weight: 500; margin-top: -0.6em;}

.article .date img                              {display: block; height: 1em; position: relative; top: 0.08em;}

.article :is(h2, h3)                            {margin-block: 0.4em -0.1em;}

.article h2                                     {font-size: 1.75em; font-weight: 800;}

.article h3                                     {font-size: 1.4em; font-weight: 700; color: var(--color1);}

.article .image                                 {display: block; width: 100%; aspect-ratio: 4/3; background: white; border-radius: var(--border-radius1); box-shadow: var(--box-shadow);} 

.article .image span                            {display: block; width: 100%; height: 100%; border-radius: var(--border-radius1); overflow: hidden; transition: .15s ease-in-out;}

.article .image span img                        {display: block; width: 100%; height: 100%; object-fit: cover;}

.article .image:hover span                      {opacity: 0.8;}

.article .video-embed                           {display: block; width: 100%; aspect-ratio: 16/9;} 

.article .video-embed span                      {display: block; width: 100%; height: 100%;}

.article .video-embed span iframe               {display: block; width: 100%; height: 100%; position: absolute; inset: 0; border-radius: var(--frame); overflow: hidden;}

.article .quote                                 {padding-left: 3.3em; box-sizing: border-box; position: relative; padding-bottom: 1em; border-bottom: solid 0.12em var(--color1);}

.article .quote:after                           {display: block; width: 1.2em; height: 1.2em; position: absolute; left: 1.3em; top: .28em; content: ""; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M384,384c-17.67,0-32-14.33-32-32s14.33-32,32-32c35.29,0,64-28.71,64-64v-32h-76.85c-20.79,0-34.53,0-48.21-6.97-12.11-6.17-21.78-15.85-27.96-27.98-6.98-13.69-6.98-27.44-6.98-48.25v-57.6c0-20.82,0-34.57,6.98-48.26,6.18-12.12,15.85-21.79,27.97-27.97,13.68-6.97,27.44-6.97,48.26-6.97h57.6c20.81,0,34.55,0,48.25,6.98,12.13,6.18,21.8,15.85,27.98,27.96,6.97,13.68,6.97,27.42,6.97,48.21v172.85c0,70.58-57.42,128-128,128ZM352.62,161.54h0s0,0,0,0ZM352.35,159.65c3.88.35,11.44.35,18.8.35h76.85s0-76.85,0-76.85c0-7.36,0-14.92-.35-18.8-3.87-.35-11.46-.35-18.85-.35h-57.6c-7.38,0-14.97,0-18.85.35-.35,3.88-.35,11.47-.35,18.85v57.6c0,7.38,0,14.97.35,18.85ZM350.45,64.62s0,0,0,0c0,0,0,0,0,0ZM447.38,62.44h0s0,0,0,0ZM96,384c-17.67,0-32-14.33-32-32s14.33-32,32-32c35.29,0,64-28.71,64-64v-32h-76.85c-20.79,0-34.53,0-48.21-6.97-12.12-6.18-21.79-15.85-27.97-27.98-6.97-13.69-6.97-27.43-6.97-48.24v-57.6c0-20.82,0-34.57,6.98-48.26,6.17-12.12,15.85-21.79,27.97-27.96C48.63,0,62.38,0,83.2,0h57.6c20.81,0,34.55,0,48.25,6.98,12.13,6.18,21.81,15.85,27.98,27.96,6.97,13.68,6.97,27.42,6.97,48.21v172.85c0,70.58-57.42,128-128,128ZM64.62,161.54s0,0,0,0c0,0,0,0,0,0ZM64.35,159.65c3.88.35,11.44.35,18.8.35h76.85s0-76.85,0-76.85c0-7.36,0-14.92-.35-18.8-3.87-.35-11.46-.35-18.85-.35h-57.6c-7.38,0-14.97,0-18.85.35-.35,3.88-.35,11.47-.35,18.85v57.6c0,7.38,0,14.97.35,18.85ZM62.45,64.62s0,0,0,0c0,0,0,0,0,0ZM161.54,64.62s0,0,0,0c0,0,0,0,0,0ZM159.38,62.44h0s0,0,0,0Z' width='1' height='1' fill='rgb(255,204,51)' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center center; background-size: contain;}

.article ul, ol                                 {display: flex; flex-wrap: wrap; gap: 0.2em; padding: 0 0 0 1.2em; margin: -0.15em 0 0;}

.article ul li, ol li                           {padding-left: 1.8em; position: relative; box-sizing: border-box;}

.article li:before                              {display: block; position: absolute; content: "";}

.article ul li:before                           {width: 1em; height: 0.6em; top: 0.43em; left: 0.1em; background: url("images/icons/chevron-white.svg") no-repeat left center; background-size: contain;}

.article ol                                     {list-style-type: none; counter-reset: li;}

.article ol li                                  {counter-increment: li;}

.article ol li:before                           {font-weight: 400; top: 0; left: -0.025em; content: counter(li)".";}

.article :is(.highlight1, .highlight2)          {display: flex; width: 100%; flex-wrap: wrap; gap: 0.9rem; padding: min(3em, calc(0.5em + 5vw)); position: relative; border-radius: var(--border-radius1); box-sizing: border-box;}

.article :is(.highlight1, .highlight2) > *:first-child 

                                                {margin-top: 0 !important;}

.article :is(.highlight1, .highlight2) h3       {color: white;}   

.article :is(.highlight1, .highlight2) .button  {margin-top: 0.5rem;}                                           

.article .highlight1                            {background: var(--white-10);}

.article .highlight2                            {background: linear-gradient(var(--color0), var(--color0)) padding-box, linear-gradient(to right, var(--color2), var(--color1), var(--color2)) border-box; border: 0.26em solid transparent; box-shadow: var(--box-shadow);}



.article .embed                                 {display: block; width: 100%; border-radius: 1em; overflow: hidden;}

.article .embed iframe                          {display: block; width: 100%;}

  @media screen and (min-width: 769px)          {

  .article :is(.image)                          {width: 112%; margin-inline: -6%;}

                                                }

  @media screen and (min-width: 641px)          {

  .article .preview-blog                        {padding: 0;}

  .article .preview-blog .inner                 {justify-content: space-between; flex-direction: row; align-items: stretch; padding: 1.4em 1.4em 1.4em 0;}

  .article .preview-blog .img                   {width: 27%;}

  .article .preview-blog .img a                 {border-radius: 0 var(--border-radius1) var(--border-radius1) 0;}

  .article .preview-blog .info                  {width: 70%; justify-content: space-between; padding: 0; flex-grow: unset;}

  .article .preview-blog .title                 {font-size: 3.6cqw;}

  .article .preview-blog .date                  {flex-direction: row; align-items: center; gap: 0.2em; left: auto; top: auto; right: 1em; bottom: 0.3em; opacity: 0.6;}

  .article .preview-blog .date span             {display: inline-block; font-size: 0.8em; text-transform: none !important; font-weight: 500; margin: 0;}

  .article .preview-blog .date div              {flex-direction: row; gap: 0.2em; padding: 0; border: none; border-radius: 0;}

  .article .preview-blog .date .day:after       {content: ".";}

  .article .preview-blog .flex .button          {font-size: 0.7em;}

  }



.features                                       {counter-reset: feature; margin-bottom: 0.5em;}

.features > div                                 {display: flex; padding: 0.5em; box-sizing: border-box; counter-increment: feature;}

.features .box                                  {background: var(--white-10); flex-direction: column; align-items: center; gap: var(--gap1); padding: min(3em, calc(1em + 3cqw)); position: relative; overflow: hidden; container-type: inline-size; margin: 0;}

.features .box:before                           {display: block; width: 100%; height: 1em; position: absolute; left: 0; bottom: 0.07em; z-index: -1; font-size: 90cqw; font-weight: 700; color: black; opacity: 0.25; content: "0"counter(feature);}

.features .box .icon                            {margin-bottom: 0.5em;}

.features .box h2                               {font-size: min(2em, calc(1em + 3cqw));}

.features .box p                                {font-size: 0.9em;}



body:has(.item-info) h1                         {font-size: min(calc(1em + 4vw), 2.7em);}



.section:has(.cover-slider)                     {overflow: hidden;}



.cover-slider                                   {overflow: visible; position: relative; padding: 0 !important;}

.cover-slider .swiper-slide img                 {display: block; width: 100%; height: 100%; object-fit: cover;} 

.cover-slider .image                            {width: 100%; padding-top: 66.66%; position: relative;}

.cover-slider .image .swiper                    {display: block; width: 100%; height: 100%; position: absolute; inset: 0; border-radius: var(--border-radius1);}

.cover-slider .image .swiper-slide              {width: 100%; height: 100%;}

.cover-slider .thumbs                           {display: flex; width: 100%; justify-content: center; padding-inline: 3rem; box-sizing: border-box; margin-top: var(--gap2);}

.cover-slider .thumbs .swiper                   {display: block; width: 100%; max-width: var(--wrapper-thin-max); border-radius: calc(0.5 * var(--border-radius1));}

.cover-slider .thumbs .swiper-slide div         {display: block; width: 100%; padding-top: calc(100% * 9 / 16); position: relative;}

.cover-slider .thumbs .swiper-slide span        {display: block; position: absolute; inset: 0;}

.cover-slider .thumbs .swiper-slide:not(.swiper-slide-thumb-active)

                                                {opacity: 0.4;}

.cover-slider .thumbs .swiper-slide:hover       {opacity: 1; cursor: pointer}

  @media screen and (min-width: 1081px)         {

  .cover .swiper-button                         {font-size: 0.85em; padding-right: 0;}

  .cover .swiper-button-prev                    {left: -1.6em;}

  .cover .swiper-button-next                    {right: -1.6em;}

  }



.steps                                          {row-gap: 3em;}                    

.steps > div                                    {display: flex; flex-direction: column; align-items: center; gap: var(--gap1); padding: 0 1.2em; box-sizing: border-box; position: relative;}

.steps > div:nth-child(-n+2):before             {display: block; background: var(--color1); position: absolute; border-radius: 0.08em; content: "";}

.steps > div .icon                              {margin-bottom: 0.5em;}

.steps > div h2                                 {font-size: min(1.5em, calc(1em + 3cqw));}

.steps > div p                                  {font-size: 0.9em;}

  @media screen and (min-width: 769px)          {

  .steps.grid                                   {--row-count: 3;}

  .steps > div:before                           {width: calc(100% - var(--icon-size) - 3em); height: 0.16em; left: calc(50% + 0.5 * var(--icon-size) + 1.5em); top: calc(0.5 * var(--icon-size) - 0.08em);}

  }



.item-info                                      {display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--gap2);}



.price-buy                                      {width: auto; gap: 1em 1.4em; background: var(--white-10); padding: 0.8em 0.8em 0.8em 1.4em; border-radius: 2em;}

.price-buy .price                               {display: block; font-size: 1.1em; font-weight: 700; letter-spacing: 0;}



.specs                                          {max-width: 40rem; flex-direction: column; gap: var(--gap2); background: var(--white-10); padding: min(4em, calc(1em + 5vw));}

.specs h2                                       {font-size: 1.8em;}

.specs table                                    {width: 100%; border-collapse: collapse;}

.specs table td                                 {width: 40%; font-size: 0.9em; text-align: left; vertical-align: top;}

.specs table td:last-child                      {width: 60%; text-align: right; padding-left: 1.2em;}

.specs table tr:not(:first-child) td            {padding-top: 1em; border-top: solid 1px var(--white-20);}

.specs table tr:not(:last-child) td             {padding-bottom: 1em;}





.checkbox                                       {display: block; position: relative;}



input[type="checkbox"]:not(:checked),

input[type="checkbox"]:checked                  {position: absolute; left: -9999px; top: 0;}



.chk1:not(:checked) + label,   

.chk1:checked + label                           {display: block; min-width: 0.9em; min-height: 0.9em; position: relative; text-align: left; font-size: 0.9em; color: var(--color0); font-weight: 400; padding-inline-start: 1.4em; cursor: pointer; box-sizing: border-box; transition: .25s ease-in-out;}

.chk1:not(:checked) + label:before,

.chk1:checked + label:before                    {display: block; width: 0.9em; height: 0.9em; background: var(--color0-40); opacity: 0.7; position: absolute; left: 0; top: 0.3em; border-radius: 0.2em; overflow: hidden; content: "";}

.chk1:checked + label:before                    {background: URL('images/icons/check-white.svg'), var(--color1); opacity: 1;}

.chk1:disabled + label,                  

.chk1:disabled + label:before                   {opacity: 0.4;}

.chk1 + label a                                 {color: inherit; font-weight: 500; text-decoration: underline; transition: .25s ease-in-out;}

.chk1 + label a:hover                           {opacity: 0.8; text-decoration-color: transparent;}



.wndw                                           {display: flex; width: 100%; height: 100%; flex-direction: row; justify-content: center; align-items: center; padding: min(1rem, 5%); box-sizing: border-box; position: fixed; left: -99999px; top: 0; z-index: 1000000;}

.wndw:before                                    {display: block; width: 100%; height: 100%; background: rgba(0,0,0,0.65); backdrop-filter: blur(4px); position: absolute; left: 0; top: 0; z-index: -1; content: ""; opacity: 0; transition: opacity .3s ease-in-out;}

.wndw > .outer                                  {display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1;}

.wndw > div                                     {display: flex; width: 100%; max-width: 48em; max-height: calc(100svh - 3rem); background: var(--color0); position: relative; border-radius: 1.2em; top: 0; z-index: 2; box-shadow: 0 0 0.6em rgba(0,0,0,0.12); transform: scale(0.8); transition: .25s ease-in-out;}

.wndw > div .overflow                           {display: block; width: 100%; max-height: 100%; overflow-y: auto; overflow-x: hidden; box-sizing: border-box;}

.wndw > div .overflow > div                     {display: block; width: 100%; height: auto;}

.wndw.show                                      {left: 0;}

.wndw.show:before                               {opacity: 1;}

.wndw.show > div                                {transform: scale(1);}

.wndw.show.hide                                 {left: -99999px; transition: left 0s ease-in-out; transition-delay: 0.3s;}

.wndw.show.hide:before                          {opacity: 0;}

.wndw.show.hide > div                           {transform: scale(0.8) !important; opacity: 0;}

.wndw .cross                                    {display: block; width: 1.8em; height: 1.8em; font-size: 1em; background: var(--color2); border-radius: 100%; cursor: pointer; position: absolute; right: -0.6em; top: -0.6em; z-index: 10002; box-shadow: 0 0 0.4em rgba(0,0,0,0.1); transition: .2s ease-in-out;}

.wndw .cross span                               {display: block; width: 50%; height: 0.14em; background: white; border-radius: 2px; position: absolute; left: 25%; top: calc(50% - 0.07em); z-index: 1;}

.wndw .cross:hover                              {background: var(--color0b);}

.wndw .cross span:nth-child(1)                  {transform: rotate(45deg);}

.wndw .cross span:nth-child(2)                  {transform: rotate(-45deg);}

.wndw .wndw-content                             {display: flex; width: 100%; justify-content: center; align-items: flex-start; align-content: flex-start; flex-wrap: wrap; gap: 1.2em; font-size: 1rem; padding: max(2rem, 8%) min(6rem, 10vw); box-sizing: border-box;}

.wndw .wndw-content .icon                       {margin-bottom: -0.4em;}

.wndw .wndw-content .wndw-title                 {display: block; width: 100%; text-align: center; font-size: min(2em, calc(1em + 3vw)); font-weight: 700; line-height: 1.1; margin-bottom: 0.15em;}

.wndw .wndw-content p                           {display: block; width: 100%; text-align: center; font-size: 0.9em;}

.wndw .wndw-content p strong                    {font-weight: 700;}

.wndw .wndw-content .title:has(+ p),

.wndw .wndw-content .title2:has(+ p)            {margin-bottom: -0.35em;}

.wndw .wndw-content .flex                       {gap: 0.3em; margin-top: 1em;}

.wndw .wndw-content .flex .button               {min-width: 8em; font-size: 0.9em;}  

.wndw .wndw-content .link                       {font-size: 0.75em; opacity: 0.8; cursor: pointer;}



.phones                                         {display: block; width: 100%;}

.phones ul                                      {display: flex; width: 100%; flex-wrap: wrap;}

.phones ul li                                   {display: flex; width: 100%; justify-content: space-between; align-items: center; gap: 0.75em 1em; box-sizing: border-box;}

.phones ul li:not(:last-child)                  {margin-bottom: 1em; padding-bottom: 1em; border-bottom: solid 1px var(--color0-30);}

.phones ul li .info                             {display: flex; flex-direction: column; flex-shrink: unset;}

.phones ul li .info span                        {display: block; width: 100%; text-align: left; font-weight: 400; box-sizing: border-box; position: relative;}

.phones ul li .info .title                      {font-size: 1.2em; font-weight: 800; margin-top: -0.1em;}

.phones ul li .info .address                    {font-size: 0.85em; padding-left: 1.3em;}

.phones ul li .info .address:Before             {display: block; width: 1.1em; height: 1.1em; background: url("images/icons/marker-color0.svg") no-repeat left center; background-size: contain; position: absolute; left: 0; top: 0.13em; content: "";}

.phones ul li a                                 {white-space: nowrap;}

  @media screen and (max-width: 540px)          {

  .phones ul li                                 {flex-wrap: wrap;}

  .phones ul li .info                           {width: 100%;}

  .phones ul li .info .title                    {font-size: 1.45em;}

  }



.contacts                                       {display: flex; width: 100%; justify-content: center; flex-direction: column; gap: 3em; background: var(--white-10); padding: min(4em, calc(1em + 5vw)); box-sizing: border-box; border-radius: var(--border-radius1);}

.contacts > div                                 {display: flex; flex-direction: column; align-items: center; gap: var(--gap1);}

.contacts h2                                    {font-size: 1.55em;}

.contacts .small                                {font-size: 0.7em;}

.contacts .contact                              {display: block; text-align: left; color: inherit; padding-left: 1.65em; position: relative; box-sizing: border-box; transition: .15s ease-in-out;}

.contacts .contact img                          {display: block; height: 1.15em; position: absolute; left: 0; top: 0.18em;}

.contacts .contact span                         {display: block; font-size: 0.75em; opacity: 0.7;}

.contacts .contact[href]:hover                  {opacity: 0.8;}

  @media screen and (min-width: 1081px)         {

  .contacts                                     {justify-content: space-between; flex-direction: row; font-size: 0.9em;}

  .contacts > div                               {align-items: flex-start;}

  .contacts > div:nth-child(1)                  {width: 12em;}

  .contacts > div:nth-child(2)                  {width: 12em;}

  .contacts *                                   {text-align: left;}

  }



input[type="date"]                              {background-image: url("images/icons/calendar-white.svg"); background-repeat: no-repeat; background-position: right 1em center; background-size: auto 1em;}

input[type="date"]::-webkit-inner-spin-button,

input[type="date"]::-webkit-clear-button        {opacity: 0;}

input[type="date"]::-webkit-calendar-picker-indicator

                                                {opacity: 0;}



.form                                           {display: flex; width: 100%; flex-wrap: wrap; gap: var(--form-gap); position: relative; z-index: 10;}

.form h2                                        {font-size: min(calc(0.8em + 3vw), 1.6em); padding-inline: var(--padding1); box-sizing: border-box; margin-top: 0.4em;}

.form.form-cols                                 {justify-content: space-between;}

.form.form-cols > div                           {display: flex; width: 100%; align-items: flex-start; align-content: flex-start; flex-wrap: wrap; gap: var(--form-gap); position: relative; z-index: 10;}

.form.form-cols > div > *:first-child           {margin-top: 0;}

  @media screen and (min-width: 769px)          {

  .form.form-cols > div                         {width: 48%;}

  }



.form-items                                     {display: flex; width: 100%; flex-wrap: wrap; gap: 1.4em var(--form-items-gap);}

  @media screen and (min-width: 769px)          {

  .form-items :is(.w33, .w33-50)                {width: calc(33.33% - 2 / 3 * var(--form-items-gap));}

  .form-items .w66                              {width: calc(66% - 0.5 * var(--form-items-gap));}

  }

  @media screen and (min-width: 341px) and (max-width: 768px){

  .form-items .w33-50                           {width: calc(50% - 0.5 * var(--form-items-gap));}

  }

  @media screen and (min-width: 481px)          {

  .form-items .w50-100                          {width: calc(50% - 0.5 * var(--form-items-gap));}

  }



.form-item                                      {display: block; width: 100%; text-transform: none;}

.form-item .element                             {display: block; width: 100%; height: var(--form-item-height); border: var(--form-item-border); border-radius: calc(0.5 * var(--form-item-height)); box-sizing: border-box; position: relative; transition: .15s ease-in-out;}

.form-item .element :is(input, textarea)        {display: block; width: 100%; height: 100%; font-size: 1em; color: white; font-weight: 700; border: none; outline: none; padding: calc(0.5 * var(--form-item-height) - 1em) var(--form-item-padding); box-sizing: border-box; background-color: transparent; font-family: var(--font1); transition: .15s ease-in-out;}

.form-item .element:has(textarea)               {height: 14em;}

.form-item .element textarea                    {padding-block: var(--form-item-padding);}

.form-item .element > label                     {display: block; font-size: 0.8em; font-weight: 500; color: white; letter-spacing: 0; background: var(--color0); padding-inline: 0.4em; position: absolute; left: var(--form-item-padding); top: -0.77em; transition: .15s ease-in-out;}

.form-item .element:focus-within                {border-color: var(--white-60);}

.form-item-error                                {display: block; width: 100%; font-size: 0.75em; color: var(--color-error); font-weight: 700; letter-spacing: 0; padding-inline: 1.6em; box-sizing: border-box; margin-top: 0.5em;}

.form-item-note                                 {display: block; width: 100%; font-size: 0.75em; color: var(--color0c); font-weight: 700; letter-spacing: 0; padding-inline: 1em; box-sizing: border-box; margin-top: 0.5em;}

.form-item-note a                               {color: inherit; text-decoration: underline; transition: .15s ease-in-out;}

.form-item-note a:hover                         {color: var(--color0b); text-decoration-color: transparent;}

.form-item.obligatory .element > label:after    {color: var(--color-error); content: " *";}



.form .send                                     {display: flex; width: 100%; flex-direction: column; align-items: center; flex-wrap: wrap; gap: 1.2em; padding: 0 var(--padding1); box-sizing: border-box;}

.form .send span                                {display: block; font-size: 0.75em; color: var(--white-70);}

.form .send span a                              {color: inherit; text-decoration: underline; transition: .2s ease-in-out;}

.form .send span a:hover                        {opacity: 0.7; text-decoration-color: transparent;}



.grid                                           {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; --row-count: 1;}

.grid > *                                       {width: calc(100% / var(--row-count));}

.grid:has(.img-box)                             {row-gap: var(--gap2);}

  @media screen and (min-width: 1281px)         {

  .grid.g5-4-2                                  {--row-count: 5;}

  }

  @media screen and (min-width: 961px) and (max-width: 1280px){

  .grid.g5-4-2                                  {--row-count: 4;}

  }

  @media screen and (max-width: 960px)          {

  .grid.g5-4-2                                  {--row-count: 2; max-width: 30rem;}

  }

  @media screen and (min-width: 1081px)         {

  .grid.g3-1,

  .grid.g3-2-1                                  {--row-count: 3;}

  .grid.g4-2-1                                  {--row-count: 4;}

  }

  @media screen and (min-width: 541px)          {

  .grid.g2-1                                    {--row-count: 2;}

  }

  @media screen and (min-width: 541px) and (max-width: 1080px){

  .grid.g3-2-1,

  .grid.g4-2-1                                  {--row-count: 2;}

  }



.grid-message                                   {display: flex; width: calc(100% - 0.6em); margin: 0.3em; justify-content: center; flex-wrap: wrap; gap: 0.5em; background: var(--white-10); padding: 0.8em; box-sizing: border-box; border-radius: var(--border-radius0);}

.grid-message p                                 {font-size: 0.8em;}



.cart-row                                       {display: flex; width: 100%; flex-direction: row; justify-content: space-between; align-items: center; gap: 0.5em 2em; background: white; letter-spacing: 0; padding: 0.5em 1.2em 0.5em 0; position: relative; border-radius: calc(0.6 * var(--border-radius1)); box-sizing: border-box;}

.cart-row > *                                   {flex-shrink: 0;}

.cart-row .img                                  {display: block; width: 5.6em; aspect-ratio: 4/3; background: white; border-radius: 0 var(--border-radius0) var(--border-radius0) 0; overflow: hidden;}

.cart-row .img img                              {display: block; width: 100%; height: 100%; object-fit: cover; transition: .15s ease-in-out;}

.cart-row .img:hover img                        {opacity: 0.9;}

.cart-row .info                                 {display: block; flex-grow: 2; flex-shrink: unset;}

.cart-row .info span                            {display: block; text-align: left; color: var(--color0); line-height: 1.3;}

.cart-row .info .title                          {font-weight: 600;}

.cart-row .info .title a                        {color: inherit; transition: .15s ease-in-out;}

.cart-row .info .title a:hover                  {color: var(--color1);}

.cart-row .info .note                           {display: block; font-size: 0.8em; color: var(--black-60); margin-top: 0.5em;}

.cart-row .price                                {font-size: 1em; color: var(--color0); font-weight: 700;}

.cart-row .action                               {display: block; width: 1.4em; height: 1.4em; position: relative; cursor: pointer; border-radius: 100%; transition: .15s ease-in-out;}

.cart-row .action:before,

.cart-row .action:after                         {display: block; width: 60%; height: 0.18em; background: white; border-radius: 0.03em; position: absolute; left: 20%; top: calc(50% - 0.09em); content: "";}

.cart-row .action:after                         {transform: rotate(-90deg);}

.cart-row .action:hover                         {opacity: 0.8;}

.cart-row .remove                               {background: var(--black-30); transform: rotate(45deg);}

.cart-row .add                                  {background: var(--color1);}

  @media screen and (min-width: 961px)          {

  .cart-row                                     {flex-wrap: nowrap;}

  .cart-row .info                               {margin-left: -0.8em;}  

  }

  @media screen and (max-width: 960px)          {

  .cart-row                                     {flex-direction: column; align-items: flex-start; padding: 0.8em 2.2em 0.8em 7em;}

  .cart-row .info                               {padding-right: 2.5em;}  

  .cart-row .img                                {width: 6em; height: 4.6em; aspect-ratio: unset; position: absolute; left: 0; top: calc(50% - 2.3em);}

  .cart-row .action                             {position: absolute; right: 1.8em; top: calc(50% - 0.8em);}

  }



.cart-items                                     {display: flex; width: 100%; flex-direction: column; gap: 0.6em;}





h2:has(+ .cart-items)                           {font-size: min(calc(1.2em + 4vw), 1.8em); margin-top: var(--gap1);}



.cart-row.not-sel                               {background: var(--white-10);}

.cart-row.not-sel .info span                    {color: white;}

.cart-row.not-sel .info .note                   {color: var(--white-70);}

.cart-row.not-sel .price                        {color: white;}








