/* =========================================================================
   StronaFull v2 — Premium foundation
   Tone: Modern Editorial × Tech Premium. Vanilla CSS, no build step.
   ========================================================================= */

/* --- Default theme variables (overridden by themes/*.css) ---------------- */
:root{
  --bg:#fafafa;
  --surface:#ffffff;
  --surface-2:#f4f4f5;
  --text:#0a0a0a;
  --text-2:#3f3f46;
  --muted:#71717a;
  --border:#e4e4e7;
  --border-strong:#a1a1aa;
  --primary:#0f172a;
  --primary-2:#1e293b;
  --primary-light:#f1f5f9;
  --accent:#3b82f6;
  /* Tekst zawsze CZYTELNY na tle primary/accent (zwykle saturated colored bg).
     Default biały — themy z bardzo jasnym primary mogą override (rzadkie). */
  --on-primary:#fff;
  --on-accent:#fff;
  --gradient-1:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);
  --gradient-2:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);
  --shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --shadow:0 4px 14px -4px rgba(0,0,0,.08);
  --shadow-lg:0 24px 48px -12px rgba(0,0,0,.18);
  --shadow-xl:0 32px 64px -16px rgba(0,0,0,.25);
  --radius-sm:6px;
  --radius:10px;
  --radius-lg:18px;
  --radius-xl:28px;
  --easing:cubic-bezier(.16,1,.3,1);
  --easing-bounce:cubic-bezier(.34,1.56,.64,1);
  --transition-fast:.15s var(--easing);
  --transition:.3s var(--easing);
  --transition-slow:.6s var(--easing);
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,system-ui,"Segoe UI",sans-serif;
  --font-serif:"Newsreader","Source Serif Pro",Georgia,serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --container-max:1280px;
  --container-px:24px;
  /* Hero context — adapts per variant + theme */
  --hero-text:#fff;
  --hero-text-2:rgba(255,255,255,.85);
  --hero-muted:rgba(255,255,255,.7);
  --hero-border:rgba(255,255,255,.18);
  /* Spacing scale */
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:24px;
  --space-6:32px;
  --space-8:48px;
  --space-10:64px;
  --space-12:96px;
}

/* --- Reset + base -------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  padding:0;
  font-family:var(--font-sans);
  font-size:15px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}
a:hover{color:var(--primary)}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}

/* Selection */
::selection{background:var(--primary);color:var(--on-primary)}

/* Focus visible */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* --- Typography ---------------------------------------------------------- */
h1,h2,h3,h4,h5,h6{margin:0 0 .5em;font-weight:700;line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(28px,4vw,48px);letter-spacing:-.03em}
h2{font-size:clamp(22px,3vw,32px)}
h3{font-size:18px;letter-spacing:-.01em}
p{margin:0 0 1em}
small{font-size:.85em}
.muted{color:var(--muted)}
.text-2{color:var(--text-2)}

/* --- Container ----------------------------------------------------------- */
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-px)}
.container-narrow{max-width:880px;margin:0 auto;padding:0 var(--container-px)}
.container-wide{max-width:1440px;margin:0 auto;padding:0 var(--container-px)}

/* --- Buttons ------------------------------------------------------------- */
.btn,
.btn-action,
button.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 22px;
  font-size:14px;
  font-weight:600;
  letter-spacing:.005em;
  border-radius:var(--radius);
  cursor:pointer;
  white-space:nowrap;
  transition:transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);
  background:var(--primary);
  color:var(--on-primary);
  border:1px solid var(--primary);
}
.btn:hover{background:var(--primary-2);transform:translateY(-1px);box-shadow:var(--shadow);text-decoration:none;color:var(--on-primary)}
.btn:active{transform:translateY(0)}
.btn.outline{background:transparent;color:var(--primary);border-color:var(--border-strong)}
.btn.outline:hover{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}
.btn.ghost{background:transparent;color:var(--text);border-color:transparent}
.btn.ghost:hover{background:var(--surface-2);color:var(--text)}
.btn.lg{padding:15px 30px;font-size:15px}
.btn.sm{padding:7px 14px;font-size:13px}

/* --- Site header (base — overridden per variant) ------------------------- */
.site-header{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
}
.site-header .row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 0;flex-wrap:wrap}
.site-header .brand{
  font-size:20px;
  font-weight:800;
  letter-spacing:-.02em;
  display:inline-flex;align-items:center;gap:10px;
}
.site-header nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.site-header nav a{
  padding:8px 14px;
  font-size:14px;
  font-weight:500;
  color:var(--text-2);
  border-radius:var(--radius-sm);
  transition:background var(--transition-fast),color var(--transition-fast);
}
.site-header nav a:hover{background:var(--surface-2);color:var(--text)}

/* --- Site footer (base) -------------------------------------------------- */
.site-footer{
  margin-top:80px;
  padding:64px 0 32px;
  background:var(--surface);
  border-top:1px solid var(--border);
}
.site-footer h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0 0 16px;color:var(--text)}
.site-footer .footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:48px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.site-footer ul a{font-size:14px;color:var(--muted);transition:color var(--transition-fast)}
.site-footer ul a:hover{color:var(--text)}
.site-footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* --- Hero (base — variants override) ------------------------------------ */
.hero{
  position:relative;
  overflow:hidden;
  padding:80px 0;
  background:var(--gradient-1);
  color:var(--hero-text);
  --hero-text:#fff;
  --hero-text-2:rgba(255,255,255,.85);
  --hero-muted:rgba(255,255,255,.7);
  --hero-border:rgba(255,255,255,.18);
}
.hero .hero-content{position:relative;z-index:1}
.hero h1{color:var(--hero-text);margin:0 0 16px}
.hero p.lead{font-size:18px;color:var(--hero-text-2);max-width:640px;margin:0 0 32px}
.hero-stats{display:flex;gap:48px;flex-wrap:wrap}
.hero-stat .v{display:block;font-size:36px;font-weight:800;letter-spacing:-.02em;color:var(--hero-text)}
.hero-stat .l{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--hero-muted);font-weight:600}

/* --- Entry cards (base) -------------------------------------------------- */
.entries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.entry-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px;
  transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.entry-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}
.entry-card-head{display:flex;align-items:flex-start;gap:14px}
.entry-card-logo{
  flex-shrink:0;
  width:56px;height:56px;
  border-radius:12px;
  background:#fff; /* białe tło — przezroczyste loga (PNG) nie znikną na ciemnych motywach */
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:20px;
  color:var(--text-2);
  overflow:hidden;
  padding:4px;
}
/* contain — szanujemy proporcje loga (prostokątne, panoramiczne, kwadratowe) */
.entry-card-logo img{width:100%;height:100%;object-fit:contain}
/* Gdy w środku jest litera (placeholder) — biały tekst nie ma tła; reset do gradientu */
.entry-card-logo:not(:has(img)){background:var(--gradient-1);color:#fff;border:0;padding:0}
.entry-card h3{margin:0;font-size:17px;line-height:1.3}
.entry-card .desc{color:var(--text-2);font-size:14px;line-height:1.5;flex:1}
.entry-card .location{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.entry-card .actions{display:flex;gap:8px;flex-wrap:wrap}
.entry-card .pcat{
  display:inline-block;
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,transparent);
  padding:4px 10px;border-radius:99px;
}

/* Premium card variants — body.premium-X overrides */
.entry-card.premium,
.entry-card[data-premium="1"]{
  border-color:#fbbf24;
  background:linear-gradient(135deg,color-mix(in srgb,#fbbf24 5%,var(--surface)),var(--surface));
}
body.premium-gold .entry-card.premium{border-color:#fbbf24;box-shadow:0 0 0 1px #fbbf24,var(--shadow)}
body.premium-platinum .entry-card.premium{border-color:#94a3b8;background:linear-gradient(135deg,color-mix(in srgb,#cbd5e1 12%,var(--surface)),var(--surface))}
body.premium-emerald .entry-card.premium{border-color:#10b981}
body.premium-rose .entry-card.premium{border-color:#f43f5e}

/* --- Sections + section heads ------------------------------------------- */
.section{padding:64px 0}
.section-head{margin-bottom:32px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-end}
.section-head .tag{
  display:inline-block;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--accent);
  margin-bottom:8px;
}
.section-head h2{margin:0}

/* --- Tag / pill / chip --------------------------------------------------- */
.cat-tag,.tag-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;
  font-size:12px;font-weight:600;
  background:var(--surface-2);
  color:var(--text-2);
  border-radius:99px;
  border:1px solid var(--border);
  text-decoration:none;
  transition:all var(--transition-fast);
}
.cat-tag:hover,.tag-pill:hover{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}

/* --- Listing toolbar (firmy/artykuly view + per-page picker) ------------- */
.listing-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  padding:14px 18px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin:18px 0;
}
.lt-views{display:inline-flex;background:var(--surface-2);padding:4px;border-radius:var(--radius-sm);gap:2px}
.lt-view-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;font-size:13px;font-weight:600;
  color:var(--text-2);text-decoration:none;
  border-radius:calc(var(--radius-sm) - 2px);
  transition:background var(--transition-fast),color var(--transition-fast);
}
.lt-view-btn:hover{background:var(--surface);color:var(--text)}
.lt-view-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}
.lt-icon{font-size:14px;line-height:1}
.lt-label{font-size:13px}
@media(max-width:640px){.lt-label{display:none}}

.lt-per{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--muted)}
.lt-per-label{margin-right:6px;font-weight:600}
.lt-per-btn{
  padding:6px 10px;
  border-radius:var(--radius-sm);
  font-size:13px;font-weight:600;
  color:var(--text-2);
  text-decoration:none;
  transition:background var(--transition-fast),color var(--transition-fast);
}
.lt-per-btn:hover{background:var(--surface-2);color:var(--text)}
.lt-per-btn.active{background:var(--primary);color:var(--on-primary)}

/* List view (firmy.php?view=list) */
.entries-list{display:flex;flex-direction:column;gap:14px}
.entry-row-logo-placeholder{
  flex-shrink:0;width:72px;height:72px;border-radius:12px;
  background:var(--gradient-1);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:24px;text-decoration:none;
}
.badge-prem{
  display:inline-block;
  padding:2px 8px;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  color:#451a03;
  border-radius:99px;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-left:8px;
  vertical-align:middle;
}

/* Compact view — gęstsza siatka */
.entries-grid.is-compact{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.entries-grid.is-compact .entry-card{padding:16px}
.entries-grid.is-compact .desc{display:none}

/* Table view wrapper */
.view-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.entries-table-ad td{padding:24px!important;background:var(--surface-2)}

/* --- Pagination --------------------------------------------------------- */
.pagination{display:flex;justify-content:center;gap:6px;margin:48px 0;flex-wrap:wrap}
.pagination a,.pagination span{
  padding:8px 14px;font-size:14px;font-weight:600;
  border-radius:var(--radius-sm);background:var(--surface);
  border:1px solid var(--border);color:var(--text-2);
  text-decoration:none;transition:all var(--transition-fast);
  min-width:40px;text-align:center;
}
.pagination a:hover{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}
.pagination .current{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}

/* --- Forms -------------------------------------------------------------- */
input[type=text],input[type=search],input[type=email],input[type=url],input[type=tel],
input[type=number],textarea,select{
  width:100%;
  padding:12px 16px;
  font-size:15px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  transition:border-color var(--transition-fast),box-shadow var(--transition-fast);
  outline:none;
}
input:focus,textarea:focus,select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent);
}

/* --- Hero search base --------------------------------------------------- */
.hero-search{
  display:flex;gap:8px;
  max-width:640px;
  background:var(--surface);
  padding:8px;
  border-radius:99px;
  box-shadow:0 8px 32px -8px rgba(0,0,0,.15);
}
.hero-search input{border:0;padding:12px 20px;font-size:15px;background:transparent}
.hero-search input:focus{box-shadow:none}
.hero-search button{
  padding:0 24px;
  background:var(--primary);color:var(--on-primary);
  border-radius:99px;font-weight:700;font-size:14px;
  border:0;cursor:pointer;
  transition:background var(--transition-fast);
}
.hero-search button:hover{background:var(--primary-2)}

/* --- Empty state -------------------------------------------------------- */
.empty{
  text-align:center;padding:80px 24px;
  color:var(--muted);
}
.empty .ico{font-size:48px;margin-bottom:16px;opacity:.5}
.empty h2{color:var(--text);margin-bottom:8px}

/* --- Breadcrumbs -------------------------------------------------------- */
.breadcrumbs{font-size:13px;color:var(--muted);margin:24px 0;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.breadcrumbs a{color:var(--text-2);text-decoration:none}
.breadcrumbs a:hover{color:var(--primary);text-decoration:underline}
.breadcrumbs .sep{color:var(--border-strong)}

/* --- Sticky ad bars ----------------------------------------------------- */
:root{--sticky-top-h:0px;--sticky-bottom-h:0px}
body{padding-top:var(--sticky-top-h);padding-bottom:var(--sticky-bottom-h)}
.sticky-ad{position:fixed;left:0;right:0;z-index:90;display:flex;justify-content:center;background:var(--surface);box-shadow:0 2px 12px rgba(0,0,0,.08);padding:8px}
.sticky-ad-top{top:0;border-bottom:1px solid var(--border)}
.sticky-ad-bottom{bottom:0;border-top:1px solid var(--border)}
.sticky-ad-close{position:absolute;top:4px;right:8px;width:28px;height:28px;border-radius:99px;background:rgba(0,0,0,.08);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:0}
.sticky-ad-close:hover{background:rgba(0,0,0,.18)}

/* --- Popup ad ---------------------------------------------------------- */
.popup-ad-overlay{position:fixed;inset:0;background:rgba(15,23,42,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:popupIn .3s var(--easing)}
@keyframes popupIn{from{opacity:0}to{opacity:1}}
.popup-ad-box{position:relative;background:var(--surface);border-radius:var(--radius-lg);padding:24px;max-width:520px;box-shadow:var(--shadow-xl);animation:popupBoxIn .4s var(--easing-bounce)}
@keyframes popupBoxIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.popup-ad-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:99px;background:var(--surface-2);font-size:18px;cursor:pointer;border:0;display:flex;align-items:center;justify-content:center}

/* --- Ad container styling ---------------------------------------------- */
.ad{margin:24px 0;text-align:center}
.ad img{display:inline-block;max-width:100%;height:auto;border-radius:var(--radius)}
.ad-place-header{margin:0;padding:12px 0;background:var(--surface-2)}
.ad-place-entry_sidebar{margin:0}
.ad-place-between_entries{padding:24px;background:var(--surface-2);border-radius:var(--radius)}

/* --- Contact reveal (anti-scrap) --------------------------------------- */
.contact-reveal{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;vertical-align:middle;max-width:100%;min-width:0}
.contact-reveal .cr-masked{font-family:var(--font-mono);letter-spacing:.06em;color:var(--muted);user-select:none;overflow-wrap:anywhere;word-break:break-word;min-width:0;max-width:100%}
.contact-reveal .cr-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;line-height:1.2;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:99px;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}
.contact-reveal .cr-btn:hover{background:var(--accent);color:var(--on-accent)}
.contact-reveal .cr-trap{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important;border:0!important;padding:0!important}
.contact-reveal.is-loading .cr-btn{opacity:.65;cursor:wait}
.contact-reveal.is-error .cr-btn{border-color:#dc2626;color:#dc2626}
.contact-reveal .cr-revealed-link{font-weight:600;color:var(--text);text-decoration:none;overflow-wrap:anywhere;word-break:break-word;min-width:0;max-width:100%;display:inline-block}
.contact-reveal .cr-revealed-link:hover{text-decoration:underline}
@media(max-width:520px){
  .contact-reveal .cr-btn .cr-btn-label{display:none}
  .contact-reveal .cr-btn .cr-btn-icon{font-size:14px}
}

/* Sidebar contact rows + dossier table — wymuszają break dla długich emaili/URL */
.contact-row .val,
.contact-row .val a,
.firma-stack a[href^="mailto"],
.firma-stack a[href*="://"]{
  overflow-wrap:anywhere;
  word-break:break-word;
  min-width:0;
  max-width:100%;
}
.contact-row{min-width:0}
.contact-row > div:not(.ico){min-width:0;flex:1}

/* Contact reveal WEWNĄTRZ buttonów kontaktowych (.btn-contact, .fwh-cta na primary bg)
   — jasny tekst na ciemnym primary background, niezależnie od motywu. */
.btn-contact .contact-reveal .cr-masked,
.fwh-cta .contact-reveal .cr-masked,
.cr-inline .contact-reveal .cr-masked{
  color:rgba(255,255,255,.78);
}
.btn-contact .contact-reveal .cr-btn,
.fwh-cta .contact-reveal .cr-btn,
.cr-inline .contact-reveal .cr-btn{
  color:#fff;
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.45);
  backdrop-filter:blur(4px);
}
.btn-contact .contact-reveal .cr-btn:hover,
.fwh-cta .contact-reveal .cr-btn:hover,
.cr-inline .contact-reveal .cr-btn:hover{
  background:#fff;
  color:var(--primary);
  border-color:#fff;
}
.btn-contact .contact-reveal .cr-revealed-link,
.fwh-cta .contact-reveal .cr-revealed-link,
.cr-inline .contact-reveal .cr-revealed-link{
  color:#fff;
}

/* --- Sidebar (firma) ---------------------------------------------------- */
.sidebar{display:flex;flex-direction:column;gap:18px}
.sidebar .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.sidebar .card h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:14px;text-transform:uppercase;letter-spacing:.08em}
.contact-row{display:flex;gap:12px;padding:10px 0;border-top:1px solid var(--border)}
.contact-row:first-of-type{border-top:0;padding-top:0}
.contact-row .ico{flex-shrink:0;width:36px;height:36px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:16px}
.contact-row .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}
.contact-row .val{font-size:14px;color:var(--text);word-break:break-word}

/* --- Premium slider (sidebar) ------------------------------------------ */
.premium-slider{position:relative;min-height:240px}
.ps-slide{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;text-align:center;color:var(--text);text-decoration:none;padding:8px}
.ps-slide.active{display:flex;animation:fadeIn .5s var(--easing)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ps-logo{width:72px;height:72px;border-radius:12px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;margin-bottom:12px;overflow:hidden;padding:6px}
.ps-logo img{width:100%;height:100%;object-fit:contain}
.ps-logo-placeholder{background:var(--gradient-1)!important;color:#fff!important;border:0!important;padding:0!important}
.ps-name{font-weight:700;font-size:15px;margin-bottom:4px}
.ps-cat{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.ps-city{font-size:12px;color:var(--muted);margin:6px 0}
.ps-desc{font-size:12px;color:var(--text-2);line-height:1.4}
.ps-dots{display:flex;justify-content:center;gap:6px;margin-top:12px}
.ps-dot{width:8px;height:8px;border-radius:99px;background:var(--border);border:0;cursor:pointer;padding:0;transition:background var(--transition-fast)}
.ps-dot.active{background:var(--primary)}

/* --- Brand mark variants (body.brand-v-*) ----------------------------- */
.brand{position:relative}
body[class*="brand-v-"] .brand::before{
  content:"";display:inline-block;width:14px;height:14px;
  background:var(--primary);
  margin-right:10px;vertical-align:-2px;
}
body.brand-v-classic .brand::before{border-radius:3px}
body.brand-v-circle .brand::before{border-radius:50%}
body.brand-v-hex .brand::before{clip-path:polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0% 50%)}
body.brand-v-diamond .brand::before{transform:rotate(45deg)}
body.brand-v-rounded .brand::before{border-radius:6px}
body.brand-v-outline .brand::before{background:transparent;border:2px solid var(--primary);border-radius:3px}
body.brand-v-dot .brand::before{width:8px;height:8px;border-radius:50%}
body.brand-v-bars .brand::before{background:linear-gradient(90deg,var(--primary) 33%,transparent 33%,transparent 66%,var(--primary) 66%);border-radius:0}
body.brand-v-slash .brand::before{clip-path:polygon(20% 0,100% 0,80% 100%,0 100%)}
body.brand-v-dots .brand::before{background:radial-gradient(circle,var(--primary) 30%,transparent 32%) 0 0/4px 4px}
body.brand-v-stripes .brand::before{background:repeating-linear-gradient(45deg,var(--primary),var(--primary) 2px,transparent 2px,transparent 4px)}
body.brand-v-arrow .brand::before{clip-path:polygon(0 30%,60% 30%,60% 0,100% 50%,60% 100%,60% 70%,0 70%)}
body.brand-v-target .brand::before{background:radial-gradient(circle,var(--primary) 30%,transparent 35%,var(--primary) 50%,transparent 55%,var(--primary) 70%);border-radius:50%}
body.brand-v-double .brand::before{width:18px;background:linear-gradient(90deg,var(--primary) 40%,transparent 40%,transparent 60%,var(--primary) 60%);border-radius:2px}
body.brand-v-glow .brand::before{border-radius:50%;box-shadow:0 0 12px var(--primary),0 0 4px var(--primary)}
body.brand-v-frame .brand::before{background:transparent;border:3px double var(--primary);width:16px;height:16px}
body.brand-v-corner .brand::before{background:linear-gradient(135deg,var(--primary) 50%,transparent 50%)}
body.brand-v-chip .brand::before{width:18px;height:12px;border-radius:3px;background:var(--primary);box-shadow:inset 0 -2px 0 rgba(0,0,0,.15)}
body.brand-v-pixel .brand::before{background:linear-gradient(90deg,var(--primary) 50%,transparent 50%) 0 0/4px 4px}
body.brand-v-none .brand::before{display:none!important}
body[class*="brand-v-"]:not(.brand-v-none) .brand::before{display:inline-block!important}

/* --- Footer custom pages strip ---------------------------------------- */
.footer-pages-strip{background:var(--surface-2);border-top:1px solid var(--border);padding:14px 0;font-size:13px}
.footer-pages-strip a{color:var(--text-2);font-weight:500}
.footer-pages-strip a:hover{color:var(--primary);text-decoration:underline}

/* --- Entry extras (shared bottom: artykuły + kategorie firm/artykułów) - */
.entry-extras{margin:48px 0 32px}
.ee-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:flex-start}
@media(max-width:880px){.ee-grid{grid-template-columns:1fr;gap:24px}}
.ee-block{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px;
}
.ee-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.ee-head h3{
  margin:0;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  color:var(--text);
  display:flex;align-items:center;gap:8px;
}
.ee-head .ico-svg{flex-shrink:0;color:var(--accent)}
.ee-more{
  font-size:12px;font-weight:600;
  color:var(--accent);
  text-decoration:none;
  white-space:nowrap;
}
.ee-more:hover{text-decoration:underline}

/* Articles list — 2-3 columns grid (more uniwersalne dla pełnej szerokości) */
.ee-articles{display:flex;flex-direction:column;gap:14px}
.ee-articles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:14px;
}
.ee-art{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:14px;align-items:center;
  text-decoration:none;color:inherit;
  padding:8px;
  border-radius:var(--radius-sm);
  transition:background var(--transition-fast);
}
.ee-art:hover{background:var(--surface-2)}
.ee-art-img{
  width:80px;height:60px;
  border-radius:8px;
  overflow:hidden;
  background:var(--surface-2);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.ee-art-img img{width:100%;height:100%;object-fit:cover}
.ee-art-noimg{color:var(--muted)}
.ee-art-body{min-width:0}
.ee-art-cat{
  display:inline-block;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);
  margin-bottom:4px;
}
.ee-art-title{
  font-size:14px;font-weight:600;
  line-height:1.35;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;
}
.ee-art:hover .ee-art-title{color:var(--accent)}

/* Categories list — kompaktowe pigułki, default 2 kolumny */
.ee-cats{
  list-style:none;
  padding:0;margin:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
/* Wide variant — pełna szerokość, auto-fill (4-6 kolumn na desktopie) */
.ee-cats-wide{
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:8px;
}
@media(max-width:480px){.ee-cats,.ee-cats-wide{grid-template-columns:1fr}}
.ee-cats li{margin:0}
.ee-cats a{
  display:block;
  padding:8px 12px;
  font-size:13px;
  color:var(--text-2);
  background:var(--surface-2);
  border:1px solid transparent;
  border-radius:var(--radius-sm);
  text-decoration:none;
  transition:all var(--transition-fast);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ee-cats a:hover{
  background:var(--primary-light);
  color:var(--primary);
  border-color:var(--accent);
  transform:translateX(2px);
}

/* --- Cross-domain sidebar links -------------------------------------- */
.cross-links-sidebar h3{font-size:13px;margin-bottom:10px}
.cross-links-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.cross-links-list a{display:block;padding:10px;background:var(--surface-2);border-radius:var(--radius-sm);text-decoration:none;font-size:13px;transition:background var(--transition-fast)}
.cross-links-list a:hover{background:var(--primary-light)}
.cl-name{font-weight:600;color:var(--text)}
.cl-city{color:var(--muted);font-size:12px;margin-left:6px}
.cl-host{display:block;font-size:11px;color:var(--muted);margin-top:2px;font-family:var(--font-mono)}

/* --- Hours table (premium) ------------------------------------------- */
.entry-hours{font-size:14px}
.eh-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius);background:var(--surface-2);margin-bottom:12px}
.eh-status.is-open{background:color-mix(in srgb,#10b981 12%,var(--surface))}
.eh-status.is-closed{background:color-mix(in srgb,#dc2626 8%,var(--surface))}
.eh-dot{width:8px;height:8px;border-radius:99px;background:#dc2626}
.is-open .eh-dot{background:#10b981;box-shadow:0 0 8px #10b981}
.eh-status-label{font-weight:700}
.eh-status-sub{margin-left:auto;font-size:12px;color:var(--muted)}
.entry-hours-list{list-style:none;padding:0;margin:0}
.hl-item{display:flex;justify-content:space-between;padding:6px 0;border-top:1px solid var(--border);font-size:13px}
.hl-item:first-child{border-top:0}
.hl-item.is-today{font-weight:700}
.hl-item.is-closed .hl-val{color:var(--muted)}

/* --- Social icons (premium) ------------------------------------------ */
.entry-socials{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.social-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--surface-2);transition:all var(--transition-fast);color:var(--text-2)}
.social-icon:hover{background:var(--sm-color,var(--primary));color:#fff;transform:translateY(-2px)}

/* --- Listing meta (firmy.php) --------------------------------------- */
.entry-row{
  display:flex;gap:24px;
  padding:20px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:all var(--transition);
  text-decoration:none;
  color:inherit;
  align-items:flex-start;
}
.entry-row:hover{transform:translateX(4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}
.entry-row.is-premium{background:linear-gradient(135deg,color-mix(in srgb,#fbbf24 5%,var(--surface)),var(--surface));border-color:#fbbf24}
.entry-row-logo{flex-shrink:0;width:72px;height:72px;border-radius:12px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;color:var(--text-2);overflow:hidden;padding:6px}
.entry-row-logo img{width:100%;height:100%;object-fit:contain}
.entry-row-logo:not(:has(img)){background:var(--gradient-1);color:#fff;border:0;padding:0}
.entry-row-body{flex:1;min-width:0}
.entry-row-body h3{margin:0 0 6px;font-size:18px}
.entry-row-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13px;margin-bottom:8px}
.entry-row-desc{font-size:14px;color:var(--text-2);line-height:1.5;margin:0}
.entry-row-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.btn-contact,.btn-detail,.btn-contact-2{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;text-decoration:none;text-align:center;white-space:nowrap}
.btn-contact{background:var(--primary);color:var(--on-primary)}
.btn-contact-2{background:var(--surface-2);color:var(--text-2)}
.btn-detail{background:var(--accent);color:var(--on-accent)}
.btn-table-detail{padding:6px 12px;border-radius:var(--radius-sm);background:var(--accent);color:var(--on-accent);font-size:12px;font-weight:600;text-decoration:none}

/* Listing table view */
.entries-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden}
.entries-table th{text-align:left;padding:14px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;background:var(--surface-2);border-bottom:1px solid var(--border)}
.entries-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:14px}
.entries-table tr:last-child td{border-bottom:0}
.entries-table tr:hover{background:var(--surface-2)}
.entries-table .td-name{display:flex;align-items:center;gap:10px}
.entries-table .td-logo{width:40px;height:40px;border-radius:8px;object-fit:contain;background:#fff;border:1px solid var(--border);padding:3px}
.badge-prem-mini{color:#fbbf24;font-size:14px}

/* --- Layout: home grid baseline -------------------------------------- */
.home-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:flex-start}
@media(max-width:1024px){.home-grid{grid-template-columns:1fr}}

/* --- Article cards / listings --------------------------------------- */
.article-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform var(--transition),box-shadow var(--transition);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.article-card .cover{aspect-ratio:16/9;background:var(--surface-2);overflow:hidden}
.article-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.article-card:hover .cover img{transform:scale(1.05)}
.article-card .body{padding:20px;flex:1;display:flex;flex-direction:column;gap:8px}
.article-card .cat{font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--accent)}
.article-card h3{margin:0;font-size:17px;line-height:1.35}
.article-card .excerpt{font-size:14px;color:var(--text-2);line-height:1.5}
.article-card .meta{font-size:12px;color:var(--muted);margin-top:auto}

/* --- Animation utilities -------------------------------------------- */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s var(--easing),transform .6s var(--easing)}
.fade-in.is-visible{opacity:1;transform:translateY(0)}

/* --- Responsive ------------------------------------------------------ */
@media(max-width:768px){
  :root{--container-px:16px}
  .section{padding:48px 0}
  .site-header .row{padding:14px 0}
  .site-header nav{gap:4px}
  .site-header nav a{padding:6px 10px;font-size:13px}
  .hero{padding:60px 0}
  .hero p.lead{font-size:16px}
  .entry-row{flex-direction:column;gap:12px}
  .entry-row-actions{flex-direction:row;width:100%}
  .entry-card{padding:18px}
  .home-grid{gap:32px}
}
@media(max-width:480px){
  .hero-search{flex-direction:column;border-radius:var(--radius-lg);padding:8px}
  .hero-search input{width:100%}
  .hero-search button{padding:14px 24px;width:100%}
}
