/* ====================================================
   BLOG PIOTR MUSZALSKI — styl spójny ze stroną "dossier"
   ==================================================== */
:root{
  --bg:#f4f0e6;
  --bg-2:#ece6d6;
  --panel:#e6dfcc;
  --paper:#27332b;
  --ink:#211f1b;
  --ink-dim:#5d594e;
  --ink-faint:#8c8676;
  --brass:#9b7d3f;
  --brass-hot:#bb9a55;
  --rust:#b6552f;
  --line:rgba(33,31,27,.16);
  --line-soft:rgba(33,31,27,.08);
  --grid:rgba(33,31,27,.04);
  --display:'Bricolage Grotesque',sans-serif;
  --serif:'Newsreader',Georgia,serif;
  --mono:'JetBrains Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--serif);font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none;
}
::selection{background:var(--brass);color:var(--bg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* grid backdrop */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 120% 90% at 50% 0%,#000 35%,transparent 90%);
}
/* film grain */
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== custom cursor — celownik z § ===== */
.cur,.cur-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none}
.cur{
  width:30px;height:30px;margin:-15px 0 0 -15px;
  border:2px solid #b3924e;border-radius:50%;
  box-shadow:0 0 0 1px rgba(244,240,230,.55),0 2px 8px rgba(33,31,27,.22);
  transition:width .25s,height .25s,margin .25s,border-color .25s,background .25s;
}
.cur::before,.cur::after{content:"";position:absolute;background:#b3924e}
.cur::before{left:50%;top:-8px;width:2px;height:7px;transform:translateX(-50%)}
.cur::after{left:50%;bottom:-8px;width:2px;height:7px;transform:translateX(-50%)}
.cur-dot{
  width:auto;height:auto;margin:0;
  font-family:var(--serif);font-weight:500;font-size:0;line-height:1;
  color:#b3924e;transition:font-size .25s,color .25s;
  text-shadow:0 0 3px rgba(244,240,230,.9),0 1px 3px rgba(33,31,27,.35);
}
.cur-dot::before{
  content:"";position:absolute;left:50%;top:50%;
  width:6px;height:6px;border-radius:50%;background:#b3924e;
  transform:translate(-50%,-50%) scale(1);
  box-shadow:0 0 0 1.5px rgba(244,240,230,.85),0 1px 4px rgba(33,31,27,.3);
  transition:transform .2s,opacity .2s;opacity:1;
}
body.hov .cur{width:52px;height:52px;margin:-26px 0 0 -26px;border-color:#c4a25c;background:rgba(179,146,78,.1)}
body.hov .cur-dot{font-size:24px}
body.hov .cur-dot::before{transform:translate(-50%,-50%) scale(0);opacity:0}
@media(hover:none),(pointer:coarse){body{cursor:auto}.cur,.cur-dot{display:none}}

.wrap{max-width:1180px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass)}
.mono-dim{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint)}

/* ===== NAV ===== */
nav#nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 48px;
  transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
nav#nav.scrolled{
  background:rgba(244,240,230,.85);backdrop-filter:blur(14px) saturate(1.2);
  padding:14px 48px;border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--display)}
.brand .glyph{
  width:40px;height:40px;display:grid;place-items:center;flex-shrink:0;
  border:1px solid var(--brass);position:relative;overflow:hidden;
  font-family:var(--mono);font-size:13px;font-weight:500;color:var(--brass);
  letter-spacing:.04em;transition:color .3s;
}
.brand .glyph::after{content:"";position:absolute;inset:0;background:var(--brass);transform:translateY(101%);transition:transform .4s cubic-bezier(.7,0,.2,1);z-index:-1}
.brand:hover .glyph{color:var(--bg)}
.brand:hover .glyph::after{transform:none}
.brand .bn{font-size:15px;font-weight:500;letter-spacing:.02em}
.brand .bn small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.28em;color:var(--ink-faint);margin-top:2px}
.nav-links{display:flex;flex-direction:row;gap:18px;list-style:none;align-items:center}
.nav-links a{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-dim);padding:5px 0;position:relative;transition:color .25s;
  display:inline-flex;align-items:baseline;
}
.nav-links a .n{color:var(--brass);margin-right:7px;opacity:.7}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:1px;height:1px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.burger{display:none;background:none;border:1px solid var(--line);width:44px;height:44px;cursor:none;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:20px;height:1.5px;background:var(--ink);transition:.3s}

/* ===== BLOG HEADER ===== */
header.blog-hero{padding:170px 0 70px;position:relative}
.blog-hero .meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:46px;flex-wrap:wrap;gap:16px;
}
.blog-hero h1{
  font-family:var(--display);font-weight:200;
  font-size:clamp(3rem,9vw,7rem);line-height:.86;letter-spacing:-.04em;
}
.blog-hero h1 b{font-weight:700}
.blog-hero h1 i{font-style:normal;color:var(--brass)}
.blog-hero .lede{margin-top:30px;max-width:38em;font-size:1.2rem;color:var(--ink-dim);font-weight:300}
.blog-hero .sentencja{
  margin-top:40px;max-width:30em;padding:4px 0 4px 26px;
  border-left:2px solid var(--brass);
  font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.4;color:var(--ink);
}
.blog-hero .sentencja b{font-weight:500;font-style:normal;color:var(--brass)}

/* ===== FILTRY KATEGORII ===== */
.cats{display:flex;gap:10px;flex-wrap:wrap;margin-top:40px}
.cats a{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  padding:9px 18px;border:1px solid var(--line);border-radius:40px;color:var(--ink-dim);
  transition:background .3s,color .3s,border-color .3s;
}
.cats a:hover,.cats a.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* ===== LISTA WPISÓW ===== */
.posts{padding:30px 0 130px}
.post-row{
  display:grid;grid-template-columns:150px 1fr 130px;gap:40px;align-items:baseline;
  padding:40px 0;border-top:1px solid var(--line);position:relative;
  transition:background .35s,padding-left .35s;
}
.post-row:last-child{border-bottom:1px solid var(--line)}
.post-row:hover{background:linear-gradient(90deg,rgba(155,125,63,.05),transparent);padding-left:18px}
.post-row .pr-date{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-faint);line-height:1.7}
.post-row .pr-cat{display:inline-block;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:12px}
.post-row h2{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.1;letter-spacing:-.02em;margin-bottom:12px;transition:color .3s}
.post-row:hover h2{color:var(--brass)}
.post-row p{color:var(--ink-dim);font-size:1.02rem;max-width:46em}
.post-row .pr-read{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-faint);text-align:right;line-height:1.7}
.post-row .pr-arrow{font-family:var(--display);color:var(--brass);font-size:1.4rem;opacity:0;transform:translateX(-8px);transition:opacity .3s,transform .3s}
.post-row:hover .pr-arrow{opacity:1;transform:none}

/* ===== ARTYKUŁ ===== */
.article{padding:160px 0 100px}
.article .a-back{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);display:inline-flex;gap:8px;margin-bottom:46px;transition:color .25s}
.article .a-back:hover{color:var(--brass)}
.article .a-cat{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:22px}
.article h1{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,5vw,3.8rem);line-height:1.05;letter-spacing:-.03em;margin-bottom:28px}
.article .a-meta{display:flex;gap:24px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-faint);padding-bottom:38px;border-bottom:1px solid var(--line);margin-bottom:48px}
.article .a-meta span{display:flex;align-items:center;gap:8px}
.article .a-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--brass)}

/* treść artykułu */
.prose{font-size:1.16rem;line-height:1.8;color:var(--ink-dim)}
.prose > *{margin-bottom:1.4em}
.prose h2{font-family:var(--display);font-weight:500;font-size:1.9rem;color:var(--ink);letter-spacing:-.01em;margin-top:1.8em;line-height:1.2}
.prose h3{font-family:var(--display);font-weight:500;font-size:1.4rem;color:var(--ink);margin-top:1.6em}
.prose p{color:var(--ink-dim)}
.prose strong{color:var(--ink);font-weight:600}
.prose em{font-style:italic}
.prose a{color:var(--brass);border-bottom:1px solid var(--brass);transition:opacity .25s}
.prose a:hover{opacity:.7}
.prose blockquote{
  border-left:2px solid var(--brass);padding:6px 0 6px 28px;margin:1.6em 0;
  font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink);
}
.prose ul,.prose ol{padding-left:1.5em;color:var(--ink-dim)}
.prose li{margin-bottom:.5em}
.prose li::marker{color:var(--brass)}
.prose hr{border:none;height:1px;background:var(--line);margin:2.4em 0}
.prose code{font-family:var(--mono);font-size:.9em;background:var(--bg-2);padding:2px 6px;border-radius:3px;color:var(--ink)}
.prose .lead{font-family:var(--display);font-weight:300;font-size:1.45rem;line-height:1.4;color:var(--ink);letter-spacing:-.01em}
.prose .lead i{font-style:italic;font-family:var(--serif);color:var(--brass)}

/* podpis autora pod artykułem */
.a-sign{margin-top:60px;padding-top:36px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:14px}
.a-sign .name{font-family:var(--serif);font-style:italic;font-size:1.7rem;color:var(--ink)}
.a-sign .role{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-faint);text-align:right}

/* nawigacja prev/next */
.a-nav{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:60px}
.a-nav a{padding:28px;border:1px solid var(--line);transition:background .35s,border-color .35s}
.a-nav a:hover{background:var(--bg-2);border-color:var(--brass)}
.a-nav .lab{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:10px}
.a-nav .tt{font-family:var(--display);font-weight:500;font-size:1.1rem;color:var(--ink);line-height:1.2}
.a-nav .next{text-align:right}
.a-nav .empty{border:1px solid var(--line-soft);background:transparent;pointer-events:none}

/* ===== MANIFEST (rozbudowany cytat) ===== */
.manifest{background:var(--paper);color:var(--bg);padding:130px 0;position:relative;overflow:hidden}
.manifest::before{
  content:"„";position:absolute;top:-6%;left:3%;
  font-family:var(--display);font-weight:800;font-size:28rem;line-height:1;
  color:rgba(187,154,85,.1);z-index:0;pointer-events:none;
}
.manifest .wrap{max-width:980px}
.manifest .m-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--brass-hot);display:flex;align-items:center;gap:14px;margin-bottom:40px;position:relative;z-index:1;
}
.manifest .m-eyebrow::before{content:"";width:40px;height:1px;background:var(--brass-hot)}
.manifest blockquote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.4rem,3vw,2.3rem);line-height:1.45;letter-spacing:-.01em;
  position:relative;z-index:1;color:#f0ebdd;
}
.manifest blockquote b{font-weight:500;font-style:normal;color:var(--brass-hot)}
.manifest cite{
  display:block;margin-top:44px;font-family:var(--mono);font-style:normal;
  font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(240,235,221,.55);position:relative;z-index:1;
}

/* ===== FOOTER ===== */
footer{border-top:1px solid var(--line);padding:56px 0 40px;position:relative;z-index:2}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:30px;margin-bottom:48px}
.foot-big{font-family:var(--display);font-weight:200;font-size:clamp(2.2rem,7vw,5rem);line-height:.85;letter-spacing:-.04em}
.foot-big b{font-weight:700}
.foot-nav{display:flex;flex-direction:column;gap:10px}
.foot-nav a{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);transition:color .25s}
.foot-nav a:hover{color:var(--brass)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;padding-top:26px;border-top:1px solid var(--line)}
.foot-legal{display:flex;gap:24px;list-style:none;flex-wrap:wrap}
.foot-legal a,.foot-copy{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-faint);transition:color .25s}
.foot-legal a:hover{color:var(--brass)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  body{font-size:17px}
  .wrap,.wrap-narrow{padding:0 22px}
  nav#nav{padding:16px 22px}nav#nav.scrolled{padding:12px 22px}
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:330px;background:var(--bg-2);
    flex-direction:column;justify-content:center;align-items:flex-start;padding:80px 36px;gap:8px;
    transform:translateX(101%);transition:transform .5s cubic-bezier(.16,1,.3,1);border-left:1px solid var(--line)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:14px;padding:12px 0}
  .burger{display:flex;z-index:90}
  .burger.x span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  header.blog-hero{padding:130px 0 50px}
  .article{padding:120px 0 70px}
  .post-row{grid-template-columns:1fr;gap:10px}
  .post-row .pr-read,.post-row .pr-arrow{display:none}
  .a-nav{grid-template-columns:1fr}
  .prose{font-size:1.08rem}
}
