.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%;}

#in_message {
    position: absolute;
    left: -9999em;
    top: 0;
}

.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; }



:root                                           {

                                                --font1:            "barlow-condensed", sans-serif; /* 500, 700, 800 */

                                                --font2:            "span-condensed", serif; /* 600 */



                                                --color0:           #1F1B19; 

                                                --color0b:          #423b38;

                                                --color0b-85:       rgba(49,44,42,0.85);

                                                --color0b-08:       rgba(49,44,42,0.08);

                                                --color0c:          #C9AEA0;  

                                                --color0d:          #F7F1ED;

                                                --color1:           #B5000D; 

                                                --color1b:          #d80c1a; 

                                                --color-white-20:   rgba(255,255,255,0.2);

                                                --color-white-30:   rgba(255,255,255,0.3);



                                                --header:             7rem;

                                                --spacing1:           0.15em;

                                                --button-size:        2.8em;

                                                --gap1:               1rem;

                                                --gap2:               min(2.5rem, calc(1rem + 5vw));

                                                --font2-line:         1.1;

                                                --border-radius1:     1rem;

                                                --text-shadow1:       0 0.1em 0.3em rgba(0,0,0,0.7);

                                                --blur1:              blur(7px);





                                                --wrapper-padding:      7vw;

                                                --section-padding:      min(5rem, calc(1.3rem + 6vw));



                                                --padding-inline:       1.6rem;



                                                }

  

html                                            {display: block; width: 100%; height: 100%; background: white; text-align: center; font-size: min(18px, calc(11px + 1vw)); color: var(--color0); font-weight: 500; line-height: 1.5; font-family: var(--font1);}

  @media screen and (min-width: 2001px)         {

  html                                          {font-size: calc(6px + 0.6vw);}

  }



body                                            {display: block; width: 100%; height: 100%; margin-inline: auto; position: relative; overflow-x: hidden; overflow-y: auto;}

body.fixed                                      {height: 100%; overflow: hidden;}



.background                                     {display: block; position: fixed; inset: 0; background: url("/themes/default/images/background.webp") no-repeat center top; 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 40%, black 60%, transparent);                                           

                                                 -webkit-mask-image: linear-gradient(to right, transparent, black 40%, black 60%, transparent);

                                                }



form                                            {display: flex; width: 100%; min-height: 100%; flex-direction: column; overflow-x: hidden;}





.wrapper                                        {display: flex; width: calc(100% - 2 * var(--wrapper-padding)); max-width: 48rem; flex-direction: column; align-items: center; justify-content: center; flex-wrap: wrap; gap: var(--gap2); margin-inline: auto; position: relative; box-sizing: border-box; z-index: 10;}

.wrapper.wide                                   {max-width: 62rem;}

.wrapper.medium                                 {max-width: 52rem;}

.wrapper.narrow                                 {max-width: 46rem;}

.wrapper.thin                                   {max-width: 38rem;}



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: .25s ease-in-out;}



.hp .header                                     {position: absolute; background: none;}



.header                                         {display: flex; width: 100%; height: var(--header); background: var(--color0); box-sizing: border-box; position: relative; z-index: 1000;}

.header .wrapper                                {height: 100%; flex-direction: row; justify-content: space-between; align-items: center;}

.header .logo                                   {display: flex; height: 100%; justify-content: center; align-items: center; position: absolute; top: 0; z-index: 2;}

.header .logo img                               {display: block; width: 100%; height: auto;} 

.header .collapse                               {display: block; width: 100%;}

.header .collapse .inner                        {display: flex; width: 100%; box-sizing: border-box;}

.header nav                                     {display: flex; flex-wrap: wrap; box-sizing: border-box;}

.header nav ul                                  {display: flex; align-content: center; flex-wrap: wrap;}

.header nav ul li                               {display: block;}

.header nav ul li a                             {display: flex; height: var(--header-item); align-items: center; color: white; font-weight: 500; line-height: 1.25; letter-spacing: var(--spacing1); text-transform: uppercase; padding-top: 0.05em; box-sizing: border-box; position: relative; transition: .25s ease-in-out;}

.header .buttons                                {display: flex; gap: 0.3em;}

.header .buttons .button.soc                    {width: var(--button-size); padding-inline: 0;}

.header .lang                                   {position: relative;}

.header .lang ul                                {display: flex; align-items: center; gap: 0.3em; overflow: hidden;}

.header .lang ul li                             {display: block; box-sizing: border-box;}

.header .lang ul li a                           {width: var(--button-size); aspect-ratio: 1; background: transparent; padding-inline: 0;}

.header .lang ul li a:hover                     {background: var(--color-white-30);}

.header .lang ul li.sel                         {order: -1;}

  @media screen and (min-width: 1081px)         {

  .header .wrapper                              {container-type: inline-size; --header-item: 3.2cqw;}

  .header .logo                                 {width: 8cqw; left: calc(50% - 4cqw);}

  .header .collapse                             {width: 100%;}

  .header .collapse .inner                      {justify-content: space-between; align-items: center;}

  .header nav                                   {flex-grow: 2;}

  .header nav ul                                {gap: 0.4cqw;}

  .header nav ul li:nth-child(4)                {margin-right: 15.6cqw;}

  .header nav ul li a                           {font-size: 1.1cqw; padding-inline: 1.2em; border: solid 0.11em transparent; border-radius: calc(0.5 * var(--header-item));}

  .header nav ul li a:hover,            

  .header nav ul li a[aria-current="page"]      {border-color: white;}

  .header .buttons .button                      {font-size: 1.1cqw;}

  .header .lang                                 {display: block; height: var(--button-size); font-size: 1.1cqw; overflow: hidden; margin-inline: 1.2cqw 0.6cqw; position: relative; transition: .25s ease-in-out;}

  .header .lang .trigger                        {display: block; width: 100%; aspect-ratio: 1; border-radius: 100%; position: absolute; left: 0; top: 0; z-index: 3; cursor: pointer; transition: .25s ease-in-out;}

  .header .lang .trigger:not(.hover):hover      {background: var(--color-white-30);}   

  .header .lang ul                              {flex-direction: column; overflow: hidden; padding: 0.45em; margin: -0.45em; border-radius: calc(0.7 * var(--button-size));}

  .header .lang ul li                           {cursor: pointer;}

  .header .lang ul li a                         {font-size: 1.1cqw;}

  .header .lang:has(.trigger.hover)             {overflow: visible;}

  .header .lang:has(.trigger.hover) ul          {height: auto; background: var(--color0b-85); box-shadow: 0 0 0.5em rgba(0,0,0,0.25);}

  .header :is(.buttons, .lang)                  {position: relative; top: -0.02em;}

  .header :is(.home, #navicon)                  {display: none;}                 

  }

  @media screen and (max-width: 1080px)         {

  body                                          {--header: 6rem;}

  .header .home                                 {display: block; width: 1.3em; height: 1.3em;}

  .header .home svg                             {display: block; width: 100%; height: 100%; fill: white; transition: .25s ease-in-out;}

  .header .home:hover svg                       {fill: white;}

  .header .logo                                 {width: 5em; left: calc(50% - 2.5em);}

  .header .collapse                             {width: calc(16rem + 15vw); height: 100%; background: var(--color0b-85); backdrop-filter: blur(5px); overflow-y: auto; position: fixed; right: -19rem; top: 0; z-index: 5; box-sizing: border-box; opacity: 0; transition: .5s ease-in-out;}                                              

  .header .collapse .inner                      {min-height: 100%; flex-direction: column; align-content: flex-start; gap: 2em; padding: calc(0.4 * var(--header));}

  .header .lang                                 {display: flex; order: -1; font-size: 0.7em; top: -0.25rem;}

  .header .lang .trigger                        {display: none;}

  .header .lang ul                              {width: 100%; align-items: center;}

  .header .lang ul li.sel a                     {background: var(--color-white-30);}

  .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: 1em; padding: 0.65em 0;}              

  .header nav ul li a[aria-current="page"]      {padding-left: 1.4em;}

  .header nav ul li a[aria-current="page"]:after{display: block; width: 0.9em; height: 0.1em; background: white; position: absolute; left: 0; top: 1.2em; content: "";}

  .header .buttons                              {align-items: flex-end; flex-grow: 2; font-size: 0.85em;}

  .header .buttons *:first-child                {flex-grow: 2;}

  .header .navicon                              {display: block; width: 1.5em; height: 1em; cursor: pointer; position: relative; z-index: 10;}

  .header .navicon span                         {display: block; width: 100%; height: 0.14em; background: white; border-radius: 2px; position: absolute; left: 0; transition: .25s 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.07em);}

  .header .navicon span:nth-child(4)            {bottom: 0;}

  .header .navicon:hover span                   {background: white;}

  .header #navicon div                          {display: none; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2;}

  .header.show:before                           {opacity: 0.85 !important;}

  .header.show #navicon:after                   {color: white;}

  .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                        {right: 0; opacity: 1;}

  }



.hp .footer                                     {padding-top: 0;}



.footer                                         {display: block; width: 100%; background: var(--color0d); padding-block: calc(0.7 * var(--section-padding)) calc(0.4 * var(--section-padding));}

.footer .buttons                                {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.5em; font-size: 0.9em;}

.footer-contacts                                {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.2em 0.5em; font-size: 0.9em;}

.footer-contacts li                             {display: flex; align-items: center; position: relative;}

.footer-contacts li:not(:last-child):after      {display: inline-block; position: relative;}

.footer .soc a:not(:hover)                      {background: white;}

.footer .links                                  {display: flex; justify-content: center; flex-wrap: wrap; gap: 0.4em 0.8em;}

.footer .links > *                              {font-size: 0.7em; color: var(--color0); font-weight: 500; line-height: 1.25;}

.footer .links a                                {color: inherit; text-decoration: underline; transition: .25s ease-in-out;}

.footer .links a:hover                          {color: var(--color0b); text-decoration-color: transparent;}

  @media screen and (min-width: 769px)          {

  .footer-contacts li                           {gap: 0.53em;}

  .footer-contacts li:not(:last-child):after    {width: 0.08em; height: 1em; background: var(--color1); top: -0.06em; content: "";}

  }

  @media screen and (max-width: 768px)          {

  .footer-contacts li:not(:last-child):after    {content: ",";}

  }



.main                                           {display: flex; width: 100%; flex-direction: column; align-items: center; flex-grow: 3;}

.main > div                                     {display: block; width: 100%;}



.section                                        {display: block; width: 100%; position: relative; z-index: 1; padding-top: var(--section-padding); isolation: isolate;}

.section.padding-top-0                          {padding-top: 0;}

.section.padding-bottom                         {padding-bottom: var(--section-padding);}



.section-logo                                   {display: flex; width: calc(1.4 * var(--section-padding)); aspect-ratio: 1; justify-content: center; align-items: center; background-image: linear-gradient(to top, var(--color1), var(--color1b)); border-radius: 100%; border: solid 0.3em white; padding-bottom: calc(0.13 * var(--section-padding)); box-sizing: border-box; position: absolute; left: calc(50% - 0.7 * var(--section-padding)); top: calc(-0.7 * var(--section-padding)); z-index: 3;}

.section-logo img                               {display: block; width: 65%;}



.container                                      {display: flex; width: 100%; max-width: 40rem; flex-direction: column; align-items: center; gap: var(--gap1);}



.icon1                                          {display: flex; width: 3.4em; height: 3.4em; justify-content: center; align-items: center; background: var(--color0d); border-radius: 100%;}

.icon1 img                                      {display: block; width: 35%;}



h1, h2, h3                                      {display: block; width: 100%; text-align: center;; font-weight: 800; box-sizing: border-box; font-family: var(--font2); line-height: var(--font2-line);}

h1                                              {font-size: min(4rem, calc(1.5rem + 5vw)); margin-bottom: 0.1em;}

h2                                              {font-size: min(3.4rem, calc(1rem + 5vw));}

h3                                              {font-size: min(2.4rem, calc(0.9rem + 3vw));}



.subheadline                                    {color: var(--color1); font-weight: 700; letter-spacing: var(--spacing1); text-transform: uppercase; margin-top: -0.15em;}



.button                                         {display: flex; height: var(--button-size); justify-content: center; align-items: center; gap: 0.4em; font-size: min(0.8em, calc(0.6em + 1vw)); color: white; font-weight: 500; line-height: 1.1; letter-spacing: var(--spacing1); text-transform: uppercase; border: none; outline: solid 2px transparent; padding: 0.05em 1.45em 0; border-radius: calc(0.5 * var(--button-size)); cursor: pointer; text-decoration: none !important; box-sizing: border-box; font-family: var(--font1); transition: .25s ease-in-out;}

.button img                                     {display: block; height: 1.15em; position: relative; top: -0.03em;}

.button.white-20                                {background: var(--color-white-20);}

.button.white-20:hover                          {background: var(--color-white-30);}

.button.color1                                  {background: var(--color1);}

.button.color1:hover                            {background: var(--color1b);}



.button.box-shadow                              {box-shadow: 0 0 1em rgba(0,0,0,0.5);}

.button.box-shadow:hover                        {box-shadow: 0 0 1em transparent;}



.soc                                            {display: flex; flex-wrap: wrap; gap: 0.5em;}

.soc .button                                    {font-size: 0.9em; width: var(--button-size); padding-inline: 0; box-shadow: 0 0 0.4em rgba(0,0,0,0.2);}

.soc .button:hover                              {background: var(--color0b-08); box-shadow: 0 0 0 rgba(0,0,0,0);}



.link                                           {display: block; font-size: 1em; color: var(--color1); text-decoration: underline; transition: .25s ease-in-out;}

.link:hover                                     {color: Var(--color1b); text-decoration-color: transparent;}



*:has(.gradient)                                {position: relative; z-index: 1;}



.gradient                                       {display: block; --gradient-width: min(100rem, 200vw); width: var(--gradient-width); height: 100%; position: absolute; left: calc(50% - 0.5 * var(--gradient-width)); top: 0; z-index: -1; overflow: hidden;}

.gradient:before                                {display: block; width: 100%; aspect-ratio: 1; background-image: radial-gradient(var(--gradient-color), transparent 50%); position: absolute; left: 0; top: 0; content: ""; transform: translateY(-50%);}

.gradient.color0d                               {--gradient-color: var(--color0d);}



.main :is(p, li)                                {width: 100%;}

.main :is(p a, li a)                            {color: var(--color1); text-decoration: underline; transition: .25s ease-in-out;}

.main :is(p a, li a):hover                      {color: var(--color1b); text-decoration-color: transparent;}



em                                              {font-style: italic;}

strong                                          {font-weight: 800;}



.submenu                                        {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.3em;}

.submenu > div                                  {display: flex; max-width: 100%; overflow-y: auto; padding-inline: 1em; box-sizing: border-box; scrollbar-width: none; -ms-overflow-style: none;}

.submenu > div::-webkit-scrollbar               {display: none; width: 0;}

.submenu > div nav                              {display: flex; gap: 0.3em;}

.submenu a                                      {display: flex; height: 2.4em; align-items: center; font-size: 0.85em; color: var(--color0b); background: var(--color0d); letter-spacing: var(--spacing1); padding: 0.15em 1em 0 1.1em; border-radius: 1.2em; border: solid 0.14em transparent; box-sizing: border-box; white-space: nowrap; transition: .25s ease-in-out;}

.submenu a:hover                                {background: transparent; border-color: var(--color0c);}

.submenu a.sel                                  {color: white; background: var(--color0c); border-color: var(--color0c);}

.submenu:has(> div)                             {width: 100vw; margin-inline: calc(50% - 50vw);}



.pagination                                     {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.3em;}

.pagination a                                   {display: flex; width: 2.4em; height: 2.4em; justify-content: center; align-items: center; font-size: 0.85em; color: var(--color0b); background: var(--color0d); letter-spacing: var(--spacing1); padding: 0.15em 0 0 0.1em; border-radius: 1.2em; border: solid 0.14em transparent; box-sizing: border-box; white-space: nowrap; transition: .25s ease-in-out;}

.pagination a:hover                             {background: transparent; border-color: var(--color0c);}

.pagination a.sel                               {color: white; background: var(--color0c); border-color: var(--color0c);}



.anim                                           {transition-delay: 2s; opacity: 0; transform: scale(0.9,0.9); transition: .6s ease-in-out;}

.anim.play                                      {opacity: 1; transform: scale(1,1);}



.flex                                           {display: flex !important; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.3em; box-sizing: border-box;}



.section:has(.arc)                              {background-image: linear-gradient(to bottom, var(--color0) var(--section-padding), transparent var(--arc-gradient-end)); --arc-gradient-end: 100%; z-index: 0;}

.section:has(.arc) h2                           {color: white; text-shadow: var(--text-shadow1);}



.arc                                            {display: flex; width: 100%; height: 100%; justify-content: center; position: absolute; inset: 0;}

.arc div                                        {display: block; width: 100vw; margin-inline: calc(50% - 50vw); position: relative; isolation: isolate;}

.arc div:after                                  {display: block; width: 100%; height: 50%; background-image: linear-gradient(to bottom, var(--color0), var(--color0) 10%, transparent); position: absolute; left: 0; top: 0; z-index: 1; content: "";}

.arc div img                                    {display: block; width: 100%; height: 100%; object-fit: cover; object-position: center bottom; position: relative; z-index: -1;}

  @media screen and (max-width: 1080px)         {

  .section:has(.arc)                            {--arc-gradient-end: 40rem}

  .arc                                          {max-height: var(--arc-gradient-end);}

  }



.hero                                           {background: var(--color0); isolation: isolate; overflow: hidden;}

.hero .images                                   {display: block; width: 100%; height: 60%; position: absolute; left: 0; top: 0; z-index: -1; opacity: 0.5;}

.hero .images:after                             {display: block; background-image: linear-gradient(to bottom, var(--color0), transparent 10rem, transparent 50%, var(--color0)); position: absolute; inset: 0; z-index: 1; content: "";}

.hero .images span                              {display: block; width: 100%; height: 100%; position: absolute; inset: 0; opacity: 0; transform-origin: center bottom; animation-name: image; animation-duration: 15s; animation-iteration-count: infinite;}

.hero .images span:nth-child(2)                 {animation-delay: 5s;}

.hero .images span:nth-child(3)                 {animation-delay: 10s;}

.hero .images span img                          {display: block; width: 100%; height: 100%; object-fit: cover;}

.hero .container                                {padding-block: clamp(10em, calc(5em + 12vw), 20em) 4em;}

.hero :is(h1, p)                                {color: white; text-shadow: var(--text-shadow1);}

.hero .flex                                     {margin-top: 0.8em;}

.hero .arc1                                     {height: auto; position: relative; inset: auto;}

.hero .arc1 div:after                           {display: none;}

  @media screen and (max-width: 1200px)         {

  .hero .arc1 div                               {width: calc(30rem + 60vw); margin-inline: calc(50% - 15rem - 30vw);}

  }

  @media screen and (max-width: 960px)          {

  .hero .container                              {padding-top: 14em;}

  }



@keyframes image                                {

                                                0%      {opacity: 0; transform: scale(1);}

                                                5%     {opacity: 1;}

                                                33%     {opacity: 1;}

                                                44%     {opacity: 0; transform: scale(1.15);}

                                                100%    {opacity: 0; transform: scale(1,1);}



}



.hero + .section                                {margin-top: calc(-3.4 * var(--section-padding));}

  @media screen and (min-width: 1201px) and (max-width: 1700px){

  .hero + .section                              {margin-top: calc(-2.6 * var(--section-padding));}

  }

  @media screen and (max-width: 1200px)         {

  .hero + .section                              {margin-top: calc(-1.7 * var(--section-padding));}

  }



.swiper-button                                  {display: flex; width: var(--button-size); height: var(--button-size); justify-content: center; align-items: center; font-size: 1em; margin: 0; padding: 0; border: none; border-radius: 100%; box-sizing: border-box; cursor: pointer; transition: .25s ease-in-out;}                                

.swiper-button-prev                             {transform: rotate(-180deg);}

.swiper-button img                              {display: block; width: 32%;}

.swiper-button:before,

.swiper-button:after                            {display: none;}

.swiper-button-disabled                         {opacity: 0.15 !important; filter: saturate(0);}



.carousel                                       {display: flex; width: 100%; flex-direction: column; align-items: center; position: relative;}

.carousel .swiper                               {width: 100%;}

.carousel .swiper-slide                         {display: flex; height: auto; position: relative; overflow: hidden; flex-shrink: 0; transition: .5s ease-in-out;}

.carousel .swiper-slide > *                     {width: 100%;}

.carousel:has(.bottom-controls)                 {margin-bottom: 3.5rem;}

.carousel .controls                             {padding: 0.5rem 1rem 0; margin-block: -1px;}

.carousel .controls .button                     {font-size: min(0.8em, calc(0.2em + 2vw));}

.carousel .controls .swiper-button              {width: var(--button-size); height: var(--button-size); position: relative; inset: auto;}



.section:has(.arc-carousel)                     {padding-bottom: 0;}



.arc-carousel                                   {width: 100vw; margin-inline: calc(50% - 50vw);}

.arc-carousel .controls                         {background: var(--color0);}



.arc-preview                                    {display: block; width: 100%; padding-top: calc(100% * 16 / 9); position: relative;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% auto; mask-size: 100% auto;

                                                 mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");                                           

                                                 -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");

                                                }

.arc-preview .aspect-ratio                      {display: block; width: 100%; height: 100%; position: absolute; inset: 0;}

.arc-preview .aspect-ratio > img                {display: block; width: 100%; height: 100%; object-fit: cover; position: relative; transition: .25s ease-in-out;}

.arc-preview:after                              {display: block; position: absolute; inset: 0; z-index: 1; content: ""; background-image: linear-gradient(to top, var(--color0), var(--color0) 3%, transparent 80%);}

.arc-preview .inner                             {display: flex; width: 100%; height: 100%; flex-direction: column; align-items: center; justify-content: flex-end; gap: var(--gap1); padding: 1.5em 1.5em 3.5em; box-sizing: border-box; position: absolute; inset: 0; z-index: 2; container-type: inline-size;}

.arc-preview .inner .icon                       {display: flex; width: 3.3em; height: 3.3em; justify-content: center; align-items: center; background: rgba(0,0,0,0.5); border-radius: 100%; box-sizing: border-box;}

.arc-preview .inner .icon img                   {display: block; width: 40%;}

.arc-preview .inner .title                      {max-width: 10em; font-size: min(1.5em, 12cqw); font-weight: 600; color: white; font-family: var(--font2); line-height: var(--font2-line);}

.arc-preview > a                                {display: block; position: absolute; inset: 0; z-index: 3;}

.arc-preview:has(> a):hover > img               {filter: brightness(1.2);}



.section:has(.features)                         {background-image: linear-gradient(to top, var(--color0), transparent 30rem);}

.section:has(.features) .arc-carousel .controls {padding-bottom: var(--section-padding);}



.preview                                        {display: flex; width: 100%; flex-direction: column; flex-wrap: wrap; background: var(--color0d); container-type: inline-size; border-radius: var(--border-radius1); overflow: hidden; transition: .25s ease-in-out;}

.preview .img                                   {width: 100%; aspect-ratio: 16/9; position: relative; flex-shrink: 0;}

.preview .img span                              {display: block; width: 100%; height: 100%; transition: .25s ease-in-out;}

.preview .img span img                          {display: block; width: 100%; height: 100%; object-fit: cover;}

.preview .img:hover span                        {filter: brightness(1.1);}

.preview > div                                  {display: flex; width: 100%; align-items: flex-start; align-content: flex-start; flex-grow: 2; flex-wrap: wrap; gap: 0.6em; --preview-inner-padding: 1.8em; padding: var(--preview-inner-padding); box-sizing: border-box; position: relative;}

.preview > div .title                           {text-align: left; font-size: 1.5em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin: -0.15em 0 0 !important;}

.preview > div .title a                         {color: inherit; text-decoration-color: transparent; transition: .25s ease-in-out;}

.preview > div .title a:hover                   {text-decoration-color: var(--color0b); color: var(--color0b);}

.preview > div .descr                           {font-size: 0.85em; font-weight: 500;}

.preview > div .date                            {display: block; font-size: 0.75em;}



.previews                                       {display: flex; width: 100%; justify-content: space-between; flex-wrap: wrap; gap: 1.2em; box-sizing: border-box;}

  @media screen and (min-width: 769px)          {

  .previews > *                                 {width: calc(50% - 0.6em);}

  } 



.hp .preview                                    {background: var(--color0b-85);}

.hp .preview .title                             {color: white;}

.hp .preview .title a:hover                     {color: var(--color0d); text-decoration-color: var(--color0d);}

.hp .preview .date                              {color: var(--color0c);}

  @media screen and (max-width: 1080px)         {

  .hp .section:has(.previews)                   {padding-bottom: 0;}

  }



body:not(.hp) .trips                            {padding-top: var(--section-padding);}



.trips                                          {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap2) 6%;}

.trips .trip                                    {display: flex; width: 100%; max-width: 20rem; flex-direction: column; align-items: center; gap: var(--gap1);}

.trips .trip .img                               {display: flex; width: min(7em, calc(4em + 5vw)); aspect-ratio: 1; justify-content: center; align-items: center; background-color: white; border-radius: 100%; overflow: hidden; box-shadow: 0 0 1em rgba(0,0,0,0.2);}

.trips .trip .img:not(:has(img))                {background-image: url("/themes/default/images/icons/marker-color0.svg"); background-repeat: no-repeat; background-position: center center; background-size: 40% auto;}

.trips .trip .img img                           {display: block; width: 100%; height: 100%; object-fit: cover;}

.trips .trip .img.icon img                      {width: 40%; height: auto;}

.trips .trip .title                             {font-size: 1.6em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin-block: 0.25em -0.15em;}

.trips .trip p                                  {font-size: 0.85em;}

.trips .trip .label                             {display: flex; min-height: 2.2em; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.35em; font-size: 0.7em; font-weight: 700; padding: 0.05em 1em 0; border: solid 0.14em var(--color1); border-radius: 1.1em; box-sizing: border-box;}

.trips .trip .label span                        {display: flex; align-items: center; position: relative;}

.trips .trip .label span:not(:last-child):after {display: block; width: 0.1em; height: 0.8em; background: var(--color1); margin-left: 0.35em; content: "";}

.trips .trip .link                              {font-size: 0.75em; font-weight: 700;}

  @media screen and (min-width: 1081px)         {

  .trips .trip                                  {width: 28%;}

  }

  @media screen and (min-width: 581px) and (max-width: 1080px){

  .trips .trip                                  {width: 47%;}

  }



.reviews                                        {display: flex; width: 100%; justify-content: space-between; flex-wrap: wrap; gap: var(--gap1) 0;}

.reviews .review                                {display: flex; width: 100%; flex-direction: column; gap: 1.5em; background: var(--color0b-85); backdrop-filter: var(--blur1); padding: min(2.2em, calc(1em + 5vw)); border-radius: var(--border-radius1); box-sizing: border-box;}

.reviews .review-head                           {display: flex; width: 100%; align-items: center; gap: var(--gap1);}

.reviews .review-head .img                      {display: block; width: 2.6em; aspect-ratio: 1; border-radius: 100%; flex-shrink: 0; overflow: hidden; background: url("/themes/default/images/icons/user-color0.svg") no-repeat center center, white; background-size: 50% auto;}

.reviews .review-head .img img                  {display: block; width: 100%; height: 100%; object-fit: cover;}

.reviews .review-head > div                     {display: block; flex-grow: 2;}

.reviews .review-head > div p                   {text-align: left; font-size: 1.1em; color: white; font-weight: 500; margin-block: -0.1em 0.15em;}

.reviews .review-head > div img                 {display: block; width: 3em;}

.reviews .review > p                            {text-align: left; font-size: 0.85em; color: white;}

.reviews .review .date                          {display: flex; justify-content: flex-end; align-items: flex-end; flex-grow: 2; text-align: right; font-size: 0.75em; color: var(--color0c);}

  @media screen and (min-width: 1081px)         {

  .section:has(.reviews) .arc                   {height: calc(100% + 6em);}

  .reviews .review                              {width: 32%; min-height: 30rem;}

  }



.section:has(.map)                              {padding-top: 0;}



.map                                            {display: flex; width: 100%; max-width: 120rem; justify-content: center; position: relative; margin-inline: auto;}

.map:before, .map:after                         {display: block; width: 30%; height: 100%; background-image: linear-gradient(to right, white, transparent); position: absolute; left: -1px; top: 0; z-index: 2; content: "";}

.map:after                                      {left: auto; right: -1px; transform: rotate(180deg);}

.map a                                          {display: block; width: 100%;}

.map a:before, .map a:after                     {display: block; width: 100vw; height: 30%; background-image: linear-gradient(to bottom, white, transparent); position: absolute; left: calc(50% - 50vw); top: 0; z-index: 3; content: "";}

.map a:after                                    {background-image: linear-gradient(to top, var(--color0d), transparent); top: auto; bottom: 0;;}

.map a img:nth-child(1)                         {display: block; width: 100%;}

.map a img:nth-child(2)                         {display: block; width: 3em; position: absolute; bottom: 50%; left: calc(50% - 1.5em);}

  @media screen and (max-width: 960px)          {

  .map                                          {width: 1000px; margin-inline: calc(50% - 500px);}

  }



.about                                          {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap2) 8%; margin-top: var(--gap2);}

.about > div                                    {display: flex; width: 100%; max-width: 30rem; flex-direction: column; align-items: center; gap: var(--gap1);}

.about > div .img                               {display: block; width: 90%; aspect-ratio: 1; border-radius: var(--border-radius1); overflow: hidden;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% auto; mask-size: 100% auto;

                                                 mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");                                           

                                                 -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");

                                                }

.about > div .img img                           {display: block; width: 100%; height: 100%; object-fit: cover;}

.about > div p                                  {margin-top: 0.3em;}

  @media screen and (min-width: 769px)          {

  .about > div                                  {width: 46%;}

  .about > div p                                {font-size: 0.9em;}

  }



section:has(.arc2) .infographics                {margin-bottom: calc(2 * var(--section-padding));}

section:has(.infographics) .arc2                {min-height: 100%; height: auto; max-height: none;}

section:has(.infographics) .arc2 div:after      {height: 80%;}



.infographics                                   {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap2) 6%;}

.infographics > div                             {display: flex; width: 47%; max-width: 20rem; flex-direction: column; align-items: center; gap: var(--gap1);}

.infographics > div .img                        {display: flex; width: min(7em, calc(4em + 5vw)); aspect-ratio: 1; justify-content: center; align-items: center; background-color: var(--color-white-20); border-radius: 100%; overflow: hidden; box-shadow: 0 0 1em rgba(0,0,0,0.6);}

.infographics > div .img img                    {display: block; width: 2.2em; object-fit: cover;}

.infographics > div *                           {color: white; text-shadow: var(--text-shadow1);}

.infographics > div .title                      {font-size: 1.6em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin-block: 0.25em -0.15em;}

.infographics > div p                           {font-size: 0.85em;}

  @media screen and (min-width: 1081px)         {

  section:has(.arc2) .infographics              {margin-bottom: calc(3 * var(--section-padding));}

  .infographics > div                           {width: 28%;}

  }

  @media screen and (max-width: 640px)          {

  .infographics > div                           {font-size: 0.85em;}

  }



.article-styles :is(ul, ol)                     {display: flex; flex-wrap: wrap; gap: 0.2em; padding: 0 0 0 0.7em; margin: -0.15em 0 0;}

.article-styles :is(ul li, ol li)               {text-align: left; padding-left: 1.6em; position: relative; box-sizing: border-box;}

.article-styles li:before                       {display: block; position: absolute; content: "";}

.article-styles ul li:before                    {width: 0.26em; height: 0.26em; top: 0.48em; left: 0.1em; background: none; border: solid 0.1em var(--color0); border-radius: 100%;}

.article-styles ol                              {list-style-type: none; counter-reset: li;}

.article-styles ol li                           {counter-increment: li;}

.article-styles ol li:before                    {top: 0; left: -0.05em; content: counter(li)".";}



.article                                        {display: flex; width: 100%; align-items: flex-start; align-content: flex-start; flex-wrap: wrap; gap: var(--gap1);}

.article *                                      {text-align: left;}

.article h1                                     {font-size: min(2.6rem, calc(1.2rem + 5vw)); margin-top: 0 !important; text-wrap: unset;}

.article .article-info                          {display: flex; width: 100%; font-size: 0.8em; position: relative; top: -0.4em;}

.article .article-info > span                   {display: flex; align-items: center;}

.article .article-info > span a                 {color: var(--color1); text-decoration: underline; transition: .25s ease-in-out;}

.article .article-info > span a:hover           {color: var(--color1b); text-decoration-color: transparent;}         

.article .article-info > span:nth-child(2)::before

                                                {display: block; width: 0.07em; height: 0.95em; background: var(--color0); opacity: 0.35; margin-inline: 0.55em; position: relative; top: -0.08em; content: "";}

.article :is(h2, h3)                            {margin-block: 0.4em -0.2rem; color: var(--color1);}

.article h2                                     {font-size: 1.85em;}

.article h3                                     {font-size: 1.45em;}

.article .image                                 {display: block; width: 100%; aspect-ratio: 16/9; border-radius: var(--border-radius1); overflow: hidden; transition: .25s ease-in-out;} 

.article .image span                            {display: block; width: 100%; height: 100%; transition: .25s ease-in-out;}

.article .image span img                        {display: block; width: 100%; height: 100%; object-fit: cover;}

.article .image:hover                           {opacity: 0.8;}

.article .highlight1                            {display: flex; width: calc(100% - 1em); flex-wrap: wrap; gap: 0.9rem; font-size: 0.9em; padding-left: 1.4em; margin-left: 1em; border-left: solid 0.13em var(--color1); box-sizing: border-box; margin-block: 0.5em;}

.article .highlight1 > *:first-child            {margin-top: 0 !important;}

.article .highlight1 :is(h2, h3)                {color: var(--color0);}

.article .highlight1 .button                    {font-size: 0.7em; position: relative; left: -0.08em;}

.article .highlight2                            {display: flex; width: 100%; flex-wrap: wrap; gap: 0.9rem; font-size: 0.9em; background: var(--color0d); padding: 2.3em; border-radius: var(--border-radius1); box-sizing: border-box; margin-block: 0.5em;}

.article .highlight2 > *:first-child            {margin-top: 0 !important;}

.article .highlight2 :is(h2, h3)                {color: var(--color0);}

.article .highlight2 .button                    {font-size: 0.7em; position: relative; left: -0.08em;}

.article .embed                                 {display: block; width: 100%; border-radius: 1em; overflow: hidden;}

.article .embed iframe                          {display: block; width: 100%;}

  @media screen and (min-width: 541px)          {

  .article .preview                             {flex-direction: row;}

  .article .preview .img                        {width: 30%; aspect-ratio: 16/9;;}

  .article .preview > div                       {width: 70%; --preview-inner-padding: 1.5em;}

  .article .preview > div .title                {font-size: 1.35em; margin: -0.1em 0 0 !important;}

  .article .preview > div .date                 {font-size: 0.65em;}

  }



.slider-gallery                                 {display: block; width: 100%; position: relative; --button-size: 2em;}                       

.slider-gallery .swiper-slide a                 {display: block; width: 100%; padding-top: 75%; position: relative; border-radius: var(--border-radius1); overflow: hidden; transition: .25s ease-in-out;}     

.slider-gallery .swiper-slide a span            {display: block; position: absolute; inset: 0;}

.slider-gallery .swiper-slide a span img        {display: block; width: 100%; height: 100%; object-fit: cover;}     

.slider-gallery .swiper-slide a[href]:hover     {opacity: 0.8;}

.slider-gallery .swiper-button                  {top: calc(50% - 0.5 * var(--button-size));}

.slider-gallery .swiper-button-prev             {left: calc(-0.5 * var(--button-size));}

.slider-gallery .swiper-button-next             {right: calc(-0.5 * var(--button-size));}



.gallery-previews                               {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap2) 6%;}



.gallery-preview                                {display: flex; width: 100%; max-width: 26rem; flex-direction: column; align-items: center; gap: 0.7rem;}

.gallery-preview .img                           {display: block; width: 90%; aspect-ratio: 1; border-radius: var(--border-radius1); overflow: hidden;

                                                 -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center top; mask-position: center top; -webkit-mask-size: 100% auto; mask-size: 100% auto;

                                                 mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");                                           

                                                 -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 500 1000'%3E%3Cpath d='M500,1000V62.4c0-9.2-6.8-19.8-15.1-23.7C484.9,38.7,401.6,0,250,0S15.1,38.7,15.1,38.7C6.8,42.5,0,53.2,0,62.4v937.6h500Z' width='1' height='1' fill='white' stroke='none' stroke-width='0' stroke-linecap='round'/%3E%3C/svg%3E");

                                                }

.gallery-preview .img img                       {display: block; width: 100%; height: 100%; object-fit: cover;}

.gallery-preview .title                         {font-size: 1.65em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin: 0.3rem 0 -0.45rem !important;}

.gallery-preview .title a                       {color: inherit; text-decoration-color: transparent; transition: .25s ease-in-out;}

.gallery-preview .title a:hover                 {text-decoration-color: var(--color0b); color: var(--color0b);}

.gallery-preview p                              {margin-top: 0.3em;}

.gallery-preview .button                        {font-size: 0.6em; margin-top: 0.2rem;}

  @media screen and (min-width: 1081px)         {

  .gallery-previews > *                         {width: 29%;}

  }

  @media screen and (min-width: 641px) and (max-width: 1080px){

  .gallery-previews > *                         {width: 47%;}

  }

  @media screen and (min-width: 641px)          {

  .gallery-preview p                            {font-size: 0.9em;}

  }



.pricelist                                      {display: flex; width: 100%; flex-direction: column; gap: 0.3em;}

.pricelist .row                                 {display: flex; width: 100%; padding: 0.9rem 1rem 0.8rem; border-radius: 0.6em; box-sizing: border-box;}

.pricelist .row.head                            {font-size: 0.8em; font-weight: 700; padding-block: 0 0.3rem;}

.pricelist .row:not(.head)                      {background: var(--color0d);}

.pricelist .row span                            {display: block; flex-grow: 2; text-align: right; font-weight: 700; line-height: 1.3; white-space: nowrap;}

.pricelist .row span:first-child                {text-align: left;}

  @media screen and (max-width: 640px)          {

  .pricelist                                    {font-size: 0.85em;}

  }

  @media screen and (max-width: 440px)          {

  .pricelist                                    {width: 100vw; margin-inline: calc(50% - 50vw); font-size: 0.8em;}

  .pricelist .row                               {border-radius: 0;}

  }



.pricelist.discounts .row span:nth-child(1)     {width: max(6em, 22%); flex-grow: 0;}

.pricelist.discounts .row span:nth-child(2)     {width: max(5em, 22%); flex-grow: 0;}

.pricelist.discounts .row:not(.head) span:nth-child(3)     

                                                {font-weight: 500;}



.address                                        {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 0.4em;}

.address img                                    {display: block; width: 1em; position: relative; top: -0.09em;}

  @media screen and (max-width: 768px)          {

  .address                                      {max-width: 20em; flex-direction: column;}

  .address img                                  {width: 1.4em;}

  }



.contact-card                                   {display: flex; justify-content: center; align-items: center; gap: 1.4em; background: var(--color0d); border-radius: var(--border-radius1); padding: 2.2em; box-sizing: border-box;}

.contact-card .img                              {display: block; width: 6em; aspect-ratio: 1; border-radius: 100%; overflow: hidden; flex-shrink: 0;}

.contact-card .img img                          {display: block; width: 100%; height: 100%; object-fit: cover;}

.contact-card .info1                            {display: flex; flex-direction: column; align-items: center; flex-wrap: wrap; flex-grow: 2;}

.contact-card .info1 .name                      {font-size: 1.75em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin-block: 0.1em 0.2em;}

.contact-card .info1 a                          {display: flex; align-items: center; gap: 0.4em; color: var(--color0); text-decoration: underline; text-decoration-color: transparent; transition: .25s ease-in-out;}

.contact-card .info1 a img                      {display: block; width: 1em; position: relative; top: -0.03em;}

.contact-card .info1 a:hover                    {text-decoration-color: var(--color0);}

.contact-card .info2                            {display: flex; flex-direction: column; align-items: flex-start; flex-wrap: wrap; flex-shrink: 0; box-sizing: border-box; position: relative; top: 0.14em;}

.contact-card .info2 p                          {font-size: 0.85em;}

  @media screen and (min-width: 769px)          {

  .contact-card .info1 .name,

  .contact-card .info2 p                        {text-align: left;}

  .contact-card .info1                          {align-items: flex-start;}

  .contact-card .info2                          {padding-left: 2.5em; margin-left: 2em; border-left: solid 1px var(--color0c);}

  }

  @media screen and (max-width: 768px)          {

  .contact-card                                 {flex-direction: column;}

  }



.booking-opts                                   {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: var(--gap1) 2%;}

.booking-opts > div                             {display: flex; width: 100%; max-width: 30em; flex-direction: column; justify-content: flex-start; align-items: center; gap: var(--gap1); border-radius: var(--border-radius1); padding: 2.4em; border: solid 0.2em transparent; box-sizing: border-box;}

.booking-opts > div .icon                       {display: flex; width: 4em; aspect-ratio: 1; justify-content: center; align-items: center; border-radius: 100%; overflow: hidden;}

.booking-opts > div .icon img                   {display: block;}

.booking-opts > div .title                      {font-size: 1.75em; font-weight: 600; font-family: var(--font2); line-height: var(--font2-line); margin-block: 0.1em -0.1em;}

.booking-opts > div .button                     {font-size: 0.7em;}

.booking-opts > div:nth-child(1)                {background: var(--color0d);}

.booking-opts > div:nth-child(1) .icon img      {width: 100%; height: 100%; object-fit: cover;}

.booking-opts > div:nth-child(2)                {border-color: var(--color0d);}

.booking-opts > div:nth-child(2) .icon          {background: var(--color0c);}

.booking-opts > div:nth-child(2) .icon img      {width: 50%;}

  @media screen and (min-width: 769px)          {

  .booking-opts > div                           {width: 49%;}

  }



.contact1                                       {display: flex; width: 100%; justify-content: center; align-items: center; flex-wrap: wrap;}

.contact1 span                                  {display: flex; width: 100%; justify-content: center; align-items: center; text-align: center; font-size: 1.15em;}

  @media screen and (min-width: 641px)          {

  .contact1 span                                {width: auto;}

  .contact1 span:last-child:before              {display: block; width: 0.1em; height: 0.8em; background: var(--color1); margin-inline: 0.6em; position: relative; top: 0.1em; content: "";}

  }

  @media screen and (max-width: 640px)          {

  .contact1 span:last-child                     {font-size: 1.4em; font-weight: 700;}

  }



.contact-form                                   {display: flex; width: 100%; flex-wrap: wrap; padding: min(5em, calc(1em + 5vw)); box-sizing: border-box; border-radius: var(--border-radius1); box-shadow: 0 0 1.5em rgba(0,0,0,0.2);}

.contact-form h2                                {margin-bottom: 0.5em;}

.contact-form .form-items                       {display: flex; width: 100%; flex-wrap: wrap; gap: 0.5em 0.4em;}

.contact-form .form-items > div                 {display: flex; width: 100%; flex-wrap: wrap; gap: 0.2em;}

.contact-form .form-items :is(input, textarea)  {display: block; width: 100%; color: var(--color0); font-size: 1em; font-weight: 700; background: var(--color0d); padding: 0.28em 1.2em 0; border: solid 0.1em var(--color0c); outline: none; border-radius: var(--border-radius); border-radius: 1.6em; font-family: var(--font1); box-sizing: border-box; transition: .25s ease-in-out;}

.contact-form .form-items input                 {height: 3em; padding-bottom: 0.2em;}

.contact-form .form-items textarea              {height: 10rem; padding-block: 1em;}

.contact-form :is(input, textarea)::placeholder {color: var(--color0c); font-weight: 500;}



.contact-form .form-items :is(input, textarea):focus        

                                                {background: transparent; border-color: var(--color0b);}

.contact-form .form-items label                 {display: block; width: 100%; font-size: 0.85em; font-variation-settings: "wght" 600; order: -1;}

.contact-form .send                             {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 0.8em 0; margin-top: 1rem;}

.contact-form .send span                        {display: block; width: 100%; text-align: center; font-size: 0.75em; line-height: 1.3; opacity: 0.6;} 

.contact-form .send span a                      {color: inherit; text-decoration: underline;}

.contact-form .send span a:hover                {opacity: 0.7; text-decoration-color: transparent;}

  @media screen and (min-width: 961px)          {

  .contact-form .form-items > div:not(:nth-child(4))  

                                                {width: calc(33.33% - 0.3em);}

  }



.wndw                                           {display: flex; width: 100%; height: 100%; flex-direction: row; justify-content: center; align-items: center; padding: 5em min(1rem, 5%) 4.5em; box-sizing: border-box; position: fixed; left: -99999px; top: 0; z-index: 100000;}

.wndw:before                                    {display: block; width: 100%; height: 100%; background: rgba(255,255,255,0.75); backdrop-filter: blur(12px); position: absolute; left: 0; top: 0; z-index: -1; content: ""; opacity: 0; transition: opacity .4s ease-in-out;}

.wndw > .outer                                  {display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1;}

.wndw > div                                     {width: 100%; max-width: 40em; max-height: calc(100vh - 4rem); background: var(--color0b-85); position: relative; border-radius: 1.2em; overflow: hidden; top: 5em; z-index: 2; overflow-y: auto; overflow-x: hidden; box-shadow: 0 0 0.75em rgba(0,0,0,0.4); transition: .4s ease-in-out;}

.wndw > div .overflow                           {overflow-y: auto; overflow-x: hidden; box-sizing: border-box;}

.wndw.show                                      {left: 0;}

.wndw.show:before                               {opacity: 1;}

.wndw.show > div                                {top: 0;}

.wndw.show.hide                                 {left: -99999px; transition-delay: 0.4s;}

.wndw.show.hide:before                          {opacity: 0;}

.wndw.show.hide > div                           {top: -5em; opacity: 0;}

.wndw .close                                    {display: block; width: 1.2em; height: 1.2em; font-size: 1em; cursor: pointer; position: absolute; right: 1rem; top: 1rem; z-index: 10002;}

.wndw .close span                               {display: block; width: 100%; height: 3px; background: var(--color0c); border-radius: 2px; position: absolute; left: 0; top: calc(50% - 1px); z-index: 1; transition: .2s ease-in-out;}

.wndw .close:hover span                         {background: white;}

.wndw .close span:nth-child(1)                  {transform: rotate(45deg);}

.wndw .close span:nth-child(2)                  {transform: rotate(-45deg);}

.wndw .wndw-content                             {display: flex; width: 100%; justify-content: center; flex-wrap: wrap; gap: 1.5em; font-size: 1rem; padding: max(2.5rem, 9%); box-sizing: border-box;}

.wndw .wndw-content *                           {color: white;}

.wndw .wndw-content .title                      {display: block; width: 100%; text-align: center; font-size: min(2em, calc(1.1em + 3vw)); font-weight: 600; line-height: 1.1; margin-block: 0 -0.25em; font-family: var(--font2);}

.wndw .wndw-content p                           {display: block; width: 100%; text-align: center; font-size: 0.85em;}

.wndw .wndw-content .flex                       {gap: 0.3em;}

.wndw .wndw-content .button                     {font-size: 0.65em;}