
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0f172a;
  --ink-soft:#334155;
  --paper:#ffffff;
  --paper-card:#f8fafc;
  --paper-deep:#f1f5f9;
  --primary:#2f3b38;
  --primary-deep:#1e2826;
  --signal:#54a032;
  --signal-deep:#43811f;
  --line:#e2e8f0;
  --line-soft:#f1f5f9;
  --muted:#64748b;
  --display:'Inter',system-ui,-apple-system,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'Inter',ui-monospace,monospace;
  --r:8px;
  --r-lg:14px;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
::selection{background:var(--signal);color:#fff}

/* texture - very subtle on white */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.4;
  background-image:linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);
  background-size:80px 80px}

/* mono label */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--signal);font-weight:600;display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:1px;background:var(--signal)}
.idx{font-family:var(--mono);font-size:13px;color:var(--muted);letter-spacing:.08em}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;letter-spacing:-.025em}
h1 em,h2 em{font-style:normal;color:var(--signal);font-weight:700}

/* ============ DEMO BANNER ============ */
.demo-banner{position:fixed;top:0;left:0;right:0;z-index:300;background:linear-gradient(90deg,var(--primary-deep) 0%,var(--primary) 100%);color:#fff;font-size:13px;
  display:flex;align-items:center;justify-content:center;gap:14px;padding:9px 20px;text-align:center;flex-wrap:wrap;
  border-bottom:1px solid rgba(255,255,255,.08)}
.demo-banner .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 4px rgba(111,191,75,.3);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 7px rgba(111,191,75,0)}}
.demo-banner span{opacity:.85}
.demo-banner b{font-weight:600}
.demo-banner a{color:#fff;font-weight:600;text-decoration:none;border-bottom:1.5px solid var(--signal);padding-bottom:1px;white-space:nowrap}
.demo-banner a:hover{color:var(--signal)}
.demo-banner a.banner-secondary{font-weight:500;border-bottom-color:rgba(255,255,255,.3);opacity:.8}
.demo-banner a.banner-secondary:hover{opacity:1;border-bottom-color:var(--signal)}

/* ============ HEADER ============ */
header{position:fixed;top:39px;left:0;right:0;z-index:200;transition:all .3s}
.nav{display:flex;justify-content:space-between;align-items:center;padding:18px 0;transition:all .3s}
header.scrolled{background:rgba(255,255,255,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(255,255,255,.6) inset}
header.scrolled .nav{padding:12px 0}
.logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo-img{height:36px;width:auto;flex-shrink:0;display:block}
.logo-img-footer{height:42px;filter:brightness(0) invert(1) sepia(.2) hue-rotate(180deg) saturate(2)}
.foot-brand .logo-img-footer{filter:none}
.logo-txt{display:flex;flex-direction:column;line-height:1}
.logo-txt strong{font-family:var(--display);font-weight:700;font-size:17px;color:var(--ink);display:block;line-height:1.05;letter-spacing:-.01em}
.logo-txt span{font-family:var(--body);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{text-decoration:none;font-weight:500;font-size:15px;color:var(--ink-soft);transition:color .2s;position:relative}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--signal);transition:width .25s}
.nav-links a:not(.nav-cta):hover{color:var(--ink)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--signal);color:#fff!important;padding:11px 22px;border-radius:var(--r);font-weight:600;font-size:14px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 14px -4px rgba(111,191,75,.4)}
.nav-cta:hover{background:var(--signal-deep);transform:translateY(-1px);box-shadow:0 8px 20px -4px rgba(111,191,75,.5)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink)}
.menu-toggle svg{width:26px;height:26px}
.nav-close{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink)}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:var(--r);font-weight:600;font-size:15px;
  text-decoration:none;border:0;cursor:pointer;font-family:var(--body);transition:all .25s;position:relative}
.btn svg{width:17px;height:17px;transition:transform .25s}
.btn-primary{background:var(--signal);color:#fff;box-shadow:0 6px 18px -6px rgba(111,191,75,.5)}
.btn-primary:hover{background:var(--signal-deep);transform:translateY(-2px);box-shadow:0 14px 30px -8px rgba(111,191,75,.55)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--primary);background:var(--primary);color:#fff}

/* ============ HERO ============ */
.hero{position:relative;padding:160px 0 100px;z-index:1;overflow:hidden;min-height:680px}
.hero-bg{position:absolute;top:0;right:0;bottom:0;width:50vw;background:url('hero-bg.jpg') center center / cover no-repeat;z-index:0}
.hero-bg::before{content:"";position:absolute;top:0;left:0;bottom:0;width:160px;background:linear-gradient(to right,var(--paper) 0%,rgba(255,255,255,.6) 40%,transparent 100%);pointer-events:none}
.hero-grid{display:block;position:relative;z-index:2}
.hero-content{max-width:560px}
.hero-coord{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--muted);letter-spacing:.06em;margin-bottom:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-coord b{color:var(--ink);font-weight:700}
.hero h1{font-size:clamp(40px,5.6vw,66px);color:var(--ink);margin:18px 0 24px;font-weight:700}
.hero-lead{font-size:19px;color:var(--ink-soft);max-width:520px;margin-bottom:36px;line-height:1.6}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:0;margin-top:54px;border-top:1px solid var(--line)}
.hero-stats .stat{padding:24px 30px 0 0;margin-right:30px;border-right:1px solid var(--line)}
.hero-stats .stat:last-child{border-right:0}
.hero-stats strong{font-family:var(--display);font-size:40px;font-weight:700;color:var(--ink);display:block;line-height:1;letter-spacing:-.03em}
.hero-stats strong i{color:var(--signal);font-style:normal}
.hero-stats span{font-size:13px;color:var(--muted);margin-top:8px;display:block;font-weight:500}

/* hero image card */
.hero-figure{position:relative}
.hero-photo{position:relative;background:linear-gradient(160deg,var(--primary-deep) 0%,var(--primary) 100%);border-radius:var(--r-lg);
  aspect-ratio:4/4.4;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;
  box-shadow:0 40px 80px -30px rgba(47,59,56,.45),0 0 0 1px rgba(255,255,255,.05) inset}
.hero-photo::before{content:"";position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:38px 38px}
.hero-photo img{position:relative;z-index:2;max-height:96%;width:auto;object-fit:contain;filter:drop-shadow(0 20px 30px rgba(0,0,0,.4))}
.hero-target{position:absolute;top:26px;left:26px;z-index:3;width:60px;height:60px}
.hero-target::before,.hero-target::after{content:"";position:absolute;background:var(--signal)}
.hero-target::before{left:50%;top:0;bottom:0;width:1.5px;transform:translateX(-50%)}
.hero-target::after{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%)}
.hero-target i{position:absolute;inset:18px;border:1.5px solid var(--signal);border-radius:50%}
.hero-tag{position:absolute;bottom:22px;left:22px;right:22px;z-index:3;background:rgba(15,23,42,.7);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:14px}
.hero-tag .ico{width:38px;height:38px;flex-shrink:0;border-radius:50%;background:var(--signal);display:flex;align-items:center;justify-content:center;color:#fff}
.hero-tag .ico svg{width:19px;height:19px}
.hero-tag .t1{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:600}
.hero-tag .t2{color:#fff;font-weight:600;font-size:14px}
.hero-badge{position:absolute;top:24px;right:-10px;z-index:4;background:var(--signal);color:#fff;font-family:var(--mono);
  font-size:11px;font-weight:700;letter-spacing:.08em;padding:9px 16px;text-transform:uppercase;border-radius:4px;box-shadow:0 10px 24px -8px rgba(111,191,75,.6)}

/* ============ MARQUEE / TRUST ============ */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-card);padding:22px 0;overflow:hidden;position:relative;z-index:1}
.trust-track{display:flex;gap:56px;width:max-content;animation:scroll 32s linear infinite;align-items:center}
.trust:hover .trust-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.trust-item{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:14px;font-weight:500;letter-spacing:.01em;color:var(--ink-soft);white-space:nowrap}
.trust-item svg{width:18px;height:18px;color:var(--signal);flex-shrink:0}

/* ============ SECTION ============ */
.sec{position:relative;z-index:1;padding:110px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:64px;flex-wrap:wrap}
.sec-head .l{max-width:640px}
.sec-head h2{font-size:clamp(30px,4.2vw,48px);color:var(--ink);margin-top:18px}
.sec-head .r{font-size:16px;color:var(--muted);max-width:300px;text-align:right;padding-bottom:6px}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.svc{padding:38px 34px;border:1px solid var(--line);margin:-0.5px;background:#fff;transition:all .3s;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--signal);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc:hover{background:linear-gradient(160deg,var(--primary-deep) 0%,var(--primary) 100%);z-index:2;transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(47,59,56,.4)}
.svc:hover::before{transform:scaleX(1)}
.svc-no{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.08em;font-weight:600;transition:color .3s}
.svc-ico{width:54px;height:54px;background:var(--paper-deep);border:1.5px solid var(--line);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--signal);margin:22px 0 24px;transition:all .3s}
.svc-ico svg{width:24px;height:24px}
.svc h3{font-size:21px;color:var(--ink);margin-bottom:12px;transition:color .3s;font-weight:600}
.svc p{font-size:14.5px;color:var(--muted);line-height:1.65;transition:color .3s}
.svc:hover .svc-no{color:rgba(255,255,255,.5)}
.svc:hover .svc-ico{border-color:var(--signal);background:var(--signal);color:#fff}
.svc:hover h3{color:#fff}
.svc:hover p{color:rgba(255,255,255,.72)}

/* ============ PROCES ============ */
.proces{background:linear-gradient(160deg,var(--primary-deep) 0%,var(--primary) 100%);color:#fff;position:relative;z-index:1;overflow:hidden}
.proces::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:80px 80px}
.proces::after{content:"";position:absolute;top:-30%;right:-15%;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(111,191,75,.25) 0%,transparent 65%);pointer-events:none;z-index:0}
.proces .kicker{color:var(--signal)}
.proces .sec-head h2{color:#fff}
.proces .sec-head .r{color:rgba(255,255,255,.6)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.step{padding:36px 28px 36px 0;position:relative}
.step:not(:last-child){border-right:1px solid rgba(255,255,255,.12);padding-right:28px;margin-right:28px}
.step-no{font-family:var(--mono);font-size:13px;color:var(--signal);font-weight:700;letter-spacing:.08em;display:inline-flex;align-items:center;gap:10px;margin-bottom:24px}
.step-no::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.15);width:40px}
.step h3{font-size:20px;color:#fff;margin-bottom:12px;font-weight:600}
.step p{font-size:14px;color:rgba(255,255,255,.62);line-height:1.6}

/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.about-visual{position:relative}
.about-quote{background:linear-gradient(160deg,var(--primary-deep) 0%,var(--primary) 100%);color:#fff;padding:44px 40px;border-radius:var(--r-lg);position:relative;overflow:hidden;
  box-shadow:0 30px 60px -25px rgba(47,59,56,.5)}
.about-quote::before{content:"\201C";position:absolute;top:-14px;right:20px;font-family:var(--display);font-size:140px;font-weight:700;color:var(--signal);opacity:.2;line-height:1}
.about-quote .qt{font-size:23px;line-height:1.36;font-weight:500;position:relative;z-index:1;margin-bottom:28px}
.about-quote .qa{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.about-quote .qa-av{width:48px;height:48px;border-radius:50%;background:var(--signal);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:16px;color:#fff;flex-shrink:0}
.about-quote .qa-n{font-weight:600;font-size:15px}
.about-quote .qa-r{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:rgba(255,255,255,.6);text-transform:uppercase}
.about-mini{display:flex;gap:0;margin-top:18px}
.about-mini .m{flex:1;background:#fff;border:1px solid var(--line);padding:22px;text-align:center;margin-left:-1px}
.about-mini .m:first-child{margin-left:0;border-top-left-radius:var(--r);border-bottom-left-radius:var(--r)}
.about-mini .m:last-child{border-top-right-radius:var(--r);border-bottom-right-radius:var(--r)}
.about-mini strong{font-family:var(--display);font-size:30px;font-weight:700;color:var(--signal);display:block;line-height:1;letter-spacing:-.02em}
.about-mini span{font-size:12px;color:var(--muted);margin-top:6px;display:block}
.about-text h2{font-size:clamp(28px,3.8vw,44px);color:var(--ink);margin:18px 0 22px}
.about-text>p{font-size:16.5px;color:var(--ink-soft);margin-bottom:16px;line-height:1.68}
.about-feats{margin-top:34px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.feat{display:flex;gap:15px;align-items:flex-start}
.feat-ico{flex-shrink:0;width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,rgba(111,191,75,.12),rgba(111,191,75,.04));display:flex;align-items:center;justify-content:center;color:var(--signal)}
.feat-ico svg{width:21px;height:21px}
.feat h4{font-family:var(--body);font-weight:600;font-size:15.5px;color:var(--ink);margin-bottom:4px}
.feat p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}

/* ============ PODRUCJE ============ */
.area{background:var(--paper-deep);position:relative;z-index:1}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.area-map{position:relative;aspect-ratio:1.15;border:1px solid var(--line);background:var(--paper-card);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 12px 32px -16px rgba(47,59,56,.18);z-index:1}
.area-map.leaflet-container{font-family:var(--body)}
.leaflet-tooltip.city-label{background:#fff;border:1px solid var(--line);color:var(--ink);font-family:var(--body);font-size:12px;font-weight:600;padding:4px 10px;border-radius:6px;box-shadow:0 4px 10px -3px rgba(15,23,42,.18);white-space:nowrap}
.leaflet-tooltip.city-label.main{background:var(--signal);border-color:var(--signal);color:#fff;font-size:13px;padding:5px 12px;box-shadow:0 6px 14px -3px rgba(111,191,75,.5)}
.leaflet-tooltip-right.city-label::before,.leaflet-tooltip-left.city-label::before{display:none}
.leaflet-control-attribution{font-size:10px!important;background:rgba(255,255,255,.85)!important;padding:2px 6px!important}
.leaflet-attribution-flag{display:none!important}
.leaflet-bar a{border-radius:6px!important;color:var(--ink)!important}
.area-map svg{width:100%;height:100%}
.area-pins{margin-top:32px;display:flex;flex-wrap:wrap;gap:10px}
.pin{font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.01em;padding:8px 14px;background:#fff;border:1px solid var(--line);border-radius:999px;color:var(--ink-soft);transition:all .2s;display:flex;align-items:center;gap:8px}
.pin::before{content:"";width:6px;height:6px;background:var(--signal);border-radius:50%}
.pin:hover{border-color:var(--signal);color:var(--ink);transform:translateY(-2px);box-shadow:0 6px 14px -6px rgba(111,191,75,.25)}

/* ============ FAQ ============ */
.faq-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:64px;align-items:start}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;padding:26px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:var(--display);font-size:19px;font-weight:600;color:var(--ink);transition:color .2s;letter-spacing:-.015em}
.faq-q:hover{color:var(--signal)}
.faq-q .pm{flex-shrink:0;width:30px;height:30px;border:1.5px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ink);transition:all .25s}
.faq-q .pm::before{width:12px;height:1.5px}
.faq-q .pm::after{width:1.5px;height:12px}
.faq-item.open .pm{background:var(--signal);border-color:var(--signal);transform:rotate(90deg)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 54px 28px 0;color:var(--muted);font-size:15.5px;line-height:1.7}

/* ============ CONTACT ============ */
.contact{background:linear-gradient(160deg,var(--primary-deep) 0%,var(--primary) 100%);color:#fff;position:relative;z-index:1;overflow:hidden}
.contact::before{content:"";position:absolute;top:-30%;left:-10%;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(111,191,75,.22) 0%,transparent 65%);pointer-events:none}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px}
.contact .kicker{color:var(--signal)}
.contact h2{font-size:clamp(30px,4.2vw,46px);color:#fff;margin:18px 0 18px}
.contact-info>p{color:rgba(255,255,255,.7);font-size:16px;margin-bottom:36px;max-width:420px}
.crow{display:flex;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.crow:last-child{border-bottom:0}
.crow .ci{flex-shrink:0;width:46px;height:46px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--signal)}
.crow .ci svg{width:20px;height:20px}
.crow .cl{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:3px}
.crow .cv{font-size:16px;font-weight:600}
.crow .cv a{text-decoration:none}
.crow .cv a:hover{color:var(--signal)}
.cform{background:#fff;color:var(--ink);padding:40px;border-radius:var(--r-lg);box-shadow:0 40px 80px -30px rgba(0,0,0,.4),0 0 0 1px var(--line) inset}
.cform h3{font-size:23px;margin-bottom:6px;font-weight:700;letter-spacing:-.01em}
.cform .sub{font-size:14px;color:var(--muted);margin-bottom:26px}
.fg{margin-bottom:18px}
.fg label{display:block;font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--r);font-size:15px;font-family:var(--body);background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:0;border-color:var(--signal);box-shadow:0 0 0 3px rgba(111,191,75,.12)}
.fg textarea{resize:vertical;min-height:104px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ============ FOOTER ============ */
footer{background:#1b2220;color:#fff;padding:72px 0 28px;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:52px}
.foot-brand .logo-txt strong{color:#fff}
.foot-brand p{color:rgba(255,255,255,.5);font-size:14.5px;line-height:1.7;max-width:300px;margin-top:18px}
.foot-col h5{font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:20px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:12px}
.foot-col a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14.5px;transition:color .2s}
.foot-col a:hover{color:var(--signal)}
.foot-partner{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;padding:22px 28px;margin-bottom:26px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;text-align:center}
.foot-partner-label{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.foot-partner-logo{display:inline-flex;align-items:center;background:#fff;padding:8px 16px;border-radius:8px;text-decoration:none;transition:transform .2s,box-shadow .2s}
.foot-partner-logo:hover{transform:translateY(-2px);box-shadow:0 8px 20px -6px rgba(111,191,75,.4)}
.foot-partner-logo img{display:block;height:32px;width:auto}
.foot-partner-desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5}
.foot-partner-desc a{color:var(--signal);text-decoration:none;font-weight:600}
.foot-partner-desc a:hover{text-decoration:underline}
@media(max-width:680px){
  .foot-partner{padding:18px 16px;gap:12px}
  .foot-partner-desc{font-size:12.5px}
}
.foot-bottom{padding-top:26px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.45)}
.foot-bottom .legal a{color:rgba(255,255,255,.5);text-decoration:none;margin:0 6px}
.foot-bottom .legal a:hover{color:#fff}
.foot-credit a{color:var(--signal);text-decoration:none;font-weight:600}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* ============ MOBILE ============ */
@media(max-width:1000px){
  .about-grid,.area-grid,.faq-grid,.contact-grid{grid-template-columns:1fr;gap:46px}
  .hero{padding:130px 0 0;min-height:auto}
  .hero-content{max-width:100%;padding-bottom:50px}
  .hero-bg{position:relative;width:auto;height:380px;margin:30px -32px 0;z-index:1}
  .hero-bg::before{display:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:0}
  .step:nth-child(2){border-right:0;margin-right:0;padding-right:0}
  .step{border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:30px;margin-bottom:30px;margin-right:0}
  .step:nth-child(odd){border-right:1px solid rgba(255,255,255,.12);padding-right:28px;margin-right:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sec-head .r{text-align:left;max-width:none}
  /* Mobile menu kicks in here (umjesto na 680px) - tableti i veliki telefoni */
  .menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--r);background:var(--paper-deep);transition:background .2s}
  .menu-toggle:hover{background:var(--line)}
  /* Neutralize backdrop-filter containing block dok je menu otvoren da nav-links bude full viewport */
  body.menu-open header{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:transparent!important;border-bottom:0!important;box-shadow:none!important;transition:none!important}
  .nav-links{position:fixed!important;inset:0!important;top:0!important;background:#ffffff!important;display:flex!important;flex-direction:column!important;justify-content:flex-start!important;align-items:stretch!important;gap:6px!important;
    transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:310;padding:104px 28px 30px!important;list-style:none;margin:0;overflow-y:auto}
  .nav-links::before{content:"";display:block;position:absolute;top:30px;left:28px;width:160px;height:42px;background:url('geohor-logo.png') left center / contain no-repeat}
  .nav-links.open{transform:none}
  .nav-links li{width:100%;text-align:left;border-bottom:1px solid var(--line)}
  .nav-links li:last-child{border-bottom:0;margin-top:18px}
  .nav-links a{font-size:20px;font-weight:500;display:block;width:100%;padding:18px 4px;color:var(--ink);text-align:left}
  .nav-links a:not(.nav-cta)::after{display:none}
  .nav-links a.nav-cta{font-size:16px;padding:16px 22px;justify-content:center;text-align:center}
  .nav-close{position:fixed;top:28px;right:24px;z-index:320;width:44px;height:44px;border-radius:var(--r);background:var(--paper-deep);opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:center;justify-content:center}
  .nav-close.show{opacity:1;pointer-events:auto}
  body.menu-open .demo-banner{display:none}
  .demo-banner span.hide-sm{display:none}
}
@media(max-width:680px){
  .wrap{padding:0 20px}
  .hero{padding:120px 0 0}
  .hero-bg{height:300px;margin:24px -20px 0}
  .hero-stats{flex-wrap:wrap;gap:0}
  .hero-stats .stat{padding:18px 20px 0 0;margin-right:20px}
  .svc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step{border-right:0!important;margin-right:0!important;padding-right:0!important}
  .step:nth-child(odd){border-right:0!important;margin-right:0!important;padding-right:0!important}
  .about-feats,.frow,.foot-grid{grid-template-columns:1fr}
  .sec{padding:74px 0}
  .sec-head{margin-bottom:44px}
  .faq-a p{padding-right:0}
  .cform{padding:28px 22px}
}

/* ============ PODSTRANICE ============ */
.page-hero{padding:150px 0 60px;position:relative;border-bottom:1px solid var(--line);background:var(--paper-card)}
.page-hero .crumb{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.06em;margin-bottom:18px}
.page-hero .crumb a:hover{color:var(--signal)}
.page-hero h1{font-size:clamp(34px,4.6vw,54px);color:var(--ink);margin:14px 0 18px}
.page-hero p{font-size:18px;color:var(--ink-soft);max-width:600px}
.page-figure{margin-top:8px;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 24px 50px -28px rgba(47,59,56,.35)}
.page-figure img{width:100%;height:440px;object-fit:cover;display:block}
.spec-table{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.spec-table th{background:var(--primary);color:#fff;font-family:var(--display);font-size:14px;font-weight:600;text-align:left;padding:15px 20px;letter-spacing:-.01em}
.spec-table td{padding:14px 20px;border-bottom:1px solid var(--line);font-size:15px;color:var(--ink-soft)}
.spec-table tr:last-child td{border-bottom:0}
.spec-table tr:hover td{background:var(--paper-card)}
.spec-table .mono{font-family:var(--mono);color:var(--signal);font-size:14px}
.layer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.layer{padding:32px 30px;border:1px solid var(--line);margin:-0.5px;background:#fff}
.layer .ln{font-family:var(--mono);font-size:12px;color:var(--signal);font-weight:600;letter-spacing:.08em}
.layer h3{font-size:20px;color:var(--ink);margin:12px 0 10px;font-weight:600}
.layer p{font-size:14.5px;color:var(--muted);line-height:1.65}
.gal4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gal4 img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r);border:1px solid var(--line)}
@media(max-width:1000px){.layer-grid{grid-template-columns:1fr 1fr}.gal4{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.layer-grid{grid-template-columns:1fr}.gal4{grid-template-columns:1fr 1fr}.page-figure img{height:280px}}

/* ============ TRUST LOGOTIPI ============ */
.trust-track{gap:64px}
.trust-item img{height:30px;width:auto;max-width:140px;object-fit:contain;display:block;filter:grayscale(1);opacity:.6;transition:filter .25s,opacity .25s}
.trust-item:hover img{filter:none;opacity:1}

/* ============ MOBILNA STATISTIKA - jedan red ============ */
@media(max-width:680px){
  .hero-stats{flex-wrap:nowrap!important;gap:0}
  .hero-stats .stat{padding:16px 10px 0 0!important;margin-right:10px!important;flex:1;min-width:0}
  .hero-stats .stat:last-child{margin-right:0!important}
  .hero-stats strong{font-size:25px}
  .hero-stats span{font-size:10.5px;margin-top:5px}
  .trust-item img{height:24px;max-width:104px}
  .trust-track{gap:40px}
}
@media(max-width:380px){
  .hero-stats strong{font-size:21px}
  .hero-stats span{font-size:9.5px}
}

/* ============ REFERENCE ZID (logotipi) ============ */
.ref-wall{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.ref-tile{border:1px solid var(--line);margin:-0.5px;min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 24px;text-align:center;background:#fff;transition:background .3s,box-shadow .3s,transform .3s;position:relative}
.ref-tile:hover{background:var(--paper-card);z-index:2;transform:translateY(-2px);box-shadow:0 16px 34px -18px rgba(47,59,56,.3)}
.ref-tile .rt-logo img{height:38px;width:auto;max-width:150px;object-fit:contain;filter:grayscale(1);opacity:.62;transition:filter .25s,opacity .25s}
.ref-tile:hover .rt-logo img{filter:none;opacity:1}
.ref-tile .rt-name{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);letter-spacing:-.02em;line-height:1.2}
.ref-tile .rt-loc{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--muted)}
.ref-cta{margin-top:40px;display:flex;justify-content:center}
@media(max-width:760px){.ref-wall{grid-template-columns:1fr 1fr}.ref-tile{min-height:120px;padding:22px 16px}}
@media(max-width:420px){.ref-wall{grid-template-columns:1fr 1fr}.ref-tile .rt-name{font-size:15px}}

/* ============ FOOTER SOCIAL ============ */
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all .2s}
.foot-social a:hover{background:var(--signal);border-color:var(--signal);color:#fff;transform:translateY(-2px)}
.foot-social svg{width:19px;height:19px}

/* ============ REFERENCE KATEGORIJE (sve-reference) ============ */
.ref-cat{padding:34px 0;border-top:1px solid var(--line)}
.ref-cat:first-of-type{border-top:0}
.rc-head{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.rc-head .rc-ico{width:46px;height:46px;border-radius:12px;background:var(--paper-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--signal);flex-shrink:0}
.rc-head .rc-ico svg{width:22px;height:22px}
.rc-head h3{font-size:21px;color:var(--ink);font-weight:600}
@media(max-width:760px){.ref-wall[style]{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:420px){.ref-wall[style]{grid-template-columns:repeat(2,1fr)!important}}

/* ============ DORADE v2 ============ */
/* Reference - samo logotipi, bez lokacija */
.ref-wall.logos-only .ref-tile{min-height:120px;padding:24px}
.ref-wall.logos-only .rt-logo img{height:42px;max-width:150px}
@media(max-width:760px){
  .ref-wall.logos-only{grid-template-columns:repeat(3,1fr)} /* 3 u red i na mobu */
  .ref-wall.logos-only .ref-tile{min-height:82px;padding:14px 10px}
  .ref-wall.logos-only .rt-logo img{height:26px;max-width:82px}
}

/* Mobilne dorade hero sekcije */
@media(max-width:680px){
  /* veci brojevi statistike */
  .hero-stats strong{font-size:34px}
  .hero-stats span{font-size:11.5px;margin-top:6px}
  .hero-stats .stat{padding:16px 8px 0 0!important;margin-right:8px!important}
  /* CTA gumbi u jedan red */
  .hero-actions{flex-wrap:nowrap;gap:10px}
  .hero-actions .btn{flex:1;justify-content:center;padding:13px 12px;font-size:14px;white-space:nowrap}
  /* naslovna slika niza (16:9) i pomaknuta gore */
  .hero-bg{height:200px;margin:14px -20px 0;background-position:center top}
}
@media(max-width:380px){
  .hero-stats strong{font-size:29px}
  .hero-stats span{font-size:10.5px}
  .hero-actions .btn{font-size:13px;padding:12px 8px}
}

/* Header logo badge */
.logo-50{font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--green-dark,#54a032);border:1px solid var(--signal);border-radius:20px;padding:3px 8px;line-height:1;white-space:nowrap}
@media(max-width:760px){.logo-50{display:none}}

/* Mobilni izbornik - Akripol logo umjesto naslijedjenog geodeti puta */
@media(max-width:1000px){
  .nav-links::before{background-image:url('images/logo-akripol.png')!important;width:150px!important;height:44px!important}
}

/* Desktop - header uvijek ima pozadinu (ne samo na scroll) */
@media(min-width:1001px){
  header{background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(16px) saturate(160%);backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid var(--line)}
  header.scrolled{background:rgba(255,255,255,.96);box-shadow:0 4px 20px -8px rgba(47,59,56,.18)}
}

/* FIX: reference logo zid - sprjeci horizontalni overflow na mobu */
.ref-tile{min-width:0}
.ref-tile .rt-logo{max-width:100%;display:flex;align-items:center;justify-content:center}
.ref-tile .rt-logo img{max-width:100%}
@media(max-width:760px){
  .ref-wall{grid-template-columns:repeat(3,1fr)!important}
  .ref-wall .ref-tile{min-height:88px;padding:16px 10px}
  .ref-wall .ref-tile .rt-logo img{height:28px;max-width:100%}
}
@media(max-width:430px){
  .ref-wall{grid-template-columns:repeat(2,1fr)!important}
}

/* Sec-head s opisom ispod naslova (umjesto desno) */
.sec-head-stack{display:block}
.sec-lead{font-size:17px;color:var(--muted);margin-top:16px;max-width:620px;line-height:1.65}

/* Hero - duzi/meksi bijeli gradient na desktopu */
@media(min-width:1001px){
  .hero-bg::before{width:340px;background:linear-gradient(to right,var(--paper) 0%,rgba(255,255,255,.92) 30%,rgba(255,255,255,.45) 65%,transparent 100%)}
}
/* Hero slika tocno 16:9 na mobu */
@media(max-width:680px){
  .hero-bg{aspect-ratio:16/9;height:auto;background-position:center top}
}

/* ============ DORADE v3 ============ */
/* Footer bijeli logo */
.foot-logo{height:30px;width:auto;display:block;margin-bottom:16px}
/* Mobilna naslovna slika ~15px gore */
@media(max-width:680px){
  .hero-bg{margin:-1px -20px 0}
}
/* Mobilni header: bijela pozadina na scroll + manji font izbornika */
@media(max-width:1000px){
  header.scrolled{background:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);box-shadow:0 4px 16px -8px rgba(47,59,56,.18)}
  .nav-links a{font-size:16px}
  .nav-links a.nav-cta{font-size:15px}
}
