*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f3f8f5;--green:#229070;--green-mid:#29a882;--green-light:#a8d9c6;--green-xlight:#e4f4ee;
  --black:#0d1a14;--gray:#405850;--gray-light:#507060;--border:rgba(34,144,112,0.13);

  /* spacing scale - zmienia się per breakpoint */
  --section-py: 5rem;
  --section-px: max(4vw, calc((100vw - 1280px) / 2));
  --content-max: 1280px;
}
/* laptop 1024–1440 */
@media(min-width:1024px){
  :root{ --section-py: 6rem; }
}
/* desktop 1440+ */
@media(min-width:1440px){
  :root{ --section-py: 7rem; --section-px: max(5vw, calc((100vw - 1400px) / 2)); --content-max: 1400px; }
}
/* wide 1920+ */
@media(min-width:1920px){
  :root{ --section-py: 8rem; --section-px: max(6vw, calc((100vw - 1600px) / 2)); --content-max: 1600px; }
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--black);font-family:'Instrument Sans',sans-serif;font-weight:400;line-height:1.6;overflow-x:hidden}

/* custom scrollbar */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(to bottom, var(--green-mid), var(--green));
  border-radius:8px;
  border:2px solid var(--bg);
}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(to bottom, var(--green), #0f5c40);}
* { scrollbar-width: thin; scrollbar-color: var(--green) var(--bg); }

/* NAV */
body > nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0.9rem 4vw;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
  background:rgba(244,247,240,0.92);
  backdrop-filter:blur(14px);
}
.logo{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.4rem;letter-spacing:-0.02em;color:var(--black);text-decoration:none;justify-self:start}
.logo span{color:var(--green);display:inline-block;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),color 0.2s;}
.logo:hover span{transform:translateY(-3px) scale(1.3);color:var(--green-mid);}
.nav-right{display:flex;align-items:center;gap:1rem;}
nav a.cta-nav{font-size:1rem;font-weight:600;color:#fff;background:var(--green);padding:0.75rem 1.6rem;min-height:44px;display:inline-flex;align-items:center;border-radius:15px;text-decoration:none;transition:background 0.2s,transform 0.15s}
nav a.cta-nav:hover{background:#0f5c40;transform:scale(1.02)}
/* focus styles for accessibility */
a:focus-visible,button:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px;}

/* ===================== HERO ===================== */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 4rem;
  padding: 6rem var(--section-px) 3rem;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

/* giant watermark text - above grid */
.h-bg-text {
  position:absolute;z-index:2;pointer-events:none;
  left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;
  font-size:clamp(14rem,26vw,30rem);
  line-height:1;
  letter-spacing:-0.05em;
  color:rgba(34,144,112,0.055);
  user-select:none;
  white-space:nowrap;
}

/* line grid - below watermark */
.h-bg-dots {
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(34,144,112,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,144,112,0.08) 1px, transparent 1px);
  background-size: 52px 52px;
}

/* big soft glows */
.h-bg-glow {
  position:absolute;pointer-events:none;border-radius:50%;z-index:0;
}
.h-bg-glow-1 {
  width:55vw;height:55vw;top:-15%;right:-8%;
  background:radial-gradient(circle, rgba(34,144,112,0.10) 0%, transparent 65%);
  animation: glowDrift 16s ease-in-out infinite;
}
.h-bg-glow-2 {
  width:35vw;height:35vw;bottom:-8%;left:10%;
  background:radial-gradient(circle, rgba(168,217,198,0.10) 0%, transparent 65%);
  animation: glowDrift 20s ease-in-out infinite reverse 3s;
}
@keyframes glowDrift{0%,100%{transform:translate(0,0)}50%{transform:translate(-2%,4%)}}

/* left content fade mask */
.h-bg-mask {
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background: linear-gradient(to right, var(--bg) 0%, var(--bg) 18%, transparent 48%);
}

/* - left: copy - */
.hero-left {
  position:relative;z-index:3;
  display:flex;flex-direction:column;
  gap:0;
  padding-right:1rem;
}

.hero-badge {
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--green-xlight);border:1px solid var(--green-light);
  color:var(--green);font-size:0.72rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:0.38rem 0.9rem;border-radius:20px;
  margin-bottom:1.6rem;width:fit-content;
  animation:fadeUp 0.6s 0.1s both;
}
.badge-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.25}}

.hero h1 {
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:clamp(3rem,4vw,5rem);
  line-height:1;letter-spacing:-0.03em;
  color:var(--black);margin-bottom:1.6rem;
  animation:fadeUp 0.7s 0.2s both;
}
.hero h1 em{font-style:normal;color:var(--green);}

.hero-sub {
  font-size:clamp(1.05rem,1.6vw,1.35rem);
  color:var(--gray);max-width:42ch;margin-bottom:2.4rem;line-height:1.7;
  animation:fadeUp 0.7s 0.32s both;
}

.hero-actions {
  display:flex;gap:0.85rem;align-items:center;flex-wrap:wrap;
  animation:fadeUp 0.7s 0.44s both;
}

.btn-primary {
  background:var(--green);color:#fff;
  font-family:'Instrument Sans',sans-serif;font-size:1.2rem;font-weight:600;
  padding:0.9rem 2rem;border-radius:15px;text-decoration:none;
  transition:transform 0.15s,background 0.2s,box-shadow 0.2s;
  border:none;cursor:pointer;display:inline-block;
  box-shadow:0 4px 20px rgba(34,144,112,0.25);
  letter-spacing:0.01em;
}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);background:#1a7a5e;box-shadow:0 8px 28px rgba(34,144,112,0.35);}

.btn-ghost {
  color:var(--gray);font-size:1.1rem;text-decoration:none;
  display:inline-flex;align-items:center;gap:0.4rem;
  transition:color 0.2s;
}
.btn-ghost::after{content:'→';transition:transform 0.2s;}
.btn-ghost:hover{color:var(--green);}
.btn-ghost:hover::after{transform:translateX(3px);}

/* scroll hint */
.hero-scroll {
  position:absolute;bottom:2rem;left:5vw;
  font-size:0.65rem;letter-spacing:0.16em;
  color:var(--gray-light);text-transform:uppercase;z-index:3;
  display:flex;align-items:center;gap:0.6rem;
  animation:fadeUp 0.7s 0.8s both;
}
.hero-scroll::before{
  content:'';display:block;width:28px;height:1px;
  background:var(--gray-light);
}

/* - right: phone column - */
.hero-visual {
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:center;
  padding: 2rem 0;
  animation:phoneSlideIn 0.9s cubic-bezier(0.16,1,0.3,1) 0.15s both;
}

@keyframes phoneSlideIn {
  from { opacity:0; transform:translateX(60px) scale(0.94); }
  to   { opacity:1; transform:translateX(0)    scale(1); }
}

/* phone */
.phone {
  position:relative;
  width:clamp(260px, 28vw, 360px);
  flex-shrink:0;
  z-index:3;
  animation:phoneRock 6s ease-in-out infinite;
  filter:
    drop-shadow(0 2px 0 rgba(255,255,255,0.8))
    drop-shadow(0 32px 64px rgba(13,26,20,0.18))
    drop-shadow(0 8px 24px rgba(34,144,112,0.12));
}
/* - phone glow ring - pojawia się co kilka sekund */
.phone::before {
  content:'';
  position:absolute;
  inset:-12px;
  border-radius:56px;
  background:transparent;
  border:2px solid transparent;
  animation:phoneGlowRing 5s ease-in-out infinite 2s;
  pointer-events:none;
  z-index:-1;
}
@keyframes phoneGlowRing {
  0%,40%,100% { border-color:transparent; box-shadow:none; }
  50% { border-color:rgba(34,144,112,0.35); box-shadow:0 0 40px rgba(34,144,112,0.15), inset 0 0 20px rgba(34,144,112,0.05); }
  70% { border-color:rgba(34,144,112,0.15); box-shadow:0 0 20px rgba(34,144,112,0.08); }
}

/* notification flash - pierwsze fi-notif błyska */
.phone-feed-inner .fi-notif:first-of-type {
  animation:notifFlash 5s ease-in-out infinite 2.5s;
}
@keyframes notifFlash {
  0%,35%,100% { box-shadow:none; border-color:rgba(34,144,112,0.1); }
  40% { box-shadow:0 0 0 3px rgba(34,144,112,0.2), 0 4px 20px rgba(34,144,112,0.15); border-color:rgba(34,144,112,0.4); }
  60% { box-shadow:0 0 0 1px rgba(34,144,112,0.1); border-color:rgba(34,144,112,0.2); }
}

/* live dot na chrome pulsuje mocniej */
.phone-live-dot::before {
  animation:livePulse 1.2s ease-in-out infinite;
}
@keyframes livePulse {
  0%,100% { opacity:1; box-shadow:0 0 0 0 rgba(34,144,112,0.6); }
  50% { opacity:0.8; box-shadow:0 0 0 5px rgba(34,144,112,0); }
}

/* screen subtle shimmer */
.phone-screen::before {
  content:'';
  position:absolute;
  top:-100%;left:-60%;
  width:40%;height:300%;
  background:linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.06) 50%, transparent 60%);
  animation:screenShimmer 8s ease-in-out infinite 3s;
  pointer-events:none;
  z-index:10;
}
@keyframes screenShimmer {
  0%,80%,100% { transform:translateX(-100%); opacity:0; }
  82% { opacity:1; }
  95% { transform:translateX(350%); opacity:0; }
}

.phone-frame {
  background:#0d1a14;
  border-radius:44px;
  padding:12px;
  border:1px solid rgba(255,255,255,0.06);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.04),
    0 0 0 1.5px rgba(0,0,0,0.6);
}

/* subtle side buttons */
.phone-frame::before {
  content:'';
  position:absolute;
  left:-3px;top:100px;
  width:3px;height:36px;
  background:rgba(13,26,20,0.9);
  border-radius:2px 0 0 2px;
  box-shadow:0 46px 0 rgba(13,26,20,0.9), 0 86px 0 rgba(13,26,20,0.9);
}
.phone-frame::after {
  content:'';
  position:absolute;
  right:-3px;top:130px;
  width:3px;height:52px;
  background:rgba(13,26,20,0.9);
  border-radius:0 2px 2px 0;
}

.phone-screen {
  background:#f0f5f2;
  border-radius:33px;
  overflow:hidden;
  position:relative;
  aspect-ratio: 9 / 19.5;
  display:flex;
  flex-direction:column;
}

/* dynamic island */
.phone-island {
  position:absolute;top:12px;left:50%;transform:translateX(-50%);
  width:100px;height:26px;
  background:#0d1a14;border-radius:20px;
  z-index:10;
  display:flex;align-items:center;justify-content:flex-end;
  padding-right:10px;gap:5px;
}
.phone-island-dot {
  width:8px;height:8px;border-radius:50%;
  background:rgba(34,144,112,0.6);
  animation:islandPulse 3s ease-in-out infinite;
}
.phone-island-dot:first-child{animation-delay:0s;}
.phone-island-dot:last-child{width:6px;height:6px;animation-delay:0.4s;}
@keyframes islandPulse{0%,100%{opacity:0.5}50%{opacity:1;box-shadow:0 0 6px rgba(34,144,112,0.8)}}

/* status row */
.phone-status {
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 18px 8px;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:10px;font-weight:800;color:var(--black);
}
.phone-status-icons{display:flex;gap:4px;align-items:center;}

/* top chrome: app header */
.phone-chrome {
  margin:0 10px 8px;
  background:#fff;
  border-radius:16px;
  padding:10px 14px;
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid rgba(34,144,112,0.1);
}
.phone-app-name {
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:13px;
  color:var(--black);letter-spacing:-0.02em;
}
.phone-app-name span{color:var(--green);}
.phone-live-dot {
  display:flex;align-items:center;gap:5px;
  font-size:8px;font-weight:600;color:var(--green);
  letter-spacing:0.06em;text-transform:uppercase;
  font-family:'Instrument Sans',sans-serif;
}
.phone-live-dot::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--green);
  animation:pulse 1.5s infinite;
  box-shadow:0 0 0 2px rgba(34,144,112,0.2);
}

/* scrolling feed inside phone */
.phone-feed {
  padding:0 10px 14px;
  display:flex;flex-direction:column;gap:7px;
  flex:1;
  min-height:0;
  overflow:hidden;
  position:relative;
}
.phone-feed::after {
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:60px;
  background:linear-gradient(to top, #f0f5f2, transparent);
  pointer-events:none;z-index:2;
}

/* feed scrolling animation */
.phone-feed-inner {
  display:flex;flex-direction:column;gap:7px;
  animation:feedScroll 14s linear infinite;
}
@keyframes feedScroll{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}

/* feed item types */
.fi {
  background:#fff;
  border-radius:13px;
  border:1px solid rgba(34,144,112,0.1);
  overflow:hidden;
  flex-shrink:0;
}

/* metric card */
.fi-metrics {
  padding:11px 13px;
}
.fi-label {
  font-size:7.5px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray-light);margin-bottom:8px;
  font-family:'Instrument Sans',sans-serif;
}
.fi-nums {
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;
}
.fi-num-item{}
.fi-num-val {
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:17px;line-height:1;
  letter-spacing:-0.025em;color:var(--green);
}
.fi-num-lbl {
  font-size:7px;color:var(--gray-light);margin-top:2px;
  font-family:'Instrument Sans',sans-serif;
  text-transform:uppercase;letter-spacing:0.04em;
}

/* bar chart card */
.fi-chart {padding:11px 13px;}
.fi-bars {
  display:flex;align-items:flex-end;gap:4px;height:44px;
  margin-top:6px;
}
.fi-bar {
  flex:1;border-radius:3px 3px 0 0;
  background:var(--green-light);
}
.fi-bar.hi{background:var(--green);}
.fi-bar:nth-child(1){height:35%}
.fi-bar:nth-child(2){height:52%}
.fi-bar:nth-child(3){height:41%}
.fi-bar:nth-child(4){height:67%}
.fi-bar:nth-child(5){height:58%}
.fi-bar:nth-child(6){height:80%}
.fi-bar:nth-child(7){height:88%}
.fi-bar.hi{height:100%}

/* notification / lead card */
.fi-notif {
  padding:10px 13px;
  display:flex;align-items:flex-start;gap:9px;
}
.fi-notif-dot {
  width:28px;height:28px;border-radius:9px;
  background:var(--green-xlight);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--green);
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:8px;
}
.fi-notif-body{flex:1;}
.fi-notif-title{font-size:9.5px;font-weight:700;color:var(--black);line-height:1.3;font-family:'Bricolage Grotesque',sans-serif;}
.fi-notif-sub{font-size:7.5px;color:var(--gray-light);margin-top:2px;font-family:'Instrument Sans',sans-serif;}
.fi-notif-badge {
  font-size:6.5px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:2px 7px;border-radius:20px;flex-shrink:0;align-self:flex-start;margin-top:2px;
  background:var(--green-xlight);color:var(--green);border:1px solid var(--green-light);
}
.fi-notif-badge.hot{background:var(--green);color:#fff;border-color:var(--green);}

/* ai chat bubble */
.fi-chat{padding:11px 13px;}
.fi-chat-who{font-size:7px;font-weight:700;color:var(--green);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:5px;font-family:'Instrument Sans',sans-serif;}
.fi-chat-bubble{
  background:var(--green-xlight);border-radius:0 10px 10px 10px;
  padding:8px 10px;
  font-size:9px;color:var(--black);line-height:1.55;
  font-family:'Instrument Sans',sans-serif;
}
.fi-chat-time{font-size:6.5px;color:var(--gray-light);margin-top:4px;text-align:right;font-family:'Instrument Sans',sans-serif;}

/* entry */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* cursor */
.cursor-glow{
  position:fixed;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.07) 0%,transparent 70%);
  pointer-events:none;z-index:0;left:0;top:0;
  will-change:transform;
  transition:transform 0.18s ease;
}
@media(max-width:768px){.cursor-glow{display:none}}

.hero-mobile-cards{display:none;}
.process-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: 2rem;
}
.process-step {
  display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  padding:1.75rem 1.5rem;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;
  transition:border-color 0.25s,background 0.25s;
}
.process-step:hover{border-color:rgba(34,144,112,0.4);background:rgba(34,144,112,0.08);}
.process-num {
  width:38px;height:38px;border-radius:10px;
  background:rgba(34,144,112,0.18);
  border:1px solid rgba(34,144,112,0.3);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:0.82rem;
  color:var(--green-light);margin-bottom:1.25rem;flex-shrink:0;
}
.process-step-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.15rem;color:#fff;margin-bottom:0.5rem;}
.process-step-desc{font-size:1rem;color:rgba(255,255,255,0.45);line-height:1.6;}

/* ============ FAQ ============ */
/* ===== SEKCJE: centered label + heading ===== */
.faq > .section-label,
.faq > .section-title,
.calc-section > .section-label,
.calc-section > .section-title,
.case-study > .section-label,
.case-study > .section-title,
.team .team-intro .section-label,
.team .team-intro .section-title,
.vs-section > .section-label,
.vs-section > .section-title,
.opinions > .section-label,
.opinions > .section-title,
.social-proof-header .section-label,
.social-proof-header .section-title{
  display:block;text-align:center;margin-left:auto;margin-right:auto;
}
.faq > .section-label,
.calc-section > .section-label,
.case-study > .section-label,
.team .team-intro .section-label,
.vs-section > .section-label,
.opinions > .section-label,
.social-proof-header .section-label{
  display:inline-flex;
}
.faq,
.calc-section,
.case-study,
.opinions,
.vs-section{
  text-align:center;
}
.faq .faq-grid,
.calc-section .calc-inner,
.case-study .case-study-inner,
.opinions .testimonials-grid,
.vs-section .vs-table{
  text-align:left;
}
.team .team-intro{text-align:center;}
.team .team-intro .team-manifesto{margin-left:auto;margin-right:auto;}
.social-proof-header{text-align:center;}

.faq{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:#fff;}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3.5rem;}

.faq-item{
  border:1px solid var(--border);border-radius:16px;
  overflow:hidden;background:var(--bg);
  transition:border-color 0.2s;
}
.faq-item:hover{border-color:var(--green-light);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.5rem;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.15rem;
  color:var(--black);background:none;border:none;cursor:pointer;
  text-align:left;gap:1rem;
}
.faq-q:hover{color:var(--green);}
.faq-icon{
  width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--green);flex-shrink:0;
  transition:transform 0.3s,background 0.2s,border-color 0.2s;
}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--green);border-color:var(--green);color:#fff;}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.35s ease, padding 0.35s ease;
  font-size:1.05rem;color:var(--gray);line-height:1.75;
}
.faq-item.open .faq-a{max-height:300px;padding:0 1.5rem 1.25rem;}

/* ============ PORTFOLIO FILTER ============ */
.portfolio-filters{
  display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:2rem;
}
.pf-btn{
  font-size:0.78rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  padding:0.45rem 1rem;border-radius:20px;border:1px solid rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);
  cursor:pointer;transition:all 0.2s;font-family:'Instrument Sans',sans-serif;
}
.pf-btn:hover{background:rgba(34,144,112,0.2);border-color:rgba(34,144,112,0.4);color:var(--green-light);}
.pf-btn.active{background:var(--green);border-color:var(--green);color:#fff;}
.vc[data-cat]{transition:opacity 0.3s,transform 0.3s;}
.vc.hidden{opacity:0;pointer-events:none;transform:scale(0.96);}
.vc-add{transition:opacity 0.3s;}

/* ============ STICKY MOBILE CTA ============ */
.sticky-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:90;
  padding:0.75rem 5vw;
  background:rgba(243,248,245,0.97);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--border);
  align-items:center;
  gap:1rem;
  transform:translateY(100%);
  transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);
}
.sticky-cta.visible{transform:translateY(0);}
@media(max-width:768px){.sticky-cta{display:flex;}}
.sticky-cta-text{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:0.88rem;color:var(--black);
  flex:1;
  line-height:1.3;
}
.sticky-cta-text span{color:var(--green);}
.sticky-cta .btn-primary{
  flex:1;
  text-align:center;
  justify-content:center;
  padding:0.75rem 1rem;
  font-size:0.88rem;
  white-space:nowrap;
}
.sticky-cta-desktop{
  position:fixed;right:24px;bottom:24px;z-index:90;
  display:none;align-items:center;gap:0.75rem;
  background:rgba(243,248,245,0.97);
  border:1px solid var(--border);
  border-radius:14px;
  padding:0.6rem 0.7rem;
  box-shadow:0 12px 36px rgba(0,0,0,0.18);
  backdrop-filter:blur(10px);
  transform:translateY(120%);
  transition:transform 0.3s cubic-bezier(0.16,1,0.3,1);
}
.sticky-cta-desktop.visible{transform:translateY(0);}
.sticky-cta-desktop-mail{
  color:var(--gray);text-decoration:none;font-size:0.82rem;font-weight:600;
  padding:0.45rem 0.6rem;border-radius:10px;
}
.sticky-cta-desktop-mail:hover{color:var(--black);background:rgba(0,0,0,0.04);}
.sticky-cta-desktop .btn-primary{padding:0.65rem 0.9rem;font-size:0.82rem;}
@media(min-width:769px){.sticky-cta-desktop{display:flex;}}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.65s ease,transform 0.65s ease;}
.reveal.in-view{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:0.1s;}
.reveal-delay-2{transition-delay:0.2s;}
.reveal-delay-3{transition-delay:0.3s;}
.reveal-delay-4{transition-delay:0.4s;}
.orbit-section {
  padding:var(--section-py) var(--section-px);
  background: var(--black);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  overflow: visible; /* karty pływające muszą być widoczne */
  position: relative;
}
.orbit-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.03;
  pointer-events: none;
}
.orbit-section-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  position: relative;
  z-index: 1;
  max-width: var(--content-max);
  margin: 0 auto;
}
@media(max-width:768px){.orbit-section-inner{grid-template-columns:1fr}}
.orbit-section-text .section-label,.orbit-section .section-label{color:rgba(200,224,208,0.8);background:rgba(34,144,112,0.12);border-color:rgba(34,144,112,0.22);}
.orbit-section-text .section-label::before,.orbit-section .section-label::before{background:rgba(168,217,198,0.7);}
.orbit-section-text .section-title { color: #fff; margin-bottom: 1.5rem }
.orbit-section-text p {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.45);
  line-height: 1.8;
  margin-bottom: 2rem;
}
.orbit-services-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.orbit-services-list li {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: 1.05rem;
  color: rgba(255,255,255,0.6);
}
.orbit-services-list li::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--green);
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 8px var(--green);
}

/* The orbit itself */
.orbit-wrap {
  position: relative;
  width: clamp(320px, 38vw, 540px);
  height: clamp(320px, 38vw, 540px);
  margin: 0 auto;
  overflow: visible;
}
.orbit-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(34,144,112,0.18);
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
}
.orbit-ring.r1{width:40%;height:40%;border-color:rgba(34,144,112,0.35)}
.orbit-ring.r2{width:68%;height:68%}
.orbit-ring.r3{width:100%;height:100%;border-color:rgba(34,144,112,0.08)}

/* spinning dashes on rings */
.orbit-ring.r2::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: 50%;
  border: 1px dashed rgba(34,144,112,0.2);
  animation: spinring 20s linear infinite;
}
.orbit-ring.r3::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: 50%;
  border: 1px dashed rgba(34,144,112,0.1);
  animation: spinring 30s linear infinite reverse;
}
@keyframes spinring { to { transform: rotate(360deg) } }

.orbit-glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 42%; height: 42%;
  border-radius: 50%;
  background: radial-gradient(circle,rgba(34,144,112,0.2) 0%,transparent 70%);
  pointer-events: none;
  animation: glowpulse 3s ease-in-out infinite;
}
@keyframes glowpulse{0%,100%{opacity:0.7}50%{opacity:1}}

.orbit-center {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 26%; height: 26%;
  border-radius: 50%;
  background: var(--green);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 3;
  box-shadow: 0 0 0 8% rgba(34,144,112,0.1), 0 0 50px rgba(34,144,112,0.3);
}
.orbit-center-text {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 0.82rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.3;
}

.orbit-card {
  position: absolute;
  background: rgba(13,26,20,0.9);
  border: 1px solid rgba(34,144,112,0.25);
  border-radius: 16px;
  padding: 0.9rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  white-space: nowrap;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  backdrop-filter: blur(8px);
  z-index: 2;
}
.orbit-card-icon {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: rgba(34,144,112,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--green-light);
}
.orbit-card-label {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
}
.orbit-card-val {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.45);
  margin-top: 2px;
}
.orbit-card-val.pos { color: var(--green-light) }

/* orbit card positions - na zewnątrz ring r3, równomiernie */
.orbit-card.oc1{top:-8%;   left:50%;   transform:translateX(-50%);   animation:float1 4.0s ease-in-out infinite;}
.orbit-card.oc2{top:14%;   right:-8%;  transform:none;               animation:float2 4.5s ease-in-out infinite 0.5s;}
.orbit-card.oc3{top:65%;   right:-8%;  transform:none;               animation:float1 5.0s ease-in-out infinite 1.0s;}
.orbit-card.oc4{bottom:-8%;left:50%;   transform:translateX(-50%);   animation:float2 4.2s ease-in-out infinite 1.5s;}
.orbit-card.oc5{top:65%;   left:-8%;   transform:none;               animation:float1 3.8s ease-in-out infinite 0.8s;}
.orbit-card.oc6{top:14%;   left:-8%;   transform:none;               animation:float2 4.8s ease-in-out infinite 0.3s;}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* TICKER */
.ticker{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0.85rem 0;white-space:nowrap;background:var(--green-xlight)}
.ticker-inner{display:inline-flex;animation:tick 24s linear infinite}
.ticker-inner span{font-family:'Bricolage Grotesque',sans-serif;font-size:0.77rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray);padding:0 2.5rem}
.ticker-inner span.a{color:var(--green)}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* STATS */
.stats-bar{
  background:#fff;
  border-bottom:1px solid var(--border);
  position:relative;
}
.stats-bar-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  max-width:var(--content-max);
  margin:0 auto;
}
.stat-item{
  padding:2.2rem max(1.5rem,2.5vw) 1.8rem;
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:0.4rem;
  position:relative;
}
.stat-item:last-child{border-right:none;}
.stat-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--green),var(--green-mid),transparent);
  opacity:0.6;
}
.stat-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:2.8rem;color:var(--green);letter-spacing:-0.04em;line-height:1;margin-bottom:0.15rem}
.stat-num span{color:var(--green)}
.stat-label{font-size:1.05rem;color:var(--gray);line-height:1.5;max-width:18ch;}
.stat-source{font-size:0.68rem;color:var(--gray-light);text-transform:uppercase;letter-spacing:0.07em;}

/* ============ DIGAN AI ============ */
@keyframes diganOrb1{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(5%,4%) scale(1.12)}50%{transform:translate(-2%,7%) scale(0.93)}75%{transform:translate(-5%,2%) scale(1.06)}}
@keyframes diganOrb2{0%,100%{transform:translate(0,0) scale(1)}30%{transform:translate(-7%,-5%) scale(1.15)}60%{transform:translate(4%,-3%) scale(0.9)}80%{transform:translate(2%,4%) scale(1.08)}}
@keyframes diganOrb3{0%,100%{transform:translate(-50%,-50%) scale(1)}35%{transform:translate(-48%,-53%) scale(1.2)}70%{transform:translate(-52%,-47%) scale(0.85)}}
@keyframes diganGlow{0%,100%{opacity:0.5;box-shadow:0 0 20px rgba(34,144,112,0.4)}50%{opacity:1;box-shadow:0 0 40px rgba(34,144,112,0.9),0 0 80px rgba(34,144,112,0.3)}}
@keyframes diganBadgePulse{0%,100%{box-shadow:0 0 0 0 rgba(34,144,112,0),0 0 12px rgba(34,144,112,0.2)}50%{box-shadow:0 0 0 6px rgba(34,144,112,0),0 0 24px rgba(34,144,112,0.5)}}
@keyframes diganFadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes diganCardIn{from{opacity:0;transform:translateY(32px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes diganFloat1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(4deg)}}
@keyframes diganFloat2{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(14px) rotate(-5deg)}}
@keyframes diganFloat3{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.07)}}
@keyframes diganAurora{0%,100%{opacity:0.35;background-position:0% 50%}50%{opacity:0.65;background-position:100% 50%}}
@keyframes diganShimmer{0%{transform:translateX(-100%) skewX(-12deg)}100%{transform:translateX(300%) skewX(-12deg)}}
@keyframes diganRing{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:0.4}50%{transform:translate(-50%,-50%) scale(1.15);opacity:0.15}}
@keyframes diganParticle{0%{transform:translate(0,0) scale(1);opacity:0.6}100%{transform:translate(var(--px),var(--py)) scale(0);opacity:0}}

/* WRAPPER - white bg, card inside */
.digan-ai-wrap{
  padding:var(--section-py) var(--section-px);
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.digan-ai-wrap::before{
  content:'';position:absolute;
  width:700px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.06) 0%,transparent 70%);
  top:-100px;right:-150px;pointer-events:none;
  animation:diganOrb1 20s ease-in-out infinite;
}

.digan-ai-section{
  max-width:var(--content-max);
  margin:0 auto;
  background:#060f0a;
  border-radius:28px;
  border:1px solid rgba(34,144,112,0.25);
  overflow:hidden;
  padding:clamp(2.5rem,5vw,5rem) clamp(2rem,5vw,5rem);
  position:relative;
  isolation:isolate;
  box-shadow:
    0 0 0 1px rgba(34,144,112,0.1),
    0 30px 80px rgba(6,15,10,0.35),
    0 0 120px rgba(34,144,112,0.12),
    inset 0 1px 0 rgba(255,255,255,0.05);
}
/* animated orbs */
.digan-ai-section::before{
  content:'';position:absolute;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.32) 0%,transparent 60%);
  top:-280px;left:-100px;
  animation:diganOrb1 12s ease-in-out infinite;
  pointer-events:none;z-index:0;
  filter:blur(2px);
}
.digan-ai-section::after{
  content:'';position:absolute;
  width:650px;height:650px;border-radius:50%;
  background:radial-gradient(circle,rgba(41,168,130,0.22) 0%,transparent 60%);
  bottom:-220px;right:-80px;
  animation:diganOrb2 16s ease-in-out infinite;
  pointer-events:none;z-index:0;
  filter:blur(2px);
}
/* third blob - center */
.digan-ai-section .digan-blob3{
  position:absolute;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.14) 0%,transparent 70%);
  top:50%;left:50%;
  animation:diganOrb3 20s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
/* extra blob top-right corner */
.digan-ai-section .digan-blob4{
  position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(168,217,198,0.1) 0%,transparent 70%);
  top:-80px;right:10%;
  animation:diganOrb2 25s ease-in-out infinite reverse;
  pointer-events:none;z-index:0;
  filter:blur(1px);
}
/* aurora gradient strip */
.digan-ai-section .digan-aurora{
  position:absolute;inset:0;
  background:linear-gradient(120deg,
    transparent 0%,
    rgba(34,144,112,0.06) 30%,
    rgba(41,168,130,0.1) 50%,
    rgba(34,144,112,0.06) 70%,
    transparent 100%);
  background-size:200% 200%;
  animation:diganAurora 8s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
/* grid dots bg */
.digan-ai-section .digan-grid-bg{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(34,144,112,0.18) 1px,transparent 1px);
  background-size:40px 40px;
  opacity:0.25;
  pointer-events:none;z-index:0;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
}
/* pulsing ring center */
.digan-ai-section .digan-ring{
  position:absolute;
  width:600px;height:600px;border-radius:50%;
  border:1px solid rgba(34,144,112,0.15);
  top:50%;left:50%;
  animation:diganRing 6s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
.digan-ai-section .digan-ring2{
  position:absolute;
  width:900px;height:900px;border-radius:50%;
  border:1px solid rgba(34,144,112,0.08);
  top:50%;left:50%;
  animation:diganRing 6s ease-in-out infinite 3s;
  pointer-events:none;z-index:0;
}
/* floating particles */
.digan-ai-section .digan-particles{
  position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;
}
.digan-ai-section .digan-particles span{
  position:absolute;border-radius:50%;
  background:var(--green-mid);opacity:0;
  animation:diganParticle var(--dur,6s) ease-out var(--del,0s) infinite;
}

.digan-ai-inner{position:relative;z-index:2;}

/* header */
.digan-ai-header{text-align:center;margin-bottom:5rem;}
.digan-ai-badge{
  display:inline-flex;align-items:center;gap:0.7rem;
  margin-bottom:2rem;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:0.85rem;letter-spacing:0.08em;text-transform:uppercase;
  background:rgba(34,144,112,0.1);
  border:1px solid rgba(34,144,112,0.4);
  padding:0.55rem 1.2rem;border-radius:24px;
  color:var(--green-light);
  animation:diganBadgePulse 3s ease-in-out infinite;
  position:relative;
}
.digan-ai-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--green-mid);flex-shrink:0;
  animation:pulse 1.5s ease-in-out infinite;
}
.digan-ai-badge-x{color:rgba(255,255,255,0.25);font-weight:300;font-size:1.1rem;}
.digan-ai-title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(2.2rem,4vw,3.8rem);letter-spacing:-0.03em;line-height:1.02;
  color:#fff;margin-bottom:1.25rem;margin-left:auto;margin-right:auto;
  text-shadow:0 0 80px rgba(34,144,112,0.45),0 0 30px rgba(34,144,112,0.2);
}
.digan-ai-title em{
  font-style:normal;
  background:linear-gradient(135deg,var(--green-mid),var(--green-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.digan-ai-sub{
  font-size:1.05rem;color:rgba(255,255,255,0.4);line-height:1.75;
  max-width:50ch;margin:0 auto;
}

/* cards grid */
.digan-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}
.digan-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:24px;
  padding:2rem 1.9rem 1.8rem;
  display:flex;flex-direction:column;gap:0.45rem;
  position:relative;overflow:hidden;
  cursor:default;
  transition:border-color 0.3s,background 0.3s,transform 0.3s,box-shadow 0.3s;
  opacity:0;
  animation:diganCardIn 0.6s cubic-bezier(0.22,1,0.36,1) both;
  animation-delay:calc(var(--di,0) * 0.08s);
}
/* top accent line */
.digan-card::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,144,112,0.6),transparent);
  opacity:0;transition:opacity 0.3s;
}
/* glow spot on hover */
.digan-card::after{
  content:'';position:absolute;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.15),transparent 70%);
  top:-60px;left:-40px;
  opacity:0;transition:opacity 0.4s;pointer-events:none;
}
.digan-card:hover{
  border-color:rgba(34,144,112,0.35);
  background:rgba(34,144,112,0.06);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,0.4),0 0 0 1px rgba(34,144,112,0.15);
}
.digan-card:hover::before{opacity:1;}
.digan-card:hover::after{opacity:1;}
.digan-card:hover .digan-card-icon{
  background:rgba(34,144,112,0.25);
  box-shadow:0 0 20px rgba(34,144,112,0.4);
  color:#fff;
}
.digan-card--wide{grid-column:span 3;}
.digan-card--wide{
  background:linear-gradient(135deg,rgba(34,144,112,0.08),rgba(34,144,112,0.03));
  border-color:rgba(34,144,112,0.2);
  flex-direction:row;align-items:flex-start;gap:2rem;flex-wrap:wrap;
}
.digan-card--wide .digan-card-body{flex:1;min-width:260px;}
.digan-card--wide .digan-card-icon{flex-shrink:0;width:56px;height:56px;border-radius:16px;margin-bottom:0;}
.digan-card-icon{
  width:48px;height:48px;border-radius:14px;
  background:rgba(34,144,112,0.12);border:1px solid rgba(34,144,112,0.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--green-mid);margin-bottom:0.75rem;
  flex-shrink:0;
  transition:background 0.3s,box-shadow 0.3s,color 0.3s;
}
.digan-card-tag{
  font-size:0.68rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--green-mid);margin-bottom:0.2rem;opacity:0.8;
}
.digan-card-name{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:1.3rem;color:#fff;letter-spacing:-0.015em;line-height:1.1;
  margin-bottom:0.5rem;
}
.digan-card-desc{font-size:1.05rem;color:rgba(255,255,255,0.5);line-height:1.75;}
/* shimmer on hover */
.digan-card .digan-shimmer{
  position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:inherit;
}
.digan-card .digan-shimmer::after{
  content:'';position:absolute;
  top:0;left:0;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);
  transform:translateX(-100%) skewX(-12deg);
}
.digan-card:hover .digan-shimmer::after{
  animation:diganShimmer 0.7s ease-in-out forwards;
}
@media(max-width:960px){
  .digan-cards{grid-template-columns:repeat(2,1fr);}
  .digan-card--wide{grid-column:span 2;flex-direction:column;gap:1rem;}
  .digan-ai-section{border-radius:20px;}
}
@media(max-width:560px){
  .digan-cards{grid-template-columns:1fr;}
  .digan-card--wide{grid-column:span 1;}
  .digan-ai-title{font-size:clamp(1.9rem,7vw,2.8rem);}
  .digan-ai-section{border-radius:16px;}
  .digan-ai-wrap{padding:3rem var(--section-px);}
}

/* FOR WHOM */
.for-whom{
  padding:var(--section-py) var(--section-px);
  background:#fff;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.for-whom .for-whom-heading{margin-left:auto;margin-right:auto;}
.for-whom .for-whom-desc{margin-left:auto;margin-right:auto;}
.industry-tag{text-align:left;}
.for-whom-inner{
  max-width:var(--content-max);
  margin:0 auto;
}
.for-whom-divider{display:none;}
.for-whom-heading{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(1.9rem,3.2vw,3.2rem);letter-spacing:-0.025em;line-height:1.1;
  color:var(--black);margin-bottom:1rem;max-width:none;
}
.for-whom-desc{
  font-size:1.05rem;color:var(--gray);line-height:1.7;
  margin-bottom:2.5rem;max-width:52ch;
}
.industries{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.industry-tag{
  display:flex;flex-direction:column;align-items:flex-start;gap:0.75rem;
  font-size:1rem;font-weight:700;
  background:#fff;border:1px solid rgba(34,144,112,0.2);
  padding:1.4rem 1.5rem;border-radius:16px;
  color:var(--black);cursor:default;
  transition:border-color 0.2s,color 0.2s,background 0.2s,transform 0.2s,box-shadow 0.2s;
}
.industry-tag:hover{border-color:var(--green);color:var(--green);background:var(--green-xlight);transform:translateY(-3px);box-shadow:0 8px 24px rgba(34,144,112,0.1);}
.industry-tag svg{width:22px;height:22px;flex-shrink:0;opacity:0.7;}
.industry-tag:hover svg{opacity:1;}
.pillars{display:flex;flex-direction:column;gap:1.2rem;}
.pillar{
  display:flex;align-items:center;gap:1.2rem;
  padding:1.4rem 1.6rem;
  background:#fff;border:1px solid rgba(34,144,112,0.18);border-radius:16px;
  transition:border-color 0.2s,background 0.2s,transform 0.2s,box-shadow 0.2s;
  box-shadow:0 4px 15px rgba(0,0,0,0.02);
}
.pillar:hover{border-color:var(--green);background:var(--green-xlight);transform:translateY(-3px);box-shadow:0 8px 25px rgba(34,144,112,0.08);}
.pillar-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--green-xlight);border:1px solid var(--green-light);
  display:flex;align-items:center;justify-content:center;
  color:var(--green);flex-shrink:0;
}
.pillar-icon svg{width:22px;height:22px;}
.pillar-text{flex:1;}
.pillar-name{font-size:1.15rem;font-weight:700;color:var(--black);line-height:1.2;margin-bottom:0.3rem;}
.pillar-sub{font-size:1rem;color:var(--gray);line-height:1.5;}

/* SERVICES */
.services{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:var(--bg);text-align:center;}
.services .section-title{margin-left:auto;margin-right:auto;}
.service-card{text-align:left;}
.section-label{
  display:inline-flex;align-items:center;gap:0.45rem;
  font-size:0.75rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--green);margin-bottom:1.5rem;
  background:var(--green-xlight);border:1px solid var(--green-light);
  padding:0.4rem 1rem 0.4rem 0.8rem;border-radius:24px;
}
.section-label::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--green);flex-shrink:0;
}
.section-title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(1.9rem,3.2vw,3.2rem);
  letter-spacing:-0.025em;line-height:1.05;
  margin-bottom:clamp(2rem,4vw,4rem);
  max-width:30ch;color:var(--black)
}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden}
@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.services-grid{grid-template-columns:1fr}}
.service-card{padding:2.5rem 2rem;background:#fff;position:relative;overflow:hidden;transition:background 0.25s}
.service-card:hover{background:var(--green-xlight)}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform 0.3s}
.service-card:hover::after{transform:scaleX(1)}
.service-num{font-family:'Bricolage Grotesque',sans-serif;font-size:0.68rem;font-weight:600;letter-spacing:0.1em;color:var(--green);margin-bottom:1rem}
.svc-icon{width:38px;height:38px;color:var(--green);margin-bottom:1.2rem;display:block}
.service-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.3rem;margin-bottom:0.6rem;color:var(--black)}
.service-desc{font-size:1.05rem;color:var(--gray);line-height:1.65}

/* PORTFOLIO */
.portfolio{padding:var(--section-py) var(--section-px);border-bottom:1px solid rgba(255,255,255,0.06);background:var(--black);text-align:center;}
.portfolio .portfolio-grid{text-align:left;}
.portfolio .portfolio-filters{justify-content:center;}
.portfolio .section-label{color:var(--green-light);background:rgba(34,144,112,0.15);border-color:rgba(34,144,112,0.3);}
.portfolio .section-label::before{background:var(--green-light);}
.portfolio .section-title{color:#fff;margin-bottom:0.75rem;margin-left:auto;margin-right:auto;}
.portfolio-subtitle{font-size:1rem;color:rgba(255,255,255,0.35);margin-bottom:3.5rem;max-width:48ch;margin-left:auto;margin-right:auto;}
.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
@media(max-width:1100px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}

.vc{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:9/16;background:#111;border:1px solid rgba(255,255,255,0.07);transition:border-color 0.25s,transform 0.25s;display:flex;flex-direction:column}
.vc:hover{border-color:var(--green);transform:translateY(-4px)}
.vc iframe{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:20px}
.vc-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:linear-gradient(160deg,#1a2a1e 0%,#111 100%)}
.vc-placeholder-icon{width:52px;height:52px;border-radius:50%;background:rgba(34,144,112,0.25);border:1px solid rgba(34,144,112,0.3);display:flex;align-items:center;justify-content:center;color:var(--green-light);transition:background 0.2s,transform 0.2s}
.vc:hover .vc-placeholder-icon{background:rgba(34,144,112,0.45);transform:scale(1.08)}
.vc-placeholder-hint{font-size:0.68rem;color:rgba(255,255,255,0.2);letter-spacing:0.05em}
.vc-overlay{position:absolute;bottom:0;left:0;right:0;padding:3rem 1.1rem 1.1rem;background:linear-gradient(to top,rgba(0,0,0,0.9) 0%,transparent 100%);z-index:3;pointer-events:none}
.vc-kind{font-size:0.55rem;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:var(--green-light);background:rgba(34,144,112,0.3);border:1px solid rgba(34,144,112,0.4);padding:2px 8px;border-radius:20px;display:inline-block;margin-bottom:0.5rem}
.vc-client{font-size:0.65rem;color:rgba(255,255,255,0.5);font-weight:500;margin-bottom:3px}
.vc-title{font-family:'Bricolage Grotesque',sans-serif;font-size:0.88rem;font-weight:700;color:#fff;line-height:1.3}

.vc-add{aspect-ratio:9/16;border-radius:20px;border:1.5px dashed rgba(255,255,255,0.08);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.9rem;cursor:pointer;transition:border-color 0.2s,background 0.2s;background:rgba(255,255,255,0.02)}
.vc-add:hover{border-color:rgba(34,144,112,0.5);background:rgba(34,144,112,0.05)}
.vc-add-icon{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.2);transition:border-color 0.2s,color 0.2s}
.vc-add:hover .vc-add-icon{border-color:var(--green);color:var(--green)}
.vc-add span{font-size:0.72rem;color:rgba(255,255,255,0.2);text-align:center;line-height:1.5;padding:0 1.5rem;transition:color 0.2s}
.vc-add:hover span{color:rgba(255,255,255,0.4)}

/* SLIDER KLIENCI */
.social-proof{padding:var(--section-py) 0;border-bottom:1px solid var(--border);background:#fff;overflow:hidden}
.social-proof-header{padding:0 var(--section-px);margin-bottom:3.5rem}
.clients-slider-wrap{position:relative;overflow:hidden}
.clients-slider-wrap::before,.clients-slider-wrap::after{content:'';position:absolute;top:0;bottom:0;z-index:2;width:120px;pointer-events:none}
.clients-slider-wrap::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.clients-slider-wrap::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.clients-track{display:flex;gap:1.5rem;width:max-content;animation:slide-clients 20s linear infinite;padding:0 2rem}
.clients-track:hover{animation-play-state:paused}
@keyframes slide-clients{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.client-card{flex-shrink:0;min-width:180px;padding:1.6rem 1.8rem;border:1px solid var(--green-light);border-radius:14px;background:var(--green-xlight);transition:background 0.2s,border-color 0.2s,transform 0.2s;cursor:default}
.client-card:hover{background:var(--green-light);border-color:var(--green);transform:translateY(-3px)}
.client-card-logo{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.5rem;color:var(--green);letter-spacing:-0.02em;margin-bottom:0.4rem}
.client-card-tag{font-size:0.8rem;font-weight:600;color:var(--gray-light);text-transform:uppercase;letter-spacing:0.1em}

/* OPINIONS */
.opinions{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:var(--bg)}
.opinions-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.2rem;margin-top:3.5rem}
.opinion-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;transition:border-color 0.25s,transform 0.2s;text-align:left}
.opinion-card:hover{border-color:var(--green-light);transform:translateY(-2px)}
.opinion-card:nth-child(1){grid-column:span 2}
.opinion-card:nth-child(2){grid-column:span 2}
.opinion-card:nth-child(3){grid-column:span 2}
.opinion-card:nth-child(4){grid-column:span 3}
.opinion-card:nth-child(5){grid-column:span 3}
@media(max-width:900px){.opinions-grid{grid-template-columns:1fr}.opinion-card:nth-child(n){grid-column:1/-1}}
.opinion-stars{color:var(--green);font-size:0.85rem;letter-spacing:2px}
.opinion-text{font-size:1.05rem;color:var(--gray);line-height:1.75;font-style:italic;flex:1}
.opinion-author{display:flex;align-items:center;gap:0.75rem;padding-top:1rem;border-top:1px solid var(--border)}
.opinion-avatar{width:36px;height:36px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:0.8rem;color:var(--green);flex-shrink:0}
.opinion-name{font-weight:500;font-size:1rem;color:var(--black);line-height:1.2}
.opinion-company{font-size:0.85rem;color:var(--gray-light)}

/* CASE STUDY */
.case-study{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:#fff}
.case-study-inner{margin-top:3.5rem;border:1px solid var(--green-light);border-radius:20px;overflow:hidden;background:var(--green-xlight)}
.case-study-top{padding:3rem 3rem 2.5rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;border-bottom:1px solid var(--green-light)}
.case-tag{display:inline-block;background:var(--green);color:#fff;font-size:0.7rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:20px;margin-bottom:1rem}
.case-study-top h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(1.5rem,2.5vw,2.1rem);letter-spacing:-0.02em;line-height:1.1;color:var(--black);margin-bottom:1rem}
.case-study-top p{font-size:1rem;color:var(--gray);line-height:1.75}
.case-results{display:flex;flex-direction:column;gap:1rem}
.case-result-item{background:#fff;border-radius:12px;padding:1.2rem 1.5rem;display:flex;align-items:center;gap:1.2rem;border:1px solid var(--green-light)}
.case-result-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.9rem;color:var(--green);letter-spacing:-0.03em;line-height:1;white-space:nowrap}
.case-result-label{font-size:1.05rem;color:var(--gray);line-height:1.5}
.case-study-bottom{padding:2rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.case-client-info{display:flex;align-items:center;gap:1rem}
.case-client-dot{width:44px;height:44px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:0.85rem;color:#fff}
.case-client-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1rem;color:var(--black)}
.case-client-cat{font-size:0.8rem;color:var(--gray-light)}
.case-services{display:flex;gap:0.5rem;flex-wrap:wrap}
.case-service-tag{padding:0.3rem 0.75rem;border:1px solid var(--green-light);border-radius:20px;font-size:0.75rem;color:var(--green);font-weight:500;background:#fff}

/* WHY */
.why{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:var(--bg);}
.why-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:3.5rem;max-width:80ch;margin-left:auto;margin-right:auto;}
.why-intro-text{font-size:1.05rem;color:var(--gray);margin-top:1rem;line-height:1.8;}
.why-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:3rem;}
.why-stat{display:flex;flex-direction:column;align-items:flex-start;gap:0.5rem;padding:1.75rem 2rem;background:#fff;border:1px solid var(--border);border-radius:20px;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;}
.why-stat:hover{border-color:var(--green-light);transform:translateY(-3px);box-shadow:0 12px 32px rgba(34,144,112,0.09);}
.why-stat-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:2.6rem;color:var(--green);letter-spacing:-0.04em;line-height:1;white-space:nowrap;flex-shrink:0;}
.why-stat-text{font-size:0.95rem;color:var(--gray);line-height:1.55;}
.why-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;}
.why-card{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;
  transition:border-color 0.25s,background 0.25s,transform 0.2s,box-shadow 0.25s;
  position:relative;overflow:hidden;
}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--green-mid));transform:scaleX(0);transform-origin:left;transition:transform 0.35s;}
.why-card:hover{border-color:var(--green-light);background:var(--green-xlight);transform:translateY(-3px);box-shadow:0 12px 32px rgba(34,144,112,0.08);}
.why-card:hover::before{transform:scaleX(1);}
.why-card--wide{grid-column:1/-1;flex-direction:row;align-items:flex-start;gap:1.25rem;}
.why-card--wide .why-card-body{flex:1;}
.why-card-icon{width:44px;height:44px;border-radius:12px;background:var(--green-xlight);border:1px solid rgba(34,144,112,0.2);display:flex;align-items:center;justify-content:center;color:var(--green);flex-shrink:0;}
.why-card-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.08rem;color:var(--black);line-height:1.3;}
.why-card-desc{font-size:0.97rem;color:var(--gray);line-height:1.7;}
@media(max-width:900px){
  .why-stats{grid-template-columns:1fr 1fr;}
  .why-cards{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){
  .why-stats{grid-template-columns:1fr;}
  .why-cards{grid-template-columns:1fr;}
}

/* TEAM */
.team{padding:var(--section-py) var(--section-px);border-bottom:1px solid var(--border);background:#fff}
.team-intro{max-width:72ch;margin-bottom:5rem;margin-left:auto;margin-right:auto;}
.team-intro .section-title{margin-bottom:1.2rem}
.team-manifesto{font-size:clamp(1.1rem,1.8vw,1.35rem);color:var(--gray);line-height:1.75;font-style:italic}
.team-manifesto em{font-style:normal;color:var(--green);font-weight:600}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.team-card{border:1px solid var(--border);border-radius:20px;padding:2.5rem;background:var(--bg);transition:border-color 0.25s,background 0.25s;position:relative;overflow:hidden}
.team-card:hover{border-color:var(--green-light);background:var(--green-xlight)}
.team-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform 0.35s}
.team-card:hover::before{transform:scaleX(1)}
.team-avatar{width:64px;height:64px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.3rem;color:var(--green);margin-bottom:1.5rem;border:3px solid #fff;box-shadow:0 0 0 2px var(--green-light)}
.team-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.3rem;letter-spacing:-0.02em;color:var(--black);margin-bottom:0.25rem}
.team-role{font-size:0.8rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-bottom:1.1rem}
.team-bio{font-size:1.05rem;color:var(--gray);line-height:1.8;margin-bottom:1.5rem}
.team-skills{display:flex;flex-wrap:wrap;gap:0.4rem}
.team-skill{font-size:0.68rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:20px;border:1px solid var(--green-light);color:var(--green);background:#fff}

/* POPUP */
.popup-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.popup-overlay.open{display:flex}
.popup-box{background:#fff;border-radius:20px;width:min(560px,94vw);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;position:relative}
.popup-header{padding:1.4rem 1.6rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.popup-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.1rem;letter-spacing:-0.01em;color:var(--black)}
.popup-close{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray);transition:background 0.2s}
.popup-close:hover{background:var(--bg)}
.popup-body{flex:1;overflow-y:auto}
.popup-body iframe{width:100%;min-height:450px;border:none;display:block}

/* ===== CTA ===== */
.cta-section{
  padding:7rem var(--section-px);
  background:var(--black);
  position:relative;overflow:hidden;
  text-align:center;
}
.cta-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 80% at 50% 100%, rgba(34,144,112,0.12) 0%, transparent 65%);
}
.cta-section::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(34,144,112,0.5) 50%, transparent 100%);
}
.cta-inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  max-width:640px;
  margin:0 auto;
  gap:0;
}
.cta-kicker{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-size:0.68rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--green-light);margin-bottom:2rem;
  background:rgba(34,144,112,0.12);border:1px solid rgba(34,144,112,0.25);
  padding:0.3rem 0.8rem 0.3rem 0.6rem;border-radius:20px;
}
.cta-kicker-dot{
  width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;
  animation:liveRing 2s ease-out infinite;
}
.cta-section h2{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(2.6rem,5vw,4.2rem);letter-spacing:-0.04em;line-height:1.05;
  margin-bottom:1.25rem;color:#fff;
}
.cta-section h2 em{font-style:normal;color:var(--green);}
.cta-section .cta-desc{
  color:rgba(255,255,255,0.4);font-size:1rem;
  line-height:1.75;margin-bottom:2.5rem;
  max-width:48ch;
}
.cta-stats{display:none;}
.cta-right{
  width:100%;
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  position:relative;overflow:visible;
  box-shadow:none;
}
.cta-right::before{display:none;}
.cta-right-title{display:none;}
.cta-right-sub{display:none;}
.btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:0.6rem;
  background:var(--green);color:#fff;
  font-family:'Bricolage Grotesque',sans-serif;font-size:1.05rem;font-weight:700;
  padding:1rem 2.4rem;border-radius:15px;
  transition:transform 0.15s,box-shadow 0.2s,background 0.2s;
  border:none;cursor:pointer;letter-spacing:-0.01em;
  box-shadow:0 4px 32px rgba(34,144,112,0.4);
  margin-bottom:1.5rem;width:auto;
}
.btn-white:hover{transform:translateY(-2px);background:#1a7a5e;box-shadow:0 8px 40px rgba(34,144,112,0.55);}
.btn-white svg{transition:transform 0.2s}
.btn-white:hover svg{transform:translateX(4px)}
.cta-trust{
  display:flex;flex-wrap:wrap;justify-content:center;gap:0.4rem 1.2rem;
}
.cta-trust span{
  display:flex;align-items:center;gap:0.45rem;
  font-size:0.78rem;color:rgba(255,255,255,0.25);
}
.cta-trust span::before{
  content:'';width:14px;height:14px;flex-shrink:0;
  border-radius:50%;background:rgba(34,144,112,0.2);border:1px solid rgba(34,144,112,0.4);
  background-image:url("data:image/svg+xml,%3Csvg width='7' height='5' viewBox='0 0 7 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 2.5l1.5 1.5 3.5-3.5' stroke='%2329a882' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* ===== FOOTER ===== */
footer{background:var(--black);color:#fff;position:relative;z-index:2;}
footer nav{position:static;display:flex;background:none;border:none;padding:0;backdrop-filter:none}

.footer-divider{
  height:1px;
  background:linear-gradient(to right, transparent, rgba(34,144,112,0.3) 30%, rgba(34,144,112,0.3) 70%, transparent);
  margin:0 var(--section-px);
}
.footer-main{
  padding:4rem var(--section-px) 3rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:1.5rem;
}
.footer-logo-large{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(1.8rem,3vw,2.8rem);letter-spacing:-0.03em;
  color:#fff;text-decoration:none;
  transition:opacity 0.2s;
}
.footer-logo-large:hover{opacity:0.7;}
.footer-logo-large span{color:var(--green);}
.footer-tagline-main{
  font-size:0.9rem;color:rgba(255,255,255,0.3);
  letter-spacing:0.02em;margin-top:-0.5rem;
}
.footer-contact-row{
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:center;
}
.footer-legal{display:flex;align-items:center;gap:1.2rem;}
.footer-logo{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:1.4rem;letter-spacing:-0.02em;color:#fff;
  text-decoration:none;display:inline-block;margin-bottom:1rem;
}
.footer-logo span{color:var(--green);}
.footer-desc{font-size:0.88rem;color:rgba(255,255,255,0.32);line-height:1.8;max-width:34ch;margin-bottom:1.5rem}
.footer-mail-link{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-size:0.85rem;color:rgba(255,255,255,0.45);text-decoration:none;
  transition:color 0.2s;
}
.footer-mail-link:hover{color:#fff;}
.footer-mail-link svg{opacity:0.5;}
.footer-company{
  display:flex;gap:0.75rem;flex-wrap:wrap;justify-content:center;
  font-size:0.74rem;color:rgba(255,255,255,0.35);
}

.footer-col-title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.25);margin-bottom:1.2rem;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:0.6rem;}
.footer-links a{font-size:0.88rem;color:rgba(255,255,255,0.4);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:#fff;}

.footer-bottom{
  padding:1.4rem var(--section-px);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,0.05);
}
.footer-copy{font-size:0.72rem;color:rgba(255,255,255,0.18);}
.footer-bottom-right{display:flex;align-items:center;gap:1.5rem;}
.footer-legal a{font-size:0.72rem;color:rgba(255,255,255,0.18);text-decoration:none;transition:color 0.2s;}
.footer-legal a:hover{color:rgba(255,255,255,0.5);}
.footer-socials{display:flex;gap:0.5rem;}
.footer-social{
  width:32px;height:32px;border:1px solid rgba(255,255,255,0.08);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.3);text-decoration:none;
  transition:border-color 0.2s,color 0.2s,background 0.2s;
}
.footer-social:hover{border-color:rgba(34,144,112,0.5);color:var(--green);background:rgba(34,144,112,0.08);}
.footer-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(34,144,112,0.1);border:1px solid rgba(34,144,112,0.2);
  color:var(--green);font-size:0.7rem;font-weight:600;
  letter-spacing:0.06em;padding:0.35rem 0.85rem;border-radius:20px;
}
.footer-badge-dot{width:5px;height:5px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
/* ============================================================
   TABLET 768–1024px
   ============================================================ */
@media(min-width:769px) and (max-width:1024px){
  .hero{gap:3rem;}
  .hero h1{font-size:clamp(3rem,4.5vw,4.5rem);}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:1fr 1fr;}
  .why{gap:3.5rem;}
  .why h2{font-size:clamp(1.8rem,3vw,2.4rem);}
  .why-stat-num{font-size:1.6rem;}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);}
  .orbit-section-inner{grid-template-columns:1fr;}
  .orbit-wrap{width:clamp(280px,42vw,460px);height:clamp(280px,42vw,460px);}
  .faq-grid{grid-template-columns:1fr;}
  .case-study-top{gap:2rem;}
  .process-steps{grid-template-columns:repeat(2,1fr);}
  .process-step{padding:1.5rem 1.25rem;}
  .opinions-grid{grid-template-columns:1fr;margin-top:2.5rem;}
  .opinion-card:nth-child(n){grid-column:1/-1;}
  .section-title{font-size:clamp(1.8rem,3vw,2.5rem);}
}

/* ============================================================
   LARGE DESKTOP 1440–1920px
   ============================================================ */
@media(min-width:1440px){
  .hero h1{font-size:clamp(4rem,4.5vw,5.5rem);}
  .hero-sub{font-size:1.25rem;max-width:46ch;}
  .services-grid{grid-template-columns:repeat(4,1fr);}
  .portfolio-grid{grid-template-columns:repeat(4,1fr);}
  .section-title{font-size:clamp(2.4rem,2.8vw,3.8rem);}
  .stat-num{font-size:3rem;}
  .process-step-title{font-size:1.1rem;}
  .process-step-desc{font-size:1rem;}
}

/* ============================================================
   ULTRAWIDE 1920px+
   ============================================================ */
@media(min-width:1920px){
  .hero h1{font-size:clamp(4.5rem,5vw,6.5rem);}
  .hero-sub{font-size:1.4rem;max-width:50ch;}
  .section-title{font-size:clamp(2.8rem,3vw,4.5rem);}
  .stat-num{font-size:3.5rem;}
  .cta-section h2{font-size:clamp(4.5rem,5vw,6.5rem);}
  .team-card{padding:3rem;}
  .service-card{padding:3rem 2.5rem;}
}

/* ============================================================
   MOBILE - wszystkie poprawki w jednym miejscu
   ============================================================ */
@media(max-width:768px){

  /* HERO */
  .hero{
    grid-template-columns:1fr;
    gap:0;
    padding: 5rem 5vw 0;
    min-height: auto;
    overflow:hidden;
  }
  .hero-visual{display:none;}
  .hero-left{padding-right:0;padding-bottom:2.5rem;}
  .hero-scroll{display:none;}
  .h-bg-text{font-size:8rem;left:auto;right:-1rem;transform:translateY(-50%);}
  .hero h1{font-size:clamp(2.8rem,8vw,3.8rem);line-height:1;}
  .hero-sub{font-size:1rem;max-width:100%;margin-bottom:1.6rem;}
  .hero-actions{flex-direction:column;gap:0.75rem;width:100%;}
  .btn-primary{width:100%;text-align:center;justify-content:center;}
  .btn-ghost{text-align:left;}

  /* animowane karty mobile - horizontal scroll strip */
  .hero-mobile-cards{
    display:block;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:1.5rem 5vw 2rem;
    border-top:1px solid var(--border);
    background:var(--bg);
  }
  .hero-mobile-cards::-webkit-scrollbar{display:none;}
  .hmc-inner{
    display:flex;gap:0.75rem;
    width:max-content;
    animation:hmcDrift 18s ease-in-out infinite;
  }
  @keyframes hmcDrift{
    0%,100%{transform:translateX(0)}
    50%{transform:translateX(-40px)}
  }
  .hmc-card{
    display:flex;flex-direction:column;gap:2px;
    background:#fff;border:1px solid var(--border);border-radius:14px;
    padding:0.85rem 1.1rem;flex-shrink:0;
    position:relative;
    box-shadow:0 2px 12px rgba(13,26,20,0.06);
    animation:fcFloat 4s ease-in-out infinite;
  }
  .hmc-card:nth-child(2){animation-duration:5s;animation-delay:0.5s;}
  .hmc-card:nth-child(3){animation-duration:4.5s;animation-delay:1s;}
  .hmc-card:nth-child(4){animation-duration:5.5s;animation-delay:0.3s;}
  .hmc-card:nth-child(5){animation-duration:4.2s;animation-delay:0.8s;}
  .hmc-card--accent{background:var(--green-xlight);border-color:var(--green-light);}
  .hmc-dot{
    position:absolute;top:10px;right:10px;
    width:7px;height:7px;border-radius:50%;
    background:var(--green);
    animation:pulse 1.5s infinite;
    box-shadow:0 0 6px rgba(34,144,112,0.6);
  }
  .hmc-val{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.05rem;color:var(--black);letter-spacing:-0.02em;}
  .hmc-lbl{font-size:0.68rem;color:var(--gray-light);letter-spacing:0.04em;}

  /* STATS */
  .stats-bar-inner{grid-template-columns:1fr 1fr;}
  .stat-item{padding:1.75rem 1.25rem;border-bottom:1px solid var(--border);}
  .stat-item:nth-child(2n){border-right:none;}
  .stat-item:nth-child(3),.stat-item:nth-child(4){border-bottom:none;}
  .stat-num{font-size:2.2rem;}
  /* FOR WHOM */
  .industries{grid-template-columns:repeat(2,1fr);}

  /* TICKER */
  .ticker{padding:0.65rem 0;}

  /* ORBIT */
  .orbit-section-inner{grid-template-columns:1fr;gap:2.5rem;}
  .orbit-wrap{width:clamp(260px,75vw,340px);height:clamp(260px,75vw,340px);}
  .orbit-card{padding:0.65rem 0.9rem;}
  .orbit-card-icon{width:30px;height:30px;}
  .orbit-card-label{font-size:0.72rem;}
  .orbit-card-val{font-size:0.62rem;}
  .orbit-cards-mobile{display:none;}

  /* PROCESS STEPS */
  .process-steps{grid-template-columns:1fr;gap:0.75rem;}

  /* SERVICES - 2 kolumny na mobile */
  .services{padding:4rem 5vw;}
  .section-title{margin-bottom:2rem;}
  .services-grid{grid-template-columns:1fr 1fr;gap:1px;}
  .service-card{padding:1.5rem 1.25rem;}
  .service-num{display:none;}
  .svc-icon{width:30px;height:30px;margin-bottom:0.9rem;}
  .service-name{font-size:1.15rem;margin-bottom:0.4rem;}
  .service-desc{font-size:1rem;line-height:1.55;}

  /* PORTFOLIO */
  .portfolio{padding:4rem 5vw;}
  .portfolio-grid{grid-template-columns:1fr 1fr;}
  .portfolio-filters{gap:0.4rem;}
  .pf-btn{font-size:0.68rem;padding:0.38rem 0.7rem;}

  /* OPINIONS */
  .opinions{padding:4rem 5vw;}
  .opinions-grid{grid-template-columns:1fr;margin-top:2rem;}
  .opinion-card:nth-child(n){grid-column:1/-1;}
  .opinion-card{padding:1.5rem;}
  .opinion-text{font-size:1.05rem;}

  /* CASE STUDY */
  .case-study{padding:4rem 5vw;}
  .case-study-top{grid-template-columns:1fr;gap:1.5rem;padding:1.75rem 1.25rem;}
  .case-study-bottom{padding:1.25rem 1.5rem;flex-direction:column;align-items:flex-start;}
  .case-result-item{padding:1rem 1.25rem;}
  .case-result-num{font-size:1.6rem;}

  /* KLIENCI */
  .social-proof{padding:4rem 0;}
  .social-proof-header{padding:0 5vw;margin-bottom:2.5rem;}

  /* TEAM */
  .team{padding:4rem 5vw;}
  .team-intro{margin-bottom:3rem;}
  .team-grid{grid-template-columns:1fr;}
  .team-card{padding:1.5rem;}
  .team-avatar{width:52px;height:52px;font-size:1.1rem;}
  .team-name{font-size:1.15rem;}

  /* FAQ */
  .faq{padding:4rem 5vw;}
  .faq-grid{grid-template-columns:1fr;gap:0.6rem;margin-top:2rem;}
  .faq-q{font-size:0.92rem;padding:1rem 1.25rem;}

  /* WHY */
  .why{grid-template-columns:1fr;gap:2rem;padding:4rem 5vw;}
  .why-list li{font-size:0.9rem;padding:1rem 0;}

  /* FOOTER */
  .footer-top{grid-template-columns:1fr;gap:2.5rem;padding:2.5rem 5vw 2rem;}
  .footer-bottom{flex-direction:column;gap:0.5rem;padding:1rem 5vw;}
  .footer-bottom-right{flex-direction:column;gap:0.75rem;align-items:flex-start;}

  /* CTA */
  .cta-section{padding:5rem 5vw;}
  .cta-inner{flex-direction:column;gap:0;}
  .cta-section h2{font-size:clamp(2.2rem,9vw,3.2rem);line-height:1.05;}
  .btn-white{width:100%;}

  /* STICKY CTA */
  .sticky-cta{padding:0.75rem 5vw;}
}

@media(max-width:480px){
  .hero h1{font-size:clamp(2.8rem,9vw,4rem);line-height:0.95;}
  .services-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .industries{grid-template-columns:1fr;}
}

@media(max-width:360px){
  .hero h1{font-size:clamp(2.4rem,8.5vw,3.2rem);}
  .stats-bar-inner{grid-template-columns:1fr;}
  .stat-item{border-right:none;border-bottom:1px solid var(--border);}
  .stat-item:nth-child(3),.stat-item:nth-child(4){border-bottom:1px solid var(--border);}
  .stat-item:last-child{border-bottom:none;}
}


/* ============ MY vs AGENCJA ============ */
.vs-section{padding:var(--section-py) var(--section-px);background:#fff;border-bottom:1px solid var(--border);}
.vs-table{margin-top:3.5rem;border-radius:20px;overflow:hidden;border:1px solid rgba(34,144,112,0.25);box-shadow:0 12px 40px rgba(34,144,112,0.06);}
.vs-header{display:grid;grid-template-columns:1.2fr 1.2fr 1.1fr;background:var(--black);}
.vs-th{padding:1.4rem 1.8rem;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:0.95rem;letter-spacing:0.08em;text-transform:uppercase;display:flex;align-items:center;}
.vs-th:first-child{color:rgba(255,255,255,0.2);}
.vs-th.us{color:var(--green);font-size:1.05rem;background:rgba(34,144,112,0.18);}
.vs-th.them{color:rgba(255,255,255,0.35);}
.vs-row{display:grid;grid-template-columns:1.2fr 1.2fr 1.1fr;border-bottom:1px solid var(--border);transition:background 0.2s;}
.vs-row:last-child{border-bottom:none;}
.vs-row:hover .vs-cell.feat{color:var(--green);background:var(--green-xlight);}
.vs-cell{padding:1.4rem 1.8rem;font-size:1.05rem;line-height:1.6;display:flex;align-items:center;}
.vs-cell.feat{background:var(--bg);color:var(--black);font-weight:700;font-family:'Bricolage Grotesque',sans-serif;font-size:1.15rem;transition:color 0.2s, background 0.2s;}
.vs-cell.us{background:var(--green-xlight);color:var(--black);font-weight:600;box-shadow:-1px 0 0 rgba(34,144,112,0.15), 1px 0 0 rgba(34,144,112,0.15);}
.vs-cell.them{background:#fff;color:var(--gray);}
.vs-yes{color:var(--green);font-weight:800;font-size:1.4rem;line-height:1;margin-right:0.6rem;margin-top:-2px;}
.vs-no{color:#e74c3c;font-weight:800;font-size:1.4rem;line-height:1;margin-right:0.6rem;margin-top:-2px;}
@media(max-width:768px){
  .vs-header{grid-template-columns:1fr 1fr;}
  .vs-th:first-child{display:none;}
  .vs-th{font-size:0.75rem;padding:1.1rem;}
  .vs-row{grid-template-columns:1fr 1fr;}
  .vs-cell.feat{display:none;}
  .vs-cell{padding:1.1rem;font-size:1rem;align-items:flex-start;}
}

/* ============ ROI KALKULATOR ============ */
.calc-section{padding:var(--section-py) var(--section-px);background:var(--bg);border-bottom:1px solid var(--border);}
.calc-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;margin-top:3.5rem;}
.calc-budget-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:3rem;color:var(--green);letter-spacing:-0.04em;line-height:1;margin-bottom:1.4rem;}
.calc-budget-num span{font-size:1.3rem;color:var(--gray-light);font-weight:400;letter-spacing:0;}
.calc-lbl{font-size:0.72rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-light);margin-bottom:0.75rem;display:block;}
input[type=range].calc-slider{width:100%;-webkit-appearance:none;height:5px;background:var(--green-light);border-radius:4px;outline:none;cursor:pointer;margin-bottom:0.5rem;}
input[type=range].calc-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--green);box-shadow:0 2px 12px rgba(34,144,112,0.35);cursor:pointer;transition:transform 0.15s;}
input[type=range].calc-slider::-webkit-slider-thumb:hover{transform:scale(1.2);}
input[type=range].calc-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--green);border:none;cursor:pointer;}
.calc-range-labels{display:flex;justify-content:space-between;font-size:0.7rem;color:var(--gray-light);}
.calc-disclaimer{font-size:0.72rem;color:var(--gray-light);margin-top:2rem;line-height:1.65;padding-top:1.25rem;border-top:1px solid var(--border);}
.calc-cards{display:flex;flex-direction:column;gap:1rem;}
.calc-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.4rem 1.6rem;display:flex;align-items:center;gap:1.2rem;transition:border-color 0.2s;}
.calc-card:first-child{background:var(--green-xlight);border-color:var(--green-light);}
.calc-card-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.9rem;color:var(--green);letter-spacing:-0.03em;line-height:1;white-space:nowrap;min-width:110px;}
.calc-card-desc strong{display:block;font-size:1.05rem;color:var(--black);margin-bottom:3px;font-family:'Bricolage Grotesque',sans-serif;}
.calc-card-desc span{font-size:0.875rem;color:var(--gray-light);}
@media(max-width:768px){
  .calc-inner{grid-template-columns:1fr;gap:2.5rem;}
  .calc-budget-num{font-size:2.2rem;}
}

/* team photo */
.team-avatar{position:relative;overflow:hidden;}
.team-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%;}

/* ============ GLOBAL AMBIENT GRADIENTS ============ */
@keyframes ambientDrift{
  0%,100%{transform:translate(0,0) scale(1);opacity:0.5}
  33%{transform:translate(3%,5%) scale(1.05);opacity:0.7}
  66%{transform:translate(-4%,2%) scale(0.96);opacity:0.45}
}
@keyframes ambientDrift2{
  0%,100%{transform:translate(0,0) scale(1);opacity:0.4}
  40%{transform:translate(-3%,-4%) scale(1.08);opacity:0.65}
  75%{transform:translate(4%,3%) scale(0.94);opacity:0.35}
}
@keyframes sectionGlow{
  0%,100%{opacity:0.6}50%{opacity:1}
}

/* light sections: for-whom, services, team, faq, vs, opinions, social-proof, case-study, calc */
.for-whom,.services,.team,.faq,.vs-section,.opinions,.social-proof,.case-study,.calc-section{
  position:relative;overflow:hidden;
}
.for-whom::after,.services::after,.team::after,.faq::after{
  content:'';position:absolute;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(34,144,112,0.06) 0%,transparent 70%);
  bottom:-150px;right:-80px;
  animation:ambientDrift 20s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
.for-whom>*,.services>*,.team>*,.faq>*{position:relative;z-index:1;}

.vs-section::before,.opinions::before,.social-proof::before,.case-study::before,.calc-section::before{
  content:'';position:absolute;
  width:600px;height:400px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(34,144,112,0.055) 0%,transparent 70%);
  top:-100px;left:-100px;
  animation:ambientDrift2 22s ease-in-out infinite;
  pointer-events:none;z-index:0;
}
.vs-section>*,.opinions>*,.social-proof>*,.case-study>*,.calc-section>*{position:relative;z-index:1;}

/* extra glow on section-label badges */
.section-label{
  transition:box-shadow 0.3s;
}
.section-label:hover{
  box-shadow:0 0 16px rgba(34,144,112,0.25);
}

/* service card subtle glow accent on hover */
.service-card::before{
  background:linear-gradient(135deg,rgba(34,144,112,0.08),transparent 60%);
  opacity:0;transition:opacity 0.3s;
}
.service-card:hover::before{opacity:1;}

/* industry-tag shimmer on hover */
.industry-tag{
  position:relative;overflow:hidden;
}
.industry-tag::after{
  content:'';position:absolute;
  top:-50%;left:-75%;width:50%;height:200%;
  background:linear-gradient(105deg,transparent,rgba(34,144,112,0.12),transparent);
  transform:skewX(-20deg);
  transition:left 0.45s ease;
}
.industry-tag:hover::after{left:125%;}

/* stats bar number glow */
.stat-num{
  transition:text-shadow 0.3s;
}
.stat-item:hover .stat-num{
  text-shadow:0 0 20px rgba(34,144,112,0.4);
}

/* team cards subtle lift */
.team-card{
  transition:transform 0.3s,box-shadow 0.3s;
}
.team-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(34,144,112,0.1);
}

/* opinion cards glow */
.opinion-card{
  transition:border-color 0.3s,box-shadow 0.3s,transform 0.3s;
}
.opinion-card:hover{
  border-color:rgba(34,144,112,0.25);
  box-shadow:0 12px 40px rgba(34,144,112,0.07);
  transform:translateY(-3px);
}

/* CTA section extra radial */
.cta-section::before{
  animation:ambientDrift 16s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
