/* ============ MEDImarketing — shared design system ============ */
:root{
  --navy:#0a3a78;--navy-deep:#072a59;--blue:#0c4487;--cyan:#00c1cf;--cyan-bright:#13d6e3;
  --sky:#58b5dd;--mist:#a3d7e2;--ink:#0c1b33;--slate:#516079;
  --paper:#f4f8fc;--paper-2:#eaf3fa;--white:#fff;
  --line:rgba(12,68,135,.12);
  --shadow-sm:0 2px 10px rgba(10,58,120,.06);
  --shadow:0 18px 50px -22px rgba(10,58,120,.35);
  --shadow-lg:0 40px 90px -40px rgba(10,58,120,.55);
  --r:18px;--r-lg:28px;
  --grad:linear-gradient(120deg,var(--cyan) 0%,var(--sky) 55%,var(--blue) 100%);
  --grad-deep:linear-gradient(135deg,#0a3a78 0%,#0c4487 45%,#0890a8 100%);
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Plus Jakarta Sans",system-ui,sans-serif;color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:"Plus Jakarta Sans",sans-serif;line-height:1.08;letter-spacing:-.02em;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1180px,92vw);margin-inline:auto}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--grad);border-radius:2px}
.btn{--bg:var(--grad);display:inline-flex;align-items:center;gap:.6em;padding:.95em 1.7em;border-radius:999px;border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:.98rem;background-image:var(--bg);color:#fff;box-shadow:0 14px 30px -12px rgba(0,193,207,.6);transition:transform .35s var(--ease),box-shadow .35s var(--ease),filter .35s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 22px 40px -14px rgba(0,193,207,.75);filter:saturate(1.1)}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--blue);box-shadow:inset 0 0 0 1.6px var(--line)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.6px var(--cyan);color:var(--navy);filter:none}
.btn--light{background:#fff;color:var(--blue);background-image:none;box-shadow:0 14px 30px -14px rgba(7,42,89,.6)}

/* ====== NAV (pełna szerokość) ====== */
header.nav{position:fixed;inset:0 0 auto 0;z-index:90;background:rgba(255,255,255,.8);backdrop-filter:blur(18px) saturate(1.4);border-bottom:1px solid rgba(12,68,135,.08);transition:background .35s var(--ease),box-shadow .35s var(--ease)}
.nav.scrolled{background:rgba(255,255,255,.95);box-shadow:0 10px 34px -18px rgba(10,58,120,.45)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.85rem 0;transition:padding .35s var(--ease)}
.nav.scrolled .nav-inner{padding:.6rem 0}
.brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.brand img{height:30px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}
.nav-links>li>a,.dd-toggle{position:relative;padding:.5em .8em;font-size:.9rem;font-weight:600;color:var(--slate);transition:color .25s var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:.35em;white-space:nowrap}
.nav-links>li>a::after,.dd-toggle::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.18em;height:2px;border-radius:2px;background:var(--grad);transform:scaleX(0);transform-origin:center;transition:transform .32s var(--ease)}
.nav-links>li>a:hover,.dd-toggle:hover,.has-dd:hover .dd-toggle{color:var(--blue)}
.nav-links>li>a:hover::after,.dd-toggle:hover::after,.has-dd:hover .dd-toggle::after{transform:scaleX(1)}
.nav-links a.active{color:var(--blue)}
.nav-links a.active::after{transform:scaleX(1)}
.dd-toggle svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4;transition:transform .3s}
.has-dd:hover .dd-toggle svg{transform:rotate(180deg)}
/* dropdown */
.has-dd{position:relative}
.has-dd::after{content:"";position:absolute;top:100%;left:0;right:0;height:18px}
.dd{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(10px);background:#fff;border-radius:20px;padding:.6rem;box-shadow:var(--shadow-lg);width:340px;opacity:0;pointer-events:none;transition:.3s var(--ease);border:1px solid var(--line)}
.has-dd:hover .dd{opacity:1;pointer-events:auto;transform:translateX(-50%)}
.dd a{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:13px;font-size:.88rem;font-weight:600;color:var(--slate);transition:background .25s,color .25s}
.dd a:hover{background:var(--paper);color:var(--blue)}
.dd a .di{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#e3f7fa,#d3ecfb);display:grid;place-items:center;flex-shrink:0}
.dd a .di svg{width:17px;height:17px;stroke:var(--blue);fill:none;stroke-width:2}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-cta .btn{padding:.7em 1.3em;font-size:.88rem}
.burger{display:none;width:44px;height:44px;border:0;background:transparent;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:22px;height:2px;background:var(--blue);border-radius:2px;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ====== HERO (home) ====== */
.hero{position:relative;padding:150px 0 90px;overflow:hidden}
section[id]{scroll-margin-top:84px}
.hero-bg{position:absolute;inset:0;z-index:-2;background:linear-gradient(160deg,#e8f6ff 0%,#eef9ff 60%,#f1faff 100%)}
.hero-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;z-index:-1;animation:float 14s ease-in-out infinite}
.hero-blob.b1{width:420px;height:420px;background:radial-gradient(circle,#9fe8ee,transparent 70%);top:-80px;right:-60px}
.hero-blob.b2{width:340px;height:340px;background:radial-gradient(circle,#bcdcff,transparent 70%);bottom:-40px;left:-80px;animation-delay:-5s}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-26px)}}
.grid-overlay{position:absolute;inset:0;z-index:-1;opacity:.5;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 80%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.hero h1{font-family:"Plus Jakarta Sans",system-ui,sans-serif;font-size:clamp(2.3rem,5vw,3.7rem);font-weight:800;line-height:1.14;letter-spacing:-.015em;margin:1.1rem 0 1.2rem}
.hero h1 .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.12rem;color:var(--slate);max-width:34ch;margin-bottom:1.1rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.hero-trust{display:flex;gap:1.6rem;margin-top:2.6rem;flex-wrap:wrap}
.hero-trust .t{display:flex;flex-direction:column}
.hero-trust .t b{font-family:"Plus Jakarta Sans";font-size:1.6rem;color:var(--navy);line-height:1}
.hero-trust .t span{font-size:.82rem;color:var(--slate);margin-top:.25rem}
.hero-visual{position:relative}
/* wyraźne zdjęcie w zaokrąglonej ramce z miękkim cieniem, na dopasowanym tle */
.hero-img{position:relative;width:100%;aspect-ratio:4/5;border-radius:26px;overflow:hidden;
  box-shadow:0 34px 70px -28px rgba(10,58,120,.45)}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff;aspect-ratio:4/5}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,42,89,.35))}
.float-card{position:absolute;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-radius:16px;padding:.85rem 1.05rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.7rem;border:1px solid rgba(255,255,255,.8);animation:bob 6s ease-in-out infinite}
.float-card .ic{width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;flex-shrink:0}
.float-card .ic svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.2}
.float-card b{font-family:"Plus Jakarta Sans";font-size:1.05rem;color:var(--navy);display:block;line-height:1}
.float-card span{font-size:.74rem;color:var(--slate)}
.fc1{top:8%;left:-32px;animation-delay:-1s}
.fc2{bottom:12%;right:-26px;animation-delay:-3s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ====== SUBPAGE HERO ====== */
.subhero{position:relative;padding:140px 0 70px;background:var(--grad-deep);color:#fff;overflow:hidden}
.subhero.has-bg{background-size:cover;background-position:center}
.subhero::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(0,193,207,.4),transparent 70%);top:-200px;right:-120px;filter:blur(50px)}
.subhero::after{content:"";position:absolute;inset:0;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(80% 80% at 70% 20%,#000,transparent 75%)}
.subhero .wrap{position:relative;z-index:1}
.crumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:rgba(255,255,255,.75);margin-bottom:1.1rem;flex-wrap:wrap}
.crumb a:hover{color:#fff}
.crumb svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4;opacity:.6}
.subhero h1{font-size:clamp(2.1rem,4.5vw,3.4rem);font-weight:800;max-width:18ch}
.subhero .ic-badge{width:70px;height:70px;border-radius:20px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:1.4rem}
.subhero .ic-badge svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:1.9}
.subhero p.intro{margin-top:1.2rem;font-size:1.12rem;color:rgba(255,255,255,.85);max-width:60ch}

/* ====== SECTIONS ====== */
section{position:relative}
.section{padding:96px 0}
.section-head{max-width:680px;margin-bottom:3rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.85rem);margin:.9rem 0 .8rem}
.section-head p{color:var(--slate);font-size:1.05rem}
.prose p{color:var(--slate);margin-bottom:1.1rem;font-size:1.05rem}
.prose strong{color:var(--navy)}

/* benefits / cards grid */
.benefits{background:var(--paper)}
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.ben{background:#fff;border-radius:var(--r);padding:2rem 1.7rem;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease);position:relative;overflow:hidden}
.ben::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.ben:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.ben:hover::before{transform:scaleX(1)}
.ben .ic{width:54px;height:54px;border-radius:15px;background:linear-gradient(135deg,#e3f7fa,#d3ecfb);display:grid;place-items:center;margin-bottom:1.2rem}
.ben .ic svg{width:26px;height:26px;stroke:var(--blue);fill:none;stroke-width:2}
.ben h3{font-size:1.18rem;margin-bottom:.5rem}
.ben p{color:var(--slate);font-size:.96rem}

/* about/offer split */
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:3.2rem;align-items:center}
.about-grid.rev{grid-template-columns:1.08fr .92fr}
.about-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff;aspect-ratio:4/5}
.about-photo.wide{aspect-ratio:3/2}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block}
.about-badge{position:absolute;left:18px;bottom:18px;background:var(--grad-deep);color:#fff;border-radius:16px;padding:1rem 1.3rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.8rem}
.about-badge b{font-family:"Plus Jakarta Sans";font-size:2rem;line-height:1}
.about-badge span{font-size:.82rem;opacity:.92;max-width:12ch}
.about p{color:var(--slate);margin-bottom:1rem}
.about strong{color:var(--navy)}
.offer-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.4rem;margin:1.5rem 0}
.offer-list li{display:flex;align-items:center;gap:.65rem;font-weight:600;color:var(--ink);font-size:.97rem}
.offer-list li svg{width:21px;height:21px;flex-shrink:0;stroke:var(--cyan);fill:none;stroke-width:2.6}

/* benefit checklist (home: Dlaczego warto) */
.benefit-list{list-style:none;display:flex;flex-direction:column;gap:.9rem;margin:.4rem 0 1.6rem}
.benefit-list li{display:flex;gap:.85rem;align-items:flex-start;font-size:1.02rem;color:var(--ink);font-weight:500}
.benefit-list li .bi{width:28px;height:28px;border-radius:9px;background:linear-gradient(135deg,#e3f7fa,#d3ecfb);display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.benefit-list li .bi svg{width:16px;height:16px;stroke:var(--blue);fill:none;stroke-width:2.8}

/* hero SERP mock visual */
.serp{position:relative;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);border:1px solid var(--line);padding:1.5rem}
.serp-bar{display:flex;align-items:center;gap:.6rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.65rem 1.1rem;font-size:.92rem;color:var(--slate);font-weight:600;margin-bottom:1.2rem}
.serp-bar svg{width:18px;height:18px;stroke:var(--slate);fill:none;stroke-width:2}
.serp-res{padding:.9rem 1rem;border-radius:14px;margin-bottom:.7rem}
.serp-res.top{background:linear-gradient(120deg,#eafaff,#eef4ff);border:1px solid rgba(0,193,207,.3)}
.serp-res .u{font-size:.78rem;color:#1a8a3c;font-weight:600}
.serp-res .t{font-size:1rem;color:var(--blue);font-weight:700;margin:.15rem 0 .3rem}
.serp-res.dim .ln{height:8px;border-radius:5px;background:var(--line);margin-top:.5rem}
.serp-res.dim .ln.s{width:65%}
.serp-res.dim .u2{height:8px;width:40%;border-radius:5px;background:rgba(26,138,60,.25);margin-bottom:.5rem}
.serp-stars{color:#f5a623;font-size:.9rem;letter-spacing:2px}
.serp-rank{position:absolute;top:-16px;right:-16px;background:var(--grad);color:#fff;border-radius:15px;padding:.65rem 1rem;box-shadow:var(--shadow);font-weight:700;font-size:.85rem;display:flex;align-items:center;gap:.45rem;animation:bob 6s ease-in-out infinite}
.serp-rank svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.4}

/* service detail: icon + photo */
.svc-ic{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,#e3f7fa,#d3ecfb);display:grid;place-items:center;margin-bottom:1rem}
.svc-ic svg{width:30px;height:30px;stroke:var(--blue);fill:none;stroke-width:2}
.svc-photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff;align-self:start;aspect-ratio:3/2}
.svc-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* service info card (zakres usługi) */
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.2rem;box-shadow:var(--shadow-sm);align-self:start}
.info-card h3{font-size:1.25rem;color:var(--navy);margin-bottom:1.1rem}
.info-card .offer-list{margin:0}

/* clients marquee — dark background so białe logotypy są widoczne */
.clients{background:var(--grad-deep);padding:74px 0;position:relative;overflow:hidden}
.clients::before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(0,193,207,.3),transparent 70%);top:-200px;left:-120px;filter:blur(50px)}
.clients .wrap{position:relative}
.clients h2{text-align:center;font-size:1.6rem;color:#fff;margin-bottom:.4rem}
.clients p{text-align:center;color:rgba(255,255,255,.78);margin-bottom:2.5rem}
.marquee{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:3.5rem;width:max-content;animation:scroll 38s linear infinite}
.clients:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:48px;width:auto;object-fit:contain;opacity:.82;transition:opacity .35s,transform .35s}
.marquee-track img:hover{opacity:1;transform:scale(1.06)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* services grid (home + overview) */
.services{background:var(--grad-deep);color:#fff;overflow:hidden}
.services .section-head h2,.services .eyebrow{color:#fff}
.services .eyebrow::before{background:#fff}
.services .section-head p{color:rgba(255,255,255,.82)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.svc-grid.cols3{grid-template-columns:repeat(3,1fr)}
.svc{position:relative;display:block;border-radius:var(--r);padding:2.1rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(6px);overflow:hidden;transition:background .4s var(--ease),transform .4s var(--ease);color:#fff}
.svc:hover{background:rgba(255,255,255,.13);transform:translateY(-5px)}
.svc .num{position:absolute;top:1.2rem;right:1.6rem;font-family:"Plus Jakarta Sans";font-weight:800;font-size:3.4rem;color:rgba(255,255,255,.1);line-height:1}
.svc .tag{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan-bright)}
.svc h3{font-size:1.3rem;margin:.7rem 0 .7rem;max-width:20ch}
.svc p{color:rgba(255,255,255,.8);font-size:.95rem}
.svc .ic{width:50px;height:50px;border-radius:14px;background:rgba(255,255,255,.12);display:grid;place-items:center;margin-bottom:1.1rem}
.svc .ic svg{width:25px;height:25px;stroke:#fff;fill:none;stroke-width:2}
.svc .lnk{margin-top:1rem;font-size:.85rem;font-weight:700;color:var(--cyan-bright);display:inline-flex;align-items:center;gap:.4em}
.svc .lnk svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.4;transition:transform .3s}
.svc:hover .lnk svg{transform:translateX(4px)}

/* steps (process) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;counter-reset:s}
.step{position:relative;padding:2rem 1.6rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:"Plus Jakarta Sans";font-weight:800;font-size:2.6rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;display:block;margin-bottom:.8rem}
.step h3{font-size:1.1rem;margin-bottom:.45rem}
.step p{color:var(--slate);font-size:.93rem}

/* marketing rich text + stats */
.med-grid{display:grid;grid-template-columns:1fr .8fr;gap:3.5rem;align-items:start}
.med-body p{color:var(--slate);margin-bottom:1rem}
.med-body strong{color:var(--navy)}
.med-note{background:var(--paper);border-left:4px solid var(--cyan);border-radius:0 14px 14px 0;padding:1.1rem 1.3rem;margin:1.4rem 0;font-size:.96rem;color:var(--ink)}
.stat-stack{display:flex;flex-direction:column;gap:1.1rem;position:sticky;top:110px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.stat .big{font-family:"Plus Jakarta Sans";font-weight:800;font-size:3rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat p{color:var(--slate);font-size:.95rem;margin-top:.4rem}
.stat .ring{position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;border:14px solid var(--paper-2);opacity:.7}

/* single post hero */
.post-hero{position:relative;padding:150px 0 56px;background-size:cover;background-position:center;color:#fff;min-height:420px;display:flex;align-items:flex-end}
.post-hero .crumb{color:rgba(255,255,255,.8)}
.post-date{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);padding:.4rem .9rem;border-radius:999px;font-size:.85rem;font-weight:600;margin-bottom:1rem}
.post-date svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:2}
.post-hero h1{font-size:clamp(1.9rem,4vw,3rem);font-weight:800;max-width:24ch}

/* article body */
.article{max-width:760px;margin-inline:auto;font-size:1.08rem;color:#2a3b53;line-height:1.8}
.article>*{margin-bottom:1.15rem}
.article h2{font-size:clamp(1.5rem,2.6vw,2rem);color:var(--navy);margin:2.4rem 0 1rem}
.article h3{font-size:1.3rem;color:var(--navy);margin:1.8rem 0 .8rem}
.article h4{font-size:1.1rem;color:var(--navy);margin:1.4rem 0 .6rem}
.article p{margin-bottom:1.15rem}
.article a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(12,68,135,.3)}
.article a:hover{text-decoration-color:var(--cyan)}
.article strong,.article b{color:var(--navy);font-weight:700}
.article ul,.article ol{padding-left:1.3rem;margin-bottom:1.3rem;display:flex;flex-direction:column;gap:.55rem}
.article li{padding-left:.3rem}
.article ul li{list-style:none;position:relative;padding-left:1.6rem}
.article ul li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border-radius:50%;background:var(--grad)}
.article ol{list-style:decimal}
.article img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow);margin:1.6rem 0;border:5px solid #fff}
.article blockquote{border-left:4px solid var(--cyan);background:var(--paper);border-radius:0 14px 14px 0;padding:1.1rem 1.4rem;font-style:italic;color:var(--ink)}
.article table{width:100%;border-collapse:collapse;font-size:.96rem}
.article th,.article td{border:1px solid var(--line);padding:.7rem .9rem;text-align:left}
.article th{background:var(--paper);color:var(--navy)}
.article-foot{max-width:760px;margin:2.6rem auto 0;display:flex;gap:1rem;justify-content:space-between;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:2rem}

/* blog */
.blog{background:var(--paper)}
.blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.blog-grid.cols3{grid-template-columns:repeat(3,1fr)}
.post{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.post:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post .thumb{aspect-ratio:16/9;background:var(--grad-deep);position:relative;overflow:hidden;display:grid;place-items:center}
.post .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.post:hover .thumb img{transform:scale(1.05)}
.post .thumb>svg{width:44px;height:44px;stroke:rgba(255,255,255,.85);fill:none;stroke-width:1.6}
.post .body{padding:1.3rem;display:flex;flex-direction:column;flex:1}
.post time{font-size:.78rem;color:var(--cyan);font-weight:700;letter-spacing:.04em}
.post h3{font-size:1.02rem;margin:.5rem 0 .9rem;line-height:1.3;flex:1}
.post .more{font-size:.85rem;font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:.4em}
.post .more svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.4;transition:transform .3s}
.post:hover .more svg{transform:translateX(4px)}

/* CTA band */
.cta-band{padding:90px 0}
.cta-inner{position:relative;background:var(--grad-deep);border-radius:var(--r-lg);padding:3.5rem;text-align:center;color:#fff;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta-inner::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(0,193,207,.4),transparent 70%);top:-160px;left:-80px;filter:blur(40px)}
.cta-inner h2{position:relative;font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:.8rem}
.cta-inner p{position:relative;color:rgba(255,255,255,.85);max-width:50ch;margin:0 auto 1.8rem}
.cta-inner .btn{position:relative}

/* contact */
.contact{background:var(--grad-deep);color:#fff;overflow:hidden;position:relative}
.contact::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(0,193,207,.35),transparent 70%);top:-160px;right:-120px;filter:blur(40px)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;position:relative}
.contact .eyebrow,.contact h2{color:#fff}
.contact .eyebrow::before{background:#fff}
.contact h2{font-size:clamp(1.9rem,3.6vw,2.85rem);margin:.9rem 0 1rem}
.contact .lead{color:rgba(255,255,255,.85);margin-bottom:2rem;max-width:42ch}
.info-row{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid rgba(255,255,255,.14)}
.info-row .ic{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.12);display:grid;place-items:center;flex-shrink:0}
.info-row .ic svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2}
.info-row b{display:block;font-family:"Plus Jakarta Sans";font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;opacity:.7;font-weight:600}
.info-row span,.info-row a{font-size:1.02rem;font-weight:600}
.info-row a:hover{color:var(--cyan-bright)}
.form{background:rgba(255,255,255,.97);border-radius:var(--r-lg);padding:2.4rem;box-shadow:var(--shadow-lg);color:var(--ink)}
.form h3{color:var(--navy);font-size:1.4rem;margin-bottom:.4rem}
.form .sub{color:var(--slate);font-size:.92rem;margin-bottom:1.6rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.field input,.field textarea{width:100%;padding:.85rem 1rem;border-radius:12px;border:1.6px solid var(--line);font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--paper);transition:border .25s,box-shadow .25s}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(0,193,207,.14);background:#fff}
.field textarea{resize:vertical;min-height:110px}
.consent{display:flex;gap:.6rem;font-size:.78rem;color:var(--slate);margin:.4rem 0 1.2rem;line-height:1.5}
.consent input{margin-top:.2rem;accent-color:var(--cyan)}
.form .btn{width:100%;justify-content:center}
.form .btn:disabled{opacity:.7;cursor:wait}
.form-status{margin-top:.9rem;font-size:.9rem;font-weight:600;text-align:center;min-height:1px}
.form-status.ok{color:#1c7a47}
.form-status.err{color:#c0392b}
.map-embed{margin-top:2.5rem;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff;height:340px}
.map-embed iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.2)}
.map-full{width:100%;line-height:0}
.map-full iframe{width:100%;height:440px;border:0;display:block;filter:grayscale(.2)}
@media(max-width:680px){.map-full iframe{height:320px}}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:64px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.2rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-logo{display:inline-block;background:#fff;padding:.55rem .85rem;border-radius:12px;margin-bottom:1.1rem;box-shadow:var(--shadow-sm)}
.foot-logo img{height:28px;display:block}
.foot-brand p{font-size:.92rem;max-width:32ch}
.foot-contact{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-top:1.3rem}
.foot-contact li{display:flex;align-items:center;gap:.65rem;font-size:.92rem}
.foot-contact svg{width:17px;height:17px;stroke:var(--cyan-bright);fill:none;stroke-width:2;flex:0 0 auto}
.foot-contact a:hover{color:var(--cyan-bright)}
.foot-col h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.1rem;font-weight:700}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.foot-col a{font-size:.92rem;transition:color .25s}
.foot-col a:hover{color:var(--cyan-bright)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1.6rem;font-size:.84rem;flex-wrap:wrap;gap:.8rem}
.foot-socials{display:flex;gap:.6rem}
.foot-socials a{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .3s}
.foot-socials a:hover{background:var(--grad)}
.foot-socials svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}

/* exit-intent popup */
.exit-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.2rem;background:rgba(8,27,51,.55);backdrop-filter:blur(5px);opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.exit-modal.show{opacity:1;pointer-events:auto}
.exit-card{position:relative;background:#fff;border-radius:var(--r-lg);max-width:460px;width:100%;padding:2.6rem 2rem 1.8rem;text-align:center;box-shadow:var(--shadow-lg);transform:translateY(18px) scale(.96);transition:transform .42s var(--ease);overflow:hidden}
.exit-modal.show .exit-card{transform:none}
.exit-card::before{content:"";position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:240px;height:120px;background:radial-gradient(circle,rgba(0,193,207,.18),transparent 70%)}
.exit-x{position:absolute;top:.7rem;right:1rem;border:0;background:none;font-size:1.9rem;line-height:1;color:var(--slate);cursor:pointer;transition:color .2s}
.exit-x:hover{color:var(--ink)}
.exit-ic{position:relative;width:66px;height:66px;border-radius:19px;background:var(--grad);display:grid;place-items:center;margin:0 auto 1.1rem;box-shadow:0 14px 30px -12px rgba(0,193,207,.6)}
.exit-ic svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:2}
.exit-card h3{position:relative;font-family:"Plus Jakarta Sans",sans-serif;font-size:1.5rem;color:var(--navy);margin-bottom:.6rem}
.exit-card p{position:relative;color:var(--slate);margin-bottom:1.4rem;font-size:1rem}
.exit-actions{position:relative;display:flex;flex-direction:column;gap:.7rem}
.exit-actions .btn{width:100%;justify-content:center}
.exit-no{position:relative;margin-top:1rem;border:0;background:none;color:var(--slate);font-size:.85rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.exit-no:hover{color:var(--ink)}

/* cookie consent (RODO) */
.cookie-bar{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:150;max-width:540px;margin-inline:auto;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.85rem;transform:translateY(22px);opacity:0;pointer-events:none;transition:.4s var(--ease)}
.cookie-bar.show{transform:none;opacity:1;pointer-events:auto}
.cookie-bar p{font-size:.88rem;color:var(--slate);margin:0;line-height:1.55}
.cookie-bar p b{color:var(--ink);font-family:"Plus Jakarta Sans",sans-serif}
.cookie-bar a{color:var(--blue);font-weight:600}
.cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-actions .btn{flex:1;justify-content:center;padding:.72em 1.1em;font-size:.9rem;min-width:130px}
@media(max-width:520px){.cookie-bar{left:.7rem;right:.7rem;bottom:.7rem}}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
[data-reveal][data-d="4"]{transition-delay:.32s}

/* responsive */
@media(max-width:980px){
  .hero-grid,.about-grid,.about-grid.rev,.med-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{max-width:460px;margin-inline:auto}
  .hero-img{width:100%;margin:0}
  .ben-grid,.svc-grid.cols3{grid-template-columns:1fr 1fr}
  .blog-grid,.blog-grid.cols3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stat-stack{position:static;flex-direction:row;flex-wrap:wrap}
  .stat{flex:1;min-width:200px}
}
@media(max-width:980px){
  .nav-cta .btn{display:none}
  .burger{display:flex}
  .nav-links{position:absolute;top:calc(100% + 8px);left:4vw;right:4vw;display:flex;flex-direction:column;align-items:stretch;background:#fff;border-radius:22px;padding:1rem;box-shadow:var(--shadow-lg);gap:.1rem;transform:scale(.98) translateY(-8px);opacity:0;pointer-events:none;transition:.3s var(--ease);max-height:80vh;overflow-y:auto}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links>li>a,.dd-toggle{padding:.8em 1em;font-size:1rem}
  .has-dd::after{display:none}
  .dd{position:static;transform:none;opacity:1;pointer-events:auto;box-shadow:none;border:0;width:auto;padding:.2rem .2rem .6rem 1rem;display:none}
  .has-dd.open .dd{display:block}
  .has-dd:hover .dd{transform:none}
  .dd a{padding:.5rem .5rem}
  .has-dd:hover .dd-toggle svg{transform:none}
  .has-dd.open .dd-toggle svg{transform:rotate(180deg)}
}
@media(max-width:680px){
  .ben-grid,.svc-grid,.svc-grid.cols3,.blog-grid,.blog-grid.cols3,.offer-list,.foot-grid,.steps{grid-template-columns:1fr}
  .section{padding:70px 0}
  .hero{padding:130px 0 60px}
  .subhero{padding:120px 0 52px}
  .float-card{display:none}
  .cta-inner{padding:2.4rem 1.5rem}
  .foot-bottom{flex-direction:column;text-align:center}
  .hero h1{font-size:clamp(2rem,8vw,2.6rem)}
  .med-grid,.about-grid{gap:2rem}
  .wrap{width:90vw}
}
@media(max-width:380px){
  .nav-inner{padding:.7rem 0}
  .brand img{height:26px}
}
