/* ============================================================
   n3flow — style podstron sygnałów (lista + karta)
   Rozszerza styles.css (te same tokeny w :root)
   ============================================================ */

/* ---------- Subpage hero / breadcrumb ---------- */
.subhero{position:relative;padding-block:clamp(40px,7vh,72px) clamp(28px,4vh,44px);overflow:hidden}
.subhero__glow{position:absolute;top:-30%;right:-10%;width:50vw;height:50vw;max-width:600px;background:radial-gradient(circle,rgba(163,230,53,.1),transparent 62%);filter:blur(20px);z-index:0}
.subhero .container{position:relative;z-index:1}
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--font-m);font-size:.76rem;color:var(--text-dim);margin-bottom:22px}
.breadcrumb a{color:var(--text-dim);transition:.2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{opacity:.5}
.breadcrumb .cur{color:var(--accent)}
.subhero h1{font-size:clamp(1.9rem,4.4vw,3rem);margin-bottom:14px}
.subhero__lead{font-size:clamp(1rem,1.6vw,1.15rem);color:var(--text-dim);max-width:60ch}

/* ---------- Toolbar (filtry listy) ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:26px}
.toolbar__filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.toolbar__search{position:relative;flex:1;min-width:220px;max-width:340px}
.toolbar__search input{width:100%;background:var(--bg-panel);border:1px solid var(--border);border-radius:50px;padding:11px 16px 11px 40px;color:var(--text-hi);font-family:var(--font-b);font-size:.9rem;transition:.2s}
.toolbar__search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(163,230,53,.12)}
.toolbar__search::before{content:"⌕";position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-dim);font-size:1.1rem}
.selectwrap{position:relative}
.selectwrap select{appearance:none;background:var(--bg-panel);border:1px solid var(--border);border-radius:50px;padding:10px 36px 10px 16px;color:var(--text);font-family:var(--font-m);font-size:.78rem;cursor:pointer;transition:.2s}
.selectwrap select:hover{border-color:var(--border-accent);color:var(--text-hi)}
.selectwrap::after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--accent);pointer-events:none;font-size:.7rem}
.toolbar__count{font-family:var(--font-m);font-size:.8rem;color:var(--text-dim);white-space:nowrap}
.toolbar__count b{color:var(--accent)}

.signals-empty{text-align:center;padding:60px 20px;color:var(--text-dim);font-family:var(--font-m)}

/* ---------- Source badge ---------- */
.src{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-m);font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:50px;border:1px solid var(--border)}
.src--wlasne{color:var(--accent);border-color:var(--border-accent)}
.src--publiczne{color:var(--cyan);border-color:rgba(56,232,200,.3)}
.src--sygnal{color:var(--text);border-color:var(--border)}
.src i{width:5px;height:5px;border-radius:50%;background:currentColor}

/* signal card: clickable title */
.signal__title-link{color:var(--text-hi);transition:.2s}
.signal__title-link:hover{color:var(--accent)}
.signal__src-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}

/* ============================================================
   RADAR TYGODNIA
   ============================================================ */
.rw-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
.rw-stat{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r);padding:18px 16px;text-align:center}
.rw-stat__num{display:block;font-family:var(--font-m);font-size:1.9rem;font-weight:600;color:var(--accent);line-height:1}
.rw-stat__lbl{display:block;font-size:.74rem;color:var(--text-dim);margin-top:8px}

.rw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rw-block{position:relative;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;overflow:hidden;transition:.3s var(--ease)}
.rw-block::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--c,var(--accent))}
.rw-block--build{--c:var(--build)}.rw-block--it{--c:var(--it)}.rw-block--trans{--c:var(--trans)}
.rw-block:hover{transform:translateY(-4px);border-color:var(--c)}
.rw-block__head{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.rw-block__ico{font-size:1.9rem;filter:drop-shadow(0 0 10px var(--glow))}
.rw-block__head h2{font-size:1.4rem}
.rw-block__region{font-family:var(--font-m);font-size:.7rem;color:var(--text-dim)}
.rw-block__badge{margin-left:auto;font-family:var(--font-m);font-size:.66rem;color:var(--c);border:1px solid currentColor;border-radius:50px;padding:4px 10px;white-space:nowrap}
.rw-list{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.rw-list li{position:relative;padding-left:22px;font-size:.92rem;color:var(--text)}
.rw-list li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--c)}
.rw-fresh{border-top:1px solid var(--border);padding-top:16px}
.rw-fresh__lbl{font-family:var(--font-m);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:10px}
.rw-fresh__items{display:flex;flex-direction:column;gap:8px}
.rw-fresh__item{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-hi);padding:8px 10px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--r-sm);transition:.2s}
.rw-fresh__item:hover{border-color:var(--c);transform:translateX(3px)}
.rw-fresh__item .nw{font-family:var(--font-m);font-size:.58rem;color:var(--c);border:1px solid currentColor;border-radius:50px;padding:2px 6px;flex-shrink:0}
.rw-fresh__item .ar{margin-left:auto;color:var(--c)}
.rw-fresh__empty{font-size:.82rem;color:var(--text-dim);font-style:italic}

@media(max-width:900px){.rw-grid{grid-template-columns:1fr}.rw-stats{grid-template-columns:1fr 1fr}}

/* ============================================================
   SIGNAL DETAIL
   ============================================================ */
.detail{padding-bottom:clamp(56px,9vh,100px)}
.detail__grid{display:grid;grid-template-columns:1.55fr .95fr;gap:clamp(28px,4vw,48px);align-items:start}

/* main column */
.dcard{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(22px,3vw,34px);margin-bottom:22px}
.dcard__accent{position:relative;overflow:hidden}
.dcard__accent::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--c,var(--accent))}
.dcard.c-build{--c:var(--build)}.dcard.c-it{--c:var(--it)}.dcard.c-trans{--c:var(--trans)}

.detail__head{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:18px}
.detail__code{font-family:var(--font-m);font-size:.82rem;color:var(--text-dim);display:flex;align-items:center;gap:8px}
.detail__code i{width:8px;height:8px;border-radius:50%;background:var(--c,var(--accent))}
.detail h2.detail__title{font-size:clamp(1.5rem,3vw,2.1rem);margin:6px 0 8px;line-height:1.2}
.detail__fresh{font-family:var(--font-m);font-size:.68rem;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.detail__fresh .dot{animation:pulse 1.8s infinite}

.facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin:22px 0}
.fact{background:var(--bg-panel);padding:15px 18px}
.fact__k{font-family:var(--font-m);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}
.fact__v{font-size:.96rem;color:var(--text-hi);font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.pot-dots{display:inline-flex;gap:4px}
.pot-dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.12)}
.pot-dots i.on{background:var(--c,var(--accent))}

.dsection{margin:26px 0}
.dsection h3{font-size:1.12rem;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.dsection h3 .ic{color:var(--accent)}
.dsection p{color:var(--text);font-size:.96rem}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.tag{font-family:var(--font-m);font-size:.74rem;padding:6px 12px;border-radius:50px;border:1px solid var(--border);color:var(--text);background:rgba(255,255,255,.02)}
.matchlist{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.matchlist li{position:relative;padding-left:28px;color:var(--text);font-size:.94rem}
.matchlist li::before{content:"→";position:absolute;left:0;color:var(--accent);font-weight:700}

/* transparency box */
.transp{border:1px dashed var(--border-accent);border-radius:var(--r);padding:18px 20px;background:rgba(163,230,53,.03);margin:24px 0}
.transp h4{font-family:var(--font-d);font-size:.96rem;color:var(--text-hi);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.transp ul{display:flex;flex-direction:column;gap:7px}
.transp li{position:relative;padding-left:24px;font-size:.88rem;color:var(--text-dim)}
.transp li::before{content:"✕";position:absolute;left:0;color:#E5564B;font-weight:700;font-size:.8rem}

/* ---------- ANATOMY: raw vs public ---------- */
.anatomy{margin-top:8px}
.anatomy__intro{color:var(--text-dim);font-size:.94rem;margin-bottom:20px;max-width:64ch}
.harvbar{display:flex;flex-wrap:wrap;gap:8px 18px;font-family:var(--font-m);font-size:.7rem;color:var(--text-dim);background:var(--bg-void);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 16px;margin-bottom:20px}
.harvbar span{display:flex;gap:6px;align-items:center}
.harvbar b{color:var(--text);font-weight:500}
.harvbar .ok{color:var(--accent)}

.split2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.rawbox{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.rawbox__head{display:flex;align-items:center;gap:9px;padding:13px 16px;font-family:var(--font-m);font-size:.74rem;letter-spacing:.03em;border-bottom:1px solid var(--border)}
.rawbox--private .rawbox__head{background:rgba(229,86,75,.08);color:#F0938B}
.rawbox--public .rawbox__head{background:rgba(163,230,53,.08);color:var(--accent)}
.rawbox__body{padding:6px 0}
.rawrow{display:flex;justify-content:space-between;gap:14px;padding:10px 16px;font-size:.82rem;border-bottom:1px solid var(--border)}
.rawrow:last-child{border-bottom:none}
.rawrow__k{color:var(--text-dim);font-family:var(--font-m);font-size:.72rem;flex-shrink:0;max-width:46%}
.rawrow__v{color:var(--text-hi);text-align:right}
.rawbox--private .rawrow__v{color:var(--text-dim);font-family:var(--font-m)}
.rawbox--private .redact{color:#E5564B;letter-spacing:.05em}
.rawbox__foot{padding:12px 16px;font-size:.74rem;display:flex;align-items:center;gap:8px}
.rawbox--private .rawbox__foot{color:#F0938B;background:rgba(229,86,75,.05)}
.rawbox--public .rawbox__foot{color:var(--accent);background:rgba(163,230,53,.05)}

.arrowflow{display:grid;place-items:center;padding:10px 0;color:var(--accent)}

/* ---------- Pipeline steps ---------- */
.pipe{display:grid;grid-template-columns:1fr;gap:0;counter-reset:p;margin-top:8px}
.pipe__step{position:relative;display:flex;gap:16px;padding:14px 0 14px 4px}
.pipe__step:not(:last-child)::after{content:"";position:absolute;left:15px;top:38px;bottom:-6px;width:1px;background:var(--border)}
.pipe__num{counter-increment:p;flex-shrink:0;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-m);font-size:.78rem;background:var(--bg-void);border:1px solid var(--border-accent);color:var(--accent);z-index:1}
.pipe__step:last-child .pipe__num{background:var(--accent);color:#0A1005;border-color:var(--accent)}
.pipe__c h4{font-family:var(--font-d);font-size:.98rem;color:var(--text-hi);margin-bottom:3px}
.pipe__c p{font-size:.86rem;color:var(--text-dim)}
.pipe__tag{font-family:var(--font-m);font-size:.62rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}

/* bridge to operator panel */
.op-bridge{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:space-between;margin-top:26px;padding:20px 22px;border:1px solid var(--border-accent);border-radius:var(--r);background:linear-gradient(120deg,rgba(56,232,200,.05),rgba(163,230,53,.04))}
.op-bridge__lbl{font-family:var(--font-m);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:6px}
.op-bridge p{font-size:.88rem;color:var(--text);max-width:46ch;margin:0}
.op-bridge .btn{white-space:nowrap}

/* ---------- Sidebar ---------- */
.dside{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.cta-card{background:linear-gradient(160deg,rgba(20,29,46,.9),rgba(10,15,26,.92));border:1px solid var(--border-accent);border-radius:var(--r-lg);padding:24px}
.cta-card h3{font-size:1.2rem;margin-bottom:10px}
.cta-card p{font-size:.88rem;color:var(--text-dim);margin-bottom:18px}
.cta-card .btn{margin-bottom:10px}
.cta-card .btn:last-child{margin-bottom:0}
.cta-card__note{font-family:var(--font-m);font-size:.68rem;color:var(--text-dim);text-align:center;margin-top:12px}

.miniinfo{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r);padding:20px}
.miniinfo h4{font-family:var(--font-m);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:14px}
.miniinfo .mantra{margin:0;padding:0;border:none;background:none;text-align:left;font-size:.82rem;line-height:1.8}

/* related */
.related{margin-top:36px}
.related h3{font-size:1.3rem;margin-bottom:20px;text-align:center}
.related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .detail__grid{grid-template-columns:1fr}
  .dside{position:static}
  .related__grid{grid-template-columns:1fr}
}
@media(max-width:680px){
  .split2{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar__search{max-width:none}
}
