/*
Theme Name: PSI Lite
Theme URI: https://example.local/
Author: Nova
Description: Lekki motyw WordPress bez Gutenberga, lokalne pliki, sekcje page.php sterowane z panelu edycji strony.
Version: 19.0.0
Text Domain: psi-lite
*/

/* =========================================================
   ROOT
   ========================================================= */
:root{
  color-scheme:light;
  --psi-bg:#ffffff;
  --psi-surface:#ffffff;
  --psi-text:#0b1220;
  --psi-muted:#1f2937;
  --psi-soft:#f8fafc;
  --psi-border:#d4dce8;
  --psi-blue:#064fb8;
  --psi-blue-hover:#003b8f;
  --psi-green:#047857;
  --psi-red:#991b1b;
  --psi-yellow:#92400e;
  --psi-lcp:#d1fae5;
  --psi-cls:#dbeafe;
  --psi-space-1:8px;
  --psi-space-2:16px;
  --psi-space-3:24px;
  --psi-space-4:32px;
  --psi-space-5:40px;
  --psi-space-6:48px;
  --psi-radius:14px;
  --psi-radius-sm:10px;
  --psi-shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --psi-shadow-sm:0 4px 12px rgba(15,23,42,.05);
  --psi-shadow:0 8px 24px rgba(15,23,42,.06);
  --psi-shadow-hover:0 14px 34px rgba(15,23,42,.10);
  --psi-transition:160ms ease;
  --psi-max:760px;
  --psi-wide:900px;
  --psi-related:1100px;
}

/* =========================================================
   RESET / BASE
   ========================================================= */
*{box-sizing:border-box}

html{
  font-size:16px;
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}

body{
  margin:0;
  background:var(--psi-bg);
  color:var(--psi-text);
  font-family:Arial,Helvetica,sans-serif;
  font-size:15px;
  line-height:1.65;
  text-rendering:optimizeSpeed;
}

img,svg{
  max-width:100%;
  height:auto;
  display:block;
}

p{
  margin:0 0 14px;
  color:var(--psi-muted);
}

h1,h2,h3,h4{
  line-height:1.22;
  margin:0 0 14px;
  color:var(--psi-text);
  font-weight:800;
}

h1{
  font-size:34px;
  letter-spacing:-.03em;
}

h2{
  font-size:23px;
  letter-spacing:-.02em;
}

h3{font-size:18px}
h4{font-size:14px}

a{
  color:var(--psi-blue);
  font-weight:700;
  text-decoration:none;
}

a:hover{
  color:var(--psi-blue-hover);
  text-decoration:underline;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:3px solid rgba(6,79,184,.42);
  outline-offset:3px;
}

::selection{
  background:var(--psi-blue);
  color:#fff;
}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.psi-site-header{
  border-bottom:1px solid var(--psi-border);
  background:#fff;
}

.psi-header-inner{
  width:min(100% - 32px, var(--psi-wide));
  min-height:58px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--psi-space-2);
}

.psi-brand{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--psi-text);
  font-weight:800;
}

.psi-brand:hover{text-decoration:none}

.psi-logo-dot{
  width:22px;
  height:22px;
  border-radius:999px;
  background:conic-gradient(from 35deg,#4285f4,#34a853,#fbbc04,#ea4335,#4285f4);
  position:relative;
  flex:0 0 22px;
}

.psi-logo-dot:after{
  content:"";
  position:absolute;
  inset:5px;
  border-radius:999px;
  background:#fff;
}

.psi-nav-wrap{
  display:flex;
  align-items:center;
  gap:var(--psi-space-2);
}

.psi-top-nav{
  display:flex;
  align-items:center;
  gap:var(--psi-space-2);
  font-size:13px;
}

.psi-top-nav ul{
  display:flex;
  align-items:center;
  gap:var(--psi-space-2);
  list-style:none;
  margin:0;
  padding:0;
}

.psi-top-nav a{
  color:#0f172a;
  font-weight:700;
}

.psi-lang{
  display:flex;
  align-items:center;
  gap:6px;
  color:var(--psi-muted);
  font-size:12px;
}

.psi-flag{font-size:13px}

.psi-menu-toggle{
  display:none;
  width:42px;
  height:42px;
  border:1px solid var(--psi-border);
  border-radius:10px;
  background:#fff;
  color:var(--psi-text);
  align-items:center;
  justify-content:center;
  cursor:pointer;
}

.psi-menu-toggle span,
.psi-menu-toggle span:before,
.psi-menu-toggle span:after{
  display:block;
  width:18px;
  height:2px;
  background:currentColor;
  border-radius:999px;
  position:relative;
}

.psi-menu-toggle span:before,
.psi-menu-toggle span:after{
  content:"";
  position:absolute;
  left:0;
}

.psi-menu-toggle span:before{top:-6px}
.psi-menu-toggle span:after{top:6px}
.psi-menu-toggle[aria-expanded="true"] span{background:transparent}
.psi-menu-toggle[aria-expanded="true"] span:before{top:0;transform:rotate(45deg)}
.psi-menu-toggle[aria-expanded="true"] span:after{top:0;transform:rotate(-45deg)}

/* =========================================================
   LAYOUT
   ========================================================= */
.psi-main{
  width:min(100% - 32px, var(--psi-max));
  margin:0 auto;
  padding:56px 0 64px;
}

.psi-main--wide{
  width:min(100% - 32px, var(--psi-wide));
}

.psi-page-head{
  text-align:center;
  margin-bottom:var(--psi-space-4);
}

.psi-page-head__kicker{
  font-size:13px;
  color:var(--psi-muted);
  margin-bottom:8px;
}

.psi-page-head__lead{
  font-size:16px;
  color:var(--psi-muted);
  margin:0;
}

.psi-section{
  margin:0 0 42px;
}

.psi-section:last-child{margin-bottom:0}

.psi-section-head{
  margin-bottom:var(--psi-space-2);
}

.psi-section-head--center{text-align:center}

.psi-section-title{
  margin-bottom:8px;
}

.psi-section-lead{
  color:var(--psi-muted);
  max-width:680px;
}

.psi-section-head--center .psi-section-lead{
  margin-left:auto;
  margin-right:auto;
}

/* Dynamic contrast classes from PHP */
.psi-section.is-dark-bg,
.psi-section.is-dark-bg h2,
.psi-section.is-dark-bg h3,
.psi-section.is-dark-bg p,
.psi-section.is-dark-bg .psi-section-lead{
  color:#fff !important;
}

.psi-section.is-dark-bg a{
  color:#bfdbfe;
}

.psi-section.is-light-bg{
  color:var(--psi-text);
}

.psi-section.is-light-bg .psi-section-lead{
  color:var(--psi-muted) !important;
}

/* =========================================================
   GENERIC CARDS / COMPONENTS
   ========================================================= */
.psi-card{
  background:#fff;
  border:1px solid var(--psi-border);
  border-radius:var(--psi-radius);
  box-shadow:0 1px 2px rgba(15,23,42,.02);
}

.psi-card-pad{padding:24px}

.psi-soft-card,
.psi-hero-mission,
.psi-cta{
  background:linear-gradient(110deg,#eef6ff 0%,#effcf4 100%);
  border-radius:var(--psi-radius);
}

.psi-soft-card{padding:28px}
.psi-muted-card{background:var(--psi-soft);border-radius:var(--psi-radius-sm);padding:18px}

.psi-hero-mission{padding:30px}
.psi-hero-mission h2{font-size:20px}

.psi-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.psi-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.psi-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

.psi-metric-card{
  padding:var(--psi-space-3);
  min-height:150px;
}

.psi-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:42px;
  min-height:42px;
  border-radius:10px;
  padding:8px;
  font-weight:900;
  font-size:17px;
  margin-bottom:16px;
  color:#111827;
}

.psi-badge--lcp{background:var(--psi-lcp);color:#047857}
.psi-badge--inp{background:#fff;color:#111827}
.psi-badge--cls{background:var(--psi-cls);color:#1d4ed8}
.psi-badge--blue{background:#dbeafe;color:#003b8f}
.psi-badge--green{background:#dcfce7;color:#047857}
.psi-badge--yellow{background:#fef3c7;color:#92400e}
.psi-badge--red{background:#fee2e2;color:#991b1b}
.psi-badge--gray{background:#f1f5f9;color:#334155}

.psi-card-title{
  font-weight:900;
  margin-bottom:4px;
}

.psi-card-subtitle,
.psi-card-text{
  color:var(--psi-muted);
  font-size:13px;
}

.psi-card-subtitle{margin-bottom:12px}
.psi-card-text{margin:0}

.psi-api-card{
  display:flex;
  align-items:flex-start;
  gap:var(--psi-space-2);
  padding:var(--psi-space-3);
}

.psi-api-icon{
  width:34px;
  height:34px;
  flex:0 0 34px;
  color:#334155;
}

.psi-api-card h3{
  font-size:15px;
  margin-bottom:6px;
}

.psi-api-card p{
  color:var(--psi-muted);
  font-size:13px;
  margin-bottom:10px;
}

/* =========================================================
   STATS / TABS / LISTS
   ========================================================= */
.psi-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--psi-space-2);
}

.psi-stat{
  text-align:center;
  background:var(--psi-soft);
  border-radius:12px;
  padding:22px 16px;
  color:var(--psi-text);
}

.psi-stat strong{
  display:block;
  font-size:30px;
  line-height:1;
  color:var(--psi-blue);
  margin-bottom:8px;
  font-weight:900;
}

.psi-stat:nth-child(2) strong{color:var(--psi-red)}
.psi-stat:nth-child(3) strong{color:var(--psi-green)}

.psi-stat span{
  display:block;
  color:var(--psi-muted);
  font-size:12px;
  line-height:1.35;
}

.psi-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  background:var(--psi-soft);
  border-radius:10px;
  padding:8px;
  margin-bottom:var(--psi-space-3);
}

.psi-tab{
  border:0;
  border-radius:7px;
  padding:7px 10px;
  font-weight:900;
  font-size:12px;
  color:#0b1220;
  background:#e2e8f0;
}

.psi-tab:first-child,
.psi-tab.active{
  background:#dbeafe;
  color:#003b8f;
}

.psi-term-card{
  display:grid;
  grid-template-columns:52px 1fr;
  gap:var(--psi-space-2);
  padding:var(--psi-space-3);
}

.psi-term-card .psi-badge{margin:0}

.psi-thresholds{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin-top:14px;
}

.psi-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:6px 11px;
  background:#f1f5f9;
  font-size:12px;
  font-weight:900;
}

.psi-pill--good{background:#d1fae5;color:#065f46}
.psi-pill--mid{background:#fef3c7;color:#78350f}
.psi-pill--bad{background:#fee2e2;color:#991b1b}

.psi-list-cards{
  display:grid;
  gap:var(--psi-space-2);
}

.psi-list-card{
  padding:var(--psi-space-3);
  background:var(--psi-soft);
  border-radius:10px;
}

.psi-list-card h3{
  font-size:15px;
  margin-bottom:6px;
}

.psi-list-card p{
  font-size:13px;
  color:var(--psi-muted);
  margin:0;
}

/* =========================================================
   STEPS / SCORE / RESOURCES
   ========================================================= */
.psi-steps{
  counter-reset:step;
  display:grid;
  gap:var(--psi-space-2);
}

.psi-step{
  display:grid;
  grid-template-columns:30px 1fr;
  gap:var(--psi-space-2);
}

.psi-step:before{
  counter-increment:step;
  content:counter(step);
  width:24px;
  height:24px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dbeafe;
  color:#003b8f;
  font-weight:900;
  font-size:12px;
}

.psi-step:nth-child(2):before{background:#fee2e2;color:#991b1b}
.psi-step:nth-child(3):before{background:#fef3c7;color:#78350f}
.psi-step:nth-child(4):before{background:#dcfce7;color:#065f46}

.psi-step h3{
  font-size:14px;
  margin-bottom:3px;
}

.psi-step p{
  font-size:13px;
  color:var(--psi-muted);
  margin:0;
}

.psi-score-row{
  display:flex;
  flex-wrap:wrap;
  gap:var(--psi-space-2);
}

.psi-score{
  display:flex;
  align-items:center;
  gap:9px;
  padding:11px 16px;
  border-radius:7px;
  background:#f1f5f9;
  font-size:13px;
  color:var(--psi-text);
}

.psi-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#334155;
}

.psi-dot--green{background:#047857}
.psi-dot--yellow{background:#b45309}
.psi-dot--red{background:#dc2626}

.psi-link-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--psi-space-2);
}

.psi-resource-card{
  display:grid;
  grid-template-columns:42px 1fr;
  gap:var(--psi-space-2);
  padding:var(--psi-space-3);
}

.psi-resource-icon{
  width:34px;
  height:34px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
}

.psi-resource-card h3{
  font-size:15px;
  margin-bottom:6px;
}

.psi-resource-card p{
  font-size:13px;
  color:var(--psi-muted);
  margin:0;
}

.psi-doc-toc{
  background:var(--psi-soft);
  border-radius:12px;
  padding:var(--psi-space-3);
}

.psi-doc-toc strong{
  display:block;
  margin-bottom:10px;
}

.psi-doc-toc a{
  display:block;
  margin:6px 0;
  font-size:13px;
}

.psi-metrics-lines{
  border-left:4px solid var(--psi-blue);
  padding-left:18px;
  display:grid;
  gap:var(--psi-space-2);
}

.psi-metric-line h3{
  font-size:15px;
  margin-bottom:4px;
}

.psi-metric-line p{
  font-size:13px;
  color:var(--psi-muted);
  margin-bottom:8px;
}

.psi-metric-line:nth-child(1){border-color:#047857}
.psi-metric-line:nth-child(2){border-color:#b45309}
.psi-metric-line:nth-child(3){border-color:#1d4ed8}

/* =========================================================
   CTA / BUTTONS
   ========================================================= */
.psi-cta{
  text-align:center;
  padding:var(--psi-space-4);
  color:var(--psi-text);
}

.psi-cta h2{font-size:20px}

.psi-button,
.psi-search-form button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  padding:0 22px;
  border-radius:999px;
  background:var(--psi-blue);
  color:#fff;
  font-weight:900;
  font-size:13px;
  border:0;
  cursor:pointer;
}

.psi-button:hover,
.psi-search-form button:hover{
  color:#fff;
  text-decoration:none;
  background:var(--psi-blue-hover);
}

.psi-button--green{
  background:#047857;
}

/* =========================================================
   BLOG / ARCHIVES / POST CARDS
   ========================================================= */
.psi-archive-head{
  margin-bottom:var(--psi-space-4);
}

.psi-archive-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#003b8f;
  background:#eff6ff;
  border-radius:999px;
  padding:6px 11px;
  font-size:12px;
  font-weight:900;
  margin-bottom:14px;
}

.psi-post-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--psi-space-2);
}

.psi-post-grid--2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.psi-post-card{
  display:flex;
  flex-direction:column;
  min-width:0;
  height:100%;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--psi-border);
  border-radius:16px;
  box-shadow:var(--psi-shadow);
  transition:box-shadow .2s ease, transform .2s ease;
}

.psi-post-card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(0,0,0,.08);
}

.psi-post-card__media{
  display:block;
  width:100%;
  aspect-ratio:16/9;
  background:#f8fafc;
  overflow:hidden;
  contain:layout paint;
}

.psi-post-card__media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:0;
}

.psi-post-card__media > span{
  display:block;
  width:100%;
  height:100%;
  background:
    radial-gradient(circle at 25% 25%, rgba(66,133,244,.18), transparent 32%),
    radial-gradient(circle at 75% 45%, rgba(52,168,83,.18), transparent 34%),
    linear-gradient(110deg,#eff6ff,#f8fafc 48%,#f0fdf4);
}

.psi-post-card__body{
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  padding:var(--psi-space-3);
  background:#fff;
}

.psi-post-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  color:var(--psi-muted);
  font-size:12px;
  margin-bottom:12px;
}

.psi-post-card__cat{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  background:#dbeafe;
  color:#002f6c;
  border:1px solid #6da7f7;
  font-size:11px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.psi-post-card h2,
.psi-post-card h3{
  display:block;
  font-size:19px;
  line-height:1.28;
  letter-spacing:-.02em;
  margin:0 0 12px;
}

.psi-post-card h2 a,
.psi-post-card h3 a{
  color:var(--psi-text);
}

.psi-post-card__excerpt{
  display:block;
  color:var(--psi-muted);
  font-size:14px;
  line-height:1.55;
  margin:0 0 18px;
}

.psi-read-more{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:32px;
  margin-top:auto;
  color:var(--psi-blue);
  font-weight:900;
  font-size:14px;
}

.psi-blog-section{
  margin-top:var(--psi-space-6);
}

.psi-blog-section .psi-section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
}

.psi-pagination{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:34px;
}

.psi-pagination .page-numbers{
  min-width:38px;
  min-height:38px;
  border:1px solid var(--psi-border);
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  color:var(--psi-text);
  background:#fff;
  font-weight:900;
}

.psi-pagination .page-numbers.current{
  background:var(--psi-blue);
  color:#fff;
  border-color:var(--psi-blue);
}

/* =========================================================
   SINGLE POST
   ========================================================= */
.psi-single{
  width:min(100% - 32px, var(--psi-max));
  margin:0 auto;
  padding:56px 0 64px;
}

.psi-single-head{
  text-align:center;
  margin-bottom:var(--psi-space-4);
}

.psi-single-title{
  font-size:38px;
}

.psi-single-meta{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  color:var(--psi-muted);
  font-size:13px;
  margin-top:10px;
}

.psi-single-meta a{
  color:var(--psi-blue);
  font-weight:800;
}

.psi-content{
  font-size:16px;
  line-height:1.75;
  overflow-anchor:auto;
}

.psi-content h2{margin-top:36px}
.psi-content h3{margin-top:28px}

.psi-content ul,
.psi-content ol{
  padding-left:24px;
}

.psi-content figure,
.psi-content .wp-caption{
  max-width:100%;
  margin:28px auto;
  background:#f8fafc;
}

.psi-content figure.aligncenter,
.psi-content .wp-caption.aligncenter{
  margin-left:auto;
  margin-right:auto;
}

.psi-content figure.alignleft,
.psi-content .wp-caption.alignleft,
.psi-content img.alignleft,
.psi-content figure.alignright,
.psi-content .wp-caption.alignright,
.psi-content img.alignright{
  float:none;
  margin:28px auto;
}

.psi-content img,
.psi-content .wp-caption img{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  border-radius:12px;
  opacity:1;
  filter:none;
  transform:none;
  transition:none;
}

.psi-content .wp-caption-text,
.psi-content figcaption{
  margin-top:7px;
  color:var(--psi-muted);
  font-size:13px;
  line-height:1.4;
}

.psi-content blockquote{
  margin:28px 0;
  padding:var(--psi-space-3);
  border-left:4px solid var(--psi-blue);
  background:var(--psi-soft);
  border-radius:0 12px 12px 0;
}

/* Categories + tags under content */
.psi-post-footer-meta{
  margin-top:var(--psi-space-5);
  padding:22px 0 0;
  border-top:1px solid var(--psi-border);
  display:grid;
  gap:var(--psi-space-2);
}

.psi-post-footer-row{
  display:grid;
  grid-template-columns:112px 1fr;
  gap:var(--psi-space-2);
  align-items:start;
}

.psi-post-footer-label{
  color:var(--psi-text);
  font-size:13px;
  font-weight:900;
  letter-spacing:.01em;
  padding-top:5px;
}

.psi-post-footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.psi-post-footer-links a,
.psi-post-footer-links span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:6px 12px;
  border-radius:999px;
  background:#eff6ff;
  color:#003b8f;
  border:1px solid #7fb4ff;
  font-size:12px;
  line-height:1.1;
  font-weight:900;
  text-decoration:none;
}

.psi-post-footer-links a:hover{
  background:#dbeafe;
  text-decoration:none;
}

.psi-post-footer-links--tags a,
.psi-post-footer-links--tags span{
  background:#f8fafc;
  color:#111827;
  border:1px solid #cbd5e1;
}

.psi-post-footer-links--tags a:hover{
  background:#eef2f7;
}

/* Author box */
.psi-author-box{
  margin-top:34px;
  padding:var(--psi-space-3);
  border:1px solid var(--psi-border);
  border-radius:18px;
  background:linear-gradient(110deg,#f8fbff 0%,#f8fffb 100%);
  display:grid;
  grid-template-columns:72px 1fr;
  gap:var(--psi-space-2);
  align-items:start;
  contain:layout paint;
}

.psi-author-box__avatar{
  width:72px;
  height:72px;
  border-radius:999px;
  background:linear-gradient(135deg,#dbeafe,#dcfce7);
  color:#003b8f;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  font-weight:900;
  border:1px solid #b9d4ff;
  overflow:hidden;
  flex:0 0 72px;
}

.psi-author-box__avatar img{
  width:72px;
  height:72px;
  border-radius:999px;
  object-fit:cover;
}

.psi-author-box h2{
  font-size:20px;
  margin:0 0 6px;
}

.psi-author-box p{
  color:var(--psi-muted);
  margin:0 0 12px;
}

.psi-author-box a{
  color:var(--psi-blue);
  font-weight:900;
}

.psi-post-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--psi-space-2);
  margin-top:var(--psi-space-5);
  overflow-anchor:none;
}

.psi-post-nav a{
  display:block;
  border:1px solid var(--psi-border);
  border-radius:var(--psi-radius);
  padding:var(--psi-space-2);
  color:var(--psi-text);
  background:#fff;
}

.psi-post-nav span{
  display:block;
  color:var(--psi-muted);
  font-size:12px;
  margin-bottom:6px;
}

/* Related posts full width */
.psi-related-full{
  width:100%;
  background:#fff;
  border-top:1px solid var(--psi-border);
  padding:42px 0 70px;
  margin:0;
}

.psi-related-full .psi-main{
  width:min(100% - 32px, var(--psi-related));
  padding:0;
}

.psi-related-full .psi-section-head{
  display:block;
  margin-bottom:var(--psi-space-3);
}

.psi-related-full .psi-section-title{
  font-size:26px;
  margin-bottom:7px;
}

.psi-related-full .psi-section-lead{
  font-size:14px;
  color:var(--psi-muted);
  max-width:none;
}

.psi-related-full .psi-post-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:26px;
}

/* =========================================================
   BREADCRUMBS / SEARCH / 404
   ========================================================= */
.psi-breadcrumb{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
  color:var(--psi-muted);
  font-size:13px;
  margin-bottom:20px;
}

.psi-breadcrumb a{
  color:var(--psi-blue);
  font-weight:800;
}

.psi-breadcrumb span{
  color:var(--psi-muted);
}

.psi-empty{
  text-align:center;
  padding:60px 28px;
  background:linear-gradient(110deg,#edf6ff 0%,#effcf4 100%);
  border-radius:var(--psi-radius);
  color:var(--psi-text);
}

.psi-empty__code{
  font-size:74px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.06em;
  color:var(--psi-blue);
  margin-bottom:16px;
}

.psi-search-form{
  display:flex;
  gap:10px;
  margin:24px auto 0;
  max-width:560px;
}

.psi-search-form input[type="search"]{
  flex:1;
  min-height:44px;
  border:1px solid var(--psi-border);
  border-radius:999px;
  padding:0 16px;
  font:inherit;
  color:var(--psi-text);
}

/* =========================================================
   FOOTER
   ========================================================= */
.psi-footer{
  border-top:1px solid var(--psi-border);
  background:#fff;
  color:var(--psi-muted);
}

.psi-footer-inner{
  width:min(100% - 32px,var(--psi-wide));
  margin:0 auto;
  padding:48px 0 28px;
}

.psi-footer-cols{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:60px;
  padding-bottom:40px;
  border-bottom:1px solid var(--psi-border);
}

.psi-footer h3{
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
  color:var(--psi-text);
  margin-bottom:16px;
}

.psi-footer ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:11px;
}

.psi-footer a,
.psi-footer li{
  font-size:13px;
  color:var(--psi-blue);
}

.psi-footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--psi-space-2);
  padding-top:24px;
  color:var(--psi-muted);
  font-size:12px;
}

.psi-back{
  display:inline-flex;
  align-items:center;
  gap:7px;
  margin-top:18px;
  font-size:13px;
}

/* =========================================================
   MOBILE
   ========================================================= */
@media (max-width:900px){
  .psi-related-full .psi-post-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:760px){
  body{
    font-size:15px;
  }

  h1{
    font-size:28px;
  }

  .psi-header-inner{
    display:grid;
    grid-template-columns:1fr auto;
    min-height:auto;
    padding:14px 0;
    align-items:center;
  }

  .psi-menu-toggle{
    display:inline-flex;
  }

  .psi-nav-wrap{
    grid-column:1/-1;
    display:none;
    width:100%;
    padding:14px 0 4px;
    border-top:1px solid var(--psi-border);
  }

  body.psi-menu-open .psi-nav-wrap{
    display:block;
  }

  .psi-top-nav,
  .psi-top-nav ul{
    display:block;
    width:100%;
  }

  .psi-top-nav ul{
    margin-top:8px;
  }

  .psi-top-nav li{
    margin:0;
    border-bottom:1px solid #f1f5f9;
  }

  .psi-top-nav a{
    display:block;
    min-height:44px;
    padding:12px 0;
    font-size:15px;
  }

  .psi-lang{
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid #f1f5f9;
  }

  .psi-grid-3,
  .psi-grid-2,
  .psi-grid-4,
  .psi-stats,
  .psi-link-grid,
  .psi-footer-cols,
  .psi-post-grid,
  .psi-post-grid--2,
  .psi-related-full .psi-post-grid{
    grid-template-columns:1fr;
  }

  .psi-main{
    padding:34px 0 44px;
  }

  .psi-page-head{
    text-align:left;
  }

  .psi-hero-mission,
  .psi-soft-card,
  .psi-cta{
    padding:var(--psi-space-3);
  }

  .psi-term-card,
  .psi-resource-card{
    grid-template-columns:1fr;
  }

  .psi-api-card{
    display:block;
  }

  .psi-api-icon{
    margin-bottom:12px;
  }

  .psi-blog-section .psi-section-head{
    display:block;
  }

  .psi-single{
    padding:34px 0 44px;
  }

  .psi-single-title{
    font-size:30px;
  }

  .psi-content{
    font-size:16px;
  }

  .psi-content figure,
  .psi-content .wp-caption{
    margin:22px auto;
  }

  .psi-post-footer-row{
    grid-template-columns:1fr;
    gap:8px;
  }

  .psi-post-footer-label{
    padding-top:0;
  }

  .psi-author-box{
    grid-template-columns:1fr;
    padding:var(--psi-space-3);
  }

  .psi-post-nav{
    grid-template-columns:1fr;
  }

  .psi-related-full{
    padding:34px 0 48px;
  }

  .psi-related-full .psi-main{
    width:min(100% - 28px, var(--psi-related));
  }

  .psi-related-full .psi-section-title{
    font-size:22px;
  }

  .psi-related-full .psi-post-grid{
    gap:var(--psi-space-2);
  }

  .psi-related-full .psi-post-card__body{
    padding:var(--psi-space-2);
  }

  .psi-search-form{
    display:block;
  }

  .psi-search-form input[type="search"],
  .psi-search-form button{
    width:100%;
  }

  .psi-search-form button{
    margin-top:10px;
  }

  .psi-footer-bottom{
    display:block;
  }

  .psi-footer-bottom > * + *{
    margin-top:12px;
  }
}

/* =========================================================
   REDUCED MOTION / PERFORMANCE
   ========================================================= */
@media (hover:none){
  .psi-post-card:hover{
    transform:none;
    box-shadow:0 1px 2px rgba(15,23,42,.02);
  }
}

@media (prefers-reduced-motion:reduce){
  *,
  *:before,
  *:after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* =========================================================
   PLUGIN COMPAT: AWP + BB24 COOKIE CONSENT
   ========================================================= */
.awp-artykuly-container{
  margin:2.2em 0;
  padding:20px 22px;
  border:1px solid var(--psi-border);
  border-radius:var(--psi-radius);
  background:#fff;
  color:var(--psi-text);
  box-shadow:var(--psi-shadow);
}

.awp-heading{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  padding-bottom:12px;
  border-bottom:1px solid var(--psi-border);
  font-size:.74rem;
  font-weight:900;
  line-height:1.25;
  letter-spacing:.075em;
  text-transform:uppercase;
  color:#334155;
}

.awp-heading strong,
.awp-heading span,
.awp-icon{
  color:inherit;
  opacity:1;
}

.awp-lista a{
  color:var(--psi-text);
}

.awp-lista a:hover,
.awp-lista a:focus-visible{
  color:var(--psi-blue);
  text-decoration:underline;
  text-underline-offset:3px;
}

.awp-lista .arrow{
  color:#475569;
}

.bb24-cookie-banner{
  background:#0b1220;
  color:#fff;
  font-family:Arial,Helvetica,sans-serif;
}

.bb24-cookie-text,
.bb24-cookie-text strong{
  color:#fff;
  opacity:1;
}

.bb24-cookie-link{
  color:#bfdbfe;
  font-weight:900;
}

.bb24-btn--primary{
  background:#047857;
  color:#fff;
}

.bb24-btn--primary:hover{
  background:#065f46;
  color:#fff;
}

.bb24-btn--ghost{
  background:#fff;
  color:#0b1220;
}



/* =========================================================
   DESIGN SYSTEM v17 — 8px spacing, unified radius/shadow,
   PSI-like hover states and lightweight micro-interactions
   ========================================================= */

/* 8px spacing system */
.psi-section{
  margin-bottom:var(--psi-space-5);
}

.psi-section-head{
  margin-bottom:var(--psi-space-2);
}

.psi-grid-2,
.psi-grid-3,
.psi-grid-4,
.psi-post-grid,
.psi-link-grid,
.psi-stats,
.psi-list-cards,
.psi-steps,
.psi-score-row,
.psi-thresholds,
.psi-footer-cols,
.psi-post-footer-links{
  gap:var(--psi-space-2);
}

/* Unified radius system */
.psi-card,
.psi-soft-card,
.psi-hero-mission,
.psi-muted-card,
.psi-metric-card,
.psi-list-card,
.psi-resource-card,
.psi-api-card,
.psi-term-card,
.psi-stat,
.psi-score,
.psi-cta,
.psi-empty,
.psi-post-card,
.psi-post-nav a,
.psi-author-box,
.psi-search-form input[type="search"],
.psi-button,
.psi-search-form button,
.psi-doc-toc,
.awp-artykuly-container{
  border-radius:var(--psi-radius);
}

/* Smaller elements use smaller radius */
.psi-badge,
.psi-tab,
.psi-resource-icon,
.psi-pagination .page-numbers,
.psi-menu-toggle{
  border-radius:var(--psi-radius-sm);
}

/* Unified shadow system */
.psi-card,
.psi-post-card,
.psi-author-box,
.psi-api-card,
.psi-resource-card,
.psi-term-card,
.awp-artykuly-container{
  box-shadow:var(--psi-shadow-xs);
}

.psi-soft-card,
.psi-hero-mission,
.psi-cta,
.psi-empty{
  box-shadow:none;
}

/* Card polish */
.psi-card,
.psi-post-card,
.psi-api-card,
.psi-resource-card,
.psi-term-card,
.psi-list-card,
.psi-stat,
.psi-post-nav a{
  border:1px solid var(--psi-border);
  background:#fff;
}

/* PSI-like hover states: subtle, accessible, no layout shift */
.psi-card,
.psi-post-card,
.psi-resource-card,
.psi-api-card,
.psi-term-card,
.psi-list-card,
.psi-post-nav a,
.psi-button,
.psi-search-form button,
.psi-pagination .page-numbers,
.psi-post-footer-links a,
.psi-read-more,
.awp-lista a{
  transition:
    background-color var(--psi-transition),
    border-color var(--psi-transition),
    box-shadow var(--psi-transition),
    color var(--psi-transition),
    transform var(--psi-transition);
}

.psi-card:hover,
.psi-post-card:hover,
.psi-resource-card:hover,
.psi-api-card:hover,
.psi-term-card:hover,
.psi-list-card:hover,
.psi-post-nav a:hover{
  transform:translateY(-1px);
  border-color:#b8c5d8;
  box-shadow:var(--psi-shadow-sm);
  text-decoration:none;
}

.psi-post-card:hover{
  box-shadow:var(--psi-shadow-hover);
}

/* Button hover: no filter, stable paint */
.psi-button:hover,
.psi-search-form button:hover{
  transform:translateY(-1px);
  box-shadow:var(--psi-shadow-sm);
}

/* Link micro-interaction */
.psi-read-more{
  position:relative;
  width:max-content;
  text-underline-offset:3px;
}

.psi-read-more:hover{
  transform:translateX(2px);
  text-decoration:none;
}

/* Category / tag chips */
.psi-post-card__cat,
.psi-post-footer-links a,
.psi-post-footer-links span,
.psi-pill,
.psi-archive-kicker{
  border-radius:999px;
}

/* Content rhythm based on 8px grid */
.psi-main{
  padding-top:var(--psi-space-6);
  padding-bottom:var(--psi-space-6);
}

.psi-page-head{
  margin-bottom:var(--psi-space-4);
}

.psi-hero-mission,
.psi-soft-card,
.psi-cta{
  padding:var(--psi-space-4);
}

.psi-card-pad,
.psi-metric-card,
.psi-list-card,
.psi-resource-card,
.psi-term-card,
.psi-api-card,
.psi-author-box{
  padding:var(--psi-space-3);
}

.psi-post-card__body{
  padding:var(--psi-space-3);
}

.psi-post-card__meta{
  margin-bottom:var(--psi-space-1);
}

.psi-post-card h2,
.psi-post-card h3{
  margin-bottom:var(--psi-space-1);
}

.psi-post-card__excerpt{
  margin-bottom:var(--psi-space-2);
}

/* More consistent metric cards */
.psi-metric-card{
  min-height:160px;
}

/* PageSpeed safe: disable transform effects on touch and reduced motion */
@media (hover:none), (prefers-reduced-motion:reduce){
  .psi-card:hover,
  .psi-post-card:hover,
  .psi-resource-card:hover,
  .psi-api-card:hover,
  .psi-term-card:hover,
  .psi-list-card:hover,
  .psi-post-nav a:hover,
  .psi-button:hover,
  .psi-search-form button:hover,
  .psi-read-more:hover{
    transform:none;
  }
}

/* Mobile spacing remains compact but aligned to 8px grid */
@media (max-width:760px){
  .psi-main,
  .psi-single{
    padding-top:var(--psi-space-4);
    padding-bottom:var(--psi-space-5);
  }

  .psi-section{
    margin-bottom:var(--psi-space-4);
  }

  .psi-hero-mission,
  .psi-soft-card,
  .psi-cta,
  .psi-card-pad,
  .psi-metric-card,
  .psi-list-card,
  .psi-resource-card,
  .psi-term-card,
  .psi-api-card,
  .psi-author-box,
  .psi-post-card__body{
    padding:var(--psi-space-2);
  }
}


/* =========================================================
   v18 — FINAL radius consistency + frontend section icons
   ========================================================= */

:root{
  --psi-radius:18px;
  --psi-radius-sm:12px;
  --psi-radius-pill:999px;
}

/* Jeden system zaokrągleń — wymuszone na wszystkich boxach */
.psi-card,
.psi-soft-card,
.psi-hero-mission,
.psi-muted-card,
.psi-metric-card,
.psi-list-card,
.psi-resource-card,
.psi-api-card,
.psi-term-card,
.psi-stat,
.psi-score,
.psi-cta,
.psi-empty,
.psi-post-card,
.psi-post-nav a,
.psi-author-box,
.psi-search-form input[type="search"],
.psi-doc-toc,
.awp-artykuly-container{
  border-radius:var(--psi-radius) !important;
}

.psi-badge,
.psi-tab,
.psi-resource-icon,
.psi-pagination .page-numbers,
.psi-menu-toggle{
  border-radius:var(--psi-radius-sm) !important;
}

.psi-button,
.psi-search-form button,
.psi-post-card__cat,
.psi-post-footer-links a,
.psi-post-footer-links span,
.psi-pill,
.psi-archive-kicker,
.psi-single-tax a,
.psi-single-tax span{
  border-radius:var(--psi-radius-pill) !important;
}

/* Misja miała wyglądać jak część tego samego systemu */
.psi-hero-mission{
  overflow:hidden;
}

/* Ikony sekcji na froncie */
.psi-section-head{
  display:flex;
  align-items:flex-start;
  gap:14px;
}

.psi-section-icon{
  width:34px;
  height:34px;
  min-width:34px;
  border-radius:var(--psi-radius-sm);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#eff6ff;
  color:var(--psi-blue);
  margin-top:1px;
}

.psi-section-icon svg{
  width:22px;
  height:22px;
  display:block;
}

.psi-section-head__text{
  min-width:0;
  flex:1;
}

.psi-section-title{
  margin-bottom:6px;
}

.psi-hero-mission__head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:12px;
}

.psi-hero-mission__icon{
  width:38px;
  height:38px;
  min-width:38px;
  border-radius:var(--psi-radius-sm);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.72);
  color:var(--psi-blue);
}

.psi-hero-mission__icon svg{
  width:22px;
  height:22px;
  display:block;
}

.psi-hero-mission__head h2{
  margin:0;
}

/* Dynamiczny kolor ikony nadpisuje SVG path przez currentColor */
.psi-section-icon svg path,
.psi-hero-mission__icon svg path{
  fill:currentColor;
}

/* CTA icon */
.psi-cta .psi-section-icon{
  margin:0 auto 12px;
}

/* Mobile */
@media (max-width:760px){
  .psi-section-head{
    gap:12px;
  }

  .psi-section-icon{
    width:32px;
    height:32px;
    min-width:32px;
  }

  .psi-hero-mission__head{
    align-items:flex-start;
  }
}


/* =========================================================
   v19 — HARD RADIUS FIX
   Sekcja z kolorem tła też musi mieć radius, bo tło siedzi na .psi-section
   ========================================================= */

:root{
  --psi-radius:22px;
  --psi-radius-sm:14px;
}

/* Radius na samym kontenerze sekcji, bo inline background jest właśnie na .psi-section */
.psi-section{
  border-radius:var(--psi-radius) !important;
  overflow:hidden;
}

/* Sekcje z własnym tłem dostają padding, żeby radius był widoczny jak w mockupie */
.psi-section[style*="background"]{
  padding:var(--psi-space-4) !important;
}

/* W mission nie może być podwójnej ostrej warstwy */
.psi-section--mission{
  border-radius:var(--psi-radius) !important;
  overflow:hidden;
}

.psi-section--mission .psi-hero-mission{
  border-radius:0 !important;
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
}

/* Wszystkie pudełka i karty — wymuszenie radiusu */
.psi-card,
.psi-soft-card,
.psi-hero-mission,
.psi-muted-card,
.psi-metric-card,
.psi-list-card,
.psi-resource-card,
.psi-api-card,
.psi-term-card,
.psi-stat,
.psi-score,
.psi-cta,
.psi-empty,
.psi-post-card,
.psi-post-nav a,
.psi-author-box,
.psi-search-form input[type="search"],
.psi-doc-toc,
.awp-artykuly-container{
  border-radius:var(--psi-radius) !important;
  overflow:hidden;
}

/* Karty metryk z Core Web Vitals */
.psi-grid-3 > .psi-card,
.psi-metric-card{
  border-radius:var(--psi-radius) !important;
}

/* Małe badge i ikonki */
.psi-badge,
.psi-tab,
.psi-resource-icon,
.psi-pagination .page-numbers,
.psi-menu-toggle,
.psi-section-icon,
.psi-hero-mission__icon{
  border-radius:var(--psi-radius-sm) !important;
}

/* Pill zostaje pigułką */
.psi-button,
.psi-search-form button,
.psi-post-card__cat,
.psi-post-footer-links a,
.psi-post-footer-links span,
.psi-pill,
.psi-archive-kicker,
.psi-single-tax a,
.psi-single-tax span{
  border-radius:999px !important;
}

/* Żeby białe sekcje nie wyglądały jak puste wielkie karty */
.psi-section.is-light-bg[style*="background:#ffffff"],
.psi-section.is-light-bg[style*="background: #ffffff"],
.psi-section.is-light-bg[style*="background-color:#ffffff"],
.psi-section.is-light-bg[style*="background-color: #ffffff"]{
  padding:0 !important;
  overflow:visible;
}

/* Ale mission z jasnym gradientem/kolorem ma zostać kartą */
.psi-section--mission.is-light-bg{
  padding:var(--psi-space-4) !important;
  overflow:hidden !important;
}

/* Mobile */
@media (max-width:760px){
  :root{
    --psi-radius:18px;
    --psi-radius-sm:12px;
  }

  .psi-section[style*="background"],
  .psi-section--mission.is-light-bg{
    padding:var(--psi-space-3) !important;
  }
}
