/* ===========================================================================
   razem-core — redakcyjny system projektowy ("prestiż gazety/think-tanku")
   Display: Playfair Display (serif, wysoki kontrast). Tekst/UI: Clash Grotesk
   (font marki Razem). Kolor wiodący: karmin Razem (#870F57). Akcent per domena.
   =========================================================================== */

/* ---- Fonty (self-host, zero zewn. requestów) ----------------------------- */
@font-face{font-family:"Clash Grotesk";src:url("/fonts/ClashGrotesk-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Clash Grotesk";src:url("/fonts/ClashGrotesk-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Clash Grotesk";src:url("/fonts/ClashGrotesk-Semibold.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Clash Grotesk";src:url("/fonts/ClashGrotesk-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Playfair Display";src:url("/fonts/playfair-display-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Playfair Display";src:url("/fonts/playfair-display-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Playfair Display";src:url("/fonts/playfair-display-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Playfair Display";src:url("/fonts/playfair-display-latin-900-normal.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}

/* ---- Tokeny -------------------------------------------------------------- */
:root{
  /* marka (nadpisywane per domena w head.html) */
  --carmine:#870F57; --carmine-700:#8A0F59; --carmine-dark:#5C0A3B;
  --carmine-50:#FCE8F4; --carmine-10:#FEF6FA;
  --accent:#1f8f4e;            /* domyślnie zielony; zdrowie nadpisuje na niebieski */
  /* neutralne (skala Razem) */
  --ink:#1C171A; --muted:#786D74; --line:#E7E4E6; --line-soft:#F1EEF0;
  --bg:#ffffff; --surface:#F7F4F5; --surface-warm:#FCF9F6;
  /* typografia */
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Clash Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  /* układ */
  --wrap:1180px; --measure:42rem; --radius:6px; --radius-l:14px;
  --shadow:0 1px 2px rgba(28,23,26,.05),0 8px 30px rgba(28,23,26,.06);
  --shadow-lift:0 6px 16px rgba(28,23,26,.10),0 18px 50px rgba(135,15,87,.10);
}

/* ---- Reset / baza ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{font-size:17px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-weight:400;line-height:1.65;letter-spacing:-.003em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--carmine);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.container{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.4rem)}
hr,.rule{border:0;border-top:1px solid var(--line);margin:2.5rem 0}

/* ---- Typografia --------------------------------------------------------- */
h1,h2,h3,h4{font-family:var(--serif);color:var(--carmine-700);font-weight:700;
  line-height:1.08;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.5vw,4rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
h3{font-size:clamp(1.35rem,2.2vw,1.7rem);color:var(--ink)}
p{margin:0 0 1.1rem}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);margin:0 0 1rem;display:inline-flex;align-items:center}
.eyebrow::before{content:"";width:1.6rem;height:3px;background:var(--accent);margin-right:.6rem;border-radius:2px}
.lead{font-size:clamp(1.15rem,1.7vw,1.4rem);line-height:1.55;color:var(--muted);font-weight:400}

/* ---- Przyciski ---------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);
  font-weight:600;font-size:1rem;line-height:1;padding:.85rem 1.5rem;border-radius:var(--radius);
  border:1.5px solid transparent;cursor:pointer;transition:transform .12s,box-shadow .15s,background .15s,color .15s}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--carmine);color:#fff;box-shadow:0 6px 18px rgba(135,15,87,.25)}
.btn-primary:hover{background:var(--carmine-dark);color:#fff}
.btn-secondary{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-secondary:hover{background:var(--accent);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line);font-weight:500}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ---- Header ------------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:68px}
.brand{font-family:var(--serif);font-weight:900;font-size:1.5rem;color:var(--carmine-700);
  letter-spacing:-.02em;line-height:1.05}
.brand:hover{text-decoration:none;color:var(--carmine)}
.nav-list{list-style:none;display:flex;gap:1.6rem;margin:0;padding:0}
.nav-list a{font-family:var(--sans);font-weight:500;font-size:1rem;color:var(--ink);position:relative;padding:.2rem 0}
.nav-list a:hover{text-decoration:none;color:var(--carmine)}
.nav-list a[aria-current=page]{color:var(--carmine)}
.nav-list a[aria-current=page]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--accent)}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--ink);cursor:pointer}
/* wariant B nagłówka */
.header-b .brand-row{text-align:center;padding-block:1.3rem .9rem}
.header-b .brand-centered{font-size:clamp(1.6rem,3vw,2.2rem)}
.header-b .brand-tagline{margin:.3rem 0 0;color:var(--muted);font-size:.95rem}
.header-b .nav-strip{border-top:1px solid var(--line);background:var(--surface-warm)}
.nav-list-center{justify-content:center;flex-wrap:wrap;padding-block:.7rem}

/* ---- Hero --------------------------------------------------------------- */
.home-hero{padding:clamp(3rem,8vw,6rem) 0 clamp(2rem,5vw,3.5rem);
  background:linear-gradient(180deg,var(--carmine-10),transparent 70%)}
.home-hero .container{max-width:60rem}
.hero-title{font-weight:900;font-size:clamp(2.6rem,7vw,5.2rem);line-height:1.02;margin:0 0 1.1rem}
.hero-title .hero-sub{display:block;font-size:.46em;font-weight:600;color:var(--ink);margin-top:.5rem;font-style:italic}
.hero-desc{font-size:clamp(1.15rem,1.9vw,1.45rem);color:var(--muted);max-width:40rem;margin:0 0 1.8rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.home-hero::after{content:"";display:block;max-width:60rem;margin:clamp(2rem,5vw,3rem) auto 0;
  padding-inline:clamp(1.1rem,4vw,2.4rem);border-bottom:4px solid var(--accent)}

/* ---- Sekcje home -------------------------------------------------------- */
section[class^=home-]{padding:clamp(2.2rem,5vw,3.6rem) 0}
.section-h{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 1.5rem;
  color:var(--ink);position:relative;padding-bottom:.6rem}
.section-h::after{content:"";position:absolute;left:0;bottom:0;width:4.5rem;height:5px;background:var(--accent);border-radius:3px}
.home-program{background:var(--carmine-dark);color:#fff;border-radius:var(--radius-l);
  margin:clamp(1.5rem,4vw,2.5rem) auto;max-width:var(--wrap)}
.home-program .container{padding-block:clamp(2rem,5vw,3rem)}
.home-program .section-h,.home-program h2{color:#fff}
.home-program .section-h::after{background:var(--accent)}
.home-program-desc{color:rgba(255,255,255,.85);max-width:46rem;font-size:1.15rem}

/* ---- Karty -------------------------------------------------------------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.6rem}
.card{background:var(--bg);border:1px solid var(--line);border-top:4px solid var(--accent);
  border-radius:0 0 var(--radius-l) var(--radius-l);overflow:hidden;
  transition:transform .15s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.card-media img{width:100%;object-fit:cover;aspect-ratio:16/9}
.card-body{padding:1.3rem 1.4rem 1.5rem}
.card-title{font-family:var(--serif);font-size:1.35rem;line-height:1.15;margin:0 0 .5rem;color:var(--ink)}
.card-title a{color:inherit}
.card-title a:hover{color:var(--accent);text-decoration:none}
.card-lead{color:var(--muted);font-size:.98rem;margin:0 0 .9rem}
.card-meta{font-size:.82rem;color:var(--muted);letter-spacing:.02em;margin:0}
.card-b{display:grid;grid-template-columns:1fr 240px;align-items:center}
.card-b .card-media img{height:100%;aspect-ratio:4/3}
@media(max-width:640px){.card-b{grid-template-columns:1fr}}

/* ---- Listy tematów / huby ----------------------------------------------- */
.topic-list{list-style:none;margin:0;padding:0;display:grid;gap:.2rem}
.topic-list li{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:1rem .2rem;border-bottom:1px solid var(--line)}
.topic-list a{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.topic-list a:hover{color:var(--accent);text-decoration:none}
.topic-count{font-family:var(--sans);font-size:.8rem;font-weight:600;color:#fff;background:var(--accent);
  border-radius:999px;padding:.15rem .7rem;flex:none}

/* ---- Program-CTA (artykuł) ---------------------------------------------- */
.program-cta{background:var(--carmine-10);border:1px solid var(--carmine-50);border-left:4px solid var(--carmine);
  border-radius:var(--radius-l);padding:1.6rem 1.7rem;margin:2.6rem 0}
.program-cta-h{font-family:var(--serif);margin:0 0 .4rem;color:var(--carmine-700)}
.program-cta-desc{color:var(--muted);margin:0 0 1.1rem}
.program-cta-actions{display:flex;flex-wrap:wrap;gap:.7rem}

/* ---- Artykuł ------------------------------------------------------------ */
.post{max-width:var(--measure);margin-inline:auto;padding-block:2.4rem 3.5rem}
.breadcrumbs{font-family:var(--sans);font-size:.82rem;color:var(--muted);margin-bottom:1.4rem;letter-spacing:.01em}
.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--carmine)}
.post-header{margin-bottom:2rem}
.post-title{font-size:clamp(2.1rem,4.5vw,3.2rem);line-height:1.06;margin:0 0 .8rem}
.post-lead{font-size:1.28rem;line-height:1.5;color:var(--muted);font-family:var(--sans);margin:0 0 1rem}
.post-meta{font-family:var(--sans);font-size:.85rem;color:var(--muted);letter-spacing:.02em;
  border-top:1px solid var(--line);padding-top:.9rem}
.post-cover{margin:0 0 2rem}.post-cover img{border-radius:var(--radius-l);width:100%}
.post-body{font-size:1.12rem;line-height:1.75}
.post-body>p:first-of-type::first-letter{font-family:var(--serif);font-weight:900;float:left;
  font-size:3.6rem;line-height:.8;padding:.3rem .6rem 0 0;color:var(--carmine)}
.post-body h2{margin:2.2em 0 .6em;font-size:clamp(1.6rem,3vw,2.1rem);
  border-left:5px solid var(--accent);padding-left:.8rem}
.post-body h3{margin:1.8em 0 .5em}
.post-body a{color:var(--carmine);text-decoration:underline;text-underline-offset:2px;
  text-decoration-color:var(--accent);text-decoration-thickness:2px}
.post-body a:hover{color:var(--accent)}
.post-body ul,.post-body ol{padding-left:1.3rem}.post-body li{margin:.4rem 0}

/* tabele danych */
.post-body table{border-collapse:collapse;width:100%;margin:1.8rem 0;font-family:var(--sans);font-size:.98rem}
.post-body th,.post-body td{border-bottom:1px solid var(--line);padding:.7rem .8rem;text-align:left}
.post-body thead th{font-weight:600;color:var(--carmine-700);border-bottom:2px solid var(--carmine);
  font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.post-body tbody tr:hover{background:var(--surface)}

/* cytat / pull-quote */
blockquote,.pullquote{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.35;
  font-style:italic;color:var(--carmine-700);border-left:3px solid var(--accent);
  margin:2rem 0;padding:.2rem 0 .2rem 1.5rem}
blockquote p:last-child{margin-bottom:0}
blockquote cite,.pullquote cite{display:block;font-family:var(--sans);font-style:normal;
  font-size:.95rem;font-weight:600;color:var(--muted);margin-top:.7rem}

/* callouty */
.callout{border-left:4px solid var(--accent);background:var(--surface);padding:1rem 1.2rem;
  border-radius:0 var(--radius) var(--radius) 0;margin:1.6rem 0;font-size:1.02rem}
.callout-info{border-left-color:var(--accent)}
.callout-warning{border-left-color:#c98a00;background:#fff8e6}
.callout-danger{border-left-color:#b3261e;background:#fdecea}

/* wykresy / diagramy */
.chart,.my-4{margin:2rem 0}.chart canvas{max-width:100%}
.mermaid,pre.mermaid{margin:2rem 0;text-align:center}
.content-figure{margin:2rem 0}.content-figure img{border-radius:var(--radius-l)}
.content-figure figcaption{font-family:var(--sans);font-size:.85rem;color:var(--muted);margin-top:.5rem;text-align:center}

/* tagi */
.post-tags{margin:2rem 0 0;display:flex;flex-wrap:wrap;gap:.5rem}
.tag{font-family:var(--sans);font-size:.82rem;background:transparent;color:var(--accent);
  border:1.5px solid var(--accent);border-radius:999px;padding:.2rem .8rem}
.tag:hover{text-decoration:none;background:var(--accent);color:#fff}

/* autor */
.author-card{display:flex;gap:1rem;align-items:center;margin:2.4rem 0;padding:1.2rem;
  background:var(--surface);border-radius:var(--radius-l)}
.author-avatar{border-radius:50%;flex:none}
.author-name{font-family:var(--serif);font-weight:700}
.author-bio{margin:.2rem 0 0;color:var(--muted);font-size:.92rem}

/* reverse silo / powiązane */
.related-links{margin:2.6rem 0 0;padding-top:1.6rem;border-top:4px solid var(--accent)}
.related-h{font-family:var(--serif);font-size:1.3rem;margin:0 0 .8rem}
.related-list{margin:.4rem 0;padding-left:1.1rem}.related-list li{margin:.45rem 0}
.silo-up{margin:.9rem 0 0;font-weight:600}

/* ---- Listy / taksonomie ------------------------------------------------- */
.list,.taxonomy{padding-block:2.4rem 3.5rem}
.list-header{margin-bottom:2rem;padding-bottom:1.2rem;border-bottom:4px solid var(--accent)}
.list-title{font-size:clamp(2rem,4vw,3rem);margin:0 0 .5rem}
.list-intro{color:var(--muted);font-size:1.12rem;max-width:var(--measure)}
.term-list{list-style:none;margin:0;padding:0}
.term-list li{display:flex;justify-content:space-between;gap:1rem;padding:1rem .2rem;border-bottom:1px solid var(--line)}
.term-list a{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.term-list a:hover{color:var(--accent);text-decoration:none}
.term-count{font-size:.8rem;color:var(--muted)}
.empty{color:var(--muted)}
.pagination{display:flex;gap:.6rem;justify-content:center;margin-top:2.5rem;font-family:var(--sans)}
.pagination a,.pagination span{padding:.4rem .8rem;border:1px solid var(--line);border-radius:var(--radius)}

/* ---- Footer ------------------------------------------------------------- */
.site-footer{margin-top:4rem;background:var(--ink);color:#cfc9cc;font-size:.95rem}
.site-footer a{color:#fff}.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem;padding-block:3rem 1.5rem}
@media(max-width:720px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{font-family:var(--serif);font-weight:900;font-size:1.4rem;color:#fff;display:block;margin-bottom:.4rem}
.footer-desc{color:#9b9398;margin:.3rem 0 0}
.footer-h{font-family:var(--sans);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin:0 0 .8rem}
.footer-col ul{list-style:none;margin:0;padding:0}.footer-col li{margin:.45rem 0}
.sitewide-links{list-style:none;margin:0;padding:0}.sitewide-links li{margin:.45rem 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.2rem;color:#9b9398;font-size:.85rem}
.footer-center{text-align:center;padding-block:2.5rem}
.footer-center .footer-brand{margin-bottom:.8rem}
.footer-inline{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;margin:.8rem 0}
.footer-recommend{margin:1rem 0}.footer-recommend .sitewide-links{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- Mobile ------------------------------------------------------------- */
@media(max-width:760px){
  .header-a .nav-list{position:absolute;top:68px;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--line);padding:.5rem 1.2rem;display:none;box-shadow:var(--shadow)}
  .header-a .nav-list.open{display:flex}
  .header-a .nav-list li{padding:.6rem 0;border-bottom:1px solid var(--line-soft)}
  .nav-toggle{display:block}
  .post-body>p:first-of-type::first-letter{font-size:3rem}
}
