/* ============================
   nousoos — pixel-perfect CSS
   Font: Basier Square
   Hero: pre-composited PNG image
   ============================ */

/* === Scroll Animations === */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-left{
  opacity:0;
  transform:translateX(-60px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.reveal-left.is-visible{
  opacity:1;
  transform:translateX(0);
}
.reveal-right{
  opacity:0;
  transform:translateX(60px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.reveal-right.is-visible{
  opacity:1;
  transform:translateX(0);
}
.reveal-scale{
  opacity:0;
  transform:scale(0.92);
  transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1), transform 0.9s cubic-bezier(0.16,1,0.3,1);
}
.reveal-scale.is-visible{
  opacity:1;
  transform:scale(1);
}
/* Stagger delays for children */
.stagger > *:nth-child(1){transition-delay:0s}
.stagger > *:nth-child(2){transition-delay:0.08s}
.stagger > *:nth-child(3){transition-delay:0.16s}
.stagger > *:nth-child(4){transition-delay:0.24s}
.stagger > *:nth-child(5){transition-delay:0.32s}
.stagger > *:nth-child(6){transition-delay:0.40s}

@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right,.reveal-scale{
    opacity:1;transform:none;transition:none;
  }
}

@font-face{font-family:'Basier Square';src:url('fonts/BasierSquare-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Basier Square';src:url('fonts/BasierSquare-RegularItalic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Basier Square';src:url('fonts/BasierSquare-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Basier Square';src:url('fonts/BasierSquare-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Basier Square';src:url('fonts/BasierSquare-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

:root{
  --bg:#fafafa;
  --fg:#0a0a0a;
  --muted:#6b6b6b;
  --font:'Basier Square',system-ui,sans-serif;
  --wrap:min(1500px,100%);
  --px:clamp(14px,1.4vw,32px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:#e5e5e5}
body{
  font-family:var(--font);background:var(--bg);color:var(--fg);
  line-height:1.4;-webkit-font-smoothing:antialiased;
  max-width:min(1500px,94vw);
  margin:3vw auto;
  border-radius:44px;
  clip-path:inset(0 round 44px);
}
/* Container-type moved off body so position:fixed overlay menu can escape to viewport */
footer{container-type:inline-size;container-name:card}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
i{font-style:normal;color:var(--fg);font-size:0.5em;vertical-align:0.05em;margin-left:0.08em}

.w{
  max-width:var(--wrap);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--px);
  padding-right:var(--px);
}

/* ============ NAV ============ */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--bg);
}
.nav .w{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:clamp(28px,3vw,56px);padding-bottom:clamp(18px,1.5vw,32px);
  padding-left:clamp(24px,3vw,60px);
  padding-right:clamp(24px,3vw,60px);
}
.nav-logo img{height:clamp(18px,1.4vw,26px)}
.nav nav{display:flex;gap:0;justify-content:space-between;font-size:21px;color:var(--fg);flex:1;margin-left:clamp(200px,25vw,400px)}
.nav nav a{transition:color .2s}
.nav nav a:hover{color:var(--fg)}

/* Hamburger toggle — visible only on mobile/tablet via media query */
.nav-toggle{
  display:none;
  background:none;border:0;padding:0;margin:0;cursor:pointer;
  width:44px;height:44px;
  position:relative;z-index:220;
  align-items:center;justify-content:center;flex-direction:column;gap:6px;
}
.nav-toggle span{
  display:block;width:26px;height:2px;background:var(--fg);
  transition:transform .3s cubic-bezier(0.16,1,0.3,1), opacity .2s;
  transform-origin:center;
}
.nav.is-open .nav-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav.is-open .nav-toggle span:nth-child(2){opacity:0}
.nav.is-open .nav-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============ HERO ============ */
.hero{
  padding:200px 0 200px;
  max-width:var(--wrap);
  margin:0 auto;
}
.hero.w{padding-left:0;padding-right:0}
.hero-kicker{
  display:block;
  font-size:clamp(20px,2.4vw,46px);
  font-weight:400;
  border-top:none;
  padding-top:0;
  margin-bottom:6px;
  margin-left:clamp(24px,3vw,60px);
  padding-left:0;
}
/* Hero composite image (3D layered: nou front, bread middle, soos back) */
.hero-mark{
  position:relative;
  margin-bottom:0;
}
.hero-img{
  width:100%;
  height:auto;
}

.hero-sub{
  position:absolute;
  right:clamp(24px,3vw,60px);
  top:48%;
  transform:translateY(-50%);
  font-size:clamp(20px,2.4vw,46px);
  font-weight:400;
  white-space:nowrap;
  margin:0;
}
.hero-lead{
  font-size:clamp(32px,4.86vw,90px);
  font-weight:400;
  line-height:1.3;
  text-align:justify;
  word-spacing:-0.05em;
  max-width:100%;
  margin-top:clamp(2cm,3.5vw,3.5cm);
  text-indent:clamp(60px,8vw,160px);
  padding-left:0;
  padding-right:0;
}
.btn{
  display:inline;
  background:var(--fg);
  color:var(--bg);
  text-decoration:none;
  padding:2px 10px;
  font-weight:400;
  font-size:inherit;
  transition:background .2s;
}
.btn:hover{background:var(--muted)}
.hero-lead .btn{margin-left:clamp(40px,11vw,160px)}

/* ============ SLUŽBY ============ */
.sluzby{
  padding:100px 0 100px;
  max-width:var(--wrap);margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.sluzby-img{position:relative;overflow:visible}
.sluzby-under{width:100%;aspect-ratio:3/3.55;object-fit:cover;object-position:center 40%;display:block}
.sluzby-bg{
  position:absolute;
  top:-3%;
  left:35%;
  width:55%;
  height:auto;
  z-index:2;
}
.sluzby-right{
  display:flex;flex-direction:column;
  align-items:center;
  min-width:0;
}
.sluzby-right h2{
  font-size:clamp(48px,7.36vw,106px);
  font-weight:400;
  letter-spacing:-0.04em;
  line-height:0.9;
  text-align:center;
  margin-bottom:clamp(1.5cm,3vw,3cm);
}
.sluzby-tbl{
  width:auto;
  margin:0 auto;
  border-collapse:collapse;
  font-size:clamp(16px,1.7vw,32px);
}
.sluzby-tbl tr{border-bottom:none}
.sluzby-tbl td{padding:4px 20px}
.sluzby-tbl td:first-child{color:var(--fg);font-weight:400}
.sluzby-tbl td:last-child{text-align:left;font-weight:600}
.sluzby-tbl b{font-weight:600}

/* ============ PROCES ============ */
.proces{
  padding:100px 0 0;
  max-width:var(--wrap);margin:0 auto;
}
.proces-row{
  display:grid;
  grid-template-columns:auto 1px 1fr;
  gap:clamp(40px,5vw,100px);
  align-items:start;
  padding-left:clamp(20px,4vw,90px);
}
.proces-row h2{
  font-size:clamp(48px,7.36vw,106px);
  font-weight:400;
  letter-spacing:-0.04em;
  line-height:0.9;
}
.proces-sep{
  background:var(--fg);
  width:1.5px;
  align-self:stretch;
}
.proces-defs{
  display:flex;
  flex-direction:column;
}
.pd{
  display:grid;
  grid-template-columns:clamp(120px,12vw,240px) 1fr;
  gap:clamp(12px,1.5vw,32px);
  padding:clamp(6px,0.7vw,14px) 0;
  border-top:none;
  font-size:clamp(16px,1.7vw,32px);
  line-height:1.25;
  letter-spacing:-0.01em;
}
.pd dt{font-weight:600}
.pd dd{color:var(--fg);font-weight:400}
.pd.gap{margin-top:0}

.cta{
  font-size:clamp(32px,4.86vw,90px);
  font-weight:400;
  line-height:1.3;
  letter-spacing:-0.02em;
  margin-top:100px;
  white-space:nowrap;
}
.proces{padding-bottom:100px}
.cta a{
  background:var(--fg);
  color:var(--bg);
  padding:0.05em 0.35em;
  font-weight:400;
  transition:background .2s;
}
.cta a:hover{background:var(--muted)}
.cta span{color:var(--fg);font-weight:400}

/* ============ DOPAD ============ */
.dopad{
  background:var(--fg);
  color:var(--bg);
  padding:200px 0 200px;
}
.dopad-title{
  font-size:clamp(48px,7.36vw,106px);
  font-weight:400;
  letter-spacing:-0.04em;
  line-height:0.9;
  margin:0 0 clamp(2.5cm,5vw,5cm);
  padding-left:clamp(20px,4vw,90px);
}
.dopad-title i{
  color:var(--bg);
  font-size:0.5em;
  vertical-align:0.05em;
  margin-left:0.08em;
}

.dopad-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px 36px;
  margin-bottom:clamp(2.5cm,5vw,5cm);
  align-items:start;
  padding-left:clamp(20px,4vw,90px);
}
.dcol{
  display:flex;
  flex-direction:column;
  gap:clamp(20px,2.2vw,44px);
}
.dcol-1{padding-top:clamp(20px,3vw,60px)}
.dcol-3{padding-top:clamp(40px,5vw,100px)}
.dcol p{
  font-size:clamp(16px,1.7vw,32px);
  font-weight:400;
  line-height:1.2;
  letter-spacing:-0.01em;
  margin:0;
}
.dcol a{
  color:var(--bg);
  text-decoration:underline;
  text-underline-offset:4px;
  font-size:clamp(13px,1.25vw,24px);
  font-weight:400;
}
.dcol-img{
  margin:0;
  width:160px;
  height:160px;
}
.dcol-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  filter:none;
}
.dcol-img-overlap{
  position:relative;
  width:160px;
  height:180px;
}
.dcol-img-overlap img{
  position:absolute;
  width:120px;
  height:120px;
  object-fit:cover;
  display:block;
}
.dcol-img-overlap .back-img{
  bottom:0;
  left:0;
  filter:none;
}
.dcol-img-overlap .front-img{
  top:0;
  right:0;
  left:auto;
  filter:none;
  z-index:1;
}
/* dcol-2 uses the black logo; on the dark dopad bg, invert it so it reads */
.dcol-2 .dcol-img img{filter:invert(1)}

/* === Newsletter === */
.nl{
  border-top:1px solid #333;
  padding-top:clamp(2cm,4vw,4cm);
  margin-top:clamp(2cm,4vw,4cm);
  margin-left:calc(-1 * var(--px));
  margin-right:calc(-1 * var(--px));
  text-align:left;
}
.nl-heading{
  font-size:clamp(24px,4.86vw,70px);
  font-weight:400;
  font-style:normal;
  line-height:1.1;
  letter-spacing:-0.02em;
  margin-bottom:clamp(10px,1.5vw,20px);
  max-width:100%;
}
.nl-sub{
  font-size:clamp(24px,4.58vw,66px);
  font-weight:400;
  line-height:1.3;
  letter-spacing:-0.01em;
  margin-bottom:clamp(24px,3vw,56px);
  color:var(--bg);
  white-space:nowrap;
}
.nl-form{
  display:flex;
  gap:0;
  align-items:stretch;
  max-width:560px;
  margin:0 auto;
  justify-content:center;
}
.nl-form input{
  background:transparent;
  border:none;
  border-bottom:1.5px solid #555;
  color:var(--bg);
  padding:14px 4px;
  font:inherit;
  font-size:clamp(14px,1.1vw,20px);
  flex:1;
  outline:none;
}
.nl-form input::placeholder{color:#555}
.nl-form button{
  background:var(--bg);
  color:var(--fg);
  border:none;
  padding:14px 24px;
  font:inherit;
  font-size:clamp(14px,1.1vw,20px);
  cursor:pointer;
  font-weight:500;
  margin-left:16px;
  white-space:nowrap;
  white-space:nowrap;
  transition:background .2s;
}
.nl-form button:hover{background:var(--muted);color:var(--bg)}

/* ============ KLIENTI ============ */
.clients{
  padding:clamp(2cm,3.5vw,4cm) 0;
  max-width:100%;
  overflow:hidden;
}
.clients-row{
  display:flex;
  align-items:center;
  gap:clamp(40px,5vw,80px);
  animation:marquee 20s linear infinite;
  width:max-content;
}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.clients-row img{
  height:clamp(28px,3.2vw,52px);
  width:auto;
  filter:grayscale(1);
  opacity:.55;
  transition:opacity .2s, transform .3s;
  flex-shrink:0;
}
.clients-row img:hover{opacity:1;transform:scale(1.3)}

/* ============ TÍM ============ */
.tim{
  padding:100px clamp(24px,3vw,60px) 200px;
  max-width:var(--wrap);margin:0 auto;
}
.tim h2{
  font-size:clamp(48px,7.36vw,106px);
  font-weight:400;
  letter-spacing:-0.04em;
  line-height:0.9;
  text-align:right;
  margin-bottom:clamp(1.5cm,3vw,3cm);
  padding-right:1.5cm;
}
.tim h2 i{color:var(--fg)}
.tim-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.tim-grid img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  object-position:center top;
  filter:grayscale(1);
  margin-bottom:10px;
  background:#ddd;
}
.tim-grid h3{
  font-size:clamp(16px,1.7vw,32px);
  font-weight:600;
  margin-bottom:2px;
  letter-spacing:-0.01em;
}
.tim-grid p{
  color:var(--fg);
  font-size:clamp(13px,1.25vw,24px);
}

/* ============ KONTAKT ============ */
.kontakt{
  padding:100px 0 200px;
  max-width:var(--wrap);margin:0 auto;
  text-align:left;
}
.kontakt h2{
  font-size:clamp(32px,4.86vw,90px);
  font-weight:400;
  line-height:1.3;
  letter-spacing:-0.02em;
  margin-bottom:clamp(1.5cm,3vw,3cm);
  max-width:100%;
  text-align:justify;
}
.kontakt-form{
  max-width:420px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:20px;
  text-align:left;
}
.kontakt-form label{
  display:flex;
  flex-direction:column;
  gap:5px;
  font-size:18px;
  color:var(--fg);
}
.kontakt-form input,
.kontakt-form textarea{
  border:none;
  border-bottom:1px solid var(--fg);
  background:transparent;
  padding:10px 0;
  font:inherit;
  font-size:16px;
  color:var(--fg);
  resize:vertical;
}
.kontakt-form input:focus,
.kontakt-form textarea:focus{outline:none;border-color:var(--muted)}
.kontakt-form button{
  background:var(--fg);
  color:var(--bg);
  border:none;
  padding:14px 24px;
  font:inherit;
  font-size:clamp(14px,1.1vw,20px);
  cursor:pointer;
  font-weight:500;
  width:auto;
  align-self:flex-start;
  transition:background .2s;
}
.kontakt-form button:hover{background:var(--muted)}
.fine{
  font-size:12px;
  color:var(--muted);
  text-align:left;
}

/* ============ FOOTER ============ */
footer{
  background:var(--fg);
  color:var(--bg);
  padding:clamp(80px,8vw,160px) 0 0;
  position:relative;
}
.footer-texture-wrap{
  position:absolute;
  top:-70px;
  left:calc(42% - 3cm);
  transform:translateX(-50%);
  width:220px;
  height:280px;
  pointer-events:none;
  z-index:2;
  background-image:url('img/footer-texture.svg');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.footer-texture{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.footer-top{
  max-width:var(--wrap);margin:0 auto;
  padding:60px clamp(24px,3vw,60px) 48px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}
.ft-left{
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  z-index:3;
}
.ft-logo{height:18px;filter:invert(1)}
.ft-email{
  font-size:15px;
  color:var(--bg);
  transition:color .2s;
}
.ft-email:hover{color:var(--muted)}
.ft-info{
  font-size:13px;
  color:var(--bg);
  line-height:1.5;
  margin-top:4px;
}

.ft-links{
  display:flex;
  gap:60px;
  justify-content:space-between;
  padding-right:clamp(10px,2vw,30px);
}
.ft-col{
  display:flex;
  flex-direction:column;
  gap:4px;
  font-size:15px;
  color:var(--bg);
}
.ft-col:first-child{
  margin-left:auto;
  margin-right:auto;
}
.ft-col:last-child{
  margin-right:clamp(20px,4vw,60px);
}
.ft-col a{transition:color .2s}
.ft-col a:hover{color:var(--muted)}

.ft-bottom{
  display:flex;
  gap:clamp(20px,3vw,40px);
  padding:clamp(30px,4vw,60px) clamp(24px,3vw,60px) 20px;
  font-size:12px;
  color:var(--bg);
}
.ft-bottom a{color:var(--bg);transition:color .2s}
.ft-bottom a:hover{color:var(--muted)}

.footer-mega{
  overflow:hidden;
  width:100%;
  height:22cqw;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:0;
}
.footer-mega span{
  display:block;
  font-weight:700;
  font-size:31cqw;
  letter-spacing:-0.065em;
  line-height:1;
  color:var(--bg);
  white-space:nowrap;
  margin-bottom:-5.5cqw;
  transform:translateX(-4.15cqw);
}

/* ============ RESPONSIVE: tiered breakpoints ============ */

/* === Small laptop / large tablet (max 1200px) — tighten desktop grid === */
@media(max-width:1200px){
  .hero{padding:140px 0 140px}
  .dopad{padding:140px 0 140px}
  .kontakt{padding:80px 0 140px}
  .tim{padding:80px clamp(24px,3vw,60px) 140px}
}

/* === Tablet landscape (max 1024px) === */
@media(max-width:1024px){
  :root{--px:clamp(18px,2.4vw,28px)}
  .nav .w{padding-left:var(--px);padding-right:var(--px)}
  .nav nav{margin-left:clamp(60px,10vw,160px);gap:clamp(16px,2vw,28px);font-size:clamp(14px,1.8vw,18px);justify-content:flex-end}
  .nav-logo img{height:16px}

  .hero{padding:100px 0 120px}
  .hero-kicker{margin-left:var(--px);font-size:clamp(16px,2.2vw,24px)}
  .hero-sub{font-size:clamp(16px,2.2vw,24px);right:var(--px)}
  .hero-lead{
    font-size:clamp(28px,5.2vw,54px);
    text-indent:clamp(40px,7vw,90px);
    padding-left:var(--px);padding-right:var(--px);
    margin-top:clamp(24px,3.5vw,48px);
    line-height:1.3;
    text-align:left;
    word-spacing:normal;
  }
  .hero-lead .btn{margin-left:clamp(14px,3vw,40px);white-space:nowrap}

  /* KONTAKT heading — avoid wide justify gaps on narrower widths */
  .kontakt h2{text-align:left}

  /* SLUŽBY — keep 2-col layout, just scale */
  .sluzby{padding:80px 0;gap:clamp(24px,4vw,56px);padding-left:var(--px);padding-right:var(--px)}
  .sluzby-right h2{font-size:clamp(56px,9vw,90px);margin-bottom:clamp(24px,4vw,48px);text-align:left}
  .sluzby-right{align-items:flex-start}
  .sluzby-tbl{margin:0;font-size:clamp(16px,2.2vw,22px)}
  .sluzby-tbl td{padding:4px 14px}
  .sluzby-tbl td:first-child{padding-left:0}

  /* PROCES */
  .proces{padding:80px 0}
  .proces-row{padding-left:var(--px);padding-right:var(--px);gap:clamp(24px,4vw,56px)}
  .proces-row h2{font-size:clamp(56px,9vw,90px)}
  .pd{font-size:clamp(16px,2.2vw,22px);grid-template-columns:clamp(110px,16vw,180px) 1fr}
  .cta{font-size:clamp(28px,5vw,54px);margin-top:60px;white-space:normal;padding-left:var(--px);padding-right:var(--px)}

  /* DOPAD — keep 4-col like desktop on wide tablet */
  .dopad{padding:100px 0}
  .dopad-title{font-size:clamp(56px,9vw,90px);padding-left:var(--px);margin-bottom:clamp(40px,6vw,72px)}
  .dopad-grid{grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,36px) clamp(16px,2.4vw,28px);padding-left:var(--px);padding-right:var(--px)}
  .dcol-1{padding-top:clamp(16px,2vw,32px)}
  .dcol-3{padding-top:clamp(28px,3.5vw,60px)}
  .dcol p{font-size:clamp(15px,1.9vw,20px);line-height:1.25}
  .dcol a{font-size:clamp(12px,1.4vw,15px)}
  .dcol-img{width:clamp(90px,11vw,130px);height:clamp(90px,11vw,130px)}
  .dcol-img-overlap{width:clamp(100px,12vw,140px);height:clamp(115px,14vw,160px)}
  .dcol-img-overlap img{width:clamp(75px,9vw,100px);height:clamp(75px,9vw,100px)}

  /* TÍM — keep 4-col like desktop */
  .tim{padding:80px var(--px) 100px}
  .tim h2{font-size:clamp(56px,9vw,90px);padding-right:0;text-align:right;margin-bottom:clamp(24px,4vw,48px)}
  .tim-grid{grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px)}
  .tim-grid img{aspect-ratio:3/4;object-fit:cover;object-position:center top}
  .tim-grid h3{font-size:clamp(14px,1.6vw,20px)}
  .tim-grid p{font-size:clamp(11px,1.3vw,16px)}

  /* KONTAKT */
  .kontakt{padding:80px var(--px) 100px}
  .kontakt h2{font-size:clamp(28px,4.8vw,54px);margin-bottom:clamp(24px,4vw,48px)}

  /* Newsletter */
  .nl-heading{font-size:clamp(34px,5.2vw,54px)}
  .nl-sub{font-size:clamp(20px,3.2vw,32px);white-space:normal}

  /* Footer */
  .footer-top{padding-left:var(--px);padding-right:var(--px);grid-template-columns:1fr 1fr;gap:32px}
  .ft-bottom{padding-left:var(--px);padding-right:var(--px)}
  .ft-col:last-child{margin-right:0}
  .footer-texture-wrap{left:50%;transform:translateX(-50%);width:clamp(140px,20vw,200px);height:clamp(180px,25vw,250px);top:-60px}
}

/* Newsletter: restore inner padding on all tablet+ so text doesn't kiss the edge */
@media(max-width:1024px){
  .nl-heading,.nl-sub,.nl-form{padding-left:var(--px);padding-right:var(--px)}
}

/* === Tablet portrait (max 820px) — simplify sluzby + dopad to 2-col === */
@media(max-width:820px){
  body{max-width:min(1500px,96vw);margin:14px auto;border-radius:28px;clip-path:none;overflow:hidden auto}

  /* === HAMBURGER MENU === */
  .nav-toggle{display:flex}
  .nav nav{
    position:fixed;
    top:0;left:0;right:0;
    width:100vw;height:100dvh;
    background:var(--bg);
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:clamp(18px,3vw,28px);
    margin:0;padding:0;
    font-size:clamp(34px,6.5vw,52px);
    font-weight:400;
    transform:translateY(-101%);
    transition:transform .45s cubic-bezier(0.16,1,0.3,1);
    z-index:210;
    pointer-events:none;
  }
  .nav.is-open nav{transform:translateY(0);pointer-events:auto}
  .nav nav a{
    opacity:0;transform:translateY(12px);
    transition:opacity .3s ease, transform .3s ease;
    padding:8px 20px;
  }
  .nav.is-open nav a{opacity:1;transform:translateY(0)}
  .nav.is-open nav a:nth-child(1){transition-delay:.12s}
  .nav.is-open nav a:nth-child(2){transition-delay:.18s}
  .nav.is-open nav a:nth-child(3){transition-delay:.24s}
  .nav.is-open nav a:nth-child(4){transition-delay:.30s}
  .nav.is-open nav a:nth-child(5){transition-delay:.36s}
  /* Ensure logo + toggle sit above the overlay */
  .nav .w{position:relative;z-index:220}
  .nav-logo{position:relative;z-index:220}

  /* SLUŽBY — 2-stĺpcový desktop layout, len menšie veľkosti */
  .sluzby{grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,32px);padding-left:var(--px);padding-right:var(--px)}
  .sluzby-img{max-width:100%;margin:0;width:100%}
  .sluzby-under{aspect-ratio:3/3.55}
  .sluzby-bg{top:-3%;left:35%;width:55%}
  .sluzby-right h2{text-align:center;font-size:clamp(40px,9vw,72px);margin-bottom:clamp(16px,4vw,40px)}
  .sluzby-tbl{margin:0 auto;font-size:clamp(13px,2.4vw,18px)}
  .sluzby-tbl td{padding:3px 10px}

  /* PROCES — single column, show separator as thin line underneath heading */
  .proces-row{grid-template-columns:1fr;gap:24px}
  .proces-sep{display:block;width:100%;height:1.5px;align-self:stretch}

  /* DOPAD — switch to 2×2 on tablet portrait */
  .dopad-grid{grid-template-columns:repeat(2,1fr);gap:40px 28px}
  .dcol-1,.dcol-3{padding-top:0}
  .dcol-img{width:clamp(100px,14vw,130px);height:clamp(100px,14vw,130px)}
  .dcol-img-overlap{width:clamp(120px,16vw,150px);height:clamp(140px,18vw,170px)}
  .dcol-img-overlap img{width:clamp(80px,10vw,100px);height:clamp(80px,10vw,100px)}
  .dcol p{font-size:clamp(17px,2.5vw,22px)}
  .dcol a{font-size:clamp(13px,1.7vw,16px)}

  /* TÍM — switch to 2×2 on tablet portrait */
  .tim-grid{grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,28px)}
  .tim-grid h3{font-size:clamp(16px,2.2vw,22px)}
  .tim-grid p{font-size:clamp(13px,1.7vw,18px)}

  /* CTA */
  .cta{font-size:clamp(26px,5.5vw,42px);margin-top:48px}
}

/* === Large mobile (max 600px) === */
@media(max-width:600px){
  :root{--px:clamp(16px,4.5vw,22px)}
  body{max-width:98vw;margin:10px auto;border-radius:22px;clip-path:none;overflow:hidden auto}

  /* NAV — compact header (menu overlay štýlovaný v 820px bloku) */
  .nav .w{padding-top:16px;padding-bottom:14px}
  .nav-logo img{height:14px}

  /* HERO — layout ako na desktope (full-width composite, hero-sub absolútne), len menšie veľkosti */
  .hero{padding:40px 0 56px}
  .hero-kicker{font-size:14px;margin-bottom:8px;margin-left:var(--px)}
  .hero-mark{max-width:100%;margin:0;padding:0}
  .hero-sub{
    position:absolute;
    right:var(--px);
    top:50%;
    transform:translateY(-50%);
    font-size:13px;
    margin:0;
  }
  .hero-lead{
    font-size:clamp(24px,7vw,32px);
    text-indent:0;
    line-height:1.25;
    text-align:justify;
    text-align-last:left;
    word-spacing:normal;
    margin-top:32px;
    padding-left:var(--px);
    padding-right:var(--px);
  }
  .hero-lead .btn{margin-left:6px;display:inline-block;padding:3px 10px;margin-top:6px}

  /* SLUŽBY — 2-col (obrázok vľavo, heading + tabuľka vpravo), desktop štýl s proces-matched veľkosťou písma */
  .sluzby{grid-template-columns:1fr 1fr;padding:48px 0 36px;gap:clamp(10px,2vw,18px);padding-left:var(--px);padding-right:var(--px)}
  .sluzby-img{max-width:100%;margin:0;width:100%}
  .sluzby-under{aspect-ratio:3/3.55}
  .sluzby-bg{top:-3%;left:35%;width:55%}
  .sluzby-right{padding:0;align-items:center;justify-content:center}
  .sluzby-right h2{font-size:clamp(42px,11vw,60px);text-align:center;margin-bottom:16px;line-height:0.9}
  .sluzby-tbl{font-size:15px;width:auto;margin:0 auto}
  .sluzby-tbl td{padding:4px 10px}
  .sluzby-tbl td:first-child{width:auto}

  /* PROCES */
  .proces{padding:36px 0 48px}
  .proces-row{padding-left:var(--px);padding-right:var(--px)}
  .proces-row h2{font-size:clamp(42px,11vw,60px)}
  .proces-sep{display:none}
  .pd{font-size:15px;grid-template-columns:100px 1fr;gap:12px;padding:5px 0;line-height:1.3}
  .pd dt{font-weight:600}
  .cta{font-size:clamp(18px,4.8vw,24px);margin-top:36px;line-height:1.4;padding:0 var(--px)}

  /* DOPAD — 2×2 grid on mobile, vertical stack inside each card */
  .dopad{padding:56px 0}
  .dopad-title{font-size:clamp(42px,11vw,60px);padding-left:var(--px);margin-bottom:32px}
  .dopad-grid{grid-template-columns:repeat(2,1fr);gap:28px 20px;padding:0 var(--px)}
  .dcol{flex-direction:column;align-items:flex-start;gap:14px}
  .dcol-1,.dcol-2,.dcol-3,.dcol-4{padding-top:0}
  .dcol-img{width:90px;height:90px}
  .dcol-img-overlap{width:110px;height:130px}
  .dcol-img-overlap img{width:74px;height:74px}
  .dcol p{font-size:15px;line-height:1.3}
  .dcol a{font-size:13px}

  /* Newsletter */
  .nl{margin-left:0;margin-right:0;padding:32px var(--px) 0;margin-top:40px}
  .nl-heading{font-size:clamp(26px,6.5vw,36px);margin-bottom:10px}
  .nl-sub{font-size:clamp(15px,4vw,20px);white-space:normal;margin-bottom:24px}
  .nl-form{flex-direction:column;gap:12px;align-items:stretch;max-width:100%;padding:0}
  .nl-form input{font-size:16px;padding:12px 4px}
  .nl-form button{margin-left:0;padding:14px 20px;text-align:center;font-size:15px}

  /* TÍM */
  .tim{padding:48px var(--px) 56px}
  .tim h2{font-size:clamp(42px,11vw,60px);text-align:right;padding-right:0;margin-bottom:24px}
  .tim-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .tim-grid img{aspect-ratio:3/4;object-fit:cover;object-position:center top}
  .tim-grid h3{font-size:15px}
  .tim-grid p{font-size:12px}

  /* KONTAKT */
  .kontakt{padding:48px var(--px) 64px}
  .kontakt h2{font-size:clamp(20px,5vw,26px);line-height:1.35;text-align:left;margin-bottom:24px}
  .kontakt-form{max-width:100%}
  .kontakt-form label{font-size:14px}
  .kontakt-form input,.kontakt-form textarea{font-size:16px}
  .kontakt-form button{font-size:14px;padding:13px 22px}

  /* Clients marquee */
  .clients{padding:24px 0}

  /* FOOTER */
  footer{padding-top:clamp(60px,10vw,90px)}
  .footer-top{grid-template-columns:1fr;gap:36px;padding:40px var(--px) 32px}
  .ft-left{gap:12px}
  .ft-info{font-size:12px}
  .ft-links{justify-content:flex-start;gap:48px;padding-right:0}
  .ft-col{font-size:14px}
  .ft-col:first-child{margin-left:0;margin-right:0}
  .ft-col:last-child{margin-right:0}
  .ft-bottom{padding:24px var(--px) 16px;font-size:11px;flex-wrap:wrap;gap:16px}
  .footer-texture-wrap{left:auto;right:var(--px);transform:none;top:-36px;width:100px;height:130px}
  .footer-mega span{font-size:30cqw}
}

/* === Small mobile (max 420px) — extra compact === */
@media(max-width:420px){
  body{max-width:99vw;margin:6px auto;border-radius:18px;clip-path:none;overflow:hidden auto}

  .nav .w{padding-top:12px;padding-bottom:10px}
  .nav-logo img{height:13px}

  .hero{padding:28px 0 40px}
  .hero-kicker{font-size:12px}
  .hero-sub{font-size:11px}
  .hero-lead{font-size:22px;text-indent:0;line-height:1.25;margin-top:24px}
  .hero-lead .btn{margin-left:4px;padding:2px 8px}

  .sluzby{padding:36px 0 27px;gap:6px}
  .sluzby-img{max-width:100%}
  .sluzby-right h2{font-size:38px;margin-bottom:12px}
  .sluzby-tbl{font-size:13px}
  .sluzby-tbl td{padding:3px 8px}

  .proces{padding:27px 0 36px}
  .proces-row h2{font-size:38px}
  .pd{font-size:13px;grid-template-columns:88px 1fr;gap:10px;padding:4px 0}
  .cta{font-size:16px;margin-top:28px;line-height:1.4}

  .dopad{padding:40px 0}
  .dopad-title{font-size:38px;margin-bottom:26px}
  .dopad-grid{gap:28px}
  .dcol-img{width:86px;height:86px}
  .dcol-img-overlap{width:100px;height:120px}
  .dcol-img-overlap img{width:68px;height:68px}
  .dcol p{font-size:14px}
  .dcol a{font-size:13px}

  .nl-heading{font-size:22px}
  .nl-sub{font-size:14px}

  .tim{padding:36px var(--px) 40px}
  .tim h2{font-size:38px}
  .tim-grid{gap:14px}
  .tim-grid h3{font-size:13px}
  .tim-grid p{font-size:11px}

  .kontakt{padding:36px var(--px) 48px}
  .kontakt h2{font-size:18px}
  .kontakt-form label{font-size:13px}
  .kontakt-form button{font-size:13px}

  .clients-row img{height:24px}
  .footer-top{gap:28px;padding-top:32px}
  .ft-info{font-size:11px}
  .ft-links{gap:32px}
  .ft-bottom{font-size:10px}
  .footer-texture-wrap{width:80px;height:110px;top:-28px}
  .footer-mega span{font-size:30cqw}
}
