html { height: auto; margin: 0; background-color: #06122b;   }
#bg {  position: fixed; inset: 0; width: 100%; height: 100%; z-index: -999; pointer-events: none; filter: opacity(1.5) saturate(1.5); opacity: 0; transform: scale(1.03); transition: opacity 1.6s ease, transform 2.2s ease; }
body.bg-ready #bg { opacity: 1; transform: scale(1); }
.container { max-width: unset; }
body { font-family: "Roboto Condensed", sans-serif; height: auto; margin: 0; color: white; position: relative; font-size: 1rem; max-width: 100vw; overflow-x: hidden; }
a { transition-duration: .3s; }
::selection { background: #000dff; color: #FFFFFF; }
::-moz-selection { background: #000dff; color: #FFFFFF; }
::-webkit-selection { background: #000dff; color: #FFFFFF; }
::-webkit-scrollbar { width: 12px; }
::-webkit-scrollbar-track { background: #000; box-shadow: none; border-radius: 0px; }
::-webkit-scrollbar-thumb { background: #000dff; border-radius: 0px; }
* { margin: 0; padding: 0; outline: none !important; box-sizing: border-box; }
a { transition-duration: .3s; text-decoration: none; color:#1f66ff; }
.padding-1 { padding-left: clamp(20px, 5vw, 100px); padding-right: clamp(20px, 5vw, 100px); }
.padding-2 { padding-top: clamp(90px, 14vw, 300px); padding-bottom: clamp(90px, 14vw, 300px); }
:root {--nav-h:100px;--nav-h-s:70px;--page-x:clamp(20px, 5vw, 100px);}
p a:hover { color: white; }


.v-animace { opacity:0; transform:translateY(16px); animation:blockIn .8s cubic-bezier(.22,.61,.36,1) forwards; animation-delay:1s; }
@keyframes blockIn{ to{opacity:1;transform:translateY(0)} }
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

#top{ position: absolute; top: 0; left: 0; width: 1px; height: 1px; }
h1, h2, h3 { text-transform: uppercase; font-family: "Bebas Neue", sans-serif; font-weight: 100; letter-spacing: 3px; line-height: .98; overflow-wrap: anywhere; }
h1 { font-size: clamp(3.25rem, 10vw, 5rem); }
h2 { font-size: clamp(2.25rem, 6vw, 3rem); }
h3 { font-size: clamp(1.6rem, 4vw, 2rem); }

/*navigace*/
.nav {position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;padding:0 var(--page-x);background:transparent;opacity:0;transform:translateY(-12px);animation:navIn 1s cubic-bezier(.22,.61,.36,1) forwards;animation-delay:1s;transition:height .25s ease,background-color .25s ease,box-shadow .25s ease,backdrop-filter .25s ease}
@keyframes navIn {to{opacity:1;transform:translateY(0)}}
.nav.is-scrolled {height:var(--nav-h-s);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.nav__inner {width:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:18px}
.logo {position:relative;display:inline-block;height:26px;width:190px}
.logo__img { transition-duration: .3s; filter:invert(1) saturate(0) brightness(1.5); position:absolute;inset:0;height:26px;width:auto;display:block;opacity:0;pointer-events:none}
.logo__img--a {opacity:1;}
.logo__img--b {opacity:0}
.nav.is-scrolled .logo__img--a {opacity:0;}
.nav.is-scrolled .logo__img--b {opacity:1;}
.nav__menu {display:flex;align-items:center;gap:10px}
.nav__menu a {font-size: 18px; color:#fff;text-decoration:none;padding:10px 10px; text-transform: uppercase; font-family: "Bebas Neue", sans-serif; font-weight: 100; letter-spacing: 3px;}
.nav__menu a:hover {color:#008cff}
.nav__menu .btn {padding:10px 14px;border-radius:10px;background:#0b5ed7;color:#fff}
.nav__toggle {display:none;width:44px;height:44px;border:0;background:transparent;cursor:pointer}
.nav__toggle span {display:block;height:2px;margin:7px 0;background:#fff;transition:transform .2s ease,opacity .2s ease}

@media (max-width:1100px){
.nav { padding: 0 20px; }
.nav__toggle {display:block}
.nav__menu {position:absolute;top:var(--nav-h);left:0;right:0;padding:14px 20px 18px;background:rgb(1 9 31 / 82%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:grid;gap:8px;transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease,top .25s ease}
.nav.is-scrolled .nav__menu {top:var(--nav-h-s)}
.nav.is-open .nav__menu {opacity:1;transform:translateY(0);pointer-events:auto}
.nav__menu a {padding:12px 0} 
}

.navbar-brand:hover .logo img { filter: invert(8%) sepia(100%) saturate(7345%) hue-rotate(244deg) brightness(99%) contrast(139%);}

.butt-row { display: flex; gap: 20px; flex-wrap: wrap; }
.butt { min-width: 0; letter-spacing: 2px; font-size: 18px; font-family: "Bebas Neue", sans-serif; font-weight: 100; border-radius: 100px; display: flex; gap: 20px; padding: 20px 30px; text-transform: uppercase; letter-spacing: 1px; transition-duration: .3s; align-items: center; justify-content: space-between;}

.butt-1 { background:#0048ff; color:#fff; }
.butt-2 { background: transparent; color: #fff; border: 1px solid #444d60; }
.butt-1:hover { box-shadow:0 14px 36px rgba(0,72,255,.45); background:hsl(223, 100%, 56%); }
.butt-2:hover { border: 1px solid #fff; }
.butt .material-symbols-outlined { transition: transform .35s cubic-bezier(.22,.61,.36,1); will-change: transform; display: inline-block; }
.butt:hover .material-symbols-outlined { transform: translateX(10px); }

.nv-contact-box{
  position: fixed;
  right: 30px;
  bottom: 30px;
  padding: 20px 24px;
  border-radius: 20px;
  max-width: 260px;
  z-index: 9999;

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: #0019d845;

  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-end;

  /* výchozí stav */
  opacity: 0;
  transform: translateY(80px);
  pointer-events: none;

  /* jediné přechody, které řídí show i hide */
  transition:
    opacity .6s cubic-bezier(.4,0,.2,1),
    transform .6s cubic-bezier(.4,0,.2,1) !important;

  /* kill switch – kdyby ti někde zůstala stará animace */
  animation: none !important;
}

/* po 2s se box ukáže */
.nv-contact-box.is-visible{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* schování u patičky – bude se animovat stejným transition */
.nv-contact-box.hide{
  opacity: 0;
  transform: translateY(40px);
  pointer-events: none;
}

/* mobil */
@media (max-width:768px){
  .nv-contact-box{
    right:15px;
    bottom:15px;
    max-width:200px;
    padding:16px;
  }
}


/*s1*/
.section-1 { gap: 100px; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-end; height: auto; min-height: 100svh; padding-top: calc(var(--nav-h) + 48px); padding-bottom: 56px; }
.section-1 p { color: #586279; font-size: 1.5rem; text-transform: uppercase; }
.section-1 p span { color: white; }
.section-1 .flex { display: flex; flex-direction: column; gap: 50px; }
.section-1 h1 { margin: 0 0 -20px 0; max-width: 1100px; }


/*partners*/
.partners { width:100%;padding:26px 0; }
.partners__inner { position: absolute; padding: 0; }
.logo-marquee { position:relative;overflow:hidden;width:100% }
.logo-marquee::before,.logo-marquee::after { content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.logo-marquee::before { left:0; }
.logo-marquee::after { right:0; }
.logo-marquee__track { display:flex;align-items:center;gap:70px;padding:14px 20px;will-change:transform;animation:marquee 32s linear infinite}
.logo-marquee__logo { flex:0 0 auto;height:30px;max-width:170px;width:auto;display:block;object-fit:contain;opacity:.62;transition:opacity .2s ease,transform .2s ease}
.logo-marquee__logo--wide { height:34px;max-width:190px}
.logo-marquee__logo--tall { height:46px}
.logo-marquee__logo--mark { height:42px}
.logo-marquee { position:relative; overflow:hidden; width:100%; -webkit-mask-image:linear-gradient(90deg,transparent 10%,#000 50%,#000 92%,transparent 100%); mask-image:linear-gradient(90deg,transparent 10%,#000 50%,#000 92%,transparent 100%); }
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (max-width:768px){ .partners__title{font-size:26px} .logo-marquee__track{gap:40px} .logo-marquee__logo{height:22px;max-width:140px} .logo-marquee__logo--wide{height:25px} .logo-marquee__logo--tall{height:34px} .logo-marquee__logo--mark{height:32px} }
@media (prefers-reduced-motion:reduce){ .logo-marquee__track{animation:none;overflow:auto} }

.section-2 { display: flex; gap: 50px; flex-direction: column;  }
.section-2 .brand-iko { transition: all .2s ease; width: 60px; filter: brightness(0) invert(1); }
.section-2 .brand { display: flex; align-items: center; gap: 20px; flex: 1 1 220px; min-width: 220px; width: auto; line-height: 1.15; overflow-wrap: anywhere; }
.section-2 .brand-symbol { display: inline-flex; align-items: center; justify-content: center; width: 60px; min-width: 60px; height: 60px; color: #fff; font-size: 54px; line-height: 1; }
.section-2 .it-blok { display: flex; flex-direction: column; }
.section-2 .it-blok--primary h3 { color: #2196F3; }
.section-2 .it-blok--primary .popis { color: #c3cad7; }
.section-2 .it-blok--primary .split { border-top: 1px solid rgb(33 150 243 / 45%); }
.section-2 .split { display: flex; flex-direction: row;  }
.popis { border-right: dotted 2px #4f596f; padding: 30px 30px 0 0; min-width: min(500px, 100%); width: min(500px, 100%); color: #586279; font-size: 1.5rem; }
.loga { width: 100%; padding: 30px 0 0 30px; display: flex; flex-wrap: wrap; flex-direction: row; gap: 30px; }
.section-2 .flex { display: flex; gap: 200px; flex-direction: column; }

.section-3 { background: rgb(0 50 255 / 15%); display: flex; justify-content: center; min-height: 100vh;  }
.section-3 .stats { gap:50px; width: 100%; position: relative; display: flex; flex-wrap: wrap; flex-direction: row; }
.section-3 .stats .v-col { flex: 0 0 calc((100% - 100px) / 3); box-sizing: border-box; display: flex; flex-direction: column; gap: 50px; }
.section-3 .stats .v-col:first-child p, .describe { color: #586279; font-size: 1.5rem; text-transform: uppercase; }
.describz { text-transform: uppercase; background: #0000002e; width: auto; margin: 0 auto 0 0; padding: 10px 15px; border-radius: 100px; font-size: 1rem; color: #2196F3;}
.section-3 .stats .v-col:not(:first-child) { border-left: 1px solid #586279; padding: 50px; }
.section-3 .stats .v-col p:first-child { font-weight: 100; font-size: 10rem; }
.section-3 .stats .v-col:not(:first-child) p:last-child { text-align: right; max-width: 50%; margin: 0 0 0 auto; }

.section-4 { display: flex; justify-content: center; min-height: 100vh; gap: 100px; justify-content: flex-start; }
.section-4 h2 { min-width: calc(50vw - 200px); margin-top: 50px; }
.section-4 h3 { display: flex; align-items: center; gap: 30px;  }
.section-4 .flex article { display: flex; gap: 30px; flex-direction: column; }
.section-4 .flex { display: flex; gap: 70px; flex-direction: column; border-left: 1px solid #586279; padding: 50px; }
.section-4 h3 .butt { padding: 10px 20px; }
.section-4 .flex article a h3 { color: white; transition-duration: .3s;}
.section-4 .flex article a:hover h3 { color: #008cff;}
.section-4 .flex article a:hover .material-symbols-outlined { transform: translateX(10px); }
.section-4 .flex article a:hover .butt { border: 1px solid white; }
.section-4 { position: relative; overflow: hidden; }
.section-4::before{ content: ""; position: absolute; inset: 0; background-image: url('img/test.png'); background-repeat: no-repeat; background-position: bottom left; background-size: contain; opacity: 1; width: 35%; z-index: 0; transform: translate3d(0,0,0); will-change: transform;  transform: translate3d(0, var(--w-parallax, 0px), 0); }
.section-4 > *{ position: relative; z-index: 1; }



/*faq*/
.faq-section { display: grid; grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr); gap: 80px; padding-top: 120px; padding-bottom: 80px; align-items: start; }
.faq-section__eyebrow { color: #2196F3; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 20px; }
.faq-section__lead { color: #586279; font-size: 1.2rem; margin-top: 24px; max-width: 620px; }
.faq-list { display: flex; flex-direction: column; gap: 18px; }
.faq-item { border: 1px solid rgb(88 98 121 / 35%); border-radius: 24px; background: rgb(255 255 255 / 3%); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); transition: border-color .3s ease, background-color .3s ease, transform .3s ease; }
.faq-item[open] { border-color: rgb(33 150 243 / 65%); background: rgb(0 72 255 / 10%); transform: translateY(-2px); }
.faq-item summary { list-style: none; cursor: pointer; padding: 26px 72px 26px 28px; position: relative; font-family: "Bebas Neue", sans-serif; font-size: 1.8rem; letter-spacing: 2px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; position: absolute; right: 28px; top: 50%; transform: translateY(-50%); font-size: 2rem; color: #2196F3; transition: transform .3s ease; }
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item p { color: #c3cad7; padding: 0 28px 26px; line-height: 1.6; max-width: 720px; }

.simple-page { display: flex; flex-direction: column; gap: 70px; position: relative; }
.simple-page__intro { max-width: 900px; display: flex; flex-direction: column; gap: 24px; }
.simple-page__eyebrow { color: #2196F3; text-transform: uppercase; letter-spacing: 2px; font-size: 1.1rem; }
.simple-page__intro p:not(.simple-page__eyebrow) { color: #8d98ad; font-size: 1.35rem; line-height: 1.5; text-transform: uppercase; }
.seo-link-row { display: flex; flex-wrap: wrap; gap: 10px; }
.seo-link-row a { border: 1px solid rgb(88 98 121 / 55%); border-radius: 100px; color: #dbeafe; padding: 10px 14px; font-family: "Bebas Neue", sans-serif; text-transform: uppercase; letter-spacing: 1px; line-height: 1; }
.seo-link-row a:hover { border-color: #2196F3; color: #fff; background: rgb(33 150 243 / 14%); }
.references-page,
.career-page { background: rgb(0 50 255 / 8%); }
.reference-logos,
.reference-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; border: 1px solid rgb(88 98 121 / 35%); background: rgb(88 98 121 / 30%); }
.reference-filters { display: flex; flex-wrap: wrap; gap: 10px; margin-top: -28px; }
.reference-filter { min-height: 42px; border: 1px solid rgb(88 98 121 / 55%); border-radius: 100px; background: rgb(1 9 31 / 62%); color: #dbeafe; padding: 0 15px; cursor: pointer; font-family: "Bebas Neue", sans-serif; font-size: 1rem; line-height: 1; letter-spacing: 1px; text-transform: uppercase; transition: border-color .2s ease, background-color .2s ease, color .2s ease; }
.reference-filter:hover,
.reference-filter.is-active { border-color: #2196F3; background: #0048ff; color: #fff; }
.reference-logo { min-height: 160px; display: flex; align-items: center; justify-content: center; background: rgb(1 9 31 / 78%); padding: 36px; }
.reference-logo img { max-width: 180px; width: 75%; filter: invert(1) saturate(0) brightness(1.6); opacity: .72; }
.reference-card { position: relative; min-height: 220px; display: flex; flex-direction: column; gap: 18px; overflow: hidden; background: rgb(1 9 31 / 78%); color: #fff; padding: 30px; text-decoration: none; }
.reference-card.is-hidden { display: none; }
.reference-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgb(33 150 243 / 14%), transparent 48%); opacity: 0; transition: opacity .25s ease; pointer-events: none; }
.reference-card:hover::before { opacity: 1; }
.reference-card__number { color: #2196F3; font-family: "Bebas Neue", sans-serif; letter-spacing: 2px; font-size: 1rem; text-transform: uppercase; }
.reference-card h2 { font-size: clamp(2rem, 4vw, 3rem); letter-spacing: 2px; }
.reference-card p { color: #a9b4c8; line-height: 1.45; font-size: 1rem; text-transform: none; }
.reference-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.reference-tags span { border: 1px solid rgb(88 98 121 / 55%); border-radius: 100px; color: #dbeafe; padding: 7px 11px; font-size: .82rem; line-height: 1; }
.reference-card--link { text-decoration: none; border: 1px solid rgb(33 150 243 / 45%); }
.reference-card__cta { margin-top: auto; display: inline-flex; align-items: center; gap: 8px; color: #fff; font-family: "Bebas Neue", sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.reference-card__cta .material-symbols-outlined { font-size: 18px; }
.case-page { display: grid; grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr); gap: 80px; align-items: start; }
.case-hero { position: sticky; top: 120px; display: flex; flex-direction: column; gap: 28px; max-width: 620px; }
.case-meta { display: grid; gap: 1px; border: 1px solid rgb(88 98 121 / 35%); background: rgb(88 98 121 / 30%); }
.case-meta__item { display: grid; gap: 6px; background: rgb(1 9 31 / 78%); padding: 18px; }
.case-meta__label { color: #2196F3; font-family: "Bebas Neue", sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.case-meta__value { color: #dbeafe; line-height: 1.35; }
.case-meta__value a { color: #fff; text-decoration: underline; text-decoration-color: rgb(33 150 243 / 70%); text-underline-offset: 3px; }
.case-meta__value a:hover { color: #93c5fd; }
.case-content { display: flex; flex-direction: column; gap: 28px; border-left: 1px solid rgb(88 98 121 / 35%); padding-left: 42px; }
.case-section { display: flex; flex-direction: column; gap: 16px; }
.case-section h2 { font-size: clamp(2rem, 4vw, 3rem); }
.case-section p,
.case-section li { color: #a9b4c8; font-size: 1.08rem; line-height: 1.55; }
.case-section ul { display: grid; gap: 12px; padding-left: 22px; }
.case-tech { display: flex; flex-wrap: wrap; gap: 10px; }
.case-tech span { border: 1px solid rgb(33 150 243 / 48%); border-radius: 100px; color: #dbeafe; background: rgb(33 150 243 / 10%); padding: 9px 13px; line-height: 1; }
.case-actions { display: flex; flex-wrap: wrap; gap: 14px; padding-top: 10px; }
.blog-list,
.legal-list { display: flex; flex-direction: column; gap: 18px; max-width: 1000px; }
.blog-page { display: grid; grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr); gap: 80px; align-items: start; }
.blog-page .simple-page__intro { max-width: 620px; position: sticky; top: 120px; }
.blog-page .blog-list { max-width: none; }
.blog-item { border: 1px solid rgb(88 98 121 / 35%); border-radius: 24px; background: rgb(255 255 255 / 3%); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); transition: border-color .3s ease, background-color .3s ease, transform .3s ease; }
.blog-item[open] { border-color: rgb(33 150 243 / 65%); background: rgb(0 72 255 / 10%); transform: translateY(-2px); }
.legal-item { border: 1px solid rgb(88 98 121 / 35%); border-radius: 24px; background: rgb(255 255 255 / 3%); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); transition: border-color .3s ease, background-color .3s ease, transform .3s ease; }
.legal-item[open] { border-color: rgb(33 150 243 / 65%); background: rgb(0 72 255 / 10%); transform: translateY(-2px); }
.blog-item summary,
.legal-item summary { list-style: none; cursor: pointer; position: relative; padding: 28px 78px 28px 30px; font-family: "Bebas Neue", sans-serif; font-size: 1.8rem; letter-spacing: 2px; text-transform: uppercase; color: #fff; }
.blog-item summary::-webkit-details-marker,
.legal-item summary::-webkit-details-marker { display: none; }
.blog-item summary::after,
.legal-item summary::after { content: "+"; position: absolute; right: 30px; top: 50%; transform: translateY(-50%); color: #2196F3; font-size: 2rem; transition: transform .3s ease; }
.blog-item[open] summary::after,
.legal-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.blog-item__content,
.legal-item p { color: #c3cad7; padding: 0 30px 30px; line-height: 1.65; font-size: 1.05rem; }
.blog-item__content { display: flex; flex-direction: column; gap: 18px; max-width: 860px; }
.career-box { max-width: 1000px; border-left: 1px solid #586279; padding-left: 50px; display: flex; flex-direction: column; gap: 30px; }
.career-box p,
.career-box li { color: #c3cad7; font-size: 1.15rem; line-height: 1.6; }
.career-box ul { display: grid; gap: 12px; padding-left: 22px; }
.service-page { display: grid; grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr); gap: 80px; align-items: start; }
.service-page .simple-page__intro { max-width: 620px; position: sticky; top: 120px; }
.service-content { border-left: 1px solid rgb(88 98 121 / 35%); padding-left: 50px; display: flex; flex-direction: column; gap: 26px; }
.service-content h2 { font-size: clamp(1.8rem, 3vw, 2.4rem); }
.service-content p,
.service-content li { color: #c3cad7; font-size: 1.18rem; line-height: 1.65; }
.service-content ul { display: grid; gap: 12px; padding-left: 22px; }
.service-content .butt-row { margin-top: 22px; }
.contact-layout { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; border-top: 1px solid rgb(88 98 121 / 27%); }
.contact-page { display: grid; grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr); gap: 80px; align-items: start; }
.contact-page .simple-page__intro { max-width: 620px; position: sticky; top: 120px; }
.contact-page__content { display: flex; flex-direction: column; gap: 60px; }
.contact-page .contact-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: 42px; }
.contact-panel { border-left: 1px solid rgb(88 98 121 / 27%); padding: 34px 30px 0 30px; display: flex; flex-direction: column; gap: 22px; min-height: 260px; }
.contact-panel p,
.contact-panel a:not(.butt) { color: #c3cad7; font-size: 1.15rem; line-height: 1.6; }
.contact-panel a:not(.butt) { display: flex; align-items: center; gap: 14px; }
.contact-panel a:not(.butt):hover { color: #2196F3; }
.contact-panel .material-symbols-outlined { color: #2196F3; min-width: 24px; }
.contact-page .legal-list { max-width: none; }

@media (max-width: 992px){
.faq-section { grid-template-columns: 1fr; gap: 40px; padding-top: 80px; }
.blog-page { grid-template-columns: 1fr; gap: 40px; }
.blog-page .simple-page__intro { position: static; max-width: 900px; }
.contact-page { grid-template-columns: 1fr; gap: 40px; }
.contact-page .simple-page__intro { position: static; max-width: 900px; }
.service-page { grid-template-columns: 1fr; gap: 40px; }
.service-page .simple-page__intro { position: static; max-width: 900px; }
.case-page { grid-template-columns: 1fr; gap: 40px; }
.case-hero { position: static; max-width: 900px; }
.case-content { padding-left: 28px; }
.service-content { padding-left: 28px; }
.reference-logos,
.reference-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.contact-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: 42px; }
.career-box { padding-left: 28px; }
}

@media (max-width: 640px){
.faq-section { padding-bottom: 40px; }
.faq-item summary { font-size: 1.35rem; padding: 22px 60px 22px 20px; }
.faq-item summary::after { right: 20px; }
.faq-item p { padding: 0 20px 22px; }
.simple-page { gap: 42px; }
.simple-page__intro p:not(.simple-page__eyebrow) { font-size: 1.05rem; }
.reference-logos,
.reference-grid { grid-template-columns: 1fr; }
.reference-logo { min-height: 120px; }
.reference-card { min-height: 190px; padding: 24px; }
.case-content { padding-left: 0; border-left: 0; border-top: 1px solid rgb(88 98 121 / 35%); padding-top: 30px; }
.case-section p,
.case-section li { font-size: 1.05rem; }
.blog-item summary,
.legal-item summary { font-size: 1.35rem; padding: 22px 60px 22px 20px; }
.blog-item summary::after,
.legal-item summary::after { right: 20px; }
.blog-item__content,
.legal-item p { padding: 0 20px 22px; }
.contact-panel { padding: 28px 22px; }
.contact-layout { grid-template-columns: 1fr; }
.contact-panel { border-left: 1px solid rgb(88 98 121 / 27%); }
}

@media (max-width: 1200px){
.section-2 .brand { flex-basis: calc(50% - 11px); min-width: 230px; width: auto; }
.section-4 { gap: 60px; }
.section-4 h2 { min-width: 32vw; }
.section-3 .stats .v-col p:first-child { font-size: clamp(5rem, 13vw, 10rem); }
}

@media (max-width: 992px){
:root { --nav-h: 86px; --nav-h-s: 68px; }
.section-1 { gap: 64px; padding-top: calc(var(--nav-h) + 42px); }
.section-1 .flex { gap: 34px; max-width: 780px; }
.section-1 p { font-size: 1.25rem; line-height: 1.35; }
.partners__inner { position: static; margin-bottom: 18px; }
.section-2 .split { flex-direction: column; gap: 28px; }
.popis { border-right: 0; border-bottom: dotted 2px #4f596f; padding: 28px 0; width: 100%; min-width: 0; }
.loga { padding: 0; gap: 22px; }
.section-2 .brand { flex: 1 1 calc(50% - 11px); min-width: 230px; width: auto; }
.section-2 .flex { gap: 96px; }
.section-3 { min-height: auto; }
.section-3 .stats { gap: 0; }
.section-3 .stats .v-col { flex: 0 0 100%; gap: 24px; }
.section-3 .stats .v-col:not(:first-child) { border-left: 0; border-top: 1px solid #586279; padding: 40px 0; }
.section-3 .stats .v-col:not(:first-child) p:last-child { max-width: 540px; text-align: left; margin: 0; }
.section-4 { flex-direction: column; min-height: auto; gap: 44px; }
.section-4::before { width: 52%; opacity: .45; }
.section-4 h2 { min-width: 0; margin-top: 0; }
.section-4 .flex { border-left: 0; border-top: 1px solid #586279; padding: 40px 0 0; gap: 48px; }
.footer-grid { gap: 48px 0; }
.footer-author { margin-top: 120px; }
.footer-contacts { flex-direction: column; gap: 18px; }
}

@media (max-width: 640px){
:root { --nav-h: 76px; --nav-h-s: 64px; --page-x: 20px; }
h1 { font-size: clamp(3rem, 15vw, 3.7rem); letter-spacing: 1.5px; line-height: .95; }
h2 { letter-spacing: 1.5px; }
h3 { letter-spacing: 1.3px; }
.nav { padding: 0 var(--page-x); }
.logo { width: 150px; height: 22px; }
.logo__img { height: 22px; }
.section-1 { min-height: auto; gap: 56px; padding-top: calc(var(--nav-h) + 28px); padding-bottom: 56px; }
.section-1 .flex { gap: 28px; width: 100%; }
.section-1 h1 { margin: 0; max-width: 100%; }
.section-1 p { font-size: 1.08rem; line-height: 1.38; }
.butt-row { width: 100%; gap: 14px; }
.butt { width: 100%; min-height: 56px; padding: 16px 22px; font-size: 17px; line-height: 1.1; }
.nv-contact-box { display: none; }
.partners { padding: 8px 0 0; }
.logo-marquee__track { padding-left: 0; padding-right: 0; }
.section-2 { gap: 34px; }
.section-2 .flex { gap: 70px; }
.section-2 .brand-symbol { width: 42px; min-width: 42px; height: 42px; font-size: 40px; }
.section-2 .brand-iko { width: 42px; }
.section-2 .brand { flex-basis: 100%; min-width: 0; width: 100%; gap: 14px; }
.popis { font-size: 1.15rem; line-height: 1.45; }
.loga { gap: 18px; }
.section-3 .stats .v-col:first-child p,
.describe { font-size: 1.1rem; line-height: 1.4; }
.section-3 .stats .v-col p:first-child { font-size: clamp(4.5rem, 28vw, 7rem); line-height: .9; }
.section-4::before { width: 90%; opacity: .25; }
.section-4 h3 { align-items: flex-start; gap: 18px; flex-direction: column; }
.section-4 h3 .butt { width: auto; padding: 10px 18px; }
.service-content { padding-left: 0; border-left: 0; border-top: 1px solid rgb(88 98 121 / 35%); padding-top: 30px; }
.service-content p,
.service-content li,
.career-box p,
.career-box li { font-size: 1.05rem; }
.career-box { padding-left: 0; border-left: 0; border-top: 1px solid #586279; padding-top: 30px; }
.contact-page .contact-layout { grid-template-columns: 1fr; }
.contact-panel { min-height: auto; }
.site-footer { margin-top: 6vh; }
.footer-bg__logo { width: 120vw; opacity: .28; }
.footer-col--nav,
.footer-col--contacts { padding-left: 0; border-left: 0; border-top: 1px solid rgb(88 98 121 / 27%); padding-top: 28px; }
.footer-col--nav .footer-links { font-size: 1.65rem; gap: 14px; }
.footer-author { margin-top: 60px; }
.footer-col--contacts .butt-row { margin: 32px 0; }
.footer-bottom-right { align-items: flex-start; gap: 28px; }
}

@media (max-width: 380px){
.padding-1 { padding-left: 18px; padding-right: 18px; }
.nav { padding: 0 18px; }
h1 { font-size: clamp(2.7rem, 14vw, 3.2rem); }
.nav__toggle { width: 40px; }
}



/*footer*/
.logo-vyrobil { filter: invert(1) brightness(1.5); width: 90px; }
.site-footer { position: relative; min-height: 60vh; height: auto; margin-top: 10vh;}
.footer-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.footer-bg__logo{ position: absolute; right: 0; bottom: 0; width: 80vw; height: auto; opacity: .5; pointer-events: none; filter: invert(1); mix-blend-mode: color-burn; }
.footer-grid{ position: relative; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.footer-col--nav { display: flex; flex-direction: column; }
.footer-author { margin-top: 300px; }
.footer-col--empty { display: flex; flex-direction: column; }
.footer-bottom-right { margin-top: auto; }
.footer-modal { display: none; position: fixed; inset: 0; z-index: 9999; }
.footer-modal:target { display: block; }
.footer-modal__backdrop { position: absolute; inset: 0; display: block; background: rgb(0 0 0 / 72%); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.footer-modal__panel { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); max-width: 760px; width: calc(100% - 32px); max-height: calc(100vh - 48px); overflow: auto; background: rgb(1 9 31 / 95%); border: 1px solid rgb(88 98 121 / 45%); border-radius: 24px; padding: 34px; box-shadow: 0 30px 90px rgb(0 0 0 / 45%); }
.footer-modal__head { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.footer-modal__head h3 { opacity: 1; font-size: 2rem; }
.footer-modal__close { color: #fff; font-size: 24px; line-height: 1; }
.footer-modal__close:hover { color: #2196F3; }
.footer-modal__form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.footer-modal__form label { display: flex; flex-direction: column; gap: 8px; color: #c3cad7; text-transform: uppercase; letter-spacing: 1px; }
.footer-modal__form input,
.footer-modal__form textarea,
.footer-modal__form select { width: 100%; box-sizing: border-box; border: 1px solid rgb(88 98 121 / 45%); background: rgb(255 255 255 / 5%); color: #fff; padding: 16px; font: inherit; border-radius: 18px; }
.footer-modal__form textarea,
.footer-modal__form .form-consent,
.footer-modal__form .form-status,
.footer-modal__actions { grid-column: 1 / -1; }
.footer-modal__form textarea { resize: vertical; min-height: 150px; }
.footer-modal__form input:focus,
.footer-modal__form textarea:focus,
.footer-modal__form select:focus { border-color: #2196F3; box-shadow: 0 0 0 3px rgb(33 150 243 / 18%); }
.footer-modal__form select option { color: #071023; }
.form-hp { position: absolute; left: -9999px; width: 1px !important; height: 1px; opacity: 0; pointer-events: none; }
.form-status { display: none; margin: 0; padding: 14px 16px; border-radius: 14px; line-height: 1.45; background: rgb(255 255 255 / 7%); border: 1px solid rgb(88 98 121 / 45%); color: #dbeafe; }
.form-status.is-visible { display: block; }
.form-status.is-success { border-color: rgb(34 197 94 / 55%); color: #bbf7d0; }
.form-status.is-error { border-color: rgb(248 113 113 / 60%); color: #fecaca; }
.form-consent { flex-direction: row !important; align-items: flex-start; gap: 12px !important; text-transform: none !important; letter-spacing: 0 !important; line-height: 1.4; }
.form-consent input { width: 18px; min-width: 18px; height: 18px; margin-top: 2px; }
.footer-modal__actions { display: flex; justify-content: flex-end; gap: 14px; margin-top: 8px; }
.footer-action { min-height: 52px; box-sizing: border-box; border: 1px solid rgb(88 98 121 / 55%); border-radius: 100px; background: transparent; color: #fff; padding: 0 22px; cursor: pointer; font-family: "Bebas Neue", sans-serif; font-size: 1.1rem; line-height: 1; letter-spacing: 1px; text-transform: uppercase; display: inline-flex; align-items: center; justify-content: center; }
.footer-action:hover { border-color: #fff; }
.footer-action[type="submit"] { background: #0048ff; border-color: #0048ff; }
.footer-action[type="submit"]:hover { box-shadow: 0 14px 36px rgba(0,72,255,.45); background: hsl(223, 100%, 56%); border-color: hsl(223, 100%, 56%); }
.footer-col--nav,
.footer-col--contacts { border-left: 1px solid rgb(88 98 121 / 27%); padding: 0 0 0 30px; }
.footer-col--nav .footer-links { display: flex; flex-direction: column; font-size: 2rem; gap: 20px; }
.footer-col--nav .footer-links a { color: white; text-transform: uppercase; font-weight: 500; font-family: 'Bebas Neue'; }
.footer-col--secondary .footer-links { display: flex; flex-direction: column; gap: 10px; margin-top: 30px; }
.footer-col--secondary .footer-links a { color: white;  }
.footer-col--contacts .butt-row { margin: 50px 0 50px 0; flex-direction: column; }
footer h3 { font-size: 1.2rem; opacity: .5; }
.footer-to-top { align-items: center; justify-content: center; width: fit-content; }
.footer-bottom-right { margin-top: auto; display: flex; gap: 50px; flex-direction: column-reverse; align-items: flex-end; }
.footer-to-top.butt:hover .material-symbols-outlined { transform: translateY(-10px); }
.footer-contact { color: white; }
.footer-contact:hover,
.footer-col--secondary .footer-links a:hover,
.footer-col--nav .footer-links a:hover { color: #008cff; }
.footer-contacts { display: flex; flex-direction: row; gap: 30px; margin-top: 30px; }
.footer-contacts a { display: flex; align-items: center; gap: 10px;  }
.footer-contacts a span { font-size: 18px; }
@media (max-width: 1100px){
.footer-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){ 
.footer-grid{ grid-template-columns: 1fr; } 
.footer-modal__panel { padding: 24px 18px; }
.footer-modal__form { grid-template-columns: 1fr; }
.footer-modal__actions { flex-direction: column; }
.footer-action { text-align: center; }
}


/*loading bar*/
#top-loader { position: fixed; top: 0; left: 0; width: 0%; height: 3px; background: #0048ff; z-index: 9999; transition: width 0.4s ease, opacity 0.4s ease; box-shadow: 0 0 10px rgba(0,72,255,0.7); }
#top-loader.active {  width: 80%; }
#top-loader.finish { width: 100%; opacity: 0; }    

.simple-page__intro,
.service-content,
.contact-layout,
.contact-panel,
.career-box,
.footer-col,
.footer-contacts,
.butt-row,
.butt { min-width: 0; max-width: 100%; }

.butt { white-space: normal; text-align: left; }
.butt .material-symbols-outlined { flex: 0 0 auto; }
.footer-contacts { flex-wrap: wrap; }
.footer-contact { min-width: 0; overflow-wrap: anywhere; }
.footer-col--contacts .butt-row .butt { width: 100%; }

@media (max-width: 992px){
.contact-page,
.blog-page,
.service-page { grid-template-columns: minmax(0, 1fr); }
.contact-page .contact-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.contact-panel { padding-left: 28px; padding-right: 24px; }
}

@media (max-width: 640px){
.padding-1 { padding-left: 18px; padding-right: 18px; }
.nav { padding: 0 18px; }
.simple-page,
.contact-page,
.blog-page,
.service-page { grid-template-columns: minmax(0, 1fr); }
.contact-page .contact-layout,
.contact-layout { grid-template-columns: minmax(0, 1fr); }
.contact-panel,
.service-content,
.career-box { width: 100%; min-width: 0; }
.contact-panel { padding: 28px 0; border-left: 0; border-top: 1px solid rgb(88 98 121 / 27%); }
.footer-grid { grid-template-columns: minmax(0, 1fr); gap: 44px; }
.footer-col { min-width: 0; }
.footer-col--nav,
.footer-col--contacts { padding-left: 0; border-left: 0; border-top: 1px solid rgb(88 98 121 / 27%); padding-top: 28px; }
.footer-col--secondary .footer-links { margin-top: 18px; }
.footer-col--nav .footer-links { font-size: 1.65rem; gap: 14px; }
.footer-author { margin-top: 56px; }
.footer-contacts { flex-direction: column; gap: 16px; }
.footer-col--contacts .butt-row { margin: 32px 0; }
.footer-bottom-right { align-items: flex-start; gap: 28px; }
.footer-to-top { width: 56px; min-height: 56px; padding: 0; justify-content: center; }
}

@media (max-width: 380px){
h1 { font-size: clamp(2.65rem, 14vw, 3.2rem); }
.butt { padding-left: 20px; padding-right: 20px; }
}








