/* =====================================================================
   o-nas-neural.css - warstwa wizualna dla strony "O nas / Kontakt"
   -------------------------------------------------------------------
   Bazuje na ai-neural.css (wczytywany PRZED tym plikiem w szablonie).
   Paleta: Indigo #4F46E5 · Cyan #22D3EE · Emerald #10B981 + akcent Pink
   Styl: "Studio Dossier" - paszport firmowy, KPI tiles, live ticker.
   ===================================================================== */

/* ── 0. TOKENY PALETY (warstwa o-nas) ───────────────────────────── */
.neural-page--onas{
  --on-indigo:       #4F46E5;
  --on-indigo-2:     #6366F1;
  --on-indigo-3:     #818CF8;
  --on-cyan:         #22D3EE;
  --on-cyan-2:       #67E8F9;
  --on-emerald:      #10B981;
  --on-emerald-2:    #34D399;
  --on-violet:       #A78BFA;
  --on-pink:         #F43F5E;
  --on-amber:        #F59E0B;

  --on-bg:           #050a18;
  --on-bg-2:         #0B1120;
  --on-bg-3:         #111827;
  --on-card:         #0F172A;
  --on-line:         rgba(148,163,184,.14);
  --on-line-2:       rgba(148,163,184,.22);

  --on-grad:         linear-gradient(135deg,#4F46E5 0%,#22D3EE 100%);
  --on-grad-emerald: linear-gradient(135deg,#10B981 0%,#22D3EE 100%);
  --on-grad-violet:  linear-gradient(135deg,#6366F1 0%,#A78BFA 100%);
  --on-grad-tri:     linear-gradient(135deg,#4F46E5 0%,#22D3EE 50%,#10B981 100%);

  --on-glow:         0 0 60px rgba(34,211,238,.25);
  --on-glow-em:      0 0 40px rgba(16,185,129,.22);
  --on-shadow-xl:    0 36px 72px -28px rgba(5,7,20,.60), 0 12px 26px -16px rgba(5,7,20,.40);
  --on-shadow-lg:    0 22px 50px -20px rgba(5,7,20,.50);
}

/* ── globalny override tła dark sections ────────────────────────── */
.neural-page--onas .neural-section--dark{
  background: var(--on-bg-2);
}

/* ================================================================
   1. HERO - "Studio Dossier"
   ================================================================ */
.nhero--onas{
  position:relative;
  padding: 160px 0 110px;
  background:
    radial-gradient(ellipse 70% 60% at 20% 10%, rgba(79,70,229,.18), transparent 60%),
    radial-gradient(ellipse 60% 60% at 90% 100%, rgba(16,185,129,.15), transparent 60%),
    linear-gradient(180deg,#050a18 0%,#030712 100%);
  overflow:hidden;
}
.nhero--onas .nhero__grid-overlay{
  background-image:
    linear-gradient(rgba(34,211,238,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,211,238,.07) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
          mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  opacity:.55;
  animation: onGridSlide 28s linear infinite;
}
@keyframes onGridSlide{ to{ background-position: 56px 56px; } }

.nhero--onas__flow{
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none;
  z-index:1;
  opacity:.85;
  mix-blend-mode: screen;
}

.nhero--onas__aurora{
  position:absolute; inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 60% 40% at 18% 30%, rgba(79,70,229,.30), transparent 60%),
    radial-gradient(ellipse 55% 45% at 82% 68%, rgba(16,185,129,.22), transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(34,211,238,.18), transparent 65%);
  filter: blur(38px);
  animation: onAuroraDrift 20s ease-in-out infinite alternate;
  z-index:1;
}
@keyframes onAuroraDrift{
  0%   { transform: translate3d(0,0,0) scale(1); opacity:.9; }
  50%  { transform: translate3d(-30px,16px,0) scale(1.05); opacity:1; }
  100% { transform: translate3d(22px,-18px,0) scale(.97); opacity:.85; }
}

.nhero--onas .nhero__orb--1{
  background: radial-gradient(circle, rgba(79,70,229,.42), transparent 65%);
  width:680px; height:680px;
  top:-200px; left:-180px;
}
.nhero--onas .nhero__orb--2{
  background: radial-gradient(circle, rgba(34,211,238,.32), transparent 65%);
  width:560px; height:560px;
  bottom:-160px; right:-140px;
  animation-delay:-9s;
}
.nhero--onas .nhero__orb--3{
  position:absolute;
  background: radial-gradient(circle, rgba(16,185,129,.20), transparent 65%);
  width:380px; height:380px;
  top:50%; left:34%;
  filter: blur(70px);
  animation: onOrbFloat 14s ease-in-out infinite;
}
@keyframes onOrbFloat{
  0%,100%{ transform: translate(0,0); }
  50%    { transform: translate(36px,-26px); }
}

.nhero--onas .nhero__inner{
  display:grid;
  grid-template-columns: minmax(0,1.05fr) minmax(0,1fr);
  gap: clamp(36px,6vw,80px);
  align-items:center;
}

/* eyebrow - niezależne stylowanie pod studio aestetyk */
.nhero--onas .nhero__eyebrow{
  color: var(--on-emerald-2);
  background: rgba(16,185,129,.10);
  border-color: rgba(16,185,129,.30);
}
.nhero--onas .nhero__eyebrow-dot{
  background: var(--on-emerald-2);
  box-shadow: 0 0 10px var(--on-emerald-2);
}

/* Sekcja O NAS - sec-head pełna szerokość, bez kapsla 760/620 */
.neural-page--onas #o-nas .sec-head{
  max-width: 100%;
  width: 100%;
}
.neural-page--onas #o-nas .sec-head__title,
.neural-page--onas #o-nas .sec-head__sub{
  max-width: 100%;
  width: 100%;
}

/* H1 - pełen ciąg, akcent inline na frazie usług */
.nhero--onas .nhero__title{
  font-family: 'Space Grotesk', var(--font-display, sans-serif);
  font-weight: 700;
  font-size: clamp(2.2rem, 4.6vw, 3.6rem);
  line-height: 1.12;
  letter-spacing:-.022em;
  color: #fff;
  margin: 0 0 22px;
  max-width: 22ch;
  text-wrap: balance;
}
.nhero--onas .nhero__title-accent{
  background: linear-gradient(120deg,#22D3EE 0%,#6366F1 50%,#10B981 100%);
  background-size: 220% 100%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  animation: onGradShift 9s ease-in-out infinite;
  font-weight:800;
  /* gradient czyta się jak jeden ciągły fragment, bez wymuszania nowej linii */
}
@keyframes onGradShift{
  0%,100%{ background-position: 0% 50%; }
  50%    { background-position: 100% 50%; }
}

/* subtitle */
.nhero--onas .nhero__subtitle{
  color: rgba(255,255,255,.74);
  font-size: clamp(1rem,1.5vw,1.12rem);
  line-height:1.7;
  max-width:56ch;
  margin:0 0 28px;
}

/* hero feature chips */
.nhero--onas .nhero__bullets{
  list-style:none; padding:0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px;
  margin: 0 0 36px;
}
.nhero--onas .nhero__bullets li{
  padding:18px 18px 16px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  display:flex; flex-direction:column; align-items:flex-start; gap:12px;
  font-size:.88rem;
  line-height:1.5;
  color: rgba(255,255,255,.88);
  text-align:left;
  min-height:120px;
  transition: background .25s, border-color .25s, transform .25s;
}
.nhero--onas .nhero__bullets li:hover{
  background: rgba(34,211,238,.08);
  border-color: rgba(34,211,238,.32);
  transform: translateY(-3px);
}
.nhero--onas .nhero__bullets li i{
  width:38px; height:38px;
  display:grid; place-items:center;
  border-radius:11px;
  background: var(--on-grad);
  color:#fff; font-size:.95rem;
  flex:0 0 38px;
  box-shadow: 0 8px 20px -8px rgba(34,211,238,.55);
}
.nhero--onas .nhero__bullets li strong{ color:#fff; font-weight:700; margin-right:2px; }

/* trust */
.nhero--onas .nhero__trust{ border-top:1px solid var(--on-line); }
.nhero--onas .nhero__trust em{
  display:inline-flex; align-items:center;
  padding:4px 12px;
  font-style:normal;
  font-size:.78rem;
  color: var(--on-cyan-2);
  background: rgba(34,211,238,.08);
  border:1px solid rgba(34,211,238,.22);
  border-radius:999px;
}

/* ================================================================
   2. STUDIO DOSSIER (prawa strona hero)
   ================================================================ */
.nhero--onas .nhero__right{
  position:relative;
  min-height:580px;
  display:flex; align-items:center; justify-content:center;
  z-index:3;
}
.dossier{
  position:relative;
  width:100%;
  max-width:560px;
  margin:0 auto;
}

.dossier__panel{
  position:relative;
  background: linear-gradient(160deg,#0F1430 0%,#0A0F24 100%);
  border:1px solid rgba(34,211,238,.18);
  border-radius:22px;
  padding:24px;
  box-shadow:
    0 50px 100px -30px rgba(5,7,20,.75),
    0 0 0 1px rgba(34,211,238,.08) inset,
    var(--on-glow);
  transform: perspective(1400px) rotateY(-3deg) rotateX(2deg);
  transition: transform .6s cubic-bezier(.22,1,.36,1);
  z-index:2;
  animation: onDossierFloat 7s ease-in-out infinite;
}
.dossier__panel:hover{
  transform: perspective(1400px) rotateY(0deg) rotateX(0deg) translateY(-4px);
}
@keyframes onDossierFloat{
  0%,100%{ transform: perspective(1400px) rotateY(-3deg) rotateX(2deg) translateY(0); }
  50%    { transform: perspective(1400px) rotateY(-3deg) rotateX(2deg) translateY(-6px); }
}

/* corner ticks */
.dossier__tick{
  position:absolute; width:14px; height:14px;
  border:1.5px solid rgba(34,211,238,.45);
  pointer-events:none;
  z-index:3;
}
.dossier__tick--tl{ top:6px; left:6px;     border-right:0; border-bottom:0; }
.dossier__tick--tr{ top:6px; right:6px;    border-left:0;  border-bottom:0; }
.dossier__tick--bl{ bottom:6px; left:6px;  border-right:0; border-top:0; }
.dossier__tick--br{ bottom:6px; right:6px; border-left:0;  border-top:0; }

/* head */
.dossier__head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.dossier__head-l{
  display:flex; align-items:center; gap:9px;
  font-family: var(--font-mono);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  font-weight:600;
}
.dossier__head-l i{ color: var(--on-cyan); font-size:.88rem; }
.dossier__status{
  display:inline-flex; align-items:center; gap:7px;
  padding:4px 10px;
  border-radius:999px;
  background: rgba(16,185,129,.12);
  border:1px solid rgba(16,185,129,.28);
  color: var(--on-emerald-2);
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.14em;
  font-weight:600;
}
.dossier__status-dot{
  width:7px; height:7px; border-radius:50%;
  background: var(--on-emerald-2);
  box-shadow: 0 0 10px var(--on-emerald-2);
  animation: dotPulse 1.6s ease-in-out infinite;
}

/* identity strip */
.dossier__id{
  display:flex; align-items:center; gap:14px;
  padding:14px;
  background: rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  margin-bottom:18px;
}
.dossier__id-mark{
  width:54px; height:54px;
  border-radius:14px;
  background: var(--on-grad-tri);
  background-size:200% 200%;
  animation: onGradShift 8s ease-in-out infinite;
  display:grid; place-items:center;
  color:#fff;
  font-family:'Space Grotesk', sans-serif;
  font-weight:800;
  font-size:1.4rem;
  letter-spacing:.02em;
  flex-shrink:0;
  box-shadow:
    0 10px 24px -8px rgba(79,70,229,.55),
    0 0 0 1px rgba(255,255,255,.18) inset;
}
.dossier__id-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.dossier__id-meta strong{
  font-family:'Space Grotesk', sans-serif;
  color:#fff;
  font-size:1.1rem;
  font-weight:700;
  letter-spacing:-.005em;
}
.dossier__id-meta > span{
  font-family:var(--font-mono);
  font-size:.76rem;
  letter-spacing:.05em;
  color:rgba(255,255,255,.6);
}
.dossier__id-meta .dossier__id-loc{
  display:inline-flex; align-items:center; gap:6px;
  color: var(--on-cyan-2);
  margin-top:2px;
}
.dossier__id-meta .dossier__id-loc i{ font-size:.7rem; }

/* KPI grid */
.dossier__kpis{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:18px;
}
.dossier__kpi{
  padding:14px;
  background: rgba(34,211,238,.04);
  border:1px solid rgba(34,211,238,.14);
  border-radius:12px;
  display:flex; flex-direction:column; gap:4px;
  transition: background .3s, border-color .3s;
}
.dossier__kpi:hover{
  background: rgba(34,211,238,.07);
  border-color: rgba(34,211,238,.28);
}
.dossier__kpi-val{
  font-family:'Space Grotesk', sans-serif;
  font-weight:700;
  font-size:1.6rem;
  line-height:1;
  background: var(--on-grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.dossier__kpi-label{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color: rgba(255,255,255,.65);
}

/* live ticker */
.dossier__ticker{
  padding:14px;
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;
  margin-bottom:14px;
}
.dossier__ticker-label{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color: var(--on-emerald-2);
  font-weight:600;
  margin-bottom:8px;
}
.dossier__ticker-pulse{
  width:6px; height:6px; border-radius:50%;
  background: var(--on-emerald-2);
  box-shadow: 0 0 10px var(--on-emerald-2);
  animation: dotPulse 1.6s ease-in-out infinite;
}
.dossier__ticker-feed{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:6px;
  height:84px;
  overflow:hidden;
  position:relative;
}
.dossier__ticker-feed li{
  font-family:var(--font-mono);
  font-size:.78rem;
  color: rgba(255,255,255,.78);
  display:flex; align-items:center; gap:8px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  animation: onTickerScroll 18s linear infinite;
}
.dossier__ticker-feed li i{
  color: var(--on-cyan);
  font-size:.7rem;
  flex-shrink:0;
}
@keyframes onTickerScroll{
  0%   { transform: translateY(0); opacity:1; }
  20%  { transform: translateY(0); opacity:1; }
  25%  { transform: translateY(-22px); opacity:.4; }
  100% { transform: translateY(-22px); opacity:.4; }
}
.dossier__ticker-feed li:nth-child(1){ animation-delay: 0s; }
.dossier__ticker-feed li:nth-child(2){ animation-delay: -4.5s; }
.dossier__ticker-feed li:nth-child(3){ animation-delay: -9s; }
.dossier__ticker-feed li:nth-child(4){ animation-delay: -13.5s; }

/* stack chips */
.dossier__stack{
  display:flex; flex-wrap:wrap; gap:6px;
}
.dossier__stack-chip{
  padding:5px 11px;
  border-radius:999px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.78);
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.04em;
  transition: all .25s;
}
.dossier__stack-chip:hover{
  background: rgba(34,211,238,.08);
  border-color: rgba(34,211,238,.30);
  color: var(--on-cyan-2);
}

/* floating badges */
.dossier__badge{
  position:absolute;
  display:flex; align-items:center; gap:10px;
  padding:11px 14px;
  border-radius:14px;
  background: linear-gradient(160deg,#0F1430 0%,#0A0F24 100%);
  border:1px solid rgba(34,211,238,.22);
  box-shadow: 0 16px 36px -14px rgba(5,7,20,.6), var(--on-glow-em);
  z-index:4;
  font-family:var(--font-body);
}
.dossier__badge i{
  width:28px; height:28px;
  display:grid; place-items:center;
  border-radius:50%;
  background: var(--on-grad-emerald);
  color:#fff;
  font-size:.78rem;
}
.dossier__badge span{ display:flex; flex-direction:column; gap:0; }
.dossier__badge strong{
  color:#fff;
  font-size:.86rem;
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.005em;
}
.dossier__badge span span{
  font-family:var(--font-mono);
  font-size:.65rem;
  letter-spacing:.06em;
  color: rgba(255,255,255,.6);
  text-transform:uppercase;
}
.dossier__badge--1{
  top: 18px;
  left: -28px;
  animation: onBadgeFloat 5s ease-in-out infinite;
}
.dossier__badge--2{
  bottom: 32px;
  right: -32px;
  animation: onBadgeFloat 5s ease-in-out infinite -2.5s;
}
@keyframes onBadgeFloat{
  0%,100%{ transform: translateY(0); }
  50%    { transform: translateY(-6px); }
}

/* ================================================================
   3. MANIFEST (LIGHT) - dropcap + 4 stat tiles
   ================================================================ */
.neural-page--onas .manifest-grid{
  display:grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
}

.manifest-text{
  font-family: var(--font-body);
  color: var(--ink-soft);
}
.manifest-text p{
  font-size: 1.04rem;
  line-height: 1.75;
  margin: 0 0 18px;
}
.manifest-text strong{ color: var(--ink); font-weight:700; }
.manifest-text__lead{
  font-size: 1.12rem !important;
  color: var(--ink) !important;
}
.manifest-text__dropcap{
  float:left;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 800;
  font-size: 5.6rem;
  line-height: .85;
  margin: 6px 14px 0 0;
  background: var(--on-grad-tri);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}

.manifest-quote{
  position:relative;
  margin: 32px 0 0;
  padding: 26px 28px 22px;
  background: linear-gradient(180deg, #FFFFFF, #F6F7FB);
  border:1px solid var(--line-l);
  border-left: 4px solid;
  border-image: linear-gradient(180deg,#22D3EE,#10B981) 1;
  border-radius: 14px;
  box-shadow: 0 18px 40px -22px rgba(11,18,32,.18);
}
.manifest-quote i{
  position:absolute; top:-12px; left:24px;
  width:32px; height:32px;
  display:grid; place-items:center;
  border-radius:10px;
  background: var(--on-grad);
  color:#fff;
  font-size:.85rem;
  box-shadow: 0 10px 22px -8px rgba(34,211,238,.55);
}
.manifest-quote p{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  font-size: 1.18rem !important;
  line-height: 1.5 !important;
  color: var(--ink) !important;
  margin: 8px 0 10px !important;
}
.manifest-quote cite{
  font-family: var(--font-mono);
  font-style: normal;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted-l);
}

/* stats sidebar */
.manifest-stats{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  position: sticky;
  top: 96px;
}
.manifest-stat{
  position:relative;
  padding: 22px 22px 20px;
  background: #FFFFFF;
  border:1px solid var(--line-l);
  border-radius: 16px;
  transition: all .35s;
  overflow: hidden;
}
.manifest-stat::before{
  content:'';
  position:absolute; top:0; left:0; right:0; height:3px;
  background: var(--on-grad-tri);
  background-size: 200% 100%;
  animation: onGradShift 8s ease-in-out infinite;
  transform: scaleX(.4);
  transform-origin:left;
  transition: transform .5s ease;
}
.manifest-stat:hover{
  transform: translateY(-3px);
  border-color: var(--on-cyan);
  box-shadow: 0 22px 50px -28px rgba(34,211,238,.45);
}
.manifest-stat:hover::before{ transform: scaleX(1); }

.manifest-stat__num{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing:-.02em;
  margin-bottom: 6px;
}
.manifest-stat__num span{
  background: var(--on-grad-tri);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.manifest-stat__label{
  display:block;
  font-weight: 600;
  font-size: .98rem;
  color: var(--ink);
  margin-bottom: 3px;
}
.manifest-stat__sub{
  display:block;
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .05em;
  color: var(--muted-l);
}

/* ================================================================
   4. METHOD GRID (DARK) - 6 cards z stepem + ikoną + deliverable
   ================================================================ */
.method-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.method-card{
  position:relative;
  padding: 26px 24px 22px;
  background: linear-gradient(160deg, rgba(15,23,42,.85), rgba(11,17,32,.95));
  border:1px solid var(--on-line);
  border-radius: 16px;
  transition: all .35s cubic-bezier(.16,1,.3,1);
  overflow: hidden;
}
.method-card::before{
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(135deg, rgba(79,70,229,.08), transparent 60%);
  opacity: 0;
  transition: opacity .4s;
  pointer-events:none;
}
.method-card::after{
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background: var(--on-grad-tri);
  background-size: 200% 100%;
  transform: scaleX(0);
  transform-origin:left;
  transition: transform .5s ease;
}
.method-card:hover{
  transform: translateY(-4px);
  border-color: rgba(34,211,238,.35);
  box-shadow: 0 24px 50px -24px rgba(5,7,20,.7), var(--on-glow);
}
.method-card:hover::before{ opacity: 1; }
.method-card:hover::after{ transform: scaleX(1); }

.method-card__head{
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom: 18px;
}
.method-card__step{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 800;
  font-size: 2.2rem;
  line-height: 1;
  letter-spacing: -.02em;
  background: linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.04));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.method-card__icon{
  width: 44px; height: 44px;
  display: grid; place-items:center;
  border-radius: 12px;
  background: var(--on-grad);
  color:#fff;
  font-size: 1.05rem;
  box-shadow: 0 12px 26px -12px rgba(34,211,238,.55);
  position: relative;
  z-index: 1;
}
.method-card__title{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.12rem;
  line-height: 1.25;
  color: #fff;
  margin: 0 0 8px;
  letter-spacing:-.005em;
  position: relative;
  z-index: 1;
}
.method-card__desc{
  font-size: .88rem;
  line-height: 1.6;
  color: rgba(255,255,255,.68);
  margin: 0 0 18px;
  position: relative;
  z-index: 1;
}
.method-card__deliverable{
  display:inline-flex; align-items:center; gap:7px;
  padding: 5px 11px;
  border-radius: 999px;
  background: rgba(16,185,129,.10);
  border: 1px solid rgba(16,185,129,.25);
  color: var(--on-emerald-2);
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  position: relative;
  z-index: 1;
}
.method-card__deliverable i{ font-size: .7rem; }

/* ================================================================
   5. KANON (LIGHT) - 4 numerowane karty wartości
   ================================================================ */
.kanon-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.kanon-card{
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 22px;
  align-items: start;
  padding: 28px 28px 26px;
  background: #FFFFFF;
  border:1px solid var(--line-l);
  border-radius: 18px;
  transition: all .35s;
  overflow: hidden;
}
.kanon-card::before{
  content:'';
  position:absolute; top:0; left:0; bottom:0;
  width: 4px;
  background: linear-gradient(180deg, var(--on-cyan), var(--on-emerald));
  transform: scaleY(0);
  transform-origin:top;
  transition: transform .5s ease;
}
.kanon-card:hover{
  transform: translateY(-3px);
  border-color: var(--on-emerald);
  box-shadow: 0 26px 60px -28px rgba(16,185,129,.32);
}
.kanon-card:hover::before{ transform: scaleY(1); }

.kanon-card__num{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 800;
  font-size: 3rem;
  line-height: 1;
  letter-spacing: -.04em;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--on-indigo);
  font-style: italic;
  flex-shrink: 0;
  width: 56px;
}
.kanon-card__body{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.kanon-card__icon{
  width: 42px; height: 42px;
  display: grid; place-items:center;
  border-radius: 11px;
  background: linear-gradient(135deg, rgba(34,211,238,.10), rgba(16,185,129,.10));
  border: 1px solid rgba(34,211,238,.22);
  color: var(--on-indigo);
  font-size: 1rem;
}
.kanon-card__title{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.18rem;
  line-height: 1.25;
  color: var(--ink);
  margin: 4px 0 0;
  letter-spacing:-.005em;
}
.kanon-card__desc{
  font-size: .94rem;
  line-height: 1.6;
  color: var(--muted-l);
  margin: 0;
}

/* ================================================================
   6. FACT GRID (DARK) - 4 dossier-style cards
   ================================================================ */
.fact-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.fact-card{
  position: relative;
  padding: 24px 22px 22px;
  background: linear-gradient(160deg, rgba(15,23,42,.85), rgba(11,17,32,.95));
  border: 1px solid var(--on-line);
  border-radius: 16px;
  display: flex; flex-direction: column; gap: 6px;
  transition: all .35s;
  overflow: hidden;
}
.fact-card::before{
  content:'';
  position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, var(--on-indigo), var(--on-cyan), var(--on-emerald));
  background-size: 200% 100%;
  animation: onGradShift 8s ease-in-out infinite;
  opacity: .55;
}
.fact-card:hover{
  transform: translateY(-3px);
  border-color: rgba(34,211,238,.32);
  box-shadow: 0 24px 50px -24px rgba(5,7,20,.7);
}
.fact-card__label{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--on-cyan-2);
  font-weight: 600;
  margin-bottom: 6px;
}
.fact-card__label i{ font-size: .8rem; }
.fact-card__value{
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.18rem;
  line-height: 1.3;
  color: #fff;
  letter-spacing:-.005em;
}
.fact-card__value a{ color: #fff; transition: color .25s; }
.fact-card__value a:hover{ color: var(--on-cyan-2); }
.fact-card__meta{
  font-family: var(--font-body);
  font-size: .82rem;
  color: rgba(255,255,255,.62);
  line-height: 1.5;
}
.fact-card__meta code{
  font-family: var(--font-mono);
  font-size: .82rem;
  color: var(--on-emerald-2);
  background: rgba(16,185,129,.08);
  padding: 1px 6px;
  border-radius: 4px;
}
.fact-card__link{
  display:inline-flex; align-items:center; gap:6px;
  margin-top: auto;
  padding-top: 12px;
  font-family: var(--font-mono);
  font-size: .78rem;
  color: var(--on-cyan-2);
  border-top: 1px solid rgba(255,255,255,.05);
  transition: gap .25s, color .25s;
}
.fact-card__link:hover{ gap: 10px; color: #fff; }

.fact-card__social{
  display:flex; gap:8px;
  margin-top: 4px;
  margin-bottom: 4px;
}
.fact-card__social a{
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 10px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--on-line);
  color: rgba(255,255,255,.78);
  font-size: .98rem;
  transition: all .3s;
}
.fact-card__social a:hover{
  transform: translateY(-2px);
  background: var(--on-grad);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 12px 24px -10px rgba(34,211,238,.55);
}

/* ================================================================
   7. MAPA (LIGHT)
   ================================================================ */
.onas-mapsec{ padding-bottom: 80px !important; }
.onas-map{
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--line-l);
  box-shadow: 0 26px 60px -28px rgba(11,18,32,.18);
  background: #FFFFFF;
}
.onas-map__frame iframe{
  display: block;
  filter: grayscale(.35) contrast(1.05);
  transition: filter .4s;
}
.onas-map:hover .onas-map__frame iframe{ filter: grayscale(0) contrast(1); }

.onas-map__card{
  position: absolute;
  top: 32px; left: 32px;
  width: 320px;
  padding: 22px 22px 20px;
  background: #FFFFFF;
  border: 1px solid var(--line-l);
  border-radius: 16px;
  box-shadow: 0 30px 60px -22px rgba(11,18,32,.30);
}
.onas-map__pin{
  position: absolute;
  top: -18px; right: -18px;
  width: 48px; height: 48px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--on-grad);
  color: #fff;
  font-size: 1.05rem;
  box-shadow: 0 14px 30px -10px rgba(34,211,238,.55);
  animation: onMapPin 2.4s ease-in-out infinite;
}
@keyframes onMapPin{
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-6px); }
}
.onas-map__card strong{
  display:block;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.18rem;
  color: var(--ink);
  margin-bottom: 6px;
}
.onas-map__card p{
  font-size: .94rem;
  line-height: 1.55;
  color: var(--muted-l);
  margin: 0 0 14px;
}
.onas-map__coords{
  display:flex; gap:14px;
  margin-bottom: 14px;
  padding: 10px 12px;
  background: var(--light-1);
  border-radius: 10px;
}
.onas-map__coords span{
  display:inline-flex; align-items:center; gap:6px;
  font-family: var(--font-mono);
  font-size: .78rem;
  color: var(--ink-soft);
}
.onas-map__coords span i{
  font-size: .68rem;
  color: var(--on-cyan);
}
.onas-map__nav{
  display:inline-flex; align-items:center; gap:8px;
  padding: 11px 18px;
  border-radius: 12px;
  background: var(--on-grad);
  color: #fff !important;
  font-weight: 600;
  font-size: .9rem;
  transition: filter .3s, transform .3s, box-shadow .3s;
  box-shadow: 0 12px 26px -10px rgba(34,211,238,.55);
}
.onas-map__nav:hover{
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: 0 16px 32px -12px rgba(34,211,228,.65);
}

/* ================================================================
   8. KONTAKT - wzmocnienie standardowego ncontact
   ================================================================ */
.neural-page--onas .neural-section--contact .ncontact::before{
  background: linear-gradient(90deg, var(--on-indigo), var(--on-cyan), var(--on-emerald)) !important;
}

/* --- 8a. Select wrapper (custom chevron + focus state) --- */
.neural-page--onas .ncontact__select{
  position: relative;
  display: block;
}
.neural-page--onas .ncontact__select::after{
  content: "";
  position: absolute;
  right: 18px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--on-indigo);
  border-bottom: 2px solid var(--on-indigo);
  transform: translateY(-70%) rotate(45deg);
  pointer-events: none;
  transition: transform .3s, border-color .3s;
}
.neural-page--onas .ncontact__select:hover::after{
  border-color: var(--on-cyan);
}
.neural-page--onas .ncontact__select select{
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 14px 44px 14px 18px;
  font-family: var(--font-body);
  font-size: .96rem;
  line-height: 1.4;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line-l);
  border-radius: 12px;
  box-shadow: 0 1px 0 rgba(15,23,42,.02);
  cursor: pointer;
  transition: border-color .25s, box-shadow .25s, background .25s;
}
.neural-page--onas .ncontact__select select:hover{
  border-color: rgba(79,70,229,.45);
}
.neural-page--onas .ncontact__select select:focus{
  outline: none;
  border-color: var(--on-indigo);
  box-shadow:
    0 0 0 4px rgba(79,70,229,.10),
    0 1px 0 rgba(15,23,42,.02);
}
.neural-page--onas .ncontact__select select:focus + ::after,
.neural-page--onas .ncontact__select:focus-within::after{
  transform: translateY(-30%) rotate(-135deg);
  border-color: var(--on-indigo);
}
.neural-page--onas .ncontact__select select option{
  font-family: var(--font-body);
  color: var(--ink);
  background: #fff;
}
.neural-page--onas .ncontact__select select:invalid,
.neural-page--onas .ncontact__select select option[value=""]{
  color: var(--muted-l);
}

/* --- 8b. ncontact__info aside (social, list, badges) --- */
.neural-page--onas .ncontact__info{
  padding: 32px 28px !important;
  background:
    linear-gradient(180deg, rgba(79,70,229,.06), rgba(34,211,238,.04) 60%, rgba(16,185,129,.05)) !important;
  border: 1px solid rgba(79,70,229,.12) !important;
  border-radius: 18px !important;
  position: relative;
  overflow: hidden;
}
.neural-page--onas .ncontact__info::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--on-indigo), var(--on-cyan), var(--on-emerald));
  opacity: .85;
}

/* - list (ul.contact-info__list li) - */
.neural-page--onas .ncontact__info .contact-info__list{
  list-style: none;
  padding: 0;
  margin: 4px 0 6px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.neural-page--onas .ncontact__info .contact-info__list li{
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: .92rem;
  color: var(--ink);
  line-height: 1.5;
}
.neural-page--onas .ncontact__info .contact-info__list li i{
  width: 36px; height: 36px;
  display: grid; place-items: center;
  flex-shrink: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(79,70,229,.10), rgba(34,211,238,.10));
  color: var(--on-indigo);
  font-size: .94rem;
  border: 1px solid rgba(79,70,229,.10);
}
.neural-page--onas .ncontact__info .contact-info__list li a{
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px dashed rgba(79,70,229,.22);
  padding-bottom: 1px;
  transition: color .25s, border-color .25s;
}
.neural-page--onas .ncontact__info .contact-info__list li a:hover{
  color: var(--on-indigo);
  border-color: var(--on-indigo);
}

/* - social - */
.neural-page--onas .ncontact__info .contact-info__social{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
  padding-top: 18px;
  border-top: 1px solid rgba(79,70,229,.10);
}
.neural-page--onas .ncontact__info .contact-info__social a{
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: #FFFFFF;
  border: 1px solid rgba(15,23,42,.08);
  color: var(--ink);
  font-size: 1.02rem;
  text-decoration: none;
  transition: transform .3s, color .3s, background .3s, border-color .3s, box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.neural-page--onas .ncontact__info .contact-info__social a::before{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--on-indigo), var(--on-cyan));
  opacity: 0;
  transition: opacity .3s;
  z-index: 0;
}
.neural-page--onas .ncontact__info .contact-info__social a i{
  position: relative;
  z-index: 1;
}
.neural-page--onas .ncontact__info .contact-info__social a:hover{
  transform: translateY(-3px);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 14px 28px -10px rgba(79,70,229,.45);
}
.neural-page--onas .ncontact__info .contact-info__social a:hover::before{
  opacity: 1;
}

/* - badges - */
.neural-page--onas .ncontact__info .ncontact__badges{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(79,70,229,.10);
}
.neural-page--onas .ncontact__info .ncontact__badge{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 12px;
  background: #FFFFFF;
  border: 1px solid rgba(79,70,229,.10);
  font-family: var(--font-body);
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  transition: border-color .25s, transform .25s, box-shadow .25s;
}
.neural-page--onas .ncontact__info .ncontact__badge i{
  width: 30px; height: 30px;
  display: grid; place-items: center;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--on-indigo), var(--on-cyan));
  color: #fff;
  font-size: .82rem;
  flex-shrink: 0;
}
.neural-page--onas .ncontact__info .ncontact__badge:hover{
  transform: translateY(-2px);
  border-color: rgba(79,70,229,.32);
  box-shadow: 0 12px 24px -12px rgba(79,70,229,.22);
}
@media (max-width: 480px){
  .neural-page--onas .ncontact__info .ncontact__badges{ grid-template-columns: 1fr; }
}

/* ================================================================
   9. RESPONSIVE
   ================================================================ */
@media (max-width: 1100px){
  .nhero--onas .nhero__inner{
    grid-template-columns: 1fr;
    gap: 60px;
  }
  .nhero--onas .nhero__right{ min-height: 0; }
  .dossier{ max-width: 520px; }
  .dossier__panel{
    transform: perspective(1400px) rotateY(0) rotateX(0);
    animation: none;
  }
  .nhero--onas .nhero__bullets{ grid-template-columns: 1fr; }

  .neural-page--onas .manifest-grid{
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .manifest-stats{
    position: static;
    grid-template-columns: repeat(2,1fr);
  }

  .method-grid{ grid-template-columns: repeat(2, 1fr); }
  .fact-grid{   grid-template-columns: repeat(2, 1fr); }

  .onas-map__card{
    position: relative;
    top: 0; left: 0;
    width: auto;
    margin: -60px 18px 18px;
    z-index: 2;
  }
}

@media (max-width: 720px){
  .nhero--onas{ padding: 130px 0 80px; }
  .nhero--onas .nhero__title{ font-size: clamp(2rem, 8vw, 2.6rem); }
  .dossier__id{ flex-direction: column; align-items: flex-start; }
  .dossier__kpis{ grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .dossier__kpi-val{ font-size: 1.4rem; }
  .dossier__badge--1{ left: 0; top: 8px; }
  .dossier__badge--2{ right: 0; bottom: 16px; }

  .method-grid{ grid-template-columns: 1fr; }
  .kanon-grid{  grid-template-columns: 1fr; }
  .fact-grid{   grid-template-columns: 1fr; }

  .kanon-card{ grid-template-columns: 1fr; gap: 14px; }
  .kanon-card__num{ font-size: 2.4rem; width: auto; }

  .manifest-stats{ grid-template-columns: 1fr; }

  .manifest-text__dropcap{ font-size: 4.4rem; }
}
