/* =========================================================================
   AIArchiwum , strona-wizytówka
   Hand-written CSS, bez frameworka i bez CDN (postawa: zasoby w UE / wydajność).
   Light-only. WCAG 2.1 AA. Akcenty modułów tylko jako cienkie sygnały.
   ========================================================================= */

/* ----- Fonty: Geist (self-hosted, bez CDN) -------------------------------
   Pliki .woff2 leżą w /fonts/ (pobrane raz, serwowane lokalnie , runtime bez
   CDN, zgodnie z postawą "zasoby w UE"). Geist to font zmienny (variable),
   jeden plik pokrywa wagi 100-900. Fallback systemowy gdyby plik nie wczytał. */
@font-face{
  font-family:"Geist";
  src:url("fonts/Geist-Variable.woff2") format("woff2");
  font-weight:100 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Geist Mono";
  src:url("fonts/GeistMono-Variable.woff2") format("woff2");
  font-weight:100 900;font-style:normal;font-display:swap;
}

:root{
  /* Marka / akcja */
  --brand:#4a2b7b;          /* fiolet marki , nagłówek/stopka/pasma */
  --brand-700:#3c2266;
  --action:#6d28d9;         /* głębszy, stonowany fiolet , spójny z marką, mniej "AI-purple"; biały tekst na nim spełnia WCAG AA */
  --action-hover:#5b21b6;
  --on-action:#ffffff;

  /* Akcenty modułów (cienkie sygnały) */
  --m-core:#4a2b7b;
  --m-archive:#7B1E3A;
  --m-dms:#1E4A7B;
  --m-hr:#2D6A3F;
  --m-ai:#863bff;
  --m-reports:#9a5b00;

  /* Powierzchnie i tekst */
  --bg:#fbfbfe;             /* tło strony (lawenda) */
  --surface:#ffffff;
  --tint:#f5f3fb;           /* delikatne pasmo sekcji */
  --tint-2:#f1eefb;
  --ink:#1f1733;            /* nagłówki */
  --text:#3a3a44;           /* body */
  --muted:#586277;          /* drugorzędny (AA na białym i lawendzie) */
  --border:#e6e4ef;
  --border-strong:#d6d3e4;

  /* Status */
  --success:#136c34;
  --success-bg:#e9f6ee;
  --warning:#8a5300;
  --warning-bg:#fbf3e2;
  --danger:#dc2626;

  /* Promienie , miękka skala "squircle" (koncentryczne zagnieżdżanie kart) */
  --r-xs:7px; --r-sm:11px; --r-md:16px; --r-lg:24px; --r-xl:30px; --r-pill:999px;

  /* Cienie , miękkie, dwuwarstwowe, tintowane odcieniem atramentu/fioletu
     (Soft Structuralism: rozproszony cień otoczenia, zero twardej czerni). */
  --sh-xs:0 1px 2px rgba(31,23,51,.05), 0 1px 1px rgba(31,23,51,.03);
  --sh-sm:0 2px 4px rgba(31,23,51,.04), 0 6px 16px rgba(31,23,51,.06);
  --sh-md:0 4px 10px rgba(31,23,51,.05), 0 18px 40px rgba(31,23,51,.10);
  --sh-lg:0 8px 24px rgba(31,23,51,.08), 0 40px 80px rgba(31,23,51,.14);
  /* uniesiona karta (hover) , cień tintowany fioletem marki dla "ciepła" */
  --sh-float:0 6px 16px rgba(74,43,123,.10), 0 28px 60px rgba(74,43,123,.16);
  /* subtelny górny highlight , krawędź "obrobionego" materiału */
  --hl-top:inset 0 1px 0 rgba(255,255,255,.7);

  /* Typografia , Geist (sans + mono) z fallbackiem systemowym */
  --font-sans:"Geist",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-display:"Geist",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:"Geist Mono",ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;

  /* Układ */
  --container:1200px;
  --nav-h:64px;
  --ease:cubic-bezier(.2,0,.2,1);
  /* "framer-motion-like" easingi: spring z lekkim overshootem + miękkie wyjście */
  --spring:cubic-bezier(.34,1.42,.5,1);
  --ease-out:cubic-bezier(.22,1,.36,1);
  /* premium "heavy settle" , ciężka masa, płynne dojście (Linear/Apple-tier) */
  --ease-premium:cubic-bezier(.32,.72,0,1);
}

/* ----- Reset / base ----------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 16px);-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-sans);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:var(--action);text-decoration:none}
a:hover{color:var(--action-hover)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.12;letter-spacing:-.015em;margin:0;font-weight:700}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:3px solid var(--action);outline-offset:2px;border-radius:4px}

/* Skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--brand);color:#fff;padding:12px 18px;z-index:1000;border-radius:0 0 var(--r-sm) 0}
.skip:focus{left:0;color:#fff}

/* ----- Layout helpers --------------------------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tint{background:var(--tint)}
/* Ciemna sekcja-akcent: mocny kontrast, przerywa rytm jasnych sekcji,
   przyciąga uwagę w kluczowym punkcie (różnicowanie sekcji). */
.section--dark{background:linear-gradient(165deg,#3a2566 0%,#241749 62%,#1b1336 100%);color:#fff}
.section--dark .section__title{color:#fff}
.section--dark .section__lead{color:rgba(255,255,255,.76)}
.section--dark .eyebrow{color:#c9b8f0}
/* Punkty na ciemnym tle: minimalne, bez kafelków, dużo oddechu */
.dpoints{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,44px);margin-top:clamp(30px,4vw,48px)}
.dpoint{padding-top:20px;border-top:2px solid rgba(201,184,240,.32)}
.dpoint h3{font-size:18px;color:#fff;margin-bottom:8px;letter-spacing:-.01em}
.dpoint p{font-size:14.5px;color:rgba(255,255,255,.72);line-height:1.55}
@media (max-width:760px){.dpoints{grid-template-columns:1fr;gap:22px}}
.section__head{max-width:780px;margin-bottom:clamp(36px,5vw,60px)}
.section__head.center{margin-inline:auto;text-align:center}
.eyebrow{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;color:var(--brand)}
.eyebrow::before{content:"";width:30px;height:1.5px;background:currentColor;opacity:.5;border-radius:2px;flex:none}
h2.section__title{font-size:clamp(30px,4vw,46px);margin-top:18px;font-weight:760;letter-spacing:-.022em}
.section__title + .section__lead{margin-top:18px}
.section__lead{font-size:clamp(17px,1.6vw,20px);color:var(--muted);max-width:62ch;line-height:1.55}
.center .eyebrow{justify-content:center}

/* ----- Buttons ---------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-sans);font-weight:600;font-size:16px;line-height:1;
  padding:14px 22px;border-radius:var(--r-pill);border:1.5px solid transparent;
  cursor:pointer;transition:background .28s var(--ease-premium),color .28s var(--ease-premium),border-color .28s var(--ease-premium),box-shadow .28s var(--ease-premium),transform .28s var(--ease-premium);
  min-height:48px;text-align:center;
}
.btn svg{width:18px;height:18px;flex:none}
/* CTA z ikoną wiodącą w osobnym kółku ("button-in-button" , kinetyka wewnętrzna) */
.btn--ic{padding-right:8px}
.btn__ic{
  width:30px;height:30px;flex:none;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;justify-content:center;margin-left:2px;
  transition:transform .35s var(--ease-premium),background .28s var(--ease-premium);
}
.btn__ic svg{width:16px;height:16px}
.btn--primary .btn__ic{background:rgba(255,255,255,.18)}
.btn--on-brand .btn__ic{background:rgba(74,43,123,.10)}
.btn--ghost .btn__ic{background:rgba(109,40,217,.08)}
.btn--ghost-brand .btn__ic{background:rgba(255,255,255,.16)}
.btn:hover .btn__ic{transform:translate(3px,-1px) scale(1.05)}
.btn:hover .btn__ic svg{transform:none}
.btn--primary{background:var(--action);color:var(--on-action);box-shadow:var(--sh-sm)}
.btn--primary:hover{background:var(--action-hover);color:#fff;box-shadow:var(--sh-md);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--border-strong)}
.btn--ghost:hover{border-color:var(--action);color:var(--action);background:rgba(109,40,217,.04)}
.btn--on-brand{background:#fff;color:var(--brand)}
.btn--on-brand:hover{background:#f3effc;color:var(--brand-700);transform:translateY(-1px)}
.btn--ghost-brand{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost-brand:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
.btn--block{width:100%}
/* micro-interakcje (framer-motion „whileTap"/ikona) */
.btn:active{transform:translateY(0) scale(.97)}
.btn svg{transition:transform .2s var(--ease-out)}
.btn:hover svg{transform:translateX(2px)}

/* ----- Topbar ----------------------------------------------------------- */
.topbar{position:sticky;top:0;z-index:100;background:var(--brand);color:#fff}
.topbar__inner{height:var(--nav-h);display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--font-display);font-weight:700;letter-spacing:.01em;font-size:19px}
.brand:hover{color:#fff}
.brand__mark{width:34px;height:34px;flex:none}
.brand small{display:block;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;opacity:.72;margin-top:1px}
.nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav a{color:rgba(255,255,255,.86);font-size:15px;font-weight:500;padding:9px 12px;border-radius:var(--r-xs);transition:background .15s var(--ease),color .15s var(--ease)}
.nav a:hover{color:#fff;background:rgba(255,255,255,.10)}
.nav__cta{margin-left:6px}
.nav__login{color:#fff !important;border:1px solid rgba(255,255,255,.4);padding:8px 14px !important}
.nav__login:hover{background:rgba(255,255,255,.10)}
/* CTA na białym tle wewnątrz nav/drawer: nadpisz białą barwę z `.nav a` /
   `.drawer__panel a` (wyższa specyficzność), inaczej biały tekst na białym tle. */
.nav a.btn--on-brand,.drawer__panel a.btn--on-brand{color:var(--brand)}
.nav a.btn--on-brand:hover,.drawer__panel a.btn--on-brand:hover{color:var(--brand-700)}
.topbar.scrolled{box-shadow:0 6px 24px rgba(31,23,51,.28)}
.navtoggle{display:none;margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;width:44px;height:44px;border-radius:var(--r-xs);cursor:pointer;align-items:center;justify-content:center}
.navtoggle svg{width:24px;height:24px}

/* Mobile drawer */
.drawer{position:fixed;inset:0;z-index:200;display:none}
.drawer[aria-hidden="false"]{display:block}
.drawer__scrim{position:absolute;inset:0;background:rgba(31,23,51,.5);backdrop-filter:blur(2px)}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,340px);background:var(--brand);padding:18px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--sh-lg);overflow-y:auto}
.drawer__panel a{color:#fff;font-size:18px;padding:14px 12px;border-radius:var(--r-xs);border-bottom:1px solid rgba(255,255,255,.10)}
.drawer__panel a:hover{background:rgba(255,255,255,.10)}
.drawer__close{align-self:flex-end;background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;width:44px;height:44px;border-radius:var(--r-xs);cursor:pointer;margin-bottom:8px}
.drawer__cta{margin-top:14px}

/* ----- Hero ------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 520px at 88% -10%, #efe9fb 0%, rgba(239,233,251,0) 60%),
  linear-gradient(180deg,#f7f4fd 0%, var(--bg) 70%)}
.hero__inner{padding-block:clamp(40px,6vw,74px)}
.hero__copy{max-width:768px;margin-inline:auto;text-align:center}
.hero h1{font-size:clamp(36px,5.4vw,62px);font-weight:780;letter-spacing:-.03em;line-height:1.04}
.hero h1 .accent{color:var(--brand)}
.hero__lead{font-size:clamp(17px,1.7vw,20px);color:var(--text);margin:20px auto 0;max-width:60ch;line-height:1.55}
.hero__cta{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:28px}

/* ----- Animated hero: rotujące słowo (adaptacja framer-motion → CSS) ----- */
.hero h1 .fixed{display:block;font-weight:540;letter-spacing:-.022em;color:#2a2440}
.rotator{display:block;position:relative;overflow:hidden;height:1.18em;margin-top:.06em}
.rotator__word{
  position:absolute;left:0;right:0;top:0;
  font-weight:780;color:var(--brand);white-space:nowrap;
  opacity:0;transform:translateY(115%);
  transition:transform .55s cubic-bezier(.22,.68,.28,1.15),opacity .45s var(--ease);
  will-change:transform,opacity;
}
.rotator__word.is-active{opacity:1;transform:translateY(0)}
.rotator__word.is-prev{opacity:0;transform:translateY(-130%)}
/* fallback bez JS: pokaż pierwsze słowo statycznie (treść nigdy ukryta) */
html:not(.js) .rotator__word{position:static;opacity:1;transform:none}
html:not(.js) .rotator__word + .rotator__word{display:none}

/* ----- Browser-frame mockup -------------------------------------------- */
/* Double-bezel: rama jak "obrobiony" sprzęt , zewnętrzna taca + koncentryczny rdzeń.
   Zewnętrzny promień r-xl(30) − padding(9) = wewnętrzny 21px → współśrodkowe łuki. */
.bezel{background:linear-gradient(180deg,#f3f0fb,#ece8f8);padding:9px;border-radius:var(--r-xl);box-shadow:var(--sh-lg);border:1px solid rgba(74,43,123,.08)}
.frame{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--r-xl) - 9px);box-shadow:var(--sh-sm),var(--hl-top);overflow:hidden}
.frame__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#faf9fe;border-bottom:1px solid var(--border)}
.frame__dot{width:10px;height:10px;border-radius:50%;background:#e0ddec}
.frame__url{margin-left:10px;font-family:var(--font-mono);font-size:11px;color:var(--muted);background:#fff;border:1px solid var(--border);border-radius:var(--r-pill);padding:4px 12px}
/* realne zrzuty produktu wpięte w ramkę (edge-to-edge pod paskiem przeglądarki) */
.shot-img{display:block;width:100%;height:auto}

/* ----- Hero: render pulpitu produktu (zamiast statycznego zrzutu) --------
   Pełny pulpit AIArchiwum zbudowany w HTML + pływające karty akcentowe
   nachodzące na krawędzie (jak panel SaaS). Liczniki KPI animowane w JS;
   pasek postępu, puls i delikatne unoszenie kart w CSS.
   prefers-reduced-motion → stan statyczny, bez ruchu. */
.hero__media{position:relative;margin-top:clamp(34px,5vw,56px)}
.dash{display:grid;grid-template-columns:212px 1fr;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-float),var(--hl-top)}

/* pasek boczny */
.dash__side{padding:18px 14px;border-right:1px solid var(--border);background:#fbfaff}
.dash__brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.01em}
.dash__logo{width:27px;height:27px;flex:none;display:grid;place-items:center;border-radius:8px;background:linear-gradient(150deg,var(--brand),var(--action));box-shadow:var(--sh-xs)}
.dash__logo svg{width:15px;height:15px;color:#fff}
.dash__label{display:block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:22px 0 9px 4px}
.dash__nav{display:flex;flex-direction:column;gap:2px}
.dash__item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;font-size:13px;font-weight:500;color:var(--text)}
.dash__item svg{width:17px;height:17px;color:var(--muted);flex:none}
.dash__item.is-active{background:#fff;color:var(--ink);font-weight:600;box-shadow:var(--sh-xs)}
.dash__item.is-active svg{color:var(--action)}
.dash__store{margin-top:24px;padding:0 4px}
.dash__store-bar{height:6px;border-radius:var(--r-pill);background:#ece8f6;overflow:hidden}
.dash__store-bar span{display:block;height:100%;width:68%;border-radius:inherit;background:linear-gradient(90deg,var(--brand),var(--action))}
.dash__store small{display:block;margin-top:7px;font-size:10.5px;color:var(--muted)}

/* główny obszar */
.dash__main{min-width:0;padding:16px 20px 20px;display:flex;flex-direction:column;gap:15px}
.dash__top{display:flex;align-items:center;gap:14px}
.dash__search{flex:1;min-width:0;display:flex;align-items:center;gap:9px;padding:9px 14px;border-radius:var(--r-pill);background:#f4f2fb;border:1px solid var(--border);color:var(--muted);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash__search svg{width:15px;height:15px;flex:none}
.dash__user{display:flex;align-items:center;gap:9px;flex:none}
.dash__ava{width:31px;height:31px;border-radius:50%;display:grid;place-items:center;font-size:11.5px;font-weight:700;color:#fff;background:linear-gradient(150deg,var(--brand),var(--action))}
.dash__id{display:flex;flex-direction:column;line-height:1.25}
.dash__id b{font-size:12.5px;color:var(--ink)}
.dash__id small{font-size:10.5px;color:var(--muted)}
.dash__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.dash__head h3{font-family:var(--font-display);font-size:22px;font-weight:740;letter-spacing:-.02em;color:var(--ink)}
.dash__head p{font-size:12.5px;color:var(--muted);margin-top:3px}
.dash__btn{flex:none;display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--r-pill);background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;box-shadow:var(--sh-sm)}
.dash__btn svg{width:14px;height:14px;color:#fff}
.dash__kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}
.kpi{display:flex;flex-direction:column;gap:8px;padding:13px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-xs)}
.kpi__l{font-size:11px;font-weight:500;color:var(--muted)}
.kpi__n{font-size:25px;font-weight:760;line-height:1;letter-spacing:-.02em;color:var(--ink);font-variant-numeric:tabular-nums}
.kpi__chip{align-self:flex-start;font-family:var(--font-mono);font-size:10px;font-weight:600;padding:3px 8px;border-radius:var(--r-pill)}
.kpi__chip--up{background:var(--success-bg);color:var(--success)}
.kpi__chip--warn{background:#fbf0df;color:#9a6b16}
.kpi__chip--down{background:#fde9e7;color:#b4392f}
.dash__recent{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-xs);padding:4px 4px 6px}
.dash__rhead{display:flex;align-items:center;justify-content:space-between;padding:11px 12px 7px}
.dash__rhead h4{font-size:13px;font-weight:650;color:var(--ink)}
.dash__rhead span{font-size:11px;color:var(--muted)}
.dash__list{list-style:none}
.dash__list li{display:flex;align-items:center;gap:11px;padding:9px 12px;border-top:1px solid var(--border)}
.dash__ic{width:31px;height:31px;flex:none;display:grid;place-items:center;border-radius:9px}
.dash__ic svg{width:15px;height:15px}
.dash__ic--ar{background:rgba(74,43,123,.09);color:var(--brand)}
.dash__ic--ai{background:rgba(109,40,217,.10);color:var(--action)}
.dash__ic--fl{background:#e6f5f0;color:#13795f}
.dash__meta{display:flex;flex-direction:column;min-width:0;line-height:1.3}
.dash__meta b{font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash__meta small{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash__stat{margin-left:auto;flex:none;font-family:var(--font-mono);font-size:10px;font-weight:600;padding:3px 9px;border-radius:var(--r-pill)}
.dash__stat--ok{background:var(--success-bg);color:var(--success)}
.dash__stat--proc{background:rgba(109,40,217,.10);color:var(--action)}

/* pływające karty akcentowe (nachodzą na krawędzie pulpitu) */
.fcard{position:absolute;z-index:3;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-float);padding:13px 15px;width:236px}
.fcard b{display:block;font-size:14px;color:var(--ink)}
.fcard small{font-size:11px;color:var(--muted)}
.fcard--analiza{left:-28px;bottom:-26px;animation:floatA 7s ease-in-out infinite}
.fcard--deal{right:-24px;bottom:18px;width:250px;animation:floatB 8.5s ease-in-out infinite}
.fcard__top{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:600;color:var(--ink);margin-bottom:9px}
.fcard__dot{width:9px;height:9px;border-radius:50%;background:var(--success);animation:dotPulse 2.4s ease-out infinite}
.fcard__bar{height:7px;border-radius:var(--r-pill);background:#ece8f6;overflow:hidden;margin:10px 0 8px}
.fcard__bar span{display:block;height:100%;border-radius:inherit;width:0;background:linear-gradient(90deg,var(--brand),var(--action));animation:barFill 1.3s var(--ease-out) .6s both}
.fcard__row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.fcard__row b{font-size:13px}
.fcard__tag{font-size:10.5px;color:var(--muted);flex:none}
.fcard__chips{display:flex;gap:6px;margin:9px 0 10px}
.fcard__chips span{font-family:var(--font-mono);font-size:10px;color:var(--text);background:#f4f2fb;border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 8px}
.fcard__stat{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--success);background:var(--success-bg);border-radius:var(--r-pill);padding:4px 10px}
.fcard__stat svg{width:13px;height:13px}
.fpill{position:absolute;z-index:3;display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:var(--r-pill);box-shadow:var(--sh-float);padding:9px 14px;font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap}
.fpill svg{width:15px;height:15px}
.fpill--secure{top:150px;right:-20px;animation:floatB 9s ease-in-out infinite}
.fpill--secure svg{color:var(--action)}
.fpill__eu{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:#eef2fb}
.fpill__eu svg{width:13px;height:13px;color:#2a4b9b}
.fpill--audit{left:-16px;top:152px;animation:floatA 8s ease-in-out infinite}
.fpill--audit svg{color:var(--brand)}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(22,141,90,.45)}70%{box-shadow:0 0 0 7px rgba(22,141,90,0)}100%{box-shadow:0 0 0 0 rgba(22,141,90,0)}}
@keyframes barFill{from{width:0}to{width:var(--p)}}
@media (prefers-reduced-motion:reduce){
  .fcard,.fpill{animation:none}
  .fcard__dot{animation:none}
  .fcard__bar span{animation:none;width:var(--p)}
}

/* ----- Trust strip ------------------------------------------------------ */
/* Pasek zaufania: zamiast płaskiego slabu na całą szerokość, oprawiony
   panel premium (ten sam język co ctaband / bezel): gradient, squircle,
   miękki cień, chipy ikon, górny highlight + poświata. */
.trust{background:var(--bg);padding-block:clamp(28px,5vw,56px)}
.trust__panel{
  position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(135deg,var(--brand),#5d3a93);
  border-radius:var(--r-xl);box-shadow:var(--sh-lg);
  padding:clamp(28px,4vw,48px);
}
.trust__panel::before{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.14);pointer-events:none}
.trust__panel::after{content:"";position:absolute;right:-70px;top:-90px;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.10),transparent 70%);pointer-events:none}
.trust__inner{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,30px) clamp(26px,3vw,44px)}
.trust__item{display:flex;gap:14px;align-items:flex-start}
.trust__ic{
  width:44px;height:44px;flex:none;border-radius:var(--r-sm);display:grid;place-items:center;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);color:#e3d9fb;
}
.trust__ic svg{width:21px;height:21px}
.trust__item>div{min-width:0}  /* pozwól tekstowi zawijać w wąskiej kolumnie (fix min-width:auto) */
.trust__item b{display:block;color:#fff;font-weight:650;font-size:15.5px;font-family:var(--font-display);letter-spacing:-.01em;margin-bottom:3px}
.trust__item span{color:rgba(255,255,255,.72);font-size:13.5px;line-height:1.5}
.trust__note{
  position:relative;margin-top:clamp(20px,2.8vw,32px);padding-top:20px;
  border-top:1px solid rgba(255,255,255,.16);
  font-family:var(--font-mono);font-size:12.5px;letter-spacing:.01em;color:rgba(255,255,255,.72);
  display:flex;gap:10px;align-items:flex-start;
}
.trust__note svg{width:17px;height:17px;color:#cdbdf2;flex:none;margin-top:2px}
.trust__note span{min-width:0}

/* ----- Problem → rozwiązanie ------------------------------------------- */
.ps{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface);box-shadow:var(--sh-sm)}
.ps__col{padding:clamp(22px,3vw,34px)}
.ps__col--pain{background:#fbfafc}
.ps__col--sol{background:linear-gradient(180deg,#faf7ff,#fff)}
.ps__h{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:9px}
.ps__col--pain .ps__h{color:var(--muted)}
.ps__col--sol .ps__h{color:var(--brand)}
.ps__row{display:flex;gap:11px;padding:13px 0;border-top:1px solid var(--border);font-size:15px;line-height:1.5}
.ps__row:first-of-type{border-top:0}
.ps__row svg{width:18px;height:18px;flex:none;margin-top:2px}
.ps__col--pain svg{color:#b9577a}
.ps__col--sol svg{color:var(--success)}
.ps__kicker{margin-top:30px;text-align:center;font-family:var(--font-display);font-size:clamp(18px,2.2vw,24px);color:var(--ink);font-weight:700}

/* ----- Module cards ----------------------------------------------------- */
/* ----- BENTO :: Moduły (Core = szeroka, wyróżniona komórka u góry) --------
   Wszystkie karty mają zbliżoną ilość treści, więc wariancję budujemy
   SZEROKOŚCIĄ, nie wysokością (wysoka wyróżniona komórka = pusta komórka).
   Baza 6 kolumn:
     rząd 1 : Core (1-4, szeroka) + Archiwum (5-6)
     rząd 2 : DMS (1-2) + HR (3-4) + AI (5-6)   (trzy równe)
     rząd 3 : Pulpit (1-6, klamra na całą szerokość)
   Wysokość rzędów wg treści (bez wymuszania), więc bez pustych luk. */
.modules{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
/* Core: szeroka komórka wiodąca; lista 4 pozycji w 2 kolumnach wypełnia szerokość. */
.mcard--feature{grid-column:span 4;display:flex;flex-direction:column;box-shadow:var(--sh-md),var(--hl-top)}
/* lista w siatce 2 kolumn (column-count nie działa na flexie) wypełnia szerokość. */
.mcard--feature .mcard__list{margin-top:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:8px 28px}
/* Archiwum oraz trzy równe (DMS / HR / AI) jako tercje rzędu. */
.mcard--rail{grid-column:span 2}
/* Pulpit: pełnoszerokościowa klamra; cechy rozłożone w pasek na całą szerokość. */
.mcard--rail-end{grid-column:1 / -1}
.mcard--rail-end .mcard__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px 28px}
@media (max-width:1080px){
  .modules{grid-template-columns:repeat(2,1fr)}
  .mcard--feature{grid-column:1 / -1;box-shadow:var(--sh-md),var(--hl-top)}
  .mcard--rail{grid-column:auto}
  .mcard--rail-end{grid-column:1 / -1}
}
@media (max-width:640px){
  .modules{grid-template-columns:1fr}
  .mcard--feature,.mcard--rail,.mcard--rail-end{grid-column:auto}
  .mcard--feature{box-shadow:var(--sh-sm),var(--hl-top)}
  .mcard--feature .mcard__list,.mcard--rail-end .mcard__list{grid-template-columns:1fr;margin-top:18px}
}
.mcard{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:24px 22px;box-shadow:var(--sh-xs),var(--hl-top);transition:transform .4s var(--ease-premium),box-shadow .4s var(--ease-premium),border-color .4s var(--ease-premium);overflow:hidden}
.mcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,var(--brand))}
.mcard:hover{transform:translateY(-4px);box-shadow:var(--sh-float),var(--hl-top);border-color:var(--border-strong)}
.mcard__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mcard__icon{width:50px;height:50px;flex:none;border-radius:var(--r-sm);display:grid;place-items:center;background:var(--tint);color:var(--accent);box-shadow:var(--hl-top);transition:transform .3s var(--ease-out)}
.mcard__icon svg{width:25px;height:25px}
.mcard:hover .mcard__icon{transform:translateY(-1px) scale(1.04)}
.mcard__eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:600}
.mcard h3{font-size:20px;margin:6px 0 9px}
.mcard p{font-size:14.5px;color:var(--muted);line-height:1.55}
.mcard__list{margin-top:14px;display:flex;flex-direction:column;gap:7px}
.mcard__list li{font-size:13.5px;color:var(--text);display:flex;gap:8px;align-items:flex-start}
.mcard__list svg{width:15px;height:15px;color:var(--accent);flex:none;margin-top:3px}
.mcard__opt{position:absolute;top:18px;right:20px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--tint);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px 9px}

/* ----- How it works (stepper + diagram) -------------------------------- */
.steps{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;counter-reset:step;position:relative}
.step{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 16px;position:relative;box-shadow:var(--sh-xs)}
.step__no{width:34px;height:34px;border-radius:var(--r-pill);background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:15px;margin-bottom:13px}
.step h3{font-size:16px;margin-bottom:8px}
.step p{font-size:13px;color:var(--muted);line-height:1.5}
.step--key{border-color:#cdbdf2;box-shadow:0 0 0 3px rgba(109,40,217,.10),var(--sh-sm)}
.step--key .step__no{background:var(--action)}
.step__badge{display:inline-flex;align-items:center;gap:6px;margin-top:11px;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--action);background:rgba(109,40,217,.08);border-radius:var(--r-pill);padding:4px 9px}
.step__badge svg{width:13px;height:13px}

.flow{margin-top:34px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:clamp(18px,3vw,30px);box-shadow:var(--sh-sm)}
.flow svg{width:100%;height:auto}
.flow__cap{margin-top:14px;text-align:center;font-size:13px;color:var(--muted);font-family:var(--font-mono)}

/* ----- Zig-zag feature rows -------------------------------------------- */
.zig{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.zig + .zig{margin-top:clamp(48px,7vw,88px)}
.zig--rev .zig__media{order:-1}
.zig__list{margin-top:20px;display:flex;flex-direction:column;gap:12px}
.zig__list li{display:flex;gap:11px;font-size:15.5px;line-height:1.5}
.zig__list svg{width:19px;height:19px;color:var(--success);flex:none;margin-top:2px}

/* ----- Comparison table ------------------------------------------------- */
/* ----- Wdrożenie: karty wariantów (on-premises / SaaS) ------------------ */
.deploy{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:clamp(26px,3.4vw,40px)}
.dopt{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(24px,3vw,32px);box-shadow:var(--sh-xs),var(--hl-top)}
.dopt--onprem{background:linear-gradient(180deg,#faf7ff,#fff);border-color:#cdbdf2;box-shadow:var(--sh-md),var(--hl-top)}
.dopt__top{display:flex;align-items:center;gap:13px}
.dopt__ic{width:46px;height:46px;flex:none;border-radius:var(--r-sm);display:grid;place-items:center;background:var(--tint);color:var(--brand);box-shadow:var(--hl-top)}
.dopt--saas .dopt__ic{color:var(--m-dms)}
.dopt__ic svg{width:23px;height:23px}
.dopt h3{font-size:21px;letter-spacing:-.01em}
.dopt__tag{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;margin:14px 0 16px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;border-radius:var(--r-pill)}
.dopt__tag svg{width:13px;height:13px}
.dopt--onprem .dopt__tag{background:var(--brand);color:#fff}
.dopt--saas .dopt__tag{background:var(--tint);color:var(--brand);border:1px solid var(--border-strong)}
.dopt__lead{font-size:15px;color:var(--muted);line-height:1.55;margin-bottom:18px}
.dopt__list{display:flex;flex-direction:column;gap:12px;margin-top:auto}
.dopt__list li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;line-height:1.5}
.dopt__list li svg{width:18px;height:18px;flex:none;margin-top:2px;color:var(--brand)}
.dopt--saas .dopt__list li svg{color:var(--m-dms)}
.dopt__list li span{min-width:0}
.dopt__list b{color:var(--ink);font-weight:650}
.deploy-tableh{font-size:clamp(18px,2.2vw,22px);letter-spacing:-.01em;margin-bottom:16px}
@media (max-width:860px){.deploy{grid-template-columns:1fr}}

.cmp-wrap{overflow:hidden;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-sm);background:var(--surface)}
table.cmp{width:100%;border-collapse:collapse;font-size:15px}
table.cmp th,table.cmp td{padding:15px 18px;text-align:left;vertical-align:top;border-bottom:1px solid var(--border)}
table.cmp thead th{background:var(--brand);color:#fff;font-family:var(--font-display);font-size:16px}
table.cmp thead th:first-child{background:var(--brand-700)}
table.cmp tbody th{font-weight:600;color:var(--ink);background:#fbfafc;width:30%;font-family:var(--font-sans);font-size:14.5px}
table.cmp td{color:var(--text)}
table.cmp .col-onprem{background:#faf7ff}
.cmp tr:last-child th,.cmp tbody tr:last-child td,.cmp tbody tr:last-child th{border-bottom:0}
.cmp-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:3px 9px;border-radius:var(--r-pill)}
.cmp-rec{background:var(--tint);border:1px solid var(--border-strong);color:var(--brand)}

/* ----- AI + security (two pillars) ------------------------------------- */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.pillar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:clamp(22px,3vw,32px);box-shadow:var(--sh-xs)}
.pillar h3{font-size:21px;margin-bottom:6px;display:flex;align-items:center;gap:11px}
.pillar h3 .ic{width:40px;height:40px;border-radius:var(--r-sm);display:grid;place-items:center;flex:none}
.pillar--ai h3 .ic{background:color-mix(in srgb,var(--m-ai) 12%,#fff);color:var(--m-ai)}
.pillar--sec h3 .ic{background:color-mix(in srgb,var(--brand) 12%,#fff);color:var(--brand)}
.pillar h3 .ic svg{width:21px;height:21px}
.pillar ul{margin-top:16px;display:flex;flex-direction:column;gap:11px}
.pillar li{display:flex;gap:11px;font-size:15px;line-height:1.5}
.pillar li svg{width:18px;height:18px;flex:none;margin-top:2px}
.pillar--ai li svg{color:var(--m-ai)}
.pillar--sec li svg{color:var(--brand)}

/* ----- Maturity / regulatory ------------------------------------------- */
.reglist{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.regitem{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--sh-xs)}
.regitem svg.lead{width:22px;height:22px;flex:none;margin-top:2px;color:var(--brand)}
.regitem h3{font-size:16px;margin-bottom:5px;display:flex;flex-wrap:wrap;gap:9px;align-items:center}
.regitem p{font-size:14px;color:var(--muted);line-height:1.5}
.status{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:var(--r-pill)}
.status svg{width:12px;height:12px}
.status--live{background:var(--success-bg);color:var(--success)}
.status--soon{background:var(--warning-bg);color:var(--warning)}
.reg-disclaimer{margin-top:18px;font-size:12.5px;color:var(--muted);font-family:var(--font-mono)}

/* ----- Agents teaser ---------------------------------------------------- */

/* ----- Integrations grid ------------------------------------------------ */
/* ----- BENTO :: Integracje (jedna szeroka komórka "kontrolowana ścieżka") --
   Ta sama baza 6 kolumn co Moduły, dla spójności między sekcjami.
     rząd 1 : Import e-mail (1-2) + Konektory ŚCIEŻKA (3-6, szeroka)
     rząd 2 : Powiadomienia (1-2) + Upload (3-4) + Automatyzacje (5-6)
     rząd 3 : Licencja modułowa (1-6, pełna szerokość, klamra) */
.feat-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:1fr;gap:16px;align-items:stretch}
.feat{grid-column:span 2}
/* Jedyna wyróżniona komórka: spokojna powierzchnia --tint, mocniejsza
   krawędź i highlight, wyłącznie istniejące tokeny (bez nowych hex). */
.feat--path{grid-column:span 4;background:var(--tint);border-color:var(--border-strong);box-shadow:var(--sh-xs),var(--hl-top)}
.feat--wide{grid-column:1 / -1}
/* dwie szersze karty w dolnym rzędzie siatki feat (6 kolumn, span 3) */
.feat--half{grid-column:span 3}
@media (max-width:1080px){
  .feat-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}
  .feat,.feat--half{grid-column:auto}
  .feat--path,.feat--wide{grid-column:1 / -1}
}
@media (max-width:640px){
  .feat-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .feat,.feat--path,.feat--wide,.feat--half{grid-column:auto}
}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:22px;box-shadow:var(--sh-xs)}
.feat__ic{width:40px;height:40px;border-radius:var(--r-sm);background:var(--tint);color:var(--brand);display:grid;place-items:center;margin-bottom:13px}
.feat__ic svg{width:21px;height:21px}
.feat h3{font-size:16px;margin-bottom:7px}
.feat p{font-size:14px;color:var(--muted);line-height:1.5}

/* ----- Stat cards (liczby z badań) + callout "shadow AI" ----------------
   Duże liczby na białych kartach z atrybucją źródła; siatka auto-fit działa
   dla 3 lub 4 kart. Callout ryzyka: spokojny bursztyn (kolor "uwaga" już
   używany na stronie), bez krzykliwej czerwieni. */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:clamp(24px,3.4vw,38px)}
.statc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:24px 22px;box-shadow:var(--sh-xs)}
.statc__n{font-family:var(--font-display);font-size:clamp(34px,4.4vw,46px);font-weight:780;letter-spacing:-.03em;line-height:1;color:var(--brand);font-variant-numeric:tabular-nums}
.statc__l{font-size:14px;color:var(--text);margin-top:11px;line-height:1.45}
.statc__src{display:block;margin-top:13px;padding-top:11px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.03em;color:var(--muted)}
.riskbox{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;background:#fffaf2;border:1px solid #f0dcb8;border-radius:var(--r-md);padding:clamp(20px,3vw,26px);box-shadow:var(--sh-xs);margin-bottom:clamp(24px,3.4vw,38px)}
.riskbox__ic{width:42px;height:42px;border-radius:var(--r-sm);background:#fbecd0;color:#9a6b16;display:grid;place-items:center;flex:none}
.riskbox__ic svg{width:22px;height:22px}
.riskbox h3{font-size:19px;margin-bottom:7px;letter-spacing:-.01em}
.riskbox p{font-size:15px;color:var(--text);line-height:1.55;max-width:76ch}
@media (max-width:560px){
  .riskbox{grid-template-columns:1fr;gap:12px}
}

/* ----- Obrazy sekcji (art-directed, duotone fioletowy) ------------------
   Poziome zdjęcia łamiące monotonię kafelków z ikonami; spójna paleta marki,
   wjeżdżają na scroll (mniej statycznie). */
.figband{margin-top:clamp(26px,3.6vw,42px);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--sh-md),var(--hl-top);background:var(--surface)}
.figband img,.figband video{display:block;width:100%;height:auto}
/* #problem: obraz obok nagłówka (split), nie dominujący baner nad panelem */
.prob-top{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,4vw,52px);align-items:center;margin-bottom:clamp(34px,5vw,56px)}
.prob-top__media{margin-top:0}
@media (max-width:860px){.prob-top{grid-template-columns:1fr;gap:22px}}

/* ----- Splitrow (styl ksefhub: tekst + infografika, naprzemiennie) ------- */
.splitrow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4.5vw,60px);align-items:center}
.splitrow + .splitrow{margin-top:clamp(40px,6vw,80px)}
.splitrow--rev .splitrow__media{order:-1}
.splitrow .figband{margin-top:0}
/* przezroczysta animacja "pływa" na tle sekcji (bez białej karty), z miękkim cieniem wg kształtu */
.splitrow__media video{display:block;width:100%;height:auto}
.splitrow__media--bare{background:none;border:0;box-shadow:none}
.splitrow__media--bare video{filter:drop-shadow(0 16px 30px rgba(74,43,123,.18))}
.splitrow__kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);font-weight:600;margin-bottom:14px}
.splitrow__kicker b{color:var(--action);font-weight:700}
.splitrow h3{font-size:clamp(22px,2.6vw,29px);font-weight:740;letter-spacing:-.02em;line-height:1.14;margin-bottom:12px;color:var(--ink)}
.splitrow__copy>p{font-size:16px;color:var(--muted);line-height:1.55;margin-bottom:17px;max-width:48ch}
.splitrow__list{list-style:none;display:flex;flex-direction:column;gap:11px}
.splitrow__list li{display:flex;gap:11px;font-size:15px;line-height:1.5;color:var(--text)}
.splitrow__list svg{width:19px;height:19px;flex:none;margin-top:2px;color:var(--action)}
@media (max-width:860px){.splitrow{grid-template-columns:1fr;gap:24px}.splitrow--rev .splitrow__media{order:0}}

/* ----- Subhead (labelled group inside one section) ---------------------- */
.subhead{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:clamp(28px,4vw,44px) 0 16px}
.subhead:first-of-type{margin-top:clamp(8px,2vw,16px)}

/* ----- Knowledge base --------------------------------------------------- */
.kb{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.kbcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-xs);transition:transform .4s var(--ease-premium),box-shadow .4s var(--ease-premium)}
.kbcard:hover{transform:translateY(-4px);box-shadow:var(--sh-float)}
.kbcard__top{height:120px;display:grid;place-items:center;background:linear-gradient(135deg,var(--tint),var(--tint-2));border-bottom:1px solid var(--border);color:var(--brand)}
.kbcard__top svg{width:40px;height:40px;opacity:.55}
.kbcard__b{padding:18px 20px}
.kbcard__tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.kbcard h3{font-size:16.5px;margin:8px 0;line-height:1.3}
.kbcard a{font-size:14px;font-weight:600;display:inline-flex;gap:6px;align-items:center}
.kbcard a svg{width:15px;height:15px}

/* ----- FAQ -------------------------------------------------------------- */
.faq{max-width:820px;margin-inline:auto}
.qa{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);margin-bottom:12px;overflow:hidden;box-shadow:var(--sh-xs)}
.qa__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;background:none;border:0;cursor:pointer;padding:18px 22px;font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--ink);min-height:56px}
.qa__q:hover{color:var(--brand)}
.qa__q .chev{width:22px;height:22px;flex:none;color:var(--brand);transition:transform .2s var(--ease)}
.qa[open] .qa__q .chev{transform:rotate(180deg)}
.qa__a{padding:0 22px 20px;color:var(--text);font-size:15.5px;line-height:1.6;max-width:70ch}
/* native <details> animation-friendly */
.qa>summary{list-style:none}
.qa>summary::-webkit-details-marker{display:none}

/* ----- Demo form -------------------------------------------------------- */
.demo{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,52px);align-items:start}
.prep{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:24px;box-shadow:var(--sh-xs)}
.prep h3{font-size:18px;margin-bottom:14px}
.prep li{display:flex;gap:11px;font-size:14.5px;padding:9px 0;border-top:1px solid var(--border);line-height:1.45}
.prep li:first-child{border-top:0}
.prep li svg{width:18px;height:18px;color:var(--brand);flex:none;margin-top:2px}
.contact-mini{margin-top:20px;padding-top:18px;border-top:1px solid var(--border);font-size:14px;color:var(--muted);display:flex;flex-direction:column;gap:9px}
.contact-mini a{display:inline-flex;align-items:center;gap:9px;color:var(--ink);font-weight:500}
.contact-mini svg{width:17px;height:17px;color:var(--brand)}

.formcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:clamp(22px,3vw,32px);box-shadow:var(--sh-sm)}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.fg.full{grid-column:1/-1}
.fg label{font-size:14px;font-weight:600;color:var(--ink)}
.fg label .req{color:var(--danger);margin-left:2px}
.fg input,.fg select,.fg textarea{font-family:inherit;font-size:16px;color:var(--ink);background:#fff;border:1.5px solid var(--border-strong);border-radius:var(--r-sm);padding:12px 14px;min-height:48px;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.fg textarea{min-height:104px;resize:vertical;line-height:1.5}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--action);box-shadow:0 0 0 3px rgba(109,40,217,.15)}
.fg .err{font-size:13px;color:var(--danger);display:none;align-items:center;gap:6px}
.fg .err svg{width:15px;height:15px;flex:none}
.fg[data-invalid="true"] input,.fg[data-invalid="true"] select,.fg[data-invalid="true"] textarea{border-color:var(--danger)}
.fg[data-invalid="true"] .err{display:flex}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:18px}
.consent input{width:20px;height:20px;flex:none;margin-top:1px;accent-color:var(--action)}
.form-note{font-size:12.5px;color:var(--muted);margin-top:14px;line-height:1.5}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success svg{width:54px;height:54px;color:var(--success);margin-inline:auto;margin-bottom:14px}
.form-success h3{font-size:22px;margin-bottom:8px}
.form-success p{color:var(--muted);max-width:42ch;margin-inline:auto}
.formcard[data-sent="true"] form{display:none}
.formcard[data-sent="true"] .form-success{display:block}

/* ----- CTA band --------------------------------------------------------- */
.ctaband{background:linear-gradient(135deg,var(--brand),#5d3a93);color:#fff;border-radius:var(--r-lg);padding:clamp(30px,5vw,56px);text-align:center;box-shadow:var(--sh-md)}
.ctaband h2{color:#fff;font-size:clamp(24px,3.2vw,36px);max-width:20ch;margin-inline:auto}
.ctaband p{color:rgba(255,255,255,.82);margin-top:14px;max-width:54ch;margin-inline:auto;font-size:17px}
.ctaband__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}

/* ----- Footer ----------------------------------------------------------- */
.footer{background:var(--brand);color:rgba(255,255,255,.8);padding-block:clamp(40px,6vw,64px) 28px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.16)}
.footer .brand{margin-bottom:14px}
.footer__about{font-size:14px;color:rgba(255,255,255,.7);max-width:34ch;line-height:1.55}
.footer h5{color:#fff;font-family:var(--font-display);font-size:14px;letter-spacing:.02em;margin:0 0 14px;text-transform:uppercase;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;opacity:.7}
.footer__grid a{display:block;color:rgba(255,255,255,.8);font-size:14px;padding:5px 0}
.footer__grid a:hover{color:#fff}
.footer__bottom{display:flex;flex-wrap:wrap;gap:14px 26px;align-items:center;justify-content:space-between;padding-top:24px}
.footer__legal{display:flex;flex-wrap:wrap;gap:8px 20px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em}
.footer__legal a{color:rgba(255,255,255,.8)}
.footer__tag{font-family:var(--font-mono);font-size:11.5px;color:rgba(255,255,255,.78);letter-spacing:.03em}

/* ----- Reveal on scroll -------------------------------------------------
   Hidden state ONLY when JS is active (.js on <html>). Bez JS treść jest
   w pełni widoczna , animacja nigdy nie ukrywa treści (a11y / no-JS). */
.js .reveal{opacity:0;transform:translateY(20px);filter:blur(5px);transition:opacity .7s var(--ease-out),transform .8s var(--ease-premium),filter .7s var(--ease-out)}
.reveal.in{opacity:1;transform:none;filter:none}
/* media w hero wjeżdża z subtelnym "pop" (scale), jak w framer-motion */
.js .hero__media.reveal{transform:translateY(20px) scale(.985)}
.hero__media.reveal.in{transform:none}
/* stagger: dzieci grupy [data-stagger] dostają opóźnienie inline z JS (--d) */
.js [data-stagger] .reveal{transition-delay:calc(var(--d,0) * 70ms)}

/* ----- Responsive ------------------------------------------------------- */
@media (max-width:1080px){
  .modules{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(3,1fr)}
  .feat-grid,.kb{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .nav{display:none}
  .navtoggle{display:inline-flex}
  .dash__kpis{grid-template-columns:repeat(2,1fr)}
  .fpill--audit{display:none}
  .trust__inner{grid-template-columns:1fr 1fr}
  .ps{grid-template-columns:1fr}
  .ps__col--pain{border-bottom:1px solid var(--border)}
  .pillars,.reglist,.demo{grid-template-columns:1fr}
  .zig{grid-template-columns:1fr;gap:28px}
  .zig--rev .zig__media,.zig__media{order:-1}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .dash{grid-template-columns:1fr}
  .dash__side{display:none}
  .dash__main{padding:14px 16px 16px}
  .fpill--secure,.fcard--deal{display:none}
  .fcard--analiza{left:8px;bottom:-14px;width:215px}
}
@media (max-width:640px){
  body{font-size:16px}
  .modules,.steps,.feat-grid,.kb,.field-grid,.trust__inner{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .hero__media{margin-top:30px}
  .fcard,.fpill{display:none}
  .dash__head h3{font-size:19px}
  .kpi__n{font-size:22px}
  /* comparison table → stacked cards */
  table.cmp thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  table.cmp,table.cmp tbody,table.cmp tr,table.cmp th,table.cmp td{display:block;width:100%}
  table.cmp tr{border-bottom:2px solid var(--border)}
  table.cmp tbody th{background:var(--brand);color:#fff;width:100%;font-family:var(--font-display)}
  table.cmp td{border-bottom:1px solid var(--border)}
  table.cmp td::before{content:attr(data-label);display:block;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
}

/* ----- Reduced motion --------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none;filter:none}
}

/* print-ish / selection */
::selection{background:rgba(109,40,217,.18)}

/* ----- Hover na kontrolkach pomocniczych (feedback / a11y) -------------- */
.navtoggle:hover{background:rgba(255,255,255,.10)}
.drawer__close:hover{background:rgba(255,255,255,.10)}
.contact-mini a:hover{color:var(--brand)}

/* Komunikat błędu wysyłki formularza (wstrzykiwany przez app.js po nieudanym POST) */
.form-error{margin:10px 0 0;color:#b42318;font-size:14px;font-weight:600;line-height:1.5}

/* reCAPTCHA v3: badge ukryty z prawego rogu; Google wymaga wtedy widocznej notki .form-legal */
.grecaptcha-badge{visibility:hidden!important}
.form-legal{margin:8px 0 0;font-size:12px;line-height:1.5;color:var(--muted,#6b7280)}
.form-legal a{color:inherit;text-decoration:underline}
