/* ============================================================
   KAMIENIARSTWO SZTUM — STYLE.CSS
   WEB STANDARDS 2026 v1.1 — dawidweb.com
   Mobile-first | WCAG 2.2 AA | CSS Custom Properties
   ============================================================ */

/* ── RESET & BASE ─────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html { overflow-x: hidden; }
body { overflow-x: hidden; -webkit-text-size-adjust: 100%; }

/* Global: hide native <details> marker everywhere */
summary { list-style: none; list-style-type: none; }
summary::-webkit-details-marker { display: none !important; }
summary::marker { display: none !important; content: '' !important; font-size: 0 !important; }
details summary::before { display: none !important; }

/* ── CSS CUSTOM PROPERTIES ────────────────────────────────── */
:root {
  /* Kolory marki */
  --color-primary:        #1e293b;   /* głęboki granat/łupek */
  --color-primary-hover:  #0f172a;
  --color-secondary:      #334155;
  --color-accent:         #1D6A5B;   /* szmaragdowy / teal green */
  --color-accent-light:   #d1f0e8;
  --color-accent-hover:   #155a4d;

  /* Tekst */
  --color-text:           #1e293b;
  --color-text-secondary: #475569;
  --color-text-light:     #94a3b8;
  --color-text-on-dark:   #f8fafc;

  /* Tła */
  --color-bg:             #ffffff;
  --color-bg-alt:         #f8f6f2;   /* ciepła biel, jak kamień */
  --color-bg-dark:        #1e293b;
  --color-bg-dark-alt:    #0f172a;

  /* Obramowania */
  --color-border:         #e2ddd6;
  --color-border-strong:  #b8b0a5;

  /* Stany */
  --color-success:        #15803d;
  --color-warning:        #15325a;
  --color-error:          #dc2626;
  --color-focus:          #3b82f6;

  /* Typografia */
  --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body:    'Lato', 'Segoe UI', system-ui, -apple-system, sans-serif;

  /* Spacing tokens */
  --space-xs:   0.25rem;   /* 4px */
  --space-sm:   0.5rem;    /* 8px */
  --space-md:   1rem;      /* 16px */
  --space-lg:   1.5rem;    /* 24px */
  --space-xl:   2rem;      /* 32px */
  --space-2xl:  3rem;      /* 48px */
  --space-3xl:  4rem;      /* 64px */
  --space-4xl:  6rem;      /* 96px */

  /* Zaokrąglenia */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;

  /* Cienie */
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md:  0 4px 12px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.07);
  --shadow-lg:  0 10px 30px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.08);

  /* Przejścia */
  --transition: 220ms ease;

  /* Nagłówek */
  --header-h: 72px;
}

/* ── TYPOGRAFIA BAZOWA ────────────────────────────────────── */
html {
  font-size: 100%; /* 16px base — respektuje ustawienia przeglądarki */
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 1rem);
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.9rem + 0.25vw, 1.125rem);
  line-height: 1.65;
  color: var(--color-text);
  background: var(--color-bg);
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

/* ── SKIP TO CONTENT ──────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  padding: 0.75rem 1.5rem;
  background: var(--color-primary);
  color: var(--color-text-on-dark);
  font-weight: 600;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  text-decoration: none;
  z-index: 9999;
  transition: top var(--transition);
}
.skip-link:focus {
  top: 0;
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
}

/* ── FOCUS VISIBLE ────────────────────────────────────────── */
:focus-visible {
  outline: 3px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ── KONTENER ─────────────────────────────────────────────── */
.container {
  width: min(100% - 2rem, 1200px);
  margin-inline: auto;
}

@media (min-width: 768px) {
  .container { width: min(100% - 4rem, 1200px); }
}
@media (min-width: 1200px) {
  .container { width: min(100% - 6rem, 1200px); }
}

/* ── NAGŁÓWKI ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-primary);
}

h1 { font-size: clamp(1.75rem, 1.2rem + 2.5vw, 3rem);    line-height: 1.1; }
h2 { font-size: clamp(1.375rem, 1rem + 1.75vw, 2.25rem); line-height: 1.2; }
h3 { font-size: clamp(1.125rem, 0.9rem + 1vw, 1.625rem); line-height: 1.25; }
h4 { font-size: clamp(1rem, 0.85rem + 0.75vw, 1.25rem);  line-height: 1.3; }

p { max-width: 72ch; }
p + p { margin-top: var(--space-md); }

a {
  color: var(--color-accent);
  text-underline-offset: 3px;
  transition: color var(--transition);
}
a:hover { color: var(--color-accent-hover); }

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

/* ── TOP BAR ──────────────────────────────────────────────── */
.top-bar {
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
  font-size: 0.875rem;
  padding: 0.5rem 0;
  display: none;
}

.top-bar__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.top-bar a {
  color: var(--color-text-on-dark);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  opacity: 0.85;
  transition: opacity var(--transition);
}
.top-bar a:hover { opacity: 1; color: var(--color-text-on-dark); }

@media (min-width: 768px) { .top-bar { display: block; } }

/* ── HEADER / NAV ─────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  height: var(--header-h);
  display: flex;
  align-items: center;
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  width: 100%;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  text-decoration: none;
  flex-shrink: 0;
}

.logo__icon {
  width: 40px;
  height: 40px;
  background: var(--color-primary);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo__img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.logo__name {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: 0.01em;
}
.logo__tagline {
  font-size: 0.7rem;
  color: var(--color-text-secondary);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* Nawigacja desktop */
.site-nav {
  display: none;
}

.site-nav ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0;
}

.site-nav a {
  display: block;
  padding: 0.625rem 0.875rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
  white-space: nowrap;
}
.site-nav a:hover {
  color: var(--color-accent);
  background: var(--color-bg-alt);
}
.site-nav a.active,
.site-nav a[aria-current="page"],
.site-nav .current-menu-item > a {
  color: var(--color-accent);
  font-weight: 600;
}

.header__cta {
  display: none;
}

/* Hamburger */
.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}
.hamburger:hover { background: var(--color-bg-alt); }
.hamburger span {
  display: block;
  height: 2px;
  background: var(--color-primary);
  border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}
.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  display: none;
  position: fixed;
  inset: var(--header-h) 0 0 0;
  background: var(--color-bg);
  z-index: 999;
  padding: var(--space-lg) var(--space-md);
  overflow-y: auto;
  border-top: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
}
.mobile-menu.is-open { display: block; }

.mobile-menu ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.mobile-menu a {
  display: block;
  padding: 1rem var(--space-md);
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border);
  transition: color var(--transition), background var(--transition);
}
.mobile-menu a:hover,
.mobile-menu a.active,
.mobile-menu .current-menu-item > a {
  color: var(--color-accent);
  background: var(--color-bg-alt);
}
.mobile-menu__cta {
  margin-top: var(--space-xl);
}

@media (min-width: 992px) {
  .hamburger { display: none; }
  .site-nav { display: block; }
  .header__cta { display: flex; align-items: center; gap: var(--space-sm); }
}

/* Mobile header fix - logo nie może wypychać hamburgera poza ekran */
@media (max-width: 991px) {
  .header__inner { gap: 0.5rem; flex-wrap: nowrap; }
  .logo { flex: 1 1 auto; min-width: 0; overflow: hidden; }
  .logo__text { min-width: 0; flex: 1 1 auto; overflow: hidden; }
  .logo__name { font-size: 1rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .logo__tagline { font-size: 0.65rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .hamburger { flex-shrink: 0; margin-left: auto; }
}
@media (max-width: 480px) {
  .logo__tagline { display: none; }
  .logo__img { width: 40px; height: 40px; }
}

/* ── PRZYCISKI ────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: 0.8rem 2rem;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 280ms ease;
  white-space: nowrap;
  min-height: 46px;
  letter-spacing: 0.01em;
}

.btn:active { transform: scale(0.97); }

.btn-primary {
  background: linear-gradient(135deg, var(--ks-btn-bg) 0%, var(--ks-hero-end) 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(29, 106, 91, 0.25);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-accent-hover) 0%, var(--ks-btn-bg) 100%);
  color: #fff;
  box-shadow: 0 6px 20px rgba(29, 106, 91, 0.4);
  transform: translateY(-1px);
}

.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-outline:hover {
  background: var(--color-primary);
  color: var(--color-text-on-dark);
}

.btn-outline-light {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.7);
}
.btn-outline-light:hover {
  background: rgba(255,255,255,0.15);
  border-color: #fff;
}

.btn-accent {
  background: linear-gradient(135deg, var(--ks-hero-end) 0%, var(--ks-btn-bg) 100%);
  color: #fff;
  border-color: #3b6daa;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(245,158,11,0.4);
}
.btn-accent:hover {
  background: linear-gradient(135deg, color-mix(in srgb, var(--ks-hero-end) 70%, #fff) 0%, var(--ks-hero-end) 100%);
  color: #fff;
  box-shadow: 0 6px 24px rgba(245,158,11,0.55);
  transform: translateY(-2px);
}

.btn-sm {
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  min-height: 38px;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* ── BREADCRUMBS ──────────────────────────────────────────── */
.breadcrumbs {
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-border);
  padding: 0.75rem 0;
  font-size: 0.875rem;
}
.breadcrumbs__list {
  list-style: none;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.25rem;
}
.breadcrumbs__item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  color: var(--color-text-secondary);
}
.breadcrumbs__item:not(:last-child)::after {
  content: '›';
  color: var(--color-text-light);
}
.breadcrumbs__item a {
  color: var(--color-text-secondary);
  text-decoration: none;
}
.breadcrumbs__item a:hover { color: var(--color-accent); }
.breadcrumbs__item[aria-current="page"] { color: var(--color-text); font-weight: 500; }

/* ── HERO ─────────────────────────────────────────────────── */
.hero {
  position: relative;
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
  overflow: hidden;
  padding: var(--space-4xl) 0;
  min-height: 520px;
  display: flex;
  align-items: center;
}

.hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center 90%;
  opacity: 0.7;
  z-index: 0;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,
    rgba(15, 23, 42, 0.42) 0%,
    rgba(30, 41, 59, 0.22) 50%,
    rgba(30, 41, 59, 0.08) 100%);
  z-index: 1;
}

.hero__content {
  position: relative;
  z-index: 2;
  max-width: 700px;
}

.hero__label {
  display: inline-block;
  padding: 0.375rem 1rem;
  background: rgba(29, 106, 91, 0.9);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-lg);
}

.hero h1 {
  color: #fff;
  font-size: clamp(2rem, 1.5rem + 3vw, 3.5rem);
  margin-bottom: var(--space-lg);
}

.hero__desc {
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
  color: rgba(255,255,255,0.82);
  margin-bottom: var(--space-xl);
  max-width: 56ch;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
}

/* Page hero */
.page-hero {
  background: var(--color-bg-dark);
  padding: clamp(4rem, 8vw, 7rem) 0;
  min-height: 340px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.page-hero__bg {
  position: absolute;
  inset: 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: #1a2332;
  opacity: 1;
  z-index: 0;
}
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(15, 23, 42, 0.82) 0%,
    rgba(15, 23, 42, 0.6) 50%,
    rgba(15, 23, 42, 0.35) 100%
  );
  z-index: 0;
}
.page-hero__content {
  position: relative;
  z-index: 2;
  color: var(--color-text-on-dark);
}
.page-hero h1 { color: #fff; }
.page-hero__desc {
  color: rgba(255,255,255,0.85);
  font-size: 1.125rem;
  margin-top: var(--space-md);
  max-width: 60ch;
}

/* Taller hero for subpages */
.page-hero--tall {
  min-height: 520px;
  padding: clamp(5rem, 10vw, 9rem) 0;
}

/* Dedicated overlay div — replaces ::after for Customizer-driven heroes */
.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(15, 23, 42, 0.72) 0%,
    rgba(15, 23, 42, 0.50) 50%,
    rgba(15, 23, 42, 0.30) 100%
  );
  z-index: 1;
}
.page-hero--tall .page-hero__content {
  position: relative;
  z-index: 2;
}
/* When overlay div is present, disable the ::after pseudo */
.page-hero--tall::after {
  display: none;
}

.page-hero--simple {
  background:
    radial-gradient(circle at 82% 22%, rgba(110, 212, 192, 0.12), transparent 28%),
    linear-gradient(135deg, #0f1923 0%, #1a2c3d 55%, #162433 100%);
}

.page-hero--simple .page-hero__overlay {
  background: linear-gradient(
    135deg,
    rgba(15, 23, 42, 0.35) 0%,
    rgba(15, 23, 42, 0.18) 55%,
    rgba(15, 23, 42, 0.08) 100%
  );
}

@media (max-width: 768px) {
  .page-hero--tall { min-height: 400px; }
}

/* ── SEKCJE ───────────────────────────────────────────────── */
.section {
  padding: 3.5rem 0;
}
.section--alt {
  background: var(--color-bg-alt);
}
.section--dark {
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
}
.section--dark h2,
.section--dark h3,
.section--dark h4 {
  color: #fff;
}
.section--dark p {
  color: rgba(255,255,255,0.8);
}

@media (min-width: 768px) {
  .section { padding: 5rem 0; }
}
@media (min-width: 1200px) {
  .section { padding: 6rem 0; }
}

.section__header {
  margin-bottom: 2.5rem;
}
.section__header--center { text-align: center; }
.section__header--center p { margin-inline: auto; max-width: 60ch; }
.section__header h2 {
  margin-bottom: 0.75rem;
}
.section__header p {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--color-text-secondary);
}

.section__label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 0.625rem;
}
.section__label::before {
  content: '';
  width: 28px;
  height: 2px;
  background: var(--color-accent);
  border-radius: 2px;
}
.section--dark .section__label,
.page-hero .section__label {
  display: inline-block;
  padding: 0.375rem 1rem;
  background: rgba(29, 106, 91, 0.9);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
}
.section--dark .section__label::before,
.page-hero .section__label::before {
  display: none;
}
.section__header--center .section__label::before {
  display: none;
}

/* ── KARTY USŁUG ──────────────────────────────────────────── */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 576px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }

.service-card {
  background: var(--color-bg);
  border: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 350ms ease, transform 350ms ease;
  text-decoration: none;
  color: inherit;
  position: relative;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.service-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-accent), var(--ks-hero-end));
  transform: scaleX(0);
  transition: transform 350ms ease;
  transform-origin: left;
  z-index: 3;
}
.service-card:hover::before { transform: scaleX(1); }
.service-card:hover {
  box-shadow: 0 12px 40px rgba(0,0,0,0.15);
  transform: translateY(-6px);
}
.service-card__img-wrap {
  position: relative;
  overflow: hidden;
  background: #fff;
}
.service-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: contain;
  object-position: center center;
  transition: transform 500ms ease;
  display: block;
}
.service-card:hover .service-card__img { transform: none; }
.service-card__img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,23,42,0.25) 0%, transparent 50%);
  pointer-events: none;
}
.service-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.service-card__icon {
  width: 44px;
  height: 44px;
  background: var(--color-accent-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.25rem;
}
.service-card h3 {
  font-size: 1.125rem;
  color: var(--color-primary);
  font-weight: 800;
  font-family: var(--font-heading);
  text-wrap: balance;
}
.service-card p {
  font-size: 0.9375rem;
  color: var(--color-text);
  line-height: 1.65;
  flex: 1;
}
.service-card__link {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-accent);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 0.625rem;
  letter-spacing: 0.02em;
  transition: gap 250ms ease, color 250ms ease;
}
.service-card:hover .service-card__link { color: var(--color-accent-hover); gap: 10px; }
.service-card__link:hover { color: var(--color-accent-hover); }

/* ── GALERIA / GRID ZDJĘĆ ─────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}
@media (min-width: 640px) {
  .gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
}
@media (min-width: 1024px) {
  .gallery-grid--full { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
}

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  cursor: pointer;
  background: var(--color-bg-alt);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transition: box-shadow 300ms ease, transform 300ms ease;
}
.gallery-item:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  transform: translateY(-3px);
}

.gallery-item__btn {
  display: block;
  width: 100%;
  aspect-ratio: 4/3;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  position: relative;
  overflow: hidden;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  background: #fff;
  transition: transform 400ms ease;
}
.gallery-item:hover img { transform: none; }

.gallery-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,23,42,0.7) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--transition);
  display: flex;
  align-items: flex-end;
  padding: var(--space-md);
}
.gallery-item:hover .gallery-item__overlay { opacity: 1; }
.gallery-item__caption {
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
}

/* Figcaption under gallery photos */
.gallery-item figcaption {
  padding: 0.6rem 0.75rem;
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.4;
  background: #fff;
}

/* Filter tabs */
.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}
.filter-tab {
  padding: 0.5rem 1.25rem;
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: 100px;
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  min-height: 44px;
  font-family: var(--font-body);
  color: var(--color-text);
}
.filter-tab:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.filter-tab.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.gallery-item[hidden] { display: none; }

/* ── O NAS ────────────────────────────────────────────────── */
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
  align-items: center;
}
@media (min-width: 768px) {
  .about-grid { grid-template-columns: 1fr 1fr; }
}

.about-img {
  border-radius: var(--radius-lg);
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: contain; /* cale zdjecie widoczne, bez przycinania */
  background: #fff;
  box-shadow: var(--shadow-lg);
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

.stat {
  background: var(--color-bg-alt);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  border-left: 4px solid var(--color-accent);
}
.stat__value {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
}
.stat__label {
  font-size: 0.9rem;
  color: var(--color-text);
  margin-top: var(--space-xs);
}

/* ── CECHY / FEATURES (legacy — replaced by .ks-feat-* in features.php) ── */
/* Styles kept for backward compatibility but no longer used on homepage */

/* ── PRODUKTY / OFERTA ────────────────────────────────────── */
.offer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
}
@media (min-width: 768px) { .offer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .offer-grid { grid-template-columns: repeat(3, 1fr); } }

.offer-card {
  background: var(--color-bg);
  border: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow 350ms ease, transform 350ms ease;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.offer-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.12); transform: translateY(-4px); }
.offer-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: contain;
  object-position: center center;
  background: #f0ebe4;
}
.offer-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
}
.offer-card h3 { color: var(--color-primary); margin-bottom: 0.5rem; font-family: var(--font-heading); font-weight: 800; }
.offer-card p  { color: var(--color-text); font-size: 0.9375rem; line-height: 1.65; }
.offer-card__list {
  list-style: none;
  margin-top: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.offer-card__list li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: var(--color-text);
}
.offer-card__list li::before {
  content: '✓';
  color: var(--color-success);
  font-weight: 700;
  flex-shrink: 0;
}

/* ── CTA SECTION ──────────────────────────────────────────── */
.cta-section {
  background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--ks-hero-start) 100%);
  color: #fff;
  padding: 3rem 0;
  text-align: center;
}
.cta-section h2 { color: #fff; margin-bottom: var(--space-md); }
.cta-section p  { color: rgba(255,255,255,0.85); margin-bottom: 1.5rem; margin-inline: auto; }
.cta-section .btn-outline { border-color: rgba(255,255,255,0.7); color: #fff; }
.cta-section .btn-outline:hover { background: rgba(255,255,255,0.15); }
.cta-section .btn-primary {
  background: linear-gradient(135deg, var(--color-accent), var(--ks-hero-end));
  color: #fff;
  border-color: transparent;
}
.cta-section .btn-primary:hover {
  box-shadow: 0 6px 24px rgba(29,106,91,0.4);
  transform: translateY(-1px);
}
.cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: center;
  align-items: center;
}

/* ── FAQ CZYTELNOŚĆ ──────────────────────────────────────── */
details p,
details [itemprop="text"],
details span[itemprop="text"] {
  color: #374151 !important;
  font-size: 0.9625rem !important;
  line-height: 1.7 !important;
}
details summary {
  font-size: 1rem;
  min-height: 48px;
}
details[open] summary svg {
  transform: rotate(180deg);
}
details summary svg {
  transition: transform 200ms ease;
  flex-shrink: 0;
}

/* ── FORMULARZ ────────────────────────────────────────────── */
.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
@media (min-width: 768px) {
  .form-grid { grid-template-columns: repeat(2, 1fr); }
  .form-grid .full-width { grid-column: 1 / -1; }
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.form-field label {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text);
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  min-height: 44px;
  transition: border-color var(--transition), box-shadow var(--transition);
  appearance: none;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--color-focus);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
  outline: none;
}

.form-field textarea { min-height: 140px; resize: vertical; }

.form-field .error-msg {
  font-size: 0.875rem;
  color: var(--color-error);
  display: flex;
  align-items: center;
  gap: 4px;
}

.form-field input[aria-invalid="true"],
.form-field textarea[aria-invalid="true"] {
  border-color: var(--color-error);
}

/* ── FORM ROW — 2-kolumna z mobile stack ──────────────────── */
.ks-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
@media (max-width: 576px) {
  .ks-form-row {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  .cta-section .container > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }
}

/* ── KONTAKT ──────────────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 992px) {
  .contact-layout { grid-template-columns: 1.4fr 1fr; }
}

.contact-info__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.contact-item {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}

.contact-item__icon {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  background: var(--color-accent-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-item__body strong { display: block; font-size: 1rem; color: var(--color-text); }
.contact-item__body a,
.contact-item__body span { color: var(--color-text-secondary); font-size: 0.9375rem; }
.contact-item__body a { text-decoration: none; }
.contact-item__body a:hover { color: var(--color-accent); }

.map-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--color-bg-alt);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--space-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-xl);
  overflow: hidden;
}

/* ── MATERIAŁY ────────────────────────────────────────────── */
.materials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-lg);
}
.material-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-align: center;
}
.material-card__img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

.hero__desc,
.page-hero__desc,
.section__header p,
.service-card p,
.offer-card p,
.gallery-item figcaption,
.ks-faq__answer p {
  text-wrap: pretty;
}

.section__header h2,
.service-card h3,
.offer-card h3 {
  text-wrap: balance;
}

.ks-form-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  text-align: center;
}

.ks-form-intro__icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
}

.ks-form-intro h3 {
  font-size: 0.9375rem;
  color: var(--color-primary);
  margin: 0;
  font-weight: 700;
}

.ks-form-intro p {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  margin: 0;
  text-wrap: pretty;
}
.material-card__name {
  padding: var(--space-md);
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--color-text);
}

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer {
  background: var(--color-bg-dark-alt);
  color: rgba(255,255,255,0.75);
  padding: var(--space-3xl) 0 0;
  margin-top: auto;
}

.footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
}
@media (min-width: 576px) { .footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .footer__grid { grid-template-columns: 2fr 1fr 1fr 1.5fr; } }

.footer__brand { display: flex; flex-direction: column; gap: var(--space-md); }
.footer__logo { display: flex; align-items: center; gap: var(--space-sm); text-decoration: none; }
.footer__logo-text { font-family: var(--font-heading); font-size: 1.25rem; font-weight: 700; color: #fff; }
.footer__tagline { font-size: 0.9375rem; line-height: 1.6; }

.footer__col h4 {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: var(--space-md);
}

.footer__links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.footer__links a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  font-size: 0.9375rem;
  transition: color var(--transition);
}
.footer__links a:hover { color: #fff; }

.footer__contact-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.footer__contact-list li { font-size: 0.9375rem; }
.footer__contact-list a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  transition: color var(--transition);
}
.footer__contact-list a:hover { color: #fff; }

.footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: var(--space-2xl);
  padding: var(--space-lg) 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  font-size: 0.875rem;
}
.footer__legal a {
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  transition: color var(--transition);
}
.footer__legal a:hover { color: rgba(255,255,255,0.85); }
.footer__legal span { color: rgba(255,255,255,0.25); margin: 0 0.5rem; }

/* ── UTILITIES ────────────────────────────────────────────── */
.text-center  { text-align: center; }
.text-accent  { color: var(--color-accent); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}

/* ── ANIMACJE ─────────────────────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  .fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 500ms ease, transform 500ms ease;
  }
  .fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .fade-in { opacity: 1; transform: none; }
  * { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

/* ── LIGHTBOX ─────────────────────────────────────────────── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9000;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
}
.lightbox.is-open { display: flex; }
.lightbox__img {
  max-width: 100%;
  max-height: 90vh;
  object-fit: contain;
  border-radius: var(--radius-md);
}
.lightbox__close {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.15);
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 1.5rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition);
}
.lightbox__close:hover { background: rgba(255,255,255,0.25); }

.lightbox__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  max-width: min(90vw, 1000px);
}
.lightbox__caption {
  color: rgba(255,255,255,0.75);
  font-size: 0.9375rem;
  text-align: center;
}

/* ── GALLERY FILTER ───────────────────────────────────────── */
.gallery-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}
.gallery-filter__btn {
  padding: 0.5rem 1.25rem;
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: 100px;
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  min-height: 44px;
  font-family: var(--font-body);
  color: var(--color-text);
}
.gallery-filter__btn:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.gallery-filter__btn.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
/* gallery-item__btn rules moved to gallery section above */

/* ── CONTACT FORM ─────────────────────────────────────────── */
.contact-form-wrap {
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  border: 1px solid var(--color-border);
}
.contact-form-wrap__title {
  font-size: clamp(1.1rem, 1rem + 0.5vw, 1.4rem);
  margin-bottom: 1rem;
  color: var(--color-primary);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 0.875rem;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.875rem;
}
@media (max-width: 540px) { .form-row { grid-template-columns: 1fr; } }
.form-label {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.form-input,
.form-textarea,
select.form-input {
  width: 100%;
  padding: 0.55rem 0.8rem;
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-text);
  background: #fff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  min-height: 44px;
  transition: border-color 200ms ease, box-shadow 200ms ease;
  appearance: none;
  line-height: 1.4;
}
.form-input:focus,
.form-textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(29,106,91,0.1);
  outline: none;
}
.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-text-light);
}
.form-input[aria-invalid="true"],
.form-textarea[aria-invalid="true"] {
  border-color: var(--color-error);
}
.form-textarea { min-height: 90px; resize: vertical; }
.form-error {
  font-size: 0.875rem;
  color: var(--color-error);
  min-height: 1.2em;
}
.form-success {
  display: none;
  align-items: center;
  gap: var(--space-sm);
  background: #dcfce7;
  color: #15803d;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius-md);
  padding: 1rem 1.25rem;
  font-weight: 600;
  margin-top: var(--space-lg);
}
.form-success[hidden] {
  display: none !important;
}

/* ── CONTACT INFO CARDS ───────────────────────────────────── */
.contact-info { display: flex; flex-direction: column; gap: 0.75rem; }
.contact-info__card {
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1rem 1.25rem;
}
.contact-info__card h3 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 1rem;
  margin-bottom: var(--space-md);
  color: var(--color-primary);
}
.contact-info__link {
  color: var(--color-accent);
  text-decoration: none;
  font-size: 0.9375rem;
  transition: color var(--transition);
  display: inline-flex;
  align-items: center;
}
.contact-info__link:hover { color: var(--color-accent-hover); }
.contact-info__link--big {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-primary);
  font-family: var(--font-heading);
}
.contact-info__link--big:hover { color: var(--color-accent); }
.contact-info__card p {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  margin-top: var(--space-xs);
}
.contact-info__card address { font-style: normal; line-height: 1.7; }

/* ── FEATURE ITEM (alias) ─────────────────────────────────── */
.feature-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-xl);
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition), transform var(--transition);
}
.feature-item:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.feature-item__icon {
  width: 52px;
  height: 52px;
  background: var(--color-accent-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-accent);
}
.feature-item h3 { font-size: 1.0625rem; color: var(--color-primary); }
.feature-item p  { font-size: 0.9375rem; color: var(--color-text); line-height: 1.65; }

/* ── RADIUS FULL ──────────────────────────────────────────── */
:root { --radius-full: 100px; }

/* ── REVIEW CARDS ─────────────────────────────────────────── */
.reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
@media (min-width: 576px) { .reviews-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .reviews-grid { grid-template-columns: repeat(3, 1fr); } }

.review-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: box-shadow var(--transition), transform var(--transition);
}
.review-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.review-card__stars {
  display: flex;
  gap: 3px;
  color: #3b6daa;
}
.review-card__text {
  font-size: 0.9375rem;
  color: var(--color-text);
  line-height: 1.7;
  font-style: italic;
  flex: 1;
}
.review-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: auto;
}
.review-card__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-accent-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--color-accent);
  flex-shrink: 0;
}
.review-card__name {
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--color-text);
}
.review-card__date {
  font-size: 0.8125rem;
  color: var(--color-text-light);
}

/* ── TRUST BAR ────────────────────────────────────────────── */
.trust-bar {
  background: var(--color-bg-dark);
  color: rgba(255,255,255,0.9);
  padding: var(--space-md) 0;
  border-bottom: 2px solid var(--color-accent);
}
.trust-bar__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2xl);
  align-items: center;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.9375rem;
  font-weight: 500;
}
.trust-item__value {
  font-family: var(--font-heading);
  font-size: 1.375rem;
  font-weight: 700;
  color: #3b6daa;
}
.trust-item__label {
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.3;
}

/* ── PRICE CARD ───────────────────────────────────────────── */
.price-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}
@media (min-width: 576px) { .price-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .price-cards { grid-template-columns: repeat(3, 1fr); } }
.price-card {
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: box-shadow var(--transition), border-color var(--transition);
}
.price-card:hover { box-shadow: var(--shadow-md); border-color: var(--color-accent); }
.price-card--featured {
  border-color: var(--color-accent);
  background: var(--color-accent-light);
  position: relative;
}
.price-card__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-accent);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.25rem 1rem;
  border-radius: var(--radius-full);
}
.price-card__title { font-size: 1.1rem; font-weight: 700; color: var(--color-primary); }
.price-card__from { font-size: 0.8125rem; color: var(--color-text-secondary); }
.price-card__price {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
}
.price-card__price span { font-size: 1rem; font-weight: 400; color: var(--color-text-secondary); }
.price-card__list {
  list-style: none;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  flex: 1;
}
.price-card__list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
}
.price-card__list li::before {
  content: '✓';
  color: var(--color-success);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ── SEO LOCATION SECTION ─────────────────────────────────── */
.location-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-md);
}
.location-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  transition: box-shadow var(--transition), border-color var(--transition), transform var(--transition);
}
.location-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-accent);
  transform: translateY(-2px);
}
.location-card__city {
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--color-primary);
}
.location-card__distance {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}

/* ── LANDING PAGE HERO (full-screen) ──────────────────────── */
.hero-landing {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
  overflow: hidden;
}
.hero-landing__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.45;
  z-index: 0;
}
.hero-landing__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(10, 15, 28, 0.95) 0%,
    rgba(15, 23, 42, 0.80) 55%,
    rgba(15, 23, 42, 0.50) 100%
  );
  z-index: 1;
}
.hero-landing__content {
  position: relative;
  z-index: 2;
  max-width: 700px;
}
.hero-landing__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  background: rgba(29,106,91,0.9);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.45rem 1.1rem;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-lg);
}
.hero-landing h1 {
  color: #fff;
  font-size: clamp(2rem, 1.5rem + 3.5vw, 3.75rem);
  line-height: 1.1;
  margin-bottom: var(--space-lg);
}
.hero-landing__lead {
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
  color: rgba(255,255,255,0.85);
  margin-bottom: var(--space-xl);
  max-width: 54ch;
}
.hero-landing__phone {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: clamp(1.375rem, 1rem + 1.5vw, 2rem);
  font-family: var(--font-heading);
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background: var(--color-accent);
  padding: 0.75rem 2rem;
  border-radius: var(--radius-md);
  transition: background var(--transition), box-shadow var(--transition);
}
.hero-landing__phone:hover {
  background: var(--color-accent-hover);
  color: #fff;
  box-shadow: 0 6px 24px rgba(29,106,91,0.5);
}
.hero-landing__secondary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  font-size: 0.9375rem;
  font-weight: 500;
  margin-left: var(--space-lg);
  border-bottom: 1px solid rgba(255,255,255,0.4);
  padding-bottom: 2px;
  transition: color var(--transition), border-color var(--transition);
}
.hero-landing__secondary:hover {
  color: #fff;
  border-color: #fff;
}

/* ── STRIP NAV (landing page) ─────────────────────────────── */
.strip-nav {
  background: var(--color-bg-dark);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 1000;
  border-bottom: 2px solid var(--color-accent);
}
.strip-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: var(--space-md);
}
.strip-nav__logo {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  text-decoration: none;
  flex-shrink: 0;
}
.strip-nav__logo-name {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
}
.strip-nav__logo-tagline {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.strip-nav__phone {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  background: var(--color-accent);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--transition);
}
.strip-nav__phone:hover { background: var(--color-accent-hover); color: #fff; }

/* ── COMPARISON TABLE ─────────────────────────────────────── */
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}
.compare-table th, .compare-table td {
  padding: 0.875rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
.compare-table th {
  background: var(--color-primary);
  color: #fff;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
}
.compare-table tr:nth-child(even) td { background: var(--color-bg-alt); }
.compare-table td:first-child { font-weight: 600; }
.compare-table .yes { color: var(--color-success); font-weight: 700; }
.compare-table .no  { color: var(--color-text-light); }

/* ── STICKY PHONE BAR ─────────────────────────────────────── */
.sticky-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 800;
  background: var(--color-accent);
  padding: 0.875rem var(--space-md);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  box-shadow: 0 -4px 20px rgba(0,0,0,0.25);
}
.sticky-cta a {
  color: #fff;
  font-weight: 700;
  font-size: 1.0625rem;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
@media (min-width: 769px) {
  .sticky-cta { display: none; }
}

/* ── SCROLL TO TOP ─────────────────────────────────────── */
.scroll-top {
  position: fixed;
  bottom: 5.5rem;
  right: 1.25rem;
  z-index: 799;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-primary);
  color: white;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s, transform 0.3s, background 0.2s;
  pointer-events: none;
}
.scroll-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.scroll-top:hover {
  background: var(--color-accent);
}
@media (min-width: 769px) {
  .scroll-top { bottom: 2rem; right: 2rem; }
}


/* ============================================================
   BLOG, ARCHIVE, SINGLE, SEARCH, 404, COMMENTS, SIDEBAR
   ============================================================ */

/* ── BLOG HERO ─────────────────────────────────────────────── */
.blog-hero{background:linear-gradient(135deg,var(--ks-hero-start) 0%,var(--ks-btn-bg) 50%,var(--ks-hero-end) 100%);color:#fff;padding:3.5rem 0 3rem;position:relative}
.blog-hero::before{content:'';position:absolute;inset:0;background:url('../img/banery/nagrobki-hero.webp') center/cover;opacity:.08}
.blog-hero .container{position:relative;z-index:1}
.blog-hero__bc{font-size:.8125rem;color:rgba(255,255,255,.55);margin-bottom:1rem}
.blog-hero__bc a{color:rgba(255,255,255,.65);text-decoration:none}
.blog-hero__bc a:hover{color:#fff}
.blog-hero__title{font-family:var(--font-heading);font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:800;margin-bottom:.5rem;line-height:1.2}
.blog-hero__desc{font-size:1.0625rem;color:rgba(255,255,255,.8);max-width:650px;line-height:1.7}

/* ── BLOG LAYOUT ───────────────────────────────────────────── */
.blog-content{padding:3rem 0}
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start}

/* ── CATEGORY FILTERS ──────────────────────────────────────── */
.blog-cats{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.blog-cat-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1rem;border:1px solid var(--color-border);border-radius:2rem;font-size:.875rem;color:var(--color-text-secondary);text-decoration:none;transition:all .2s;background:#fff}
.blog-cat-pill:hover,.blog-cat-pill.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}
.blog-cat-count{font-size:.75rem;opacity:.7}

/* ── BLOG GRID (CARDS) ─────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.blog-grid--3{grid-template-columns:repeat(3,1fr)}
.blog-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 2px 12px rgba(0,0,0,.06);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.blog-card__img-wrap{position:relative;display:block;overflow:hidden;aspect-ratio:16/10}
.blog-card__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.blog-card:hover .blog-card__img{transform:scale(1.05)}
.blog-card__img--placeholder{background:var(--color-bg-alt);display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.blog-card__badge{position:absolute;top:.75rem;left:.75rem;background:var(--color-accent);color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:2rem}
.blog-card__body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.blog-card__meta{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-text-light);margin-bottom:.5rem;flex-wrap:wrap}
.blog-card__type{background:var(--color-bg-alt);padding:.125rem .5rem;border-radius:4px;font-weight:600;font-size:.75rem}
.blog-card__title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;line-height:1.35;margin-bottom:.5rem}
.blog-card__title a{color:var(--color-primary);text-decoration:none}
.blog-card__title a:hover{color:var(--color-accent)}
.blog-card__excerpt{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.65;margin-bottom:auto;flex:1}
.blog-card__read{display:inline-flex;align-items:center;gap:.25rem;color:var(--color-accent);font-weight:600;font-size:.875rem;text-decoration:none;margin-top:.75rem}
.blog-card__read:hover{text-decoration:underline}

/* ── BLOG PAGINATION ───────────────────────────────────────── */
.blog-pagination{margin-top:2.5rem;text-align:center}
.blog-pagination ul{list-style:none;padding:0;display:inline-flex;gap:.35rem;flex-wrap:wrap}
.blog-pagination li{display:inline}
.blog-pagination a,.blog-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text);text-decoration:none;transition:all .2s;padding:0 .5rem}
.blog-pagination a:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}
.blog-pagination .current{background:var(--color-accent);color:#fff;border-color:var(--color-accent);font-weight:700}

/* ── BLOG EMPTY STATE ──────────────────────────────────────── */
.blog-empty{text-align:center;padding:4rem 2rem}
.blog-empty svg{margin-bottom:1.5rem}
.blog-empty h2{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:.5rem}
.blog-empty p{color:var(--color-text-secondary);max-width:400px;margin:0 auto}
.blog-empty a{color:var(--color-accent);font-weight:600}

/* ── BLOG CTA SECTION ──────────────────────────────────────── */
.blog-cta-section{padding:0 0 3rem}
.blog-cta-box{background:linear-gradient(135deg,var(--ks-btn-bg),var(--ks-hero-end));border-radius:var(--radius-lg);padding:3rem;text-align:center;color:#fff}
.blog-cta-box h2{font-family:var(--font-heading);color:#fff;font-size:1.5rem;margin-bottom:.5rem}
.blog-cta-box p{color:rgba(255,255,255,.85);margin-bottom:1.5rem}
.blog-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── BLOG RELATED ──────────────────────────────────────────── */
.blog-related{padding:3rem 0;background:var(--color-bg-alt)}
.blog-related h2{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:1.5rem;color:var(--color-primary)}

/* ── SIDEBAR ───────────────────────────────────────────────── */
.blog-sidebar{position:sticky;top:100px}
.sidebar-widget{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}
.sidebar-widget__title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--color-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-accent)}

/* Search widget */
.sidebar-search{display:flex;gap:.5rem}
.sidebar-search__input{flex:1}

/* Categories widget */
.sidebar-cats{list-style:none;padding:0;margin:0}
.sidebar-cats li{margin-bottom:0}
.sidebar-cats a{display:flex;justify-content:space-between;align-items:center;padding:.625rem 0;font-size:.9375rem;min-height:44px;color:var(--color-text-secondary);text-decoration:none;border-bottom:1px solid var(--color-border);transition:color .2s}
.sidebar-cats a:hover,.sidebar-cats a.active{color:var(--color-accent);font-weight:600}
.sidebar-cats__count{background:var(--color-bg-alt);font-size:.75rem;padding:.125rem .5rem;border-radius:2rem;color:var(--color-text-light)}

/* Popular posts widget */
.sidebar-popular__item{display:flex;gap:.75rem;align-items:center;padding:.625rem 0;min-height:44px;text-decoration:none;border-bottom:1px solid var(--color-border);transition:background .2s}
.sidebar-popular__item:hover{background:var(--color-bg-alt);border-radius:var(--radius-md);margin:0 -.5rem;padding:.5rem}
.sidebar-popular__img{width:56px;height:56px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}
.sidebar-popular__img--placeholder{background:var(--color-bg-alt)}
.sidebar-popular__title{display:block;font-size:.875rem;font-weight:600;color:var(--color-primary);line-height:1.35}
.sidebar-popular__date{display:block;font-size:.75rem;color:var(--color-text-light);margin-top:.15rem}

/* CTA widget */
.sidebar-cta{background:linear-gradient(135deg,var(--ks-btn-bg),var(--ks-hero-end));border:none;color:#fff}
.sidebar-cta .sidebar-widget__title{color:#fff;border-color:rgba(255,255,255,.2)}
.sidebar-cta__inner{text-align:center}
.sidebar-cta__inner h3{color:#fff;font-family:var(--font-heading);font-size:1.125rem;margin:.75rem 0 .5rem}
.sidebar-cta__inner p{color:rgba(255,255,255,.8);font-size:.9375rem;margin-bottom:1rem}

/* ── SINGLE POST ───────────────────────────────────────────── */
.single-hero{padding:3rem 0 2rem;background:var(--color-bg-alt)}
.single-hero__meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:1rem}
.single-hero__cat{background:var(--color-accent);color:#fff;padding:.2rem .75rem;border-radius:2rem;font-size:.8125rem;font-weight:600;text-decoration:none}
.single-hero__title{font-family:var(--font-heading);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;line-height:1.2;color:var(--color-primary);margin-bottom:1rem}
.single-hero__excerpt{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.7;max-width:700px}
.single-hero__author{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem}
.single-hero__avatar{width:40px;height:40px;border-radius:50%;border:2px solid var(--color-border)}
.single-hero__author strong{display:block;font-size:.9375rem;color:var(--color-primary)}
.single-hero__author span{font-size:.8125rem;color:var(--color-text-light)}

/* Featured image */
.single-featured{padding:2rem 0 0}
.single-featured__fig{margin:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.single-featured__img{width:100%;max-height:500px;object-fit:cover;display:block}
.single-featured__fig figcaption{font-size:.8125rem;color:var(--color-text-light);text-align:center;padding:.75rem}

/* Article body */
.single-body{font-size:1.0625rem;line-height:1.8;color:var(--color-text)}
.single-body h2{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--color-primary);margin:2.5rem 0 1rem}
.single-body h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-primary);margin:2rem 0 .75rem}
.single-body p{margin-bottom:1.25rem}
.single-body img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:1.5rem 0}
.single-body ul,.single-body ol{margin:1rem 0 1.25rem 1.5rem}
.single-body li{margin-bottom:.35rem}
.single-body blockquote{border-left:4px solid var(--color-accent);background:var(--color-bg-alt);padding:1.25rem 1.5rem;margin:1.5rem 0;font-style:italic;border-radius:0 var(--radius-md) var(--radius-md) 0}
.single-body a{color:var(--color-accent);font-weight:600}

/* Tags */
.single-tags{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:1.5rem 0;border-top:1px solid var(--color-border);margin-top:2rem}
.single-tag{display:inline-block;padding:.25rem .75rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:2rem;font-size:.8125rem;color:var(--color-text-secondary);text-decoration:none;transition:all .2s}
.single-tag:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}

/* Share */
.single-share{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:1.25rem 0;border-top:1px solid var(--color-border)}
.single-share__btn{display:inline-flex;align-items:center;gap:.4rem;padding:.625rem 1.25rem;min-height:44px;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;text-decoration:none;transition:opacity .2s}
.single-share__btn:hover{opacity:.85}
.single-share__btn--fb{background:#1877f2;color:#fff}
.single-share__btn--wa{background:#25d366;color:#fff}

/* Inline CTA */
.single-cta{background:linear-gradient(135deg,var(--ks-btn-bg),var(--ks-hero-end));border-radius:var(--radius-lg);padding:2rem;text-align:center;color:#fff;margin:2rem 0}
.single-cta h3{font-family:var(--font-heading);color:#fff;font-size:1.25rem;margin-bottom:.5rem}
.single-cta p{color:rgba(255,255,255,.85);margin-bottom:1rem}

/* Post navigation */
.single-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:2rem 0;border-top:1px solid var(--color-border)}
.single-nav__link{display:block;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all .2s}
.single-nav__link:hover{border-color:var(--color-accent);background:var(--color-bg-alt)}
.single-nav__link--next{text-align:right}
.single-nav__label{display:block;font-size:.8125rem;color:var(--color-text-light);margin-bottom:.25rem}
.single-nav__title{display:block;font-weight:600;color:var(--color-primary);font-size:.9375rem;line-height:1.4}

/* ── SEARCH INLINE ─────────────────────────────────────────── */
.search-inline{display:flex;gap:.75rem;margin-bottom:2rem}
.search-inline__input{flex:1}

/* ── 404 PAGE ──────────────────────────────────────────────── */
.error-404{padding:5rem 0}
.error-404__inner{text-align:center;max-width:600px;margin:0 auto}
.error-404__code{font-family:var(--font-heading);font-size:8rem;font-weight:800;color:var(--color-accent);line-height:1;opacity:.15;margin-bottom:-1rem}
.error-404 h1{font-family:var(--font-heading);font-size:2rem;color:var(--color-primary);margin-bottom:1rem}
.error-404 p{color:var(--color-text-secondary);font-size:1.0625rem;line-height:1.7;margin-bottom:2rem}
.error-404__search{display:flex;gap:.75rem;margin-bottom:2.5rem}
.error-404__search input{flex:1}
.error-404__links h3{font-size:1rem;color:var(--color-text-light);margin-bottom:1rem}
.error-404__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.error-404__link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9375rem;color:var(--color-text);text-decoration:none;transition:all .2s}
.error-404__link:hover{border-color:var(--color-accent);background:var(--color-bg-alt);color:var(--color-accent)}
.error-404__link--phone{background:var(--color-accent);color:#fff;border-color:var(--color-accent);font-weight:600}

/* ── COMMENTS ──────────────────────────────────────────────── */
.comments-area{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--color-border)}
.comments-title{font-family:var(--font-heading);font-size:1.25rem;margin-bottom:1.5rem}
.comment-list{list-style:none;padding:0}
.comment-list .comment{padding:1.25rem;margin-bottom:1rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg)}
.comment-list .comment .comment-author{font-weight:700;font-size:.9375rem}
.comment-list .comment .comment-metadata{font-size:.8125rem;color:var(--color-text-light)}
.comment-list .comment p{margin-top:.5rem;font-size:.9375rem;line-height:1.65}
.comment-form label{display:block;font-size:.875rem;font-weight:600;color:var(--color-primary);margin-bottom:.35rem}
.comment-form input[type="text"],.comment-form input[type="email"],.comment-form input[type="url"],.comment-form textarea{width:100%;margin-bottom:1rem}
.comment-form textarea{min-height:120px}
.comments-closed{color:var(--color-text-light);font-style:italic;text-align:center;padding:1rem}

/* ── BLOG RESPONSIVE ───────────────────────────────────────── */
@media(max-width:1024px){
  .blog-layout{grid-template-columns:1fr;gap:2rem}
  .blog-sidebar{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
  .blog-sidebar .sidebar-cta{grid-column:1/-1}
}
@media(max-width:768px){
  .blog-grid{grid-template-columns:1fr}
  .blog-grid--3{grid-template-columns:1fr}
  .blog-hero{padding:2.5rem 0 2rem}
  .blog-cats{gap:.35rem}
  .blog-cat-pill{font-size:.8125rem;padding:.35rem .75rem}
  .single-nav{grid-template-columns:1fr}
  .error-404__grid{grid-template-columns:repeat(2,1fr)}
  .error-404__code{font-size:5rem}
  .blog-sidebar{grid-template-columns:1fr}
  .single-hero__title{font-size:1.5rem}
}

/* ============================================================
   RESPONSYWNOŚĆ — POPRAWKI KRYTYCZNE
   ============================================================ */

/* About stats — mobile 1 col */
@media (max-width: 576px) {
  .about-stats { grid-template-columns: 1fr; gap: 1rem; }
}

/* Blog grid — mobile stack */
@media (max-width: 576px) {
  .blog-grid { grid-template-columns: 1fr !important; gap: 1.25rem; }
}

/* Error 404 — mobile 1 col */
@media (max-width: 576px) {
  .error-404__grid { grid-template-columns: 1fr; }
}

/* Offer grid (blaty) — improve tablet */
@media (max-width: 992px) and (min-width: 769px) {
  .offer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
  .offer-grid { grid-template-columns: 1fr; gap: 1.25rem; }
  .offer-card__img { aspect-ratio: 16 / 9; }
}

/* When offer-grid has exactly 5 cards, center the last row of 2 on desktop.
   Uses a 6-col grid where each card spans 2 cols → effective 3-col layout,
   but cards 4 and 5 are shifted by 1 col each so the bottom row is centered. */
@media (min-width: 1200px) {
  .offer-grid:has(> .offer-card:nth-child(5):last-child) {
    grid-template-columns: repeat(6, 1fr);
  }
  .offer-grid:has(> .offer-card:nth-child(5):last-child) > .offer-card {
    grid-column: span 2;
  }
  .offer-grid:has(> .offer-card:nth-child(5):last-child) > .offer-card:nth-child(4) {
    grid-column: 2 / span 2;
  }
  .offer-grid:has(> .offer-card:nth-child(5):last-child) > .offer-card:nth-child(5) {
    grid-column: 4 / span 2;
  }
}
/* Fallback for browsers without :has() — target the 4th card when it is
   second-to-last (total=5) and shift start column; last card flows naturally. */
@supports not selector(:has(*)) {
  @media (min-width: 1200px) {
    .offer-grid > .offer-card:nth-child(4):nth-last-child(2) { margin-left: 50%; }
    .offer-grid > .offer-card:nth-child(5):last-child { margin-left: -50%; }
  }
}

/* Footer — small mobile */
@media (max-width: 480px) {
  .footer__grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer__brand { text-align: center; }
}

/* ============================================================
   WEB STANDARDS 2026 — ROZSZERZENIA
   Focus, a11y, print, high-contrast, selection, forms, touch
   ============================================================ */

/* ── FOCUS-VISIBLE ENHANCED ───────────────────────────────── */
:focus:not(:focus-visible) {
  outline: none;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid var(--color-focus, #3b82f6);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ── ARIA-CURRENT (nawigacja aktywna) ─────────────────────── */
[aria-current="page"],
[aria-current="step"],
.nav-menu a[aria-current="page"] {
  font-weight: 700;
  color: var(--color-accent);
  text-decoration-thickness: 3px;
}

/* ── HIGH CONTRAST MODE ───────────────────────────────────── */
@media (prefers-contrast: high) {
  :root {
    --color-text: #000;
    --color-text-secondary: #222;
    --color-bg: #fff;
    --color-bg-alt: #f0f0f0;
    --color-border: #000;
    --color-border-strong: #000;
  }
  .btn, .btn-primary, .btn-accent {
    border: 2px solid currentColor !important;
  }
  .section--dark, .cta-final {
    border: 2px solid #fff;
  }
}

/* ── FORCED COLORS (Windows High Contrast) ────────────────── */
@media (forced-colors: active) {
  .btn, .btn-primary, .btn-accent, .btn-outline {
    border: 2px solid ButtonText;
  }
  a { text-decoration: underline; }
  .gal-tab--active { border: 3px solid Highlight; }
  :focus-visible { outline: 3px solid Highlight; }
}

/* ── TEXT SELECTION ────────────────────────────────────────── */
::selection {
  background: var(--color-accent, #1D6A5B);
  color: #fff;
}

/* ── SMOOTH SCROLL — respektowanie preferencji ────────────── */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* ── TOUCH TARGET MINIMUM 44×44px ─────────────────────────── */
@media (pointer: coarse) {
  button, .btn, a.btn,
  input[type="submit"],
  input[type="button"],
  .nav-menu a,
  .gal-tab,
  .footer-menu a,
  .blog-cat-pill,
  .blog-pagination a,
  .blog-pagination span {
    min-height: 44px;
    min-width: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* ── FORM ENHANCEMENTS (inputmode, autocomplete) ──────────── */
input, textarea, select {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  accent-color: var(--color-accent, #1D6A5B);
}

input::placeholder,
textarea::placeholder {
  color: var(--color-text-light, #94a3b8);
  opacity: 1;
}

/* Autofill styling */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0px 1000px var(--color-bg-alt, #f8f6f2) inset;
  -webkit-text-fill-color: var(--color-text, #1e293b);
  transition: background-color 5000s ease-in-out 0s;
}

/* Invalid states — only when user has interacted */
input:user-invalid,
textarea:user-invalid,
select:user-invalid {
  border-color: var(--color-error, #dc2626);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.15);
}

input:user-valid:not(:placeholder-shown),
textarea:user-valid:not(:placeholder-shown) {
  border-color: var(--color-success, #15803d);
}

/* ── IMAGES — ASPECT RATIO & LOADING ─────────────────────── */
img[loading="lazy"] {
  content-visibility: auto;
}

img {
  font-style: italic; /* Fallback text styling for broken images */
  vertical-align: middle;
  shape-margin: 0.75rem;
}

/* ── SCROLL MARGIN FOR ANCHORS ────────────────────────────── */
[id] {
  scroll-margin-top: calc(var(--header-h, 72px) + 1.5rem);
}

/* ── TABLE DEFAULTS ───────────────────────────────────────── */
table {
  border-collapse: collapse;
  width: 100%;
  font-variant-numeric: tabular-nums;
}
th, td {
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
th {
  font-weight: 700;
  color: var(--color-primary);
  background: var(--color-bg-alt);
}

/* ── DETAILS/SUMMARY (FAQ accordion) ──────────────────────── */
details {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0;
  margin-bottom: 0.75rem;
}
details summary {
  padding: 1rem 1.25rem;
  cursor: pointer;
  font-weight: 600;
  color: var(--color-primary);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 44px;
}
details summary::after {
  content: '+';
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--color-text-light);
  transition: transform 0.25s ease;
}
details[open] summary::after {
  content: '−';
}
details summary::-webkit-details-marker { display: none; }
details > :not(summary) {
  padding: 0 1.25rem 1rem;
}

/* ── BREADCRUMBS ──────────────────────────────────────────── */
.breadcrumbs {
  font-size: 0.8125rem;
  color: var(--color-text-light);
  padding: 0.75rem 0;
}
.breadcrumbs a {
  color: var(--color-text-secondary);
  text-decoration: none;
}
.breadcrumbs a:hover { color: var(--color-accent); text-decoration: underline; }
.breadcrumbs__sep { margin: 0 0.5rem; opacity: 0.5; }

/* ── VISUALLY HIDDEN (enhanced) ───────────────────────────── */
.visually-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/* ── LOADING STATES ───────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, var(--color-bg-alt) 25%, #e8e4df 50%, var(--color-bg-alt) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-md);
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* ── NOTIFICATION / ALERT ─────────────────────────────────── */
.alert {
  padding: 1rem 1.25rem;
  border-radius: var(--radius-md);
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: 1rem;
}
.alert--success { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; }
.alert--error   { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }
.alert--warning { background: #fef3c7; color: #92400e; border: 1px solid #fcd34d; }
.alert--info    { background: #dbeafe; color: #1e40af; border: 1px solid #93c5fd; }

/* ── PRINT STYLES ─────────────────────────────────────────── */
@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  body {
    font-size: 12pt;
    line-height: 1.5;
    font-family: Georgia, 'Times New Roman', serif;
  }

  a, a:visited { text-decoration: underline; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 0.8em; }
  a[href^="#"]::after,
  a[href^="javascript:"]::after,
  a[href^="tel:"]::after { content: ""; }

  img { max-width: 100% !important; page-break-inside: avoid; }

  h1, h2, h3 { page-break-after: avoid; }
  p, li { orphans: 3; widows: 3; }

  .site-header,
  .top-bar,
  .site-footer,
  .sticky-cta-mobile,
  .lightbox,
  nav,
  .btn,
  .gal-tabs,
  .gal-cta,
  .dodatki-cta,
  .contact-form,
  .cta-final,
  .loc-index-cta,
  form {
    display: none !important;
  }

  .container { width: 100%; max-width: 100%; }
  .sectio

/* ── MOBILE HEADER OVERRIDE (v2 force) ─────────────────────── */
@media (max-width: 991.98px) {
  .header__inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 0.5rem !important;
    width: 100% !important;
  }
  .logo {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .logo__text {
    min-width: 0 !important;
    flex: 1 1 auto !important;
    overflow: hidden !important;
  }
  .logo__name {
    font-size: 1rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .logo__tagline {
    font-size: 0.65rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .site-nav { display: none !important; }
  .header__cta { display: none !important; }
  .hamburger {
    display: flex !important;
    flex-shrink: 0 !important;
    margin-left: auto !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    position: relative !important;
    z-index: 20 !important;
    background: transparent !important;
    border: 0 !important;
    padding: 8px !important;
  }
  .hamburger span {
    display: block !important;
    width: 28px !important;
    height: 3px !important;
    background: var(--color-primary, #0E97D4) !important;
    border-radius: 2px !important;
    margin: 3px auto !important;
  }
}
@media (max-width: 480px) {
  .logo__tagline { display: none !important; }
  .logo__img { width: 40px !important; height: 40px !important; }
  .logo__name { font-size: 0.95rem !important; }
}
