/* =============================================================================
   site.css — OSK Pawłat Szczecinek
   Charakter: CIEMNY navy+gold, diagonal-split hero, alternating-split rhythm.
   Seed: grain-overlay + cursor-glow, Space Grotesk display / Inter body.
   Nadpisuje i rozszerza styles.css (tokens.css → styles.css → site.css).
   NIE zmienia wartości tokenów z tokens.css — wyłącznie ich konsumpcja.
   ============================================================================= */

/* --- Fonty (Sora jako display heading zamiast Space Grotesk — token --font-heading) */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Inter:wght@400;500;600&display=swap');

/* --- Korekta typografii dla ciemnego motywu -------------------------------- */
body { color: var(--text-body); background: var(--color-bg); }
p  { color: var(--text-body); }
.muted { color: var(--text-muted); }
strong { color: var(--text-strong); }

/* --- Link globalny (nawigacja) ---------------------------------------------- */
a { color: inherit; text-decoration: none; }
a:hover { color: var(--color-primary); }

/* --- Nagłówki sekcji z akcentem złota -------------------------------------- */
h2 { color: var(--text-strong); }
h3 { color: var(--text-strong); }

/* ============================================================================
   HEADER / NAWIGACJA
   ============================================================================ */
.site-header {
  background: color-mix(in srgb, var(--color-bg) 92%, transparent);
  border-bottom-color: var(--color-border);
}
.site-header .brand-name {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-lg);
  color: var(--text-strong);
  letter-spacing: -0.01em;
}
.site-header .brand-city {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}
.site-header nav[aria-label="Główna"] a {
  color: var(--text-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  transition: color var(--motion-dur) var(--motion-ease);
}
.site-header nav[aria-label="Główna"] a:hover { color: var(--color-primary); }
.site-header nav[aria-label="Główna"] a.cta-nav {
  background: var(--color-primary);
  color: var(--text-onPrimary);
  padding: 10px 20px;
  border-radius: var(--radius-md);
  font-weight: 700;
}
.site-header nav[aria-label="Główna"] a.cta-nav:hover {
  background: var(--color-primary600);
  color: var(--text-onPrimary);
}

/* hamburger kreski na ciemnym tle */
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  background: var(--text-strong);
}
.nav-toggle {
  background: transparent;
  border-color: var(--color-border);
}

/* ============================================================================
   HERO — DIAGONAL-SPLIT
   Lewa połowa: ciemny navy, treść; prawa: realne zdjęcie.
   Przekątna krawędź: clip-path na obu stronach.
   ============================================================================ */
.hero-diagonal {
  min-height: clamp(560px, 90svh, 900px);
  display: grid;
  grid-template-columns: 1fr;
  overflow: hidden;
  position: relative;
  isolation: isolate;
}
@media (min-width: 768px) {
  .hero-diagonal {
    grid-template-columns: 1fr 1fr;
  }
}

/* Lewa strona: content */
.hero-diagonal__content {
  background: var(--color-bg);
  padding: clamp(48px, 8vw, 96px) clamp(24px, 5vw, 72px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-5);
  position: relative;
  z-index: 2;
}
/* Przekątna złota krawędź — tylko desktop */
@media (min-width: 768px) {
  .hero-diagonal__content::after {
    content: "";
    position: absolute;
    right: -40px;
    top: 0;
    bottom: 0;
    width: 80px;
    background: var(--color-bg);
    clip-path: polygon(0 0, 40px 0, 100% 100%, 0 100%);
    z-index: 3;
  }
  /* Złota linia na przekątnej */
  .hero-diagonal__content::before {
    content: "";
    position: absolute;
    right: -43px;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, var(--color-primary) 0%, transparent 100%);
    transform: skewX(-6deg);
    z-index: 4;
    opacity: 0.7;
  }
}

/* Prawa strona: zdjęcie */
.hero-diagonal__image {
  position: relative;
  min-height: 320px;
  overflow: hidden;
}
@media (max-width: 767px) {
  .hero-diagonal__image {
    order: -1;
    min-height: 240px;
  }
}
.hero-diagonal__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
/* gradient overlay na zdjęciu dla spójności */
.hero-diagonal__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(15,27,49,0.3) 0%, transparent 60%);
  z-index: 1;
}

/* Eyebrow */
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  font-weight: 600;
}
.hero-eyebrow::before {
  content: "";
  display: block;
  width: 28px;
  height: 2px;
  background: var(--color-primary);
  border-radius: 1px;
}

/* H1 na hero */
.hero-diagonal__content h1 {
  font-size: clamp(32px, 6vw, var(--fs-4xl));
  font-weight: 800;
  color: var(--text-strong);
  line-height: 1.05;
  overflow-wrap: break-word;
  word-break: break-word;
}
.hero-diagonal__content h1 em {
  font-style: normal;
  color: var(--color-primary);
}

/* Lead pod H1 */
.hero-diagonal__content .hero-lead {
  font-size: var(--fs-lg);
  color: var(--text-body);
  max-width: 42ch;
  line-height: 1.55;
}

/* CTA cluster */
.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

/* Linia zaufania */
.hero-trust {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.hero-trust .stars { color: var(--color-primary); font-size: var(--fs-sm); letter-spacing: 2px; }
.hero-trust .rating { font-size: var(--fs-sm); font-weight: 700; color: var(--text-strong); }
.hero-trust .reviews-count { font-size: var(--fs-sm); color: var(--text-muted); }

/* ============================================================================
   PRZYCISKI — gold primary
   ============================================================================ */
.btn-gold {
  background: var(--color-primary);
  color: var(--text-onPrimary);
  font-weight: 700;
  border-radius: var(--radius-md);
  min-height: 52px;
  padding: 0 var(--space-6);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border: none;
  cursor: pointer;
  text-align: center;
  font-size: var(--fs-base);
  transition: background var(--motion-dur) var(--motion-ease),
              transform var(--motion-dur) var(--motion-ease),
              box-shadow var(--motion-dur) var(--motion-ease);
  box-shadow: 0 4px 16px rgba(224, 164, 58, 0.28);
}
.btn-gold:hover {
  background: var(--color-primary600);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(224, 164, 58, 0.38);
  color: var(--text-onPrimary);
}
.btn-gold:active { transform: translateY(0); }
.btn-gold:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.btn-gold:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 3px; }

.btn-outline {
  background: transparent;
  border: 1.5px solid var(--color-border);
  color: var(--text-body);
  min-height: 52px;
  padding: 0 var(--space-5);
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: var(--fs-base);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  cursor: pointer;
  transition: border-color var(--motion-dur) var(--motion-ease),
              color var(--motion-dur) var(--motion-ease),
              background var(--motion-dur) var(--motion-ease);
}
.btn-outline:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 8%, transparent);
}
.btn-outline:active { transform: translateY(1px); }
.btn-outline:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-outline:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 3px; }

/* ============================================================================
   PASEK LICZB (count-up)
   ============================================================================ */
.stats-bar {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-7);
}
.stats-bar__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  text-align: center;
}
@media (min-width: 640px) {
  .stats-bar__grid { grid-template-columns: repeat(4, 1fr); }
}
.stat-item { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); }
.stat-item__number {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}
.stat-item__label {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  max-width: 15ch;
  text-align: center;
}

/* ============================================================================
   SEKCJE TREŚCIOWE — alternating-split rhythm
   ============================================================================ */

/* Kicker / nadtytuł sekcji */
.section-kicker {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-primary);
  font-weight: 600;
  display: block;
  margin-bottom: var(--space-3);
}

/* Sekcja alternating-split: tekst 55% / wizualizacja 45% */
.split-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
  padding-block: var(--section-gap);
}
@media (min-width: 768px) {
  .split-section {
    grid-template-columns: 55fr 45fr;
  }
  .split-section.flip {
    grid-template-columns: 45fr 55fr;
  }
  .split-section.flip .split-section__media {
    order: -1;
  }
}
.split-section__text { display: flex; flex-direction: column; gap: var(--space-5); }
.split-section__media { position: relative; }
.split-section__media .media-frame { --media-ratio: 4/3; }

/* ============================================================================
   KAFLE "DLACZEGO OSK PAWŁAT" — 2×2 siatka
   ============================================================================ */
.why-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 640px) {
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
.why-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color var(--motion-dur) var(--motion-ease),
              transform var(--motion-dur) var(--motion-ease);
}
.why-card:hover {
  border-color: var(--color-primary);
  transform: translateY(-3px);
}
.why-card__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-primary) 14%, transparent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.why-card__icon svg { width: 22px; height: 22px; stroke: var(--color-primary); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.why-card h3 { font-size: var(--fs-lg); color: var(--text-strong); margin: 0; }
.why-card p { color: var(--text-body); margin: 0; font-size: var(--fs-base); }

/* ============================================================================
   KATEGORIE / USŁUGI — karty kursów
   ============================================================================ */
.courses-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 640px) {
  .courses-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .courses-grid { grid-template-columns: repeat(3, 1fr); }
}
.course-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--motion-dur) var(--motion-ease),
              box-shadow var(--motion-dur) var(--motion-ease),
              transform var(--motion-dur) var(--motion-ease);
}
.course-card:hover {
  border-color: var(--color-primary);
  box-shadow: 0 12px 36px rgba(0,0,0,0.3);
  transform: translateY(-4px);
}
.course-card__badge {
  background: var(--color-primary);
  color: var(--text-onPrimary);
  font-size: var(--fs-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: var(--space-2) var(--space-4);
  display: inline-block;
  align-self: flex-start;
  margin: var(--space-5) var(--space-5) 0;
  border-radius: var(--radius-sm);
}
.course-card__body {
  padding: var(--space-4) var(--space-5) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.course-card h3 { font-size: var(--fs-xl); color: var(--text-strong); margin: 0; }
.course-card p { color: var(--text-body); margin: 0; font-size: var(--fs-base); flex: 1; }
.course-card__price {
  font-family: var(--font-heading);
  font-size: var(--fs-2xl);
  font-weight: 800;
  color: var(--color-primary);
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.course-card__price small {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  font-weight: 400;
  display: block;
  margin-top: 2px;
}

/* ============================================================================
   KROKI KURSU
   ============================================================================ */
.steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  position: relative;
}
@media (min-width: 768px) {
  .steps { grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
}
.step-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
  position: relative;
}
/* linia łącząca kroki (desktop) */
@media (min-width: 768px) {
  .step-item:not(:last-child)::after {
    content: "";
    position: absolute;
    right: calc(-1 * var(--space-5) / 2 - 1px);
    top: 36px;
    width: var(--space-5);
    height: 2px;
    background: linear-gradient(90deg, var(--color-primary), transparent);
  }
}
.step-item__num {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-primary);
  color: var(--text-onPrimary);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: var(--fs-lg);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.step-item h3 { font-size: var(--fs-base); color: var(--text-strong); font-weight: 700; margin: 0; }
.step-item p { font-size: var(--fs-sm); color: var(--text-muted); margin: 0; }

/* ============================================================================
   OPINIE
   ============================================================================ */
.reviews-section {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 768px) { .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-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
}
.review-card__stars { color: var(--color-primary); letter-spacing: 2px; font-size: var(--fs-sm); }
.review-card blockquote {
  color: var(--text-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  margin: 0;
  quotes: "\201E" "\201D";
}
.review-card blockquote::before { content: open-quote; color: var(--color-primary); font-size: 2em; line-height: 0; vertical-align: -0.4em; margin-right: 4px; }
.review-card__author { font-weight: 600; color: var(--text-strong); font-size: var(--fs-sm); margin-top: auto; }
.review-card__placeholder {
  font-size: var(--fs-xs);
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  border-radius: var(--radius-sm);
  padding: 2px 8px;
  display: inline-block;
  width: fit-content;
}
/* Google aggregate */
.google-agg {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  flex-wrap: wrap;
}
.google-agg__score {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}
.google-agg__label { font-size: var(--fs-sm); color: var(--text-muted); }
.google-agg__link { font-size: var(--fs-sm); color: var(--color-accent); text-decoration: underline; }
.google-agg__link:hover { color: var(--color-accentHover); }

/* ============================================================================
   SEKCJA CTA
   ============================================================================ */
.cta-section {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: clamp(40px, 6vw, 80px) var(--space-7);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: "";
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--color-primary) 12%, transparent), transparent 70%);
  pointer-events: none;
}
.cta-section h2 { color: var(--text-strong); max-width: 28ch; }
.cta-section p { color: var(--text-body); max-width: 44ch; }
.cta-phone-link {
  font-family: var(--font-heading);
  font-size: var(--fs-2xl);
  font-weight: 800;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  transition: color var(--motion-dur) var(--motion-ease);
}
.cta-phone-link:hover { color: var(--color-primary600); }

/* ============================================================================
   STOPKA
   ============================================================================ */
.site-footer {
  background: var(--color-neutral900);
  border-top: 1px solid var(--color-border);
  padding-block: var(--space-8);
  color: var(--text-muted);
}
.footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
@media (min-width: 768px) {
  .footer-inner { grid-template-columns: 1fr 1fr 1fr; }
}
.footer-brand__name {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 800;
  color: var(--text-strong);
  margin-bottom: var(--space-3);
}
.footer-brand p { font-size: var(--fs-sm); color: var(--text-muted); max-width: 30ch; }
.footer-nap-list { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-nap-list h4 {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}
.footer-nap-list address { font-style: normal; }
.footer-nap-list a { color: var(--text-muted); transition: color var(--motion-dur); }
.footer-nap-list a:hover { color: var(--color-primary); }
.footer-links h4 {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  margin-bottom: var(--space-4);
}
.footer-links nav { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-links nav a { font-size: var(--fs-sm); color: var(--text-muted); transition: color var(--motion-dur); }
.footer-links nav a:hover { color: var(--text-body); }
.footer-bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border);
  font-size: var(--fs-xs);
  color: var(--text-muted);
  text-align: center;
}

/* ============================================================================
   STICKY CTA MOBILE
   ============================================================================ */
.mobile-cta .btn-gold, .mobile-cta .btn-outline {
  min-height: 48px;
  font-size: var(--fs-sm);
}

/* ============================================================================
   BREADCRUMB
   ============================================================================ */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-sm);
  color: var(--text-muted);
  flex-wrap: wrap;
  padding-block: var(--space-5);
}
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb__sep { color: var(--color-border); }
.breadcrumb span { color: var(--text-body); }

/* ============================================================================
   HERO PODSTRON (bez diagonal — uproszczony)
   ============================================================================ */
.page-hero {
  background: var(--color-surface);
  padding-block: clamp(48px, 7vw, 88px);
  border-bottom: 1px solid var(--color-border);
}
.page-hero h1 {
  font-size: clamp(28px, 5vw, var(--fs-3xl));
  font-weight: 800;
  color: var(--text-strong);
  margin-bottom: var(--space-3);
}
.page-hero p.lead {
  font-size: var(--fs-lg);
  color: var(--text-body);
  max-width: 48ch;
}

/* ============================================================================
   CENNIK — tabela
   ============================================================================ */
.pricing-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}
.pricing-table th, .pricing-table td {
  padding: var(--space-4) var(--space-5);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--fs-base);
  overflow-wrap: break-word;
  word-break: break-word;
}
.pricing-table th {
  background: var(--color-surface);
  color: var(--text-muted);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
}
.pricing-table td { color: var(--text-body); }
.pricing-table td:last-child {
  color: var(--color-primary);
  font-weight: 700;
  font-family: var(--font-heading);
}
.pricing-table tr:hover td { background: var(--color-surface); }
.pricing-note {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-primary);
}

/* ============================================================================
   FAQ — akordeon (na bazie fx-akordeon-faq)
   ============================================================================ */
.faq-section .fx-akordeon-faq summary {
  color: var(--text-strong);
  font-size: var(--fs-lg);
}
.faq-section .fx-akordeon-faq .fx-faq__tresc p {
  color: var(--text-body);
}

/* ============================================================================
   FORMULARZ KONTAKTOWY
   ============================================================================ */
.contact-form .field input,
.contact-form .field textarea,
.contact-form .field select {
  background: var(--color-surface);
  border-color: var(--color-border);
  color: var(--text-strong);
}
.contact-form .field input:focus,
.contact-form .field textarea:focus {
  border-color: var(--color-primary);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}
.contact-form .field label { color: var(--text-body); }
.rodo-note {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: 1.6;
  margin-top: var(--space-3);
}

/* ============================================================================
   MAPA (embed placeholder)
   ============================================================================ */
.map-embed {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  min-height: 340px;
  background: var(--color-surface);
  position: relative;
}
.map-embed iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 340px;
  border: none;
}
.map-placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--text-muted);
  font-size: var(--fs-sm);
  text-align: center;
  padding: var(--space-6);
}

/* ============================================================================
   SKIP-LINK (dostępność)
   ============================================================================ */
.skip-link {
  position: absolute;
  top: -999px;
  left: var(--space-3);
  z-index: 200;
  background: var(--color-primary);
  color: var(--text-onPrimary);
  padding: var(--space-3) var(--space-5);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  font-weight: 700;
}
.skip-link:focus { top: 0; }

/* ============================================================================
   MEDIA QUERIES — brak poziomego scrolla 390px
   ============================================================================ */
@media (max-width: 480px) {
  /* Tabele scrollowalne na wąskich */
  .pricing-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Tekst i gridy */
  .hero-cta { flex-direction: column; align-items: stretch; }
  .btn-gold, .btn-outline { justify-content: center; }
  .steps { gap: var(--space-3); }
  .step-item { padding: var(--space-4) var(--space-3); }
  /* Upewnij się że słowa łamią się */
  h1, h2, h3 { overflow-wrap: break-word; word-break: break-word; }
}

/* ============================================================================
   DODATKOWE AKCENTY NAVY+GOLD
   ============================================================================ */
/* separator sekcji — złota linia */
.section-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-primary), transparent);
  border: none;
  margin: 0;
  opacity: 0.3;
}

/* podkreślenie złote pod H2 w sekcjach "premium" */
.h2-accent {
  position: relative;
  padding-bottom: var(--space-4);
}
.h2-accent::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 48px;
  height: 3px;
  background: var(--color-primary);
  border-radius: 2px;
}
.sec-head .h2-accent::after {
  left: 50%;
  transform: translateX(-50%);
}

/* obszary obsługi — tagi */
.areas-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.area-tag {
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  color: var(--color-accent);
  border: 1px solid color-mix(in srgb, var(--color-accent) 30%, transparent);
  border-radius: var(--radius-pill);
  padding: 4px 14px;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
}

/* alternating bg sekcji */
.section--dark { background: var(--color-bg); }
.section--surface { background: var(--color-surface); }
