/* ==========================================================================
   DNET TECH — system stylów
   Strona docelowa: dnet-tech.pl
   ========================================================================== */

/* === 1. Reset + tokeny === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--text);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
/* liczby / akcenty techniczne */
.mono,.hero-stats strong,.p-save-num{font-family:var(--font-mono);font-feature-settings:"tnum" 1}

/* === Dostępność === */
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}
.skip-link{
  position:absolute;left:12px;top:-60px;z-index:100;
  background:var(--primary);color:#fff;padding:10px 18px;border-radius:0 0 10px 10px;
  font-weight:600;transition:top .2s;
}
.skip-link:focus{top:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

:root{
  /* warstwy — DARK PREMIUM (spójne z DNETHUB) */
  --bg:#0a0b10;             /* hsl(240 10% 4%) */
  --bg-alt:#0e1016;
  --bg-dark:#070810;
  --bg-darker:#050609;
  --surface:#13151c;        /* karty */
  --surface-2:#171a22;
  --text:#f1f3f8;
  --muted:#8b93a7;
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.14);

  /* marka — violet → purple → sky */
  --primary:#8b5cf6;        /* hsl(263 75% 63%) */
  --primary-dark:#7c3aed;
  --accent:#38bdf8;         /* sky */
  --violet:#a974f0;
  --green:#22c55e;
  --amber:#f59e0b;
  --brand-grad:linear-gradient(135deg,#8b5cf6,#a855f7,#38bdf8);

  /* domyślny kolor kategorii (nadpisywany inline --cat-color z data.js) */
  --cat-color:#8b5cf6;

  /* czcionki */
  --font:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'Cascadia Code',monospace;

  /* układ */
  --radius:0.625rem;
  --radius-lg:18px;
  --container:1240px;
  --container-narrow:880px;

  /* cienie */
  --shadow-sm:0 2px 10px -2px rgba(0,0,0,.5);
  --shadow-md:0 18px 40px -18px rgba(0,0,0,.6);
  --shadow-lg:0 30px 70px -22px rgba(0,0,0,.7);
  --glow:0 0 0 1px rgba(139,92,246,.4),0 18px 50px -18px rgba(139,92,246,.45);
}

/* poświata tła */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(620px 420px at 12% -5%,rgba(139,92,246,.13),transparent 70%),
    radial-gradient(680px 480px at 92% 0%,rgba(56,189,248,.10),transparent 70%);
}

/* === 2. Container / typografia === */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container.narrow{max-width:var(--container-narrow)}

h1,h2,h3,h4{letter-spacing:-.02em;font-weight:800;line-height:1.15}
h1{font-size:clamp(2rem,4.6vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.3rem)}
h3{font-size:1.18rem}
.text-muted{color:var(--muted)}
.grad-text{
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary));
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{to{background-position:200% center}}

/* === 3. Sekcje === */
.section{padding:90px 0}
.section-alt{background:var(--bg-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
/* eyebrow nad nagłówkiem sekcji */
.eyebrow{
  display:block;text-align:center;margin-bottom:12px;
  font-size:.76rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  background:linear-gradient(90deg,#8b5cf6,#38bdf8);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
/* delikatna poświata pod sekcją flagowych */
#flagowe{background:radial-gradient(900px 380px at 50% -8%,rgba(139,92,246,.09),transparent 70%)}
.section-dark{background:var(--bg-dark);color:#fff}
.section-title{text-align:center;margin-bottom:12px;position:relative;padding-bottom:20px}
.section-title::after{
  content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:0;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent),var(--violet));
  background-size:220% 100%;
  transition:width .7s cubic-bezier(.22,.61,.36,1) .15s;
}
.section-title.in-view::after{width:72px;animation:lineShimmer 4s linear infinite}
@keyframes lineShimmer{to{background-position:220% 0}}

/* ===== Mikro-interakcje ===== */
.btn{position:relative;overflow:hidden}
.btn-primary::after,.btn-light::after{
  content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-20deg);transition:left .6s ease;pointer-events:none;
}
.btn-primary:hover::after,.btn-light:hover::after{left:150%}

/* podkreślenie linków w nawigacji */
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-5px;height:2px;border-radius:2px;
  background:var(--brand-grad);transform:scaleX(0);transform-origin:center;transition:transform .25s ease;
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

/* draw-in ikon SVG — „rysują się" przy wejściu karty w widok */
.reveal .ico path,.reveal .ico line,.reveal .ico circle,.reveal .ico rect,.reveal .ico polyline{
  stroke-dasharray:150;stroke-dashoffset:150;
}
.reveal.in-view .ico path,.reveal.in-view .ico line,.reveal.in-view .ico circle,.reveal.in-view .ico rect,.reveal.in-view .ico polyline{
  animation:icoDraw .85s cubic-bezier(.65,0,.35,1) forwards;
}
@keyframes icoDraw{to{stroke-dashoffset:0}}
.section-sub{text-align:center;color:var(--muted);font-size:1.08rem;max-width:640px;margin:0 auto 56px}
.section-dark .section-sub{color:#9ca3af}

/* === 4. Przyciski === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 22px;border-radius:10px;font-weight:600;font-size:.95rem;
  border:none;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn-primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 8px 24px -10px rgba(139,92,246,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(139,92,246,.75)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:#f1f5f9}
.btn-dark{background:var(--bg-dark);color:#fff}
.btn-dark:hover{background:#000}
.btn-lg{padding:15px 32px;font-size:1rem}
.section-dark .btn-ghost{color:#fff;border-color:rgba(255,255,255,.25)}
.section-dark .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* === 5. Navbar === */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(10,11,16,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.32rem;letter-spacing:-.02em;color:var(--text)}
.logo-mark{width:34px;height:34px;flex-shrink:0;transition:transform .35s}
.logo:hover .logo-mark{transform:rotate(-12deg) scale(1.08)}
.logo-lockup{display:flex;flex-direction:column;line-height:1.05}
.logo-tagline{font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.logo-text strong{color:var(--primary);font-weight:800}
.logo-text em{font-style:normal;font-size:.7em;color:var(--muted);font-weight:600;margin-left:2px}
.nav-links{display:flex;gap:28px;flex:1;justify-content:center}
.nav-links a{position:relative;color:var(--muted);font-weight:500;font-size:.95rem;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}

.nav-toggle{display:none;background:transparent;border:none;width:42px;height:42px;border-radius:8px;align-items:center;justify-content:center}
.nav-toggle:hover{background:var(--bg-alt)}
.nav-toggle span{width:22px;height:2px;background:var(--text);position:relative;transition:transform .25s,background .25s}
.nav-toggle span:before,.nav-toggle span:after{content:"";position:absolute;width:22px;height:2px;background:var(--text);left:0;transition:transform .25s}
.nav-toggle span:before{top:-7px}.nav-toggle span:after{top:7px}

/* === 6. Hero === */
.hero{
  position:relative;overflow:hidden;
  padding:104px 0 116px;text-align:center;
  background:
    radial-gradient(680px 360px at 22% 6%, rgba(139,92,246,.22) 0%, transparent 60%),
    radial-gradient(680px 360px at 80% 2%, rgba(56,189,248,.15) 0%, transparent 60%),
    radial-gradient(1000px 520px at 50% -14%, rgba(168,85,247,.10) 0%, transparent 72%);
}
/* siatka kropek — tekstura premium (dev-tools) */
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.6;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1.4px);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse 78% 62% at 50% 30%, #000 0%, transparent 72%);
          mask-image:radial-gradient(ellipse 78% 62% at 50% 30%, #000 0%, transparent 72%);
}
.hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.92;
  -webkit-mask-image:radial-gradient(circle at 50% 22%, #000 0, #000 64%, transparent 96%);
          mask-image:radial-gradient(circle at 50% 22%, #000 0, #000 64%, transparent 96%);
}
.hero .container{position:relative;z-index:1}
/* logo-centerpiece nad nagłówkiem hero */
.hero-logo{
  position:relative;width:84px;height:84px;margin:0 auto 26px;
  display:flex;align-items:center;justify-content:center;
  animation:fadeUp .7s both, logoFloat 5s ease-in-out infinite;
}
.hero-logo img{position:relative;z-index:1;width:84px;height:84px;
  filter:drop-shadow(0 8px 26px rgba(139,92,246,.55))}
.hero-logo-ring{
  position:absolute;inset:-14px;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(168,85,247,.45) 0%,rgba(139,92,246,.12) 45%,transparent 70%);
  animation:logoPulse 3s ease-in-out infinite;
}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes logoPulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.18);opacity:.45}}
@media (prefers-reduced-motion:reduce){
  .hero-logo,.hero-logo-ring{animation:none}
}

.hero .badge{
  display:inline-flex;align-items:center;gap:9px;padding:8px 18px;border-radius:999px;
  background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.32);
  color:#c4b5fd;font-weight:600;font-size:.85rem;margin-bottom:26px;
  backdrop-filter:blur(8px);animation:fadeUp .7s .05s both;
}
.hero .badge::before{
  content:"";width:7px;height:7px;border-radius:50%;background:#a855f7;
  animation:badgePulse 2.4s ease-out infinite;
}
@keyframes badgePulse{
  0%{box-shadow:0 0 0 0 rgba(168,85,247,.55)}
  70%{box-shadow:0 0 0 8px rgba(168,85,247,0)}
  100%{box-shadow:0 0 0 0 rgba(168,85,247,0)}
}
.hero h1{margin-bottom:22px;animation:fadeUp .7s .15s both}
.hero .lead{font-size:1.16rem;color:var(--muted);max-width:680px;margin:0 auto 34px;animation:fadeUp .7s .28s both}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:56px;animation:fadeUp .7s .4s both}
.hero-stats{display:flex;gap:56px;justify-content:center;flex-wrap:wrap;animation:fadeUp .7s .52s both}
.hero-stats strong{display:block;font-size:2rem;font-weight:800;
  background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 16px rgba(168,85,247,.6));
  animation:statGlow 3.5s ease-in-out infinite}
@keyframes statGlow{
  0%,100%{filter:drop-shadow(0 0 12px rgba(168,85,247,.45))}
  50%{filter:drop-shadow(0 0 22px rgba(168,85,247,.85))}
}
@media (prefers-reduced-motion:reduce){.hero-stats strong{animation:none}}
.hero-stats span{color:var(--muted);font-size:.9rem}
.hero-stats div{position:relative;transition:transform .2s}
.hero-stats div:hover{transform:translateY(-4px)}
.hero-stats div+div::before{
  content:"";position:absolute;left:-28px;top:50%;transform:translateY(-50%);
  width:1px;height:38px;background:linear-gradient(180deg,transparent,var(--border-strong),transparent);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* kafelki kategorii w hero */
.hero-tags{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:42px;animation:fadeUp .7s .62s both}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  color:var(--muted);font-size:.86rem;font-weight:500;
  transition:border-color .2s,color .2s,background .2s,transform .2s;
}
.hero-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--cat-color);box-shadow:0 0 8px var(--cat-color)}
.hero-tag:hover{border-color:var(--cat-color);color:var(--text);background:rgba(255,255,255,.06);transform:translateY(-2px)}

/* === 7. Kategorie === */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.cat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 22px;text-align:center;color:var(--text);
  transition:transform .25s,box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.cat-card:before{
  content:"";position:absolute;inset:0 0 auto 0;height:4px;
  background:var(--cat-color);opacity:.85;transform:translateY(-4px);transition:transform .3s;
}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--cat-color)}
.cat-card:hover:before{transform:translateY(0)}
.cat-ico{
  display:flex;align-items:center;justify-content:center;width:64px;height:64px;
  margin:0 auto 20px;border-radius:18px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--cat-color) 92%,#fff),color-mix(in srgb,var(--cat-color) 72%,#000));
  border:1px solid color-mix(in srgb,var(--cat-color) 55%,transparent);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 8px 20px -10px color-mix(in srgb,var(--cat-color) 80%,transparent);
  transition:transform .3s,box-shadow .3s;
}
.cat-ico .ico{width:30px;height:30px;color:#fff;transition:transform .3s;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}
.cat-card:hover .cat-ico{box-shadow:inset 0 1px 0 rgba(255,255,255,.3), 0 14px 30px -10px color-mix(in srgb,var(--cat-color) 90%,transparent)}
.cat-card:hover .cat-ico .ico{transform:scale(1.08) rotate(-4deg)}

/* ikony — bazowe */
.ico{display:block}
.cat-card h3{font-size:1.12rem;margin-bottom:6px}
.cat-card p{color:var(--muted);font-size:.9rem;margin-bottom:14px}
.cat-count{
  display:inline-block;font-size:.78rem;font-weight:600;color:var(--cat-color);
  background:color-mix(in srgb,var(--cat-color) 12%,transparent);
  padding:4px 12px;border-radius:999px;
}

/* === 8. Karty produktów === */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prod-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;color:var(--text);
  transition:transform .2s,box-shadow .25s,border-color .25s;
  position:relative;cursor:pointer;
}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--primary)}
.prod-card:after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .35s ease;
}
.prod-card:hover:after{width:100%}
.prod-top{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:3px solid var(--cat-color);background:linear-gradient(135deg,color-mix(in srgb,var(--cat-color) 10%,transparent),color-mix(in srgb,var(--cat-color) 3%,transparent))}
.prod-top::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:radial-gradient(color-mix(in srgb,var(--cat-color) 45%,transparent) 1px,transparent 1.4px);
  background-size:13px 13px;
  -webkit-mask-image:linear-gradient(105deg,#000,transparent 72%);
          mask-image:linear-gradient(105deg,#000,transparent 72%);
}
.prod-top>*{position:relative;z-index:1}
.prod-ico{display:flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:13px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--cat-color) 92%,#fff),color-mix(in srgb,var(--cat-color) 72%,#000));
  border:1px solid color-mix(in srgb,var(--cat-color) 55%,transparent);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 6px 16px -8px color-mix(in srgb,var(--cat-color) 80%,transparent);
  transition:transform .3s,box-shadow .3s}
.prod-ico .ico{width:25px;height:25px;color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}
.prod-card:hover .prod-ico{transform:scale(1.08) rotate(-4deg)}
.tag{font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border:1px solid transparent}
.tag-ready{background:rgba(34,197,94,.16);color:#4ade80;border-color:rgba(34,197,94,.3)}
.tag-beta{background:rgba(245,158,11,.16);color:#fbbf24;border-color:rgba(245,158,11,.3)}
.tag-demo{background:rgba(56,189,248,.16);color:#38bdf8;border-color:rgba(56,189,248,.3)}
.tag-dev{background:rgba(255,255,255,.07);color:#9ca3af;border-color:rgba(255,255,255,.12)}

/* ===== Glassmorphism + glow (dark premium) ===== */
.cat-card,.prod-card,.why,.p-feat,.mini-card,.roi-pick,.faq-item{
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.015));
  backdrop-filter:blur(8px);
}
.cat-card:hover,.prod-card:hover{
  box-shadow:0 0 0 1px color-mix(in srgb,var(--cat-color) 55%,transparent),
             0 22px 55px -22px color-mix(in srgb,var(--cat-color) 65%,transparent);
}
.why:hover,.p-feat:hover,.mini-card:hover{
  box-shadow:var(--glow);border-color:rgba(139,92,246,.4)
}
/* wyróżnienie produktu flagowego — złota gwiazdka przy nazwie */
.flag-star{
  display:inline-block;margin-left:7px;font-size:.82em;line-height:1;
  color:#fbbf24;filter:drop-shadow(0 0 6px rgba(245,158,11,.55));
  vertical-align:baseline;
}

/* ===== Sekcje flagowe (rozbudowane) ===== */
.flagships{display:flex;flex-direction:column;gap:24px}
.flag-row{
  display:grid;grid-template-columns:.82fr 1.18fr;gap:44px;align-items:center;
  padding:40px;border:1px solid var(--border);border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.014));
  backdrop-filter:blur(8px);position:relative;overflow:hidden;
  transition:border-color .25s,box-shadow .25s;
}
.flag-row:hover{border-color:color-mix(in srgb,var(--cat-color) 45%,transparent);
  box-shadow:0 24px 60px -28px color-mix(in srgb,var(--cat-color) 70%,transparent)}
.flag-row:nth-child(even) .flag-media{order:2}
.flag-media{
  position:relative;border-radius:18px;min-height:252px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:
    radial-gradient(120% 120% at 28% 18%,color-mix(in srgb,var(--cat-color) 42%,transparent),transparent 70%),
    linear-gradient(135deg,color-mix(in srgb,var(--cat-color) 22%,#0c0e15),#0c0e15);
  border:1px solid color-mix(in srgb,var(--cat-color) 32%,transparent);
}
.flag-media::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  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:28px 28px;
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 0%, transparent 70%);
          mask-image:radial-gradient(circle at 50% 50%, #000 0%, transparent 70%);
}
.flag-ico{
  position:relative;z-index:1;width:104px;height:104px;
  display:flex;align-items:center;justify-content:center;border-radius:26px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  animation:floaty 6s ease-in-out infinite;will-change:transform;
}
.flag-ico .ico{width:58px;height:58px;color:#fff}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.flag-eyebrow{
  display:inline-block;margin-bottom:10px;font-size:.74rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;
  background:linear-gradient(90deg,#fbbf24,#f59e0b);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.flag-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.flag-cat{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--cat-color)}
.flag-body h3{font-size:1.85rem;margin-bottom:6px}
.flag-tag{color:var(--primary);font-weight:600;margin-bottom:12px}
.flag-intro{color:var(--muted);margin-bottom:18px}
.flag-feats{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin-bottom:22px}
.flag-feats li{font-size:.92rem;padding-left:22px;position:relative}
.flag-feats li:before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:var(--cat-color)}
.prod-card h4{font-size:1.2rem;margin:20px 24px 6px;letter-spacing:-.01em}
.prod-tagline{margin:0 24px 12px;color:var(--primary);font-size:.92rem;font-weight:600}
.prod-desc{color:var(--muted);font-size:.93rem;margin:0 24px 16px;flex:1}
.prod-meta{margin:0 24px;padding:12px 0;border-top:1px solid var(--border);font-size:.78rem;color:var(--muted)}
.prod-link{
  display:inline-block;margin:0 24px 22px;font-weight:700;font-size:.9rem;color:var(--primary);
  transition:transform .2s;
}
.prod-card:hover .prod-link{transform:translateX(4px)}

/* === 9. Proces (Jak działamy) === */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.proc-step{position:relative;padding:0 18px}
.proc-step:not(:last-child):after{
  content:"";position:absolute;top:26px;left:calc(50% + 28px);right:calc(-50% + 28px);
  height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:.35;
}
.proc-num{
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;font-size:1.4rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  box-shadow:0 12px 24px -12px rgba(99,102,241,.7);
}
.proc-step h3{margin-bottom:8px}
.proc-step p{color:var(--muted);font-size:.93rem;margin-bottom:10px}
.proc-time{
  display:inline-block;font-size:.78rem;font-weight:600;color:var(--primary);
  background:#eef2ff;padding:4px 12px;border-radius:999px;
}

/* === 10. Dlaczego my === */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why{padding:28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:transform .2s,box-shadow .2s}
.why:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.why-ico{
  display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;
  border-radius:14px;font-size:1.55rem;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(139,92,246,.20),rgba(56,189,248,.10));
  border:1px solid var(--border);
}
.why h3{margin-bottom:8px}
.why p{color:var(--muted);font-size:.93rem}

/* === Pasek filtrów produktów === */
.prod-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 0 36px}
.pf-chip{
  display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  color:var(--muted);font-size:.88rem;font-weight:600;font-family:inherit;
  transition:border-color .2s,color .2s,background .2s,transform .15s;
}
.pf-chip:hover{color:var(--text);border-color:var(--border-strong);transform:translateY(-1px)}
.pf-chip .pf-dot{width:8px;height:8px;border-radius:50%;background:var(--cat-color,#8b5cf6);box-shadow:0 0 8px var(--cat-color,#8b5cf6)}
.pf-chip .pf-n{font-family:var(--font-mono);font-size:.78rem;opacity:.7}
.pf-chip.active{
  color:#fff;border-color:transparent;
  background:linear-gradient(135deg,rgba(139,92,246,.35),rgba(56,189,248,.22));
  box-shadow:0 8px 22px -12px rgba(139,92,246,.7);
}
.pf-chip.active[data-filter]:not([data-filter="all"]){
  background:linear-gradient(135deg,color-mix(in srgb,var(--cat-color) 42%,transparent),color-mix(in srgb,var(--cat-color) 14%,transparent));
}
.prod-empty{text-align:center;color:var(--muted);padding:30px 0}

/* === Sekcja O twórcy === */
.founder{display:grid;grid-template-columns:300px 1fr;gap:36px;align-items:start;max-width:1000px;margin:0 auto}
.founder-card{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 26px;text-align:center;position:sticky;top:96px;
}
.founder-avatar{
  width:88px;height:88px;margin:0 auto 16px;border-radius:24px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:700;font-size:1.9rem;color:#fff;letter-spacing:.02em;
  background:var(--brand-grad);box-shadow:0 12px 30px -12px rgba(139,92,246,.7);
}
.founder-card h3{font-size:1.25rem;margin-bottom:4px}
.founder-role{color:var(--primary);font-weight:600;font-size:.92rem;margin-bottom:20px}
.founder-meta{text-align:left;margin-bottom:22px;display:flex;flex-direction:column;gap:9px}
.founder-meta li{display:flex;justify-content:space-between;gap:12px;font-size:.88rem;border-bottom:1px solid var(--border);padding-bottom:8px}
.founder-meta li:last-child{border-bottom:0;padding-bottom:0}
.founder-meta span{color:var(--muted)}
.founder-meta b{color:var(--text);font-weight:600;text-align:right}
.founder-story p{color:var(--muted);font-size:1.02rem;margin-bottom:16px;line-height:1.7}
.founder-story b{color:var(--text);font-weight:600}
.founder-pillars{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.fp{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.02)}
.fp-ico{font-size:1.5rem;flex-shrink:0}
.fp b{display:block;font-size:.92rem;color:var(--text)}
.fp span{font-size:.8rem;color:var(--muted)}

/* === 11. CTA / formularz === */
.cta-band{
  position:relative;overflow:hidden;
  background:
    radial-gradient(620px 320px at 82% 120%, rgba(56,189,248,.38), transparent 60%),
    radial-gradient(520px 280px at 12% -20%, rgba(192,132,252,.35), transparent 60%),
    linear-gradient(135deg,#7c3aed,#6d28d9);
  color:#fff;text-align:center;padding:96px 0;
}
.cta-band::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px, transparent 1.4px);
  background-size:30px 30px;
  -webkit-mask-image:radial-gradient(ellipse 70% 80% at 50% 50%, #000, transparent 78%);
          mask-image:radial-gradient(ellipse 70% 80% at 50% 50%, #000, transparent 78%);
}
.cta-band .container{position:relative;z-index:1}
.cta-band h2{margin-bottom:14px}
.cta-band p{font-size:1.1rem;opacity:.92;max-width:600px;margin:0 auto 32px}
.cta-band .btn-light{box-shadow:0 14px 28px -14px rgba(0,0,0,.4)}

.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:680px;margin:0 auto;text-align:left}
.contact-form input,.contact-form select,.contact-form textarea{
  padding:14px 16px;border-radius:10px;border:none;font-size:1rem;font-family:inherit;
  background:#fff;color:#0b1220;
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#6b7280;opacity:1}
.contact-form select{color:#0b1220}
.contact-form select:invalid{color:#6b7280}            /* placeholder-option szary, dopóki nie wybrano */
.contact-form select option{color:#0b1220;background:#fff}
.contact-form select,.contact-form textarea{grid-column:1/-1}
.contact-form textarea{resize:vertical;min-height:90px}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:2px solid #fff}
.contact-form button{grid-column:1/-1}
.form-msg{grid-column:1/-1;margin:0;font-size:.94rem;font-weight:600;min-height:1.2em}
.form-msg.ok{color:#bbf7d0}
.form-msg.err{color:#fecaca}

/* === 12. Footer === */
.footer{background:var(--bg-darker);color:#94a3b8;padding:64px 0 32px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.footer .logo{color:#fff;font-size:1.25rem}
.footer .logo-text strong{color:#a5b4fc}
.footer-brand p{margin-top:14px;font-size:.9rem;max-width:320px}
.footer-brand .muted{margin-top:18px;font-size:.78rem;color:#475569}
.footer-col h5{color:#fff;font-size:.95rem;margin-bottom:14px}
.footer-col a{display:block;font-size:.9rem;padding:5px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid #1f2937;margin-top:48px;padding-top:24px;text-align:center;font-size:.82rem;color:#475569}

/* === 13. Animacje reveal === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,.61,.36,1)}
.reveal.in-view{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1!important;transform:none!important}
}

/* === 14. Strona kategorii === */
.kat-hero{
  padding:60px 0 50px;color:#fff;
  background:linear-gradient(135deg,var(--cat-color),color-mix(in srgb,var(--cat-color) 50%,#000));
  position:relative;overflow:hidden;
}
.kat-hero:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 300px at 80% -10%,rgba(255,255,255,.15) 0%,transparent 70%);
}
.kat-hero-inner{position:relative;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.kat-hero-ico{font-size:4rem;line-height:1;flex-shrink:0}
.kat-hero h1{margin-bottom:8px}
.kat-hero .lead{font-size:1.1rem;opacity:.92;max-width:680px;margin-top:8px}
.kat-hero .breadcrumb{margin-bottom:14px;color:rgba(255,255,255,.7);font-size:.88rem}
.kat-hero .breadcrumb a{color:#fff;font-weight:600}

.other-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* === 15. Strona produktu === */
.breadcrumb{padding:22px 0;font-size:.9rem;color:var(--muted)}
.breadcrumb a{color:var(--primary);font-weight:600}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb span.sep{margin:0 8px;color:var(--border)}

.p-hero{padding:36px 0 60px;position:relative;overflow:hidden}
.p-hero:before{content:"";position:absolute;inset:0;background:var(--cat-color);opacity:.06;z-index:-1}
.p-hero-top{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.p-icon{display:flex;width:74px;height:74px;align-items:center;justify-content:center;border-radius:20px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--cat-color) 92%,#fff),color-mix(in srgb,var(--cat-color) 72%,#000));
  border:1px solid color-mix(in srgb,var(--cat-color) 55%,transparent);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 10px 24px -10px color-mix(in srgb,var(--cat-color) 85%,transparent)}
.p-icon .ico{width:40px;height:40px;color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}
.p-cat-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--cat-color)}
.p-hero h1{margin-bottom:10px}
.p-tagline{font-size:1.2rem;color:var(--primary);font-weight:600;margin-bottom:18px}
.p-intro{font-size:1.06rem;color:var(--muted);max-width:760px;margin-bottom:28px}
.p-hero-cta{display:flex;gap:12px;flex-wrap:wrap}

.p-savings{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.p-save-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center}
.p-save-box.time{border-bottom:4px solid var(--accent)}
.p-save-box.money{border-bottom:4px solid var(--green)}
.p-save-box.who{border-bottom:4px solid var(--primary);text-align:left}
.p-save-num{font-size:2rem;font-weight:800;letter-spacing:-.02em;display:block}
.p-save-box.time .p-save-num{color:var(--accent)}
.p-save-box.money .p-save-num{color:var(--green)}
.p-save-cap{display:block;color:var(--muted);font-size:.85rem;margin-top:4px}
.p-save-box.who h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:6px}
.p-save-box.who p{font-size:.95rem}

.p-feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.p-feat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:transform .2s,box-shadow .2s}
.p-feat:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.p-feat h3{margin-bottom:6px}
.p-feat h3:before{content:"▹";color:var(--primary);margin-right:8px;font-weight:800}
.p-feat p{color:var(--muted);font-size:.93rem}

.p-benefits{max-width:760px;margin:0 auto}
.p-benefits li{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:16px 20px;margin-bottom:12px;font-size:1rem;font-weight:500;
  display:flex;align-items:center;gap:14px;
}
.p-benefits li:before{
  content:"✓";flex-shrink:0;width:28px;height:28px;border-radius:50%;
  background:#dcfce7;color:#15803d;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.p-meta-bar{
  text-align:center;color:var(--muted);font-size:.95rem;
  padding:18px;background:var(--bg-alt);border-radius:12px;
}
.p-meta-bar b{color:var(--text)}

/* === 16. Mini-karty (powiązane produkty/kategorie) === */
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.mini-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px;text-align:center;color:var(--text);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.mini-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--primary)}
.mini-card .m-ico{display:flex;justify-content:center;margin-bottom:10px}
.mini-card .m-ico .ico{width:22px;height:22px;color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}
.mini-card .m-ico{align-items:center;width:44px;height:44px;margin:0 auto 10px;border-radius:12px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--cat-color) 92%,#fff),color-mix(in srgb,var(--cat-color) 72%,#000));
  border:1px solid color-mix(in srgb,var(--cat-color) 55%,transparent);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25)}
.mini-card h4{font-size:.96rem}
.mini-card span{font-size:.76rem;color:var(--muted)}

/* === 17. 404 === */
.error-page{padding:120px 0;text-align:center}
.error-page h1{font-size:5rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:8px}
.error-page p{color:var(--muted);font-size:1.1rem;margin-bottom:28px}

/* === 18. Responsive === */
/* === Watermark ikony w hero produktu === */
.p-hero .container{position:relative;z-index:1}
.p-hero-watermark{
  position:absolute;top:50%;right:-30px;transform:translateY(-50%);
  width:320px;height:320px;opacity:.06;color:var(--cat-color);
  pointer-events:none;z-index:0;
}
.p-hero-watermark .ico{width:100%;height:100%}

/* === Strony prawne (prose) === */
.prose{max-width:780px;margin:0 auto;color:var(--muted)}
.prose h1{color:var(--text);margin-bottom:6px}
.prose .doc-meta{color:var(--muted);font-size:.88rem;margin-bottom:26px}
.prose h2{color:var(--text);font-size:1.3rem;margin:30px 0 10px}
.prose h3{color:var(--text);font-size:1.05rem;margin:18px 0 6px}
.prose p{margin-bottom:12px}
.prose ul{margin:0 0 12px}
.prose li{position:relative;padding-left:20px;margin-bottom:6px}
.prose li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--primary)}
.prose a{color:var(--primary)}
.prose strong{color:var(--text)}
.legal-note{
  background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.32);
  border-radius:10px;padding:14px 16px;color:#fcd34d;font-size:.9rem;margin-bottom:26px;
}

@media (max-width:1080px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .other-cats,.mini-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .process{grid-template-columns:repeat(2,1fr);gap:32px 0}
  .proc-step:after{display:none}
  .p-savings,.p-feat-grid{grid-template-columns:1fr}
  .flag-row{grid-template-columns:1fr;gap:22px}
  .flag-row .flag-media{order:0!important;min-height:170px}
  .flag-feats{grid-template-columns:1fr}
  .founder{grid-template-columns:1fr;gap:24px}
  .founder-card{position:static;max-width:420px;margin:0 auto}
  .nav-links{
    position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--border);padding:12px 0;
    transform:translateY(-110%);opacity:0;pointer-events:none;transition:transform .25s,opacity .25s;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a{padding:14px 24px;width:100%;text-align:center;border-bottom:1px solid var(--border)}
  .nav-toggle{display:flex}
  .nav-inner .btn{display:none}
  .navbar{position:relative}
}
@media (max-width:640px){
  .cat-grid,.prod-grid,.why-grid{grid-template-columns:1fr}
  .other-cats,.mini-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .contact-form{grid-template-columns:1fr}
  .founder-pillars{grid-template-columns:1fr}
  .section{padding:64px 0}
  .hero{padding:64px 0 80px}
  .hero-stats{gap:28px}
  .kat-hero-inner{flex-direction:column;text-align:center;align-items:center}
}
