/* ============================================================
   PMT-AI — „Neon Control Room" design system
   Ładowany PO bootstrap.min.css (nadpisuje motyw BS)
   ============================================================ */

:root{
  /* Kolory bazowe */
  --bg:#070B14;
  --surface:#0E1626;
  --surface-alt:#131F33;
  --text-primary:#EAF2FF;
  --text-muted:#8CA0C0;

  /* Akcenty */
  --accent:#22E6D2;          /* cyan — magistrala CAN */
  --accent-2:#7C5CFF;        /* violet — AI */
  --success:#A6F135;         /* lime — plug&play / diody OK */
  --border:#26344D;

  /* Gradienty */
  --grad-from:#22E6D2;
  --grad-to:#7C5CFF;
  --grad-primary:linear-gradient(135deg,var(--grad-from),var(--grad-to));
  --grad-card:linear-gradient(160deg,rgba(19,31,51,.55),rgba(14,22,38,.35));
  --grad-line:linear-gradient(90deg,var(--accent),transparent);

  /* Alpha akcentów */
  --accent-a10:rgba(34,230,210,.10);
  --accent-a35:rgba(34,230,210,.35);
  --accent2-a12:rgba(124,92,255,.12);
  --accent2-a40:rgba(124,92,255,.40);
  --success-a15:rgba(166,241,53,.15);
  --success-a40:rgba(166,241,53,.40);

  /* Typografia */
  --font-head:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --tracking-head:-.02em;
  --tracking-mono:.08em;

  /* Promienie */
  --r-sm:8px;
  --r-btn:12px;
  --r-card:18px;
  --r-pill:999px;

  /* Cienie / poświaty */
  --shadow-card:0 8px 40px rgba(0,0,0,.45);
  --shadow-nav:0 4px 24px rgba(0,0,0,.40);
  --glow-btn:0 0 0 1px var(--accent2-a40),0 8px 24px rgba(34,230,210,.25);
  --glow-accent:0 0 6px var(--accent);
  --glow-dot:0 0 8px currentColor;

  /* Layout */
  --section-y:96px;
  --container-max:1200px;

  /* Motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);
  --dur-fast:200ms;
  --dur-reveal:500ms;
}
@media (max-width:768px){ :root{ --section-y:56px; } }

/* ---------- Base ---------- */
html{ scroll-behavior:smooth; position:relative; min-height:100%; }
body.pmt-body{
  background:var(--bg);
  color:var(--text-primary);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  margin:0;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4,.h1,.h2,.h3{ font-family:var(--font-head); letter-spacing:var(--tracking-head); line-height:1.08; font-weight:700; }
a{ color:var(--accent); text-decoration:none; }
a:hover{ color:var(--text-primary); }
.mono{ font-family:var(--font-mono); letter-spacing:var(--tracking-mono); }
.pmt-body .text-muted{ color:var(--text-muted) !important; }

/* ---------- Tło ---------- */
.pmt-bg{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(38,52,77,.35) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(38,52,77,.35) 39px 40px);
  opacity:.5;
}
.pmt-bg::before,.pmt-bg::after{
  content:""; position:absolute; border-radius:50%; filter:blur(120px); opacity:.14;
}
.pmt-bg::before{ width:52vw; height:52vw; top:-10vw; right:-8vw; background:radial-gradient(circle,var(--accent),transparent 65%); }
.pmt-bg::after{ width:46vw; height:46vw; bottom:-12vw; left:-10vw; background:radial-gradient(circle,var(--accent-2),transparent 65%); }

/* ---------- Kontener / sekcje ---------- */
.pmt-container{ max-width:var(--container-max); margin-inline:auto; padding-inline:clamp(16px,4vw,24px); }
.pmt-section{ position:relative; padding-block:var(--section-y); }
.pmt-section--alt{ background:var(--surface); }
.pmt-section--line::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:var(--grad-line); opacity:.5;
}
.eyebrow{
  font-family:var(--font-mono); text-transform:uppercase; letter-spacing:var(--tracking-mono);
  color:var(--accent); font-size:.8rem; font-weight:500; display:inline-flex; align-items:center; gap:.55rem;
}
.eyebrow::before{ content:""; width:22px; height:1px; background:var(--accent); display:inline-block; }
.section-title{ font-size:clamp(1.9rem,3.6vw,2.7rem); margin-top:.6rem; }
.section-lead{ color:var(--text-muted); max-width:60ch; font-size:1.075rem; }

/* ---------- Navbar ---------- */
.pmt-navbar{
  position:sticky; top:0; z-index:1000;
  background:rgba(7,11,20,.72); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition:background var(--dur-fast) ease, box-shadow var(--dur-fast) ease;
}
.pmt-navbar.is-scrolled{ background:rgba(7,11,20,.92); box-shadow:var(--shadow-nav); }
.pmt-navbar .pmt-container{ display:flex; align-items:center; gap:1rem; height:68px; }
.pmt-brand{ font-family:var(--font-head); font-weight:700; font-size:1.25rem; color:var(--text-primary); display:inline-flex; align-items:center; gap:.5rem; }
.pmt-brand:hover{ color:var(--text-primary); }
.pmt-brand .dot{ width:11px; height:11px; border-radius:50%; background:var(--grad-primary); box-shadow:0 0 10px var(--accent); }
.pmt-nav{ display:flex; align-items:center; gap:.25rem; margin-left:auto; }
.pmt-nav .nav-link{
  font-family:var(--font-body); font-weight:500; font-size:.98rem; color:var(--text-muted);
  padding:.5rem .85rem; border-radius:var(--r-pill); position:relative; transition:color var(--dur-fast) ease, background var(--dur-fast) ease;
}
.pmt-nav .nav-link:hover{ color:var(--text-primary); background:var(--accent2-a12); }
.pmt-nav .nav-link.active{ color:var(--accent); }
.pmt-nav .nav-admin{ color:var(--text-muted); font-size:.85rem; opacity:.75; }

/* Hamburger */
.pmt-burger{ margin-left:auto; display:none; background:none; border:1px solid var(--border); border-radius:var(--r-sm); width:44px; height:40px; color:var(--text-primary); align-items:center; justify-content:center; }
@media (max-width:900px){
  .pmt-burger{ display:inline-flex; }
  .pmt-nav{
    position:fixed; inset:68px 0 auto 0; flex-direction:column; align-items:stretch; gap:.35rem; margin:0;
    padding:1rem clamp(16px,4vw,24px) 1.5rem; background:rgba(10,17,32,.97); backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border); transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:opacity var(--dur-fast) ease, transform var(--dur-fast) ease;
  }
  .pmt-nav.open{ opacity:1; transform:translateY(0); pointer-events:auto; }
  .pmt-nav .nav-link{ padding:.85rem 1rem; font-size:1.05rem; }
}

/* ---------- Przyciski ---------- */
.btn-glow,.btn-ghost{
  display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-head); font-weight:600;
  border-radius:var(--r-btn); padding:.85rem 1.5rem; font-size:1rem; cursor:pointer; border:1px solid transparent;
  transition:transform var(--dur-fast) ease, box-shadow var(--dur-fast) ease, background var(--dur-fast) ease, border-color var(--dur-fast) ease;
}
.btn-glow{ background:var(--grad-primary); color:#070B14; box-shadow:var(--glow-btn); }
.btn-glow:hover{ color:#070B14; transform:scale(1.02); box-shadow:0 0 0 1px var(--accent2-a40),0 12px 32px rgba(34,230,210,.4); }
.btn-glow:active{ transform:scale(1); }
.btn-ghost{ background:transparent; border-color:var(--border); color:var(--text-primary); }
.btn-ghost:hover{ color:var(--text-primary); border-color:var(--accent); box-shadow:inset 0 0 0 1px var(--accent-a35), 0 0 18px rgba(34,230,210,.12); }
.btn-sm{ padding:.5rem .95rem; font-size:.9rem; }
:where(.btn-glow,.btn-ghost,.nav-link,a,button):focus-visible{ outline:3px solid var(--accent2-a40); outline-offset:2px; }

/* ---------- Karty ---------- */
.pmt-card{
  position:relative; background:var(--grad-card); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1px solid var(--border); border-radius:var(--r-card); box-shadow:var(--shadow-card);
  padding:26px; height:100%; overflow:hidden;
  transition:transform 250ms var(--ease-out), box-shadow 250ms var(--ease-out);
}
.pmt-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px; background:var(--grad-primary);
  opacity:0; transition:opacity 250ms ease;
}
.pmt-card:hover{ transform:translateY(-4px); box-shadow:0 16px 50px rgba(0,0,0,.5),0 0 24px rgba(34,230,210,.08); }
.pmt-card:hover::before{ opacity:1; }
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .pmt-card{ background:var(--surface-alt); }
}

/* Karta modułu */
.pmt-card--module{ display:flex; flex-direction:column; gap:.75rem; }
.module-head{ display:flex; align-items:center; justify-content:space-between; gap:.5rem; }
.module-code{ font-family:var(--font-mono); letter-spacing:var(--tracking-mono); text-transform:uppercase; color:var(--accent); font-size:.82rem; }
.module-name{ font-family:var(--font-head); font-size:1.15rem; font-weight:600; margin:0; }
.module-desc{ color:var(--text-muted); font-size:.95rem; margin:0; flex:1; }
.module-chips{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:.35rem; }

/* Pusty slot „dołóż moduł" */
.module-slot--empty{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem; min-height:180px;
  border:1.5px dashed var(--border); border-radius:var(--r-card); color:var(--text-muted);
  font-family:var(--font-mono); font-size:.8rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  transition:border-color var(--dur-fast) ease, color var(--dur-fast) ease, box-shadow var(--dur-fast) ease;
}
.module-slot--empty .plus{ font-size:2rem; line-height:1; color:var(--accent); }
.module-slot--empty:hover{ border-color:var(--accent); color:var(--text-primary); box-shadow:0 0 24px rgba(34,230,210,.12); }

/* ---------- Diody / chipy ---------- */
.status-dot{ width:9px; height:9px; border-radius:50%; display:inline-block; box-shadow:var(--glow-dot); }
.status-dot--ok{ color:var(--success); background:var(--success); }
.status-dot--new{ color:var(--accent-2); background:var(--accent-2); }
.status-dot--warn{ color:var(--accent); background:var(--accent); }
.status-pulse{ animation:pulse 2s ease-in-out infinite; }

.cap-chip{
  display:inline-flex; align-items:center; gap:.4rem; padding:4px 12px; border-radius:var(--r-pill);
  background:var(--accent-a10); border:1px solid var(--accent-a35); color:var(--accent);
  font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
}
.cap-chip::before{ content:""; width:6px; height:6px; border-radius:50%; background:currentColor; box-shadow:var(--glow-dot); }
.cap-chip--pnp{ background:var(--success-a15); border-color:var(--success-a40); color:var(--success); }
.cap-chip--ai{ background:var(--accent2-a12); border-color:var(--accent2-a40); color:var(--accent-2); }
.cap-chip--selv{ background:var(--accent2-a12); border-color:var(--accent2-a40); color:var(--accent-2); }

/* Status badge (etap modułu) */
.status-badge{
  display:inline-flex; align-items:center; gap:.4rem; padding:3px 10px; border-radius:var(--r-pill);
  font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  border:1px solid var(--border); color:var(--text-muted); background:rgba(255,255,255,.02);
}
.status-badge--prod{ color:var(--success); border-color:var(--success-a40); }
.status-badge--design{ color:var(--accent); border-color:var(--accent-a35); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-top:clamp(48px,7vw,96px); padding-bottom:clamp(48px,7vw,110px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,4rem); align-items:center; }
@media (max-width:900px){ .hero-grid{ grid-template-columns:1fr; } }
.hero h1{ font-size:clamp(2.2rem,6vw,4rem); margin:1rem 0 1.1rem; }
.hero h1 .grad{ background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-sub{ color:var(--text-muted); font-size:clamp(1.05rem,1.6vw,1.25rem); max-width:56ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:.85rem; margin-top:1.8rem; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:1.5rem; margin-top:2.2rem; color:var(--text-muted); font-family:var(--font-mono); font-size:.78rem; letter-spacing:var(--tracking-mono); text-transform:uppercase; }
.hero-meta span{ display:inline-flex; align-items:center; gap:.5rem; }

/* Hero rail (SVG) */
.hero-rail{ width:100%; }
.hero-rail svg{ width:100%; height:auto; display:block; overflow:visible; }
.bus-flow{ stroke-dasharray:8 10; animation:flow 3s linear infinite; }
.ai-bubble-svg{ animation:floaty 6s ease-in-out infinite; }

/* ---------- „Jak to działa" ---------- */
.step-card{ position:relative; }
.step-num{ font-family:var(--font-mono); font-size:2.4rem; font-weight:500; background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.step-icon{ margin:1rem 0 .8rem; color:var(--accent); }
.step-card h3{ font-size:1.2rem; }

/* ---------- AI terminal ---------- */
.ai-terminal{
  background:var(--surface-alt); border:1px solid var(--accent-a35); border-radius:var(--r-card);
  box-shadow:0 0 40px rgba(34,230,210,.08),var(--shadow-card); overflow:hidden; max-width:820px; margin-inline:auto;
}
.ai-terminal-bar{ display:flex; align-items:center; gap:.5rem; padding:.7rem 1rem; border-bottom:1px solid var(--border); background:rgba(0,0,0,.2); }
.ai-terminal-bar .tdot{ width:11px; height:11px; border-radius:50%; }
.ai-terminal-bar .tdot:nth-child(1){ background:#ff5f57; }
.ai-terminal-bar .tdot:nth-child(2){ background:#febc2e; }
.ai-terminal-bar .tdot:nth-child(3){ background:#28c840; }
.ai-terminal-bar .tlabel{ margin-left:.6rem; font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:var(--tracking-mono); color:var(--text-muted); }
.ai-terminal-body{ padding:1.4rem 1.5rem; font-family:var(--font-mono); font-size:.95rem; line-height:1.9; min-height:150px; }
.ai-line{ color:var(--text-muted); }
.ai-line .usr{ color:var(--text-primary); }
.ai-line .ok{ color:var(--success); }
.ai-line .ai{ color:var(--accent); }
.ai-cursor::after{ content:"▋"; color:var(--accent); animation:blink 1s steps(2) infinite; }

/* ---------- Czat konfiguratora ---------- */
.chat-scroll{ max-height:min(52vh,520px); overflow-y:auto; padding:1.4rem 1.5rem; display:flex; flex-direction:column; gap:1rem; }
.chat-msg{ display:flex; gap:.7rem; max-width:88%; }
.chat-msg .who{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--tracking-mono); text-transform:uppercase; padding-top:.2rem; flex:0 0 auto; }
.chat-msg .bubble{ padding:.7rem 1rem; border-radius:14px; line-height:1.5; }
.chat-msg--ai{ align-self:flex-start; }
.chat-msg--ai .who{ color:var(--accent); }
.chat-msg--ai .bubble{ background:var(--surface); border:1px solid var(--border); }
.chat-msg--user{ align-self:flex-end; flex-direction:row-reverse; }
.chat-msg--user .who{ color:var(--text-muted); }
.chat-msg--user .bubble{ background:var(--accent2-a12); border:1px solid var(--accent2-a40); }
.chat-typing{ display:inline-flex; gap:4px; align-items:center; }
.chat-typing span{ width:7px; height:7px; border-radius:50%; background:var(--accent); animation:blink 1.2s infinite; }
.chat-typing span:nth-child(2){ animation-delay:.2s; } .chat-typing span:nth-child(3){ animation-delay:.4s; }
.chat-input{ display:flex; gap:.6rem; padding:1rem 1.2rem; border-top:1px solid var(--border); background:rgba(0,0,0,.2); }
.chat-input input{ flex:1; background:var(--surface); border:1px solid var(--border); color:var(--text-primary); border-radius:var(--r-btn); padding:.75rem 1rem; font-family:var(--font-body); font-size:1rem; }
.chat-input input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-a10); }
.result-mod{ display:flex; align-items:flex-start; gap:1rem; }
.result-qty{ flex:0 0 auto; min-width:44px; height:44px; display:flex; align-items:center; justify-content:center; border-radius:12px; background:var(--grad-primary); color:#070B14; font-family:var(--font-head); font-weight:700; }
.result-note{ display:flex; gap:.6rem; color:var(--text-muted); font-size:.92rem; }
.result-note::before{ content:"›"; color:var(--accent); }

/* ---------- Dla kogo ---------- */
.audience-track{ height:100%; }
.audience-track h3{ display:flex; align-items:center; gap:.6rem; font-size:1.3rem; }
.audience-track--pro h3{ color:var(--accent); }
.audience-track--fan h3{ color:var(--accent-2); }
.audience-list{ list-style:none; padding:0; margin:1rem 0 0; display:flex; flex-direction:column; gap:.7rem; }
.audience-list li{ display:flex; gap:.65rem; color:var(--text-muted); }
.audience-list li::before{ content:""; flex:0 0 7px; height:7px; margin-top:.55rem; border-radius:50%; background:currentColor; }
.audience-track--pro .audience-list li::before{ background:var(--accent); box-shadow:var(--glow-dot); color:var(--accent); }
.audience-track--fan .audience-list li::before{ background:var(--accent-2); box-shadow:0 0 8px var(--accent-2); }

/* ---------- Trust / liczniki ---------- */
.trust-stat{ text-align:center; }
.trust-stat .num{ font-family:var(--font-mono); font-size:clamp(2rem,4vw,2.8rem); font-weight:500; font-variant-numeric:tabular-nums; background:var(--grad-primary); -webkit-background-clip:text; background-clip:text; color:transparent; }
.trust-stat .lbl{ font-family:var(--font-mono); font-size:.75rem; text-transform:uppercase; letter-spacing:var(--tracking-mono); color:var(--text-muted); margin-top:.35rem; }

/* ---------- Use case tile ---------- */
.usecase-tile{ text-align:left; }
.usecase-tile .uc-icon{ color:var(--accent); margin-bottom:1rem; }
.usecase-tile h3{ font-size:1.2rem; }
.usecase-tile .uc-mods{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:var(--tracking-mono); color:var(--text-muted); text-transform:uppercase; margin-top:.6rem; }

/* ---------- CTA band ---------- */
.cta-band{ text-align:center; position:relative; border-radius:24px; padding:clamp(2.5rem,6vw,4.5rem); background:var(--grad-card); border:1px solid var(--border); overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(600px circle at 50% -20%,rgba(34,230,210,.18),transparent 70%); pointer-events:none; }
.cta-band h2{ font-size:clamp(1.8rem,4vw,2.8rem); position:relative; }

/* ---------- Footer ---------- */
.pmt-footer{ background:var(--surface); border-top:1px solid var(--border); position:relative; padding-block:3rem 2rem; }
.pmt-footer::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:var(--grad-line); opacity:.4; }
.pmt-footer a{ color:var(--text-muted); }
.pmt-footer a:hover{ color:var(--accent); }
.pmt-footer .foot-brand{ font-family:var(--font-head); font-weight:700; color:var(--text-primary); font-size:1.15rem; }
.pmt-footer .foot-copy{ font-family:var(--font-mono); font-size:.75rem; letter-spacing:.04em; color:var(--text-muted); }

/* ---------- Breadcrumb / detail ---------- */
.pmt-breadcrumb{ font-family:var(--font-mono); font-size:.8rem; letter-spacing:var(--tracking-mono); text-transform:uppercase; color:var(--text-muted); display:flex; gap:.6rem; align-items:center; }
.pmt-breadcrumb a{ color:var(--text-muted); }
.pmt-breadcrumb a:hover{ color:var(--accent); }
.spec-group{ margin-top:1.8rem; }
.spec-group h5{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:var(--tracking-mono); font-size:.85rem; color:var(--accent); }
.spec-table{ width:100%; border-collapse:collapse; }
.spec-table th,.spec-table td{ padding:.7rem .9rem; border-bottom:1px solid var(--border); text-align:left; vertical-align:top; }
.spec-table th{ width:38%; color:var(--text-muted); font-weight:500; }
.spec-table td{ font-variant-numeric:tabular-nums; }

/* ---------- Admin (czytelne tabele na ciemnym) ---------- */
.pmt-body .table{ color:var(--text-primary); border-color:var(--border); }
.pmt-body .table > :not(caption) > * > *{ background:transparent; border-color:var(--border); color:var(--text-primary); }
.pmt-body .table thead th{ color:var(--text-muted); font-family:var(--font-mono); font-size:.78rem; text-transform:uppercase; letter-spacing:var(--tracking-mono); }
.pmt-body .table-hover > tbody > tr:hover > *{ background:var(--accent2-a12); }
.pmt-body .form-control,.pmt-body .form-select{ background:var(--surface-alt); border:1px solid var(--border); color:var(--text-primary); }
.pmt-body .form-control:focus,.pmt-body .form-select:focus{ background:var(--surface-alt); border-color:var(--accent); color:var(--text-primary); box-shadow:0 0 0 3px var(--accent-a10); }
.pmt-body .form-control::placeholder{ color:#5f7290; }
.pmt-body .form-label{ color:var(--text-muted); font-size:.9rem; }
.pmt-body .breadcrumb{ --bs-breadcrumb-divider-color:var(--text-muted); }
.pmt-body .breadcrumb-item.active{ color:var(--text-muted); }
.admin-shell{ padding-block:2.5rem; }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(24px); }
.reveal.is-visible{ opacity:1; transform:translateY(0); transition:opacity var(--dur-reveal) var(--ease-out), transform var(--dur-reveal) var(--ease-out); transition-delay:calc(var(--i,0) * 60ms); }

/* SVG diody */
.svg-pulse{ animation:svgpulse 2s ease-in-out infinite; }
@keyframes svgpulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

/* ---------- Keyframes ---------- */
@keyframes flow{ to{ stroke-dashoffset:-36; } }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 4px currentColor; } 50%{ box-shadow:0 0 14px currentColor,0 0 22px currentColor; } }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
@keyframes blink{ 0%,50%{ opacity:1; } 50.01%,100%{ opacity:0; } }

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* ===== Panel ===== */
/* Panel sterowników: karty instalacji, badge online/offline, formularze logowania. */

.panel-card{ display:flex; flex-direction:column; gap:.75rem; }
.panel-card:hover{ transform:none; }
.panel-card__head{ display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; }
.panel-card__meta{
  display:flex; flex-wrap:wrap; gap:1.25rem; color:var(--text-muted);
  font-size:.78rem; letter-spacing:var(--tracking-mono);
}

.online-badge{
  display:inline-flex; align-items:center; gap:.45rem; padding:4px 12px; border-radius:var(--r-pill);
  font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  border:1px solid var(--border); white-space:nowrap;
}
.online-badge::before{ content:""; width:7px; height:7px; border-radius:50%; background:currentColor; box-shadow:var(--glow-dot); }
.online-badge--on{ background:var(--success-a15); border-color:var(--success-a40); color:var(--success); }
.online-badge--off{ background:transparent; color:var(--text-muted); }

/* Komunikaty (TempData) */
.panel-alert{
  padding:.85rem 1.15rem; border-radius:var(--r-sm); border:1px solid var(--border);
  background:var(--surface); font-size:.95rem;
}
.panel-alert--success{ border-color:var(--success-a40); background:var(--success-a15); color:var(--success); }
.panel-alert--error{ border-color:rgba(255,92,124,.4); background:rgba(255,92,124,.12); color:#FF5C7C; }

/* Karta logowania/rejestracji */
.auth-card{ max-width:440px; margin:0 auto; }
.auth-card:hover{ transform:none; }
.auth-title{ font-size:1.6rem; margin-bottom:.25rem; }
.auth-sub{ font-size:.95rem; margin-bottom:1.5rem; }
.auth-alt{ font-size:.9rem; margin:1.25rem 0 0; text-align:center; }
.auth-alt a{ color:var(--accent); }

/* Użytkownik w nawigacji */
.nav-user{ color:var(--text-muted); font-size:.8rem; letter-spacing:var(--tracking-mono); }

/* ---------- Pulpit instalacji (Panel/Installations/Details) ---------- */
.panel-module-head{
  font-size:.85rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  color:var(--text-muted); border-bottom:1px solid var(--border); padding-bottom:.4rem; margin-bottom:.9rem;
}
.point-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(170px, 1fr)); gap:.85rem; }
.point-tile{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-sm);
  padding:.75rem .9rem; display:flex; flex-direction:column; gap:.5rem;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.point-tile__head{ display:flex; align-items:center; justify-content:space-between; gap:.5rem; }
.point-tile__name{ font-size:.72rem; letter-spacing:var(--tracking-mono); color:var(--text-muted); text-transform:uppercase; }
.point-tile__history{
  background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:.85rem;
  padding:0; line-height:1; opacity:.6;
}
.point-tile__history:hover{ opacity:1; color:var(--accent); }
.point-tile__value{ font-family:var(--font-mono); font-size:1.35rem; font-weight:500; }
.point-tile__ctl .form-control{ background:rgba(255,255,255,.04); border-color:var(--border); color:inherit; }

/* Jakość punktu (q z telemetrii) */
.point-tile.q-good .point-tile__value{ color:var(--success, #7CFFB2); }
.point-tile.q-stale .point-tile__value{ color:var(--text-muted); }
.point-tile.q-stale{ border-style:dashed; }
.point-tile.q-fault{ border-color:rgba(255,92,124,.55); }
.point-tile.q-fault .point-tile__value{ color:#FF5C7C; }
.point-tile.q-override .point-tile__value{ color:#C9A6FF; }

/* Miganie po zapisie */
@keyframes tileOk{ 0%{ box-shadow:0 0 0 0 var(--success-a40);} 100%{ box-shadow:0 0 0 12px transparent;} }
@keyframes tileErr{ 0%{ box-shadow:0 0 0 0 rgba(255,92,124,.5);} 100%{ box-shadow:0 0 0 12px transparent;} }
.point-tile--ok{ animation:tileOk .8s ease-out; }
.point-tile--err{ animation:tileErr .8s ease-out; border-color:rgba(255,92,124,.55); }

/* Feed zdarzeń */
.evt-feed{ list-style:none; margin:0; padding:0; max-height:340px; overflow-y:auto; font-size:.78rem; }
.evt-feed li{ padding:.35rem 0; border-bottom:1px dashed var(--border); }
.evt-feed__item--critical{ color:#FF5C7C; }
.evt-feed__empty{ border-bottom:none !important; }

/* Modal panelu (potwierdzenia, historia) */
.panel-modal{
  position:fixed; inset:0; z-index:1050; display:flex; align-items:center; justify-content:center;
  background:rgba(4,8,16,.72); backdrop-filter:blur(4px);
}
.panel-modal[hidden]{ display:none; }
.panel-modal__box{ max-width:480px; width:calc(100% - 2rem); }
.panel-modal__box:hover{ transform:none; }

/* ===== Programy / Test demo (cykl życia programów) ===== */

/* Badge statusu wersji programu */
.prog-badge{
  display:inline-block; padding:.15rem .55rem; border:1px solid var(--border); border-radius:999px;
  font-family:var(--font-mono, monospace); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase;
  white-space:nowrap;
}
.prog-badge--draft{ color:var(--text-muted); }
.prog-badge--validated{ color:var(--accent, #6EE7FF); border-color:var(--accent-a35, rgba(110,231,255,.35)); }
.prog-badge--simulated{ color:#C9A6FF; border-color:rgba(201,166,255,.4); }
.prog-badge--approved, .prog-badge--demoapproved{ color:var(--success, #7CFFB2); border-color:var(--success-a40, rgba(124,255,178,.4)); }
.prog-badge--deployed{ color:var(--success, #7CFFB2); border-color:var(--success-a40, rgba(124,255,178,.4)); background:var(--success-a15, rgba(124,255,178,.12)); }
.prog-badge--rolledback{ color:#FFC46B; border-color:rgba(255,196,107,.4); }
.prog-badge--failed{ color:#FF5C7C; border-color:rgba(255,92,124,.45); }

/* Diff porównania wersji */
.diff-added{ color:var(--success, #7CFFB2); border-color:var(--success-a40, rgba(124,255,178,.4)); }
.diff-removed{ color:#FF5C7C; border-color:rgba(255,92,124,.45); }
.diff-changed{ color:#FFC46B; border-color:rgba(255,196,107,.4); }

/* Aktywna wersja na liście */
.prog-active-dot{ color:var(--success, #7CFFB2); }
.prog-row--active td{ background:var(--success-a15, rgba(124,255,178,.06)) !important; }

/* Wejścia symulacji (Test demo) */
.sim-input{
  border:1px solid var(--border); border-radius:12px; padding:.6rem .75rem;
  background:rgba(255,255,255,.02);
}
.sim-input--stale{ border-style:dashed; opacity:.75; }
.sim-input__name{ font-size:.78rem; }
.sim-input__value{ font-size:.9rem; color:var(--success, #7CFFB2); }
.sim-input__num{ max-width:110px; background:rgba(255,255,255,.04); border-color:var(--border); color:inherit; }
.sim-input__slider{ flex:1; }
.sim-stale{ font-size:.7rem; color:var(--text-muted); display:flex; align-items:center; gap:.3rem; }

/* Prędkość symulacji */
.sim-speed--active{ background:var(--accent-a35, rgba(110,231,255,.25)) !important; border-color:var(--accent, #6EE7FF) !important; }

/* Oś czasu symulacji */
.sim-timeline{ max-height:320px; overflow-y:auto; border:1px solid var(--border); border-radius:12px; }
.sim-timeline table{ margin-bottom:0; }

/* Wyniki scenariuszy */
.sim-scenario{ padding:.3rem 0; border-bottom:1px dashed var(--border); }
.sim-scenario--pass{ color:var(--success, #7CFFB2); }
.sim-scenario--fail{ color:#FF5C7C; }

/* Strefa niebezpieczna */
.sim-danger-zone{ border-color:rgba(255,92,124,.35); }

/* ===== Programowanie z AI (Chat) ===== */
.aichat-transcript-card{ min-height:60vh; }
.aichat-transcript{
  flex:1; min-height:44vh; max-height:62vh; overflow-y:auto;
  display:flex; flex-direction:column; gap:.6rem; padding-right:.35rem;
}
.aichat-msg{
  border:1px solid var(--border); border-radius:14px; padding:.6rem .85rem;
  max-width:88%; font-size:.92rem; line-height:1.45; white-space:pre-wrap; word-break:break-word;
}
.aichat-msg--user{
  align-self:flex-end; background:var(--accent-a15, rgba(110,231,255,.08));
  border-color:var(--accent-a35, rgba(110,231,255,.3));
}
.aichat-msg--ai{ align-self:flex-start; background:rgba(255,255,255,.03); }
.aichat-msg--system{
  align-self:center; text-align:center; color:var(--text-muted);
  font-size:.8rem; border-style:dashed; background:transparent; max-width:95%;
}
.aichat-msg--report{ align-self:stretch; max-width:100%; font-size:.82rem; }
.aichat-msg--report ul{ margin:.35rem 0 0; padding-left:1.1rem; }
.aichat-msg--ok{ border-color:var(--success-a40, rgba(124,255,178,.4)); }
.aichat-msg--bad{ border-color:rgba(255,92,124,.45); }
.aichat-inputrow{ display:flex; gap:.6rem; margin-top:.75rem; align-items:flex-end; }
.aichat-inputrow textarea{
  background:rgba(255,255,255,.04); border-color:var(--border); color:inherit; resize:vertical;
}

/* Stepper faz */
.aichat-stepper{ list-style:none; margin:0; padding:0; font-size:.78rem; }
.aichat-stepper li{
  padding:.3rem 0 .3rem 1.4rem; position:relative; color:var(--text-muted);
  border-left:1px dashed var(--border); margin-left:.45rem;
}
.aichat-stepper li::before{
  content:""; position:absolute; left:-5px; top:.55rem; width:9px; height:9px;
  border-radius:50%; background:var(--border);
}
.aichat-stepper li.is-done{ color:var(--success, #7CFFB2); }
.aichat-stepper li.is-done::before{ background:var(--success, #7CFFB2); }
.aichat-stepper li.is-current{ color:var(--accent, #6EE7FF); }
.aichat-stepper li.is-current::before{
  background:var(--accent, #6EE7FF); box-shadow:0 0 8px var(--accent-a35, rgba(110,231,255,.4));
}

/* Karta wymagań */
.aichat-card{ font-size:.85rem; }
.aichat-card h3{
  font-size:.72rem; text-transform:uppercase; letter-spacing:.08em;
  color:var(--text-muted); margin:.6rem 0 .25rem;
}
.aichat-card ul{ margin:0; padding-left:1.1rem; }
.aichat-card__open li{ color:#FFC46B; }

/* ============================================================
   Otwarty Symulator (/Symulator) — publiczne demo lead-gen
   ============================================================ */
.pubsim-goal textarea{
  width:100%; background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:12px; color:inherit; padding:.75rem .9rem; resize:vertical;
  font-size:1rem;
}
.pubsim-goal textarea:focus{
  outline:none; border-color:var(--accent);
  box-shadow:inset 0 0 0 1px var(--accent-a35), 0 0 18px rgba(34,230,210,.12);
}

/* Kroki pipeline'u */
.pubsim-steps{
  list-style:none; display:flex; flex-wrap:wrap; gap:.4rem 1.4rem;
  margin:0 0 .8rem; padding:0; font-size:.82rem;
}
.pubsim-steps li{
  position:relative; padding-left:1.25rem; color:var(--text-muted);
  font-family:var(--font-mono); letter-spacing:var(--tracking-mono);
}
.pubsim-steps li::before{
  content:""; position:absolute; left:0; top:.28rem; width:10px; height:10px;
  border-radius:50%; background:var(--border);
}
.pubsim-steps li.pubsim-step--active{ color:var(--accent, #6EE7FF); }
.pubsim-steps li.pubsim-step--active::before{
  background:var(--accent, #6EE7FF); box-shadow:0 0 8px var(--accent-a35, rgba(110,231,255,.4));
  animation:pulse 1.2s ease-in-out infinite;
}
.pubsim-steps li.pubsim-step--done{ color:var(--success, #7CFFB2); }
.pubsim-steps li.pubsim-step--done::before{ background:var(--success, #7CFFB2); }
.pubsim-log{
  font-size:.78rem; color:var(--text-muted); max-height:150px; overflow-y:auto;
  border-top:1px dashed var(--border); padding-top:.5rem;
}

/* Zestaw + CTA */
.pubsim-kit{ display:flex; gap:.8rem; align-items:flex-start; height:100%; }
.pubsim-kit:hover{ transform:none; }
.pubsim-kit__price{ color:var(--accent, #6EE7FF); white-space:nowrap; font-size:.9rem; }
.pubsim-cta{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem;
}
.pubsim-cta:hover{ transform:none; }
.pubsim-price{ font-size:1.6rem; color:var(--success, #7CFFB2); }
.pubsim-buy{ font-size:1.05rem; padding:.8rem 1.6rem; }

/* Streszczenie + JSON programu */
.pubsim-summary{ margin:0; padding-left:1.2rem; }
.pubsim-summary li{ margin-bottom:.35rem; }
.pubsim-json summary{
  cursor:pointer; color:var(--accent, #6EE7FF); font-size:.82rem;
  letter-spacing:var(--tracking-mono);
}
.pubsim-json pre{
  margin:.6rem 0 0; max-height:340px; overflow:auto; font-size:.75rem;
  background:rgba(0,0,0,.35); border:1px solid var(--border); border-radius:10px;
  padding:.75rem; color:var(--text-primary);
}

/* Modal leada */
.pubsim-modal{ position:fixed; inset:0; z-index:1200; display:flex; align-items:center; justify-content:center; }
.pubsim-modal[hidden]{ display:none; }
.pubsim-modal__backdrop{ position:absolute; inset:0; background:rgba(4,7,14,.78); backdrop-filter:blur(4px); }
.pubsim-modal__card{
  position:relative; width:min(440px, calc(100vw - 2rem)); z-index:1;
  box-shadow:0 24px 80px rgba(0,0,0,.55);
}
.pubsim-modal__card:hover{ transform:none; }
.pubsim-modal__x{
  background:transparent; border:0; color:var(--text-muted); font-size:1.4rem; line-height:1;
  cursor:pointer; padding:0 .2rem;
}
.pubsim-modal__x:hover{ color:var(--text-primary); }
.pubsim-modal .form-control{
  background:rgba(255,255,255,.04); border-color:var(--border); color:inherit;
}
.pubsim-modal .form-control:focus{
  background:rgba(255,255,255,.06); border-color:var(--accent); color:inherit; box-shadow:none;
}

/* Toast potwierdzenia */
.pubsim-toast{
  position:fixed; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:1300;
  background:var(--success-a15, rgba(124,255,178,.12)); border:1px solid var(--success-a40, rgba(124,255,178,.4));
  color:var(--success, #7CFFB2); border-radius:12px; padding:.7rem 1.2rem; font-size:.9rem;
  box-shadow:0 12px 40px rgba(0,0,0,.45); max-width:min(520px, calc(100vw - 2rem)); text-align:center;
}

/* ============================================================
   Projektant blokowy (/Symulator) — kanwa, paleta, rozmowy o blokach
   Prefiks dsn- ; tokeny Neon Control Room jak wyżej.
   ============================================================ */

/* Projektant wychodzi z kontenera strony na pełną szerokość okna.
   100vw liczy szerokość Z paskiem przewijania — nadmiar (~15px) obcina
   overflow-x:clip na html (body ma już overflow-x:hidden). */
html{ overflow-x:clip; }
.dsn-fullbleed{
  width:100vw; margin-left:calc(50% - 50vw);
  padding-inline:clamp(16px, 2.5vw, 44px);
}
/* Stały 3-kolumnowy układ: paleta | kanwa | prawy rail (założenia ⇄ czat bloku). */
.dsn-fullbleed .dsn-layout{ grid-template-columns:250px minmax(0,1fr) 400px; }
@media (max-width:1100px){
  .dsn-fullbleed{ padding-inline:16px; }
  .dsn-fullbleed .dsn-layout{ grid-template-columns:1fr; }
}

/* ---------- prawy rail (założenia / czat bloku) ---------- */
.dsn-rail{ display:flex; flex-direction:column; padding:1rem 1.1rem; align-self:start; position:sticky; top:80px; max-height:calc(100vh - 96px); }
.dsn-rail:hover{ transform:none; }
.dsn-rail__pane{ display:flex; flex-direction:column; min-height:0; flex:1; }
.dsn-rail__pane[hidden]{ display:none; }
.dsn-rail__hint{ font-size:.8rem; line-height:1.45; margin:0 0 .6rem; }
.dsn-rail__row{ display:flex; gap:.5rem; }
.dsn-rail__row input{ flex:1; }
@media (max-width:1100px){
  .dsn-rail{ position:static; max-height:none; }
}

/* ---------- FAB „Uruchom symulację" (prawy-dolny róg kanwy) ---------- */
.dsn-fab{
  position:absolute; right:20px; bottom:20px; z-index:20;
  padding:.85rem 1.5rem; font-size:1.02rem; border-radius:var(--r-pill);
  box-shadow:0 12px 34px rgba(0,0,0,.5);
}
.dsn-fab:disabled{ opacity:.45; cursor:not-allowed; box-shadow:none; }
.dsn-fab.is-running{ background:linear-gradient(135deg,#ff7a59,#ff4d5e); }
@media (max-width:1100px){ .dsn-fab{ right:12px; bottom:12px; padding:.7rem 1.1rem; font-size:.9rem; } }

/* ---------- modal postępu projektowania ---------- */
.dsn-progressmodal{ width:min(560px, calc(100vw - 2rem)); }
.dsn-progressmodal__head{ display:flex; align-items:center; gap:1rem; }
.dsn-spinner--big{
  width:34px; height:34px; border-width:3px; flex:none;
}
.dsn-progressmodal .pubsim-log{ max-height:180px; overflow-y:auto; }

/* ---------- założenia globalne ---------- */
.dsn-globalbar{ padding:1rem 1.25rem; }
.dsn-globalbar:hover{ transform:none; }
.dsn-globalbar__label{ display:flex; flex-wrap:wrap; align-items:baseline; gap:.75rem; margin-bottom:.5rem; }
.dsn-globalbar__row{ display:flex; gap:.5rem; }
.dsn-globalbar__row input{ flex:1; }
.dsn-globallog{ font-size:.82rem; display:grid; gap:.35rem; }
.dsn-globallog__item{ padding:.45rem .6rem; border-left:2px solid var(--accent); background:rgba(56,231,255,.06); border-radius:0 6px 6px 0; }

/* ---------- bieżące ustawienia bloku ---------- */
.dsn-settings{
  margin:0 0 .5rem; padding:.55rem .7rem; border:1px solid rgba(56,231,255,.18);
  border-radius:8px; background:rgba(56,231,255,.05); max-height:180px; overflow-y:auto;
}
.dsn-settings__title{ font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--accent); margin-bottom:.3rem; }
.dsn-settings__list{ margin:0; padding-left:1.05rem; display:grid; gap:.25rem; font-size:.8rem; }
.dsn-settings__list li{ line-height:1.35; }

/* ---------- wyjaśniacz pracy offline ---------- */
.dsn-offline-note{
  font-size:.82rem; color:var(--text-muted); line-height:1.5;
  background:rgba(34,230,210,.06); border:1px solid var(--accent-a35);
  border-radius:8px; padding:.55rem .75rem; margin:0 0 .75rem;
}
.dsn-offline-note strong{ color:var(--text-primary); }

/* ---------- podpowiedzi (czat + kanwa) ---------- */
.dsn-msg--hint{
  background:transparent; border:1px dashed rgba(56,231,255,.35); color:var(--text-muted);
  font-size:.78rem; font-style:italic;
}
.dsn-canvashint{
  font-size:.75rem; color:var(--accent); opacity:.85;
  margin-left:auto; margin-right:.75rem; text-align:right;
}

/* ---------- żywa symulacja: urządzenia reagują wizualnie ----------
   Karta aktuatora dostaje .dsn-block--on gdy wyjście pracuje; rodzaj animacji
   z data-anim (mapa ikon w designer.js). --sim-level (0–1) skaluje jasność AO. */
.dsn-block{ --sim-level:1; }
.dsn-block--on{ border-color:rgba(174,255,0,.55); }
.dsn-block--on .dsn-block__icon svg{ transition:filter .3s ease, transform .3s ease; }

.dsn-block--on[data-anim="glow"]{
  box-shadow:0 0 22px rgba(255,214,90,.4), inset 0 0 12px rgba(255,214,90,.08);
}
.dsn-block--on[data-anim="glow"] .dsn-block__icon svg{
  color:#ffd65a; filter:drop-shadow(0 0 calc(9px * var(--sim-level)) rgba(255,214,90,.95)) brightness(calc(1 + .6 * var(--sim-level)));
}

.dsn-block--on[data-anim="spin"] .dsn-block__icon svg{
  animation:dsnSpinIcon 1.1s linear infinite; color:var(--accent);
  filter:drop-shadow(0 0 6px rgba(56,231,255,.8));
}
@keyframes dsnSpinIcon{ to{ transform:rotate(360deg); } }

.dsn-block--on[data-anim="heat"]{ box-shadow:0 0 22px rgba(255,120,50,.35); }
.dsn-block--on[data-anim="heat"] .dsn-block__icon svg{
  color:#ff7832; animation:dsnHeatPulse 1.6s ease-in-out infinite;
}
@keyframes dsnHeatPulse{
  0%,100%{ filter:drop-shadow(0 0 4px rgba(255,120,50,.6)); }
  50%{ filter:drop-shadow(0 0 14px rgba(255,120,50,1)) brightness(1.35); }
}

.dsn-block--on[data-anim="cool"]{ box-shadow:0 0 22px rgba(120,190,255,.35); }
.dsn-block--on[data-anim="cool"] .dsn-block__icon svg{
  color:#78beff; animation:dsnCoolPulse 1.8s ease-in-out infinite;
}
@keyframes dsnCoolPulse{
  0%,100%{ filter:drop-shadow(0 0 4px rgba(120,190,255,.6)); }
  50%{ filter:drop-shadow(0 0 12px rgba(120,190,255,1)); }
}

.dsn-block--on[data-anim="bubble"] .dsn-block__icon svg{
  color:var(--accent); animation:dsnBubble .9s ease-in-out infinite;
  filter:drop-shadow(0 0 7px rgba(56,231,255,.8));
}
@keyframes dsnBubble{
  0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-3px); }
}

.dsn-block--on[data-anim="flash"]{ animation:dsnSirenCard .7s steps(2) infinite; }
.dsn-block--on[data-anim="flash"] .dsn-block__icon svg{
  color:#ff4d5e; animation:dsnSirenIcon .7s steps(2) infinite;
}
@keyframes dsnSirenCard{
  0%{ box-shadow:0 0 24px rgba(255,77,94,.55); border-color:rgba(255,77,94,.8); }
  50%{ box-shadow:0 0 6px rgba(255,77,94,.15); border-color:rgba(255,77,94,.35); }
}
@keyframes dsnSirenIcon{
  0%{ filter:drop-shadow(0 0 12px rgba(255,77,94,1)) brightness(1.4); }
  50%{ filter:drop-shadow(0 0 2px rgba(255,77,94,.4)); }
}

.dsn-block--on[data-anim="flow"]{ box-shadow:0 0 20px rgba(56,160,255,.3); }
.dsn-block--on[data-anim="flow"] .dsn-block__icon svg{
  color:#38a0ff; animation:dsnFlowPulse 1.2s ease-in-out infinite;
}
@keyframes dsnFlowPulse{
  0%,100%{ filter:drop-shadow(0 0 3px rgba(56,160,255,.5)); }
  50%{ filter:drop-shadow(0 0 10px rgba(56,160,255,1)); }
}

.dsn-block--on[data-anim="move"] .dsn-block__icon svg{
  color:var(--success); animation:dsnMoveWiggle 1s ease-in-out infinite;
  filter:drop-shadow(0 0 6px rgba(174,255,0,.7));
}
@keyframes dsnMoveWiggle{
  0%,100%{ transform:translateX(0); } 50%{ transform:translateX(3px); }
}

@media (prefers-reduced-motion: reduce){
  .dsn-block--on .dsn-block__icon svg,
  .dsn-block--on[data-anim="flash"]{ animation:none !important; }
}

/* ---------- efekt pisania w czacie ---------- */
.dsn-msg--typing::after{
  content:"▍"; display:inline-block; margin-left:1px;
  color:var(--accent); animation:dsnCaret .8s steps(1) infinite;
}
@keyframes dsnCaret{ 50%{ opacity:0; } }
@media (prefers-reduced-motion: reduce){
  .dsn-msg--typing::after{ display:none; }
}

/* ---------- pasek górny ---------- */
.dsn-topbar{
  display:grid; grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) auto;
  gap:1rem 1.5rem; align-items:center;
}
.dsn-topbar:hover{ transform:none; }
@media (max-width:1100px){ .dsn-topbar{ grid-template-columns:1fr; } }
.dsn-goal{ font-family:var(--font-head); font-weight:600; font-size:1.05rem; line-height:1.35; }
.dsn-kitchips{ display:flex; flex-wrap:wrap; gap:.35rem; margin-bottom:.4rem; }
.dsn-chip{
  display:inline-flex; align-items:center; padding:2px 10px; border-radius:var(--r-pill);
  background:var(--accent-a10); border:1px solid var(--accent-a35); color:var(--accent);
  font-size:.7rem; letter-spacing:var(--tracking-mono); white-space:nowrap;
}
.dsn-priceline{ display:flex; align-items:baseline; gap:.6rem; flex-wrap:wrap; }
.dsn-price{ font-size:1.25rem; color:var(--success, #7CFFB2); }
.dsn-topbar__actions{ display:flex; flex-direction:column; gap:.5rem; min-width:230px; }
.dsn-topbar__actions .btn-glow,.dsn-topbar__actions .btn-ghost{ justify-content:center; padding:.6rem 1.1rem; font-size:.92rem; }
.dsn-topbar__actions button:disabled{ opacity:.45; cursor:not-allowed; transform:none !important; }
.dsn-autonote{
  margin-top:.5rem; font-size:.78rem; color:var(--accent);
  display:flex; align-items:center; gap:.45rem;
}

/* ---------- układ paleta | kanwa | prawy rail (stały 3-kolumnowy) ---------- */
.dsn-layout{
  display:grid; grid-template-columns:225px minmax(0,1fr) 330px; gap:1rem; align-items:start;
}
@media (max-width:1100px){
  .dsn-layout{ grid-template-columns:1fr; }
}

/* ---------- paleta ---------- */
.dsn-palette{ padding:16px; }
.dsn-palette:hover{ transform:none; }
.dsn-palette__list{ margin-top:.6rem; max-height:520px; overflow-y:auto; display:flex; flex-direction:column; gap:2px; }
.dsn-palette__group{
  font-size:.68rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  color:var(--text-muted); margin:.55rem 0 .25rem; border-bottom:1px dashed var(--border); padding-bottom:.2rem;
}
.dsn-pal-item{
  display:flex; align-items:center; gap:.55rem; width:100%; text-align:left;
  background:transparent; border:1px solid transparent; border-radius:var(--r-sm);
  color:var(--text-primary); padding:.4rem .5rem; font-size:.85rem; cursor:pointer;
  transition:background var(--dur-fast) ease, border-color var(--dur-fast) ease;
}
.dsn-pal-item:hover{ background:var(--accent2-a12); border-color:var(--accent2-a40); }
.dsn-pal-item:disabled{ opacity:.5; cursor:wait; }
.dsn-pal-item__icon{ flex:0 0 auto; width:20px; height:20px; color:var(--accent); }
.dsn-pal-item__icon svg{ width:20px; height:20px; display:block; }

/* ---------- kanwa ---------- */
/* position:relative — kotwica dla pływającego FAB; overflow:visible, bo scroll
   trzyma .dsn-canvas-scroll (FAB nie może być obcinany ani przewijany z kanwą). */
.dsn-canvas-wrap{ padding:14px; overflow:visible; position:relative; }
.dsn-canvas-wrap:hover{ transform:none; }
.dsn-canvas-head{
  display:flex; align-items:center; justify-content:space-between; gap:.5rem;
  font-size:.68rem; letter-spacing:var(--tracking-mono); color:var(--text-muted);
  padding-bottom:.55rem; border-bottom:1px solid var(--border); margin-bottom:.55rem;
}
.dsn-canvas-scroll{ overflow:auto; max-height:70vh; border-radius:var(--r-sm); }
.dsn-canvas{
  position:relative; min-width:100%; min-height:420px;
  background-image:radial-gradient(rgba(140,160,192,.22) 1px, transparent 1px);
  background-size:24px 24px;
}
.dsn-canvas__empty{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  text-align:center; font-size:.9rem; padding:2rem;
}
/* strzałki relacji — warstwa SVG pod kartami (DOM order: pierwsza w kanwie); nie łapie zdarzeń */
.dsn-links{ position:absolute; inset:0; pointer-events:none; overflow:visible; }
.dsn-links path{ fill:none; stroke:var(--accent); stroke-width:1.6; opacity:.5; }
.dsn-links marker path{ fill:var(--accent); stroke:none; opacity:.75; }
.dsn-links__label{ font-family:var(--font-mono); font-size:.62rem; fill:var(--text-primary); }
.dsn-links__labelbg{ fill:var(--surface); opacity:.9; stroke:var(--accent-a35); stroke-width:.5; }

/* ---------- blok ---------- */
.dsn-block{
  position:absolute; width:176px; min-height:112px;
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  padding:.5rem .6rem; display:flex; flex-direction:column; gap:.3rem;
  cursor:grab; user-select:none; touch-action:none;
  transition:box-shadow var(--dur-fast) ease, border-color var(--dur-fast) ease;
}
.dsn-block:hover{ border-color:var(--accent-a35); box-shadow:0 6px 24px rgba(0,0,0,.4); }
.dsn-block--drag{ cursor:grabbing; z-index:30; box-shadow:0 16px 40px rgba(0,0,0,.55), 0 0 0 1px var(--accent-a35); opacity:.92; }
.dsn-block--open{ border-color:var(--accent); box-shadow:0 0 0 1px var(--accent-a35), 0 0 20px rgba(34,230,210,.15); }
.dsn-block--error{ border-color:rgba(255,92,124,.55); }
.dsn-block--configured{ border-color:var(--success-a40, rgba(124,255,178,.4)); }
.dsn-block--flash{ animation:dsnFlash 1.6s ease-out; }
@keyframes dsnFlash{
  0%{ box-shadow:0 0 0 0 var(--accent2-a40); border-color:var(--accent-2); }
  100%{ box-shadow:0 0 0 14px transparent; }
}
.dsn-block__head{ display:flex; align-items:center; gap:.4rem; min-width:0; }
.dsn-block__icon{ flex:0 0 auto; width:20px; height:20px; color:var(--accent); }
.dsn-block--sensor .dsn-block__icon{ color:var(--accent); }
.dsn-block--actuator .dsn-block__icon{ color:var(--accent-2); }
.dsn-block__icon svg{ width:20px; height:20px; display:block; }
.dsn-block__label{
  flex:1; min-width:0; font-family:var(--font-head); font-weight:600; font-size:.86rem;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.dsn-block__rename{
  flex:1; min-width:0; background:rgba(255,255,255,.06); border:1px solid var(--accent);
  border-radius:6px; color:inherit; font-size:.8rem; padding:.1rem .35rem; outline:none;
}
.dsn-block__x{
  flex:0 0 auto; background:none; border:0; color:var(--text-muted); font-size:1.05rem;
  line-height:1; cursor:pointer; padding:0 .15rem; border-radius:4px;
}
.dsn-block__x:hover{ color:#FF5C7C; }
.dsn-block__point{
  display:inline-flex; align-items:center; gap:.3rem; align-self:flex-start; max-width:100%;
  background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--r-pill);
  color:var(--text-muted); font-size:.66rem; letter-spacing:var(--tracking-mono);
  padding:1px 8px; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.dsn-block__point:hover{ border-color:var(--accent); color:var(--accent); }
.dsn-block__caret{ font-size:.6rem; opacity:.8; }
.dsn-block__status{ line-height:1; }
.dsn-badge{
  display:inline-flex; align-items:center; gap:.3rem; padding:2px 8px; border-radius:var(--r-pill);
  border:1px solid var(--border); color:var(--text-muted); background:rgba(255,255,255,.02);
  font-family:var(--font-mono); font-size:.62rem; text-transform:uppercase; letter-spacing:var(--tracking-mono);
  white-space:nowrap;
}
.dsn-badge--warn{ color:#FFC46B; border-color:rgba(255,196,107,.4); }
.dsn-badge--ok{ color:var(--success, #7CFFB2); border-color:var(--success-a40, rgba(124,255,178,.4)); }
.dsn-badge--err{ color:#FF5C7C; border-color:rgba(255,92,124,.45); }
.dsn-block__summary,.dsn-block__note{
  font-size:.7rem; line-height:1.35; color:var(--text-muted);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.dsn-block__note{ color:#FFC46B; }
.dsn-block--error .dsn-block__note{ color:#FF5C7C; }

/* menu wyboru punktu */
.dsn-pointmenu{
  position:absolute; left:.4rem; right:.4rem; z-index:40; padding:6px;
  display:flex; flex-direction:column; gap:2px; max-height:180px; overflow-y:auto;
  background:var(--surface-alt); border-radius:10px;
}
.dsn-pointmenu:hover{ transform:none; }
.dsn-pointmenu__item{
  background:transparent; border:1px solid transparent; border-radius:6px; text-align:left;
  color:var(--text-primary); font-size:.7rem; letter-spacing:var(--tracking-mono);
  padding:.3rem .45rem; cursor:pointer;
}
.dsn-pointmenu__item:hover{ background:var(--accent2-a12); border-color:var(--accent2-a40); }
.dsn-pointmenu__item.is-current{ color:var(--success, #7CFFB2); }
.dsn-pointmenu__empty{ font-size:.72rem; padding:.35rem .45rem; }

/* ---------- panel rozmowy o bloku (pane wewnątrz .dsn-rail) ---------- */
.dsn-chatpanel__head{ display:flex; align-items:flex-start; justify-content:space-between; gap:.5rem; margin-bottom:.5rem; }
.dsn-chatlog{
  flex:1; min-height:180px; overflow-y:auto; display:flex; flex-direction:column; gap:.45rem;
  padding-right:.25rem;
}
.dsn-msg{
  border:1px solid var(--border); border-radius:12px; padding:.45rem .7rem;
  font-size:.85rem; line-height:1.45; max-width:92%; white-space:pre-wrap; word-break:break-word;
}
.dsn-msg--user{ align-self:flex-end; background:var(--accent2-a12); border-color:var(--accent2-a40); }
.dsn-msg--ai{ align-self:flex-start; background:rgba(255,255,255,.03); }
.dsn-msg--system{
  align-self:center; text-align:center; color:var(--text-muted); font-size:.74rem;
  border-style:dashed; background:transparent; max-width:100%;
}
.dsn-msg--pending{ opacity:.7; }
.dsn-msg--errnote{ align-self:stretch; max-width:100%; color:#FF5C7C; border-color:rgba(255,92,124,.45); font-size:.78rem; }
.dsn-chatstatus{
  display:flex; align-items:center; gap:.45rem; font-size:.74rem; color:var(--accent);
  padding:.45rem 0 0;
}
.dsn-chatform{ display:flex; gap:.5rem; margin-top:.6rem; }
.dsn-chatform input{ flex:1; background:rgba(255,255,255,.04); border-color:var(--border); color:inherit; }
/* Na mobile prawy rail (założenia i czat) płynie zwykłą kolumną pod kanwą — bez bottom-sheet. */

/* spinner */
.dsn-spinner{
  width:13px; height:13px; flex:0 0 auto; border-radius:50%;
  border:2px solid var(--accent-a35); border-top-color:var(--accent);
  animation:dsnSpin .8s linear infinite; display:inline-block;
}
@keyframes dsnSpin{ to{ transform:rotate(360deg); } }

/* ---------- tryb symulacji ---------- */
.dsn-canvas--sim .dsn-block{ cursor:default; min-height:190px; }
.dsn-block__sim{ margin-top:auto; border-top:1px dashed var(--border); padding-top:.4rem; display:flex; flex-direction:column; gap:.3rem; }
.dsn-block__sim[hidden]{ display:none; }
.dsn-sim-row{ display:flex; align-items:center; gap:.45rem; min-width:0; }
.dsn-sim-value{ font-size:.95rem; font-weight:500; color:var(--text-primary); }
.dsn-sim-value.is-on{ color:var(--success, #7CFFB2); }
.dsn-sim-value.is-off{ color:var(--text-muted); }
.dsn-sim-value--out{ font-size:1.1rem; }
.dsn-sim-btn{ padding:.25rem .6rem; font-size:.72rem; }
.dsn-sim-slider{ flex:1; min-width:0; }
.dsn-sim-num{ max-width:84px; background:rgba(255,255,255,.04); border-color:var(--border); color:inherit; padding:.15rem .4rem; font-size:.75rem; }
.dsn-sim--stale{ opacity:.65; }
.dsn-simstrip:hover{ transform:none; }
.dsn-simstrip__row{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:.75rem; margin-bottom:.5rem; }
.dsn-simextra{ border-top:1px dashed var(--border); padding-top:.5rem; margin-bottom:.5rem; }
.dsn-simextra__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:.5rem; }
.dsn-extra{
  display:flex; align-items:center; gap:.45rem; border:1px solid var(--border); border-radius:10px;
  padding:.35rem .55rem; background:rgba(255,255,255,.02);
}
.dsn-extra__name{ font-size:.66rem; color:var(--text-muted); max-width:110px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ---------- program / walidacja ---------- */
#dsnProgramCard:hover{ transform:none; }
.dsn-vbadge--err{ background:rgba(255,92,124,.12); border-color:rgba(255,92,124,.4) !important; color:#FF5C7C !important; }
.dsn-issues{ display:flex; flex-direction:column; gap:.25rem; margin-bottom:.6rem; }
.dsn-issue{ color:#FF5C7C; font-size:.8rem; }

/* toasty ostrzegawcze/błędów (rozszerzenie .pubsim-toast) */
.pubsim-toast--warn{
  background:rgba(255,196,107,.12); border-color:rgba(255,196,107,.4); color:#FFC46B;
}
.pubsim-toast--error{
  background:rgba(255,92,124,.12); border-color:rgba(255,92,124,.45); color:#FF5C7C;
}
