/*
Theme Name: Fast Theme
Theme URI: https://example.com/fast-theme
Author: Custom
Description: Lekki, szybki motyw WordPress bez Gutenberga z sekcjami edytowalnymi w panelu. Hero szerokie, sekcje węższe, schema.org JSON-LD, PageSpeed-friendly.
Version: 1.4.0
License: GPL v2 or later
Text Domain: fast-theme
*/

/* ============================
   RESET & BASE
   ============================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;
  font-size:1rem;line-height:1.6;color:#0f172a;background:#f3f4f6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
body.menu-open{overflow:hidden}

/* ============================
   CONTAINER
   - Domyślny: WĘŻSZY 960px (sekcje pod hero, wycentrowane)
   - .container.container-wide: PEŁNA SZEROKOŚĆ OKNA z 80px marginesem (HERO, header, footer)
   ============================ */
.container{
  width:100% !important;
  max-width:960px !important;
  margin:0 auto !important;
  padding:0 24px !important;
}
.container-wide{
  max-width:none !important;
  padding:0 80px !important;
}

/* ============================
   HEADER / NAV
   ============================ */
.site-header{position:sticky;top:0;z-index:100;background:#f3f4f6;padding:20px 0}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.5rem;color:#0f172a;flex-shrink:0}
.brand-logo{width:32px;height:32px;flex-shrink:0}
.main-nav{display:flex;align-items:center;gap:8px}

.menu-close{display:none;position:absolute;top:16px;right:16px;width:44px;height:44px;align-items:center;justify-content:center;border-radius:8px;color:#0f172a;background:transparent;transition:background .15s}
.menu-close:hover{background:#f3f4f6}

.primary-menu{list-style:none;display:flex;gap:4px;align-items:center}
.primary-menu li{position:relative}
.primary-menu a{display:inline-flex;align-items:center;padding:8px 16px;border-radius:999px;font-size:0.95rem;font-weight:500;color:#374151;transition:background .15s}
.primary-menu a:hover{background:#e5e7eb}
.primary-menu .current-menu-item > a,
.primary-menu a.active{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.05)}

.primary-menu .has-submenu > a{padding-right:8px}
.submenu-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-left:-4px;border-radius:50%;color:#64748b;transition:background .15s,transform .2s}
.submenu-toggle:hover{background:#e5e7eb;color:#0f172a}
.submenu-toggle[aria-expanded="true"]{transform:rotate(180deg)}

.submenu{
  list-style:none;
  position:absolute;top:calc(100% + 8px);left:0;
  min-width:220px;background:#fff;border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);
  padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .15s,visibility .15s,transform .15s;
  z-index:50;
}
.primary-menu li.has-submenu:hover > .submenu,
.primary-menu li.has-submenu:focus-within > .submenu,
.primary-menu li.has-submenu.is-open > .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu li{position:relative}
.submenu a{display:block;padding:10px 14px;border-radius:8px;font-size:0.92rem;font-weight:500;color:#374151;white-space:nowrap}
.submenu a:hover{background:#f3f4f6;color:#0f172a}

.nav-actions{display:flex;align-items:center;gap:12px}
.lang-switch{display:flex;align-items:center;gap:6px;color:#374151;font-size:0.9rem;font-weight:500}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:8px;font-weight:600;font-size:0.95rem;transition:transform .1s,box-shadow .15s,background .15s;white-space:nowrap}
.btn-text{padding:10px 12px;color:#0f172a}
.btn-text:hover{color:#000}
.btn-primary{background:#2563eb;color:#fff}
.btn-primary:hover{background:#1d4ed8}
.btn-danger{background:#dc2626;color:#fff;display:inline-flex;align-items:center;gap:8px}
.btn-danger::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-secondary{background:#fff;color:#0f172a;border:1px solid #e5e7eb}
.btn-secondary:hover{background:#f9fafb}

.menu-toggle{display:none;flex-direction:column;gap:5px;padding:10px;border-radius:8px}
.menu-toggle span{width:24px;height:2px;background:#0f172a;border-radius:2px;transition:transform .2s,opacity .2s}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================
   SECTION CARD
   Sekcje pod hero NIE mają białej karty wokół - tylko centrowanie i odstępy.
   Białe karty mają tylko poszczególne elementy w środku (.minicard, .result-card, .feature-card itp.)
   ============================ */
.section{padding:32px 0}
.section-card{
  background:transparent;
  border-radius:0;
  padding:24px 0;
  box-shadow:none;
  width:100%;
}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fef3f8;color:#0f172a;padding:6px 14px;border-radius:999px;font-size:0.85rem;font-weight:500;margin-bottom:20px}
.section-eyebrow svg{width:14px;height:14px;color:#ec4899}
.section-card h2,.section-card .section-h{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;line-height:1.2;letter-spacing:-0.01em;text-align:center;margin-bottom:12px}
.section-card .section-sub{text-align:center;color:#475569;font-size:1.05rem;max-width:760px;margin:0 auto 48px}
.section-head-center{text-align:center;margin-bottom:48px}
.section-head-center .section-eyebrow{margin-left:auto;margin-right:auto;display:inline-flex}

/* ============================
   HERO — SZEROKIE (1500px)
   ============================ */
.hero{min-height:calc(100vh - 80px);display:flex;align-items:center;padding:12px 0}
.hero-card{background:#fff;border-radius:24px;padding:64px;box-shadow:0 1px 3px rgba(0,0,0,.04);width:100%}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#fef3f8;color:#0f172a;padding:6px 14px;border-radius:999px;font-size:0.85rem;font-weight:500;margin-bottom:24px}
.hero-badge svg{width:14px;height:14px;color:#ec4899}
.hero h1{font-size:clamp(2.25rem,4.5vw,3.75rem);font-weight:800;line-height:1.1;letter-spacing:-0.02em;color:#0f172a;margin-bottom:24px}
.hero-desc{font-size:1.05rem;color:#475569;margin-bottom:32px;max-width:560px}
.hero-cta{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.hero-cta .btn-primary{padding:14px 24px;font-size:1rem}
.hero-cta .btn-secondary{padding:14px 24px;font-size:1rem}
.hero-meta{font-size:0.875rem;color:#64748b}

.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.feature-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:28px;transition:transform .15s,box-shadow .15s}
.feature-card:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.06)}
.feature-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feature-icon svg{width:28px;height:28px}
.feature-card h2,.feature-card h3,.feature-card h4,.feature-card h5,.feature-card h6{font-size:1.15rem;font-weight:700;color:#0f172a;margin-bottom:8px;line-height:1.3}
.feature-card .feat-desc{color:#475569;font-size:0.95rem;margin-bottom:16px;line-height:1.5}
.feature-card ul{list-style:none}
.feature-card li{position:relative;padding-left:18px;color:#334155;font-size:0.9rem;line-height:1.5;margin-bottom:6px}
.feature-card li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--dot,#3b82f6)}

/* SECTIONS */
.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.result-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:32px}
.result-card .feature-icon{margin-bottom:20px}
.result-card h3,.result-card h2,.result-card h4{font-size:1.15rem;font-weight:700;margin-bottom:10px;line-height:1.3}
.result-card p{color:#475569;font-size:0.95rem;line-height:1.55}

.compare-wrap{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap;margin-top:24px}
.compare-item{text-align:center}
.score-circle{width:160px;height:160px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;margin-bottom:16px;background:conic-gradient(var(--ring) calc(var(--p)*1%),#f1f5f9 0);position:relative}
.score-circle::before{content:"";position:absolute;inset:14px;border-radius:50%;background:#fff}
.score-value{position:relative;color:var(--ring)}
.compare-item .score-label{font-weight:700;margin-bottom:4px;font-size:1.1rem}
.compare-item .score-sub{color:#64748b;font-size:0.9rem}
.compare-arrow{font-size:2.5rem;color:#cbd5e1}

.testimonial{background:#eef2ff;border-radius:24px;padding:48px;text-align:center;max-width:780px;margin:0 auto}
.testimonial .quote-mark{font-size:3rem;color:#a5b4fc;line-height:1;margin-bottom:8px;font-family:Georgia,serif}
.testimonial blockquote{font-size:1.25rem;font-weight:600;line-height:1.4;color:#0f172a;max-width:620px;margin:0 auto 24px}
.testimonial-author{display:flex;align-items:center;justify-content:center;gap:12px}
.author-avatar{width:40px;height:40px;border-radius:50%;background:#6366f1;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.9rem}
.author-info{text-align:left}
.author-name{font-weight:700;font-size:0.95rem}
.author-title{font-size:0.85rem;color:#64748b}

.minigrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.minicard{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:24px;transition:transform .15s,box-shadow .15s}
.minicard:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.05)}
.mini-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.mini-icon svg{width:22px;height:22px}
.minicard h3,.minicard h4{font-size:1rem;font-weight:700;margin-bottom:4px}
.minicard p{font-size:0.85rem;color:#64748b;line-height:1.4}

.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid #f1f5f9;border-radius:12px;overflow:hidden}
.faq-item summary{padding:18px 24px;cursor:pointer;font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:space-between;gap:16px;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";width:10px;height:10px;border-right:2px solid #64748b;border-bottom:2px solid #64748b;transform:rotate(45deg);transition:transform .2s;flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(-135deg)}
.faq-item summary:hover{background:#f9fafb}
.faq-answer{padding:0 24px 20px;color:#475569;line-height:1.6}

.cms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px}
.cms-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:28px}
.cms-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.cms-logo{width:48px;height:48px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f8fafc}
.cms-logo svg{width:28px;height:28px}
.cms-title{font-weight:700;font-size:1.05rem;line-height:1.3}
.cms-subtitle{color:#64748b;font-size:0.85rem;margin-top:2px}
.cms-tag{display:inline-block;background:#fef3c7;color:#92400e;padding:3px 10px;border-radius:6px;font-size:0.75rem;font-weight:600;margin-top:8px}
.cms-desc{color:#475569;font-size:0.95rem;line-height:1.5;margin-bottom:12px}
.cms-link{color:#2563eb;font-weight:600;font-size:0.9rem}

.split-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.split-left .section-eyebrow{margin-bottom:16px}
.split-left h2,.split-left h3{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;line-height:1.2;margin-bottom:16px;text-align:left}
.split-left p{color:#475569;line-height:1.6}
.split-right{display:flex;flex-direction:column;gap:16px}
.split-feature{background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:20px 24px;display:flex;align-items:flex-start;gap:16px}
.split-feature .feature-icon{width:36px;height:36px;border-radius:10px;flex-shrink:0;margin:0}
.split-feature .feature-icon svg{width:20px;height:20px}
.split-content h3,.split-content h4{font-size:1.05rem;font-weight:700;margin-bottom:4px;line-height:1.3}
.split-content p{font-size:0.9rem;color:#64748b;line-height:1.5;margin:0}

.platform-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.platform-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:18px;padding:32px 28px;text-align:center}
.platform-illustration{width:120px;height:120px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}
.platform-illustration svg{width:100%;height:100%}
.platform-card h3,.platform-card h4{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.platform-card p{color:#475569;font-size:0.9rem;line-height:1.5;margin-bottom:16px}

.final-cta{border:2px solid transparent;border-radius:20px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#3b82f6,#8b5cf6,#22c55e) border-box;padding:48px;text-align:center;max-width:780px;margin:0 auto}
.final-cta h2,.final-cta h3{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;margin-bottom:12px}
.final-cta p{color:#475569;margin-bottom:20px}
.final-cta-stats{display:flex;justify-content:center;gap:48px;margin-bottom:24px;flex-wrap:wrap}
.final-cta-stat{text-align:center}
.final-cta-stat-value{font-size:1.75rem;font-weight:800;color:#0f172a}
.final-cta-stat-label{font-size:0.85rem;color:#64748b}

.entry-content h2,.entry-content h3,.entry-content h4{margin-top:32px;margin-bottom:16px;font-weight:700}
.entry-content p{margin-bottom:16px;color:#334155}
.entry-content ul,.entry-content ol{margin:16px 0 16px 24px}
.entry-content li{margin-bottom:8px}

/* ============================
   404
   ============================ */
.error-404{padding:64px 0}
.error-404-content{max-width:560px;margin:0 auto;text-align:center}
.error-code{font-size:clamp(5rem,12vw,9rem);font-weight:900;line-height:1;color:#2563eb;margin-bottom:8px;letter-spacing:-0.04em}
.error-title{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800;color:#0f172a;margin-bottom:12px;line-height:1.2}
.error-desc{color:#475569;font-size:1.05rem;margin-bottom:24px;line-height:1.6}
.error-search{margin-bottom:32px}
.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============================
   FOOTER
   ============================ */
.site-footer{
  background:#0f172a;color:#cbd5e1;
  padding:64px 0 24px;margin-top:24px;
  border-radius:24px 24px 0 0;
}
.site-footer a{color:#cbd5e1;font-weight:500;transition:color .15s}
.site-footer a:hover{color:#fff}

/* Footer main: branding + 3 menu */
.footer-main{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.5rem;color:#fff}
.footer-logo .brand-logo{width:32px;height:32px}
.footer-brand-name{color:#fff}
.footer-tagline{color:#94a3b8;font-size:0.92rem;line-height:1.5;max-width:340px}

.footer-main-rating{display:flex;align-items:center;gap:8px;margin-top:4px}
.footer-main-rating .stars{display:inline-flex;gap:2px}
.footer-rating-value{color:#fff;font-weight:700;font-size:0.95rem}

.footer-ratings{display:flex;gap:32px;margin-top:8px}
.footer-rating-val{color:#fff;font-weight:700;font-size:1.1rem}
.footer-rating-lab{color:#94a3b8;font-size:0.7rem;letter-spacing:.08em;text-transform:uppercase;margin-top:2px}

.footer-cols{display:contents}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col-title{
  color:#94a3b8;font-size:0.85rem;font-weight:600;
  margin-bottom:8px;
  letter-spacing:.02em;
}
.footer-menu{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-menu a{font-size:0.92rem;color:#cbd5e1}

/* Footer widgets */
.footer-widgets{
  border-top:1px solid #1e293b;
  padding:32px 0;
  margin-top:0;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:32px;
}
.footer-widget-title{color:#fff;font-size:0.95rem;font-weight:600;margin-bottom:12px}
.footer-widget ul{list-style:none}
.footer-widget li{margin-bottom:6px;font-size:0.9rem}

/* Footer bottom: status / copy / legal */
.footer-bottom{
  border-top:1px solid #1e293b;
  padding-top:24px;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  align-items:center;
  gap:16px;
  color:#94a3b8;font-size:0.85rem;
}
.footer-bottom-center{text-align:center}
.footer-status{justify-self:start}
.footer-legal{justify-self:end}

.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(34,197,94,.12);
  color:#86efac;
  padding:6px 14px;border-radius:999px;
  font-size:0.8rem;font-weight:500;
}
.status-dot{
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.25);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

.legal-menu{list-style:none;display:flex;gap:16px;flex-wrap:wrap;justify-content:flex-end}
.legal-menu a{font-size:0.85rem;color:#94a3b8}

/* ============================
   BLOG: header / archives
   ============================ */
.blog-header{padding:48px 0 24px;text-align:center}
.archive-label{
  display:inline-block;
  background:#fef3f8;color:#9d174d;
  padding:4px 14px;border-radius:999px;
  font-size:0.8rem;font-weight:600;
  margin-bottom:16px;letter-spacing:.02em;
}
.blog-title{
  font-size:clamp(2rem,3.5vw,3rem);
  font-weight:800;line-height:1.15;letter-spacing:-.02em;
  color:#0f172a;
  margin-bottom:12px;
}
.blog-title span{color:#2563eb}
.blog-description{color:#475569;max-width:680px;margin:0 auto;font-size:1.05rem}
.search-form-wrap{max-width:560px;margin:24px auto 0}
.search-count{color:#475569;font-size:0.95rem;margin-top:12px}

/* Search form */
.search-form{
  display:flex;gap:8px;
  background:#fff;
  border:1px solid #e5e7eb;border-radius:12px;
  padding:6px;
}
.search-input{
  flex:1;
  border:0;outline:0;background:transparent;
  padding:10px 14px;font-size:1rem;color:#0f172a;
  font-family:inherit;
}
.search-submit{padding:10px 18px;font-size:0.92rem}

/* ============================
   BLOG: post grid
   ============================ */
.post-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:24px;
  margin:32px 0;
}
.post-card{
  background:#fff;
  border:1px solid #f1f5f9;
  border-radius:16px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .15s,box-shadow .15s;
}
.post-card:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.06)}

.post-card-thumb{display:block;aspect-ratio:16/9;background:#f1f5f9;overflow:hidden}
.post-card-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.post-card-thumb:hover .post-card-img{transform:scale(1.04)}

.post-card-body{padding:24px;display:flex;flex-direction:column;flex:1;gap:12px}
.post-card-meta{display:flex;align-items:center;gap:12px;font-size:0.82rem;color:#64748b;flex-wrap:wrap}
.post-card-category{
  background:#eff6ff;color:#1d4ed8;
  padding:3px 10px;border-radius:6px;
  font-size:0.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
}
.post-card-category:hover{background:#dbeafe}
.post-card-date{color:#64748b}
.post-card-title{
  font-size:1.25rem;font-weight:700;line-height:1.3;
  color:#0f172a;
  margin:0;
}
.post-card-title a{color:inherit}
.post-card-title a:hover{color:#2563eb}
.post-card-excerpt{color:#475569;font-size:0.92rem;line-height:1.55;flex:1}
.post-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;border-top:1px solid #f1f5f9;
  font-size:0.85rem;
}
.post-card-author{display:flex;align-items:center;gap:8px;color:#475569;font-weight:500}
.author-avatar-img{border-radius:50%;width:28px;height:28px}
.post-card-readmore{color:#2563eb;font-weight:600}
.post-card-readmore:hover{color:#1d4ed8}

/* ============================
   BLOG: pagination
   ============================ */
.pagination{
  display:flex;justify-content:center;gap:6px;
  margin:32px 0 48px;flex-wrap:wrap;
}
.pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;padding:0 14px;
  background:#fff;border:1px solid #e5e7eb;border-radius:10px;
  font-weight:600;font-size:0.92rem;color:#0f172a;
  transition:background .15s,border-color .15s;
}
.pagination .page-numbers:hover{background:#f9fafb;border-color:#cbd5e1}
.pagination .page-numbers.current{background:#2563eb;color:#fff;border-color:#2563eb}
.pagination .page-numbers.dots{background:transparent;border:0}

/* No results */
.no-results{
  text-align:center;padding:64px 24px;
  background:#fff;border:1px solid #f1f5f9;border-radius:16px;
  margin:24px 0;
}
.no-results h2{font-size:1.5rem;margin-bottom:12px}
.no-results p{color:#475569;margin-bottom:24px}

/* ============================
   BLOG: single post
   ============================ */
.single-post{padding-bottom:24px}
.single-header{padding:48px 0 32px;text-align:center}
.single-categories{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.single-category{
  background:#eff6ff;color:#1d4ed8;
  padding:4px 14px;border-radius:999px;
  font-size:0.8rem;font-weight:600;
}
.single-category:hover{background:#dbeafe}
.single-title{
  font-size:clamp(2rem,4vw,3.25rem);
  font-weight:800;line-height:1.15;letter-spacing:-.02em;
  color:#0f172a;
  margin-bottom:16px;
  max-width:880px;margin-left:auto;margin-right:auto;
}
.single-excerpt{
  font-size:1.15rem;color:#475569;line-height:1.55;
  max-width:680px;margin:0 auto 24px;
}
.single-meta{
  display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;
  color:#64748b;font-size:0.92rem;
}
.single-meta-author{display:flex;align-items:center;gap:10px}
.single-meta-author-info{display:flex;flex-direction:column;text-align:left}
.single-meta-author-name{font-weight:600;color:#0f172a;font-size:0.92rem}
.single-meta-date{font-size:0.82rem;color:#94a3b8}
.single-meta-reading{display:inline-flex;align-items:center;gap:6px}

.single-thumb-wrap{margin-bottom:32px}
.single-thumb{
  width:100%;
  border-radius:20px;
  aspect-ratio:16/9;
  object-fit:cover;
}

.single-content{padding:0 0 24px}
.single-content .entry-content{
  max-width:740px;margin:0 auto;
  font-size:1.05rem;line-height:1.75;color:#1e293b;
}
.single-content .entry-content h2{
  font-size:1.75rem;font-weight:800;
  margin-top:48px;margin-bottom:16px;
  color:#0f172a;line-height:1.25;
}
.single-content .entry-content h3{
  font-size:1.35rem;font-weight:700;
  margin-top:32px;margin-bottom:12px;
  color:#0f172a;line-height:1.3;
}
.single-content .entry-content h4{font-size:1.15rem;font-weight:700;margin-top:24px;margin-bottom:10px}
.single-content .entry-content p{margin-bottom:20px}
.single-content .entry-content ul,
.single-content .entry-content ol{margin:20px 0 20px 24px}
.single-content .entry-content li{margin-bottom:8px}
.single-content .entry-content a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}
.single-content .entry-content a:hover{color:#1d4ed8}
.single-content .entry-content blockquote{
  border-left:4px solid #2563eb;
  padding:8px 24px;margin:24px 0;
  background:#f8fafc;border-radius:0 12px 12px 0;
  font-style:italic;color:#334155;
}
.single-content .entry-content code{
  background:#f1f5f9;padding:2px 6px;border-radius:4px;
  font-family:"SF Mono",Monaco,Consolas,monospace;font-size:0.92em;
}
.single-content .entry-content pre{
  background:#0f172a;color:#e2e8f0;
  padding:20px;border-radius:12px;
  overflow-x:auto;margin:24px 0;
  font-family:"SF Mono",Monaco,Consolas,monospace;font-size:0.92rem;
}
.single-content .entry-content pre code{background:transparent;color:inherit;padding:0}
.single-content .entry-content img{
  border-radius:12px;margin:24px auto;display:block;
}
.single-content .entry-content figure{margin:24px 0}
.single-content .entry-content figcaption{text-align:center;color:#64748b;font-size:0.88rem;margin-top:8px}

/* Tags */
.single-tags{
  max-width:740px;margin:32px auto 0;
  padding-top:24px;border-top:1px solid #e5e7eb;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.single-tags-label{font-weight:600;color:#475569;font-size:0.9rem}
.single-tag{
  background:#f1f5f9;color:#475569;
  padding:4px 12px;border-radius:8px;
  font-size:0.85rem;font-weight:500;
}
.single-tag:hover{background:#e2e8f0;color:#0f172a}

/* Single nav */
.single-nav{
  max-width:740px;margin:48px auto 0;
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.single-nav-link{
  background:#fff;border:1px solid #f1f5f9;border-radius:12px;
  padding:16px 20px;display:flex;flex-direction:column;gap:6px;
  transition:transform .15s,border-color .15s;
}
.single-nav-link:hover{transform:translateY(-2px);border-color:#cbd5e1}
.single-nav-next{text-align:right}
.single-nav-label{font-size:0.8rem;color:#64748b;font-weight:600}
.single-nav-title{font-size:0.95rem;color:#0f172a;font-weight:600;line-height:1.4}

/* Page links (paginacja w pojedynczym wpisie) */
.page-links{
  max-width:740px;margin:24px auto 0;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-weight:600;
}
.page-links a,
.page-links > span:not(:first-child){
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  background:#fff;border:1px solid #e5e7eb;border-radius:8px;
  font-size:0.9rem;
}
.page-links > span:not(:first-child){background:#2563eb;color:#fff;border-color:#2563eb}

/* ============================
   BLOG: comments
   ============================ */
.comments-section{margin-top:48px}
.comments-section .container{max-width:740px}
.comments-title{
  font-size:1.5rem;font-weight:700;margin-bottom:24px;
  color:#0f172a;
}
.comments-list{list-style:none;margin-bottom:32px}
.comments-list ol{list-style:none;margin-left:32px}
.comments-list .comment{
  background:#fff;border:1px solid #f1f5f9;border-radius:12px;
  padding:20px;margin-bottom:16px;
}
.comments-list .comment-author{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.comments-list .comment-author img{border-radius:50%}
.comments-list .comment-author .fn{font-weight:600;color:#0f172a;font-style:normal}
.comments-list .comment-meta{font-size:0.85rem;color:#64748b;margin-bottom:12px}
.comments-list .comment-meta a{color:#64748b}
.comments-list .reply{margin-top:12px}
.comments-list .reply a{
  font-size:0.85rem;color:#2563eb;font-weight:600;
}

.comment-form{
  background:#fff;border:1px solid #f1f5f9;border-radius:16px;
  padding:24px;
}
.comment-form .comment-form-comment label,
.comment-form .comment-form-author label,
.comment-form .comment-form-email label,
.comment-form .comment-form-url label{
  display:block;font-weight:600;font-size:0.9rem;margin-bottom:6px;color:#0f172a;
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea{
  width:100%;
  padding:10px 14px;
  border:1px solid #e5e7eb;border-radius:8px;
  font-family:inherit;font-size:0.95rem;
  background:#fff;
}
.comment-form input:focus,
.comment-form textarea:focus{border-color:#2563eb;outline:0;box-shadow:0 0 0 3px rgba(37,99,235,.15)}
.comment-form textarea{min-height:120px;resize:vertical}
.comment-form p{margin-bottom:16px}
.comment-form .comment-notes{font-size:0.85rem;color:#64748b}
.comment-form .form-submit{margin-bottom:0}
.comment-reply-title{font-size:1.25rem;font-weight:700;margin-bottom:8px;color:#0f172a}
.no-comments{color:#64748b;font-style:italic}

/* ============================
   RESPONSIVE
   ============================ */
@media (max-width:1280px){
  .container-wide{padding:0 48px !important}
}
@media (max-width:980px){
  .container{padding:0 20px !important}
  .container-wide{padding:0 24px !important}
  .section-card{padding:16px 0}
  .hero-card{padding:40px 28px}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .feature-grid{grid-template-columns:1fr 1fr}
  .split-grid{grid-template-columns:1fr;gap:32px}
  .compare-arrow{transform:rotate(90deg)}

  /* Stopka */
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1 / -1}
  .footer-bottom{grid-template-columns:1fr;text-align:center;gap:16px}
  .footer-status,.footer-legal{justify-self:center}
  .legal-menu{justify-content:center}

  /* Blog */
  .single-nav{grid-template-columns:1fr}
}

@media (max-width:768px){
  .menu-toggle{display:flex}
  .main-nav{position:fixed;top:0;right:-100%;width:min(360px,90vw);height:100vh;background:#fff;flex-direction:column;align-items:stretch;justify-content:flex-start;padding:64px 20px 24px;gap:0;box-shadow:-10px 0 30px rgba(0,0,0,.15);transition:right .25s ease;overflow-y:auto;z-index:99}
  .main-nav.is-open{right:0}
  .menu-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;z-index:98}
  .menu-backdrop.is-open{opacity:1;visibility:visible}
  .menu-close{display:flex}
  .primary-menu{flex-direction:column;align-items:stretch;gap:2px;width:100%;margin-bottom:16px}
  .primary-menu li{width:100%}
  .primary-menu > li{display:flex;flex-wrap:wrap;align-items:center}
  .primary-menu > li > a{flex:1;display:block;padding:14px 16px;border-radius:10px;font-size:1rem;font-weight:600}
  .primary-menu > li.has-submenu > a{padding-right:8px}
  .submenu-toggle{width:44px;height:44px;border-radius:10px;color:#374151;margin-left:0;flex-shrink:0}
  .submenu-toggle svg{width:18px;height:18px}
  .submenu{position:static;width:100%;background:#f8fafc;box-shadow:none;border-radius:10px;padding:6px;margin:0 0 4px;opacity:1;visibility:visible;transform:none;transition:none;display:none}
  .primary-menu li.has-submenu.is-open > .submenu{display:block}
  .submenu a{padding:12px 14px;font-size:0.95rem;color:#475569;font-weight:500}
  .submenu a:hover{background:#fff;color:#0f172a}
  .nav-actions{flex-direction:column;align-items:stretch;gap:10px;border-top:1px solid #f1f5f9;padding-top:16px}
  .nav-actions .btn{width:100%;justify-content:center;padding:12px 16px;font-size:0.95rem}
  .nav-actions .btn-text{display:none}
  .nav-actions .lang-switch{display:none}
  .btn{padding:8px 14px;font-size:0.85rem}
  .hero{min-height:calc(100vh - 72px);padding:8px 0}
  .hero-card{padding:32px 20px;border-radius:16px}
  .feature-grid{grid-template-columns:1fr}
  .feature-card{padding:24px}
  .container{padding:0 16px !important}
  .container-wide{padding:0 16px !important}
  .section{padding:16px 0}
  .section-card{padding:8px 0;border-radius:0}
  .testimonial{padding:32px 20px}
  .final-cta{padding:32px 20px}
  .compare-wrap{gap:24px}
  .score-circle{width:130px;height:130px;font-size:2.25rem}

  /* Stopka mobile */
  .footer-main{grid-template-columns:1fr;gap:24px;margin-bottom:32px}
  .footer-ratings{gap:24px}

  /* Blog mobile */
  .single-header{padding:32px 0 24px}
  .single-thumb{border-radius:12px}
  .single-content .entry-content{font-size:1rem}
  .single-content .entry-content h2{font-size:1.5rem;margin-top:32px}
  .single-content .entry-content h3{font-size:1.2rem}
  .post-grid{gap:16px}
  .blog-header{padding:32px 0 16px}
}

@media (max-width:420px){
  .brand span{display:none}
  .final-cta-stats{gap:24px}
}

/* A11Y */
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
:focus-visible{outline:2px solid #2563eb;outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
