:root{ --c1:#62e3e2; --c2:#2a78e9; --text:#0b0f1a; }
    *{box-sizing:border-box}
    html,body{margin:0}
    body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#f7f8fb;overflow-x:hidden;padding-top:76px}
    a{color:inherit;text-decoration:none}
    .container{max-width:1200px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
    .shadow-soft{box-shadow:0 20px 60px rgba(10,30,60,.18), 0 8px 18px rgba(10,30,60,.12)}

    header{position:fixed;left:0;right:0;top:0;z-index:1200;background:rgba(255,255,255,.55);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid rgba(0,0,0,.04);transition:background .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s cubic-bezier(.2,.7,.2,1)}
    .nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 0;position:relative}
    .logo{display:flex;align-items:center;gap:12px;transition:opacity .42s cubic-bezier(.2,.7,.2,1), transform .42s cubic-bezier(.2,.7,.2,1)}
    .logo img{height:38px;width:auto;display:block;object-fit:contain;max-width:180px}
    .cta{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;padding:12px 24px;border-radius:18px;font-weight:800;color:#fff;border:0;background:linear-gradient(90deg,var(--c1),var(--c2));box-shadow:0 12px 24px rgba(42,120,233,.32), 0 3px 8px rgba(15,30,60,.10);transition:opacity .38s cubic-bezier(.2,.7,.2,1), transform .28s ease, box-shadow .28s ease}
    .cta:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(42,120,233,.36),0 6px 12px rgba(15,30,60,.14)}
    header.compact{background:rgba(255,255,255,.8);box-shadow:0 10px 30px rgba(15,30,60,.1)}
    header.compact .logo, header.compact .cta{opacity:0;transform:translateY(-8px) scale(.98);pointer-events:none}

    .nav-pill{display:flex;gap:8px;align-items:center;background:rgba(255,255,255,.92);border:1px solid rgba(0,0,0,.06);border-radius:9999px;padding:8px;box-shadow:0 16px 32px rgba(15,30,60,.14), 0 4px 10px rgba(15,30,60,.08);position:absolute;left:50%;transform:translateX(-50%);z-index:2;max-width:min(900px,90vw)}
    .nav-pill a{padding:10px 18px;border-radius:9999px;font-weight:600;color:#111827;opacity:.95}
    .nav-pill a.active{background:#dde1e7;box-shadow:inset 0 1px 0 rgba(255,255,255,.7), 0 1px 1px rgba(0,0,0,.06)}

    .hero{position:relative;padding:96px 0 64px;background:linear-gradient(180deg,#f8fbff 0%,#f7f8fb 35%,#f6fbff 100%)}
    .hero h1{font-size:clamp(36px,6vw,72px);line-height:1.05;margin:0 0 18px;letter-spacing:-.02em}
    .hero p{font-size:clamp(18px,2.2vw,22px);color:#334155;max-width:760px}
    .hero-actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
    .btn{display:inline-flex;align-items:center;gap:10px;padding:14px 20px;border-radius:14px;font-weight:700}
    .btn-primary{color:#fff;background:linear-gradient(135deg,var(--c1),var(--c2));box-shadow:0 18px 40px rgba(42,120,233,.25)}
    .btn-ghost{background:#fff;border:1px solid rgba(0,0,0,.08);color:#0f172a}

    section{position:relative;padding:96px 0}
    .alt{background:linear-gradient(180deg, rgba(98,227,226,.09), rgba(42,120,233,.06))}

    .marker-word{display:inline;padding:0 .15em;border-radius:.35em;background-image:linear-gradient(90deg,var(--c1),var(--c2));background-repeat:no-repeat;background-size:100% 60%;background-position:0 85%;box-decoration-break:clone;-webkit-box-decoration-break:clone}

    .about{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
    .about h2{font-size:clamp(28px,4vw,46px);margin:0 0 12px}
    .about p{color:#374151;font-size:18px}
    .badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
    .badge{padding:8px 14px;border-radius:9999px;font-weight:700;font-size:14px;border:1.5px solid #0ea5a5;background:#fff}

    .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
    .card{background:#fff;border-radius:18px;padding:22px;border:1px solid rgba(0,0,0,.06);box-shadow:0 10px 26px rgba(10,20,40,.08)}
    .card h3{margin:6px 0 8px;font-size:18px}
    .card p{margin:0;color:#475569;font-size:15px}

    .portfolio .grid{grid-template-columns:repeat(3,1fr)}
    .work{border-radius:18px;overflow:hidden;background:linear-gradient(135deg,var(--c1),var(--c2));color:#fff;position:relative}
    .work .meta{position:absolute;inset:auto 0 0 0;padding:16px;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.55) 100%)}
    .work h4{margin:0 0 4px;font-size:18px}
    .tags{display:flex;gap:8px;flex-wrap:wrap}
    .tag{padding:6px 10px;border-radius:9999px;background:rgba(255,255,255,.18);font-weight:700;font-size:12px}
    .placeholder{height:200px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;letter-spacing:.08em;filter:drop-shadow(0 8px 20px rgba(0,0,0,.2))}

    footer{padding:56px 0;background:#0b1220;color:#e5eefb}
    footer .row{display:flex;align-items:center;justify-content:space-between;gap:24px}
    footer .social{display:flex;gap:12px}
    footer .social a{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:rgba(255,255,255,.06);color:#e5eefb}

    .bubble{position:absolute;border-radius:9999px;filter:blur(2px) drop-shadow(0 18px 30px rgba(15,30,60,.35));pointer-events:none;z-index:-1;opacity:.9}
    .b1{width:420px;height:420px;right:-120px;top:-160px;background:radial-gradient(circle at 30% 30%, #6df1f0, var(--c1) 40%, rgba(98,227,226,.6) 60%, rgba(98,227,226,0) 72%)}
    .b2{width:300px;height:300px;left:-120px;top:260px;background:radial-gradient(circle at 60% 40%, #4b8cf2, var(--c2) 50%, rgba(42,120,233,.6) 70%, rgba(42,120,233,0) 82%)}
    .b3{width:360px;height:360px;right:10%;top:40%;background:radial-gradient(circle at 50% 50%, #5ce6e4, var(--c1) 45%, rgba(98,227,226,0) 70%)}
    .b4{width:260px;height:260px;left:12%;bottom:-120px;background:radial-gradient(circle at 30% 30%, #3f86ff, var(--c2) 55%, rgba(42,120,233,0) 78%)}

    .ticker-wrap{padding:36px 0;background:linear-gradient(180deg,#f7fbff 0%, rgba(98,227,226,.08) 100%)}
    .ticker-title{margin:0 0 18px;text-align:center;font-weight:800;color:#0f172a;font-size:clamp(22px,2.4vw,28px)}
    .ticker{position:relative;overflow:hidden;border-radius:9999px;background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.06);padding:6px 8px;box-shadow:0 18px 36px rgba(15,30,60,.12), 0 6px 12px rgba(15,30,60,.08)}
    .ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:1;pointer-events:none}
    .ticker::before{left:0;background:linear-gradient(90deg,#fff 0%, rgba(255,255,255,0) 100%)}
    .ticker::after{right:0;background:linear-gradient(-90deg,#fff 0%, rgba(255,255,255,0) 100%)}
    .ticker-track{display:flex;align-items:center;gap:48px;padding:18px 0;white-space:nowrap;animation:ticker 28s linear infinite}
    .tlogo{flex:0 0 auto}
    .tlogo img{height:34px;width:auto;display:block;filter:grayscale(100%);opacity:.9;transition:opacity .25s ease, filter .25s ease}
    .tlogo img:hover{filter:none;opacity:1}
    @keyframes ticker{from{transform:translateX(0)} to{transform:translateX(-50%)}}

    @media (max-width:1000px){.about{grid-template-columns:1fr}.portfolio .grid{grid-template-columns:repeat(2,1fr)}}
    @media (max-width:640px){.portfolio .grid{grid-template-columns:1fr}.grid{grid-template-columns:1fr}.hero{padding-top:72px}}

.hero {

  margin-bottom: clamp(64px, 12vh, 200px);
}
.clients {

  margin-bottom: clamp(160px, 18vh, 320px);
}
#sluzby {

  padding-top: clamp(360px, 26vh, 720px);
  background: var(--page-bg) !important;
}
@media (min-aspect-ratio: 21/9) {
  .clients { margin-bottom: clamp(220px, 22vh, 420px); }
  #sluzby { padding-top: clamp(420px, 30vh, 840px); }
}
@media (max-width: 640px) {
  .hero { margin-bottom: 48px; }
  .clients { margin-bottom: 96px; }
  #sluzby { padding-top: 96px; }
}

#sluzby {

  padding-top: clamp(200px, 14vh, 340px);
  background: var(--page-bg) !important;
}
@media (max-width: 640px) {

  #sluzby { padding-top: 72px; }
}

#sluzby {

  padding-top: clamp(64px, 12vh, 180px);

  background: var(--page-bg) !important;
}
@media (max-width: 640px) {
  #sluzby { padding-top: 56px; }
}

#sluzby {

}
@media (max-width: 640px) {
  #sluzby {  }
}

#sluzby {

}
@media (max-width: 640px) {
  #sluzby {  }
}

:root { --page-bg: #ffffff; }
body { background: var(--page-bg); }

.hero-bubbles { display: none !important; }
.hero::before, .hero::after { content: none !important; display: none !important; }

.hero, .clients, #sluzby { background: var(--page-bg) !important; }

:root { --page-bg: #ffffff; }
body { background: var(--page-bg) !important; }

.hero, .clients, #sluzby {
  background: var(--page-bg) !important;
  background-image: none !important;
}
.hero, .clients { overflow: hidden !important; }

.hero::before, .hero::after,
.clients::before, .clients::after,
#sluzby::before, #sluzby::after {
  content: none !important;
  display: none !important;
}

[class*="bubble"], [class*="bubbles"] {
  display: none !important;
  background: none !important;
  box-shadow: none !important;
  filter: none !important;
}

:root {
  --bgA: #ffffff;
  --bgB: #e1efff;
}
main > section {
  position: relative;
  z-index: 0;
  background: var(--bgA);
}
main > section:nth-of-type(even) { background: var(--bgB); }

main > section::before,
main > section::after {
  content: "" !important;
  position: absolute;
  left: 0;
  right: 0;
  height: 160px;
  pointer-events: none;
  z-index: -1;
}

main > section {
  --prev: var(--bgB);
  --current: var(--bgA);
  --next: var(--bgB);
}
main > section:nth-of-type(even) {
  --prev: var(--bgA);
  --current: var(--bgB);
  --next: var(--bgA);
}

main > section::before { top: -160px; background: linear-gradient(to bottom, var(--prev) 0%, var(--prev) 35%, var(--current) 100%); }

main > section::after { bottom: -160px; background: linear-gradient(to bottom, var(--current) 0%, var(--current) 65%, var(--next) 100%); }

main > section:first-of-type::before { display: none; }
main > section:last-of-type::after { display: none; }

[class*="bubble"], [class*="bubbles"] { display: none !important; }
.hero-bubbles { display: none !important; }

main > section { position: relative; isolation: isolate; }
main > section * { position: relative; z-index: 2; }
main > section::before, main > section::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 220px;
  pointer-events: none;
  z-index: 1;
}

main > section::before { top: -220px; background: linear-gradient(to bottom, var(--prev) 0%, var(--prev) 45%, var(--current) 100%); }

main > section::after  { bottom: -220px; background: linear-gradient(to bottom, var(--current) 0%, var(--current) 55%, var(--next) 100%); }

main > section:first-of-type::before { display: none; }
main > section:last-of-type::after { display: none; }

main > section { position: relative; isolation: isolate; background-clip: padding-box; }

main > section { --prev: var(--bgB); --current: var(--bgA); --next: var(--bgB); }
main > section:nth-of-type(even) { --prev: var(--bgA); --current: var(--bgB); --next: var(--bgA); }

main > section::before, main > section::after {
  content: "" !important;
  display: block !important;
  position: absolute;
  left: 0; right: 0;
  height: 280px;
  pointer-events: none;
  z-index: 1 !important;
}

main > section::before { top: -280px; background: linear-gradient(to bottom, var(--prev) 0%, var(--prev) 35%, var(--current) 100%) !important; }
main > section::after  { bottom: -280px; background: linear-gradient(to bottom, var(--current) 0%, var(--current) 65%, var(--next) 100%) !important; }

main > section:first-of-type::before { display: none !important; }
main > section:last-of-type::after   { display: none !important; }

.hero, .clients, #sluzby { background-image: none !important; }

.hero, .clients, #sluzby, main > section { overflow: visible !important; }

main > section { position: relative; isolation: isolate; z-index: 0; }
main > section > * { position: relative; z-index: 2; }

:root { --bgA: #ffffff; --bgB: #e1efff; }
main > section { background: var(--bgA); }
main > section:nth-of-type(even) { background: var(--bgB); }

main > section::before, main > section::after {
  content: "" !important;
  position: absolute;
  left: 0; right: 0;
  height: 320px;
  pointer-events: none;
  z-index: 1 !important;
}
main > section { --prev: var(--bgB); --current: var(--bgA); --next: var(--bgB); }
main > section:nth-of-type(even) { --prev: var(--bgA); --current: var(--bgB); --next: var(--bgA); }

main > section::before {
  top: -320px;
  background: linear-gradient(to bottom,
    var(--prev) 0%,
    color-mix(in srgb, var(--prev) 80%, transparent) 45%,
    var(--current) 100%) !important;
}

main > section::after {
  bottom: -320px;
  background: linear-gradient(to bottom,
    var(--current) 0%,
    color-mix(in srgb, var(--current) 70%, transparent) 55%,
    var(--next) 100%) !important;
}

main > section:first-of-type::before { display: none !important; }
main > section:last-of-type::after { display: none !important; }

:root {
  --bgA: #ffffff;
  --bgB: #dfeaff;
  --fadeH: 420px;
}

main > section {
  position: relative !important;
  isolation: isolate !important;
  background: var(--bgA) !important;
  border: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}
main > section:nth-of-type(even) { background: var(--bgB) !important; }

.hero, .clients, #sluzby {
  border: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

.hero, .clients, #sluzby, main > section { overflow: visible !important; }

main > section { --prev: var(--bgB); --current: var(--bgA); --next: var(--bgB); }
main > section:nth-of-type(even) { --prev: var(--bgA); --current: var(--bgB); --next: var(--bgA); }

main > section::before,
main > section::after {
  content: "" !important;
  position: absolute !important;
  left: 0; right: 0;
  height: var(--fadeH) !important;
  z-index: 1 !important;
  pointer-events: none !important;
  will-change: transform;
}

main > section::before {
  top: calc(var(--fadeH) * -1) !important;
  background: linear-gradient(
    to bottom,
    var(--prev) 0%,
    color-mix(in srgb, var(--prev) 90%, var(--current) 10%) 35%,
    color-mix(in srgb, var(--prev) 40%, var(--current) 60%) 70%,
    var(--current) 100%
  ) !important;
}

main > section::after {
  bottom: calc(var(--fadeH) * -1) !important;
  background: linear-gradient(
    to bottom,
    var(--current) 0%,
    color-mix(in srgb, var(--current) 60%, var(--next) 40%) 30%,
    color-mix(in srgb, var(--current) 10%, var(--next) 90%) 70%,
    var(--next) 100%
  ) !important;
}

main > section:first-of-type::before { display: none !important; }
main > section:last-of-type::after { display: none !important; }

main > section > * { position: relative; z-index: 2 !important; }

@supports not (background: color-mix(in srgb, #fff 50%, #000 50%)) {
  main > section::before { background: linear-gradient(to bottom, var(--prev) 0%, var(--current) 100%) !important; }
  main > section::after  { background: linear-gradient(to bottom, var(--current) 0%, var(--next) 100%) !important; }
}

:root {
  --circle-blue: #2f7dff;
  --circle-cyan: #2fe6d8;
  --circle-blue-soft: rgba(47,125,255,0.32);
  --circle-cyan-soft: rgba(47,230,216,0.28);
  --line-soft: rgba(47,125,255,0.16);
}

main > section {
  background-image:
    radial-gradient(320px 320px at 8% 18%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(380px 380px at 95% 16%, var(--circle-cyan-soft), transparent 70%),
    radial-gradient(240px 240px at 92% 86%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(300px 300px at 2% 88%, var(--circle-cyan-soft), transparent 70%),
    repeating-linear-gradient(135deg, var(--line-soft) 0 2px, transparent 2px 46px) !important;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat !important;
  background-blend-mode: normal !important;
}

main > section:nth-of-type(even) {
  background-image:
    radial-gradient(300px 300px at 92% 22%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(420px 420px at 12% 10%, var(--circle-cyan-soft), transparent 70%),
    radial-gradient(220px 220px at 12% 86%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(320px 320px at 100% 92%, var(--circle-cyan-soft), transparent 70%),
    repeating-linear-gradient(45deg, var(--line-soft) 0 2px, transparent 2px 46px) !important;
}

.hero, .clients, #sluzby, #onas, #portfolio, #kontakt {
  background-image:
    radial-gradient(320px 320px at 8% 18%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(380px 380px at 95% 16%, var(--circle-cyan-soft), transparent 70%),
    radial-gradient(240px 240px at 92% 86%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(300px 300px at 2% 88%, var(--circle-cyan-soft), transparent 70%),
    repeating-linear-gradient(135deg, var(--line-soft) 0 2px, transparent 2px 46px) !important;
}

main > section { position: relative; }
main > section > * { position: relative; z-index: 2; }

main > section { background-image: none !important; background-blend-mode: normal !important; }

footer#kontakt {
  --panel-bg: rgba(255,255,255,0.08);
  --panel-border: rgba(255,255,255,0.12);
  position: relative;
  color: #e9f0ff;
  padding-top: 72px;
}
footer#kontakt .contact-wrap {
  padding: 40px 0 8px;
}
footer#kontakt .section-title.big {
  font-size: clamp(28px, 2.4vw + 16px, 40px);
  font-weight: 900;
  letter-spacing: .02em;
  margin: 0 0 22px;
}
footer#kontakt .quote-form {
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 22px;
  padding: clamp(16px, 2vw, 28px);
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
}
footer#kontakt .quote-form .grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
footer#kontakt .quote-form .field {
  grid-column: span 12;
  display: grid;
  gap: 8px;
}
footer#kontakt .quote-form .field > span {
  opacity: .9;
  font-weight: 600;
  font-size: 14px;
}
footer#kontakt .quote-form input,
footer#kontakt .quote-form textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: #f6f9ff;
  border-radius: 14px;
  padding: 14px 16px;
  outline: none;
  font: inherit;
}
footer#kontakt .quote-form textarea { min-height: 120px; }
footer#kontakt .quote-form input::placeholder,
footer#kontakt .quote-form textarea::placeholder { color: #e9f0ff; opacity: .7; }

@media (min-width: 900px) {
  footer#kontakt .quote-form .field:nth-child(1),
  footer#kontakt .quote-form .field:nth-child(2),
  footer#kontakt .quote-form .field:nth-child(3) { grid-column: span 4; }
  footer#kontakt .quote-form .field--textarea { grid-column: 1 / -1; }
}

footer#kontakt .form-bottom{
  margin-top: 14px;
  display:flex;align-items:center;gap:16px;justify-content:space-between;
  flex-wrap: wrap;
}
footer#kontakt .form-bottom small { opacity: .8; }
footer#kontakt .cta{
  margin-top: 12px;
  background: linear-gradient(180deg,var(--btn-base2),var(--btn-base));
  color: #fff;
  border-radius: 999px;
  padding: 14px 26px;
  border: none;
  position: relative;
  box-shadow: 0 10px 18px rgba(37, 99, 235, 0.20);
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease, filter .2s ease;
}
footer#kontakt .cta::after{
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(60% 60% at 0% 0%, rgba(255,255,255,0.55), rgba(255,255,255,0) 60%);
  filter: blur(12px);
  transform: translateX(-20%);
  transition: transform .4s ease;
}
footer#kontakt .cta:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(37, 99, 235, 0.28);
  filter: saturate(1.15);
}
footer#kontakt .cta:hover::after{ transform: translateX(15%); }

footer#kontakt .cta:hover { opacity:.95; }

footer#kontakt .footer-mini { margin-top: 36px; }
footer#kontakt .steps { list-style:none; padding: 18px 0 0; margin: 0; display:grid; grid-template-columns: repeat(3,1fr); gap:12px; opacity:.95; }
footer#kontakt .steps li { background: var(--panel-bg); border:1px solid var(--panel-border); border-radius:14px; padding:12px 14px; }
footer#kontakt .steps b { font-weight:900; margin-right:10px; opacity:.9;}

.hero, #hero {
  --circle-blue-soft: rgba(47,125,255,0.28);
  --circle-cyan-soft: rgba(47,230,216,0.24);
  --line-soft: rgba(47,125,255,0.12);
  background-image:
    radial-gradient(320px 320px at 8% 18%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(380px 380px at 92% 12%, var(--circle-cyan-soft), transparent 70%),
    radial-gradient(240px 240px at 92% 86%, var(--circle-blue-soft), transparent 70%),
    radial-gradient(300px 300px at 2% 88%, var(--circle-cyan-soft), transparent 70%),
    repeating-linear-gradient(135deg, var(--line-soft) 0 2px, transparent 2px 46px) !important;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat !important;
}

#kontakt {
  --circle-blue-soft: rgba(47,125,255,0.30);
  --circle-cyan-soft: rgba(47,230,216,0.26);
  --line-soft: rgba(47,125,255,0.14);
  background-image:
    radial-gradient(360px 360px at 12% 20%, var(--circle-cyan-soft), transparent 70%),
    radial-gradient(300px 300px at 88% 78%, var(--circle-blue-soft), transparent 70%),
    repeating-linear-gradient(45deg, var(--line-soft) 0 2px, transparent 2px 46px) !important;
  background-repeat: no-repeat, no-repeat, repeat !important;
}

:root { --bridge-bg: #f3fbff; }

.hero, #hero {
  position: relative;
  margin-bottom: 0 !important;
  padding-bottom: clamp(80px, 12vh, 200px) !important;
  overflow: visible;
  z-index: 0;
}
.hero::after, #hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -140px;
  height: 140px;
  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, var(--bridge-bg) 100%);
  pointer-events: none;
  z-index: -1;
}
.clients { margin-top: 0 !important; }

#sluzby, #onas,
main > section#sluzby, main > section#onas {
  background: #ffffff !important;
  background-image: none !important;
  background-blend-mode: normal !important;
}
#sluzby::before, #sluzby::after,
#onas::before, #onas::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

:root { --bridge-bg: #eef7ff; }

.hero, #hero {
  padding-bottom: clamp(120px, 16vh, 260px) !important;
}
.hero::after, #hero::after {
  bottom: -180px;
  height: 180px;
  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, var(--bridge-bg) 100%);
}

.clients {
  position: relative;
  margin-top: 0 !important;
  padding-top: clamp(48px, 6vh, 96px) !important;
  padding-bottom: clamp(120px, 12vh, 200px) !important;
  z-index: 0;
}
.clients::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 0;
  height: 200px;
  background: linear-gradient(to bottom, var(--bridge-bg) 0%, #ffffff 100%);
  pointer-events: none;
  z-index: -1;
}

#sluzby, #onas,
main > section#sluzby, main > section#onas {
  background: #ffffff !important;
  background-image: none !important;
}
#sluzby::before, #sluzby::after,
#onas::before, #onas::after { content: none !important; }

:root { --bridge-bg: #e9f4ff; }

.hero, #hero {
  position: relative;
  isolation: isolate;
  padding-bottom: clamp(180px, 22vh, 360px) !important;
}
.hero > * { position: relative; z-index: 2; }
.hero::after, #hero::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -220px;
  height: 220px;

  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(233,244,255,0.85) 65%, var(--bridge-bg) 100%);
  pointer-events: none;
  z-index: 1;
}

.clients {
  position: relative;
  isolation: isolate;
  margin-top: 0 !important;
  padding-top: clamp(72px, 10vh, 140px) !important;
  padding-bottom: clamp(160px, 18vh, 280px) !important;
  background-color: var(--bridge-bg) !important;
}
.clients > * { position: relative; z-index: 2; }
.clients::before {

  content: "";
  position: absolute;
  left: 0; right: 0;
  top: -1px;
  height: 160px;
  background: linear-gradient(to bottom, var(--bridge-bg) 0%, rgba(233,244,255,0.85) 60%, rgba(233,244,255,0) 100%);
  pointer-events: none;
  z-index: 1;
}
.clients::after {

  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 0;
  height: 260px;
  background: linear-gradient(to bottom, var(--bridge-bg) 0%, rgba(255,255,255,0.7) 55%, #ffffff 100%);
  pointer-events: none;
  z-index: 1;
}

:root { --bridge-bg: #e9f4ff; }

.clients {
  position: relative;
  z-index: 0;
}
.clients::after {
  content: "" !important;
  position: absolute;
  left: 0; right: 0;
  bottom: -1px;
  height: 320px;
  background: linear-gradient(to bottom, var(--bridge-bg) 0%, rgba(255,255,255,0.75) 50%, #ffffff 100%);
  pointer-events: none;
  z-index: 1;
}

#sluzby { position: relative; z-index: 0; background: #ffffff !important; }
#sluzby::before {
  content: "" !important;
  position: absolute;
  left: 0; right: 0;
  top: -160px;
  height: 160px;
  background: linear-gradient(to bottom, rgba(233,244,255,0.8) 0%, rgba(233,244,255,0.35) 40%, rgba(233,244,255,0) 100%);
  pointer-events: none;
  z-index: 0;
}

.clients {
  position: relative;
  z-index: 0;
}

.clients::after {
  content: "" !important;
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 200vh;
  background: var(--bridge-bg, #e9f4ff);
  pointer-events: none;
  z-index: 0;
}

#sluzby {
  position: relative;
  background: transparent !important;
  background-image: none !important;
  z-index: 1;
}
#sluzby::before, #sluzby::after { content: none !important; }

:root { --bridge-bg: #e9f4ff; }

#sluzby {
  position: relative !important;
  background: transparent !important;
}

main > section#sluzby::before,
#sluzby::before {
  content: "" !important;
  position: absolute !important;
  left: 0; right: 0;
  top: -160px;
  height: calc(100% + 320px);
  background: var(--bridge-bg) !important;
  z-index: -1 !important;
  pointer-events: none !important;
}

.clients { overflow: visible !important; }

:root { --bridge-bg: #e9f4ff; }

main > section#sluzby,
#sluzby {
  position: relative !important;
  background-color: var(--bridge-bg) !important;
  background-image: none !important;
  background: var(--bridge-bg) !important;
  z-index: 0 !important;
}

main > section#sluzby::before,
main > section#sluzby::after,
#sluzby::before, #sluzby::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

:root { --unified-blue-bg: #e9f4ff; }

.clients, #sluzby, main > section#sluzby {
  background: var(--unified-blue-bg) !important;
  background-image: none !important;
  background-color: var(--unified-blue-bg) !important;
}

.clients::before, .clients::after,
#sluzby::before, #sluzby::after,
main > section#sluzby::before, main > section#sluzby::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

:root { --bridge-bg: var(--unified-blue-bg); }

:root {
  --unified-blue-bg: #eaf4ff;
  --bridge-bg: var(--unified-blue-bg);
}

.clients, #sluzby, main > section#sluzby {
  background: var(--unified-blue-bg) !important;
  background-color: var(--unified-blue-bg) !important;
  background-image: none !important;
  box-shadow: none !important;
}
.clients::before, .clients::after,
#sluzby::before, #sluzby::after,
main > section#sluzby::before, main > section#sluzby::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

#sluzby {
  position: relative !important;
  z-index: 0;
}
#sluzby > .bg-fix, .clients > .bg-fix { display: none; }
#sluzby::marker { content: ""; }

section.clients::before, section.clients::after,
section#sluzby::before, section#sluzby::after { content:none !important; display:none !important; background:none !important; }

:root { --unified-blue-bg: #eaf4ff; }
section.bg-unified {
  position: relative !important;
  background: var(--unified-blue-bg) !important;
  background-color: var(--unified-blue-bg) !important;
  background-image: none !important;
  box-shadow: none !important;
  z-index: 0 !important;
}
section.bg-unified::before,
section.bg-unified::after {
  content: none !important;
  display: none !important;
  background: none !important;
}
section.bg-unified > div[style*="background"],
section.bg-unified > .container,
section.bg-unified [class*="bg"],
section.bg-unified [style*="background-image"],
section.bg-unified [style*="background:"] {
  background: transparent !important;
  background-image: none !important;
}

.hero, #hero {
  position: relative;
  width: calc(100% - 48px);
  margin: 24px auto;
  border-radius: 36px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0, 30, 90, 0.12);
  padding: clamp(40px, 8vw, 96px) clamp(24px, 6vw, 64px);
}

.hero::after, #hero::after {
  content: none !important;
  display: none !important;
}

.hero > *, #hero > * { position: relative; z-index: 2; }

.hero, #hero {
  width: calc(100% - 80px) !important;
  margin: 40px auto !important;
  border-radius: 48px !important;
  border: 3px solid #2ea5ff !important;
  box-shadow: 0 14px 48px rgba(0, 30, 90, 0.14) !important;
}

@media (min-resolution: 2dppx) {
  .hero, #hero {
    box-shadow: 0 14px 48px rgba(0, 30, 90, 0.14), 0 0 0 1px rgba(46,165,255,0.15);
  }
}

.hero, #hero {

  padding: clamp(36px, 7vw, 88px) clamp(24px, 5vw, 56px) clamp(12px, 2.8vw, 28px) clamp(24px, 5vw, 56px) !important;
}

.hero, #hero {
  padding: clamp(36px, 7vw, 88px) clamp(24px, 5vw, 56px) clamp(28px, 4.5vw, 48px) clamp(24px, 5vw, 56px) !important;
}

.hero, #hero {
  padding: clamp(36px, 7vw, 88px) clamp(24px, 5vw, 56px) clamp(40px, 6vw, 72px) clamp(24px, 5vw, 56px) !important;
}

section.force-white-bg {
  position: relative !important;
  isolation: isolate !important;
  background: #ffffff !important;
  background-color: #ffffff !important;
  background-image: none !important;
  box-shadow: none !important;
  z-index: 0 !important;
}
section.force-white-bg::before,
section.force-white-bg::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

section.force-white-bg [style*="background"],
section.force-white-bg [style*="background-image"],
section.force-white-bg [class*="bg"] {
  background: transparent !important;
  background-image: none !important;
}

section.force-white-bg {
  margin-top: clamp(16px, 3vw, 40px) !important;
}

.hero, #hero {
  padding: clamp(36px, 7vw, 88px) clamp(24px, 5vw, 56px) clamp(56px, 7vw, 96px) clamp(24px, 5vw, 56px) !important;
}

.hero, #hero {
  padding: clamp(36px, 7vw, 88px) clamp(24px, 5vw, 56px) clamp(72px, 9vw, 128px) clamp(24px, 5vw, 56px) !important;
}

:root { --header-h: 84px;  }

.hero, #hero {

  min-height: calc(100svh - var(--header-h) - 80px) !important;
  overflow: clip !important;
}

@media (min-aspect-ratio: 21/9) {
  .hero, #hero {
    min-height: calc(100svh - var(--header-h) - 72px) !important;
  }
}

@media (max-height: 820px) {
  .hero, #hero {
    min-height: max(640px, calc(100svh - var(--header-h) - 64px)) !important;
  }
}

html { scroll-padding-top: var(--header-h); }

:root{
  --header-h: 84px;
  --clients-fold: clamp(220px, 24vh, 320px);
  --fold-gap: clamp(16px, 2.8vh, 28px);
}

.hero, #hero{
  min-height: calc(100svh - var(--header-h) - var(--clients-fold) - var(--fold-gap)) !important;
  overflow: clip !important;
}

section.clients, .clients{
  min-height: var(--clients-fold) !important;
  margin-top: var(--fold-gap) !important;
  margin-bottom: 0 !important;
  overflow: clip !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --clients-fold: clamp(220px, 22vh, 340px); }
}

@media (max-height: 820px){
  :root{ --clients-fold: clamp(220px, 28vh, 340px); }
}

html{ scroll-padding-top: var(--header-h); }

:root{
  --fold-fudge: 14px;
}

.hero, #hero{
  min-height: calc(100svh - var(--header-h) - var(--clients-fold) - var(--fold-gap) + var(--fold-fudge)) !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --fold-fudge: 18px; }
}

:root{
  --fold-fudge: 14px;
}

.hero, #hero{
  min-height: calc(100svh - var(--header-h) - var(--clients-fold) - var(--fold-gap)) !important;
}

section.clients, .clients{
  min-height: calc(var(--clients-fold) + var(--fold-fudge)) !important;
  margin-bottom: 0 !important;
  overflow: clip !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --fold-fudge: 18px; }
}

:root{
  --fold-fudge: 36px;
}

section.clients, .clients{
  padding-bottom: 12px !important;
  min-height: calc(var(--clients-fold) + var(--fold-fudge)) !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --fold-fudge: 42px; }
}

:root{
  --fold-fudge: 56px;
}

section.clients, .clients{
  padding-bottom: 16px !important;
  min-height: calc(var(--clients-fold) + var(--fold-fudge)) !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --fold-fudge: 64px; }
}

:root{
  --fold-fudge: 66px;
}

section.clients, .clients{
  padding-bottom: 18px !important;
  min-height: calc(var(--clients-fold) + var(--fold-fudge)) !important;
}

@media (min-aspect-ratio: 21/9){
  :root{ --fold-fudge: 74px; }
}

.card{background:#fff;border-radius:18px;padding:22px;border:1px solid rgba(0,0,0,.06);box-shadow:0 10px 26px rgba(10,20,40,.08)}
    .card h3{margin:6px 0 8px;font-size:18px}
    .card p{margin:0;color:#475569;font-size:15px}

    .portfolio .grid{grid-template-columns:repeat(3,1fr)}
    .work{border-radius:18px;overflow:hidden;background:linear-gradient(135deg,var(--c1),var(--c2));color:#fff;position:relative}
    .work .meta{position:absolute;inset:auto 0 0 0;padding:16px;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.55) 100%)}
    .work h4{margin:0 0 4px;font-size:18px}
    .tags{display:flex;gap:8px;flex-wrap:wrap}
    .tag{padding:6px 10px;border-radius:9999px;background:rgba(255,255,255,.18);font-weight:700;font-size:12px}
    .placeholder{height:200px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;letter-spacing:.08em;filter:drop-shadow(0 8px 20px rgba(0,0,0,.2))}

    footer{padding:56px 0;background:#0b1220;color:#e5eefb}
    footer .row{display:flex;align-items:center;justify-content:space-between;gap:24px}
    footer .social{display:flex;gap:12px}
    footer .social a{width:40px;height:40px;disp

  #sluzby .about .grid, #sluzby .about .card{ position:relative; z-index:1; }

.bubble--front{ z-index: 5 !important; pointer-events: none; }
.boundary-ball{
  position: absolute;
  width: 520px;
  height: 520px;
  left: 50%;
  bottom: -180px;
  transform: translateX(-25%);
  border-radius: 9999px;
  background: radial-gradient(circle at 50% 50%, rgba(63,134,255,0.95), rgba(63,134,255,0.55) 35%, rgba(63,134,255,0.18) 65%, rgba(63,134,255,0.0) 78%);
  filter: blur(0.5px) drop-shadow(0 8px 60px rgba(30, 64, 175, 0.35));
  opacity: .95;
}
@media (max-width: 768px){
  .boundary-ball{
    width: 360px;
    height: 360px;
    bottom: -140px;
    transform: translateX(-40%);
  }
}

section#sluzby{ position: relative !important; overflow: visible !important; }
.bubble{ position:absolute; border-radius:9999px; pointer-events:none; }
.bubble--front{ z-index: 9 !important; }
.services-boundary-ball{
  position: absolute;
  width: 560px;
  height: 560px;
  left: 18%;
  top: 220px;
  border-radius: 9999px;
  background: radial-gradient(circle at 50% 50%, rgba(63,134,255,0.96), rgba(63,134,255,0.55) 38%, rgba(63,134,255,0.18) 66%, rgba(63,134,255,0.0) 78%);
  filter: drop-shadow(0 18px 80px rgba(30, 64, 175, 0.35));
  opacity: .96;
}
@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }
}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }
}

section#sluzby{ position:relative !important; overflow:visible !important; isolation:auto; }
.services-boundary-ball{ z-index: 99 !important; will-change: transform; }

#sluzby
.services-text-ball{
  position:absolute;
  width: 420px;
  height: 420px;
  left: -48px;
  top: 160px;
  border-radius:9999px;
  background: radial-gradient(circle at 50% 50%, rgba(63,134,255,0.95), rgba(63,134,255,0.50) 36%, rgba(63,134,255,0.16) 64%, rgba(63,134,255,0.0) 78%);
  filter: drop-shadow(0 18px 80px rgba(30, 64, 175, 0.30));
  opacity:.96;
  z-index: 1;
  pointer-events:none;
}
@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }
}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }
}

#sluzby{ position:relative !important; overflow:visible !important; }
#sluzby
#orb-services-left{
  position:absolute !important;
  width: 460px;
  height: 460px;
  left: -56px;
  top: 200px;
  border-radius:9999px;
  background: radial-gradient(circle at 50% 50%, rgba(63,134,255,0.96), rgba(63,134,255,0.55) 36%, rgba(63,134,255,0.16) 64%, rgba(63,134,255,0.0) 78%) !important;
  filter: drop-shadow(0 20px 90px rgba(30,64,175,0.35));
  opacity: .98;
  z-index: 9999 !important;
  pointer-events: none;
}
@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }
}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }
}

#sluzby
#sluzby .container.about > div:first-child::after{
  content:"" !important;
  position:absolute !important;
  width: 520px;
  height: 520px;
  left: -40px;
  top: 140px;
  border-radius: 9999px;
  background: radial-gradient(circle at 50% 50%, rgba(63,134,255,0.96), rgba(63,134,255,0.52) 38%, rgba(63,134,255,0.18) 64%, rgba(63,134,255,0) 78%) !important;
  filter: drop-shadow(0 22px 96px rgba(30,64,175,0.35));
  opacity: .98;
  z-index: 1 !important;
  pointer-events:none;
}
@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }
}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }
}

#sluzby{ position:relative !important; }

#sluzby

@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }

}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }

}

#sluzby .container.about > div:first-child{ position:relative; }
.decor-orb{ position:absolute; left:auto; right:-220px; top:140px; width:520px; height:520px; transform:none; z-index:1; pointer-events:none; }
.decor-orb svg{ display:block; width:100%; height:100%; }

@media (max-width: 1024px){ .decor-orb{ width:420px; height:420px; right:-160px; top:150px; left:auto; transform:none; } } } }
}
@media (max-width: 640px){ .decor-orb{ width:320px; height:320px; right:-110px; top:160px; left:auto; transform:none; } } } }
}

#sluzby .container.about{
  grid-template-columns: minmax(0,1fr) minmax(0,1.25fr) !important;
}
#sluzby .about .grid .card p{
  max-width: none !important;
}
@media (max-width: 1100px){
  #sluzby .container.about{
    grid-template-columns: minmax(0,1fr) minmax(0,1.15fr) !important;
  }
}

@media (min-width: 1100px){
  #sluzby .about .grid{
    display:grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }
}

\n

\n\n\n\n\n\n\n\n

#sluzby{ position: relative; }
#sluzby::before{
  content:"";
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 0;
  border-top: 6px dashed var(--btn-base, #2f86f6);
  opacity: .55;
  pointer-events: none;
  z-index: 2;
}
\n

#sluzby{ position:relative; }
#sluzby .connectors{
  position:absolute; inset:0;
  z-index:3; pointer-events:none; overflow:visible;
  color: var(--btn-base, #2f86f6);
}
\n

#sluzby{ position:relative; }
#sluzby .connectors{ position:absolute; inset:0; z-index:0; pointer-events:none; color:var(--btn-base,#2f86f6); }
#sluzby .card{ position:relative; z-index:2; }

:where(header, .header, #header, .site-header, .main-header)::before{
  content: "";
  position: absolute;
  top: -120px;
  left: -140px;
  width: 400px;
  height: 400px;
  border-radius: 50%;

  background: radial-gradient(ellipse at 38% 38%,
    rgba(0, 232, 220, 0.50) 0%,
    rgba(0, 232, 220, 0.28) 48%,
    rgba(0, 232, 220, 0.14) 72%,
    rgba(0, 232, 220, 0.06) 88%,
    rgba(0, 232, 220, 0.00) 100%);

  filter: saturate(108%) blur(14px);

  -webkit-mask-image: radial-gradient(ellipse at 38% 38%, #000 0%, rgba(0,0,0,.9) 60%, rgba(0,0,0,.2) 85%, transparent 100%);
          mask-image: radial-gradient(ellipse at 38% 38%, #000 0%, rgba(0,0,0,.9) 60%, rgba(0,0,0,.2) 85%, transparent 100%);
  z-index: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}

:where(header, .header, #header, .site-header, .main-header){
  position: relative;
  isolation: isolate;
}
:where(header, .header, #header, .site-header, .main-header) > *{
  position: relative;
  z-index: 1;
}
:where(header, .header, #header, .site-header, .main-header)::before{
  content: "";
  position: absolute;
  top: -100px;
  left: -120px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(ellipse at 40% 40%,
    rgba(0, 232, 220, 0.55) 0%,
    rgba(0, 232, 220, 0.28) 42%,
    rgba(0, 232, 220, 0.12) 62%,
    rgba(0, 232, 220, 0.00) 78%);
  filter: saturate(108%);
  z-index: 0;
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}
:where(header, .header, #header, .site-header, .main-header).is-scrolled::before{
  opacity: 0;
  transform: scale(.92);
}

:where(header, .header, #header, .site-header, .main-header){
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
:where(header, .header, #header, .site-header, .main-header) > *{
  position: relative;
  z-index: 1;
}

@media (max-width: 768px) {
  :where(header, .header, #header, .site-header, .main-header)::before{
    content: none !important;
    display: none !important;
    opacity: 0 !important;
  }
}

@media (max-width: 1024px){
  #sluzby, #sluzby .about, #sluzby .grid{ overflow: visible; max-width: 100%; }
  #sluzby .about{ padding-left: 16px; padding-right: 16px; }
  #sluzby .grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  #sluzby .card{ width: 100%; max-width: 680px; margin-left:auto; margin-right:auto; }
  #sluzby .connectors{ display: none; }
}

section#prace img,
section[id*="prace" i] img,
section .portfolio img,
section .works img,
section .work img,
section .project img,
section .slide img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

section#prace .slide::before,
section[id*="prace" i] .slide::before,
section#prace .work::before,
section[id*="prace" i] .work::before,
section#prace .project::before,
section[id*="prace" i] .project::before{
  opacity: .15 !important;
}


/* === Dark mode: keep originals in "Naše práce" (#prace) === */
html[data-theme="dark"] #prace img,
html[data-theme="dark"] #prace picture img,
html[data-theme="dark"] #prace video,
html[data-theme="dark"] #prace canvas,
html[data-theme="dark"] #prace svg,
html[data-theme="dark"] #prace .media,
html[data-theme="dark"] #prace [style*="background-image"]{
  filter: invert(1) hue-rotate(180deg) !important;
}



/* === Dark mode: FAQ arrows white === */
html[data-theme="dark"] #faq .faq-q .chev svg,
html[data-theme="dark"] #faq .faq-q .chev svg path,
html[data-theme="dark"] #faq .faq-q .chev svg line,
html[data-theme="dark"] #faq .faq-q .chev svg polyline{
  stroke: #fff !important;
  fill: none !important;
  color: #fff !important;
  opacity: 0.95;
}



/* === Dark mode: keep original logo colors (black text) === */
html[data-theme="dark"] .logo img{
  filter: invert(1) hue-rotate(180deg) !important;
}






/* Footer logo variants: white in light, black in dark */
.footer-logo--dark { display: none; }
html[data-theme="dark"] .footer-logo--light { display: none !important; }
html[data-theme="dark"] .footer-logo--dark { display: inline-block !important; }



/* Footer logo variants: white in light, black in dark (strong rules) */
/* start footer logo variants */
.footer-logo-img.footer-logo--dark { display: none !important; }
.footer-logo-img.footer-logo--light { display: inline-block !important; }

html[data-theme="dark"] .footer-logo-img.footer-logo--light { display: none !important; }
html[data-theme="dark"] .footer-logo-img.footer-logo--dark { display: inline-block !important; }
/* end footer logo variants */



/* === Dark mode: keep original colors in portfolio "Koncepty" === */
html[data-theme="dark"] #koncepty img,
html[data-theme="dark"] #koncepty picture img,
html[data-theme="dark"] #koncepty video,
html[data-theme="dark"] #koncepty canvas,
html[data-theme="dark"] #koncepty svg,
html[data-theme="dark"] #koncepty .shot,
html[data-theme="dark"] #koncepty .work-card .shot,
html[data-theme="dark"] #koncepty [style*="background-image"]{
  filter: invert(1) hue-rotate(180deg) !important;
}


.work-card {
  position: relative;
  overflow: hidden;
}




/* paint only strokes (SVG) */
html[data-theme="dark"] .hamburger svg line,
html[data-theme="dark"] .hamburger svg path,
html[data-theme="dark"] .hamburger svg polyline {
  stroke: #fff !important;
  fill: none !important;
  opacity: 1 !important;
}

/* paint only span-based bars (non-SVG hamburgers) */
html[data-theme="dark"] .hamburger .bar,
html[data-theme="dark"] .hamburger span,
html[data-theme="dark"] .menu-toggle span,
html[data-theme="dark"] .menu-btn span,
html[data-theme="dark"] .menu-button span {
  background: #fff !important;
}



html[data-theme="dark"] .hamburger *{ opacity: 0 !important; } /* hide original svg/spans */
html[data-theme="dark"] .hamburger::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 22px;          /* bar width */
  height: 14px;         /* total height for 3 bars */
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    #ffffff 0 2px,       /* bar thickness */
    transparent 2px 6px  /* gap */
  );
  border-radius: 2px;
  box-shadow: none;
  opacity: 1;
}





/* Dark mode: hamburger = white button with black lines */
html[data-theme="dark"] .hamburger,
html[data-theme="dark"] .menu-toggle,
html[data-theme="dark"] .menu-btn,
html[data-theme="dark"] .menu-button {
  background: #ffffff !important;
  color: #000 !important;
  border-radius: inherit;
  opacity: 1 !important;
}

/* Span-based bars -> black */
html[data-theme="dark"] .hamburger .bar,
html[data-theme="dark"] .hamburger span,
html[data-theme="dark"] .menu-toggle span,
html[data-theme="dark"] .menu-btn span,
html[data-theme="dark"] .menu-button span {
  background: #000 !important;
}

/* SVG-based bars -> black strokes, no fill */
html[data-theme="dark"] .hamburger svg { fill: none !important; }
html[data-theme="dark"] .hamburger svg line,
html[data-theme="dark"] .hamburger svg path,
html[data-theme="dark"] .hamburger svg rect,
html[data-theme="dark"] .hamburger svg polyline {
  stroke: #000 !important;
  fill: none !important;
  opacity: 1 !important;
}



/* Dark mode: draw hamburger bars explicitly (black lines on white button) */

html[data-theme="dark"] .hamburger::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 22px;
  height: 14px;
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    #000 0 2px,         /* line thickness */
    transparent 2px 6px /* gap */
  );
  border-radius: 0;
  opacity: 1;
}



/* keep overlay purely visual, preserve original button positioning */
html[data-theme="dark"] .hamburger::after{
  position: absolute !important;
  pointer-events: none !important;
}



/* === Static portfolio gallery === */
.portfolio-static-gallery {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
}

.portfolio-static-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.work-card > *:not(.portfolio-static-gallery) {
  position: relative;
  z-index: 2;
}
