*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0D0F1A;--bg2:#13162A;--dark:#2D3142;
  --orange:#F5A623;--orange2:#FF8C00;
  --text:#F0F2FF;--text-muted:rgba(240,242,255,0.45);--text-dim:rgba(240,242,255,0.22);
  --border:rgba(255,255,255,0.07);--glass:rgba(255,255,255,0.04);--glass-b:rgba(255,255,255,0.1);
  --r:14px;--pad:clamp(24px,5vw,80px);
}
html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}
body{font-family:'Instrument Sans',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;max-width:100vw}
input,textarea,select,label,button,a{cursor:none}
input[type=checkbox],input[type=radio]{cursor:pointer;pointer-events:auto}
label[for]{cursor:pointer;pointer-events:auto}

/* CURSOR */
.cur{position:fixed;width:10px;height:10px;background:var(--orange);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);max-width:10px;opacity:0;transition:opacity .3s}
.cur-r{position:fixed;width:36px;height:36px;border:1.5px solid rgba(245,166,35,0.45);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s,opacity .3s;opacity:0}
.cur-r.h{width:52px;height:52px;border-color:var(--orange)}

/* PROGRESS */
#prog{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--orange),var(--orange2));z-index:200;width:0;box-shadow:0 0 10px var(--orange)}

/* NOISE */
body::before{content:'';position:fixed;inset:0;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;opacity:0.45}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad);transition:background .4s,backdrop-filter .4s;overflow:hidden;box-sizing:border-box;max-width:100vw}
#nav.sc{background:rgba(13,15,26,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nl{display:flex;gap:32px;list-style:none;align-items:center}
.nl a{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color .25s}
.nl a:hover{color:var(--orange)}
.nc{background:var(--orange);color:#0D0F1A;padding:8px 22px;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:background .25s,transform .2s}
.nc:hover{background:#ffb840;transform:scale(1.04)}
.hmb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px}
.hmb span{display:block;width:22px;height:1.5px;background:var(--text)}
.mob{display:none;position:fixed;inset:0;z-index:99;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:36px}
.mob.op{display:flex}
.mob a{font-family:'Syne',sans-serif;font-size:2.4rem;font-weight:700;color:var(--text);text-decoration:none;transition:color .2s}
.mob a:hover{color:var(--orange)}
.mob-x{position:absolute;top:24px;right:var(--pad);background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:none}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 var(--pad) clamp(60px,8vh,100px);position:relative;overflow:hidden;max-width:100vw;box-sizing:border-box}
.hbg-el{position:absolute;inset:0;z-index:0}
.hbg-el::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(245,166,35,.11) 0%,transparent 60%),radial-gradient(ellipse 100% 100% at 50% 50%,#0D0F1A 40%,#13162A 100%);animation:msh 10s ease-in-out infinite alternate}
.hbg-el::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 80%)}
@keyframes msh{0%{background-position:70% 40%}100%{background-position:65% 45%}}
.h-eye{display:inline-flex;align-items:center;gap:10px;margin-bottom:28px;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);position:relative;z-index:2;animation:fu 1s .2s both;max-width:100%;overflow:hidden}
.h-eye::before{content:'';display:block;width:28px;height:1px;background:var(--orange)}
.h-ttl{font-family:'Syne',sans-serif;font-size:clamp(3.5rem,9vw,9rem);font-weight:800;line-height:.95;letter-spacing:-.03em;position:relative;z-index:2;animation:fu 1s .35s both;max-width:100%;word-break:break-word}
.h-ttl .ln{display:block}
.h-ttl .out{-webkit-text-stroke:1.5px var(--text);color:transparent}
.h-ttl .org{color:var(--orange)}
.h-bot{margin-top:clamp(36px,5vw,64px);display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:2;animation:fu 1s .5s both}
.h-desc{max-width:440px;font-size:clamp(.95rem,1.3vw,1.05rem);line-height:1.75;color:var(--text-muted)}
.h-acts{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:100px;font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:all .25s}
.bf{background:var(--orange);color:#0D0F1A}
.bf:hover{background:#ffb840;transform:translateY(-2px)}
.bg{border:1px solid var(--glass-b);color:var(--text);backdrop-filter:blur(8px);background:var(--glass)}
.bg:hover{border-color:var(--orange);color:var(--orange)}
.h-scr{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase}
.scr-l{width:1px;height:60px;background:linear-gradient(var(--text-dim),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes fu{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* MARQUEE */
.mq-w{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;background:var(--bg2);position:relative;z-index:2}
.mq-t{display:flex;animation:mq 25s linear infinite;width:max-content}
.mq-i{display:flex;align-items:center;gap:20px;padding:0 40px;font-family:'Syne',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);white-space:nowrap}
.mq-i .dot{width:5px;height:5px;border-radius:50%;background:var(--orange);flex-shrink:0}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SHARED */
section{padding:clamp(80px,10vw,140px) var(--pad)}
.sl{font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);margin-bottom:20px;display:flex;align-items:center;gap:12px}
.sl::before{content:'';display:block;width:20px;height:1px;background:var(--orange)}
.st{font-family:'Syne',sans-serif;font-size:clamp(2.4rem,5vw,4.5rem);font-weight:800;line-height:1;letter-spacing:-.025em}
.st em{font-style:italic;color:var(--orange)}
.rev{opacity:0;transform:translateY(32px);transition:opacity .8s ease,transform .8s ease}
.rev.vis{opacity:1;transform:none}
.rl{opacity:0;transform:translateX(-32px);transition:opacity .8s ease,transform .8s ease}
.rl.vis{opacity:1;transform:none}
.rr{opacity:0;transform:translateX(32px);transition:opacity .8s ease,transform .8s ease}
.rr.vis{opacity:1;transform:none}

/* O NÁS */
#o-nas{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start;overflow:hidden}
.ab-l p{font-size:1.05rem;line-height:1.8;color:var(--text-muted);margin-bottom:20px}
.metrics{margin-top:48px;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.met{padding:28px 24px;background:var(--glass);border:1px solid var(--border)}
.met:nth-child(1){border-radius:var(--r) 0 0 0}.met:nth-child(2){border-radius:0 var(--r) 0 0}
.met:nth-child(3){border-radius:0 0 0 var(--r)}.met:nth-child(4){border-radius:0 0 var(--r) 0}
.m-n{font-family:'Syne',sans-serif;font-size:2.8rem;font-weight:800;color:var(--orange);line-height:1}
.m-l{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}
.sc-card{background:linear-gradient(135deg,rgba(245,166,35,.09) 0%,var(--glass) 100%);border:1px solid rgba(245,166,35,.22);border-radius:var(--r);padding:40px;position:sticky;top:120px}
.sc-icon{font-size:2.2rem;margin-bottom:24px;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:rgba(245,166,35,.1);border-radius:12px}
.sc-card h3{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:16px;line-height:1.2}
.sc-card p{font-size:.95rem;line-height:1.75;color:var(--text-muted)}
.tags{margin-top:28px;display:flex;gap:8px;flex-wrap:wrap}
.tag{padding:6px 16px;background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.18);border-radius:100px;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--orange)}
.sdiv{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--orange),transparent);margin:28px 0;opacity:.3}

/* SLUZBY */
#sluzby{background:var(--bg2)}
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:clamp(48px,6vw,80px)}
.svc{background:var(--bg2);padding:40px 32px;position:relative;overflow:hidden;transition:background .35s}
.svc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--orange),var(--orange2));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.23,1,.32,1)}
.svc:hover{background:#161929}
.svc:hover::before{transform:scaleX(1)}
.svc-n{font-family:'Syne',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--text-dim);margin-bottom:28px}
.svc-ic{width:44px;height:44px;background:rgba(245,166,35,.07);border:1px solid rgba(245,166,35,.14);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:20px;transition:background .3s,border-color .3s}
.svc:hover .svc-ic{background:rgba(245,166,35,.14);border-color:rgba(245,166,35,.32)}
.svc-t{font-family:'Syne',sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:12px}
.svc-d{font-size:.875rem;line-height:1.7;color:var(--text-muted)}
.svc-ar{position:absolute;bottom:28px;right:24px;font-size:1.2rem;color:var(--text-dim);transition:color .25s,transform .25s}
.svc:hover .svc-ar{color:var(--orange);transform:translate(4px,-4px)}

/* PROJEKTY */
.ph{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:clamp(48px,6vw,80px)}
.pc{font-family:'Syne',sans-serif;font-size:5rem;font-weight:800;color:var(--text-dim);line-height:1}
.pl{display:flex;flex-direction:column;gap:1px;background:var(--border)}
.pi{background:var(--bg);display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:40px;padding:36px 40px;transition:background .3s;cursor:none;position:relative;overflow:hidden}
.pi::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(245,166,35,.04),transparent);opacity:0;transition:opacity .35s}
.pi:hover{background:#0f1220}
.pi:hover::after{opacity:1}
.pl .pi:first-child{border-radius:var(--r) var(--r) 0 0}
.pl .pi:last-child{border-radius:0 0 var(--r) var(--r)}
.p-idx{font-family:'Syne',sans-serif;font-size:3.5rem;font-weight:800;color:var(--text-dim);line-height:1;transition:color .3s}
.pi:hover .p-idx{color:var(--orange)}
.p-cat{font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:8px}
.p-ttl{font-family:'Syne',sans-serif;font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:700;line-height:1.15}
.p-dsc{margin-top:10px;font-size:.875rem;line-height:1.65;color:var(--text-muted);max-width:580px}
.p-mt{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
.p-loc{font-size:.75rem;color:var(--text-dim);letter-spacing:.1em;text-align:right}
.p-ar{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-dim);transition:all .3s}
.pi:hover .p-ar{border-color:var(--orange);color:var(--orange);background:rgba(245,166,35,.08);transform:rotate(45deg)}

/* GALLERY */
.gal-block{margin-top:52px}
.gal-lbl{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.gal-lbl::before{content:'';display:block;width:16px;height:1px;background:var(--text-dim)}
.gal-lbl span{color:var(--orange)}

.gi{border-radius:10px;overflow:hidden;cursor:none;position:relative;background:var(--bg2);border:1px solid var(--border)}
.gi img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.23,1,.32,1),filter .4s;filter:brightness(.9) saturate(1.05)}
.gi:hover img{transform:scale(1.05);filter:brightness(1) saturate(1.1)}
.gi .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,15,26,.65) 0%,transparent 50%);opacity:0;transition:opacity .35s;display:flex;align-items:flex-end;padding:14px}
.gi:hover .ov{opacity:1}
.oz{width:34px;height:34px;border-radius:50%;background:rgba(245,166,35,.9);display:flex;align-items:center;justify-content:center;font-size:.85rem;margin-left:auto;color:#0D0F1A;font-weight:700}

/* ── PORÁČ – 7 fotiek ──
   Desktop: 3 stĺpce, prvý foto zaberá 2 riadky
   [MAIN] [2] [3]
   [MAIN] [4] [5]
          [6] [7]
*/
.gal-porac{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:220px;
  gap:10px;
}
.gp-main{
  grid-row:span 2;
}

/* ── KNIŽNICA – 3 fotky ──
   Desktop: [MAIN(2)] [2]
                      [3]
*/
.gal-kniznica{
  display:grid;
  grid-template-columns:3fr 2fr;
  grid-auto-rows:190px;
  gap:10px;
}
.gk-main{
  grid-row:span 2;
}

/* ── TABLET (max 900px) ── */
@media(max-width:900px){
  .gal-porac{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:200px;
  }
  .gp-main{grid-row:span 1}

  .gal-kniznica{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:200px;
  }
  .gk-main{grid-row:span 1}
}

/* ── MOBIL (max 600px) ── */
@media(max-width:600px){
  .gal-block{margin-top:28px}

  .gal-porac{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:160px;
    gap:8px;
  }
  .gp-main{grid-row:span 1}

  .gal-kniznica{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:160px;
    gap:8px;
  }
  .gk-main{grid-row:span 1}

  .oz{width:28px;height:28px;font-size:.75rem}
}

/* LIGHTBOX */
#lb{position:fixed;inset:0;z-index:500;background:rgba(5,7,14,.97);backdrop-filter:blur(24px);display:none;align-items:center;justify-content:center;padding:24px}
#lb.op{display:flex}
#lb img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 40px 120px rgba(0,0,0,.8);transition:opacity .3s}
#lb-x{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--text);font-size:1.1rem;cursor:none;display:flex;align-items:center;justify-content:center;transition:background .2s}
#lb-x:hover{background:rgba(245,166,35,.2)}
#lb-p,#lb-n{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text);font-size:1.2rem;cursor:none;display:flex;align-items:center;justify-content:center;transition:all .2s}
#lb-p:hover,#lb-n:hover{background:rgba(245,166,35,.15);border-color:var(--orange)}
#lb-p{left:24px}#lb-n{right:24px}
#lb-cap{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:.72rem;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}
#lb-cnt{position:absolute;top:28px;left:50%;transform:translateX(-50%);font-size:.72rem;color:var(--text-dim);letter-spacing:.15em}

/* SOCIALNY PODNIK */
#socialny-podnik{background:var(--bg2);position:relative;overflow:hidden}
.sp-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(245,166,35,.06) 0%,transparent 60%)}
.sp-g{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center;position:relative;z-index:1}
.sp-r{display:flex;flex-direction:column;gap:14px}
.pc-card{background:var(--glass);border:1px solid var(--glass-b);border-radius:12px;padding:22px 26px;display:flex;align-items:center;gap:18px;transition:background .3s,border-color .3s,transform .3s}
.pc-card:hover{background:rgba(245,166,35,.06);border-color:rgba(245,166,35,.2);transform:translateX(8px)}
.pc-ic{width:44px;height:44px;flex-shrink:0;background:rgba(245,166,35,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.pc-card strong{display:block;font-size:.9rem;font-weight:600;margin-bottom:3px}
.pc-card span{font-size:.82rem;color:var(--text-muted);line-height:1.5}
.sp-badge{display:inline-flex;align-items:center;gap:12px;background:rgba(245,166,35,.07);border:1px solid rgba(245,166,35,.18);border-radius:100px;padding:10px 20px;margin-top:32px;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);width:fit-content}
.sp-badge::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange);animation:pl 2s infinite}
@keyframes pl{0%,100%{opacity:1}50%{opacity:.35}}

/* KONTAKT */
.ct-w{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,100px);align-items:start}
.ct-l p{font-size:1rem;line-height:1.8;color:var(--text-muted);margin-bottom:40px}
.ct-items{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.ci{display:flex;align-items:center;gap:18px;padding:18px 22px;border-bottom:1px solid var(--border);transition:background .25s}
.ci:last-child{border-bottom:none}
.ci:hover{background:var(--glass)}
.ci-ic{width:36px;height:36px;flex-shrink:0;background:rgba(245,166,35,.07);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.ci strong{display:block;font-size:.66rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);margin-bottom:2px}
.ci a,.ci span{font-size:.9rem;color:var(--text);text-decoration:none;transition:color .2s}
.ci a:hover{color:var(--orange)}
.cf{background:var(--glass);border:1px solid var(--glass-b);border-radius:var(--r);padding:clamp(28px,4vw,44px)}
.cf h3{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:700;margin-bottom:28px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.66rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:7px}
.fg input,.fg textarea,.fg select{width:100%;padding:12px 15px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;font-family:'Instrument Sans',sans-serif;font-size:.9rem;color:var(--text);outline:none;transition:border-color .25s,background .25s;-webkit-appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--orange);background:rgba(245,166,35,.03)}
.fg textarea{resize:vertical;min-height:108px}
.fg select option{background:var(--bg2);color:var(--text)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sub{width:100%;padding:14px;background:var(--orange);color:#0D0F1A;border:none;border-radius:8px;font-family:'Syne',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:none;transition:background .25s,transform .2s;margin-top:6px}
.sub:hover{background:#ffb840;transform:translateY(-2px)}

/* FOOTER */
footer{background:#090B16;padding:clamp(48px,6vw,80px) var(--pad) 32px;border-top:1px solid var(--border)}
.ft{display:flex;justify-content:space-between;flex-wrap:wrap;gap:48px;padding-bottom:44px;border-bottom:1px solid var(--border)}
.fb p{font-size:.85rem;color:var(--text-muted);max-width:260px;line-height:1.65;margin-top:14px}
.fn h4{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px}
.fn ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.fn a{font-size:.85rem;color:var(--text-muted);text-decoration:none;transition:color .2s}
.fn a:hover{color:var(--orange)}
.fb2{padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fb2 p{font-size:.75rem;color:var(--text-dim)}

/* RESPONSIVE */
/* ── TABLET (max 1024px) ── */
@media(max-width:1024px){
  #o-nas{grid-template-columns:1fr}
  .sg{grid-template-columns:1fr 1fr}
  .sp-g{grid-template-columns:1fr}
  .ct-w{grid-template-columns:1fr}
  .pi{grid-template-columns:60px 1fr;gap:20px}
  .p-mt{display:none}

}

/* ── MOBIL (max 640px) ── */
@media(max-width:640px){
  /* NAV */
  .nl{display:none}.nc{display:none}
  .hmb{display:flex}

  /* CURSOR – skryť na mobile (touch zariadenia ho nepotrebujú) */
  .cur,.cur-r{display:none!important}
  body{cursor:auto!important}
  input,textarea,select,label,button,a{cursor:auto!important}
  input[type=checkbox],input[type=radio]{cursor:pointer!important}

  /* HERO */
  #hero{
    min-height:100svh;
    padding:100px var(--pad) 52px;
    justify-content:flex-start;
  }
  .hbg-el::after{background-size:40px 40px}
  .h-eye{margin-bottom:16px;font-size:.65rem}
  .h-ttl{font-size:clamp(2.8rem,11vw,4rem)}
  .h-bot{flex-direction:column;align-items:flex-start;gap:20px;margin-top:28px}
  .h-desc{font-size:.9rem;max-width:100%}
  .h-acts{flex-direction:column;width:100%}
  .btn{width:100%;justify-content:center;padding:14px 24px}
  .h-scr{display:none}

  /* SEKCIE – padding */
  section{padding:60px var(--pad);overflow-x:hidden}

  /* O NÁS */
  #o-nas{overflow:visible;gap:32px}
  .ab-l p{font-size:.95rem}
  .metrics{grid-template-columns:1fr 1fr;gap:2px;margin-top:28px}
  .m-n{font-size:2rem;line-height:1}
  .m-l{font-size:.72rem}
  .met{padding:20px 16px}
  .sc-card{padding:24px;position:static}

  /* SLUŽBY */
  .sg{grid-template-columns:1fr}
  .svc{padding:28px 24px}

  /* PROJEKTY */
  .ph{flex-direction:column;gap:8px;margin-bottom:32px}
  .pc{font-size:3rem}
  .pl{border-radius:var(--r)}
  .pi{grid-template-columns:1fr;padding:20px 16px;gap:8px}
  .p-idx{display:none}
  .p-ttl{font-size:1.1rem}
  .p-dsc{font-size:.82rem}


  /* SOCIÁLNY PODNIK */
  .sp-badge{font-size:.68rem;padding:8px 14px}
  .pc-card{padding:16px 18px;gap:12px}
  .pc-ic{width:38px;height:38px;font-size:1rem}

  /* KONTAKT */
  .ct-w{gap:32px}
  .fr{grid-template-columns:1fr}
  .cf{padding:24px 20px}
  .ct-items{border-radius:10px}
  .ci{padding:14px 16px;gap:12px}

  /* FOOTER */
  .ft{gap:28px}
  .fn ul{gap:8px}

  /* LIGHTBOX */
  #lb-p{left:8px}
  #lb-n{right:8px}
  #lb img{max-width:95vw;max-height:75vh}

  /* MARQUEE – spomalenie na mobile */
  .mq-track{animation-duration:40s}

  /* FORMULÁR */
  .sub{font-size:.8rem}
}

/* ── VELMI MALE OBRAZOVKY (max 390px – iPhone SE, starše) ── */
@media(max-width:390px){
  :root{--pad:16px}
  #hero{padding:90px var(--pad) 48px}
  .h-ttl{font-size:2.8rem}
  .st{font-size:1.9rem}
  .metrics{grid-template-columns:1fr 1fr}
  .m-n{font-size:1.8rem}
  .m-l{font-size:.65rem}

  .svc{padding:24px 18px}
  .sc-card{padding:20px 16px}
}
/* ── FORM STATUS ── */
.form-status {
  display: block;
  min-height: 20px;
  margin-bottom: 12px;
  font-size: .85rem;
  line-height: 1.5;
  border-radius: 6px;
  transition: all .3s;
}
.form-status--ok {
  padding: 12px 16px;
  background: rgba(42, 138, 74, .12);
  border: 1px solid rgba(42, 138, 74, .3);
  color: #5ecf8a;
}
.form-status--error {
  padding: 12px 16px;
  background: rgba(220, 60, 60, .1);
  border: 1px solid rgba(220, 60, 60, .25);
  color: #f07070;
}

/* ── DOKUMENTY ── */
.sp-docs { position:relative; z-index:1; }

.docs-wrap {
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
}

/* shared column widths */
.dh-k  { width:150px; flex-shrink:0; }
.dh-d  { width:90px;  flex-shrink:0; }
.dh-dl { width:130px; flex-shrink:0; justify-content:flex-end; }

/* Header row */
.docs-head {
  display:flex; align-items:center;
  padding:0 20px;
  background:rgba(255,255,255,.04);
  border-bottom:1px solid var(--border);
}
.dh {
  flex:1;
  padding:11px 10px;
  font-size:.62rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--text-dim);
}
.dh-n { width:44px; flex:none; text-align:center; padding-left:0; }

/* Data rows */
.docs-row {
  display:flex; align-items:center;
  padding:0 20px;
  border-bottom:1px solid var(--border);
  transition:background .25s;
}
.docs-row:last-child { border-bottom:none; }
.docs-row:hover { background:rgba(245,166,35,.04); }

.dc {
  flex:1;
  padding:16px 10px;
  font-size:.875rem;
  color:var(--text-muted);
  display:flex; align-items:center;
}
.dc-n {
  flex:none; width:44px;
  font-family:'Syne',sans-serif;
  font-size:.78rem; font-weight:700;
  color:var(--text-dim);
  justify-content:center; padding-left:0;
}
.dc-title {
  gap:14px; flex:1;
  align-items:center;
}
.dc-title strong {
  display:block;
  font-size:.875rem; font-weight:500;
  color:var(--text); line-height:1.3;
  margin-bottom:3px;
}
.dc-title em {
  display:block; font-style:normal;
  font-size:.75rem; color:var(--text-dim);
  line-height:1.4;
}

/* PDF badge */
.dc-pdf {
  flex-shrink:0;
  width:38px; height:38px;
  background:rgba(245,166,35,.1);
  border:1px solid rgba(245,166,35,.2);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:.55rem; font-weight:800;
  letter-spacing:.05em; color:var(--orange);
}

/* Category tags */
.dtag {
  display:inline-flex; align-items:center;
  padding:4px 12px; border-radius:100px;
  font-size:.68rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  white-space:nowrap;
}
.dtag-s {
  background:rgba(245,166,35,.1);
  border:1px solid rgba(245,166,35,.2);
  color:var(--orange);
}
.dtag-r {
  background:rgba(100,180,255,.08);
  border:1px solid rgba(100,180,255,.2);
  color:#7ec8ff;
}
.dtag-o {
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  color:var(--text-muted);
}

/* Download button */
.ddl {
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 16px; border-radius:6px;
  background:rgba(245,166,35,.08);
  border:1px solid rgba(245,166,35,.2);
  color:var(--orange);
  font-size:.73rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  text-decoration:none; white-space:nowrap;
  transition:background .25s, border-color .25s, transform .2s;
}
.ddl:hover {
  background:rgba(245,166,35,.18);
  border-color:var(--orange);
  transform:translateY(-1px);
}

/* Responsive */
@media(max-width:768px){
  .docs-head { display:none; }
  .docs-row  { flex-wrap:wrap; gap:8px; padding:16px; }
  .dc        { padding:0; }
  .dc-n      { display:none; }
  .dc-title  { flex:1 1 100%; }
  .dh-k      { width:auto; }
  .dh-d      { width:auto; font-size:.78rem; }
  .dh-dl     { width:auto; flex:1; justify-content:flex-start; margin-top:4px; }
}

/* ── DOKUMENTY TABUĽKA – responsívna ── */
.docs-tbl-head {
  display: grid;
  grid-template-columns: 50px 1fr 160px 100px 140px;
  background: rgba(255,255,255,0.04);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: 0 24px;
}
.docs-th {
  padding: 12px 8px;
  font-size: .62rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: rgba(240,242,255,0.22);
}
.docs-th:first-child { padding-left: 0; }
.docs-th-dl { text-align: right; }

.docs-tbl-row {
  display: grid;
  grid-template-columns: 50px 1fr 160px 100px 140px;
  align-items: center;
  padding: 0 24px;
  transition: background .25s;
}
.docs-tbl-row:hover { background: rgba(245,166,35,0.04); }

@media(max-width:700px) {
  .docs-tbl-head { display: none; }
  .docs-tbl-row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "name  dl"
      "cat   dl"
      "date  dl";
    padding: 16px;
    gap: 4px 12px;
  }
  /* Číslo – skryjeme */
  .docs-tbl-row > span:first-child { display: none; }
  /* Názov */
  .docs-tbl-row > div:nth-child(2) { grid-area: name; padding: 0; }
  /* Kategória */
  .docs-tbl-row > div:nth-child(3) { grid-area: cat;  padding: 0; }
  /* Dátum */
  .docs-tbl-row > span:nth-child(4){ grid-area: date; padding: 0; font-size: .78rem; }
  /* Tlačidlo */
  .docs-tbl-row > div:last-child   { grid-area: dl;   padding: 0; justify-content: flex-end; align-self: center; }
}
